diff --git a/openvidu-components-angular/projects/openvidu-components-angular/src/lib/components/toolbar/toolbar.component.html b/openvidu-components-angular/projects/openvidu-components-angular/src/lib/components/toolbar/toolbar.component.html index 44e8cae4..6d639552 100644 --- a/openvidu-components-angular/projects/openvidu-components-angular/src/lib/components/toolbar/toolbar.component.html +++ b/openvidu-components-angular/projects/openvidu-components-angular/src/lib/components/toolbar/toolbar.component.html @@ -4,7 +4,7 @@
- +
{ + this.brandingLogo = value; + this.cd.markForCheck(); + }); this.screenshareButtonSub = this.libService.screenshareButton$.subscribe((value: boolean) => { this.showScreenshareButton = value && !this.platformService.isMobile(); this.cd.markForCheck(); @@ -747,6 +758,7 @@ export class ToolbarComponent implements OnInit, OnDestroy, AfterViewInit { this.showLogo = value; this.cd.markForCheck(); }); + this.displayRoomNameSub = this.libService.displayRoomName$.subscribe((value: boolean) => { this.showSessionName = value; this.cd.markForCheck(); diff --git a/openvidu-components-angular/projects/openvidu-components-angular/src/lib/directives/api/api.directive.module.ts b/openvidu-components-angular/projects/openvidu-components-angular/src/lib/directives/api/api.directive.module.ts index f87c0a08..80999ad0 100644 --- a/openvidu-components-angular/projects/openvidu-components-angular/src/lib/directives/api/api.directive.module.ts +++ b/openvidu-components-angular/projects/openvidu-components-angular/src/lib/directives/api/api.directive.module.ts @@ -1,7 +1,7 @@ import { NgModule } from '@angular/core'; import { ActivitiesPanelBroadcastingActivityDirective, ActivitiesPanelRecordingActivityDirective } from './activities-panel.directive'; import { AdminLoginErrorDirective, AdminDashboardRecordingsListDirective, AdminLoginTitleDirective, AdminDashboardTitleDirective } from './admin.directive'; -import { LayoutRemoteParticipantsDirective, LogoDirective } from './internals.directive'; +import { LayoutRemoteParticipantsDirective, FallbackLogoDirective, ToolbarBrandingLogoDirective } from './internals.directive'; import { ParticipantPanelItemMuteButtonDirective } from './participant-panel-item.directive'; import { StreamDisplayAudioDetectionDirective, @@ -70,7 +70,8 @@ import { StreamDisplayParticipantNameDirective, StreamDisplayAudioDetectionDirective, StreamVideoControlsDirective, - LogoDirective, + FallbackLogoDirective, + ToolbarBrandingLogoDirective, ParticipantPanelItemMuteButtonDirective, ParticipantNameDirective, ActivitiesPanelRecordingActivityDirective, @@ -110,7 +111,8 @@ import { StreamDisplayParticipantNameDirective, StreamDisplayAudioDetectionDirective, StreamVideoControlsDirective, - LogoDirective, + FallbackLogoDirective, + ToolbarBrandingLogoDirective, ParticipantPanelItemMuteButtonDirective, ParticipantNameDirective, ActivitiesPanelRecordingActivityDirective, diff --git a/openvidu-components-angular/projects/openvidu-components-angular/src/lib/directives/api/internals.directive.ts b/openvidu-components-angular/projects/openvidu-components-angular/src/lib/directives/api/internals.directive.ts index 9426ae4f..fb8ca0da 100644 --- a/openvidu-components-angular/projects/openvidu-components-angular/src/lib/directives/api/internals.directive.ts +++ b/openvidu-components-angular/projects/openvidu-components-angular/src/lib/directives/api/internals.directive.ts @@ -1,6 +1,6 @@ // * Internal directives * -import { Directive, ElementRef, HostListener, Input } from '@angular/core'; +import { AfterViewInit, Directive, ElementRef, HostListener, Input, OnDestroy, OnInit } from '@angular/core'; import { ParticipantModel } from '../../models/participant.model'; import { OpenViduComponentsConfigService } from '../../services/config/directive-config.service'; @@ -11,16 +11,41 @@ import { OpenViduComponentsConfigService } from '../../services/config/directive @Directive({ selector: 'img[ovLogo]' }) -export class LogoDirective { +export class FallbackLogoDirective implements OnInit { defaultLogo = ''; + assetsLogo = 'assets/images/logo.png'; @Input() ovLogo: string; constructor(public elementRef: ElementRef) {} - @HostListener('error') - loadDefaultLogo() { - const element = this.elementRef.nativeElement; - element.src = this.ovLogo || this.defaultLogo; + ngOnInit() { + this.loadImage(this.ovLogo || this.assetsLogo); + } + + private loadImage(url: string) { + const element = this.elementRef.nativeElement as HTMLImageElement; + const tempImage = new Image(); + + const handleImageErrorOrLoad = (url: string) => { + if (tempImage.width <= 1 && tempImage.height <= 1) { + if (url === this.ovLogo) { + this.loadImage(this.assetsLogo); + } else if (url === this.assetsLogo) { + element.src = this.defaultLogo; + } + } else { + element.src = url; + } + }; + + tempImage.onload = () => { + handleImageErrorOrLoad(url); + }; + + tempImage.onerror = () => { + handleImageErrorOrLoad(url); + }; + tempImage.src = url; } } @@ -55,3 +80,45 @@ export class LayoutRemoteParticipantsDirective { this.update(undefined); } } + +/** + * @internal + */ +@Directive({ + selector: 'ov-videoconference[brandingLogo], ov-toolbar[brandingLogo]' +}) +export class ToolbarBrandingLogoDirective implements AfterViewInit, OnDestroy { + /** + * @ignore + */ + @Input() set brandingLogo(value: string) { + this._brandingLogo = value; + this.update(this._brandingLogo); + } + + private _brandingLogo: string = ''; + + /** + * @ignore + */ + constructor( + public elementRef: ElementRef, + private libService: OpenViduComponentsConfigService + ) {} + + ngAfterViewInit() { + this.update(this._brandingLogo); + } + + ngOnDestroy(): void { + this.clear(); + } + private clear() { + this._brandingLogo = ''; + this.update(this._brandingLogo); + } + + private update(value: string) { + this.libService.setBrandingLogo(value); + } +} diff --git a/openvidu-components-angular/projects/openvidu-components-angular/src/lib/services/config/directive-config.service.ts b/openvidu-components-angular/projects/openvidu-components-angular/src/lib/services/config/directive-config.service.ts index 1dbe1b4a..47271fbb 100644 --- a/openvidu-components-angular/projects/openvidu-components-angular/src/lib/services/config/directive-config.service.ts +++ b/openvidu-components-angular/projects/openvidu-components-angular/src/lib/services/config/directive-config.service.ts @@ -57,6 +57,9 @@ export class OpenViduComponentsConfigService { private displayRoomName = >new BehaviorSubject(true); displayRoomName$: Observable; + private brandingLogo = >new BehaviorSubject(''); + brandingLogo$: Observable; + private displayLogo = >new BehaviorSubject(true); displayLogo$: Observable; @@ -117,6 +120,7 @@ export class OpenViduComponentsConfigService { this.activitiesPanelButton$ = this.activitiesPanelButton.asObservable(); this.displayRoomName$ = this.displayRoomName.asObservable(); this.displayLogo$ = this.displayLogo.asObservable(); + this.brandingLogo$ = this.brandingLogo.asObservable(); this.recordingButton$ = this.recordingButton.asObservable(); this.broadcastingButton$ = this.broadcastingButton.asObservable(); this.toolbarSettingsButton$ = this.toolbarSettingsButton.asObservable(); @@ -262,6 +266,10 @@ export class OpenViduComponentsConfigService { this.displayRoomName.next(displayRoomName); } + setBrandingLogo(brandingLogo: string) { + this.brandingLogo.next(brandingLogo); + } + showRoomName(): boolean { return this.displayRoomName.getValue(); }