2018-03-30 15:30:30 -04:00
|
|
|
import {Injectable} from '@angular/core';
|
|
|
|
import {Event} from '../../../common/event/Event';
|
2016-07-06 12:53:49 +02:00
|
|
|
|
2018-11-28 23:49:33 +01:00
|
|
|
declare const document: {
|
|
|
|
fullscreenElement: any;
|
|
|
|
mozFullScreenElement: any;
|
|
|
|
webkitFullscreenElement: any;
|
|
|
|
exitFullscreen: () => void;
|
|
|
|
mozCancelFullScreen: () => void;
|
|
|
|
webkitExitFullscreen: () => void;
|
|
|
|
};
|
|
|
|
|
2016-07-06 12:53:49 +02:00
|
|
|
@Injectable()
|
|
|
|
export class FullScreenService {
|
|
|
|
|
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
OnFullScreenChange = new Event<boolean>();
|
2017-03-25 21:59:30 +01:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
public isFullScreenEnabled(): boolean {
|
2018-10-22 00:24:17 +02:00
|
|
|
return !!(document['fullscreenElement'] ||
|
|
|
|
document['mozFullScreenElement'] ||
|
|
|
|
document['webkitFullscreenElement']);
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
|
|
|
|
2018-12-12 21:03:06 +01:00
|
|
|
public showFullScreen(element: Element) {
|
2017-06-10 22:32:56 +02:00
|
|
|
if (this.isFullScreenEnabled()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (element.requestFullscreen) {
|
2018-12-12 21:03:06 +01:00
|
|
|
element.requestFullscreen().catch(console.error);
|
|
|
|
} else if ((<any>element).mozRequestFullScreen) {
|
|
|
|
(<any>element).mozRequestFullScreen();
|
|
|
|
} else if ((<any>element).webkitRequestFullscreen) {
|
|
|
|
(<any>element).webkitRequestFullscreen();
|
|
|
|
} else if ((<any>element).msRequestFullscreen) {
|
|
|
|
(<any>element).msRequestFullscreen();
|
2016-07-06 12:53:49 +02:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
this.OnFullScreenChange.trigger(true);
|
|
|
|
}
|
2016-07-06 12:53:49 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
public exitFullScreen() {
|
|
|
|
if (!this.isFullScreenEnabled()) {
|
|
|
|
return;
|
2016-07-06 12:53:49 +02:00
|
|
|
}
|
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
if (document.exitFullscreen) {
|
|
|
|
document.exitFullscreen();
|
|
|
|
} else if (document['mozCancelFullScreen']) {
|
|
|
|
document['mozCancelFullScreen']();
|
2018-10-22 00:24:17 +02:00
|
|
|
} else if (document['webkitExitFullscreen']) {
|
|
|
|
document['webkitExitFullscreen']();
|
2016-07-06 12:53:49 +02:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
this.OnFullScreenChange.trigger(false);
|
|
|
|
}
|
2016-07-06 12:53:49 +02:00
|
|
|
|
|
|
|
}
|