mirror of https://github.com/OpenVidu/openvidu.git
125 lines
8.0 KiB
TypeScript
125 lines
8.0 KiB
TypeScript
// * Internal directives *
|
|
|
|
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';
|
|
|
|
/**
|
|
* Load default OpenVidu logo if custom one is not exist
|
|
* @internal
|
|
*/
|
|
@Directive({
|
|
selector: 'img[ovLogo]'
|
|
})
|
|
export class FallbackLogoDirective implements OnInit {
|
|
defaultLogo =
|
|
'';
|
|
assetsLogo = 'assets/images/logo.png';
|
|
@Input() ovLogo: string;
|
|
constructor(public elementRef: ElementRef) {}
|
|
|
|
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;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @internal
|
|
*/
|
|
@Directive({
|
|
selector: 'ov-layout[ovRemoteParticipants]'
|
|
})
|
|
export class LayoutRemoteParticipantsDirective {
|
|
@Input() set ovRemoteParticipants(value: ParticipantModel[] | undefined) {
|
|
this.update(value);
|
|
}
|
|
constructor(
|
|
public elementRef: ElementRef,
|
|
private directiveService: OpenViduComponentsConfigService
|
|
) {}
|
|
|
|
ngOnDestroy(): void {
|
|
this.clear();
|
|
}
|
|
|
|
ngAfterViewInit() {
|
|
this.update(this.ovRemoteParticipants);
|
|
}
|
|
|
|
update(value: ParticipantModel[] | undefined) {
|
|
this.directiveService.setLayoutRemoteParticipants(value);
|
|
}
|
|
|
|
clear() {
|
|
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);
|
|
}
|
|
}
|