@ohayojp.com/components
Version:
Common business components of ohayojp.
227 lines • 15.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: media.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __decorate, __metadata } from "tslib";
import { Platform } from '@angular/cdk/platform';
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, NgZone, Output, Renderer2, ViewEncapsulation, } from '@angular/core';
import { InputNumber } from '@ohayojp.com/util';
import { MediaService } from './media.service';
export class MediaComponent {
/**
* @param {?} el
* @param {?} renderer
* @param {?} srv
* @param {?} ngZone
* @param {?} platform
*/
constructor(el, renderer, srv, ngZone, platform) {
this.el = el;
this.renderer = renderer;
this.srv = srv;
this.ngZone = ngZone;
this.platform = platform;
// #region fields
this.type = 'video';
this.delay = 0;
this.ready = new EventEmitter();
this.notify$ = this.srv.notify().subscribe((/**
* @return {?}
*/
() => this.initDelay()));
}
// #endregion
/**
* @return {?}
*/
get player() {
return this._p;
}
/**
* @private
* @return {?}
*/
initDelay() {
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
() => {
this.time = setTimeout((/**
* @return {?}
*/
() => this.init()), this.delay);
}));
}
/**
* @private
* @return {?}
*/
init() {
if (!((/** @type {?} */ (window))).Plyr) {
throw new Error(`No window.Plyr found, please make sure that cdn or local path exists, the current referenced path is: ${JSON.stringify(this.srv.cog.urls)}`);
}
this.ensureElement();
/** @type {?} */
const player = (this._p = new Plyr(this.videoEl, Object.assign({}, this.srv.cog.options)));
player.on('ready', (/**
* @return {?}
*/
() => this.ready.next(player)));
this.uploadSource();
}
/**
* @private
* @return {?}
*/
ensureElement() {
const { type } = this;
/** @type {?} */
let el = (/** @type {?} */ (this.el.nativeElement.querySelector(type)));
if (!el) {
el = this.renderer.createElement(type);
((/** @type {?} */ (el))).controls = true;
this.el.nativeElement.appendChild(el);
}
this.videoEl = el;
}
/**
* @private
* @return {?}
*/
destroy() {
if (this._p) {
this._p.destroy();
}
}
/**
* @private
* @return {?}
*/
uploadSource() {
const { source, type } = this;
this._p.source = typeof source === 'string' ? { type, sources: [{ src: source }] } : source;
}
/**
* @return {?}
*/
ngAfterViewInit() {
if (!this.platform.isBrowser) {
return;
}
this.srv.load();
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
this.srv.cog = { options: this.options };
if (changes.source && this._p) {
this.uploadSource();
}
}
/**
* @return {?}
*/
ngOnDestroy() {
clearTimeout(this.time);
this.destroy();
this._p = null;
this.notify$.unsubscribe();
}
}
MediaComponent.decorators = [
{
type: Component, args: [{
selector: 'media',
exportAs: 'mediaComponent',
template: `<ng-content></ng-content>`,
host: {
'[style.display]': `'block'`,
},
preserveWhitespaces: false,
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None
}]
}
];
/** @nocollapse */
MediaComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: Renderer2 },
{ type: MediaService },
{ type: NgZone },
{ type: Platform }
];
MediaComponent.propDecorators = {
type: [{ type: Input }],
source: [{ type: Input }],
options: [{ type: Input }],
delay: [{ type: Input }],
ready: [{ type: Output }]
};
__decorate([
InputNumber(),
__metadata("design:type", Object)
], MediaComponent.prototype, "delay", void 0);
if (false) {
/** @type {?} */
MediaComponent.ngAcceptInputType_delay;
/**
* @type {?}
* @private
*/
MediaComponent.prototype._p;
/**
* @type {?}
* @private
*/
MediaComponent.prototype.videoEl;
/**
* @type {?}
* @private
*/
MediaComponent.prototype.time;
/**
* @type {?}
* @private
*/
MediaComponent.prototype.notify$;
/** @type {?} */
MediaComponent.prototype.type;
/** @type {?} */
MediaComponent.prototype.source;
/** @type {?} */
MediaComponent.prototype.options;
/** @type {?} */
MediaComponent.prototype.delay;
/** @type {?} */
MediaComponent.prototype.ready;
/**
* @type {?}
* @private
*/
MediaComponent.prototype.el;
/**
* @type {?}
* @private
*/
MediaComponent.prototype.renderer;
/**
* @type {?}
* @private
*/
MediaComponent.prototype.srv;
/**
* @type {?}
* @private
*/
MediaComponent.prototype.ngZone;
/**
* @type {?}
* @private
*/
MediaComponent.prototype.platform;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media.component.js","sourceRoot":"C:/android/@ohayojp/packages/components/media/","sources":["media.component.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EACL,MAAM,EAGN,MAAM,EACN,SAAS,EAET,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAe,MAAM,aAAa,CAAC;AAGvD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAgB/C,MAAM,OAAO,cAAc;;;;;;;;IAsBzB,YACU,EAA2B,EAC3B,QAAmB,EACnB,GAAiB,EACjB,MAAc,EACd,QAAkB;QAJlB,OAAE,GAAF,EAAE,CAAyB;QAC3B,aAAQ,GAAR,QAAQ,CAAW;QACnB,QAAG,GAAH,GAAG,CAAc;QACjB,WAAM,GAAN,MAAM,CAAQ;QACd,aAAQ,GAAR,QAAQ,CAAU;;QAjBnB,SAAI,GAAkB,OAAO,CAAC;QAGf,UAAK,GAAG,CAAC,CAAC;QACf,UAAK,GAAG,IAAI,YAAY,EAAa,CAAC;QAevD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,SAAS;;;QAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,EAAC,CAAC;IACrE,CAAC;;;;;IAZD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;;;;;IAYO,SAAS;QACf,IAAI,CAAC,MAAM,CAAC,iBAAiB;;;QAAC,GAAG,EAAE;YACjC,IAAI,CAAC,IAAI,GAAG,UAAU;;;YAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,GAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QACxD,CAAC,EAAC,CAAC;IACL,CAAC;;;;;IAEO,IAAI;QACV,IAAI,CAAC,CAAC,mBAAA,MAAM,EAAO,CAAC,CAAC,IAAI,EAAE;YACzB,MAAM,IAAI,KAAK,CACb,yGAAyG,IAAI,CAAC,SAAS,CACrH,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAClB,EAAE,CACJ,CAAC;SACH;QAED,IAAI,CAAC,aAAa,EAAE,CAAC;;cAEf,MAAM,GAAG,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,oBAC1C,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,EACvB,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,OAAO;;;QAAE,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;QAElD,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;;;;;IAEO,aAAa;cACb,EAAE,IAAI,EAAE,GAAG,IAAI;;YACjB,EAAE,GAAG,mBAAA,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,CAAC,EAAe;QACjE,IAAI,CAAC,EAAE,EAAE;YACP,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YACvC,CAAC,mBAAA,EAAE,EAAoB,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC;YACzC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;SACvC;QACD,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;;;;;IAEO,OAAO;QACb,IAAI,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC;SACnB;IACH,CAAC;;;;;IAEO,YAAY;cACZ,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI;QAC7B,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;IAC9F,CAAC;;;;IAED,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE;YAC5B,OAAO;SACR;QACD,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;IAClB,CAAC;;;;;IAED,WAAW,CAAC,OAAuD;QACjE,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC;QACzC,IAAI,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,EAAE,EAAE;YAC7B,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;;;;IAED,WAAW;QACT,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxB,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC;QACf,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;IAC7B,CAAC;;;YA9GF,SAAS,SAAC;gBACT,QAAQ,EAAE,OAAO;gBACjB,QAAQ,EAAE,gBAAgB;gBAC1B,QAAQ,EAAE,2BAA2B;gBACrC,IAAI,EAAE;oBACJ,iBAAiB,EAAE,SAAS;iBAC7B;gBACD,mBAAmB,EAAE,KAAK;gBAC1B,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;;YA7BC,UAAU;YAOV,SAAS;YAOF,YAAY;YAXnB,MAAM;YARC,QAAQ;;;mBA6Cd,KAAK;qBACL,KAAK;sBACL,KAAK;oBACL,KAAK;oBACL,MAAM;;AADiB;IAAd,WAAW,EAAE;;6CAAW;;;IAZlC,uCAA4C;;;;;IAE5C,4BAAsB;;;;;IACtB,iCAA6B;;;;;IAC7B,8BAAwB;;;;;IACxB,iCAA8B;;IAI9B,8BAAuC;;IACvC,gCAA0C;;IAC1C,iCAA4B;;IAC5B,+BAAkC;;IAClC,+BAAyD;;;;;IASvD,4BAAmC;;;;;IACnC,kCAA2B;;;;;IAC3B,6BAAyB;;;;;IACzB,gCAAsB;;;;;IACtB,kCAA0B","sourcesContent":["import { Platform } from '@angular/cdk/platform';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Output,\n  Renderer2,\n  SimpleChange,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { InputNumber, NumberInput } from '@ohayo/util';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { Subscription } from 'rxjs';\nimport { MediaService } from './media.service';\nimport { PlyrMediaSource, PlyrMediaType } from './plyr.types';\n\ndeclare const Plyr: NzSafeAny;\n\n@Component({\n  selector: 'media',\n  exportAs: 'mediaComponent',\n  template: `<ng-content></ng-content>`,\n  host: {\n    '[style.display]': `'block'`,\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MediaComponent implements OnChanges, AfterViewInit, OnDestroy {\n  static ngAcceptInputType_delay: NumberInput;\n\n  private _p: NzSafeAny;\n  private videoEl: HTMLElement;\n  private time: NzSafeAny;\n  private notify$: Subscription;\n\n  // #region fields\n\n  @Input() type: PlyrMediaType = 'video';\n  @Input() source: string | PlyrMediaSource;\n  @Input() options: NzSafeAny;\n  @Input() @InputNumber() delay = 0;\n  @Output() readonly ready = new EventEmitter<NzSafeAny>();\n\n  // #endregion\n\n  get player(): NzSafeAny {\n    return this._p;\n  }\n\n  constructor(\n    private el: ElementRef<HTMLElement>,\n    private renderer: Renderer2,\n    private srv: MediaService,\n    private ngZone: NgZone,\n    private platform: Platform,\n  ) {\n    this.notify$ = this.srv.notify().subscribe(() => this.initDelay());\n  }\n\n  private initDelay(): void {\n    this.ngZone.runOutsideAngular(() => {\n      this.time = setTimeout(() => this.init(), this.delay);\n    });\n  }\n\n  private init(): void {\n    if (!(window as any).Plyr) {\n      throw new Error(\n        `No window.Plyr found, please make sure that cdn or local path exists, the current referenced path is: ${JSON.stringify(\n          this.srv.cog.urls,\n        )}`,\n      );\n    }\n\n    this.ensureElement();\n\n    const player = (this._p = new Plyr(this.videoEl, {\n      ...this.srv.cog.options,\n    }));\n\n    player.on('ready', () => this.ready.next(player));\n\n    this.uploadSource();\n  }\n\n  private ensureElement(): void {\n    const { type } = this;\n    let el = this.el.nativeElement.querySelector(type) as HTMLElement;\n    if (!el) {\n      el = this.renderer.createElement(type);\n      (el as HTMLVideoElement).controls = true;\n      this.el.nativeElement.appendChild(el);\n    }\n    this.videoEl = el;\n  }\n\n  private destroy(): void {\n    if (this._p) {\n      this._p.destroy();\n    }\n  }\n\n  private uploadSource(): void {\n    const { source, type } = this;\n    this._p.source = typeof source === 'string' ? { type, sources: [{ src: source }] } : source;\n  }\n\n  ngAfterViewInit(): void {\n    if (!this.platform.isBrowser) {\n      return;\n    }\n    this.srv.load();\n  }\n\n  ngOnChanges(changes: { [p in keyof MediaComponent]?: SimpleChange }): void {\n    this.srv.cog = { options: this.options };\n    if (changes.source && this._p) {\n      this.uploadSource();\n    }\n  }\n\n  ngOnDestroy(): void {\n    clearTimeout(this.time);\n    this.destroy();\n    this._p = null;\n    this.notify$.unsubscribe();\n  }\n}\n"]}