openvidu-admin-dashboard#
The openvidu-admin-dashboard tutorial demonstrates how to create an admin dashboard to manage the recordings of a videoconference using the OpenVidu Components Angular library.
Running this tutorial#
1. Run OpenVidu Server#
-
Download OpenVidu
-
Configure the local deployment
-
Run OpenVidu
To use a production-ready OpenVidu deployment, visit the official deployment guide.
2. Download the tutorial code#
git clone https://github.com/OpenVidu/openvidu-livekit-tutorials.git
git clone https://github.com/OpenVidu/openvidu-tutorials.git
3. Run the server application#
To run this server application, you need Node installed on your device.
- Navigate into the server directory
- Install dependencies
- Run the application
To run this server application, you need Go installed on your device.
- Navigate into the server directory
- Run the application
To run this server application, you need Ruby installed on your device.
- Navigate into the server directory
- Install dependencies
- Run the application
To run this server application, you need Java and Maven installed on your device.
- Navigate into the server directory
- Run the application
To run this server application, you need Python 3 installed on your device.
-
Navigate into the server directory
-
Create a python virtual environment
-
Activate the virtual environment
-
Install dependencies
-
Run the application
To run this server application, you need Rust installed on your device.
- Navigate into the server directory
- Run the application
To run this server application, you need PHP and Composer installed on your device.
- Navigate into the server directory
- Install dependencies
- Run the application
To run this server application, you need .NET installed on your device.
- Navigate into the server directory
- Run the application
Warning
This .NET server application needs the LIVEKIT_API_SECRET
env variable to be at least 32 characters long. Make sure to update it here and in your OpenVidu Server.
4. Run the openvidu-admin-dashboard tutorial#
To run the client application tutorial, you need Node installed on your development computer.
-
Navigate into the application client directory:
-
Install the required dependencies:
-
Serve the application:
Once the server is up and running, you can test the application by visiting http://localhost:5080
.
Accessing your application client from other devices in your local network
One advantage of running OpenVidu locally is that you can test your application client with other devices in your local network very easily without worrying about SSL certificates.
Access your application client through https://xxx-yyy-zzz-www.openvidu-local.dev:5443
, where xxx-yyy-zzz-www
part of the domain is your LAN private IP address with dashes (-) instead of dots (.). For more information, see section Accessing your app from other devices in your network.
Understanding the code#
This tutorial is an Angular project generated with Angular CLI tool. Therefore, you will see many configuration files and other components that are not the primary focus of this tutorial. We will concentrate on the following files in the src
directory:
main.ts
: This file defines the root application component. It imports theOpenViduComponentsModule
, where we configure the OpenVidu Components Angular library.app/app.component.ts
: This file defines the AppComponent, the primary and sole component of the application. It is responsible for requesting the OpenVidu token and passing it to the videoconference component, facilitating the connection to the OpenVidu Room.styles.scss
: This file defines the global styles of the application. Here, you can customize the UI of the OpenVidu Components Angular library.
To use OpenVidu Components Angular in your application, you need to install the library and import the OpenViduComponentsModule
in your Angular module. Let's see how to do this:
-
Create an Angular Project (version 17 or higher)
To begin, you will need to create a new Angular project if you haven't already. Ensure you have Node.js and the Angular CLI installed. Then, run the following command to create a new Angular project:
Replace
your-project-name
with the desired name for your project. -
Add Angular Material to your project
OpenVidu Components Angular needs Angular Material, which provides a range of UI components. To add Angular Material to your project, navigate to your project directory and run:
-
Install OpenVidu Components Angular
With your Angular project set up, it's time to add videoconferencing capabilities with OpenVidu Components Angular. Install the library using npm:
-
Import and use OpenVidu Components Angular
To use OpenVidu Components Angular in your application, you need to:
- Import the
OpenViduComponentsModule
in your Angular application. - Configure the module with the
OpenViduComponentsConfig
object. - Add the component to your template file.
- Assign the OpenVidu token and LiveKit URL to the component.
- Customize the appearance of the components using CSS variables.
- Import the
In your main.ts
application file, import the it and configure it as follows:
// Other imports ...
import { OpenViduComponentsModule, OpenViduComponentsConfig } from 'openvidu-components-angular';
const config: OpenViduComponentsConfig = {
production: true,
};
bootstrapApplication(AppComponent, {
providers: [
importProvidersFrom(
OpenViduComponentsModule.forRoot(config)
// Other imports ...
),
provideAnimations(),
],
}).catch((err) => console.error(err));
Use the ov-admin-login
component to create a login form and the ov-admin-dashboard
component to create the admin dashboard.
import { OpenViduComponentsModule } from 'openvidu-components-angular';
@Component({
selector: 'app-root',
template:`
@if (logged) {
<ov-admin-dashboard
[recordingsList]="recordings()"
(onLogoutRequested)="onLogoutRequested()"
(onRefreshRecordingsRequested)="onRefreshRecordingsRequested()"
(onLoadMoreRecordingsRequested)="onLoadMoreRecordingsRequested()"
(onRecordingDeleteRequested)="onRecordingDeleteRequested($event)"
></ov-admin-dashboard>
} @else {
<ov-admin-login (onLoginRequested)="onLoginRequested($event)">
</ov-admin-login>
}
`,
styles: [''],
standalone: true,
imports: [OpenViduComponentsModule],
})
export class AppComponent {
roomName = 'openvidu-admin-dashboard'; // (1)!
logged: boolean = false; // (2)!
// Recordings list to show in the dashboard
// This is a dummy list, you should replace it with your own list from the server
recordings: WritableSignal<RecordingInfo[]> = signal([ // (3)!
{
id: 'recording1',
roomName: this.roomName,
roomId: 'roomId1',
outputMode: RecordingOutputMode.COMPOSED,
status: RecordingStatus.READY,
filename: 'sampleRecording.mp4',
startedAt: new Date().getTime(),
endedAt: new Date().getTime(),
duration: 0,
size: 100,
location: 'http://localhost:8080/recordings/recording1',
}
]);
constructor() {}
onLoginRequested(credentials: { username: string; password: string }) { // (4)!
console.log(`Login button clicked ${credentials}`);
/**
* WARNING! This code is developed for didactic purposes only.
* The authentication process should be done in the server side.
**/
this.logged = true;
}
onLogoutRequested() { // (5)!
console.log('Logout button clicked');
/**
* WARNING! This code is developed for didactic purposes only.
* The authentication process should be done in the server side.
**/
this.logged = false;
}
onRefreshRecordingsRequested() { // (6)!
console.log('Refresh recording clicked');
/**
* WARNING! This code is developed for didactic purposes only.
* The authentication process should be done in the server side.
**/
// Getting the recordings from the server
this.recordings.update(() => [
{
id: 'recording1',
roomName: this.title,
roomId: 'roomId1',
outputMode: RecordingOutputMode.COMPOSED,
status: RecordingStatus.READY,
filename: 'sampleRecording1.mp4',
startedAt: new Date().getTime(),
endedAt: new Date().getTime(),
duration: 0,
size: 100,
location: 'http://localhost:8080/recordings/recording1',
},
]);
}
onLoadMoreRecordingsRequested() { // (7)!
console.log('Load more recordings clicked');
}
onRecordingDeleteRequested(recording: RecordingDeleteRequestedEvent) { // (8)!
console.log(`Delete recording clicked ${recording.recordingId}`);
/**
* WARNING! This code is developed for didactic purposes only.
* The authentication process should be done in the server side.
**/
// Deleting the recording from the server
this.recordings.update((recordings) =>
recordings.filter((rec) => rec.id !== recording.recordingId)
);
console.log(this.recordings());
}
}
roomName
: OpenVidu Room name.logged
: Boolean that indicates if the user is logged in.recordings
: Dummy list of recordings to show in the dashboard. You should replace it with your own list from the server from the server.onLoginRequested
method that fires when the login button is clicked.onLogoutRequested
method that fires when the logout button is clicked.onRefreshRecordingsRequested
method that fires when the refresh recordings button is clicked.onLoadMoreRecordingsRequested
method that fires when the load more recordings button is clicked.onRecordingDeleteRequested
method that fires when the delete recording button is clicked.
The app.component.ts
file declares the following properties and methods:
roomName
: OpenVidu Room name.logged
: Boolean that indicates if the user is logged in.recordings
: Dummy list of recordings to show in the dashboard. You should replace it with your own list from the server from the server.onLoginRequested
method that fires when the login button is clicked.onLogoutRequested
method that fires when the logout button is clicked.onRefreshRecordingsRequested
method that fires when the refresh recordings button is clicked.onLoadMoreRecordingsRequested
method that fires when the load more recordings button is clicked.onRecordingDeleteRequested
method that fires when the delete recording button is clicked.
Configure the URLs
For local development, leave APPLICATION_SERVER_URL
and LIVEKIT_URL
variables empty. The function configureUrls()
will automatically configure them with default values. However, for production, you should configure these variables with the correct URLs depending on your deployment.
The OpenVidu Components Angular library provides a set of CSS variables that you can use to customize the appearance of the components. You can define these variables in your application's global styles file (e.g. styles.scss
).
:root {
--ov-primary-color: #303030; /* Primary interface color */
--ov-secondary-color: #3e3f3f; /* Secondary interface color */
--ov-tertiary-color: #598eff; /* Tertiary accent color for elements */
--ov-warn-color: #eb5144; /* Warning color for alerts and notifications */
--ov-light-color: #e6e6e6; /* Light color for elements */
--ov-accent-color: #ffae35; /* Accent color for standout UI elements */
--ov-logo-background-color: #3a3d3d; /* Background color for the logo area */
--ov-text-color: #ffffff; /* Default text color */
--ov-panel-text-color: #1d1d1d; /* Text color for panel elements */
--ov-panel-background: #ffffff; /* Background color for panels */
--ov-buttons-radius: 50%; /* Border-radius for circular buttons */
--ov-leave-button-radius: 10px; /* Border-radius for the leave button */
--ov-video-radius: 5px; /* Border-radius for video elements */
--ov-panel-radius: 5px; /* Border-radius for panel elements */
}