html-to-pdfmake
Advanced tools
Comparing version 1.0.1 to 1.0.2
@@ -35,3 +35,3 @@ var pdfMake = require("pdfmake/build/pdfmake"); | ||
<li>With a sub sub unordered list: | ||
<ul> | ||
<ul style="background-color:yellow"> | ||
<li>Sub Sub First item</li> | ||
@@ -109,2 +109,6 @@ <li>Sub Sub Second item</li> | ||
</table> | ||
<div style="margin-top:20px"> | ||
An image: <img width="54" style="height:70px" src=""> | ||
</div> | ||
`, window); | ||
@@ -111,0 +115,0 @@ |
48
index.js
@@ -88,3 +88,3 @@ // source: https://github.com/OpenSlides/OpenSlides/blob/f4f8b8422f9b3fbab58e35ac3f8f870d35813b7d/client/src/app/core/ui-services/html-to-pdf.service.ts | ||
var parentNodeName = (parentNode ? parentNode.nodeName.toLowerCase() : ''); | ||
var ret, text, cssClass, cssStyle; | ||
var ret, text, cssClass; | ||
@@ -106,3 +106,3 @@ // check the node type | ||
// for links | ||
if (parentNodeName === 'a') { | ||
if (parentNodeName === "a") { | ||
ret.link = parentNode.getAttribute("href"); | ||
@@ -119,9 +119,3 @@ } | ||
if (ret.text) { | ||
cssStyle = parentNode.getAttribute("style"); | ||
if (cssStyle) { | ||
cssStyle = computeStyle(cssStyle); | ||
cssStyle.forEach(function(style) { | ||
ret[style.key] = style.value; | ||
}) | ||
} | ||
setComputedStyle(ret, parentNode.getAttribute("style")); | ||
} | ||
@@ -171,2 +165,4 @@ } else { | ||
} | ||
// check if the element has a "style" attribute | ||
setComputedStyle(ret, element.getAttribute("style")); | ||
break; | ||
@@ -190,4 +186,24 @@ } | ||
delete ret._; | ||
// check if the element has a "style" attribute | ||
setComputedStyle(ret, element.getAttribute("style")); | ||
break; | ||
} | ||
case "img": { | ||
ret = {image:element.getAttribute("src")}; | ||
ret.style = ['html-img']; | ||
cssClass = element.getAttribute("class"); | ||
if (cssClass) { | ||
ret.style = ret.style.concat(cssClass.split(' ')); | ||
} | ||
// check if we have 'width' and 'height' | ||
if (element.getAttribute("width")) { | ||
ret.width = parseFloat(element.getAttribute("width")) | ||
} | ||
if (element.getAttribute("height")) { | ||
ret.height = parseFloat(element.getAttribute("height")) | ||
} | ||
// check if the element has a "style" attribute | ||
setComputedStyle(ret, element.getAttribute("style")); | ||
break; | ||
} | ||
} | ||
@@ -297,2 +313,16 @@ // add a custom class to let the user customize the element | ||
/** | ||
* Go throught the CSS styles for the element and apply them | ||
* @param {Object} ret Our pdfmake object | ||
* @param {String} cssStyle The CSS style string | ||
*/ | ||
var setComputedStyle = function(ret, cssStyle) { | ||
if (cssStyle) { | ||
cssStyle = computeStyle(cssStyle); | ||
cssStyle.forEach(function(style) { | ||
ret[style.key] = style.value; | ||
}) | ||
} | ||
} | ||
var toCamelCase = function(str) { | ||
@@ -299,0 +329,0 @@ return str.replace(/-([a-z])/g, function (g) { return g[1].toUpperCase() }); |
{ | ||
"name": "html-to-pdfmake", | ||
"version": "1.0.1", | ||
"version": "1.0.2", | ||
"description": "Convert HTML code to PDFMake", | ||
@@ -5,0 +5,0 @@ "main": "index.js", |
@@ -245,1 +245,15 @@ var htmlToPdfMake = require('../index.js'); | ||
}) | ||
test("img",function(t) { | ||
var ret = htmlToPdfMake('<img width="10" style="height:10px" src="data:image/jpeg;base64,...encodedContent...">', window); | ||
t.check(Array.isArray(ret) && ret.length===1, "return is OK"); | ||
ret = ret[0]; | ||
t.check( | ||
ret.image === "data:image/jpeg;base64,...encodedContent..." && | ||
ret.width === 10 && ret.height === 10 && | ||
Array.isArray(ret.style) && | ||
ret.style[0] === 'html-img', | ||
"<img>"); | ||
t.finish(); | ||
}) |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
66888
9
745