ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
177 lines (175 loc) • 19.2 kB
JavaScript
/**
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE
*/
import { isPlatformBrowser } from '@angular/common';
import { booleanAttribute, ChangeDetectionStrategy, Component, EventEmitter, inject, Input, numberAttribute, Output, PLATFORM_ID, ViewChild } from '@angular/core';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { NzButtonModule } from 'ng-zorro-antd/button';
import { NzIconModule } from 'ng-zorro-antd/icon';
import { NzSpinModule } from 'ng-zorro-antd/spin';
import { drawCanvas, plotQRCodeData } from './qrcode';
import * as i0 from "@angular/core";
import * as i1 from "ng-zorro-antd/i18n";
import * as i2 from "ng-zorro-antd/spin";
import * as i3 from "ng-zorro-antd/button";
import * as i4 from "ng-zorro-antd/core/transition-patch";
import * as i5 from "ng-zorro-antd/icon";
export class NzQRCodeComponent {
constructor(i18n, el, cdr) {
this.i18n = i18n;
this.el = el;
this.cdr = cdr;
this.nzValue = '';
this.nzPadding = 0;
this.nzColor = '#000000';
this.nzBgColor = '#FFFFFF';
this.nzSize = 160;
this.nzIcon = '';
this.nzIconSize = 40;
this.nzBordered = true;
this.nzStatus = 'active';
this.nzLevel = 'M';
this.nzRefresh = new EventEmitter();
// https://github.com/angular/universal-starter/issues/538#issuecomment-365518693
// canvas is not supported by the SSR DOM
this.isBrowser = true;
this.destroy$ = new Subject();
this.platformId = inject(PLATFORM_ID);
this.isBrowser = isPlatformBrowser(this.platformId);
this.cdr.markForCheck();
}
ngOnInit() {
this.el.nativeElement.style.backgroundColor = this.nzBgColor;
this.i18n.localeChange.pipe(takeUntil(this.destroy$)).subscribe(() => {
this.locale = this.i18n.getLocaleData('QRCode');
this.cdr.markForCheck();
});
}
ngOnChanges(changes) {
const { nzValue, nzIcon, nzLevel, nzSize, nzIconSize, nzColor, nzPadding, nzBgColor } = changes;
if ((nzValue || nzIcon || nzLevel || nzSize || nzIconSize || nzColor || nzPadding || nzBgColor) && this.canvas) {
this.drawCanvasQRCode();
}
if (nzBgColor) {
this.el.nativeElement.style.backgroundColor = this.nzBgColor;
}
}
ngAfterViewInit() {
this.drawCanvasQRCode();
}
reloadQRCode() {
this.drawCanvasQRCode();
this.nzRefresh.emit('refresh');
}
drawCanvasQRCode() {
if (this.canvas) {
drawCanvas(this.canvas.nativeElement, plotQRCodeData(this.nzValue, this.nzLevel), this.nzSize, 10, this.nzPadding, this.nzColor, this.nzBgColor, this.nzIconSize, this.nzIcon);
}
}
ngOnDestroy() {
this.destroy$.next();
this.destroy$.complete();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzQRCodeComponent, deps: [{ token: i1.NzI18nService }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.2", type: NzQRCodeComponent, isStandalone: true, selector: "nz-qrcode", inputs: { nzValue: "nzValue", nzPadding: "nzPadding", nzColor: "nzColor", nzBgColor: "nzBgColor", nzSize: ["nzSize", "nzSize", numberAttribute], nzIcon: "nzIcon", nzIconSize: ["nzIconSize", "nzIconSize", numberAttribute], nzBordered: ["nzBordered", "nzBordered", booleanAttribute], nzStatus: "nzStatus", nzLevel: "nzLevel" }, outputs: { nzRefresh: "nzRefresh" }, host: { properties: { "class.ant-qrcode-border": "nzBordered" }, classAttribute: "ant-qrcode" }, viewQueries: [{ propertyName: "canvas", first: true, predicate: ["canvas"], descendants: true }], exportAs: ["nzQRCode"], usesOnChanges: true, ngImport: i0, template: `
(nzStatus !== 'active') {
<div class="ant-qrcode-mask">
(nzStatus) {
('loading') {
<nz-spin />
}
('expired') {
<div>
<p class="ant-qrcode-expired">{{ locale.expired }}</p>
<button nz-button nzType="link" (click)="reloadQRCode()">
<span nz-icon nzType="reload" nzTheme="outline"></span>
<span>{{ locale.refresh }}</span>
</button>
</div>
}
('scanned') {
<div>
<p class="ant-qrcode-expired">{{ locale.scanned }}</p>
</div>
}
}
</div>
}
(isBrowser) {
<canvas #canvas></canvas>
}
`, isInline: true, dependencies: [{ kind: "ngmodule", type: NzSpinModule }, { kind: "component", type: i2.NzSpinComponent, selector: "nz-spin", inputs: ["nzIndicator", "nzSize", "nzTip", "nzDelay", "nzSimple", "nzSpinning"], exportAs: ["nzSpin"] }, { kind: "ngmodule", type: NzButtonModule }, { kind: "component", type: i3.NzButtonComponent, selector: "button[nz-button], a[nz-button]", inputs: ["nzBlock", "nzGhost", "nzSearch", "nzLoading", "nzDanger", "disabled", "tabIndex", "nzType", "nzShape", "nzSize"], exportAs: ["nzButton"] }, { kind: "directive", type: i4.ɵNzTransitionPatchDirective, selector: "[nz-button], nz-button-group, [nz-icon], [nz-menu-item], [nz-submenu], nz-select-top-control, nz-select-placeholder, nz-input-group", inputs: ["hidden"] }, { kind: "ngmodule", type: NzIconModule }, { kind: "directive", type: i5.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzQRCodeComponent, decorators: [{
type: Component,
args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
selector: 'nz-qrcode',
exportAs: 'nzQRCode',
template: `
(nzStatus !== 'active') {
<div class="ant-qrcode-mask">
(nzStatus) {
('loading') {
<nz-spin />
}
('expired') {
<div>
<p class="ant-qrcode-expired">{{ locale.expired }}</p>
<button nz-button nzType="link" (click)="reloadQRCode()">
<span nz-icon nzType="reload" nzTheme="outline"></span>
<span>{{ locale.refresh }}</span>
</button>
</div>
}
('scanned') {
<div>
<p class="ant-qrcode-expired">{{ locale.scanned }}</p>
</div>
}
}
</div>
}
(isBrowser) {
<canvas #canvas></canvas>
}
`,
host: {
class: 'ant-qrcode',
'[class.ant-qrcode-border]': `nzBordered`
},
imports: [NzSpinModule, NzButtonModule, NzIconModule],
standalone: true
}]
}], ctorParameters: () => [{ type: i1.NzI18nService }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], propDecorators: { canvas: [{
type: ViewChild,
args: ['canvas', { static: false }]
}], nzValue: [{
type: Input
}], nzPadding: [{
type: Input
}], nzColor: [{
type: Input
}], nzBgColor: [{
type: Input
}], nzSize: [{
type: Input,
args: [{ transform: numberAttribute }]
}], nzIcon: [{
type: Input
}], nzIconSize: [{
type: Input,
args: [{ transform: numberAttribute }]
}], nzBordered: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], nzStatus: [{
type: Input
}], nzLevel: [{
type: Input
}], nzRefresh: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"qrcode.component.js","sourceRoot":"","sources":["../../../components/qr-code/qrcode.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { isPlatformBrowser } from '@angular/common';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  numberAttribute,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  PLATFORM_ID,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { NzButtonModule } from 'ng-zorro-antd/button';\nimport { NzI18nService, NzQRCodeI18nInterface } from 'ng-zorro-antd/i18n';\nimport { NzIconModule } from 'ng-zorro-antd/icon';\nimport { NzSpinModule } from 'ng-zorro-antd/spin';\n\nimport { drawCanvas, ERROR_LEVEL_MAP, plotQRCodeData } from './qrcode';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'nz-qrcode',\n  exportAs: 'nzQRCode',\n  template: `\n    @if (nzStatus !== 'active') {\n      <div class=\"ant-qrcode-mask\">\n        @switch (nzStatus) {\n          @case ('loading') {\n            <nz-spin />\n          }\n          @case ('expired') {\n            <div>\n              <p class=\"ant-qrcode-expired\">{{ locale.expired }}</p>\n              <button nz-button nzType=\"link\" (click)=\"reloadQRCode()\">\n                <span nz-icon nzType=\"reload\" nzTheme=\"outline\"></span>\n                <span>{{ locale.refresh }}</span>\n              </button>\n            </div>\n          }\n          @case ('scanned') {\n            <div>\n              <p class=\"ant-qrcode-expired\">{{ locale.scanned }}</p>\n            </div>\n          }\n        }\n      </div>\n    }\n\n    @if (isBrowser) {\n      <canvas #canvas></canvas>\n    }\n  `,\n  host: {\n    class: 'ant-qrcode',\n    '[class.ant-qrcode-border]': `nzBordered`\n  },\n  imports: [NzSpinModule, NzButtonModule, NzIconModule],\n  standalone: true\n})\nexport class NzQRCodeComponent implements OnInit, AfterViewInit, OnChanges, OnDestroy {\n  @ViewChild('canvas', { static: false }) canvas!: ElementRef<HTMLCanvasElement>;\n  @Input() nzValue: string = '';\n  @Input() nzPadding: number | number[] = 0;\n  @Input() nzColor: string = '#000000';\n  @Input() nzBgColor: string = '#FFFFFF';\n  @Input({ transform: numberAttribute }) nzSize: number = 160;\n  @Input() nzIcon: string = '';\n  @Input({ transform: numberAttribute }) nzIconSize: number = 40;\n  @Input({ transform: booleanAttribute }) nzBordered: boolean = true;\n  @Input() nzStatus: 'active' | 'expired' | 'loading' | 'scanned' = 'active';\n  @Input() nzLevel: keyof typeof ERROR_LEVEL_MAP = 'M';\n\n  @Output() readonly nzRefresh = new EventEmitter<string>();\n\n  locale!: NzQRCodeI18nInterface;\n  // https://github.com/angular/universal-starter/issues/538#issuecomment-365518693\n  // canvas is not supported by the SSR DOM\n  isBrowser = true;\n  private destroy$ = new Subject<void>();\n  private platformId = inject(PLATFORM_ID);\n\n  constructor(\n    private i18n: NzI18nService,\n    private el: ElementRef,\n    private cdr: ChangeDetectorRef\n  ) {\n    this.isBrowser = isPlatformBrowser(this.platformId);\n    this.cdr.markForCheck();\n  }\n\n  ngOnInit(): void {\n    this.el.nativeElement.style.backgroundColor = this.nzBgColor;\n    this.i18n.localeChange.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.locale = this.i18n.getLocaleData('QRCode');\n      this.cdr.markForCheck();\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { nzValue, nzIcon, nzLevel, nzSize, nzIconSize, nzColor, nzPadding, nzBgColor } = changes;\n    if ((nzValue || nzIcon || nzLevel || nzSize || nzIconSize || nzColor || nzPadding || nzBgColor) && this.canvas) {\n      this.drawCanvasQRCode();\n    }\n\n    if (nzBgColor) {\n      this.el.nativeElement.style.backgroundColor = this.nzBgColor;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.drawCanvasQRCode();\n  }\n\n  reloadQRCode(): void {\n    this.drawCanvasQRCode();\n    this.nzRefresh.emit('refresh');\n  }\n\n  drawCanvasQRCode(): void {\n    if (this.canvas) {\n      drawCanvas(\n        this.canvas.nativeElement,\n        plotQRCodeData(this.nzValue, this.nzLevel),\n        this.nzSize,\n        10,\n        this.nzPadding,\n        this.nzColor,\n        this.nzBgColor,\n        this.nzIconSize,\n        this.nzIcon\n      );\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}