diff --git a/build/html2canvas.js b/build/html2canvas.js index ac4c00a..d2a85a9 100644 --- a/build/html2canvas.js +++ b/build/html2canvas.js @@ -13,6 +13,10 @@ window.html2canvas = function(nodeList, options) { window.html2canvas.logging = true; window.html2canvas.start = Date.now(); } + + options.async = typeof(options.async) === "undefined" ? true : options.async; + options.removeContainer = typeof(options.removeContainer) === "undefined" ? true : options.removeContainer; + return renderDocument(document, options, window.innerWidth, window.innerHeight).then(function(canvas) { if (typeof(options.onrendered) === "function") { log("options.onrendered is deprecated, html2canvas returns a Promise containing the canvas"); @@ -23,7 +27,7 @@ window.html2canvas = function(nodeList, options) { }; function renderDocument(document, options, windowWidth, windowHeight) { - return createWindowClone(document, windowWidth, windowHeight).then(function(container) { + return createWindowClone(document, windowWidth, windowHeight, options).then(function(container) { log("Document cloned"); var clonedWindow = container.contentWindow; //var element = (nodeList === undefined) ? document.body : nodeList[0]; @@ -36,7 +40,10 @@ function renderDocument(document, options, windowWidth, windowHeight) { var renderer = new CanvasRenderer(width, height, imageLoader); var parser = new NodeParser(node, renderer, support, imageLoader, options); return parser.ready.then(function() { - container.parentNode.removeChild(container); + log("Finished rendering"); + if (options.removeContainer) { + container.parentNode.removeChild(container); + } return renderer.canvas; }); }); @@ -62,7 +69,7 @@ function smallImage() { return ""; } -function createWindowClone(ownerDocument, width, height) { +function createWindowClone(ownerDocument, width, height, options) { var documentElement = ownerDocument.documentElement.cloneNode(true), container = ownerDocument.createElement("iframe"); @@ -74,18 +81,6 @@ function createWindowClone(ownerDocument, width, height) { ownerDocument.body.appendChild(container); return new Promise(function(resolve) { - var loadedTimer = function() { - /* Chrome doesn't detect relative background-images assigned in style sheets when fetched through getComputedStyle, - before a certain time has passed - */ - if (container.contentWindow.getComputedStyle(div, null)['backgroundImage'] !== "none") { - documentClone.body.removeChild(div); - documentClone.body.removeChild(style); - resolve(container); - } else { - window.setTimeout(loadedTimer, 10); - } - }; var documentClone = container.contentWindow.document; /* Chrome doesn't detect relative background-images assigned in inline