/* global jsPDF */
/**
* @license
* Copyright (c) 2014 Steven Spungin (TwelveTone LLC) steven@twelvetone.tv
*
* Licensed under the MIT License.
* http://opensource.org/licenses/mit-license
*/
/**
* jsPDF Canvas PlugIn
* This plugin mimics the HTML5 Canvas
*
* The goal is to provide a way for current canvas users to print directly to a PDF.
* @name canvas
* @module
*/
(function(jsPDFAPI) {
"use strict";
/**
* @class Canvas
* @classdesc A Canvas Wrapper for jsPDF
*/
var Canvas = function() {
var jsPdfInstance = undefined;
Object.defineProperty(this, "pdf", {
get: function() {
return jsPdfInstance;
},
set: function(value) {
jsPdfInstance = value;
}
});
var _width = 150;
/**
* The height property is a positive integer reflecting the height HTML attribute of the <canvas> element interpreted in CSS pixels. When the attribute is not specified, or if it is set to an invalid value, like a negative, the default value of 150 is used.
* This is one of the two properties, the other being width, that controls the size of the canvas.
*
* @name width
*/
Object.defineProperty(this, "width", {
get: function() {
return _width;
},
set: function(value) {
if (isNaN(value) || Number.isInteger(value) === false || value < 0) {
_width = 150;
} else {
_width = value;
}
if (this.getContext("2d").pageWrapXEnabled) {
this.getContext("2d").pageWrapX = _width + 1;
}
}
});
var _height = 300;
/**
* The width property is a positive integer reflecting the width HTML attribute of the <canvas> element interpreted in CSS pixels. When the attribute is not specified, or if it is set to an invalid value, like a negative, the default value of 300 is used.
* This is one of the two properties, the other being height, that controls the size of the canvas.
*
* @name height
*/
Object.defineProperty(this, "height", {
get: function() {
return _height;
},
set: function(value) {
if (isNaN(value) || Number.isInteger(value) === false || value < 0) {
_height = 300;
} else {
_height = value;
}
if (this.getContext("2d").pageWrapYEnabled) {
this.getContext("2d").pageWrapY = _height + 1;
}
}
});
var _childNodes = [];
Object.defineProperty(this, "childNodes", {
get: function() {
return _childNodes;
},
set: function(value) {
_childNodes = value;
}
});
var _style = {};
Object.defineProperty(this, "style", {
get: function() {
return _style;
},
set: function(value) {
_style = value;
}
});
Object.defineProperty(this, "parentNode", {});
};
/**
* The getContext() method returns a drawing context on the canvas, or null if the context identifier is not supported.
*
* @name getContext
* @function
* @param {string} contextType Is a String containing the context identifier defining the drawing context associated to the canvas. Possible value is "2d", leading to the creation of a Context2D object representing a two-dimensional rendering context.
* @param {object} contextAttributes
*/
Canvas.prototype.getContext = function(contextType, contextAttributes) {
contextType = contextType || "2d";
var key;
if (contextType !== "2d") {
return null;
}
for (key in contextAttributes) {
if (this.pdf.context2d.hasOwnProperty(key)) {
this.pdf.context2d[key] = contextAttributes[key];
}
}
this.pdf.context2d._canvas = this;
return this.pdf.context2d;
};
/**
* The toDataURL() method is just a stub to throw an error if accidently called.
*
* @name toDataURL
* @function
*/
Canvas.prototype.toDataURL = function() {
throw new Error("toDataURL is not implemented.");
};
jsPDFAPI.events.push([
"initialized",
function() {
this.canvas = new Canvas();
this.canvas.pdf = this;
}
]);
return this;
})(jsPDF.API);