docx4js-fork
Version:
javascript docx parser
412 lines (366 loc) • 50.8 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };
var _officeDocument = require("../officeDocument");
var _officeDocument2 = _interopRequireDefault(_officeDocument);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var A = "A".charCodeAt(0);
//A=>0, Z=>25, AA=>26
function colStrToInt(col) {
var last = col.substr(-1).charCodeAt(0) - A;
if (col.length > 1) {
return 26 * (colStrToInt(col.substring(0, col.length - 1)) + 1) + last;
}
return last;
}
//0=>A, 25=>Z, 26=>AA
function colIntToStr(col) {
var i0 = String.fromCharCode(A + col % 26);
if (col >= 26) {
return colIntToStr(parseInt(col / 26) - 1) + i0;
} else {
return i0;
}
}
var OfficeDocument = function (_Base) {
_inherits(OfficeDocument, _Base);
function OfficeDocument() {
_classCallCheck(this, OfficeDocument);
return _possibleConstructorReturn(this, (OfficeDocument.__proto__ || Object.getPrototypeOf(OfficeDocument)).apply(this, arguments));
}
_createClass(OfficeDocument, [{
key: "_init",
value: function _init() {
var _this2 = this;
_get(OfficeDocument.prototype.__proto__ || Object.getPrototypeOf(OfficeDocument.prototype), "_init", this).call(this);
var doc = this.doc;
this._assignRel(["styles", "sharedStrings"]);
Object.assign(this.sharedStrings, {
eq: function eq(i) {
return this.root().children("sst").children().eq(parseInt(i));
},
doc: doc
});
Object.assign(this.styles, { identities: this.constructor.identities, doc: doc });
this.theme.color = function (i) {
var $ = this("a\\:clrScheme>a\\:" + ColorIndex[parseInt(i)]).children().first();
return doc.asColor($.attr("lastClr") || $.attr("val"));
};
this.color = function (_ref) {
var _ref$attribs = _ref.attribs,
rgb = _ref$attribs.rgb,
theme = _ref$attribs.theme,
indexed = _ref$attribs.indexed,
tint = _ref$attribs.tint;
var v = rgb && "#" + rgb.substr(2) || theme && _this2.theme.color(theme) || indexed != undefined && "" + XLSIcv[parseInt(indexed)];
return tint ? _this2.doc.asColor(v, { tint: parseFloat(tint) }) : v;
};
}
}, {
key: "cellPlainText",
value: function cellPlainText(sheetIndex, row, col) {
row = row + 1;
col = colIntToStr(col);
var sheet = this.sheet(this.content("sheets>sheet").get(sheetIndex).attribs);
var s = sheet("worksheet>sheetData>row[r=" + row + "]>c[r='" + col + row + "']>v").text();
if (s) {
return this.sharedStrings.eq(s).text();
}
return "";
}
}, {
key: "sheet",
value: function sheet(_ref2) {
var rid = _ref2["r:id"];
return this.getRel(rid);
}
}, {
key: "render",
value: function render(createElement) {
var identify = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.constructor.identify.bind(this.constructor);
this.renderNode(this.styles("styleSheet").get(0), createElement, identify);
return this.renderNode(this.content("workbook").get(0), createElement, identify);
}
}]);
return OfficeDocument;
}(_officeDocument2.default);
OfficeDocument.colStrToInt = colStrToInt;
OfficeDocument.colIntToStr = colIntToStr;
OfficeDocument.identities = {
workbook: function workbook(wXml, officeDocument) {
var $ = officeDocument.content("sheets");
var children = $.children("sheet").toArray();
return {
type: "workbook",
children: children
};
},
sst: function sst(_ref3, od) {
var _ref3$attribs = _ref3.attribs,
count = _ref3$attribs.count,
uniqueCount = _ref3$attribs.uniqueCount;
return { type: "sharedStrings", count: parseInt(count), uniqueCount: parseInt(uniqueCount) };
},
sheet: function sheet(wXml, od) {
var $ = od.sheet(wXml.attribs);
var _$$get = $("sheetFormatPr").get(0),
_$$get$attribs = _$$get.attribs,
baseColWidth = _$$get$attribs.baseColWidth,
defaultRowHeight = _$$get$attribs.defaultRowHeight;
var children = $("sheetData>row").toArray();
var _wXml$attribs = wXml.attribs,
rId = _wXml$attribs["r:id"],
props = _objectWithoutProperties(_wXml$attribs, ["r:id"]);
var colProps = "customWidth,min,max,style,hidden".split(",").reduce(function (o, k) {
return o[k] = parseInt, o;
}, {
width: parseFloat,
tidy: function tidy(_ref4) {
var min = _ref4.min,
max = _ref4.max,
props = _objectWithoutProperties(_ref4, ["min", "max"]);
return _extends({}, props, { min: min - 1, max: max - 1 });
}
});
return _extends({}, props, {
type: "sheet",
children: children,
cols: $("cols").children().map(function (i, a) {
return $(a).props(colProps);
}).get(),
colWidth: parseFloat(baseColWidth),
rowHeight: parseFloat(defaultRowHeight),
view: $("sheetViews>sheetView").props({ xSplit: parseInt, ySplit: parseInt })
});
},
row: function row(wXml, od) {
var $ = od.$(wXml);
var _wXml$attribs2 = wXml.attribs,
customFormat = _wXml$attribs2.customFormat,
hidden = _wXml$attribs2.hidden,
s = _wXml$attribs2.s,
_wXml$attribs2$style = _wXml$attribs2.style,
style = _wXml$attribs2$style === undefined ? customFormat && parseInt(s) || undefined : _wXml$attribs2$style,
r = _wXml$attribs2.r,
customHeight = _wXml$attribs2.customHeight,
ht = _wXml$attribs2.ht,
_wXml$attribs2$height = _wXml$attribs2.height,
height = _wXml$attribs2$height === undefined ? ht && parseFloat(ht) * (od.doc.precision || 1) : _wXml$attribs2$height;
var children = $.children("c").toArray();
return { type: "row", children: children, customHeight: customHeight, height: height, i: parseInt(r) - 1, style: style, hidden: hidden };
},
c: function c(wXml, od) {
var _wXml$attribs3 = wXml.attribs,
r = _wXml$attribs3.r,
style = _wXml$attribs3.s;
var children = od.$(wXml).children().toArray();
var _$exec = /([A-Z]+)(\d+$)/.exec(r),
_$exec2 = _slicedToArray(_$exec, 3),
col = _$exec2[1],
row = _$exec2[2];
return {
type: "cell",
name: "" + (parseInt(row) - 1) + col,
col: colStrToInt(col),
row: parseInt(row) - 1,
children: children,
style: style != undefined ? parseInt(style) : undefined
};
},
v: function v(wXml, od) {
var kind = wXml.parent.attribs.t;
var _wXml$children = _slicedToArray(wXml.children, 1),
data = _wXml$children[0].data;
switch (kind) {
case "i":
return { type: "paragraph", kind: kind, children: [].concat(_toConsumableArray(wXml.children)) };
case "s":
od.$(wXml).empty().append(od.sharedStrings.eq(data).clone().children());
break;
default:
od.$(wXml).empty().append("<r><t>" + data + "</t></r>");
break;
}
wXml.parent.attribs.t = "i";
return { type: "paragraph", kind: kind, children: [].concat(_toConsumableArray(wXml.children)) };
},
is: function is(wXml, od) {
wXml.name = "v";
return { type: "paragraph", kind: "is", children: [].concat(_toConsumableArray(wXml.children)) };
},
r: function r(wXml, od) {
var style = od.$(wXml).find(">rPr").props(TextStyle(od));
return {
type: "run",
style: style,
children: wXml.children.filter(function (_ref5) {
var name = _ref5.name;
return name != "rPr";
})
};
},
//styles
numFmt: function numFmt(wXml, od) {
return _extends({ children: null }, od.styles(wXml).props());
},
cellStyle: function cellStyle(wXml, od) {
return _extends({ children: null }, od.styles(wXml).props());
},
xf: function xf(wXml, od) {
return _extends({ children: null }, od.styles(wXml).props(_extends({
names: {
wrapText: "wrap",
horizontal: "align",
vertical: "vertAlign"
},
wrapText: function wrapText(v) {
return v == "true" || v == "1" ? true : false;
}
}, parseInt4Keys("numFmtId,fontId,fillId,borderId,xfId,applyNumberFormat,applyFont,applyFill,applyBorder,applyAlignment"), {
tidy: function tidy(_ref6) {
var applyNumberFormat = _ref6.applyNumberFormat,
applyFont = _ref6.applyFont,
applyFill = _ref6.applyFill,
applyBorder = _ref6.applyBorder,
applyAlignment = _ref6.applyAlignment,
a = _objectWithoutProperties(_ref6, ["applyNumberFormat", "applyFont", "applyFill", "applyBorder", "applyAlignment"]);
if (applyNumberFormat == 0) delete a.numFmtId;
if (applyFont == 0) delete a.fontId;
if (applyFill == 0) delete a.fillId;
if (applyBorder == 0) delete a.borderId;
if (applyAlignment == 0) delete a.alignment;
return a;
}
})));
},
tableStyle: function tableStyle(wXml, od) {
return _extends({ children: null }, od.styles(wXml).props());
},
font: function font(wXml, od) {
return _extends({ children: null }, od.styles(wXml).props(TextStyle(od)));
},
fill: function fill(wXml, od) {
return _extends({ children: null }, od.styles(wXml).props({
bgColor: od.color,
fgColor: od.color,
tidy: function tidy(_ref7) {
var _ref7$patternFill = _ref7.patternFill,
background = _ref7$patternFill.fgColor,
patternType = _ref7$patternFill.patternType;
if (patternType == "none") return {};
if (patternType && patternType.startsWith("gray")) {
var r = Number(parseInt(patternType.substring(4))).toString(16);
return { background: "#" + r + r + r };
}
return { background: background };
}
}));
},
border: function border(wXml, od) {
return _extends({ children: null }, od.styles(wXml).props({
color: od.color,
tidy_left: tidy_border,
tidy_right: tidy_border,
tidy_bottom: tidy_border,
tidy_top: tidy_border,
tidy_diagonal: tidy_border
}));
}
};
exports.default = OfficeDocument;
var parseInt4Keys = function parseInt4Keys(keys) {
return keys.split(",").reduce(function (s, k) {
return s[k] = parseInt, s;
}, {});
};
var ColorIndex = "lt1,dk1,lt2,dk2,accent1,accent2,accent3,accent4,accent5,accent6,hlink,folHlink".split(",");
var tidy_border = function tidy_border(_ref8) {
var style = _ref8.style,
a = _objectWithoutProperties(_ref8, ["style"]);
switch (style) {
case "thin":
a.sz = 1;
break;
default:
break;
}
return a;
};
var TextStyle = function TextStyle(od) {
return {
__filter: ":not(scheme,family,charset)",
names: {
rFont: "fonts",
name: "fonts",
sz: "size",
b: "bold",
i: "italic",
u: "underline",
vanish: "hidden"
},
rFont: function rFont(_ref9) {
var val = _ref9.attribs.val;
return val;
},
name: function name(_ref10) {
var val = _ref10.attribs.val;
return val;
},
b: function b(_ref11) {
var _ref11$attribs$val = _ref11.attribs.val,
val = _ref11$attribs$val === undefined ? true : _ref11$attribs$val;
return !!val;
},
i: function i(_ref12) {
var _ref12$attribs$val = _ref12.attribs.val,
val = _ref12$attribs$val === undefined ? true : _ref12$attribs$val;
return !!val;
},
u: function u(_ref13) {
var _ref13$attribs$val = _ref13.attribs.val,
val = _ref13$attribs$val === undefined ? "single" : _ref13$attribs$val;
return val;
},
vanish: function vanish(_ref14) {
var _ref14$attribs$val = _ref14.attribs.val,
val = _ref14$attribs$val === undefined ? true : _ref14$attribs$val;
return !!val;
},
sz: function sz(_ref15) {
var val = _ref15.attribs.val;
return od.doc.pt2Px(parseInt(val));
},
color: od.color
};
};
var XLSIcv = ["#000000", "#FFFFFF", "#FF0000", "#00FF00", "#0000FF", "#FFFF00", "#FF00FF", "#00FFFF", "#000000", "#FFFFFF", "#FF0000", "#00FF00", "#0000FF", "#FFFF00", "#FF00FF", "#00FFFF", "#800000", "#008000", "#000080", "#808000", "#800080", "#008080", "#C0C0C0", "#808080", "#9999FF", "#993366", "#FFFFCC", "#CCFFFF", "#660066", "#FF8080", "#0066CC", "#CCCCFF", "#000080", "#FF00FF", "#FFFF00", "#00FFFF", "#800080", "#800000", "#008080", "#0000FF", "#00CCFF", "#CCFFFF", "#CCFFCC", "#FFFF99", "#99CCFF", "#FF99CC", "#CC99FF", "#FFCC99", "#3366FF", "#33CCCC", "#99CC00", "#FFCC00", "#FF9900", "#FF6600", "#666699", "#969696", "#003366", "#339966", "#003300", "#333300", "#993300", "#993366", "#333399", "#333333", "#000000", /* "#40 icvForeground ?? */
"#000000", /* "#41 icvBackground ?? */
"#000000", /* "#42 icvFrame ?? */
"#000000", /* "#43 icv3D ?? */
"#000000", /* "#44 icv3DText ?? */
"#000000", /* "#45 icv3DHilite ?? */
"#000000", /* "#46 icv3DShadow ?? */
"#000000", /* "#47 icvHilite ?? */
"#000000", /* "#48 icvCtlText ?? */
"#000000", /* "#49 icvCtlScrl ?? */
"#000000", /* "#4A icvCtlInv ?? */
"#000000", /* "#4B icvCtlBody ?? */
"#000000", /* "#4C icvCtlFrame ?? */
"#000000", /* "#4D icvCtlFore ?? */
"#000000", /* "#4E icvCtlBack ?? */
"#000000", /* "#4F icvCtlNeutral */
"#000000", /* "#50 icvInfoBk ?? */
"#000000" /* "#51 icvInfoText ?? */
];
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/openxml/xlsx/officeDocument.js"],"names":["A","charCodeAt","colStrToInt","col","last","substr","length","substring","colIntToStr","i0","String","fromCharCode","parseInt","OfficeDocument","doc","_assignRel","Object","assign","sharedStrings","eq","i","root","children","styles","identities","constructor","theme","color","$","ColorIndex","first","asColor","attr","attribs","rgb","indexed","tint","v","undefined","XLSIcv","parseFloat","sheetIndex","row","sheet","content","get","s","text","rid","getRel","createElement","identify","bind","renderNode","workbook","wXml","officeDocument","toArray","type","sst","od","count","uniqueCount","baseColWidth","defaultRowHeight","rId","props","colProps","split","reduce","o","k","width","tidy","min","max","cols","map","a","colWidth","rowHeight","view","xSplit","ySplit","customFormat","hidden","style","r","customHeight","ht","height","precision","c","exec","name","kind","parent","t","data","empty","append","clone","is","find","TextStyle","filter","numFmt","cellStyle","xf","names","wrapText","horizontal","vertical","parseInt4Keys","applyNumberFormat","applyFont","applyFill","applyBorder","applyAlignment","numFmtId","fontId","fillId","borderId","alignment","tableStyle","font","fill","bgColor","fgColor","patternFill","background","patternType","startsWith","Number","toString","border","tidy_left","tidy_border","tidy_right","tidy_bottom","tidy_top","tidy_diagonal","keys","sz","__filter","rFont","b","u","vanish","val","pt2Px"],"mappings":"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","file":"officeDocument.js","sourcesContent":["import Base from \"../officeDocument\"\r\nconst A=\"A\".charCodeAt(0)\r\n//A=>0, Z=>25, AA=>26\r\nfunction colStrToInt(col){\r\n    const last=col.substr(-1).charCodeAt(0)-A\r\n    if(col.length>1){\r\n        return 26*(colStrToInt(col.substring(0,col.length-1))+1)+last\r\n    }\r\n    return last\r\n}\r\n//0=>A, 25=>Z, 26=>AA\r\nfunction colIntToStr(col){\r\n    const i0=String.fromCharCode(A+col%26)\r\n    if(col>=26){\r\n        return colIntToStr(parseInt(col/26)-1)+i0\r\n    }else{\r\n        return i0\r\n    }\r\n}\r\n\r\nexport default class OfficeDocument extends Base{\r\n    static colStrToInt=colStrToInt\r\n    static colIntToStr=colIntToStr\r\n    _init(){\r\n        super._init()\r\n        const doc=this.doc\r\n        this._assignRel([\"styles\",\"sharedStrings\"])\r\n        Object.assign(this.sharedStrings,{\r\n            eq(i){\r\n                return this.root().children(\"sst\").children().eq(parseInt(i))\r\n            }, \r\n            doc, \r\n        })\r\n        Object.assign(this.styles,{identities:this.constructor.identities,doc})\r\n        this.theme.color=function(i){\r\n            const $=this(`a\\\\:clrScheme>a\\\\:${ColorIndex[parseInt(i)]}`).children().first()\r\n            return doc.asColor($.attr(\"lastClr\")||$.attr(\"val\"))\r\n        }\r\n        this.color=({attribs:{rgb,theme,indexed,tint}})=>{\r\n            const v=(rgb&&`#${rgb.substr(2)}`)||(theme && this.theme.color(theme))|| (indexed!=undefined && `${XLSIcv[parseInt(indexed)]}`)\r\n            return tint ? this.doc.asColor(v,{tint:parseFloat(tint)}) : v\r\n        }\r\n    }\r\n\r\n    cellPlainText(sheetIndex,row,col){\r\n        row=row+1\r\n        col=colIntToStr(col)\r\n        const sheet=this.sheet(this.content(`sheets>sheet`).get(sheetIndex).attribs)\r\n        const s=sheet(`worksheet>sheetData>row[r=${row}]>c[r='${col}${row}']>v`).text()\r\n        if(s){\r\n            return this.sharedStrings.eq(s).text()\r\n        }\r\n        return \"\"\r\n    }\r\n\r\n    sheet({\"r:id\":rid}){\r\n        return this.getRel(rid)\r\n    }\r\n\r\n    render(createElement, identify=this.constructor.identify.bind(this.constructor)){\r\n        this.renderNode(this.styles(\"styleSheet\").get(0),createElement,identify)\r\n        return this.renderNode(this.content(\"workbook\").get(0), createElement, identify)\r\n    }\r\n\r\n    static identities={\r\n        workbook(wXml, officeDocument){\r\n            const $=officeDocument.content(\"sheets\")\r\n            const children=$.children(\"sheet\").toArray()\r\n            return {\r\n                type:\"workbook\",\r\n                children\r\n            }\r\n        },\r\n        sst({attribs:{count, uniqueCount}},od){\r\n            return {type:\"sharedStrings\",count:parseInt(count),uniqueCount:parseInt(uniqueCount)}\r\n        },\r\n        sheet(wXml, od){\r\n            const $=od.sheet(wXml.attribs)\r\n            \r\n            const {attribs:{baseColWidth,defaultRowHeight}}=$(\"sheetFormatPr\").get(0)\r\n            const children=$(\"sheetData>row\").toArray()\r\n            const {\"r:id\":rId,...props}=wXml.attribs\r\n            const colProps=\"customWidth,min,max,style,hidden\".split(\",\").reduce((o,k)=>(o[k]=parseInt,o),{\r\n                width:parseFloat,\r\n                tidy:({min,max,...props})=>({...props,min:min-1,max:max-1})\r\n            })\r\n            return {\r\n                ...props,\r\n                type:\"sheet\",\r\n                children, \r\n                cols: $(\"cols\").children().map((i,a)=>$(a).props(colProps)).get(),\r\n                colWidth: parseFloat(baseColWidth), \r\n                rowHeight:parseFloat(defaultRowHeight),\r\n                view:$(\"sheetViews>sheetView\").props({xSplit:parseInt,ySplit:parseInt})\r\n            }\r\n        },\r\n        row(wXml, od){\r\n            const $=od.$(wXml)\r\n            const {customFormat, hidden,s, style=customFormat&&parseInt(s)||undefined, r,customHeight,ht, height=ht && parseFloat(ht)*(od.doc.precision||1)}=wXml.attribs\r\n            const children=$.children(\"c\").toArray()\r\n            return {type:\"row\",children, customHeight, height, i:parseInt(r)-1, style,hidden}\r\n        },\r\n        c(wXml, od){\r\n            const {attribs:{r,s:style}}=wXml\r\n            const children=od.$(wXml).children().toArray()\r\n            const [,col,row,]=/([A-Z]+)(\\d+$)/.exec(r)\r\n            return {\r\n                type:\"cell\",\r\n                name:`${parseInt(row)-1}${col}`,\r\n                col:colStrToInt(col),\r\n                row:parseInt(row)-1, \r\n                children,\r\n                style:style!=undefined ? parseInt(style) : undefined\r\n            }\r\n        },\r\n        v(wXml,od){\r\n            const {attribs:{t:kind}}=wXml.parent\r\n            const {children:[{data}]}=wXml\r\n            switch(kind){\r\n            case \"i\":\r\n                return {type:\"paragraph\",kind,children:[...wXml.children]}\r\n            case \"s\":\r\n                od.$(wXml).empty().append(od.sharedStrings.eq(data).clone().children())\r\n                break\r\n            default:\r\n                od.$(wXml).empty().append(`<r><t>${data}</t></r>`)\r\n                break\r\n            }\r\n            wXml.parent.attribs.t=\"i\"\r\n            return {type:\"paragraph\",kind,children:[...wXml.children]}\r\n        },\r\n        is(wXml,od){\r\n            wXml.name=\"v\"\r\n            return {type:\"paragraph\",kind:\"is\",children:[...wXml.children]}\r\n        },\r\n        \r\n        r(wXml,od){\r\n            const style=od.$(wXml).find(\">rPr\").props(TextStyle(od))\r\n            return {\r\n                type:\"run\",\r\n                style, \r\n                children: wXml.children.filter(({name})=>name!=\"rPr\")\r\n            }\r\n        },\r\n\r\n        //styles\r\n        numFmt(wXml,od){\r\n            return {children:null,...od.styles(wXml).props()}\r\n        },\r\n        cellStyle(wXml,od){\r\n            return {children:null,...od.styles(wXml).props()}\r\n        },\r\n        xf(wXml,od){\r\n            return {children:null,...od.styles(wXml).props({\r\n                names:{\r\n                    wrapText:\"wrap\",\r\n                    horizontal:\"align\",\r\n                    vertical:\"vertAlign\",\r\n                },\r\n                wrapText:v=>v==\"true\"||v==\"1\" ? true : false,\r\n                ...parseInt4Keys(\"numFmtId,fontId,fillId,borderId,xfId,applyNumberFormat,applyFont,applyFill,applyBorder,applyAlignment\"),\r\n                tidy({applyNumberFormat,applyFont,applyFill,applyBorder,applyAlignment, ...a}){\r\n                    if(applyNumberFormat==0)\r\n                        delete a.numFmtId\r\n                    if(applyFont==0)\r\n                        delete a.fontId\r\n                    if(applyFill==0)\r\n                        delete a.fillId\r\n                    if(applyBorder==0)\r\n                        delete a.borderId\r\n                    if(applyAlignment==0)\r\n                        delete a.alignment\r\n                    return a\r\n                }\r\n            })}\r\n        },\r\n        tableStyle(wXml,od){\r\n            return {children:null,...od.styles(wXml).props()}\r\n        },\r\n        font(wXml,od){\r\n            return {children:null,...od.styles(wXml).props(TextStyle(od))}\r\n        },\r\n        fill(wXml,od){\r\n            return {children:null,...od.styles(wXml).props({\r\n                bgColor:od.color,\r\n                fgColor:od.color,\r\n                tidy({patternFill:{fgColor:background,patternType}}){\r\n                    if(patternType==\"none\")\r\n                        return {}\r\n                    if(patternType && patternType.startsWith(\"gray\")){\r\n                        const r=Number(parseInt(patternType.substring(4))).toString(16)\r\n                        return {background:`#${r}${r}${r}`}\r\n                    }\r\n                    return {background}\r\n                }\r\n            })}\r\n        },\r\n        border(wXml,od){\r\n            return {children:null,...od.styles(wXml).props({\r\n                color:od.color,\r\n                tidy_left:tidy_border,\r\n                tidy_right:tidy_border,\r\n                tidy_bottom:tidy_border,\r\n                tidy_top:tidy_border,\r\n                tidy_diagonal: tidy_border,\r\n            })}\r\n        },\r\n    }\r\n}\r\n\r\n\r\nconst parseInt4Keys=keys=>keys.split(\",\").reduce((s,k)=>(s[k]=parseInt,s),{})\r\nconst ColorIndex=\"lt1,dk1,lt2,dk2,accent1,accent2,accent3,accent4,accent5,accent6,hlink,folHlink\".split(\",\")\r\nconst tidy_border=({style,...a})=>{\r\n    switch(style){\r\n        case \"thin\":\r\n            a.sz=1\r\n            break\r\n        default:\r\n            break\r\n    }\r\n    return a\r\n}\r\nconst TextStyle=od=>({\r\n    __filter:\":not(scheme,family,charset)\",\r\n    names:{\r\n        rFont:\"fonts\",\r\n        name:\"fonts\",\r\n        sz:\"size\",\r\n        b:\"bold\",\r\n        i:\"italic\",\r\n        u:\"underline\",\r\n        vanish:\"hidden\"\r\n    },\r\n    rFont:({attribs:{val}})=>val,\r\n    name:({attribs:{val}})=>val,\r\n    b:({attribs:{val=true}})=>!!val,\r\n    i:({attribs:{val=true}})=>!!val,\r\n    u:({attribs:{val=\"single\"}})=>val,\r\n    vanish:({attribs:{val=true}})=>!!val,\r\n    sz:({attribs:{val}})=>od.doc.pt2Px(parseInt(val)),\r\n\r\n    color:od.color,\r\n})\r\n\r\nconst XLSIcv = [\r\n    \"#000000\",\r\n\t\"#FFFFFF\",\r\n\t\"#FF0000\",\r\n\t\"#00FF00\",\r\n\t\"#0000FF\",\r\n\t\"#FFFF00\",\r\n\t\"#FF00FF\",\r\n\t\"#00FFFF\",\r\n\t\"#000000\",\r\n\t\"#FFFFFF\",\r\n\t\"#FF0000\",\r\n\t\"#00FF00\",\r\n\t\"#0000FF\",\r\n\t\"#FFFF00\",\r\n\t\"#FF00FF\",\r\n\t\"#00FFFF\",\r\n\t\"#800000\",\r\n\t\"#008000\",\r\n\t\"#000080\",\r\n\t\"#808000\",\r\n\t\"#800080\",\r\n\t\"#008080\",\r\n\t\"#C0C0C0\",\r\n\t\"#808080\",\r\n\t\"#9999FF\",\r\n\t\"#993366\",\r\n\t\"#FFFFCC\",\r\n\t\"#CCFFFF\",\r\n\t\"#660066\",\r\n\t\"#FF8080\",\r\n\t\"#0066CC\",\r\n\t\"#CCCCFF\",\r\n\t\"#000080\",\r\n\t\"#FF00FF\",\r\n\t\"#FFFF00\",\r\n\t\"#00FFFF\",\r\n\t\"#800080\",\r\n\t\"#800000\",\r\n\t\"#008080\",\r\n\t\"#0000FF\",\r\n\t\"#00CCFF\",\r\n\t\"#CCFFFF\",\r\n\t\"#CCFFCC\",\r\n\t\"#FFFF99\",\r\n\t\"#99CCFF\",\r\n\t\"#FF99CC\",\r\n\t\"#CC99FF\",\r\n\t\"#FFCC99\",\r\n\t\"#3366FF\",\r\n\t\"#33CCCC\",\r\n\t\"#99CC00\",\r\n\t\"#FFCC00\",\r\n\t\"#FF9900\",\r\n\t\"#FF6600\",\r\n\t\"#666699\",\r\n\t\"#969696\",\r\n\t\"#003366\",\r\n\t\"#339966\",\r\n\t\"#003300\",\r\n\t\"#333300\",\r\n\t\"#993300\",\r\n\t\"#993366\",\r\n\t\"#333399\",\r\n\t\"#333333\",\r\n\t\"#000000\", /* \"#40 icvForeground ?? */\r\n\t\"#000000\", /* \"#41 icvBackground ?? */\r\n\t\"#000000\", /* \"#42 icvFrame ?? */\r\n\t\"#000000\", /* \"#43 icv3D ?? */\r\n\t\"#000000\", /* \"#44 icv3DTex