UNPKG

docx2html

Version:

a javascript docx converter to html based on docx4js

246 lines (217 loc) 20.1 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _get2 = require('babel-runtime/helpers/get'); var _get3 = _interopRequireDefault(_get2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _drawing = require('./drawing'); var _drawing2 = _interopRequireDefault(_drawing); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var unit = /[a-zA-Z]+$/g; function asNum(a) { return parseFloat(a.replace(unit, '')); } var Anchor = function (_Drawing) { (0, _inherits3.default)(Anchor, _Drawing); function Anchor() { (0, _classCallCheck3.default)(this, Anchor); return (0, _possibleConstructorReturn3.default)(this, (Anchor.__proto__ || (0, _getPrototypeOf2.default)(Anchor)).apply(this, arguments)); } (0, _createClass3.default)(Anchor, [{ key: 'convertStyle', value: function convertStyle(el) { el.style.display = 'inline-block'; el.style.position = 'relative'; (0, _get3.default)(Anchor.prototype.__proto__ || (0, _getPrototypeOf2.default)(Anchor.prototype), 'convertStyle', this).apply(this, arguments); } }, { key: 'tag', get: function get() { return 'div'; } }]); return Anchor; }(_drawing2.default); exports.default = Anchor; var PositionH = { page: function page(x) { var style = this.style, t; switch (x.align) { case 'left': if ((t = this.world.width - asNum(this.doc.section.style.paddingLeft)) >= 0) style.left = 0;else style.left = -t + 'px'; break; case 'center': style.left = (asNum(this.doc.section.style.width) - this.world.width) / 2 + 'px'; break; case 'right': if ((t = this.world.width - asNum(this.doc.section.style.paddingRight)) >= 0) style.right = 0;else style.right = -t + 'px'; break; case 'inside': style.left = 0; break; case 'outside': style.right = 0; break; default: style.left = x.posOffset + 'px'; break; } }, margin: function margin(x) { var sect = this.doc.section.style; switch (x.align) { case 'inside': case 'left': this.style.left = sect.paddingLeft; break; case 'center': this.style.left = (asNum(sect.width) - asNum(sect.paddingRight) + asNum(sect.paddingLeft) - this.world.width) / 2 + 'px'; break; case 'outside': case 'right': this.style.right = sect.paddingRight; break; default: this.style.left = x.posOffset + asNum(sect.paddingLeft) + 'px'; break; } }, column: function column(x) { Anchor.addClass(this.parent.content, 'warning warning-positionH-column'); PositionH.margin.call(this, x); }, character: function character(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionH-character'); }, leftMargin: function leftMargin(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionH-leftMargin'); }, rightMargin: function rightMargin(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionH-rightMargin'); }, insideMargin: function insideMargin(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionH-insideMargin'); }, outsideMargin: function outsideMargin(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionH-outsideMargin'); } }; var PositionV = { page: function page(x) { var style = this.style, sect = this.doc.section.style; switch (x.align) { case 'top': style.top = 0; break; case 'bottom': style.bottom = 0; break; case 'center': case 'outside': case 'inside': Anchor.addClass(this.parent.content, 'unsupported unsupported-positionV-page-' + x.align); break; default: style.top = x.posOffset + 'px'; break; } }, margin: function margin(x) { var style = this.style, sect = this.doc.section.style; switch (x.align) { case 'top': style.top = sect.paddingTop; break; case 'bottom': style.bottom = sect.paddingBottom; break; case 'center': case 'outside': case 'inside': Anchor.addClass(this.parent.content, 'unsupported unsupported-positionV-margin-' + x.align); break; default: style.top = asNum(sect.paddingTop) + x.posOffset + 'px'; break; } }, line: function line(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionV-line'); }, topMargin: function topMargin(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionV-topMargin'); }, bottomMargin: function bottomMargin(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionV-bottomMargin'); }, insideMargin: function insideMargin(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionV-insideMargin'); }, outsideMargin: function outsideMargin(x) { Anchor.addClass(this.parent.content, 'unsupported unsupported-positionV-outsideMargin'); }, paragraph: function paragraph(x) { //only offset Anchor.addClass(this.parent.content, 'unsupported unsupported-positionV-paragraph'); } }; //only support absolute page offset var Properties = function (_Drawing$Properties) { (0, _inherits3.default)(Properties, _Drawing$Properties); function Properties() { (0, _classCallCheck3.default)(this, Properties); return (0, _possibleConstructorReturn3.default)(this, (Properties.__proto__ || (0, _getPrototypeOf2.default)(Properties)).apply(this, arguments)); } (0, _createClass3.default)(Properties, [{ key: 'getParagraphPaddingLeft', value: function getParagraphPaddingLeft() { return '0pt'; } }, { key: 'positionH', value: function positionH(x) { PositionH[x.relativeFrom].call(this, x); } }, { key: 'positionV', value: function positionV(x) { PositionV[x.relativeFrom].call(this, x); } }, { key: 'wrap', value: function wrap(x) { switch (x) { case 'tight': case 'through': case 'square': case 'topAndBottom': Anchor.addClass(this.parent.content, 'unsupported unsupported-wrap-' + x); break; default: this.style.position = 'absolute'; } } }, { key: 'behindDoc', value: function behindDoc(x) { this.style.zIndex = -1; } }]); return Properties; }(_drawing2.default.Properties); Anchor.Properties = Properties; module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/docx/html/drawingAnchor.js"],"names":["unit","asNum","a","parseFloat","replace","Anchor","el","style","display","position","arguments","Drawing","PositionH","page","x","t","align","world","width","doc","section","paddingLeft","left","paddingRight","right","posOffset","margin","sect","column","addClass","parent","content","call","character","leftMargin","rightMargin","insideMargin","outsideMargin","PositionV","top","bottom","paddingTop","paddingBottom","line","topMargin","bottomMargin","paragraph","Properties","relativeFrom","zIndex"],"mappings":"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","file":"drawingAnchor.js","sourcesContent":["import Drawing from './drawing'\n\nvar unit=/[a-zA-Z]+$/g\nfunction asNum(a){\n\treturn parseFloat(a.replace(unit,''))\n}\n\nexport default class Anchor extends Drawing{\n\tget tag(){return 'div'}\n\t\n\tconvertStyle(el){\n\t\tel.style.display='inline-block'\n\t\tel.style.position='relative'\n\t\t\n\t\tsuper.convertStyle(...arguments)\n\t}\n\n}\n\nvar PositionH={\n\tpage(x){\n\t\tvar style=this.style, t;\n\t\tswitch(x.align){\n\t\tcase 'left':\n\t\t\tif((t=this.world.width-asNum(this.doc.section.style.paddingLeft))>=0)\n\t\t\t\tstyle.left=0\n\t\t\telse\n\t\t\t\tstyle.left=-t+'px'\n\t\t\tbreak\n\t\tcase 'center':\n\t\t\tstyle.left=(asNum(this.doc.section.style.width)-this.world.width)/2+'px'\n\t\t\tbreak\n\t\tcase 'right': \n\t\t\tif((t=this.world.width-asNum(this.doc.section.style.paddingRight))>=0)\n\t\t\t\tstyle.right=0\n\t\t\telse\n\t\t\t\tstyle.right=-t+'px'\n\t\t\tbreak\n\t\tcase 'inside': \n\t\t\tstyle.left=0\n\t\t\tbreak\n\t\tcase 'outside': \n\t\t\tstyle.right=0\n\t\t\tbreak\n\t\tdefault:\n\t\t\tstyle.left=x.posOffset+'px'\n\t\t\tbreak\n\t\t}\n\t},\n\tmargin(x){\n\t\tvar sect=this.doc.section.style\n\t\tswitch(x.align){\n\t\tcase 'inside': \n\t\tcase 'left':\n\t\t\tthis.style.left=sect.paddingLeft\n\t\t\tbreak\n\t\tcase 'center':\n\t\t\tthis.style.left=(asNum(sect.width)-asNum(sect.paddingRight)+asNum(sect.paddingLeft)-this.world.width)/2+'px'\n\t\t\tbreak\n\t\tcase 'outside': \n\t\tcase 'right': \n\t\t\tthis.style.right=sect.paddingRight\n\t\t\tbreak\n\t\tdefault:\n\t\t\tthis.style.left=(x.posOffset+asNum(sect.paddingLeft))+'px'\n\t\t\tbreak\n\t\t}\n\t},\n\tcolumn(x){\n\t\tAnchor.addClass(this.parent.content,'warning warning-positionH-column')\n\t\tPositionH.margin.call(this,x)\n\t},\n\tcharacter(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionH-character')\n\t},\n\tleftMargin(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionH-leftMargin')\n\t},\n\trightMargin(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionH-rightMargin')\n\t},\n\tinsideMargin(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionH-insideMargin')\n\t},\n\toutsideMargin(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionH-outsideMargin')\n\t}\n}\nvar PositionV={\n\tpage(x){\n\t\tvar style=this.style, sect=this.doc.section.style;\n\t\tswitch(x.align){\n\t\tcase 'top':\n\t\t\tstyle.top=0\n\t\t\tbreak\n\t\tcase 'bottom':\n\t\t\tstyle.bottom=0\n\t\t\tbreak\n\t\tcase 'center':\n\t\tcase 'outside':\n\t\tcase 'inside':\n\t\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionV-page-'+x.align)\n\t\tbreak\n\t\tdefault:\n\t\t\tstyle.top=x.posOffset+'px'\n\t\tbreak\n\t\t}\n\t},\n\tmargin(x){\n\t\tvar style=this.style,sect=this.doc.section.style\n\t\tswitch(x.align){\n\t\tcase 'top':\n\t\t\tstyle.top=sect.paddingTop\n\t\tbreak\n\t\tcase 'bottom':\n\t\t\tstyle.bottom=sect.paddingBottom\n\t\tbreak\n\t\tcase 'center':\n\t\tcase 'outside':\n\t\tcase 'inside':\n\t\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionV-margin-'+x.align)\n\t\tbreak\n\t\tdefault:\n\t\t\tstyle.top=asNum(sect.paddingTop)+x.posOffset+'px'\n\t\tbreak\n\t\t}\n\t},\n\tline(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionV-line')\n\t},\n\ttopMargin(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionV-topMargin')\n\t},\n\tbottomMargin(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionV-bottomMargin')\n\t},\n\tinsideMargin(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionV-insideMargin')\n\t},\n\toutsideMargin(x){\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionV-outsideMargin')\n\t},\n\tparagraph(x){//only offset\n\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-positionV-paragraph')\n\t}\n}\n\t\n//only support absolute page offset\nclass Properties extends Drawing.Properties{\n\tgetParagraphPaddingLeft(){\n\t\treturn '0pt'\n\t}\n\tpositionH(x){\n\t\tPositionH[x.relativeFrom].call(this,x)\n\t}\n\tpositionV(x){\n\t\tPositionV[x.relativeFrom].call(this,x)\n\t}\n\twrap(x){\n\t\tswitch(x){\n\t\tcase 'tight':\n\t\tcase 'through':\n\t\tcase 'square':\n\t\tcase 'topAndBottom':\n\t\t\tAnchor.addClass(this.parent.content,'unsupported unsupported-wrap-'+x)\n\t\t\tbreak\n\t\tdefault:\n\t\t\tthis.style.position='absolute'\n\t\t}\n\t}\n\tbehindDoc(x){\n\t\tthis.style.zIndex=-1\n\t}\n}\n\nAnchor.Properties=Properties\n"]}