docx2html
Version:
a javascript docx converter to html based on docx4js
314 lines (271 loc) • 28.6 kB
JavaScript
'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}"]}