@ohayojp.com/components
Version:
Common business components of ohayojp.
256 lines • 17.6 kB
JavaScript
/**
* @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"]}