UNPKG

ngx-signaturepad

Version:
116 lines 14.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.SignaturePad = void 0; var core_1 = require("@angular/core"); var i0 = require("@angular/core"); 'use strict'; var SignaturePad = /** @class */ (function () { function SignaturePad(elementRef) { // no op this.elementRef = elementRef; this.options = this.options || {}; this.onBeginEvent = new core_1.EventEmitter(); this.onEndEvent = new core_1.EventEmitter(); } SignaturePad.prototype.ngAfterContentInit = function () { var sp = require('signature_pad')['default']; // var canvas = this.elementRef.nativeElement.querySelector('canvas'); if (this.options['canvasHeight']) { canvas.height = this.options['canvasHeight']; } if (this.options['canvasWidth']) { canvas.width = this.options['canvasWidth']; } this.signaturePad = new sp(canvas, this.options); this.signaturePad.onBegin = this.onBegin.bind(this); this.signaturePad.onEnd = this.onEnd.bind(this); }; SignaturePad.prototype.resizeCanvas = function () { // When zoomed out to less than 100%, for some very strange reason, // some browsers report devicePixelRatio as less than 1 // and only part of the canvas is cleared then. var ratio = Math.max(window.devicePixelRatio || 1, 1); var canvas = this.signaturePad._canvas; canvas.width = canvas.offsetWidth * ratio; canvas.height = canvas.offsetHeight * ratio; canvas.getContext('2d').scale(ratio, ratio); this.signaturePad.clear(); // otherwise isEmpty() might return incorrect value }; // Returns signature image as an array of point groups SignaturePad.prototype.toData = function () { return this.signaturePad.toData(); }; // Draws signature image from an array of point groups SignaturePad.prototype.fromData = function (points) { this.signaturePad.fromData(points); }; // Returns signature image as data URL (see https://mdn.io/todataurl for the list of possible paramters) SignaturePad.prototype.toDataURL = function (imageType, quality) { return this.signaturePad.toDataURL(imageType, quality); // save image as data URL }; // Draws signature image from data URL SignaturePad.prototype.fromDataURL = function (dataURL, options) { if (options === void 0) { options = {}; } this.signaturePad.fromDataURL(dataURL, options); }; // Clears the canvas SignaturePad.prototype.clear = function () { this.signaturePad.clear(); }; // Returns true if canvas is empty, otherwise returns false SignaturePad.prototype.isEmpty = function () { return this.signaturePad.isEmpty(); }; // Unbinds all event handlers SignaturePad.prototype.off = function () { this.signaturePad.off(); }; // Rebinds all event handlers SignaturePad.prototype.on = function () { this.signaturePad.on(); }; // set an option on the signaturePad - e.g. set('minWidth', 50); SignaturePad.prototype.set = function (option, value) { switch (option) { case 'canvasHeight': this.signaturePad._canvas.height = value; break; case 'canvasWidth': this.signaturePad._canvas.width = value; break; default: this.signaturePad[option] = value; } }; // notify subscribers on signature begin SignaturePad.prototype.onBegin = function () { this.onBeginEvent.emit(true); }; // notify subscribers on signature end SignaturePad.prototype.onEnd = function () { this.onEndEvent.emit(true); }; SignaturePad.prototype.queryPad = function () { return this.signaturePad; }; SignaturePad.ɵfac = function SignaturePad_Factory(t) { return new (t || SignaturePad)(i0.ɵɵdirectiveInject(i0.ElementRef)); }; SignaturePad.ɵcmp = i0.ɵɵdefineComponent({ type: SignaturePad, selectors: [["signature-pad"]], inputs: { options: "options" }, outputs: { onBeginEvent: "onBeginEvent", onEndEvent: "onEndEvent" }, decls: 1, vars: 0, template: function SignaturePad_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelement(0, "canvas"); } }, encapsulation: 2 }); return SignaturePad; }()); exports.SignaturePad = SignaturePad; (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SignaturePad, [{ type: core_1.Component, args: [{ template: '<canvas></canvas>', selector: 'signature-pad', }] }], function () { return [{ type: i0.ElementRef }]; }, { options: [{ type: core_1.Input }], onBeginEvent: [{ type: core_1.Output }], onEndEvent: [{ type: core_1.Output }] }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature-pad.js","sourceRoot":"","sources":["signature-pad.ts"],"names":[],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nimport { Component, ElementRef, EventEmitter, Input, Output } from '@angular/core';\r\n\r\ndeclare var require: any;\r\n\r\nexport interface Point {\r\n  x: number;\r\n  y: number;\r\n  time: number;\r\n}\r\n\r\nexport type PointGroup = Array<Point>;\r\n\r\n@Component({\r\n  template: '<canvas></canvas>',\r\n  selector: 'signature-pad',\r\n})\r\n\r\nexport class SignaturePad {\r\n\r\n  @Input() public options: Object;\r\n  @Output() public onBeginEvent: EventEmitter<boolean>;\r\n  @Output() public onEndEvent: EventEmitter<boolean>;\r\n\r\n  private signaturePad: any;\r\n  private elementRef: ElementRef;\r\n\r\n  constructor(elementRef: ElementRef) {\r\n    // no op\r\n    this.elementRef = elementRef;\r\n    this.options = this.options || {};\r\n    this.onBeginEvent = new EventEmitter();\r\n    this.onEndEvent = new EventEmitter();\r\n  }\r\n\r\n  public ngAfterContentInit(): void {\r\n    let sp: any = require('signature_pad')['default']; //\r\n    let canvas: any = this.elementRef.nativeElement.querySelector('canvas');\r\n\r\n    if ((<any>this.options)['canvasHeight']) {\r\n      canvas.height = (<any>this.options)['canvasHeight'];\r\n    }\r\n\r\n    if ((<any>this.options)['canvasWidth']) {\r\n      canvas.width = (<any>this.options)['canvasWidth'];\r\n    }\r\n\r\n    this.signaturePad = new sp(canvas, this.options);\r\n    this.signaturePad.onBegin = this.onBegin.bind(this);\r\n    this.signaturePad.onEnd = this.onEnd.bind(this);\r\n  }\r\n\r\n  public resizeCanvas(): void {\r\n    // When zoomed out to less than 100%, for some very strange reason,\r\n    // some browsers report devicePixelRatio as less than 1\r\n    // and only part of the canvas is cleared then.\r\n    const ratio: number = Math.max(window.devicePixelRatio || 1, 1);\r\n    const canvas: any = this.signaturePad._canvas;\r\n    canvas.width = canvas.offsetWidth * ratio;\r\n    canvas.height = canvas.offsetHeight * ratio;\r\n    canvas.getContext('2d').scale(ratio, ratio);\r\n    this.signaturePad.clear(); // otherwise isEmpty() might return incorrect value\r\n  }\r\n\r\n   // Returns signature image as an array of point groups\r\n  public toData(): Array<PointGroup> {\r\n    return this.signaturePad.toData();\r\n  }\r\n\r\n  // Draws signature image from an array of point groups\r\n  public fromData(points: Array<PointGroup>): void {\r\n    this.signaturePad.fromData(points);\r\n  }\r\n\r\n  // Returns signature image as data URL (see https://mdn.io/todataurl for the list of possible paramters)\r\n  public toDataURL(imageType?: string, quality?: number): string {\r\n    return this.signaturePad.toDataURL(imageType, quality); // save image as data URL\r\n  }\r\n\r\n  // Draws signature image from data URL\r\n  public fromDataURL(dataURL: string, options: Object = {}): void {\r\n    this.signaturePad.fromDataURL(dataURL, options);\r\n  }\r\n\r\n  // Clears the canvas\r\n  public clear(): void {\r\n    this.signaturePad.clear();\r\n  }\r\n\r\n  // Returns true if canvas is empty, otherwise returns false\r\n  public isEmpty(): boolean {\r\n    return this.signaturePad.isEmpty();\r\n  }\r\n\r\n  // Unbinds all event handlers\r\n  public off(): void {\r\n    this.signaturePad.off();\r\n  }\r\n\r\n  // Rebinds all event handlers\r\n  public on(): void {\r\n    this.signaturePad.on();\r\n  }\r\n\r\n  // set an option on the signaturePad - e.g. set('minWidth', 50);\r\n  public set(option: string, value: any): void {\r\n    switch (option) {\r\n      case 'canvasHeight':\r\n        this.signaturePad._canvas.height = value;\r\n        break;\r\n      case 'canvasWidth':\r\n        this.signaturePad._canvas.width = value;\r\n        break;\r\n      default:\r\n        this.signaturePad[option] = value;\r\n    }\r\n  }\r\n\r\n  // notify subscribers on signature begin\r\n  public onBegin(): void {\r\n    this.onBeginEvent.emit(true);\r\n  }\r\n\r\n  // notify subscribers on signature end\r\n  public onEnd(): void {\r\n    this.onEndEvent.emit(true);\r\n  }\r\n\r\n  public queryPad(): any {\r\n      return this.signaturePad;\r\n  }\r\n}\r\n"]}