UNPKG

@ohayojp.com/components

Version:

Common business components of ohayojp.

227 lines 15.1 kB
/** * @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":"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","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"]}