html-to-docx-buffer
This is a fork of html-to-docx with an aim to make it more portable. Dependencies relying on Node's
fs
have been removed/replaced, making it possible to use this library client-side: e.g. downloading a page asdocx
straight from the browser.
Credit to privateOmega for the original library.
Changelog
0.1.1
Typings fix
0.1.0
Initial version, based on html-to-docx 1.1.32 with changes to remove Node dependencies.
Also added TS typings
html-to-docx is a js library for converting HTML documents to DOCX format supported by Microsoft Word 2007+, LibreOffice Writer, Google Docs, WPS Writer etc.
It was inspired by html-docx-js project but mitigates the problem of documents generated being non-compatiable with word processors like Google Docs and libreOffice Writer that doesn't support altchunks feature.
html-to-docx earlier used to use libtidy to clean up the html before parsing, but had to remove it since it was causing so many dependency issues due to node-gyp.
Installation
Use the npm to install foobar.
npm install html-to-docx
Usage
await HTMLtoDOCX(htmlString, headerHTMLString, documentOptions, footerHTMLString);
full fledged examples can be found under example/
Parameters
-
htmlString
<String> clean html string equivalent of document content. -
headerHTMLString
<String> clean html string equivalent of header. Defaults to<p></p>
if header flag istrue
. -
documentOptions
<?Object>-
orientation
<"portrait"|"landscape"> defines the general orientation of the document. Defaults to portrait. -
margins
<?Object>-
top
<Number> distance between the top of the text margins for the main document and the top of the page for all pages in this section in TWIP. Defaults to 1440. Supports equivalent measurement in pixel, cm or inch. -
right
<Number> distance between the right edge of the page and the right edge of the text extents for this document in TWIP. Defaults to 1800. Supports equivalent measurement in pixel, cm or inch. -
bottom
<Number> distance between the bottom of text margins for the document and the bottom of the page in TWIP. Defaults to 1440. Supports equivalent measurement in pixel, cm or inch. -
left
<Number> distance between the left edge of the page and the left edge of the text extents for this document in TWIP. Defaults to 1800. Supports equivalent measurement in pixel, cm or inch. -
header
<Number> distance from the top edge of the page to the top edge of the header in TWIP. Defaults to 720. Supports equivalent measurement in pixel, cm or inch. -
footer
<Number> distance from the bottom edge of the page to the bottom edge of the footer in TWIP. Defaults to 720. Supports equivalent measurement in pixel, cm or inch. -
gutter
<Number> amount of extra space added to the specified margin, above any existing margin values. This setting is typically used when a document is being created for binding in TWIP. Defaults to 0. Supports equivalent measurement in pixel, cm or inch.
-
-
title
<?String> title of the document. -
subject
<?String> subject of the document. -
creator
<?String> creator of the document. Defaults tohtml-to-docx
-
keywords
<?Array<String>> keywords associated with the document. Defaults to ['html-to-docx']. -
description
<?String> description of the document. -
lastModifiedBy
<?String> last modifier of the document. Defaults tohtml-to-docx
. -
revision
<?Number> revision of the document. Defaults to1
. -
createdAt
<?Date> time of creation of the document. Defaults to current time. -
modifiedAt
<?Date> time of last modification of the document. Defaults to current time. -
headerType
<"default"|"first"|"even"> type of header. Defaults todefault
. -
header
<?Boolean> flag to enable header. Defaults tofalse
. -
footerType
<"default"|"first"|"even"> type of footer. Defaults todefault
. -
footer
<?Boolean> flag to enable footer. Defaults tofalse
. -
font
<?String> font name to be used. Defaults toTimes New Roman
. -
fontSize
<?Number> size of font in HIP(Half of point). Defaults to 22. Supports equivalent measure in pt. -
complexScriptFontSize
<?Number> size of complex script font in HIP(Half of point). Defaults to 22. Supports equivalent measure in pt. -
table
<?Object> -
pageNumber
<?Boolean> flag to enable page number in footer. Defaults tofalse
. Page number works only if footer flag is set astrue
.
-
-
footerHTMLString
<String> clean html string equivalent of footer. Defaults to<p></p>
if footer flag istrue
.
Returns
Notes
Currently page break can be implemented by having div with classname "page-break" or style "page-break-after" despite the values of the "page-break-after", and contents inside the div element will be ignored. <div class="page-break" style="page-break-after: always;"></div>
Contributing
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate.
License
MIT