UNPKG

@ohayojp.com/components

Version:

Common business components of ohayojp.

256 lines 17.6 kB
/** * @fileoverview added by tsickle * Generated from: qr.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, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core'; import { OhayoConfigService, InputNumber, LazyService } from '@ohayojp.com/util'; import { filter } from 'rxjs/operators'; import { QR_DEFULAT_CONFIG } from './qr.config'; export class QRComponent { // #endregion /** * @param {?} cdr * @param {?} configSrv * @param {?} lazySrv * @param {?} platform */ constructor(cdr, configSrv, lazySrv, platform) { this.cdr = cdr; this.lazySrv = lazySrv; this.platform = platform; this.inited = false; this.value = ''; // tslint:disable-next-line:no-output-native this.change = new EventEmitter(); this.cog = (/** @type {?} */ (configSrv.merge('qr', QR_DEFULAT_CONFIG))); Object.assign(this, this.cog); } /** * @private * @return {?} */ init() { if (!this.inited) { return; } if (this.qr == null) { this.qr = new ((/** @type {?} */ (window))).QRious(); } this.qr.set(this.option); this.dataURL = this.qr.toDataURL(); this.change.emit(this.dataURL); this.cdr.detectChanges(); } /** * @private * @return {?} */ initDelay() { this.inited = true; setTimeout((/** * @return {?} */ () => this.init()), this.delay); } /** * @return {?} */ ngAfterViewInit() { if (!this.platform.isBrowser) { return; } if (((/** @type {?} */ (window))).QRious) { this.initDelay(); return; } /** @type {?} */ const url = (/** @type {?} */ (this.cog.lib)); this.lazy$ = this.lazySrv.change .pipe(filter((/** * @param {?} ls * @return {?} */ ls => ls.length === 1 && ls[0].path === url && ls[0].status === 'ok'))) .subscribe((/** * @return {?} */ () => this.initDelay())); this.lazySrv.load(url); } /** * @return {?} */ ngOnChanges() { /** @type {?} */ const option = { background: this.background, backgroundAlpha: this.backgroundAlpha, foreground: this.foreground, foregroundAlpha: this.foregroundAlpha, level: this.level, mime: this.mime, padding: this.padding, size: this.size, value: this.toUtf8ByteArray(this.value), }; this.option = option; this.init(); } /** * @private * @param {?} str * @return {?} */ toUtf8ByteArray(str) { str = encodeURI(str); /** @type {?} */ const result = []; for (let i = 0; i < str.length; i++) { if (str.charAt(i) !== '%') { result.push(str.charCodeAt(i)); } else { result.push(parseInt(str.substr(i + 1, 2), 16)); i += 2; } } return result.map((/** * @param {?} v * @return {?} */ v => String.fromCharCode(v))).join(''); } /** * @return {?} */ ngOnDestroy() { if (this.lazy$) { this.lazy$.unsubscribe(); } } } QRComponent.decorators = [ { type: Component, args: [{ selector: 'qr', exportAs: 'qr', template: ` <img *ngIf="dataURL" style="max-width: 100%; max-height: 100%;" [src]="dataURL" /> `, host: { '[style.display]': `'inline-block'`, '[style.height.px]': 'size', '[style.width.px]': 'size', }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ QRComponent.ctorParameters = () => [ { type: ChangeDetectorRef }, { type: OhayoConfigService }, { type: LazyService }, { type: Platform } ]; QRComponent.propDecorators = { background: [{ type: Input }], backgroundAlpha: [{ type: Input }], foreground: [{ type: Input }], foregroundAlpha: [{ type: Input }], level: [{ type: Input }], mime: [{ type: Input }], padding: [{ type: Input }], size: [{ type: Input }], value: [{ type: Input }], delay: [{ type: Input }], change: [{ type: Output }] }; __decorate([ InputNumber(), __metadata("design:type", Number) ], QRComponent.prototype, "padding", void 0); __decorate([ InputNumber(), __metadata("design:type", Number) ], QRComponent.prototype, "size", void 0); __decorate([ InputNumber(), __metadata("design:type", Number) ], QRComponent.prototype, "delay", void 0); if (false) { /** @type {?} */ QRComponent.ngAcceptInputType_padding; /** @type {?} */ QRComponent.ngAcceptInputType_size; /** @type {?} */ QRComponent.ngAcceptInputType_delay; /** * @type {?} * @private */ QRComponent.prototype.lazy$; /** * @type {?} * @private */ QRComponent.prototype.qr; /** * @type {?} * @private */ QRComponent.prototype.cog; /** * @type {?} * @private */ QRComponent.prototype.option; /** * @type {?} * @private */ QRComponent.prototype.inited; /** @type {?} */ QRComponent.prototype.dataURL; /** @type {?} */ QRComponent.prototype.background; /** @type {?} */ QRComponent.prototype.backgroundAlpha; /** @type {?} */ QRComponent.prototype.foreground; /** @type {?} */ QRComponent.prototype.foregroundAlpha; /** @type {?} */ QRComponent.prototype.level; /** @type {?} */ QRComponent.prototype.mime; /** @type {?} */ QRComponent.prototype.padding; /** @type {?} */ QRComponent.prototype.size; /** @type {?} */ QRComponent.prototype.value; /** @type {?} */ QRComponent.prototype.delay; /** @type {?} */ QRComponent.prototype.change; /** * @type {?} * @private */ QRComponent.prototype.cdr; /** * @type {?} * @private */ QRComponent.prototype.lazySrv; /** * @type {?} * @private */ QRComponent.prototype.platform; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"qr.component.js","sourceRoot":"C:/android/@ohayojp/packages/components/qr/","sources":["qr.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Platform } from '@angular/cdk/platform';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { OhayoConfigService, OhayoQRConfig, InputNumber, LazyService, NumberInput } from '@ohayo/util';\nimport { Subscription } from 'rxjs';\nimport { filter } from 'rxjs/operators';\nimport { QR_DEFULAT_CONFIG } from './qr.config';\nimport { QROptions } from './qr.types';\n\n@Component({\n  selector: 'qr',\n  exportAs: 'qr',\n  template: ` <img *ngIf=\"dataURL\" style=\"max-width: 100%; max-height: 100%;\" [src]=\"dataURL\" /> `,\n  host: {\n    '[style.display]': `'inline-block'`,\n    '[style.height.px]': 'size',\n    '[style.width.px]': 'size',\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class QRComponent implements OnChanges, AfterViewInit, OnDestroy {\n  static ngAcceptInputType_padding: NumberInput;\n  static ngAcceptInputType_size: NumberInput;\n  static ngAcceptInputType_delay: NumberInput;\n\n  private lazy$: Subscription;\n  private qr: any;\n  private cog: OhayoQRConfig;\n  private option: QROptions;\n  private inited = false;\n\n  dataURL: string;\n\n  // #region fields\n\n  @Input() background: string;\n  @Input() backgroundAlpha: number;\n  @Input() foreground: string;\n  @Input() foregroundAlpha: number;\n  @Input() level: 'L' | 'M' | 'Q' | 'H';\n  @Input() mime: string;\n  @Input() @InputNumber() padding: number;\n  @Input() @InputNumber() size: number;\n  @Input() value = '';\n  @Input() @InputNumber() delay: number;\n  // tslint:disable-next-line:no-output-native\n  @Output() readonly change = new EventEmitter<string>();\n\n  // #endregion\n\n  constructor(private cdr: ChangeDetectorRef, configSrv: OhayoConfigService, private lazySrv: LazyService, private platform: Platform) {\n    this.cog = configSrv.merge('qr', QR_DEFULAT_CONFIG)!;\n    Object.assign(this, this.cog);\n  }\n\n  private init(): void {\n    if (!this.inited) {\n      return;\n    }\n\n    if (this.qr == null) {\n      this.qr = new (window as any).QRious();\n    }\n    this.qr.set(this.option);\n    this.dataURL = this.qr.toDataURL();\n    this.change.emit(this.dataURL);\n    this.cdr.detectChanges();\n  }\n\n  private initDelay(): void {\n    this.inited = true;\n    setTimeout(() => this.init(), this.delay);\n  }\n\n  ngAfterViewInit(): void {\n    if (!this.platform.isBrowser) {\n      return;\n    }\n    if ((window as any).QRious) {\n      this.initDelay();\n      return;\n    }\n    const url = this.cog.lib!;\n    this.lazy$ = this.lazySrv.change\n      .pipe(filter(ls => ls.length === 1 && ls[0].path === url && ls[0].status === 'ok'))\n      .subscribe(() => this.initDelay());\n    this.lazySrv.load(url);\n  }\n\n  ngOnChanges(): void {\n    const option: QROptions = {\n      background: this.background,\n      backgroundAlpha: this.backgroundAlpha,\n      foreground: this.foreground,\n      foregroundAlpha: this.foregroundAlpha,\n      level: this.level,\n      mime: this.mime,\n      padding: this.padding,\n      size: this.size,\n      value: this.toUtf8ByteArray(this.value),\n    };\n    this.option = option;\n    this.init();\n  }\n\n  private toUtf8ByteArray(str: string): string {\n    str = encodeURI(str);\n    const result: number[] = [];\n    for (let i = 0; i < str.length; i++) {\n      if (str.charAt(i) !== '%') {\n        result.push(str.charCodeAt(i));\n      } else {\n        result.push(parseInt(str.substr(i + 1, 2), 16));\n        i += 2;\n      }\n    }\n    return result.map(v => String.fromCharCode(v)).join('');\n  }\n\n  ngOnDestroy(): void {\n    if (this.lazy$) {\n      this.lazy$.unsubscribe();\n    }\n  }\n}\n"]}