ngx-signaturepad
Version:
Fork of wulfsolter/angular2-signaturepad
116 lines • 14.7 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.SignaturePad = void 0;
var core_1 = require("@angular/core");
var i0 = require("@angular/core");
;
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"]}
;