@netgrif/components
Version:
Netgrif Application Engine frontend Angular components
105 lines • 18.6 kB
JavaScript
import { Component, HostListener, Inject, Optional, ViewChild } from '@angular/core';
import { DATA_FIELD_PORTAL_DATA, AbstractSimpleTextFieldComponent } from '@netgrif/components-core';
import { filter } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "@ngx-translate/core";
import * as i2 from "@angular/common";
import * as i3 from "@ngbracket/ngx-layout/extended";
import * as i4 from "@angular/material/button";
export class SignaturePadFieldComponent extends AbstractSimpleTextFieldComponent {
_translate;
_ngZone;
signPad;
canvasDiv;
signatureImg;
signPadElement;
context;
isDrawing;
canvasWidth;
canvasHeight;
aspectRatio = 0.2;
constructor(_translate, _ngZone, dataFieldPortalData) {
super(_translate, dataFieldPortalData);
this._translate = _translate;
this._ngZone = _ngZone;
}
ngAfterViewInit() {
setTimeout(() => {
this.signPadElement = this.signPad.nativeElement;
this.context = this.signPadElement.getContext('2d');
this.canvasWidth = this.canvasDiv.nativeElement.clientWidth - 2;
this.canvasHeight = this.canvasWidth * this.aspectRatio;
this.formControlRef.valueChanges.pipe(filter(value => value !== this.signatureImg)).subscribe(value => {
this.signatureImg = value;
const img = new Image();
img.onload = () => {
this.context.drawImage(img, 0, 0, this.canvasWidth, this.canvasHeight);
};
img.src = this.signatureImg;
});
});
}
onMouseDown(e) {
this.isDrawing = true;
const coords = this.relativeCoords(e);
this.context.moveTo(coords.x, coords.y);
}
onMouseUp(e) {
this.isDrawing = false;
}
mouseUp(e) {
this.isDrawing = false;
this.saveSignature();
}
onMouseMove(e) {
if (this.isDrawing) {
const coords = this.relativeCoords(e);
this.context.lineTo(coords.x, coords.y);
this.context.stroke();
}
}
clearSignature() {
this.signatureImg = undefined;
this.context.clearRect(0, 0, this.signPadElement.width, this.signPadElement.height);
this.context.beginPath();
this.formControlRef.setValue(undefined);
}
saveSignature() {
this.signatureImg = this.signPadElement.toDataURL('image/png');
this.formControlRef.setValue(this.signatureImg);
}
relativeCoords(event) {
const bounds = event.target.getBoundingClientRect();
const cords = {
clientX: event.clientX || event.changedTouches[0].clientX,
clientY: event.clientY || event.changedTouches[0].clientY
};
const x = cords.clientX - bounds.left;
const y = cords.clientY - bounds.top;
return { x, y };
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SignaturePadFieldComponent, deps: [{ token: i1.TranslateService }, { token: i0.NgZone }, { token: DATA_FIELD_PORTAL_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SignaturePadFieldComponent, selector: "nc-signature-pad-field", host: { listeners: { "document:mouseup": "onMouseUp($event)", "document:blur": "mouseUp($event)" } }, viewQueries: [{ propertyName: "signPad", first: true, predicate: ["signPad"], descendants: true }, { propertyName: "canvasDiv", first: true, predicate: ["canvasDiv"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"canvas-div\" #canvasDiv [ngClass]=\"{'canvas-disabled': formControlRef.disabled}\" (blur)=\"mouseUp($event)\">\n <canvas (mousedown)=\"onMouseDown($event)\" (mousemove)=\"onMouseMove($event)\" (touchmove)=\"onMouseMove($event)\"\n (touchstart)=\"onMouseDown($event)\" #signPad width=\"{{canvasWidth}}\" (blur)=\"mouseUp($event)\" height=\"{{canvasHeight}}\"\n class=\"canvas\" [ngClass]=\"{'canvas-background-disabled': formControlRef.disabled}\">\n </canvas>\n</div>\n<button mat-stroked-button color=\"primary\" *ngIf=\"!formControlRef.disabled\" (click)=\"clearSignature()\">{{'dataField.clear' | translate }}</button>\n<button mat-stroked-button *ngIf=\"!formControlRef.disabled\" (click)=\"saveSignature()\">{{'dataField.save' | translate }}</button>\n\n", styles: [".canvas-div{width:100%;height:100%}.canvas{border:1px solid #64748B;border-radius:6px;-webkit-text-stroke-color:#000}.canvas-disabled{cursor:not-allowed;pointer-events:none}.canvas-background-disabled{background-color:#cbd5e1;pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SignaturePadFieldComponent, decorators: [{
type: Component,
args: [{ selector: 'nc-signature-pad-field', template: "<div class=\"canvas-div\" #canvasDiv [ngClass]=\"{'canvas-disabled': formControlRef.disabled}\" (blur)=\"mouseUp($event)\">\n <canvas (mousedown)=\"onMouseDown($event)\" (mousemove)=\"onMouseMove($event)\" (touchmove)=\"onMouseMove($event)\"\n (touchstart)=\"onMouseDown($event)\" #signPad width=\"{{canvasWidth}}\" (blur)=\"mouseUp($event)\" height=\"{{canvasHeight}}\"\n class=\"canvas\" [ngClass]=\"{'canvas-background-disabled': formControlRef.disabled}\">\n </canvas>\n</div>\n<button mat-stroked-button color=\"primary\" *ngIf=\"!formControlRef.disabled\" (click)=\"clearSignature()\">{{'dataField.clear' | translate }}</button>\n<button mat-stroked-button *ngIf=\"!formControlRef.disabled\" (click)=\"saveSignature()\">{{'dataField.save' | translate }}</button>\n\n", styles: [".canvas-div{width:100%;height:100%}.canvas{border:1px solid #64748B;border-radius:6px;-webkit-text-stroke-color:#000}.canvas-disabled{cursor:not-allowed;pointer-events:none}.canvas-background-disabled{background-color:#cbd5e1;pointer-events:none}\n"] }]
}], ctorParameters: () => [{ type: i1.TranslateService }, { type: i0.NgZone }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [DATA_FIELD_PORTAL_DATA]
}] }], propDecorators: { signPad: [{
type: ViewChild,
args: ['signPad', { static: false }]
}], canvasDiv: [{
type: ViewChild,
args: ['canvasDiv']
}], onMouseUp: [{
type: HostListener,
args: ['document:mouseup', ['$event']]
}], mouseUp: [{
type: HostListener,
args: ['document:blur', ['$event']]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature-pad-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components/src/lib/data-fields/text-field/signature-pad-field/signature-pad-field.component.ts","../../../../../../../projects/netgrif-components/src/lib/data-fields/text-field/signature-pad-field/signature-pad-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    HostListener,\n    Inject,\n    NgZone,\n    Optional,\n    ViewChild\n} from '@angular/core';\nimport {TranslateService} from '@ngx-translate/core';\nimport {\n    DATA_FIELD_PORTAL_DATA,\n    DataFieldPortalData,\n    TextAreaField,\n    AbstractSimpleTextFieldComponent\n} from '@netgrif/components-core';\nimport {filter} from 'rxjs/operators';\n\n@Component({\n    selector: 'nc-signature-pad-field',\n    templateUrl: './signature-pad-field.component.html',\n    styleUrls: ['./signature-pad-field.component.scss']\n})\nexport class SignaturePadFieldComponent extends AbstractSimpleTextFieldComponent implements AfterViewInit {\n\n    @ViewChild('signPad', {static: false}) signPad!: ElementRef<HTMLCanvasElement>;\n    @ViewChild('canvasDiv') canvasDiv!: ElementRef<HTMLCanvasElement>;\n    protected signatureImg?: string;\n    protected signPadElement: any;\n    protected context: any;\n    protected isDrawing!: boolean;\n    public canvasWidth: number;\n    public canvasHeight: number;\n    public aspectRatio = 0.2;\n\n    constructor(protected _translate: TranslateService, protected _ngZone: NgZone,\n                @Optional() @Inject(DATA_FIELD_PORTAL_DATA) dataFieldPortalData: DataFieldPortalData<TextAreaField>) {\n        super(_translate, dataFieldPortalData);\n    }\n\n    public ngAfterViewInit(): void {\n        setTimeout(() => {\n            this.signPadElement = this.signPad.nativeElement;\n            this.context = this.signPadElement.getContext('2d');\n            this.canvasWidth = this.canvasDiv.nativeElement.clientWidth - 2;\n            this.canvasHeight = this.canvasWidth * this.aspectRatio;\n            this.formControlRef.valueChanges.pipe(\n                filter(value => value !== this.signatureImg)\n            ).subscribe(value => {\n                this.signatureImg = value;\n                const img = new Image();\n                img.onload = () => {\n                    this.context.drawImage(img, 0, 0, this.canvasWidth, this.canvasHeight);\n                };\n                img.src = this.signatureImg;\n            });\n        });\n    }\n\n    onMouseDown(e: any): void {\n        this.isDrawing = true;\n        const coords = this.relativeCoords(e);\n        this.context.moveTo(coords.x, coords.y);\n    }\n\n    @HostListener('document:mouseup', ['$event'])\n    onMouseUp(e: any): void {\n        this.isDrawing = false;\n    }\n\n    @HostListener('document:blur', ['$event'])\n    mouseUp(e: any): void {\n        this.isDrawing = false;\n        this.saveSignature();\n    }\n\n    onMouseMove(e: any): void {\n        if (this.isDrawing) {\n            const coords = this.relativeCoords(e);\n            this.context.lineTo(coords.x, coords.y);\n            this.context.stroke();\n        }\n    }\n\n    clearSignature(): void {\n        this.signatureImg = undefined;\n        this.context.clearRect(0, 0, this.signPadElement.width, this.signPadElement.height);\n        this.context.beginPath();\n        this.formControlRef.setValue(undefined);\n    }\n\n    saveSignature(): void {\n        this.signatureImg = this.signPadElement.toDataURL('image/png');\n        this.formControlRef.setValue(this.signatureImg);\n    }\n\n    protected relativeCoords(event: any): { x: number, y: number } {\n        const bounds = event.target.getBoundingClientRect();\n        const cords = {\n            clientX: event.clientX || event.changedTouches[0].clientX,\n            clientY: event.clientY || event.changedTouches[0].clientY\n        };\n        const x = cords.clientX - bounds.left;\n        const y = cords.clientY - bounds.top;\n        return {x, y};\n    }\n}\n","<div class=\"canvas-div\" #canvasDiv [ngClass]=\"{'canvas-disabled': formControlRef.disabled}\" (blur)=\"mouseUp($event)\">\n    <canvas (mousedown)=\"onMouseDown($event)\" (mousemove)=\"onMouseMove($event)\" (touchmove)=\"onMouseMove($event)\"\n            (touchstart)=\"onMouseDown($event)\" #signPad width=\"{{canvasWidth}}\" (blur)=\"mouseUp($event)\" height=\"{{canvasHeight}}\"\n            class=\"canvas\" [ngClass]=\"{'canvas-background-disabled': formControlRef.disabled}\">\n    </canvas>\n</div>\n<button mat-stroked-button color=\"primary\" *ngIf=\"!formControlRef.disabled\" (click)=\"clearSignature()\">{{'dataField.clear' | translate }}</button>\n<button mat-stroked-button *ngIf=\"!formControlRef.disabled\" (click)=\"saveSignature()\">{{'dataField.save' | translate }}</button>\n\n"]}