ngx-angular-qrcode
Version:
This library allow you to create beautiful QR Codes in Angular application.
221 lines • 22.8 kB
JavaScript
import { __decorate } from "tslib";
import { Component, Input, ViewChild } from '@angular/core';
import QRCodeStyling from 'qr-code-styling';
import { DefaultQrConfiguration, QrPreviewSize } from './default-qr-config';
let NgxAngularQrcodeComponent = class NgxAngularQrcodeComponent {
ngOnInit() {
}
ngOnChanges(changes) {
this.displayQr();
}
ngAfterContentInit() {
console.debug('🔥 this.qrData', this.qrData);
this.displayQr();
}
displayQr() {
var _a, _b, _c, _d, _e, _f, _g;
if (!QRCodeStyling) {
return;
}
this.qrCodeCanvas.nativeElement.innerHTML = '';
const dotsGradient = {
type: this.dotsGradientType,
rotation: this.dotsGradientRotation,
colorStops: [
{
offset: 0,
color: this.dotsStartColor
},
{
offset: 1,
color: this.dotsEndColor
}
]
};
const cornerSquareGradient = {
type: this.cornerSquareGradientType,
rotation: this.cornerSquareGradientRotation,
colorStops: [
{
offset: 0,
color: this.cornerSquareStartColor
},
{
offset: 1,
color: this.cornerSquareEndColor
}
]
};
const backgroundGradient = {
type: this.backgroundGradientType,
rotation: this.backgroundGradientRotation,
colorStops: [
{
offset: 0,
color: this.backgroundStartColor
},
{
offset: 1,
color: this.backgroundEndColor
}
]
};
const cornerDotGradient = {
type: this.cornerDotGradientType,
rotation: this.cornerDotGradientRotation,
colorStops: [
{
offset: 0,
color: this.cornerDotStartColor
},
{
offset: 1,
color: this.cornerDotEndColor
}
]
};
let config = Object.assign(Object.assign({}, DefaultQrConfiguration), { shape: this.shape, width: this.width || QrPreviewSize.width, height: this.height || QrPreviewSize.height, margin: this.margin || DefaultQrConfiguration.margin, data: this.qrData || 'https://qrtrac.com', image: this.imageUrl, dotsOptions: Object.assign({ type: this.dotsType || ((_a = DefaultQrConfiguration.dotsOptions) === null || _a === void 0 ? void 0 : _a.type), color: this.dotsColor }, (this.dotsGradient && { gradient: dotsGradient })), cornersSquareOptions: Object.assign({ type: this.cornerSquareType || ((_b = DefaultQrConfiguration.cornersSquareOptions) === null || _b === void 0 ? void 0 : _b.type), color: this.cornerSquareColor }, (this.cornerSquareGradient && { gradient: cornerSquareGradient })), cornersDotOptions: Object.assign({ type: this.cornerDotType || ((_c = DefaultQrConfiguration.cornersDotOptions) === null || _c === void 0 ? void 0 : _c.type), color: this.cornerDotColor }, (this.cornerDotGradient && { gradient: cornerDotGradient })), backgroundOptions: Object.assign({ color: this.backgroundColor }, (this.backgroundGradient && { gradient: backgroundGradient })), imageOptions: {
imageSize: this.imageSize || ((_d = DefaultQrConfiguration.imageOptions) === null || _d === void 0 ? void 0 : _d.imageSize),
margin: this.imageMargin || ((_e = DefaultQrConfiguration.imageOptions) === null || _e === void 0 ? void 0 : _e.margin),
hideBackgroundDots: this.hideImageBackgroundDots || ((_f = DefaultQrConfiguration.imageOptions) === null || _f === void 0 ? void 0 : _f.hideBackgroundDots)
}, qrOptions: {
errorCorrectionLevel: this.errorCorrectionLevel || ((_g = DefaultQrConfiguration.qrOptions) === null || _g === void 0 ? void 0 : _g.errorCorrectionLevel)
} });
this.qrCodeStyle = new QRCodeStyling(config);
this.qrCodeStyle.append(this.qrCodeCanvas.nativeElement);
}
download(fileExtension, qrName) {
console.debug('🔥 download called');
this.qrCodeStyle.download({
name: qrName || 'ngxs-qrcode',
extension: fileExtension
});
}
};
__decorate([
ViewChild('qrCodeCanvas', { static: true })
], NgxAngularQrcodeComponent.prototype, "qrCodeCanvas", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "qrData", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "imageUrl", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "shape", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "width", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "height", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "margin", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "dotsType", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "dotsGradient", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "dotsGradientType", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "dotsGradientRotation", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "dotsColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "dotsStartColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "dotsEndColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerSquareType", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerSquareGradient", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerSquareGradientType", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerSquareGradientRotation", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerSquareColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerSquareStartColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerSquareEndColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerDotType", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerDotGradient", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerDotGradientType", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerDotGradientRotation", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerDotColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerDotStartColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "cornerDotEndColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "backgroundType", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "backgroundGradient", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "backgroundGradientType", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "backgroundGradientRotation", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "backgroundColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "backgroundStartColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "backgroundEndColor", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "imageSize", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "imageMargin", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "hideImageBackgroundDots", void 0);
__decorate([
Input()
], NgxAngularQrcodeComponent.prototype, "errorCorrectionLevel", void 0);
NgxAngularQrcodeComponent = __decorate([
Component({
selector: 'qr-code',
template: `
<div #qrCodeCanvas></div>
`
})
], NgxAngularQrcodeComponent);
export { NgxAngularQrcodeComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-angular-qrcode.component.js","sourceRoot":"ng://ngx-angular-qrcode/","sources":["lib/ngx-angular-qrcode.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ElementRef, Input, OnChanges, SimpleChanges, ViewChild } from '@angular/core';\nimport QRCodeStyling, { CornerDotType, CornerSquareType, DotType, ErrorCorrectionLevel, FileExtension, Gradient, GradientType, gradientTypes, Options, ShapeType } from 'qr-code-styling';\nimport { DefaultQrConfiguration, QrPreviewSize } from './default-qr-config';\n\n@Component({\n  selector: 'qr-code',\n  template: `\n        <div #qrCodeCanvas></div>    \n  `,\n  styles: [\n  ]\n})\nexport class NgxAngularQrcodeComponent implements OnChanges, AfterContentInit {\n  @ViewChild('qrCodeCanvas', { static: true }) qrCodeCanvas!: ElementRef;\n\n  @Input() qrData!: string;\n  @Input() imageUrl!: string;\n  @Input() shape!: string | ShapeType;\n  @Input() width!: number;\n  @Input() height!: number;\n  @Input() margin!: number;\n\n  // Dots Options\n  @Input() dotsType!: string;\n  @Input() dotsGradient!: boolean;\n  @Input() dotsGradientType!: string;\n  @Input() dotsGradientRotation!: number;\n  @Input() dotsColor!: string;\n  @Input() dotsStartColor!: string;\n  @Input() dotsEndColor!: string;\n\n  // Corners Square Options\n  @Input() cornerSquareType!: string;\n  @Input() cornerSquareGradient!: boolean;\n  @Input() cornerSquareGradientType!: string;\n  @Input() cornerSquareGradientRotation!: number;\n  @Input() cornerSquareColor!: string;\n  @Input() cornerSquareStartColor!: string;\n  @Input() cornerSquareEndColor!: string;\n\n  // Corners Dot Options\n  @Input() cornerDotType!: string;\n  @Input() cornerDotGradient!: boolean;\n  @Input() cornerDotGradientType!: string;\n  @Input() cornerDotGradientRotation!: number;\n  @Input() cornerDotColor!: string;\n  @Input() cornerDotStartColor!: string;\n  @Input() cornerDotEndColor!: string;\n\n  // Background Options\n  @Input() backgroundType!: string;\n  @Input() backgroundGradient!: boolean;\n  @Input() backgroundGradientType!: string;\n  @Input() backgroundGradientRotation!: number;\n  @Input() backgroundColor!: string;\n  @Input() backgroundStartColor!: string;\n  @Input() backgroundEndColor!: string;\n\n  // Image Options\n  @Input() imageSize!: number;\n  @Input() imageMargin!: number;\n  @Input() hideImageBackgroundDots!: boolean;\n\n  @Input() errorCorrectionLevel!: string;\n\n  private qrCodeStyle!: QRCodeStyling;\n\n  ngOnInit(): void {\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.displayQr();\n  }\n\n  ngAfterContentInit(): void {\n    console.debug('🔥 this.qrData', this.qrData);\n    this.displayQr();\n  }\n\n  displayQr(): void {\n    if (!QRCodeStyling) {\n      return;\n    }\n    this.qrCodeCanvas.nativeElement.innerHTML = '';\n    const dotsGradient: Gradient = {\n      type: this.dotsGradientType as GradientType,\n      rotation: this.dotsGradientRotation,\n      colorStops: [\n        {\n          offset: 0,\n          color: this.dotsStartColor\n        },\n        {\n          offset: 1,\n          color: this.dotsEndColor\n        }\n      ]\n    }\n\n    const cornerSquareGradient: Gradient = {\n      type: this.cornerSquareGradientType as GradientType,\n      rotation: this.cornerSquareGradientRotation,\n      colorStops: [\n        {\n          offset: 0,\n          color: this.cornerSquareStartColor\n        },\n        {\n          offset: 1,\n          color: this.cornerSquareEndColor\n        }\n      ]\n    }\n    const backgroundGradient: Gradient = {\n      type: this.backgroundGradientType as GradientType,\n      rotation: this.backgroundGradientRotation,\n      colorStops: [\n        {\n          offset: 0,\n          color: this.backgroundStartColor\n        },\n        {\n          offset: 1,\n          color: this.backgroundEndColor\n        }\n      ]\n    }\n    const cornerDotGradient: Gradient = {\n      type: this.cornerDotGradientType as GradientType,\n      rotation: this.cornerDotGradientRotation,\n      colorStops: [\n        {\n          offset: 0,\n          color: this.cornerDotStartColor\n        },\n        {\n          offset: 1,\n          color: this.cornerDotEndColor\n        }\n      ]\n    }\n\n    let config: Options = {\n      ...DefaultQrConfiguration,\n      shape: this.shape as ShapeType,\n      width: this.width || QrPreviewSize.width,\n      height: this.height || QrPreviewSize.height,\n      margin: this.margin || DefaultQrConfiguration.margin,\n      data: this.qrData || 'https://qrtrac.com',\n      image: this.imageUrl,\n      dotsOptions: {\n        type: this.dotsType as DotType || DefaultQrConfiguration.dotsOptions?.type,\n        color: this.dotsColor,\n        ...(this.dotsGradient && { gradient: dotsGradient })\n      },\n      cornersSquareOptions: {\n        type: this.cornerSquareType as CornerSquareType || DefaultQrConfiguration.cornersSquareOptions?.type,\n        color: this.cornerSquareColor,\n        ...(this.cornerSquareGradient && { gradient: cornerSquareGradient })\n      },\n      cornersDotOptions: {\n        type: this.cornerDotType as CornerDotType || DefaultQrConfiguration.cornersDotOptions?.type,\n        color: this.cornerDotColor,\n        ...(this.cornerDotGradient && { gradient: cornerDotGradient })\n      },\n      backgroundOptions: {\n        color: this.backgroundColor,\n        ...(this.backgroundGradient && { gradient: backgroundGradient })\n      },\n      imageOptions: {\n        imageSize: this.imageSize || DefaultQrConfiguration.imageOptions?.imageSize,\n        margin: this.imageMargin || DefaultQrConfiguration.imageOptions?.margin,\n        hideBackgroundDots: this.hideImageBackgroundDots || DefaultQrConfiguration.imageOptions?.hideBackgroundDots\n      },\n      qrOptions: {\n        errorCorrectionLevel: this.errorCorrectionLevel as ErrorCorrectionLevel || DefaultQrConfiguration.qrOptions?.errorCorrectionLevel\n      }\n    };\n\n    this.qrCodeStyle = new QRCodeStyling(config);\n    this.qrCodeStyle.append(this.qrCodeCanvas.nativeElement);\n  }\n\n  download(fileExtension: string, qrName?: string): void {\n    console.debug('🔥 download called',);\n    this.qrCodeStyle.download({\n      name: qrName || 'ngxs-qrcode',\n      extension: fileExtension as FileExtension\n    })\n  }\n\n}\n"]}