@delon/abc
Version:
Common business components of ng-alain.
114 lines • 14.4 kB
JavaScript
import { __decorate } from "tslib";
import { Platform } from '@angular/cdk/platform';
import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, EventEmitter, Input, NgZone, Output, Renderer2, ViewEncapsulation, inject, numberAttribute } from '@angular/core';
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
import { timer, take } from 'rxjs';
import { ZoneOutside } from '@delon/util/decorator';
import { MediaService } from './media.service';
import * as i0 from "@angular/core";
export class MediaComponent {
constructor() {
this.destroy$ = inject(DestroyRef);
this.el = inject(ElementRef).nativeElement;
this.renderer = inject(Renderer2);
this.ngZone = inject(NgZone);
this.srv = inject(MediaService);
this.platform = inject(Platform);
this.type = 'video';
this.delay = 0;
this.ready = new EventEmitter();
}
get player() {
return this._p;
}
initDelay() {
timer(this.delay)
.pipe(takeUntilDestroyed(this.destroy$))
.subscribe(() => this.ngZone.runOutsideAngular(() => this.init()));
}
init() {
const winPlyr = window.Plyr;
if (!winPlyr) {
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();
const player = (this._p = new winPlyr(this.videoEl, {
...this.srv.cog.options
}));
player.on('ready', () => this.ngZone.run(() => this.ready.next(player)));
this.uploadSource();
}
ensureElement() {
const { type } = this;
let el = this.el.querySelector(type);
if (!el) {
el = this.renderer.createElement(type);
el.controls = true;
this.el.appendChild(el);
}
this.videoEl = el;
}
destroy() {
if (this._p) {
this._p.destroy();
}
}
uploadSource() {
if (this._p == null)
return;
const { source, type } = this;
this._p.source = (typeof source === 'string' ? { type, sources: [{ src: source }] } : source);
}
ngAfterViewInit() {
if (!this.platform.isBrowser) {
return;
}
this.srv
.notify()
.pipe(takeUntilDestroyed(this.destroy$), take(1))
.subscribe(() => this.initDelay());
this.srv.load();
}
ngOnChanges(changes) {
this.srv.cog = { options: this.options };
if (changes.source) {
this.uploadSource();
}
}
ngOnDestroy() {
this.destroy();
this._p = null;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: MediaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.5", type: MediaComponent, isStandalone: true, selector: "media, [media]", inputs: { type: "type", source: "source", options: "options", delay: ["delay", "delay", numberAttribute] }, outputs: { ready: "ready" }, host: { properties: { "style.display": "'block'" } }, exportAs: ["mediaComponent"], usesOnChanges: true, ngImport: i0, template: `<ng-content />`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
}
__decorate([
ZoneOutside()
], MediaComponent.prototype, "initDelay", null);
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: MediaComponent, decorators: [{
type: Component,
args: [{
selector: 'media, [media]',
exportAs: 'mediaComponent',
template: `<ng-content />`,
host: {
'[style.display]': `'block'`
},
preserveWhitespaces: false,
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
standalone: true
}]
}], propDecorators: { type: [{
type: Input
}], source: [{
type: Input
}], options: [{
type: Input
}], delay: [{
type: Input,
args: [{ transform: numberAttribute }]
}], ready: [{
type: Output
}], initDelay: [] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media.component.js","sourceRoot":"","sources":["../../../../../packages/abc/media/media.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Platform } from '@angular/cdk/platform';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Output,\n  Renderer2,\n  SimpleChange,\n  ViewEncapsulation,\n  inject,\n  numberAttribute\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { timer, take } from 'rxjs';\n\nimport type Plyr from 'plyr';\n\nimport { ZoneOutside } from '@delon/util/decorator';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nimport { MediaService } from './media.service';\n\nexport type MediaType = 'html5' | 'youtube' | 'video' | 'audio';\n\n@Component({\n  selector: 'media, [media]',\n  exportAs: 'mediaComponent',\n  template: `<ng-content />`,\n  host: {\n    '[style.display]': `'block'`\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true\n})\nexport class MediaComponent implements OnChanges, AfterViewInit, OnDestroy {\n  private readonly destroy$ = inject(DestroyRef);\n  private readonly el: HTMLElement = inject(ElementRef).nativeElement;\n  private readonly renderer = inject(Renderer2);\n  private readonly ngZone = inject(NgZone);\n  private readonly srv = inject(MediaService);\n  private readonly platform = inject(Platform);\n\n  private _p?: Plyr | null;\n  private videoEl?: HTMLElement;\n\n  @Input() type: MediaType = 'video';\n  @Input() source?: string | Plyr.SourceInfo;\n  @Input() options?: Plyr.Options;\n  @Input({ transform: numberAttribute }) delay = 0;\n  @Output() readonly ready = new EventEmitter<Plyr>();\n\n  get player(): Plyr | undefined | null {\n    return this._p;\n  }\n\n  @ZoneOutside()\n  private initDelay(): void {\n    timer(this.delay)\n      .pipe(takeUntilDestroyed(this.destroy$))\n      .subscribe(() => this.ngZone.runOutsideAngular(() => this.init()));\n  }\n\n  private init(): void {\n    const winPlyr = (window as NzSafeAny).Plyr;\n    if (!winPlyr) {\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: Plyr = (this._p = new winPlyr(this.videoEl, {\n      ...this.srv.cog.options\n    }));\n\n    player.on('ready', () => this.ngZone.run(() => this.ready.next(player)));\n\n    this.uploadSource();\n  }\n\n  private ensureElement(): void {\n    const { type } = this;\n    let el = this.el.querySelector(type) as HTMLElement;\n    if (!el) {\n      el = this.renderer.createElement(type);\n      (el as HTMLVideoElement).controls = true;\n      this.el.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    if (this._p == null) return;\n\n    const { source, type } = this;\n    this._p.source = (typeof source === 'string' ? { type, sources: [{ src: source }] } : source) as Plyr.SourceInfo;\n  }\n\n  ngAfterViewInit(): void {\n    if (!this.platform.isBrowser) {\n      return;\n    }\n    this.srv\n      .notify()\n      .pipe(takeUntilDestroyed(this.destroy$), take(1))\n      .subscribe(() => this.initDelay());\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) {\n      this.uploadSource();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy();\n    this._p = null;\n  }\n}\n"]}