Angular Openvidu as a child componnnt









up vote
0
down vote

favorite












Openvidu library angular
The library configured for the root component. But I want to add the same as a child component. The following sample code is working fine and open vidu component is called and rendered on root URL.
I don't have any Idea of angular development.



open-vidu.component.html






<div *ngIf="!session" id="join">
<div id="join-dialog">
<h1>Join a video session</h1>
<form (submit)="joinSession()">
<p>
<label>Participant </label>
<input type="text" id="userName" name="userName" [(ngModel)]="myUserName" required>
</p>
<p>
<label>Session </label>
<input type="text" id="sessionId" name="sessionId" [(ngModel)]="mySessionId" required>
</p>
<p class="text-center">
<input type="submit" name="commit" value="Join!">
</p>
</form>
</div>
</div>

<div *ngIf="session" id="session">
<opv-session [sessionName]="mySessionId" [user]="myUserName" [token]="token" (leaveSession)="handlerLeaveSessionEvent($event)"
(joinSession)="handlerJoinSessionEvent($event)" (error)="handlerErrorEvent($event)">
</opv-session>
</div>




open-vidu.component.ts

import Component, OnInit from '@angular/core';
import throwError as observableThrowError from 'rxjs';
import catchError from 'rxjs/operators';
import HttpClient, HttpHeaders from '@angular/common/http';
@Component(
selector: 'app-open-vidu',
templateUrl: './open-vidu.component.html',
styleUrls: ['./open-vidu.component.scss']
)
export class OpenViduComponent implements OnInit
OPENVIDU_SERVER_URL = 'https://' + location.hostname + ':4443';
OPENVIDU_SERVER_SECRET = 'MY_SECRET';

// Join form
mySessionId = 'SessionA';
myUserName = 'Participant' + Math.floor(Math.random() * 100);
token: string;
session = false;

constructor(private httpClient: HttpClient)

joinSession()
this.getToken().then((token) =>
this.token = token;
this.session = true;
);


handlerJoinSessionEvent(event): void
// Do something


handlerLeaveSessionEvent(event): void
this.session = false;


handlerErrorEvent(event): void
// Do something


/**
* --------------------------
* SERVER-SIDE RESPONSIBILITY
* --------------------------
* This method retrieve the mandatory user token from OpenVidu Server,
* in this case making use Angular http API.
* This behavior MUST BE IN YOUR SERVER-SIDE IN PRODUCTION. In this case:
* 1) Initialize a session in OpenVidu Server (POST /api/sessions)
* 2) Generate a token in OpenVidu Server (POST /api/tokens)
* 3) The token must be consumed in Session.connect() method of OpenVidu Browser
*/

getToken(): Promise<string>
return this.createSession(this.mySessionId).then((sessionId) =>
return this.createToken(sessionId);
);


createSession(sessionId)
return new Promise((resolve, reject) =>
const body = JSON.stringify( customSessionId: sessionId );
const options =
headers: new HttpHeaders(
Authorization: 'Basic ' + btoa('OPENVIDUAPP:' + this.OPENVIDU_SERVER_SECRET),
'Content-Type': 'application/json',
),
;
return this.httpClient
.post(this.OPENVIDU_SERVER_URL + '/api/sessions', body, options)
.pipe(
catchError((error) =>
if (error.status === 409)
resolve(sessionId);
else
console.warn('No connection to OpenVidu Server. This may be a certificate error at ' + this.OPENVIDU_SERVER_URL);
if (
window.confirm(
'No connection to OpenVidu Server. This may be a certificate error at "' +
this.OPENVIDU_SERVER_URL +
'"nnClick OK to navigate and accept it. If no certificate warning is shown, then check that your OpenVidu Server' +
'is up and running at "' +
this.OPENVIDU_SERVER_URL +
'"',
)
)
location.assign(this.OPENVIDU_SERVER_URL + '/accept-certificate');


return observableThrowError(error);
),
)
.subscribe((response) =>
console.log(response);
resolve(response['id']);
);
);


createToken(sessionId): Promise<string>
return new Promise((resolve, reject) =>
const body = JSON.stringify( session: sessionId );
const options =
headers: new HttpHeaders(
Authorization: 'Basic ' + btoa('OPENVIDUAPP:' + this.OPENVIDU_SERVER_SECRET),
'Content-Type': 'application/json',
),
;
return this.httpClient
.post(this.OPENVIDU_SERVER_URL + '/api/tokens', body, options)
.pipe(
catchError((error) =>
reject(error);
return observableThrowError(error);
),
)
.subscribe((response) =>
console.log(response);
resolve(response['token']);
);
);


ngOnInit()





open-vidu.routing.ts



import Routes from '@angular/router';
import OpenViduComponent from './open-vidu.component';


export const OpenViduRoutes: Routes = [

path: '',
component: OpenViduComponent

];


open-vidu.module.ts



import NgModule from '@angular/core';
import RouterModule from '@angular/router';
import CommonModule from '@angular/common';
import FormsModule from '@angular/forms';
import OpenViduComponent from './open-vidu.component';
import OpenViduRoutes from './open-vidu.routing';

import OpenviduSessionModule from 'openvidu-angular';

@NgModule(
imports: [
CommonModule,
RouterModule.forChild(OpenViduRoutes),
FormsModule,
OpenviduSessionModule
],
declarations: [OpenViduComponent],
exports: [
OpenViduComponent
]
)
export class OpenViduModule


app.module.ts



...
import OpenViduModule from './open-vidu/open-vidu.module';
@NgModule(
imports: [
CommonModule,
BrowserAnimationsModule,
FormsModule,
RouterModule.forRoot(AppRoutes),
HttpModule,
MaterialModule,
MatNativeDateModule,
SidebarModule,
NavbarModule,
FooterModule,
FixedpluginModule,
HttpClientModule,
OpenViduModule
],
declarations: [
AppComponent,
AdminLayoutComponent,
AuthLayoutComponent
],
providers: [TwilioService, ChatService],
bootstrap: [ AppComponent ]
)
export class AppModule


I have tried to comment the openvidu component from app.module.ts and import it in a child component but it not worked and throws following error all the time.
Error: RouterModule.forRoot() called twice.
Please suggest me what I am doing wrong in the code.
The child module code is following:



tutor.module.ts



...
import OpenViduModule from '../open-vidu/open-vidu.module';
@NgModule(
imports: [
...,
OpenViduModule
],
providers: [TutorService],
declarations: [
AddTutorComponent,
ListTutorComponent,
EditTutorComponent,
AllocateTutorComponent
]
)

export class Tutor









share|improve this question





















  • It would be great if you could share a Sample StackBlitz replicating the exact issue that you have.
    – SiddAjmera
    2 days ago










  • Hello @SiddAjmera, Please have a look at StackBlitz Project: stackblitz.com/edit/sample-project-xtmqxq?embed=1 On the following project, you will get an open-vidu component on the landing page but I want the same functionality on my specific URL like <SiteURL>/open-vidu, not on the landing page. Please help.
    – me2
    21 hours ago










  • how come you have an Angular 7n project but still with a .angular-cli.json file when you should have had an angular.json file?
    – SiddAjmera
    19 hours ago














up vote
0
down vote

favorite












Openvidu library angular
The library configured for the root component. But I want to add the same as a child component. The following sample code is working fine and open vidu component is called and rendered on root URL.
I don't have any Idea of angular development.



open-vidu.component.html






<div *ngIf="!session" id="join">
<div id="join-dialog">
<h1>Join a video session</h1>
<form (submit)="joinSession()">
<p>
<label>Participant </label>
<input type="text" id="userName" name="userName" [(ngModel)]="myUserName" required>
</p>
<p>
<label>Session </label>
<input type="text" id="sessionId" name="sessionId" [(ngModel)]="mySessionId" required>
</p>
<p class="text-center">
<input type="submit" name="commit" value="Join!">
</p>
</form>
</div>
</div>

<div *ngIf="session" id="session">
<opv-session [sessionName]="mySessionId" [user]="myUserName" [token]="token" (leaveSession)="handlerLeaveSessionEvent($event)"
(joinSession)="handlerJoinSessionEvent($event)" (error)="handlerErrorEvent($event)">
</opv-session>
</div>




open-vidu.component.ts

import Component, OnInit from '@angular/core';
import throwError as observableThrowError from 'rxjs';
import catchError from 'rxjs/operators';
import HttpClient, HttpHeaders from '@angular/common/http';
@Component(
selector: 'app-open-vidu',
templateUrl: './open-vidu.component.html',
styleUrls: ['./open-vidu.component.scss']
)
export class OpenViduComponent implements OnInit
OPENVIDU_SERVER_URL = 'https://' + location.hostname + ':4443';
OPENVIDU_SERVER_SECRET = 'MY_SECRET';

// Join form
mySessionId = 'SessionA';
myUserName = 'Participant' + Math.floor(Math.random() * 100);
token: string;
session = false;

constructor(private httpClient: HttpClient)

joinSession()
this.getToken().then((token) =>
this.token = token;
this.session = true;
);


handlerJoinSessionEvent(event): void
// Do something


handlerLeaveSessionEvent(event): void
this.session = false;


handlerErrorEvent(event): void
// Do something


/**
* --------------------------
* SERVER-SIDE RESPONSIBILITY
* --------------------------
* This method retrieve the mandatory user token from OpenVidu Server,
* in this case making use Angular http API.
* This behavior MUST BE IN YOUR SERVER-SIDE IN PRODUCTION. In this case:
* 1) Initialize a session in OpenVidu Server (POST /api/sessions)
* 2) Generate a token in OpenVidu Server (POST /api/tokens)
* 3) The token must be consumed in Session.connect() method of OpenVidu Browser
*/

getToken(): Promise<string>
return this.createSession(this.mySessionId).then((sessionId) =>
return this.createToken(sessionId);
);


createSession(sessionId)
return new Promise((resolve, reject) =>
const body = JSON.stringify( customSessionId: sessionId );
const options =
headers: new HttpHeaders(
Authorization: 'Basic ' + btoa('OPENVIDUAPP:' + this.OPENVIDU_SERVER_SECRET),
'Content-Type': 'application/json',
),
;
return this.httpClient
.post(this.OPENVIDU_SERVER_URL + '/api/sessions', body, options)
.pipe(
catchError((error) =>
if (error.status === 409)
resolve(sessionId);
else
console.warn('No connection to OpenVidu Server. This may be a certificate error at ' + this.OPENVIDU_SERVER_URL);
if (
window.confirm(
'No connection to OpenVidu Server. This may be a certificate error at "' +
this.OPENVIDU_SERVER_URL +
'"nnClick OK to navigate and accept it. If no certificate warning is shown, then check that your OpenVidu Server' +
'is up and running at "' +
this.OPENVIDU_SERVER_URL +
'"',
)
)
location.assign(this.OPENVIDU_SERVER_URL + '/accept-certificate');


return observableThrowError(error);
),
)
.subscribe((response) =>
console.log(response);
resolve(response['id']);
);
);


createToken(sessionId): Promise<string>
return new Promise((resolve, reject) =>
const body = JSON.stringify( session: sessionId );
const options =
headers: new HttpHeaders(
Authorization: 'Basic ' + btoa('OPENVIDUAPP:' + this.OPENVIDU_SERVER_SECRET),
'Content-Type': 'application/json',
),
;
return this.httpClient
.post(this.OPENVIDU_SERVER_URL + '/api/tokens', body, options)
.pipe(
catchError((error) =>
reject(error);
return observableThrowError(error);
),
)
.subscribe((response) =>
console.log(response);
resolve(response['token']);
);
);


ngOnInit()





open-vidu.routing.ts



import Routes from '@angular/router';
import OpenViduComponent from './open-vidu.component';


export const OpenViduRoutes: Routes = [

path: '',
component: OpenViduComponent

];


open-vidu.module.ts



import NgModule from '@angular/core';
import RouterModule from '@angular/router';
import CommonModule from '@angular/common';
import FormsModule from '@angular/forms';
import OpenViduComponent from './open-vidu.component';
import OpenViduRoutes from './open-vidu.routing';

import OpenviduSessionModule from 'openvidu-angular';

@NgModule(
imports: [
CommonModule,
RouterModule.forChild(OpenViduRoutes),
FormsModule,
OpenviduSessionModule
],
declarations: [OpenViduComponent],
exports: [
OpenViduComponent
]
)
export class OpenViduModule


app.module.ts



...
import OpenViduModule from './open-vidu/open-vidu.module';
@NgModule(
imports: [
CommonModule,
BrowserAnimationsModule,
FormsModule,
RouterModule.forRoot(AppRoutes),
HttpModule,
MaterialModule,
MatNativeDateModule,
SidebarModule,
NavbarModule,
FooterModule,
FixedpluginModule,
HttpClientModule,
OpenViduModule
],
declarations: [
AppComponent,
AdminLayoutComponent,
AuthLayoutComponent
],
providers: [TwilioService, ChatService],
bootstrap: [ AppComponent ]
)
export class AppModule


I have tried to comment the openvidu component from app.module.ts and import it in a child component but it not worked and throws following error all the time.
Error: RouterModule.forRoot() called twice.
Please suggest me what I am doing wrong in the code.
The child module code is following:



tutor.module.ts



...
import OpenViduModule from '../open-vidu/open-vidu.module';
@NgModule(
imports: [
...,
OpenViduModule
],
providers: [TutorService],
declarations: [
AddTutorComponent,
ListTutorComponent,
EditTutorComponent,
AllocateTutorComponent
]
)

export class Tutor









share|improve this question





















  • It would be great if you could share a Sample StackBlitz replicating the exact issue that you have.
    – SiddAjmera
    2 days ago










  • Hello @SiddAjmera, Please have a look at StackBlitz Project: stackblitz.com/edit/sample-project-xtmqxq?embed=1 On the following project, you will get an open-vidu component on the landing page but I want the same functionality on my specific URL like <SiteURL>/open-vidu, not on the landing page. Please help.
    – me2
    21 hours ago










  • how come you have an Angular 7n project but still with a .angular-cli.json file when you should have had an angular.json file?
    – SiddAjmera
    19 hours ago












up vote
0
down vote

favorite









up vote
0
down vote

favorite











Openvidu library angular
The library configured for the root component. But I want to add the same as a child component. The following sample code is working fine and open vidu component is called and rendered on root URL.
I don't have any Idea of angular development.



open-vidu.component.html






<div *ngIf="!session" id="join">
<div id="join-dialog">
<h1>Join a video session</h1>
<form (submit)="joinSession()">
<p>
<label>Participant </label>
<input type="text" id="userName" name="userName" [(ngModel)]="myUserName" required>
</p>
<p>
<label>Session </label>
<input type="text" id="sessionId" name="sessionId" [(ngModel)]="mySessionId" required>
</p>
<p class="text-center">
<input type="submit" name="commit" value="Join!">
</p>
</form>
</div>
</div>

<div *ngIf="session" id="session">
<opv-session [sessionName]="mySessionId" [user]="myUserName" [token]="token" (leaveSession)="handlerLeaveSessionEvent($event)"
(joinSession)="handlerJoinSessionEvent($event)" (error)="handlerErrorEvent($event)">
</opv-session>
</div>




open-vidu.component.ts

import Component, OnInit from '@angular/core';
import throwError as observableThrowError from 'rxjs';
import catchError from 'rxjs/operators';
import HttpClient, HttpHeaders from '@angular/common/http';
@Component(
selector: 'app-open-vidu',
templateUrl: './open-vidu.component.html',
styleUrls: ['./open-vidu.component.scss']
)
export class OpenViduComponent implements OnInit
OPENVIDU_SERVER_URL = 'https://' + location.hostname + ':4443';
OPENVIDU_SERVER_SECRET = 'MY_SECRET';

// Join form
mySessionId = 'SessionA';
myUserName = 'Participant' + Math.floor(Math.random() * 100);
token: string;
session = false;

constructor(private httpClient: HttpClient)

joinSession()
this.getToken().then((token) =>
this.token = token;
this.session = true;
);


handlerJoinSessionEvent(event): void
// Do something


handlerLeaveSessionEvent(event): void
this.session = false;


handlerErrorEvent(event): void
// Do something


/**
* --------------------------
* SERVER-SIDE RESPONSIBILITY
* --------------------------
* This method retrieve the mandatory user token from OpenVidu Server,
* in this case making use Angular http API.
* This behavior MUST BE IN YOUR SERVER-SIDE IN PRODUCTION. In this case:
* 1) Initialize a session in OpenVidu Server (POST /api/sessions)
* 2) Generate a token in OpenVidu Server (POST /api/tokens)
* 3) The token must be consumed in Session.connect() method of OpenVidu Browser
*/

getToken(): Promise<string>
return this.createSession(this.mySessionId).then((sessionId) =>
return this.createToken(sessionId);
);


createSession(sessionId)
return new Promise((resolve, reject) =>
const body = JSON.stringify( customSessionId: sessionId );
const options =
headers: new HttpHeaders(
Authorization: 'Basic ' + btoa('OPENVIDUAPP:' + this.OPENVIDU_SERVER_SECRET),
'Content-Type': 'application/json',
),
;
return this.httpClient
.post(this.OPENVIDU_SERVER_URL + '/api/sessions', body, options)
.pipe(
catchError((error) =>
if (error.status === 409)
resolve(sessionId);
else
console.warn('No connection to OpenVidu Server. This may be a certificate error at ' + this.OPENVIDU_SERVER_URL);
if (
window.confirm(
'No connection to OpenVidu Server. This may be a certificate error at "' +
this.OPENVIDU_SERVER_URL +
'"nnClick OK to navigate and accept it. If no certificate warning is shown, then check that your OpenVidu Server' +
'is up and running at "' +
this.OPENVIDU_SERVER_URL +
'"',
)
)
location.assign(this.OPENVIDU_SERVER_URL + '/accept-certificate');


return observableThrowError(error);
),
)
.subscribe((response) =>
console.log(response);
resolve(response['id']);
);
);


createToken(sessionId): Promise<string>
return new Promise((resolve, reject) =>
const body = JSON.stringify( session: sessionId );
const options =
headers: new HttpHeaders(
Authorization: 'Basic ' + btoa('OPENVIDUAPP:' + this.OPENVIDU_SERVER_SECRET),
'Content-Type': 'application/json',
),
;
return this.httpClient
.post(this.OPENVIDU_SERVER_URL + '/api/tokens', body, options)
.pipe(
catchError((error) =>
reject(error);
return observableThrowError(error);
),
)
.subscribe((response) =>
console.log(response);
resolve(response['token']);
);
);


ngOnInit()





open-vidu.routing.ts



import Routes from '@angular/router';
import OpenViduComponent from './open-vidu.component';


export const OpenViduRoutes: Routes = [

path: '',
component: OpenViduComponent

];


open-vidu.module.ts



import NgModule from '@angular/core';
import RouterModule from '@angular/router';
import CommonModule from '@angular/common';
import FormsModule from '@angular/forms';
import OpenViduComponent from './open-vidu.component';
import OpenViduRoutes from './open-vidu.routing';

import OpenviduSessionModule from 'openvidu-angular';

@NgModule(
imports: [
CommonModule,
RouterModule.forChild(OpenViduRoutes),
FormsModule,
OpenviduSessionModule
],
declarations: [OpenViduComponent],
exports: [
OpenViduComponent
]
)
export class OpenViduModule


app.module.ts



...
import OpenViduModule from './open-vidu/open-vidu.module';
@NgModule(
imports: [
CommonModule,
BrowserAnimationsModule,
FormsModule,
RouterModule.forRoot(AppRoutes),
HttpModule,
MaterialModule,
MatNativeDateModule,
SidebarModule,
NavbarModule,
FooterModule,
FixedpluginModule,
HttpClientModule,
OpenViduModule
],
declarations: [
AppComponent,
AdminLayoutComponent,
AuthLayoutComponent
],
providers: [TwilioService, ChatService],
bootstrap: [ AppComponent ]
)
export class AppModule


I have tried to comment the openvidu component from app.module.ts and import it in a child component but it not worked and throws following error all the time.
Error: RouterModule.forRoot() called twice.
Please suggest me what I am doing wrong in the code.
The child module code is following:



tutor.module.ts



...
import OpenViduModule from '../open-vidu/open-vidu.module';
@NgModule(
imports: [
...,
OpenViduModule
],
providers: [TutorService],
declarations: [
AddTutorComponent,
ListTutorComponent,
EditTutorComponent,
AllocateTutorComponent
]
)

export class Tutor









share|improve this question













Openvidu library angular
The library configured for the root component. But I want to add the same as a child component. The following sample code is working fine and open vidu component is called and rendered on root URL.
I don't have any Idea of angular development.



open-vidu.component.html






<div *ngIf="!session" id="join">
<div id="join-dialog">
<h1>Join a video session</h1>
<form (submit)="joinSession()">
<p>
<label>Participant </label>
<input type="text" id="userName" name="userName" [(ngModel)]="myUserName" required>
</p>
<p>
<label>Session </label>
<input type="text" id="sessionId" name="sessionId" [(ngModel)]="mySessionId" required>
</p>
<p class="text-center">
<input type="submit" name="commit" value="Join!">
</p>
</form>
</div>
</div>

<div *ngIf="session" id="session">
<opv-session [sessionName]="mySessionId" [user]="myUserName" [token]="token" (leaveSession)="handlerLeaveSessionEvent($event)"
(joinSession)="handlerJoinSessionEvent($event)" (error)="handlerErrorEvent($event)">
</opv-session>
</div>




open-vidu.component.ts

import Component, OnInit from '@angular/core';
import throwError as observableThrowError from 'rxjs';
import catchError from 'rxjs/operators';
import HttpClient, HttpHeaders from '@angular/common/http';
@Component(
selector: 'app-open-vidu',
templateUrl: './open-vidu.component.html',
styleUrls: ['./open-vidu.component.scss']
)
export class OpenViduComponent implements OnInit
OPENVIDU_SERVER_URL = 'https://' + location.hostname + ':4443';
OPENVIDU_SERVER_SECRET = 'MY_SECRET';

// Join form
mySessionId = 'SessionA';
myUserName = 'Participant' + Math.floor(Math.random() * 100);
token: string;
session = false;

constructor(private httpClient: HttpClient)

joinSession()
this.getToken().then((token) =>
this.token = token;
this.session = true;
);


handlerJoinSessionEvent(event): void
// Do something


handlerLeaveSessionEvent(event): void
this.session = false;


handlerErrorEvent(event): void
// Do something


/**
* --------------------------
* SERVER-SIDE RESPONSIBILITY
* --------------------------
* This method retrieve the mandatory user token from OpenVidu Server,
* in this case making use Angular http API.
* This behavior MUST BE IN YOUR SERVER-SIDE IN PRODUCTION. In this case:
* 1) Initialize a session in OpenVidu Server (POST /api/sessions)
* 2) Generate a token in OpenVidu Server (POST /api/tokens)
* 3) The token must be consumed in Session.connect() method of OpenVidu Browser
*/

getToken(): Promise<string>
return this.createSession(this.mySessionId).then((sessionId) =>
return this.createToken(sessionId);
);


createSession(sessionId)
return new Promise((resolve, reject) =>
const body = JSON.stringify( customSessionId: sessionId );
const options =
headers: new HttpHeaders(
Authorization: 'Basic ' + btoa('OPENVIDUAPP:' + this.OPENVIDU_SERVER_SECRET),
'Content-Type': 'application/json',
),
;
return this.httpClient
.post(this.OPENVIDU_SERVER_URL + '/api/sessions', body, options)
.pipe(
catchError((error) =>
if (error.status === 409)
resolve(sessionId);
else
console.warn('No connection to OpenVidu Server. This may be a certificate error at ' + this.OPENVIDU_SERVER_URL);
if (
window.confirm(
'No connection to OpenVidu Server. This may be a certificate error at "' +
this.OPENVIDU_SERVER_URL +
'"nnClick OK to navigate and accept it. If no certificate warning is shown, then check that your OpenVidu Server' +
'is up and running at "' +
this.OPENVIDU_SERVER_URL +
'"',
)
)
location.assign(this.OPENVIDU_SERVER_URL + '/accept-certificate');


return observableThrowError(error);
),
)
.subscribe((response) =>
console.log(response);
resolve(response['id']);
);
);


createToken(sessionId): Promise<string>
return new Promise((resolve, reject) =>
const body = JSON.stringify( session: sessionId );
const options =
headers: new HttpHeaders(
Authorization: 'Basic ' + btoa('OPENVIDUAPP:' + this.OPENVIDU_SERVER_SECRET),
'Content-Type': 'application/json',
),
;
return this.httpClient
.post(this.OPENVIDU_SERVER_URL + '/api/tokens', body, options)
.pipe(
catchError((error) =>
reject(error);
return observableThrowError(error);
),
)
.subscribe((response) =>
console.log(response);
resolve(response['token']);
);
);


ngOnInit()





open-vidu.routing.ts



import Routes from '@angular/router';
import OpenViduComponent from './open-vidu.component';


export const OpenViduRoutes: Routes = [

path: '',
component: OpenViduComponent

];


open-vidu.module.ts



import NgModule from '@angular/core';
import RouterModule from '@angular/router';
import CommonModule from '@angular/common';
import FormsModule from '@angular/forms';
import OpenViduComponent from './open-vidu.component';
import OpenViduRoutes from './open-vidu.routing';

import OpenviduSessionModule from 'openvidu-angular';

@NgModule(
imports: [
CommonModule,
RouterModule.forChild(OpenViduRoutes),
FormsModule,
OpenviduSessionModule
],
declarations: [OpenViduComponent],
exports: [
OpenViduComponent
]
)
export class OpenViduModule


app.module.ts



...
import OpenViduModule from './open-vidu/open-vidu.module';
@NgModule(
imports: [
CommonModule,
BrowserAnimationsModule,
FormsModule,
RouterModule.forRoot(AppRoutes),
HttpModule,
MaterialModule,
MatNativeDateModule,
SidebarModule,
NavbarModule,
FooterModule,
FixedpluginModule,
HttpClientModule,
OpenViduModule
],
declarations: [
AppComponent,
AdminLayoutComponent,
AuthLayoutComponent
],
providers: [TwilioService, ChatService],
bootstrap: [ AppComponent ]
)
export class AppModule


I have tried to comment the openvidu component from app.module.ts and import it in a child component but it not worked and throws following error all the time.
Error: RouterModule.forRoot() called twice.
Please suggest me what I am doing wrong in the code.
The child module code is following:



tutor.module.ts



...
import OpenViduModule from '../open-vidu/open-vidu.module';
@NgModule(
imports: [
...,
OpenViduModule
],
providers: [TutorService],
declarations: [
AddTutorComponent,
ListTutorComponent,
EditTutorComponent,
AllocateTutorComponent
]
)

export class Tutor





<div *ngIf="!session" id="join">
<div id="join-dialog">
<h1>Join a video session</h1>
<form (submit)="joinSession()">
<p>
<label>Participant </label>
<input type="text" id="userName" name="userName" [(ngModel)]="myUserName" required>
</p>
<p>
<label>Session </label>
<input type="text" id="sessionId" name="sessionId" [(ngModel)]="mySessionId" required>
</p>
<p class="text-center">
<input type="submit" name="commit" value="Join!">
</p>
</form>
</div>
</div>

<div *ngIf="session" id="session">
<opv-session [sessionName]="mySessionId" [user]="myUserName" [token]="token" (leaveSession)="handlerLeaveSessionEvent($event)"
(joinSession)="handlerJoinSessionEvent($event)" (error)="handlerErrorEvent($event)">
</opv-session>
</div>





<div *ngIf="!session" id="join">
<div id="join-dialog">
<h1>Join a video session</h1>
<form (submit)="joinSession()">
<p>
<label>Participant </label>
<input type="text" id="userName" name="userName" [(ngModel)]="myUserName" required>
</p>
<p>
<label>Session </label>
<input type="text" id="sessionId" name="sessionId" [(ngModel)]="mySessionId" required>
</p>
<p class="text-center">
<input type="submit" name="commit" value="Join!">
</p>
</form>
</div>
</div>

<div *ngIf="session" id="session">
<opv-session [sessionName]="mySessionId" [user]="myUserName" [token]="token" (leaveSession)="handlerLeaveSessionEvent($event)"
(joinSession)="handlerJoinSessionEvent($event)" (error)="handlerErrorEvent($event)">
</opv-session>
</div>






angular






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked 2 days ago









me2

1




1











  • It would be great if you could share a Sample StackBlitz replicating the exact issue that you have.
    – SiddAjmera
    2 days ago










  • Hello @SiddAjmera, Please have a look at StackBlitz Project: stackblitz.com/edit/sample-project-xtmqxq?embed=1 On the following project, you will get an open-vidu component on the landing page but I want the same functionality on my specific URL like <SiteURL>/open-vidu, not on the landing page. Please help.
    – me2
    21 hours ago










  • how come you have an Angular 7n project but still with a .angular-cli.json file when you should have had an angular.json file?
    – SiddAjmera
    19 hours ago
















  • It would be great if you could share a Sample StackBlitz replicating the exact issue that you have.
    – SiddAjmera
    2 days ago










  • Hello @SiddAjmera, Please have a look at StackBlitz Project: stackblitz.com/edit/sample-project-xtmqxq?embed=1 On the following project, you will get an open-vidu component on the landing page but I want the same functionality on my specific URL like <SiteURL>/open-vidu, not on the landing page. Please help.
    – me2
    21 hours ago










  • how come you have an Angular 7n project but still with a .angular-cli.json file when you should have had an angular.json file?
    – SiddAjmera
    19 hours ago















It would be great if you could share a Sample StackBlitz replicating the exact issue that you have.
– SiddAjmera
2 days ago




It would be great if you could share a Sample StackBlitz replicating the exact issue that you have.
– SiddAjmera
2 days ago












Hello @SiddAjmera, Please have a look at StackBlitz Project: stackblitz.com/edit/sample-project-xtmqxq?embed=1 On the following project, you will get an open-vidu component on the landing page but I want the same functionality on my specific URL like <SiteURL>/open-vidu, not on the landing page. Please help.
– me2
21 hours ago




Hello @SiddAjmera, Please have a look at StackBlitz Project: stackblitz.com/edit/sample-project-xtmqxq?embed=1 On the following project, you will get an open-vidu component on the landing page but I want the same functionality on my specific URL like <SiteURL>/open-vidu, not on the landing page. Please help.
– me2
21 hours ago












how come you have an Angular 7n project but still with a .angular-cli.json file when you should have had an angular.json file?
– SiddAjmera
19 hours ago




how come you have an Angular 7n project but still with a .angular-cli.json file when you should have had an angular.json file?
– SiddAjmera
19 hours ago

















active

oldest

votes











Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













 

draft saved


draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53237840%2fangular-openvidu-as-a-child-componnnt%23new-answer', 'question_page');

);

Post as a guest



































active

oldest

votes













active

oldest

votes









active

oldest

votes






active

oldest

votes















 

draft saved


draft discarded















































 


draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53237840%2fangular-openvidu-as-a-child-componnnt%23new-answer', 'question_page');

);

Post as a guest














































































這個網誌中的熱門文章

How to read a connectionString WITH PROVIDER in .NET Core?

Node.js Script on GitHub Pages or Amazon S3

Museum of Modern and Contemporary Art of Trento and Rovereto