ngx-angular-qrcode
Version:
This library allow you to create beautiful QR Codes in Angular application.
222 lines • 23.7 kB
JavaScript
import { __assign, __decorate } from "tslib";
import { Component, Input, ViewChild } from '@angular/core';
import QRCodeStyling from 'qr-code-styling';
import { DefaultQrConfiguration, QrPreviewSize } from './default-qr-config';
var NgxAngularQrcodeComponent = /** @class */ (function () {
function NgxAngularQrcodeComponent() {
}
NgxAngularQrcodeComponent.prototype.ngOnInit = function () {
};
NgxAngularQrcodeComponent.prototype.ngOnChanges = function (changes) {
this.displayQr();
};
NgxAngularQrcodeComponent.prototype.ngAfterContentInit = function () {
console.debug('🔥 this.qrData', this.qrData);
this.displayQr();
};
NgxAngularQrcodeComponent.prototype.displayQr = function () {
var _a, _b, _c, _d, _e, _f, _g;
if (!QRCodeStyling) {
return;
}
this.qrCodeCanvas.nativeElement.innerHTML = '';
var dotsGradient = {
type: this.dotsGradientType,
rotation: this.dotsGradientRotation,
colorStops: [
{
offset: 0,
color: this.dotsStartColor
},
{
offset: 1,
color: this.dotsEndColor
}
]
};
var cornerSquareGradient = {
type: this.cornerSquareGradientType,
rotation: this.cornerSquareGradientRotation,
colorStops: [
{
offset: 0,
color: this.cornerSquareStartColor
},
{
offset: 1,
color: this.cornerSquareEndColor
}
]
};
var backgroundGradient = {
type: this.backgroundGradientType,
rotation: this.backgroundGradientRotation,
colorStops: [
{
offset: 0,
color: this.backgroundStartColor
},
{
offset: 1,
color: this.backgroundEndColor
}
]
};
var cornerDotGradient = {
type: this.cornerDotGradientType,
rotation: this.cornerDotGradientRotation,
colorStops: [
{
offset: 0,
color: this.cornerDotStartColor
},
{
offset: 1,
color: this.cornerDotEndColor
}
]
};
var config = __assign(__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: __assign({ type: this.dotsType || ((_a = DefaultQrConfiguration.dotsOptions) === null || _a === void 0 ? void 0 : _a.type), color: this.dotsColor }, (this.dotsGradient && { gradient: dotsGradient })), cornersSquareOptions: __assign({ type: this.cornerSquareType || ((_b = DefaultQrConfiguration.cornersSquareOptions) === null || _b === void 0 ? void 0 : _b.type), color: this.cornerSquareColor }, (this.cornerSquareGradient && { gradient: cornerSquareGradient })), cornersDotOptions: __assign({ type: this.cornerDotType || ((_c = DefaultQrConfiguration.cornersDotOptions) === null || _c === void 0 ? void 0 : _c.type), color: this.cornerDotColor }, (this.cornerDotGradient && { gradient: cornerDotGradient })), backgroundOptions: __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);
};
NgxAngularQrcodeComponent.prototype.download = function (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: "\n <div #qrCodeCanvas></div> \n "
})
], NgxAngularQrcodeComponent);
return 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"]}