@ngx-extensions/screenfull
Version:
Wrapper module for screenfull
142 lines (134 loc) • 12.9 kB
JavaScript
import { Injectable, Directive, HostListener, Optional, SkipSelf, NgModule } from '@angular/core';
import { distinctUntilChanged, startWith } from 'rxjs/operators';
import { Subject } from 'rxjs';
import screenfull from 'screenfull';
/**
* Tracks the state of the fullscreen mode and allows interaction with its API
*/
var ScreenfullService = /** @class */ (function () {
/**
* Creates a new instance
*/
function ScreenfullService() {
this.fullScreenSub = new Subject();
this._registerListener();
this.fullScreenActive$ = this.fullScreenSub.asObservable().pipe(startWith(this.isFullScreenModeActive), distinctUntilChanged());
}
Object.defineProperty(ScreenfullService.prototype, "isFullScreenModeActive", {
/**
* Gets whether browser fullscreen mode is active or not.
*/
get: function () {
return screenfull ? screenfull.isFullscreen : false;
},
enumerable: true,
configurable: true
});
ScreenfullService.prototype.ngOnDestroy = function () {
this._removeListener();
this.fullScreenSub.complete();
};
ScreenfullService.prototype.request = function () {
if (screenfull) {
if (screenfull.enabled) {
screenfull.request();
}
}
};
ScreenfullService.prototype.exit = function () {
if (screenfull) {
if (screenfull.enabled) {
screenfull.exit();
}
}
};
/**
* Toggles the fullscreen mode of the browser
*/
ScreenfullService.prototype.toggle = function () {
if (screenfull) {
if (screenfull.enabled) {
screenfull.toggle();
}
}
};
ScreenfullService.prototype._removeListener = function () {
if (screenfull) {
screenfull.off('change', function () { });
}
};
ScreenfullService.prototype._registerListener = function () {
var _this = this;
if (screenfull) {
screenfull.on('change', function (event) {
_this._emitCurrent();
});
}
};
ScreenfullService.prototype._emitCurrent = function () {
this.fullScreenSub.next(this.isFullScreenModeActive);
};
ScreenfullService.decorators = [
{ type: Injectable }
];
ScreenfullService.ctorParameters = function () { return []; };
return ScreenfullService;
}());
/**
* Binds a host element´s click to the {@see ScreenfullService} toggle method
*/
var ToggleFullscreenDirective = /** @class */ (function () {
/**
* Creates a new instance
* @param _screenfullService the screen service singletone instance
*/
function ToggleFullscreenDirective(_screenfullService) {
this._screenfullService = _screenfullService;
}
/**
* Toggles the fullscreen mode
*/
ToggleFullscreenDirective.prototype.toggle = function () {
this._screenfullService.toggle();
};
ToggleFullscreenDirective.decorators = [
{ type: Directive, args: [{
selector: '[ngxToggleFullscreen]'
},] }
];
ToggleFullscreenDirective.ctorParameters = function () { return [
{ type: ScreenfullService }
]; };
ToggleFullscreenDirective.propDecorators = {
toggle: [{ type: HostListener, args: ['click',] }]
};
return ToggleFullscreenDirective;
}());
function SCREEN_SERVICE_FACTORY(parent) {
return parent || new ScreenfullService();
}
var SCREEN_SERVICE_PROVIDER = {
provide: ScreenfullService,
deps: [[new Optional(), new SkipSelf(), ScreenfullService]],
useFactory: SCREEN_SERVICE_FACTORY
};
var NgxScreenfullModule = /** @class */ (function () {
function NgxScreenfullModule() {
}
NgxScreenfullModule.decorators = [
{ type: NgModule, args: [{
declarations: [ToggleFullscreenDirective],
exports: [ToggleFullscreenDirective],
providers: [SCREEN_SERVICE_PROVIDER]
},] }
];
return NgxScreenfullModule;
}());
/*
* Public API Surface of @ngx-extensions/screenfull
*/
/**
* Generated bundle index. Do not edit.
*/
export { SCREEN_SERVICE_FACTORY as ɵa, SCREEN_SERVICE_PROVIDER as ɵb, NgxScreenfullModule, ScreenfullService, ToggleFullscreenDirective };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-extensions-screenfull.js.map","sources":["ng://@ngx-extensions/screenfull/lib/screenfull.service.ts","ng://@ngx-extensions/screenfull/lib/toggle-fullscreen.directive.ts","ng://@ngx-extensions/screenfull/lib/screenfull-service.provider.ts","ng://@ngx-extensions/screenfull/lib/screenfull.module.ts","ng://@ngx-extensions/screenfull/public_api.ts","ng://@ngx-extensions/screenfull/ngx-extensions-screenfull.ts"],"sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\r\nimport { distinctUntilChanged, startWith } from 'rxjs/operators';\r\nimport { Subject, Observable } from 'rxjs';\r\nimport screenfull from 'screenfull';\r\n\r\n/**\r\n * Tracks the state of the fullscreen mode and allows interaction with its API\r\n */\r\n@Injectable()\r\nexport class ScreenfullService implements OnDestroy {\r\n  private readonly fullScreenSub = new Subject<boolean>();\r\n  readonly fullScreenActive$: Observable<boolean>;\r\n\r\n  /**\r\n   * Gets whether browser fullscreen mode is active or not.\r\n   */\r\n  get isFullScreenModeActive(): boolean {\r\n    return screenfull ? screenfull.isFullscreen : false;\r\n  }\r\n\r\n  /**\r\n   * Creates a new instance\r\n   */\r\n  constructor() {\r\n    this._registerListener();\r\n    this.fullScreenActive$ = this.fullScreenSub.asObservable().pipe(\r\n      startWith(this.isFullScreenModeActive),\r\n      distinctUntilChanged()\r\n    );\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._removeListener();\r\n    this.fullScreenSub.complete();\r\n  }\r\n\r\n  request() {\r\n    if (screenfull) {\r\n      if (screenfull.enabled) {\r\n        screenfull.request();\r\n      }\r\n    }\r\n  }\r\n\r\n  exit() {\r\n    if (screenfull) {\r\n      if (screenfull.enabled) {\r\n        screenfull.exit();\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Toggles the fullscreen mode of the browser\r\n   */\r\n  toggle() {\r\n    if (screenfull) {\r\n      if (screenfull.enabled) {\r\n        screenfull.toggle();\r\n      }\r\n    }\r\n  }\r\n\r\n  private _removeListener() {\r\n    if (screenfull) {\r\n      screenfull.off('change', () => {});\r\n    }\r\n  }\r\n\r\n  private _registerListener() {\r\n    if (screenfull) {\r\n      screenfull.on('change', event => {\r\n        this._emitCurrent();\r\n      });\r\n    }\r\n  }\r\n\r\n  private _emitCurrent() {\r\n    this.fullScreenSub.next(this.isFullScreenModeActive);\r\n  }\r\n}\r\n","import { Directive, HostListener } from '@angular/core';\r\n\r\nimport { ScreenfullService } from './screenfull.service';\r\n\r\n/**\r\n * Binds a host elementÂ´s click to the {@see ScreenfullService} toggle method\r\n */\r\n@Directive({\r\n  selector: '[ngxToggleFullscreen]'\r\n})\r\nexport class ToggleFullscreenDirective {\r\n  /**\r\n   * Creates a new instance\r\n   * @param _screenfullService the screen service singletone instance\r\n   */\r\n  constructor(private readonly _screenfullService: ScreenfullService) {}\r\n\r\n  /**\r\n   * Toggles the fullscreen mode\r\n   */\r\n  @HostListener('click')\r\n  toggle() {\r\n    this._screenfullService.toggle();\r\n  }\r\n}\r\n","import { FactoryProvider, Optional, SkipSelf } from '@angular/core';\r\n\r\nimport { ScreenfullService } from './screenfull.service';\r\n\r\nexport function SCREEN_SERVICE_FACTORY(\r\n  parent: ScreenfullService\r\n): ScreenfullService {\r\n  return parent || new ScreenfullService();\r\n}\r\n\r\nexport const SCREEN_SERVICE_PROVIDER: FactoryProvider = {\r\n  provide: ScreenfullService,\r\n  deps: [[new Optional(), new SkipSelf(), ScreenfullService]],\r\n  useFactory: SCREEN_SERVICE_FACTORY\r\n};\r\n","import { NgModule } from '@angular/core';\r\n\r\nimport { ToggleFullscreenDirective } from './toggle-fullscreen.directive';\r\nimport { SCREEN_SERVICE_PROVIDER } from './screenfull-service.provider';\r\n\r\n@NgModule({\r\n  declarations: [ToggleFullscreenDirective],\r\n  exports: [ToggleFullscreenDirective],\r\n  providers: [SCREEN_SERVICE_PROVIDER]\r\n})\r\nexport class NgxScreenfullModule {}\r\n","/*\r\n * Public API Surface of @ngx-extensions/screenfull\r\n */\r\n\r\nexport * from './lib/screenfull.module';\r\nexport * from './lib/screenfull.service';\r\nexport * from './lib/toggle-fullscreen.directive';\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n\nexport {SCREEN_SERVICE_FACTORY as Éµa,SCREEN_SERVICE_PROVIDER as Éµb} from './lib/screenfull-service.provider';"],"names":[],"mappings":";;;;;AAKA;;;AAGA;;;;IAeE;QAbiB,kBAAa,GAAG,IAAI,OAAO,EAAW,CAAC;QActD,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC,IAAI,CAC7D,SAAS,CAAC,IAAI,CAAC,sBAAsB,CAAC,EACtC,oBAAoB,EAAE,CACvB,CAAC;KACH;IAbD,sBAAI,qDAAsB;;;;aAA1B;YACE,OAAO,UAAU,GAAG,UAAU,CAAC,YAAY,GAAG,KAAK,CAAC;SACrD;;;OAAA;IAaD,uCAAW,GAAX;QACE,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;KAC/B;IAED,mCAAO,GAAP;QACE,IAAI,UAAU,EAAE;YACd,IAAI,UAAU,CAAC,OAAO,EAAE;gBACtB,UAAU,CAAC,OAAO,EAAE,CAAC;aACtB;SACF;KACF;IAED,gCAAI,GAAJ;QACE,IAAI,UAAU,EAAE;YACd,IAAI,UAAU,CAAC,OAAO,EAAE;gBACtB,UAAU,CAAC,IAAI,EAAE,CAAC;aACnB;SACF;KACF;;;;IAKD,kCAAM,GAAN;QACE,IAAI,UAAU,EAAE;YACd,IAAI,UAAU,CAAC,OAAO,EAAE;gBACtB,UAAU,CAAC,MAAM,EAAE,CAAC;aACrB;SACF;KACF;IAEO,2CAAe,GAAvB;QACE,IAAI,UAAU,EAAE;YACd,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,eAAQ,CAAC,CAAC;SACpC;KACF;IAEO,6CAAiB,GAAzB;QAAA,iBAMC;QALC,IAAI,UAAU,EAAE;YACd,UAAU,CAAC,EAAE,CAAC,QAAQ,EAAE,UAAA,KAAK;gBAC3B,KAAI,CAAC,YAAY,EAAE,CAAC;aACrB,CAAC,CAAC;SACJ;KACF;IAEO,wCAAY,GAApB;QACE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;KACtD;;gBAvEF,UAAU;;;IAwEX,wBAAC;CAxED;;ACJA;;;AAGA;;;;;IAQE,mCAA6B,kBAAqC;QAArC,uBAAkB,GAAlB,kBAAkB,CAAmB;KAAI;;;;IAMtE,0CAAM,GADN;QAEE,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC;KAClC;;gBAhBF,SAAS,SAAC;oBACT,QAAQ,EAAE,uBAAuB;iBAClC;;;gBAPQ,iBAAiB;;;yBAkBvB,YAAY,SAAC,OAAO;;IAIvB,gCAAC;CAjBD;;gCCFE,MAAyB;IAEzB,OAAO,MAAM,IAAI,IAAI,iBAAiB,EAAE,CAAC;CAC1C;AAED,IAAa,uBAAuB,GAAoB;IACtD,OAAO,EAAE,iBAAiB;IAC1B,IAAI,EAAE,CAAC,CAAC,IAAI,QAAQ,EAAE,EAAE,IAAI,QAAQ,EAAE,EAAE,iBAAiB,CAAC,CAAC;IAC3D,UAAU,EAAE,sBAAsB;CACnC;;;ICTD;KAKmC;;gBALlC,QAAQ,SAAC;oBACR,YAAY,EAAE,CAAC,yBAAyB,CAAC;oBACzC,OAAO,EAAE,CAAC,yBAAyB,CAAC;oBACpC,SAAS,EAAE,CAAC,uBAAuB,CAAC;iBACrC;;IACiC,0BAAC;CALnC;;ACLA;;GAEG;;ACFH;;GAEG;;;;"}