UNPKG

docx2html

Version:

a javascript docx converter to html based on docx4js

314 lines (271 loc) 28.6 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 _converter = require('./converter'); var _converter2 = _interopRequireDefault(_converter); var _converter3 = require('./style/converter'); var _converter4 = _interopRequireDefault(_converter3); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var AZ = /[A-Z]/g, r = function r(a) { return '-' + a.toLowerCase(); }, clozed = /Z$/gi; function asStyle(x) { var a = []; for (var i in x) { !$.isFunction(x[i]) && a.push(i.replace(AZ, r) + ':' + x[i]); }return a.join(';'); } var Shape = function (_Converter) { (0, _inherits3.default)(Shape, _Converter); function Shape() { (0, _classCallCheck3.default)(this, Shape); return (0, _possibleConstructorReturn3.default)(this, (Shape.__proto__ || (0, _getPrototypeOf2.default)(Shape)).apply(this, arguments)); } (0, _createClass3.default)(Shape, [{ key: 'convertStyle', value: function convertStyle(el) { el.style.position = 'absolute'; el.style.overflow = 'hidden'; var pathStyle = { stroke: 'black', strokeWidth: 2, fillOpacity: 0 }, bgStyle = this.makeBackgroundStyle(); (0, _get3.default)(Shape.prototype.__proto__ || (0, _getPrototypeOf2.default)(Shape.prototype), 'convertStyle', this).apply(this, arguments); var style = this.wordModel.getDirectStyle(), propConverter = new this.constructor.Properties(el.style, this, pathStyle, bgStyle); style && style.parse([propConverter]); if (this.path) { if (el.style.background) pathStyle.fillOpacity = 0; var bgImage = el.style.background, grad = pathStyle.grad; delete pathStyle.grad; var svg = '<svg xmlns="http://www.w3.org/2000/svg">' + (grad ? '<defs>' + grad + '</defs>' : '') + this.path + ' style="' + asStyle(pathStyle) + '" /></svg>'; var svgImage = 'url(' + this.doc.asImageURL(svg) + ')'; bgStyle.backgroundImage = svgImage; bgStyle.backgroundSize = '100% 100%'; } } }, { key: 'makeBackgroundStyle', value: function makeBackgroundStyle() { //make background el to hold svg background var id = 'shape' + this.doc.uid(); this.content.setAttribute('id', id); var style = this.doc.createStyle('#' + id + '::before'); style.content = '""'; style.zIndex = -1; style.position = 'absolute'; style.width = '100%'; style.height = '100%'; style.left = 0; style.top = 0; return style; } }, { key: 'tag', get: function get() { return 'div'; } }]); return Shape; }(_converter2.default); exports.default = Shape; Shape.Properties = function (_Style$Properties) { (0, _inherits3.default)(Properties, _Style$Properties); function Properties(style, parent, pathStyle, bgStyle) { (0, _classCallCheck3.default)(this, Properties); var _this2 = (0, _possibleConstructorReturn3.default)(this, (Properties.__proto__ || (0, _getPrototypeOf2.default)(Properties)).apply(this, arguments)); _this2.pathStyle = pathStyle; _this2.bgStyle = bgStyle; return _this2; } (0, _createClass3.default)(Properties, [{ key: 'xfrm', value: function xfrm(x) { this.style.width = x.width + 'px'; this.style.height = x.height + 'px'; x.x && (this.style.left = x.x + 'px'); x.y && (this.style.top = x.y + 'px'); x.rotation && this.styless('transform', 'rotate(' + x.rotation + 'deg)'); this.world = x; } }, { key: 'ln', value: function ln(x) { x.color && (this.pathStyle.stroke = x.color); x.width != undefined && (this.pathStyle.strokeWidth = x.width + 'px'); switch (x.cap) { case 'rnd': this.pathStyle.strokeLinecap = 'round'; break; default: } if (x.dash) { switch (this.lineStyle(x.dash)) { case 'dotted': this.pathStyle.strokeDasharray = "5,5"; break; break; case 'dashed': this.pathStyle.strokeDasharray = "10,10"; break; } } } }, { key: 'solidFill', value: function solidFill(x) { this.pathStyle.fill = x; this.pathStyle.fillOpacity = 1; } }, { key: 'gradFill', value: function gradFill(x) { if (this.style.backgroundImage) return; var grad = []; switch (x.path) { case 'linear': grad.push('<linearGradient id="grad"'); switch (x.angel) { case 0: grad.push('x1="0%" y1="0%" x2="100%" y2="0%">'); break; case 90: grad.push('x1="0%" y1="0%" x2="0%" y2="100%">'); break; case 180: grad.push('x1="100%" y1="0%" x2="0%" y2="0%">'); break; case 270: grad.push('x1="0%" y1="100%" x2="0%" y2="0%">'); break; } grad.push('</linearGradient>'); break; case 'circle': grad.push('<radialGradient id="grad"'); grad.push('cx="50%" cy="50%" r="50%" fx="50%" fy="50%">'); grad.push('</radialGradient>'); break; } var end = grad.pop(); for (var i = 0, len = x.stops.length, a; i < len; i++) { grad.push('<stop offset="' + (a = x.stops[i]).position + '%" style="stop-opacity:1;stop-color:' + a.color + '"/>'); }grad.push(end); this.pathStyle.grad = grad.join(' '); this.pathStyle.fill = 'url(#grad)'; this.pathStyle.fillOpacity = 1; } }, { key: 'blipFill', value: function blipFill(x) { this.style.background = 'url(' + this.doc.asImageURL(x) + ')'; this.style.backgroundSize = '100% 100%'; this.noFill(); } }, { key: 'noFill', value: function noFill(x) { this.pathStyle.fillOpacity = 0; } }, { key: 'lnRef', value: function lnRef(x) { this.ln(x); } }, { key: 'fillRef', value: function fillRef(x) { if (this.style.backgroundImage) return; if (typeof x.path != 'undefined') return this.gradFill(x); if (typeof x == 'string') this.pathStyle.fill = x;else if (typeof x.color != 'undefined') this.pathStyle.fill = x.color;else return; this.pathStyle.fillOpacity = 1; } }, { key: 'fontRef', value: function fontRef(x) { x.color && (this.style.color = x.color); x.family && (this.style.fontFamily = x.family); } }, { key: 'path', value: function path(x, t) { switch (x.shape) { case 'line': this.parent.path = '<line x1="0" y1="0" x2="' + this.world.width + 'pt" y2="' + this.world.height + 'pt"'; break; case 'rect': this.parent.path = '<rect width="' + this.world.width + 'pt" height="' + this.world.height + 'pt"'; break; case 'roundRect': this.parent.path = '<rect rx="' + (t = Math.min(this.world.width, this.world.height) / 12) + 'pt" ry="' + t + 'pt" width="' + this.world.width + 'pt" height="' + this.world.height + 'pt"'; break; case 'ellipse': this.parent.path = '<ellipse cx="' + this.world.width / 2 + 'pt" cy="' + this.world.height / 2 + 'pt" rx="' + this.world.width / 2 + 'pt" ry="' + this.world.height / 2 + 'pt"'; break; case 'path': this.parent.path = '<path d="' + x.path + '"'; if (!clozed.test(x.path)) this.noFill(); break; } } }, { key: 'spAutoFit', value: function spAutoFit() { this.style.height = 'auto'; } }, { key: 'lIns', value: function lIns(x) { this.style.paddingLeft = x + 'px'; } }, { key: 'tIns', value: function tIns(x) { this.style.paddingTop = x + 'px'; } }, { key: 'rIns', value: function rIns(x) { this.style.paddingRight = x + 'px'; } }, { key: 'bIns', value: function bIns(x) { this.style.paddingBottom = x + 'px'; } }, { key: 'anchor', value: function anchor(x) { this.style.display = 'table-cell'; this.style.verticalAlign = x; } }, { key: 'vert', value: function vert(x) { this.style.height = this.world.width + 'px'; this.style.width = this.world.height + 'px'; var delta = (this.world.width - this.world.height) / 2; this.bgStyle.height = this.world.height + 'px'; this.bgStyle.width = this.world.width + 'px'; this.styless('transform', 'translate(-' + delta + 'pt,' + delta + 'pt) rotate(-' + x + 'deg) ', this.bgStyle); this.styless('transform', 'translate(' + delta + 'pt,-' + delta + 'pt) rotate(' + (x + this.world.rotation || 0) + 'deg)'); } }]); return Properties; }(_converter4.default.Properties); module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/docx/html/shape.js"],"names":["AZ","r","a","toLowerCase","clozed","asStyle","x","i","$","isFunction","push","replace","join","Shape","el","style","position","overflow","pathStyle","stroke","strokeWidth","fillOpacity","bgStyle","makeBackgroundStyle","arguments","wordModel","getDirectStyle","propConverter","constructor","Properties","parse","path","background","bgImage","grad","svg","svgImage","doc","asImageURL","backgroundImage","backgroundSize","id","uid","content","setAttribute","createStyle","zIndex","width","height","left","top","Converter","parent","y","rotation","styless","world","color","undefined","cap","strokeLinecap","dash","lineStyle","strokeDasharray","fill","angel","end","pop","len","stops","length","noFill","ln","gradFill","family","fontFamily","t","shape","Math","min","test","paddingLeft","paddingTop","paddingRight","paddingBottom","display","verticalAlign","delta","Style"],"mappings":"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","file":"shape.js","sourcesContent":["import Converter from './converter'\nimport Style from './style/converter'\n\nvar AZ=/[A-Z]/g, \n\tr=function(a){return '-'+a.toLowerCase()},\n\tclozed=/Z$/gi;\n\t\nfunction asStyle(x){\n\tvar a=[]\n\tfor(var i in x)\n\t\t!$.isFunction(x[i]) && a.push(i.replace(AZ,r)+':'+x[i])\n\treturn a.join(';')\n}\n\nexport default class Shape extends Converter{\n\tget tag(){return 'div'}\n\t\n\tconvertStyle(el){\n\t\tel.style.position='absolute'\n\t\tel.style.overflow='hidden'\n\n\t\tvar pathStyle={stroke:'black', strokeWidth:2, fillOpacity:0},\n\t\t\tbgStyle=this.makeBackgroundStyle();\n\t\tsuper.convertStyle(...arguments)\n\t\tvar style=this.wordModel.getDirectStyle(),\n\t\t\tpropConverter=new this.constructor.Properties(el.style,this, pathStyle, bgStyle);\n\t\tstyle && style.parse([propConverter])\n\t\tif(this.path){\n\t\t\tif(el.style.background)\n\t\t\t\tpathStyle.fillOpacity=0\n\t\t\tvar bgImage=el.style.background,\n\t\t\t\tgrad=pathStyle.grad;\n\t\t\tdelete pathStyle.grad;\t\t\t\t\n\t\t\t\n\t\t\tvar svg='<svg xmlns=\"http://www.w3.org/2000/svg\">'\n\t\t\t\t\t+(grad ? '<defs>'+grad+'</defs>' : '')\n\t\t\t\t\t+this.path+' style=\"'+asStyle(pathStyle)+'\" /></svg>';\n\t\t\tvar svgImage='url('+this.doc.asImageURL(svg)+')';\n\t\t\tbgStyle.backgroundImage=svgImage\n\t\t\tbgStyle.backgroundSize='100% 100%'\n\t\t}\n\t}\n\tmakeBackgroundStyle(){\n\t\t//make background el to hold svg background\n\t\tvar id='shape'+this.doc.uid()\n\t\tthis.content.setAttribute('id',id)\n\t\tvar style=this.doc.createStyle('#'+id+'::before')\n\t\tstyle.content='\"\"'\n\t\tstyle.zIndex=-1\n\t\tstyle.position='absolute'\n\t\tstyle.width='100%'\n\t\tstyle.height='100%'\n\t\tstyle.left=0\n\t\tstyle.top=0\n\t\treturn style\n\t}\n}\n\nShape.Properties=class Properties extends Style.Properties{\n\tconstructor(style,parent, pathStyle, bgStyle){\n\t\tsuper(...arguments)\n\t\tthis.pathStyle=pathStyle\n\t\tthis.bgStyle=bgStyle\n\t}\n\n\txfrm(x){\n\t\tthis.style.width=x.width+'px'\n\t\tthis.style.height=x.height+'px'\n\t\tx.x && (this.style.left=x.x+'px')\n\t\tx.y && (this.style.top=x.y+'px')\n\t\t\n\t\tx.rotation && this.styless('transform','rotate('+x.rotation+'deg)')\n\t\t\n\t\tthis.world=x\n\t}\n\tln(x){\n\t\tx.color && (this.pathStyle.stroke=x.color);\n\t\tx.width!=undefined && (this.pathStyle.strokeWidth=x.width+'px');\n\t\t\n\t\tswitch(x.cap){\n\t\tcase 'rnd':\n\t\t\tthis.pathStyle.strokeLinecap='round'\n\t\t\tbreak\n\t\tdefault:\n\t\t\t\n\t\t}\n\t\t\n\t\tif(x.dash){\n\t\t\tswitch(this.lineStyle(x.dash)){\n\t\t\tcase 'dotted':\n\t\t\t\tthis.pathStyle.strokeDasharray=\"5,5\"\n\t\t\t\tbreak\n\t\t\tbreak\n\t\t\tcase 'dashed':\n\t\t\t\tthis.pathStyle.strokeDasharray=\"10,10\"\n\t\t\tbreak\n\t\t\t}\n\t\t}\n\t}\n\tsolidFill(x){\n\t\tthis.pathStyle.fill=x\n\t\tthis.pathStyle.fillOpacity=1\n\t}\n\tgradFill(x){\n\t\tif(this.style.backgroundImage)\n\t\t\treturn\n\t\t\t\n\t\tvar grad=[]\n\t\tswitch(x.path){\n\t\tcase 'linear':\n\t\t\tgrad.push('<linearGradient id=\"grad\"')\n\t\t\tswitch(x.angel){\n\t\t\tcase 0:\n\t\t\t\tgrad.push('x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"0%\">')\n\t\t\t\tbreak\n\t\t\tcase 90:\n\t\t\t\tgrad.push('x1=\"0%\" y1=\"0%\" x2=\"0%\" y2=\"100%\">')\n\t\t\t\tbreak\n\t\t\tcase 180:\n\t\t\t\tgrad.push('x1=\"100%\" y1=\"0%\" x2=\"0%\" y2=\"0%\">')\n\t\t\t\tbreak\n\t\t\tcase 270:\n\t\t\t\tgrad.push('x1=\"0%\" y1=\"100%\" x2=\"0%\" y2=\"0%\">')\n\t\t\t\tbreak\n\t\t\t}\n\t\t\tgrad.push('</linearGradient>')\n\t\t\tbreak\n\t\tcase 'circle':\n\t\t\tgrad.push('<radialGradient  id=\"grad\"')\n\t\t\tgrad.push('cx=\"50%\" cy=\"50%\" r=\"50%\" fx=\"50%\" fy=\"50%\">')\n\t\t\tgrad.push('</radialGradient>')\n\t\t\tbreak\n\t\t}\n\t\tvar end=grad.pop()\n\t\tfor(var i=0,len=x.stops.length,a;i<len;i++)\n\t\t\tgrad.push('<stop offset=\"'+(a=x.stops[i]).position+'%\" style=\"stop-opacity:1;stop-color:'+a.color+'\"/>')\n\t\tgrad.push(end)\n\t\t\n\t\tthis.pathStyle.grad=grad.join(' ')\n\t\tthis.pathStyle.fill='url(#grad)'\n\t\tthis.pathStyle.fillOpacity=1\n\t}\n\tblipFill(x){\n\t\tthis.style.background='url('+this.doc.asImageURL(x)+')'\n\t\tthis.style.backgroundSize='100% 100%'\n\t\tthis.noFill()\n\t}\n\tnoFill(x){\n\t\tthis.pathStyle.fillOpacity=0\n\t}\n\tlnRef(x){\n\t\tthis.ln(x)\n\t}\n\tfillRef(x){\n\t\tif(this.style.backgroundImage)\n\t\t\treturn\n\t\t\n\t\tif(typeof(x.path)!='undefined')\n\t\t\treturn this.gradFill(x);\n\t\t\t\n\t\tif(typeof(x)=='string')\n\t\t\tthis.pathStyle.fill=x\n\t\telse if(typeof(x.color)!='undefined')\n\t\t\tthis.pathStyle.fill=x.color\n\t\telse\n\t\t\treturn;\n\t\tthis.pathStyle.fillOpacity=1\n\t}\n\tfontRef(x){\n\t\tx.color && (this.style.color=x.color);\n\t\tx.family && (this.style.fontFamily=x.family);\n\t}\n\tpath(x, t){\n\t\tswitch(x.shape){\n\t\tcase 'line':\n\t\t\tthis.parent.path='<line x1=\"0\" y1=\"0\" x2=\"'+this.world.width+'pt\" y2=\"'+this.world.height+'pt\"'\n\t\t\tbreak\n\t\tcase 'rect':\n\t\t\tthis.parent.path='<rect width=\"'+this.world.width+'pt\" height=\"'+this.world.height+'pt\"'\n\t\t\tbreak;\t\n\t\tcase 'roundRect':\n\t\t\tthis.parent.path='<rect rx=\"'+(t=Math.min(this.world.width, this.world.height)/12)+'pt\" ry=\"'+t+'pt\" width=\"'+this.world.width+'pt\" height=\"'+this.world.height+'pt\"'\n\t\t\tbreak;\n\t\tcase 'ellipse':\n\t\t\tthis.parent.path='<ellipse cx=\"'+this.world.width/2+'pt\" cy=\"'+this.world.height/2+'pt\" rx=\"'+this.world.width/2+'pt\" ry=\"'+this.world.height/2+'pt\"'\n\t\t\tbreak\n\t\tcase 'path':\n\t\t\tthis.parent.path='<path d=\"'+x.path+'\"'\n\t\t\tif(!clozed.test(x.path))\n\t\t\t\tthis.noFill()\n\t\t\tbreak\n\t\t}\n\t}\n\tspAutoFit(){\n\t\tthis.style.height='auto'\n\t}\n\tlIns(x){\n\t\tthis.style.paddingLeft=x+'px'\n\t}\n\ttIns(x){\n\t\tthis.style.paddingTop=x+'px'\n\t}\n\trIns(x){\n\t\tthis.style.paddingRight=x+'px'\n\t}\n\tbIns(x){\n\t\tthis.style.paddingBottom=x+'px'\n\t}\n\tanchor(x){\n\t\tthis.style.display='table-cell'\n\t\tthis.style.verticalAlign=x\n\t}\n\tvert(x){\n\t\tthis.style.height=this.world.width+'px'\n\t\tthis.style.width=this.world.height+'px'\n\t\tvar delta=(this.world.width-this.world.height)/2\n\t\t\t\t\t\t\n\t\tthis.bgStyle.height=this.world.height+'px'\n\t\tthis.bgStyle.width=this.world.width+'px'\n\t\tthis.styless('transform','translate(-'+delta+'pt,'+delta+'pt) rotate(-'+x+'deg) ', this.bgStyle)\n\n\t\tthis.styless('transform','translate('+delta+'pt,-'+delta+'pt) rotate('+(x+this.world.rotation||0)+'deg)')\n\t}\n}"]}