yxuse 3.0.64 → 3.0.66

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (76) hide show
  1. package/lib/.pnpm.cjs.js +26 -0
  2. package/lib/.pnpm.cjs.js.gz +0 -0
  3. package/lib/.pnpm.cjs.js.map +1 -0
  4. package/lib/.pnpm.es.js +54020 -0
  5. package/lib/.pnpm.es.js.gz +0 -0
  6. package/lib/.pnpm.es.js.map +1 -0
  7. package/lib/api.cjs.js +1 -1
  8. package/lib/api.es.js +1 -1
  9. package/lib/components.cjs.js +1 -1
  10. package/lib/components.es.js +2 -1
  11. package/lib/index.cjs11.js +1 -1
  12. package/lib/index.cjs11.js.map +1 -1
  13. package/lib/index.cjs12.js +1 -1
  14. package/lib/index.cjs12.js.map +1 -1
  15. package/lib/index.cjs13.js +1 -1
  16. package/lib/index.cjs13.js.map +1 -1
  17. package/lib/index.cjs14.js +2 -0
  18. package/lib/index.cjs14.js.map +1 -0
  19. package/lib/index.cjs2.js +1 -1
  20. package/lib/index.cjs2.js.map +1 -1
  21. package/lib/index.cjs3.js +1 -1
  22. package/lib/index.cjs4.js +1 -1
  23. package/lib/index.cjs5.js +1 -23
  24. package/lib/index.cjs5.js.gz +0 -0
  25. package/lib/index.cjs5.js.map +1 -1
  26. package/lib/index.cjs6.js +1 -4
  27. package/lib/index.cjs6.js.gz +0 -0
  28. package/lib/index.cjs6.js.map +1 -1
  29. package/lib/index.es11.js +1 -1
  30. package/lib/index.es12.js +5 -2379
  31. package/lib/index.es12.js.gz +0 -0
  32. package/lib/index.es12.js.map +1 -1
  33. package/lib/index.es13.js +243 -20
  34. package/lib/index.es13.js.map +1 -1
  35. package/lib/index.es14.js +23 -0
  36. package/lib/index.es14.js.map +1 -0
  37. package/lib/index.es2.js +2 -1
  38. package/lib/index.es2.js.map +1 -1
  39. package/lib/index.es3.js +1 -1
  40. package/lib/index.es4.js +1 -1
  41. package/lib/index.es5.js +446 -24386
  42. package/lib/index.es5.js.gz +0 -0
  43. package/lib/index.es5.js.map +1 -1
  44. package/lib/index.es6.js +65 -20216
  45. package/lib/index.es6.js.gz +0 -0
  46. package/lib/index.es6.js.map +1 -1
  47. package/lib/theme.cjs.js +1 -1
  48. package/lib/theme.es.js +2 -1
  49. package/lib/theme.es.js.map +1 -1
  50. package/lib/translate.cjs.js +1 -1
  51. package/lib/translate.es.js +1 -2
  52. package/lib/translate.es.js.map +1 -1
  53. package/lib/utils.cjs.js +1 -1
  54. package/lib/utils.es.js +1 -1
  55. package/lib/yxIcon.cjs.js +1 -1
  56. package/lib/yxIcon.es.js +1 -1
  57. package/lib/yxuse.css +1 -0
  58. package/lib/yxuse.css.gz +0 -0
  59. package/package.json +28 -27
  60. package/types/components/YxTable/type.d.ts +3 -1
  61. package/types/components/YxTablePro/index.d.ts +27 -0
  62. package/types/components/YxTablePro/type.d.ts +80 -0
  63. package/types/components/index.d.ts +1 -0
  64. package/lib/dayjs.min.cjs.js +0 -2
  65. package/lib/dayjs.min.cjs.js.map +0 -1
  66. package/lib/dayjs.min.es.js +0 -313
  67. package/lib/dayjs.min.es.js.gz +0 -0
  68. package/lib/dayjs.min.es.js.map +0 -1
  69. package/lib/index.cjs12.js.gz +0 -0
  70. package/lib/mqtt.min.cjs.js +0 -2
  71. package/lib/mqtt.min.cjs.js.gz +0 -0
  72. package/lib/mqtt.min.cjs.js.map +0 -1
  73. package/lib/mqtt.min.es.js +0 -7062
  74. package/lib/mqtt.min.es.js.gz +0 -0
  75. package/lib/mqtt.min.es.js.map +0 -1
  76. package/lib/style.css +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs6.js","sources":["../packages/components/YxDialog/index.vue","../packages/components/YxDrawer/index.vue","../node_modules/.pnpm/xlsx@0.18.5/node_modules/xlsx/xlsx.mjs","../packages/utils/excel/index.ts","../packages/components/YxTable/index.vue","../packages/components/YxForm/icon/question.svg?component","../packages/components/YxForm/index.vue","../packages/utils/common/update.ts","../packages/components/Update/index.vue","../packages/components/YxIcon/index.vue","../packages/components/YxUpload/index.vue","../packages/components/LogoTitle/index.vue","../packages/components/LogoTitle/index.ts"],"sourcesContent":["<!--\n * @Author: WangXin\n * @Date: 2024-01-17 18:18:08\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-15 16:06:10\n * @FilePath: /yxuse/packages/components/YxDialog/index.vue\n * @Description: \n * \n * Copyright (c) 2024 by YuXing, All Rights Reserved. \n-->\n\n<script setup lang=\"ts\" name=\"YxDialog\">\nimport { reactive } from \"vue\";\nimport type { DialogOptions } from \"./type\";\nconst dialogOptions = reactive({\n\twidth: \"40%\",\n\tshow: false,\n\ttitle: \"\",\n\tloading: false,\n\tshowFooter: true,\n\tautoClose: true\n});\nconst close = () => {\n\tconsole.log(\"关闭\");\n\tdialogMap[\"cancel\"] && dialogMap[\"cancel\"]();\n\tdialogOptions.show = false;\n};\nconst dialogMap: Record<string, Function> = {};\nconst submit = async () => {\n\t//执行提交之前的回调\n\tif (dialogMap[\"beforeSubmit\"] && !(await dialogMap[\"beforeSubmit\"]())) return;\n\tdialogOptions.loading = true;\n\ttry {\n\t\tdialogMap[\"submit\"] && (await dialogMap[\"submit\"]());\n\t\tdialogOptions.loading = false;\n\t\tif (dialogOptions.autoClose) close();\n\t} catch (err) {\n\t\tdialogOptions.loading = false;\n\t}\n};\nconst show = async ({ width, title, submit, cancel, showFooter, autoClose, beforeOpen, beforeSubmit }: DialogOptions) => {\n\tif (width) dialogOptions.width = width;\n\tif (title) dialogOptions.title = title;\n\tif (showFooter !== undefined) dialogOptions.showFooter = showFooter;\n\tif (autoClose !== undefined) dialogOptions.autoClose = autoClose;\n\tif (submit) dialogMap[\"submit\"] = submit;\n\tif (cancel) dialogMap[\"cancel\"] = cancel;\n\tif (beforeSubmit) dialogMap[\"beforeSubmit\"] = beforeSubmit;\n\tif (beforeOpen) {\n\t\tawait beforeOpen();\n\t}\n\tdialogOptions.show = true;\n};\n\ndefineExpose({\n\tshow,\n\tclose\n});\n</script>\n\n<template>\n\t<el-dialog\n\t\t:close-on-click-modal=\"false\"\n\t\tattrs\n\t\t:width=\"dialogOptions.width\"\n\t\tv-model=\"dialogOptions.show\"\n\t\t:title=\"dialogOptions.title\"\n\t\tdestroy-on-close\n\t\t:before-close=\"close\"\n\t>\n\t\t<slot />\n\t\t<template #footer v-if=\"dialogOptions.showFooter\">\n\t\t\t<span class=\"dialog-footer flex justify-end\">\n\t\t\t\t<el-button plain @click=\"dialogOptions.show = false\">取消</el-button>\n\t\t\t\t<el-button :loading=\"dialogOptions.loading\" @click=\"submit\">确认</el-button>\n\t\t\t</span>\n\t\t</template>\n\t</el-dialog>\n</template>\n\n<style scoped lang=\"scss\"></style>\n","<!--\n * @Author: WangXin\n * @Date: 2024-01-17 18:18:08\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-15 16:05:44\n * @FilePath: /yxuse/packages/components/YxDrawer/index.vue\n * @Description: \n * \n * Copyright (c) 2024 by YuXing, All Rights Reserved. \n-->\n\n<script setup lang=\"ts\" name=\"YxDrawer\">\nimport { reactive } from \"vue\";\nimport type { DrawerOptions } from \"./type\";\nconst drawerOptions = reactive({\n\twidth: \"40%\",\n\tshow: false,\n\ttitle: \"\",\n\tloading: false,\n\tshowFooter: true,\n\tautoClose: true\n});\nconst close = () => {\n\tdrawerMap[\"cancel\"] && drawerMap[\"cancel\"]();\n\tdrawerOptions.show = false;\n\tconsole.log(\"关闭\");\n};\nconst drawerMap: Record<string, Function> = {};\nconst submit = async () => {\n\t//执行提交之前的回调\n\tif (drawerMap[\"beforeSubmit\"] && !(await drawerMap[\"beforeSubmit\"]())) return;\n\tdrawerOptions.loading = true;\n\ttry {\n\t\tdrawerMap[\"submit\"] && (await drawerMap[\"submit\"]());\n\t\tdrawerOptions.loading = false;\n\t\tif (drawerOptions.autoClose) close();\n\t} catch (err) {\n\t\tdrawerOptions.loading = false;\n\t}\n};\nconst show = async ({ width, title, submit, cancel, showFooter, autoClose, beforeOpen, beforeSubmit }: DrawerOptions) => {\n\tif (width) drawerOptions.width = width;\n\tif (title) drawerOptions.title = title;\n\tif (showFooter !== undefined) drawerOptions.showFooter = showFooter;\n\tif (autoClose !== undefined) drawerOptions.autoClose = autoClose;\n\tif (submit) drawerMap[\"submit\"] = submit;\n\tif (cancel) drawerMap[\"cancel\"] = cancel;\n\tif (beforeSubmit) drawerMap[\"beforeSubmit\"] = beforeSubmit;\n\tif (beforeOpen) {\n\t\tawait beforeOpen();\n\t}\n\tdrawerOptions.show = true;\n};\ndefineExpose({\n\tshow,\n\tclose\n});\n</script>\n<template>\n\t<el-drawer\n\t\t:close-on-click-modal=\"false\"\n\t\tattrs\n\t\t:size=\"drawerOptions.width\"\n\t\tv-model=\"drawerOptions.show\"\n\t\t:title=\"drawerOptions.title\"\n\t\tdestroy-on-close\n\t\t@close=\"close\"\n\t>\n\t\t<slot />\n\t\t<template #footer v-if=\"drawerOptions.showFooter\">\n\t\t\t<span class=\"dialog-footer flex justify-end\">\n\t\t\t\t<el-button plain @click=\"drawerOptions.show = false\">取消</el-button>\n\t\t\t\t<el-button :loading=\"drawerOptions.loading\" @click=\"submit\">确认</el-button>\n\t\t\t</span>\n\t\t</template>\n\t</el-drawer>\n</template>\n\n<style scoped lang=\"scss\"></style>\n","/*! xlsx.js (C) 2013-present SheetJS -- http://sheetjs.com */\n/* vim: set ts=2: */\n/*exported XLSX */\n/*global process:false, Buffer:false, ArrayBuffer:false, DataView:false, Deno:false */\nvar XLSX = {};\nXLSX.version = '0.18.5';\nvar current_codepage = 1200, current_ansi = 1252;\n\nvar VALID_ANSI = [ 874, 932, 936, 949, 950, 1250, 1251, 1252, 1253, 1254, 1255, 1256, 1257, 1258, 10000 ];\n/* ECMA-376 Part I 18.4.1 charset to codepage mapping */\nvar CS2CP = ({\n\t/*::[*/0/*::]*/: 1252, /* ANSI */\n\t/*::[*/1/*::]*/: 65001, /* DEFAULT */\n\t/*::[*/2/*::]*/: 65001, /* SYMBOL */\n\t/*::[*/77/*::]*/: 10000, /* MAC */\n\t/*::[*/128/*::]*/: 932, /* SHIFTJIS */\n\t/*::[*/129/*::]*/: 949, /* HANGUL */\n\t/*::[*/130/*::]*/: 1361, /* JOHAB */\n\t/*::[*/134/*::]*/: 936, /* GB2312 */\n\t/*::[*/136/*::]*/: 950, /* CHINESEBIG5 */\n\t/*::[*/161/*::]*/: 1253, /* GREEK */\n\t/*::[*/162/*::]*/: 1254, /* TURKISH */\n\t/*::[*/163/*::]*/: 1258, /* VIETNAMESE */\n\t/*::[*/177/*::]*/: 1255, /* HEBREW */\n\t/*::[*/178/*::]*/: 1256, /* ARABIC */\n\t/*::[*/186/*::]*/: 1257, /* BALTIC */\n\t/*::[*/204/*::]*/: 1251, /* RUSSIAN */\n\t/*::[*/222/*::]*/: 874, /* THAI */\n\t/*::[*/238/*::]*/: 1250, /* EASTEUROPE */\n\t/*::[*/255/*::]*/: 1252, /* OEM */\n\t/*::[*/69/*::]*/: 6969 /* MISC */\n}/*:any*/);\n\nvar set_ansi = function(cp/*:number*/) { if(VALID_ANSI.indexOf(cp) == -1) return; current_ansi = CS2CP[0] = cp; };\nfunction reset_ansi() { set_ansi(1252); }\n\nvar set_cp = function(cp/*:number*/) { current_codepage = cp; set_ansi(cp); };\nfunction reset_cp() { set_cp(1200); reset_ansi(); }\n\nfunction char_codes(data/*:string*/)/*:Array<number>*/ { var o/*:Array<number>*/ = []; for(var i = 0, len = data.length; i < len; ++i) o[i] = data.charCodeAt(i); return o; }\n\nfunction utf16leread(data/*:string*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\tfor(var i = 0; i < (data.length>>1); ++i) o[i] = String.fromCharCode(data.charCodeAt(2*i) + (data.charCodeAt(2*i+1)<<8));\n\treturn o.join(\"\");\n}\nfunction utf16beread(data/*:string*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\tfor(var i = 0; i < (data.length>>1); ++i) o[i] = String.fromCharCode(data.charCodeAt(2*i+1) + (data.charCodeAt(2*i)<<8));\n\treturn o.join(\"\");\n}\n\nvar debom = function(data/*:string*/)/*:string*/ {\n\tvar c1 = data.charCodeAt(0), c2 = data.charCodeAt(1);\n\tif(c1 == 0xFF && c2 == 0xFE) return utf16leread(data.slice(2));\n\tif(c1 == 0xFE && c2 == 0xFF) return utf16beread(data.slice(2));\n\tif(c1 == 0xFEFF) return data.slice(1);\n\treturn data;\n};\n\nvar _getchar = function _gc1(x/*:number*/)/*:string*/ { return String.fromCharCode(x); };\nvar _getansi = function _ga1(x/*:number*/)/*:string*/ { return String.fromCharCode(x); };\n\nvar $cptable;\nfunction set_cptable(cptable) {\n\t$cptable = cptable;\n\tset_cp = function(cp/*:number*/) { current_codepage = cp; set_ansi(cp); };\n\tdebom = function(data/*:string*/) {\n\t\tif(data.charCodeAt(0) === 0xFF && data.charCodeAt(1) === 0xFE) { return $cptable.utils.decode(1200, char_codes(data.slice(2))); }\n\t\treturn data;\n\t};\n\t_getchar = function _gc2(x/*:number*/)/*:string*/ {\n\t\tif(current_codepage === 1200) return String.fromCharCode(x);\n\t\treturn $cptable.utils.decode(current_codepage, [x&255,x>>8])[0];\n\t};\n\t_getansi = function _ga2(x/*:number*/)/*:string*/ {\n\t\treturn $cptable.utils.decode(current_ansi, [x])[0];\n\t};\n\tcpdoit();\n}\nexport { set_cptable };\nvar DENSE = null;\nvar DIF_XL = true;\nvar Base64_map = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\";\nfunction Base64_encode(input) {\n var o = \"\";\n var c1 = 0, c2 = 0, c3 = 0, e1 = 0, e2 = 0, e3 = 0, e4 = 0;\n for (var i = 0; i < input.length; ) {\n c1 = input.charCodeAt(i++);\n e1 = c1 >> 2;\n c2 = input.charCodeAt(i++);\n e2 = (c1 & 3) << 4 | c2 >> 4;\n c3 = input.charCodeAt(i++);\n e3 = (c2 & 15) << 2 | c3 >> 6;\n e4 = c3 & 63;\n if (isNaN(c2)) {\n e3 = e4 = 64;\n } else if (isNaN(c3)) {\n e4 = 64;\n }\n o += Base64_map.charAt(e1) + Base64_map.charAt(e2) + Base64_map.charAt(e3) + Base64_map.charAt(e4);\n }\n return o;\n}\nfunction Base64_decode(input) {\n var o = \"\";\n var c1 = 0, c2 = 0, c3 = 0, e1 = 0, e2 = 0, e3 = 0, e4 = 0;\n input = input.replace(/[^\\w\\+\\/\\=]/g, \"\");\n for (var i = 0; i < input.length; ) {\n e1 = Base64_map.indexOf(input.charAt(i++));\n e2 = Base64_map.indexOf(input.charAt(i++));\n c1 = e1 << 2 | e2 >> 4;\n o += String.fromCharCode(c1);\n e3 = Base64_map.indexOf(input.charAt(i++));\n c2 = (e2 & 15) << 4 | e3 >> 2;\n if (e3 !== 64) {\n o += String.fromCharCode(c2);\n }\n e4 = Base64_map.indexOf(input.charAt(i++));\n c3 = (e3 & 3) << 6 | e4;\n if (e4 !== 64) {\n o += String.fromCharCode(c3);\n }\n }\n return o;\n}\nvar has_buf = /*#__PURE__*/(function() { return typeof Buffer !== 'undefined' && typeof process !== 'undefined' && typeof process.versions !== 'undefined' && !!process.versions.node; })();\n\nvar Buffer_from = /*#__PURE__*/(function() {\n\tif(typeof Buffer !== 'undefined') {\n\t\tvar nbfs = !Buffer.from;\n\t\tif(!nbfs) try { Buffer.from(\"foo\", \"utf8\"); } catch(e) { nbfs = true; }\n\t\treturn nbfs ? function(buf, enc) { return (enc) ? new Buffer(buf, enc) : new Buffer(buf); } : Buffer.from.bind(Buffer);\n\t}\n\treturn function() {};\n})();\n\n\nfunction new_raw_buf(len/*:number*/) {\n\t/* jshint -W056 */\n\tif(has_buf) return Buffer.alloc ? Buffer.alloc(len) : new Buffer(len);\n\treturn typeof Uint8Array != \"undefined\" ? new Uint8Array(len) : new Array(len);\n\t/* jshint +W056 */\n}\n\nfunction new_unsafe_buf(len/*:number*/) {\n\t/* jshint -W056 */\n\tif(has_buf) return Buffer.allocUnsafe ? Buffer.allocUnsafe(len) : new Buffer(len);\n\treturn typeof Uint8Array != \"undefined\" ? new Uint8Array(len) : new Array(len);\n\t/* jshint +W056 */\n}\n\nvar s2a = function s2a(s/*:string*/)/*:any*/ {\n\tif(has_buf) return Buffer_from(s, \"binary\");\n\treturn s.split(\"\").map(function(x/*:string*/)/*:number*/{ return x.charCodeAt(0) & 0xff; });\n};\n\nfunction s2ab(s/*:string*/)/*:any*/ {\n\tif(typeof ArrayBuffer === 'undefined') return s2a(s);\n\tvar buf = new ArrayBuffer(s.length), view = new Uint8Array(buf);\n\tfor (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;\n\treturn buf;\n}\n\nfunction a2s(data/*:any*/)/*:string*/ {\n\tif(Array.isArray(data)) return data.map(function(c) { return String.fromCharCode(c); }).join(\"\");\n\tvar o/*:Array<string>*/ = []; for(var i = 0; i < data.length; ++i) o[i] = String.fromCharCode(data[i]); return o.join(\"\");\n}\n\nfunction a2u(data/*:Array<number>*/)/*:Uint8Array*/ {\n\tif(typeof Uint8Array === 'undefined') throw new Error(\"Unsupported\");\n\treturn new Uint8Array(data);\n}\n\nfunction ab2a(data/*:ArrayBuffer|Uint8Array*/)/*:Array<number>*/ {\n\tif(typeof ArrayBuffer == 'undefined') throw new Error(\"Unsupported\");\n\tif(data instanceof ArrayBuffer) return ab2a(new Uint8Array(data));\n\t/*:: if(data instanceof ArrayBuffer) throw new Error(\"unreachable\"); */\n\tvar o = new Array(data.length);\n\tfor(var i = 0; i < data.length; ++i) o[i] = data[i];\n\treturn o;\n}\n\nvar bconcat = has_buf ? function(bufs) { return Buffer.concat(bufs.map(function(buf) { return Buffer.isBuffer(buf) ? buf : Buffer_from(buf); })); } : function(bufs) {\n\tif(typeof Uint8Array !== \"undefined\") {\n\t\tvar i = 0, maxlen = 0;\n\t\tfor(i = 0; i < bufs.length; ++i) maxlen += bufs[i].length;\n\t\tvar o = new Uint8Array(maxlen);\n\t\tvar len = 0;\n\t\tfor(i = 0, maxlen = 0; i < bufs.length; maxlen += len, ++i) {\n\t\t\tlen = bufs[i].length;\n\t\t\tif(bufs[i] instanceof Uint8Array) o.set(bufs[i], maxlen);\n\t\t\telse if(typeof bufs[i] == \"string\") { throw \"wtf\"; }\n\t\t\telse o.set(new Uint8Array(bufs[i]), maxlen);\n\t\t}\n\t\treturn o;\n\t}\n\treturn [].concat.apply([], bufs.map(function(buf) { return Array.isArray(buf) ? buf : [].slice.call(buf); }));\n};\n\nfunction utf8decode(content/*:string*/) {\n\tvar out = [], widx = 0, L = content.length + 250;\n\tvar o = new_raw_buf(content.length + 255);\n\tfor(var ridx = 0; ridx < content.length; ++ridx) {\n\t\tvar c = content.charCodeAt(ridx);\n\t\tif(c < 0x80) o[widx++] = c;\n\t\telse if(c < 0x800) {\n\t\t\to[widx++] = (192|((c>>6)&31));\n\t\t\to[widx++] = (128|(c&63));\n\t\t} else if(c >= 0xD800 && c < 0xE000) {\n\t\t\tc = (c&1023)+64;\n\t\t\tvar d = content.charCodeAt(++ridx)&1023;\n\t\t\to[widx++] = (240|((c>>8)&7));\n\t\t\to[widx++] = (128|((c>>2)&63));\n\t\t\to[widx++] = (128|((d>>6)&15)|((c&3)<<4));\n\t\t\to[widx++] = (128|(d&63));\n\t\t} else {\n\t\t\to[widx++] = (224|((c>>12)&15));\n\t\t\to[widx++] = (128|((c>>6)&63));\n\t\t\to[widx++] = (128|(c&63));\n\t\t}\n\t\tif(widx > L) {\n\t\t\tout.push(o.slice(0, widx));\n\t\t\twidx = 0;\n\t\t\to = new_raw_buf(65535);\n\t\t\tL = 65530;\n\t\t}\n\t}\n\tout.push(o.slice(0, widx));\n\treturn bconcat(out);\n}\n\nvar chr0 = /\\u0000/g, chr1 = /[\\u0001-\\u0006]/g;\n/*::\ndeclare type Block = any;\ndeclare type BufArray = {\n\tnewblk(sz:number):Block;\n\tnext(sz:number):Block;\n\tend():any;\n\tpush(buf:Block):void;\n};\n\ntype RecordHopperCB = {(d:any, Rn:string, RT:number):?boolean;};\n\ntype EvertType = {[string]:string};\ntype EvertNumType = {[string]:number};\ntype EvertArrType = {[string]:Array<string>};\n\ntype StringConv = {(string):string};\n\n*/\n/* ssf.js (C) 2013-present SheetJS -- http://sheetjs.com */\n/*jshint -W041 */\nfunction _strrev(x/*:string*/)/*:string*/ { var o = \"\", i = x.length-1; while(i>=0) o += x.charAt(i--); return o; }\nfunction pad0(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+v; return t.length>=d?t:fill('0',d-t.length)+t;}\nfunction pad_(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+v;return t.length>=d?t:fill(' ',d-t.length)+t;}\nfunction rpad_(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+v; return t.length>=d?t:t+fill(' ',d-t.length);}\nfunction pad0r1(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+Math.round(v); return t.length>=d?t:fill('0',d-t.length)+t;}\nfunction pad0r2(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+v; return t.length>=d?t:fill('0',d-t.length)+t;}\nvar p2_32 = /*#__PURE__*/Math.pow(2,32);\nfunction pad0r(v/*:any*/,d/*:number*/)/*:string*/{if(v>p2_32||v<-p2_32) return pad0r1(v,d); var i = Math.round(v); return pad0r2(i,d); }\n/* yes, in 2022 this is still faster than string compare */\nfunction SSF_isgeneral(s/*:string*/, i/*:?number*/)/*:boolean*/ { i = i || 0; return s.length >= 7 + i && (s.charCodeAt(i)|32) === 103 && (s.charCodeAt(i+1)|32) === 101 && (s.charCodeAt(i+2)|32) === 110 && (s.charCodeAt(i+3)|32) === 101 && (s.charCodeAt(i+4)|32) === 114 && (s.charCodeAt(i+5)|32) === 97 && (s.charCodeAt(i+6)|32) === 108; }\nvar days/*:Array<Array<string> >*/ = [\n\t['Sun', 'Sunday'],\n\t['Mon', 'Monday'],\n\t['Tue', 'Tuesday'],\n\t['Wed', 'Wednesday'],\n\t['Thu', 'Thursday'],\n\t['Fri', 'Friday'],\n\t['Sat', 'Saturday']\n];\nvar months/*:Array<Array<string> >*/ = [\n\t['J', 'Jan', 'January'],\n\t['F', 'Feb', 'February'],\n\t['M', 'Mar', 'March'],\n\t['A', 'Apr', 'April'],\n\t['M', 'May', 'May'],\n\t['J', 'Jun', 'June'],\n\t['J', 'Jul', 'July'],\n\t['A', 'Aug', 'August'],\n\t['S', 'Sep', 'September'],\n\t['O', 'Oct', 'October'],\n\t['N', 'Nov', 'November'],\n\t['D', 'Dec', 'December']\n];\nfunction SSF_init_table(t/*:any*/) {\n\tif(!t) t = {};\n\tt[0]= 'General';\n\tt[1]= '0';\n\tt[2]= '0.00';\n\tt[3]= '#,##0';\n\tt[4]= '#,##0.00';\n\tt[9]= '0%';\n\tt[10]= '0.00%';\n\tt[11]= '0.00E+00';\n\tt[12]= '# ?/?';\n\tt[13]= '# ??/??';\n\tt[14]= 'm/d/yy';\n\tt[15]= 'd-mmm-yy';\n\tt[16]= 'd-mmm';\n\tt[17]= 'mmm-yy';\n\tt[18]= 'h:mm AM/PM';\n\tt[19]= 'h:mm:ss AM/PM';\n\tt[20]= 'h:mm';\n\tt[21]= 'h:mm:ss';\n\tt[22]= 'm/d/yy h:mm';\n\tt[37]= '#,##0 ;(#,##0)';\n\tt[38]= '#,##0 ;[Red](#,##0)';\n\tt[39]= '#,##0.00;(#,##0.00)';\n\tt[40]= '#,##0.00;[Red](#,##0.00)';\n\tt[45]= 'mm:ss';\n\tt[46]= '[h]:mm:ss';\n\tt[47]= 'mmss.0';\n\tt[48]= '##0.0E+0';\n\tt[49]= '@';\n\tt[56]= '\"上午/下午 \"hh\"時\"mm\"分\"ss\"秒 \"';\n\treturn t;\n}\n/* repeated to satiate webpack */\nvar table_fmt = {\n\t0: 'General',\n\t1: '0',\n\t2: '0.00',\n\t3: '#,##0',\n\t4: '#,##0.00',\n\t9: '0%',\n\t10: '0.00%',\n\t11: '0.00E+00',\n\t12: '# ?/?',\n\t13: '# ??/??',\n\t14: 'm/d/yy',\n\t15: 'd-mmm-yy',\n\t16: 'd-mmm',\n\t17: 'mmm-yy',\n\t18: 'h:mm AM/PM',\n\t19: 'h:mm:ss AM/PM',\n\t20: 'h:mm',\n\t21: 'h:mm:ss',\n\t22: 'm/d/yy h:mm',\n\t37: '#,##0 ;(#,##0)',\n\t38: '#,##0 ;[Red](#,##0)',\n\t39: '#,##0.00;(#,##0.00)',\n\t40: '#,##0.00;[Red](#,##0.00)',\n\t45: 'mm:ss',\n\t46: '[h]:mm:ss',\n\t47: 'mmss.0',\n\t48: '##0.0E+0',\n\t49: '@',\n\t56: '\"上午/下午 \"hh\"時\"mm\"分\"ss\"秒 \"'\n};\n\n/* Defaults determined by systematically testing in Excel 2019 */\n\n/* These formats appear to default to other formats in the table */\nvar SSF_default_map = {\n\t5: 37, 6: 38, 7: 39, 8: 40, // 5 -> 37 ... 8 -> 40\n\n\t23: 0, 24: 0, 25: 0, 26: 0, // 23 -> 0 ... 26 -> 0\n\n\t27: 14, 28: 14, 29: 14, 30: 14, 31: 14, // 27 -> 14 ... 31 -> 14\n\n\t50: 14, 51: 14, 52: 14, 53: 14, 54: 14, // 50 -> 14 ... 58 -> 14\n\t55: 14, 56: 14, 57: 14, 58: 14,\n\t59: 1, 60: 2, 61: 3, 62: 4, // 59 -> 1 ... 62 -> 4\n\n\t67: 9, 68: 10, // 67 -> 9 ... 68 -> 10\n\t69: 12, 70: 13, 71: 14, // 69 -> 12 ... 71 -> 14\n\t72: 14, 73: 15, 74: 16, 75: 17, // 72 -> 14 ... 75 -> 17\n\t76: 20, 77: 21, 78: 22, // 76 -> 20 ... 78 -> 22\n\t79: 45, 80: 46, 81: 47, // 79 -> 45 ... 81 -> 47\n\t82: 0 // 82 -> 0 ... 65536 -> 0 (omitted)\n};\n\n\n/* These formats technically refer to Accounting formats with no equivalent */\nvar SSF_default_str = {\n\t// 5 -- Currency, 0 decimal, black negative\n\t5: '\"$\"#,##0_);\\\\(\"$\"#,##0\\\\)',\n\t63: '\"$\"#,##0_);\\\\(\"$\"#,##0\\\\)',\n\n\t// 6 -- Currency, 0 decimal, red negative\n\t6: '\"$\"#,##0_);[Red]\\\\(\"$\"#,##0\\\\)',\n\t64: '\"$\"#,##0_);[Red]\\\\(\"$\"#,##0\\\\)',\n\n\t// 7 -- Currency, 2 decimal, black negative\n\t7: '\"$\"#,##0.00_);\\\\(\"$\"#,##0.00\\\\)',\n\t65: '\"$\"#,##0.00_);\\\\(\"$\"#,##0.00\\\\)',\n\n\t// 8 -- Currency, 2 decimal, red negative\n\t8: '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\t66: '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\n\t// 41 -- Accounting, 0 decimal, No Symbol\n\t41: '_(* #,##0_);_(* \\\\(#,##0\\\\);_(* \"-\"_);_(@_)',\n\n\t// 42 -- Accounting, 0 decimal, $ Symbol\n\t42: '_(\"$\"* #,##0_);_(\"$\"* \\\\(#,##0\\\\);_(\"$\"* \"-\"_);_(@_)',\n\n\t// 43 -- Accounting, 2 decimal, No Symbol\n\t43: '_(* #,##0.00_);_(* \\\\(#,##0.00\\\\);_(* \"-\"??_);_(@_)',\n\n\t// 44 -- Accounting, 2 decimal, $ Symbol\n\t44: '_(\"$\"* #,##0.00_);_(\"$\"* \\\\(#,##0.00\\\\);_(\"$\"* \"-\"??_);_(@_)'\n};\n\nfunction SSF_frac(x/*:number*/, D/*:number*/, mixed/*:?boolean*/)/*:Array<number>*/ {\n\tvar sgn = x < 0 ? -1 : 1;\n\tvar B = x * sgn;\n\tvar P_2 = 0, P_1 = 1, P = 0;\n\tvar Q_2 = 1, Q_1 = 0, Q = 0;\n\tvar A = Math.floor(B);\n\twhile(Q_1 < D) {\n\t\tA = Math.floor(B);\n\t\tP = A * P_1 + P_2;\n\t\tQ = A * Q_1 + Q_2;\n\t\tif((B - A) < 0.00000005) break;\n\t\tB = 1 / (B - A);\n\t\tP_2 = P_1; P_1 = P;\n\t\tQ_2 = Q_1; Q_1 = Q;\n\t}\n\tif(Q > D) { if(Q_1 > D) { Q = Q_2; P = P_2; } else { Q = Q_1; P = P_1; } }\n\tif(!mixed) return [0, sgn * P, Q];\n\tvar q = Math.floor(sgn * P/Q);\n\treturn [q, sgn*P - q*Q, Q];\n}\nfunction SSF_parse_date_code(v/*:number*/,opts/*:?any*/,b2/*:?boolean*/) {\n\tif(v > 2958465 || v < 0) return null;\n\tvar date = (v|0), time = Math.floor(86400 * (v - date)), dow=0;\n\tvar dout=[];\n\tvar out={D:date, T:time, u:86400*(v-date)-time,y:0,m:0,d:0,H:0,M:0,S:0,q:0};\n\tif(Math.abs(out.u) < 1e-6) out.u = 0;\n\tif(opts && opts.date1904) date += 1462;\n\tif(out.u > 0.9999) {\n\t\tout.u = 0;\n\t\tif(++time == 86400) { out.T = time = 0; ++date; ++out.D; }\n\t}\n\tif(date === 60) {dout = b2 ? [1317,10,29] : [1900,2,29]; dow=3;}\n\telse if(date === 0) {dout = b2 ? [1317,8,29] : [1900,1,0]; dow=6;}\n\telse {\n\t\tif(date > 60) --date;\n\t\t/* 1 = Jan 1 1900 in Gregorian */\n\t\tvar d = new Date(1900, 0, 1);\n\t\td.setDate(d.getDate() + date - 1);\n\t\tdout = [d.getFullYear(), d.getMonth()+1,d.getDate()];\n\t\tdow = d.getDay();\n\t\tif(date < 60) dow = (dow + 6) % 7;\n\t\tif(b2) dow = SSF_fix_hijri(d, dout);\n\t}\n\tout.y = dout[0]; out.m = dout[1]; out.d = dout[2];\n\tout.S = time % 60; time = Math.floor(time / 60);\n\tout.M = time % 60; time = Math.floor(time / 60);\n\tout.H = time;\n\tout.q = dow;\n\treturn out;\n}\nvar SSFbasedate = /*#__PURE__*/new Date(1899, 11, 31, 0, 0, 0);\nvar SSFdnthresh = /*#__PURE__*/SSFbasedate.getTime();\nvar SSFbase1904 = /*#__PURE__*/new Date(1900, 2, 1, 0, 0, 0);\nfunction datenum_local(v/*:Date*/, date1904/*:?boolean*/)/*:number*/ {\n\tvar epoch = /*#__PURE__*/v.getTime();\n\tif(date1904) epoch -= 1461*24*60*60*1000;\n\telse if(v >= SSFbase1904) epoch += 24*60*60*1000;\n\treturn (epoch - (SSFdnthresh + (/*#__PURE__*/v.getTimezoneOffset() - /*#__PURE__*/SSFbasedate.getTimezoneOffset()) * 60000)) / (24 * 60 * 60 * 1000);\n}\n/* ECMA-376 18.8.30 numFmt*/\n/* Note: `toPrecision` uses standard form when prec > E and E >= -6 */\n/* exponent >= -9 and <= 9 */\nfunction SSF_strip_decimal(o/*:string*/)/*:string*/ {\n\treturn (o.indexOf(\".\") == -1) ? o : o.replace(/(?:\\.0*|(\\.\\d*[1-9])0+)$/, \"$1\");\n}\n\n/* General Exponential always shows 2 digits exp and trims the mantissa */\nfunction SSF_normalize_exp(o/*:string*/)/*:string*/ {\n\tif(o.indexOf(\"E\") == -1) return o;\n\treturn o.replace(/(?:\\.0*|(\\.\\d*[1-9])0+)[Ee]/,\"$1E\").replace(/(E[+-])(\\d)$/,\"$10$2\");\n}\n\n/* exponent >= -9 and <= 9 */\nfunction SSF_small_exp(v/*:number*/)/*:string*/ {\n\tvar w = (v<0?12:11);\n\tvar o = SSF_strip_decimal(v.toFixed(12)); if(o.length <= w) return o;\n\to = v.toPrecision(10); if(o.length <= w) return o;\n\treturn v.toExponential(5);\n}\n\n/* exponent >= 11 or <= -10 likely exponential */\nfunction SSF_large_exp(v/*:number*/)/*:string*/ {\n\tvar o = SSF_strip_decimal(v.toFixed(11));\n\treturn (o.length > (v<0?12:11) || o === \"0\" || o === \"-0\") ? v.toPrecision(6) : o;\n}\n\nfunction SSF_general_num(v/*:number*/)/*:string*/ {\n\tvar V = Math.floor(Math.log(Math.abs(v))*Math.LOG10E), o;\n\n\tif(V >= -4 && V <= -1) o = v.toPrecision(10+V);\n\telse if(Math.abs(V) <= 9) o = SSF_small_exp(v);\n\telse if(V === 10) o = v.toFixed(10).substr(0,12);\n\telse o = SSF_large_exp(v);\n\n\treturn SSF_strip_decimal(SSF_normalize_exp(o.toUpperCase()));\n}\n\n\n/*\n\t\"General\" rules:\n\t- text is passed through (\"@\")\n\t- booleans are rendered as TRUE/FALSE\n\t- \"up to 11 characters\" displayed for numbers\n\t- Default date format (code 14) used for Dates\n\n\tThe longest 32-bit integer text is \"-2147483648\", exactly 11 chars\n\tTODO: technically the display depends on the width of the cell\n*/\nfunction SSF_general(v/*:any*/, opts/*:any*/) {\n\tswitch(typeof v) {\n\t\tcase 'string': return v;\n\t\tcase 'boolean': return v ? \"TRUE\" : \"FALSE\";\n\t\tcase 'number': return (v|0) === v ? v.toString(10) : SSF_general_num(v);\n\t\tcase 'undefined': return \"\";\n\t\tcase 'object':\n\t\t\tif(v == null) return \"\";\n\t\t\tif(v instanceof Date) return SSF_format(14, datenum_local(v, opts && opts.date1904), opts);\n\t}\n\tthrow new Error(\"unsupported value in General format: \" + v);\n}\n\nfunction SSF_fix_hijri(date/*:Date*/, o/*:[number, number, number]*/) {\n /* TODO: properly adjust y/m/d and */\n o[0] -= 581;\n var dow = date.getDay();\n if(date < 60) dow = (dow + 6) % 7;\n return dow;\n}\n//var THAI_DIGITS = \"\\u0E50\\u0E51\\u0E52\\u0E53\\u0E54\\u0E55\\u0E56\\u0E57\\u0E58\\u0E59\".split(\"\");\nfunction SSF_write_date(type/*:number*/, fmt/*:string*/, val, ss0/*:?number*/)/*:string*/ {\n\tvar o=\"\", ss=0, tt=0, y = val.y, out, outl = 0;\n\tswitch(type) {\n\t\tcase 98: /* 'b' buddhist year */\n\t\t\ty = val.y + 543;\n\t\t\t/* falls through */\n\t\tcase 121: /* 'y' year */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = y % 100; outl = 2; break;\n\t\t\tdefault: out = y % 10000; outl = 4; break;\n\t\t} break;\n\t\tcase 109: /* 'm' month */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.m; outl = fmt.length; break;\n\t\t\tcase 3: return months[val.m-1][1];\n\t\t\tcase 5: return months[val.m-1][0];\n\t\t\tdefault: return months[val.m-1][2];\n\t\t} break;\n\t\tcase 100: /* 'd' day */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.d; outl = fmt.length; break;\n\t\t\tcase 3: return days[val.q][0];\n\t\t\tdefault: return days[val.q][1];\n\t\t} break;\n\t\tcase 104: /* 'h' 12-hour */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = 1+(val.H+11)%12; outl = fmt.length; break;\n\t\t\tdefault: throw 'bad hour format: ' + fmt;\n\t\t} break;\n\t\tcase 72: /* 'H' 24-hour */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.H; outl = fmt.length; break;\n\t\t\tdefault: throw 'bad hour format: ' + fmt;\n\t\t} break;\n\t\tcase 77: /* 'M' minutes */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.M; outl = fmt.length; break;\n\t\t\tdefault: throw 'bad minute format: ' + fmt;\n\t\t} break;\n\t\tcase 115: /* 's' seconds */\n\t\t\tif(fmt != 's' && fmt != 'ss' && fmt != '.0' && fmt != '.00' && fmt != '.000') throw 'bad second format: ' + fmt;\n\t\t\tif(val.u === 0 && (fmt == \"s\" || fmt == \"ss\")) return pad0(val.S, fmt.length);\n\t\t\t/*::if(!ss0) ss0 = 0; */\n\t\t\tif(ss0 >= 2) tt = ss0 === 3 ? 1000 : 100;\n\t\t\telse tt = ss0 === 1 ? 10 : 1;\n\t\t\tss = Math.round((tt)*(val.S + val.u));\n\t\t\tif(ss >= 60*tt) ss = 0;\n\t\t\tif(fmt === 's') return ss === 0 ? \"0\" : \"\"+ss/tt;\n\t\t\to = pad0(ss,2 + ss0);\n\t\t\tif(fmt === 'ss') return o.substr(0,2);\n\t\t\treturn \".\" + o.substr(2,fmt.length-1);\n\t\tcase 90: /* 'Z' absolute time */\n\t\tswitch(fmt) {\n\t\t\tcase '[h]': case '[hh]': out = val.D*24+val.H; break;\n\t\t\tcase '[m]': case '[mm]': out = (val.D*24+val.H)*60+val.M; break;\n\t\t\tcase '[s]': case '[ss]': out = ((val.D*24+val.H)*60+val.M)*60+Math.round(val.S+val.u); break;\n\t\t\tdefault: throw 'bad abstime format: ' + fmt;\n\t\t} outl = fmt.length === 3 ? 1 : 2; break;\n\t\tcase 101: /* 'e' era */\n\t\t\tout = y; outl = 1; break;\n\t}\n\tvar outstr = outl > 0 ? pad0(out, outl) : \"\";\n\treturn outstr;\n}\n\n\n/*jshint -W086 */\n/*jshint +W086 */\nfunction commaify(s/*:string*/)/*:string*/ {\n\tvar w = 3;\n\tif(s.length <= w) return s;\n\tvar j = (s.length % w), o = s.substr(0,j);\n\tfor(; j!=s.length; j+=w) o+=(o.length > 0 ? \",\" : \"\") + s.substr(j,w);\n\treturn o;\n}\nvar pct1 = /%/g;\nfunction write_num_pct(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar sfmt = fmt.replace(pct1,\"\"), mul = fmt.length - sfmt.length;\n\treturn write_num(type, sfmt, val * Math.pow(10,2*mul)) + fill(\"%\",mul);\n}\n\nfunction write_num_cm(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar idx = fmt.length - 1;\n\twhile(fmt.charCodeAt(idx-1) === 44) --idx;\n\treturn write_num(type, fmt.substr(0,idx), val / Math.pow(10,3*(fmt.length-idx)));\n}\n\nfunction write_num_exp(fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar o/*:string*/;\n\tvar idx = fmt.indexOf(\"E\") - fmt.indexOf(\".\") - 1;\n\tif(fmt.match(/^#+0.0E\\+0$/)) {\n\t\tif(val == 0) return \"0.0E+0\";\n\t\telse if(val < 0) return \"-\" + write_num_exp(fmt, -val);\n\t\tvar period = fmt.indexOf(\".\"); if(period === -1) period=fmt.indexOf('E');\n\t\tvar ee = Math.floor(Math.log(val)*Math.LOG10E)%period;\n\t\tif(ee < 0) ee += period;\n\t\to = (val/Math.pow(10,ee)).toPrecision(idx+1+(period+ee)%period);\n\t\tif(o.indexOf(\"e\") === -1) {\n\t\t\tvar fakee = Math.floor(Math.log(val)*Math.LOG10E);\n\t\t\tif(o.indexOf(\".\") === -1) o = o.charAt(0) + \".\" + o.substr(1) + \"E+\" + (fakee - o.length+ee);\n\t\t\telse o += \"E+\" + (fakee - ee);\n\t\t\twhile(o.substr(0,2) === \"0.\") {\n\t\t\t\to = o.charAt(0) + o.substr(2,period) + \".\" + o.substr(2+period);\n\t\t\t\to = o.replace(/^0+([1-9])/,\"$1\").replace(/^0+\\./,\"0.\");\n\t\t\t}\n\t\t\to = o.replace(/\\+-/,\"-\");\n\t\t}\n\t\to = o.replace(/^([+-]?)(\\d*)\\.(\\d*)[Ee]/,function($$,$1,$2,$3) { return $1 + $2 + $3.substr(0,(period+ee)%period) + \".\" + $3.substr(ee) + \"E\"; });\n\t} else o = val.toExponential(idx);\n\tif(fmt.match(/E\\+00$/) && o.match(/e[+-]\\d$/)) o = o.substr(0,o.length-1) + \"0\" + o.charAt(o.length-1);\n\tif(fmt.match(/E\\-/) && o.match(/e\\+/)) o = o.replace(/e\\+/,\"e\");\n\treturn o.replace(\"e\",\"E\");\n}\nvar frac1 = /# (\\?+)( ?)\\/( ?)(\\d+)/;\nfunction write_num_f1(r/*:Array<string>*/, aval/*:number*/, sign/*:string*/)/*:string*/ {\n\tvar den = parseInt(r[4],10), rr = Math.round(aval * den), base = Math.floor(rr/den);\n\tvar myn = (rr - base*den), myd = den;\n\treturn sign + (base === 0 ? \"\" : \"\"+base) + \" \" + (myn === 0 ? fill(\" \", r[1].length + 1 + r[4].length) : pad_(myn,r[1].length) + r[2] + \"/\" + r[3] + pad0(myd,r[4].length));\n}\nfunction write_num_f2(r/*:Array<string>*/, aval/*:number*/, sign/*:string*/)/*:string*/ {\n\treturn sign + (aval === 0 ? \"\" : \"\"+aval) + fill(\" \", r[1].length + 2 + r[4].length);\n}\nvar dec1 = /^#*0*\\.([0#]+)/;\nvar closeparen = /\\).*[0#]/;\nvar phone = /\\(###\\) ###\\\\?-####/;\nfunction hashq(str/*:string*/)/*:string*/ {\n\tvar o = \"\", cc;\n\tfor(var i = 0; i != str.length; ++i) switch((cc=str.charCodeAt(i))) {\n\t\tcase 35: break;\n\t\tcase 63: o+= \" \"; break;\n\t\tcase 48: o+= \"0\"; break;\n\t\tdefault: o+= String.fromCharCode(cc);\n\t}\n\treturn o;\n}\nfunction rnd(val/*:number*/, d/*:number*/)/*:string*/ { var dd = Math.pow(10,d); return \"\"+(Math.round(val * dd)/dd); }\nfunction dec(val/*:number*/, d/*:number*/)/*:number*/ {\n\tvar _frac = val - Math.floor(val), dd = Math.pow(10,d);\n\tif (d < ('' + Math.round(_frac * dd)).length) return 0;\n\treturn Math.round(_frac * dd);\n}\nfunction carry(val/*:number*/, d/*:number*/)/*:number*/ {\n\tif (d < ('' + Math.round((val-Math.floor(val))*Math.pow(10,d))).length) {\n\t\treturn 1;\n\t}\n\treturn 0;\n}\nfunction flr(val/*:number*/)/*:string*/ {\n\tif(val < 2147483647 && val > -2147483648) return \"\"+(val >= 0 ? (val|0) : (val-1|0));\n\treturn \"\"+Math.floor(val);\n}\nfunction write_num_flt(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/ {\n\tif(type.charCodeAt(0) === 40 && !fmt.match(closeparen)) {\n\t\tvar ffmt = fmt.replace(/\\( */,\"\").replace(/ \\)/,\"\").replace(/\\)/,\"\");\n\t\tif(val >= 0) return write_num_flt('n', ffmt, val);\n\t\treturn '(' + write_num_flt('n', ffmt, -val) + ')';\n\t}\n\tif(fmt.charCodeAt(fmt.length - 1) === 44) return write_num_cm(type, fmt, val);\n\tif(fmt.indexOf('%') !== -1) return write_num_pct(type, fmt, val);\n\tif(fmt.indexOf('E') !== -1) return write_num_exp(fmt, val);\n\tif(fmt.charCodeAt(0) === 36) return \"$\"+write_num_flt(type,fmt.substr(fmt.charAt(1)==' '?2:1),val);\n\tvar o;\n\tvar r/*:?Array<string>*/, ri, ff, aval = Math.abs(val), sign = val < 0 ? \"-\" : \"\";\n\tif(fmt.match(/^00+$/)) return sign + pad0r(aval,fmt.length);\n\tif(fmt.match(/^[#?]+$/)) {\n\t\to = pad0r(val,0); if(o === \"0\") o = \"\";\n\t\treturn o.length > fmt.length ? o : hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(frac1))) return write_num_f1(r, aval, sign);\n\tif(fmt.match(/^#+0+$/)) return sign + pad0r(aval,fmt.length - fmt.indexOf(\"0\"));\n\tif((r = fmt.match(dec1))) {\n\t\to = rnd(val, r[1].length).replace(/^([^\\.]+)$/,\"$1.\"+hashq(r[1])).replace(/\\.$/,\".\"+hashq(r[1])).replace(/\\.(\\d*)$/,function($$, $1) { return \".\" + $1 + fill(\"0\", hashq(/*::(*/r/*::||[\"\"])*/[1]).length-$1.length); });\n\t\treturn fmt.indexOf(\"0.\") !== -1 ? o : o.replace(/^0\\./,\".\");\n\t}\n\tfmt = fmt.replace(/^#+([0.])/, \"$1\");\n\tif((r = fmt.match(/^(0*)\\.(#*)$/))) {\n\t\treturn sign + rnd(aval, r[2].length).replace(/\\.(\\d*[1-9])0*$/,\".$1\").replace(/^(-?\\d*)$/,\"$1.\").replace(/^0\\./,r[1].length?\"0.\":\".\");\n\t}\n\tif((r = fmt.match(/^#{1,3},##0(\\.?)$/))) return sign + commaify(pad0r(aval,0));\n\tif((r = fmt.match(/^#,##0\\.([#0]*0)$/))) {\n\t\treturn val < 0 ? \"-\" + write_num_flt(type, fmt, -val) : commaify(\"\"+(Math.floor(val) + carry(val, r[1].length))) + \".\" + pad0(dec(val, r[1].length),r[1].length);\n\t}\n\tif((r = fmt.match(/^#,#*,#0/))) return write_num_flt(type,fmt.replace(/^#,#*,/,\"\"),val);\n\tif((r = fmt.match(/^([0#]+)(\\\\?-([0#]+))+$/))) {\n\t\to = _strrev(write_num_flt(type, fmt.replace(/[\\\\-]/g,\"\"), val));\n\t\tri = 0;\n\t\treturn _strrev(_strrev(fmt.replace(/\\\\/g,\"\")).replace(/[0#]/g,function(x){return ri<o.length?o.charAt(ri++):x==='0'?'0':\"\";}));\n\t}\n\tif(fmt.match(phone)) {\n\t\to = write_num_flt(type, \"##########\", val);\n\t\treturn \"(\" + o.substr(0,3) + \") \" + o.substr(3, 3) + \"-\" + o.substr(6);\n\t}\n\tvar oa = \"\";\n\tif((r = fmt.match(/^([#0?]+)( ?)\\/( ?)([#0?]+)/))) {\n\t\tri = Math.min(/*::String(*/r[4]/*::)*/.length,7);\n\t\tff = SSF_frac(aval, Math.pow(10,ri)-1, false);\n\t\to = \"\" + sign;\n\t\toa = write_num(\"n\", /*::String(*/r[1]/*::)*/, ff[1]);\n\t\tif(oa.charAt(oa.length-1) == \" \") oa = oa.substr(0,oa.length-1) + \"0\";\n\t\to += oa + /*::String(*/r[2]/*::)*/ + \"/\" + /*::String(*/r[3]/*::)*/;\n\t\toa = rpad_(ff[2],ri);\n\t\tif(oa.length < r[4].length) oa = hashq(r[4].substr(r[4].length-oa.length)) + oa;\n\t\to += oa;\n\t\treturn o;\n\t}\n\tif((r = fmt.match(/^# ([#0?]+)( ?)\\/( ?)([#0?]+)/))) {\n\t\tri = Math.min(Math.max(r[1].length, r[4].length),7);\n\t\tff = SSF_frac(aval, Math.pow(10,ri)-1, true);\n\t\treturn sign + (ff[0]||(ff[1] ? \"\" : \"0\")) + \" \" + (ff[1] ? pad_(ff[1],ri) + r[2] + \"/\" + r[3] + rpad_(ff[2],ri): fill(\" \", 2*ri+1 + r[2].length + r[3].length));\n\t}\n\tif((r = fmt.match(/^[#0?]+$/))) {\n\t\to = pad0r(val, 0);\n\t\tif(fmt.length <= o.length) return o;\n\t\treturn hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(/^([#0?]+)\\.([#0]+)$/))) {\n\t\to = \"\" + val.toFixed(Math.min(r[2].length,10)).replace(/([^0])0+$/,\"$1\");\n\t\tri = o.indexOf(\".\");\n\t\tvar lres = fmt.indexOf(\".\") - ri, rres = fmt.length - o.length - lres;\n\t\treturn hashq(fmt.substr(0,lres) + o + fmt.substr(fmt.length-rres));\n\t}\n\tif((r = fmt.match(/^00,000\\.([#0]*0)$/))) {\n\t\tri = dec(val, r[1].length);\n\t\treturn val < 0 ? \"-\" + write_num_flt(type, fmt, -val) : commaify(flr(val)).replace(/^\\d,\\d{3}$/,\"0$&\").replace(/^\\d*$/,function($$) { return \"00,\" + ($$.length < 3 ? pad0(0,3-$$.length) : \"\") + $$; }) + \".\" + pad0(ri,r[1].length);\n\t}\n\tswitch(fmt) {\n\t\tcase \"###,##0.00\": return write_num_flt(type, \"#,##0.00\", val);\n\t\tcase \"###,###\":\n\t\tcase \"##,###\":\n\t\tcase \"#,###\": var x = commaify(pad0r(aval,0)); return x !== \"0\" ? sign + x : \"\";\n\t\tcase \"###,###.00\": return write_num_flt(type, \"###,##0.00\",val).replace(/^0\\./,\".\");\n\t\tcase \"#,###.00\": return write_num_flt(type, \"#,##0.00\",val).replace(/^0\\./,\".\");\n\t\tdefault:\n\t}\n\tthrow new Error(\"unsupported format |\" + fmt + \"|\");\n}\nfunction write_num_cm2(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar idx = fmt.length - 1;\n\twhile(fmt.charCodeAt(idx-1) === 44) --idx;\n\treturn write_num(type, fmt.substr(0,idx), val / Math.pow(10,3*(fmt.length-idx)));\n}\nfunction write_num_pct2(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar sfmt = fmt.replace(pct1,\"\"), mul = fmt.length - sfmt.length;\n\treturn write_num(type, sfmt, val * Math.pow(10,2*mul)) + fill(\"%\",mul);\n}\nfunction write_num_exp2(fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar o/*:string*/;\n\tvar idx = fmt.indexOf(\"E\") - fmt.indexOf(\".\") - 1;\n\tif(fmt.match(/^#+0.0E\\+0$/)) {\n\t\tif(val == 0) return \"0.0E+0\";\n\t\telse if(val < 0) return \"-\" + write_num_exp2(fmt, -val);\n\t\tvar period = fmt.indexOf(\".\"); if(period === -1) period=fmt.indexOf('E');\n\t\tvar ee = Math.floor(Math.log(val)*Math.LOG10E)%period;\n\t\tif(ee < 0) ee += period;\n\t\to = (val/Math.pow(10,ee)).toPrecision(idx+1+(period+ee)%period);\n\t\tif(!o.match(/[Ee]/)) {\n\t\t\tvar fakee = Math.floor(Math.log(val)*Math.LOG10E);\n\t\t\tif(o.indexOf(\".\") === -1) o = o.charAt(0) + \".\" + o.substr(1) + \"E+\" + (fakee - o.length+ee);\n\t\t\telse o += \"E+\" + (fakee - ee);\n\t\t\to = o.replace(/\\+-/,\"-\");\n\t\t}\n\t\to = o.replace(/^([+-]?)(\\d*)\\.(\\d*)[Ee]/,function($$,$1,$2,$3) { return $1 + $2 + $3.substr(0,(period+ee)%period) + \".\" + $3.substr(ee) + \"E\"; });\n\t} else o = val.toExponential(idx);\n\tif(fmt.match(/E\\+00$/) && o.match(/e[+-]\\d$/)) o = o.substr(0,o.length-1) + \"0\" + o.charAt(o.length-1);\n\tif(fmt.match(/E\\-/) && o.match(/e\\+/)) o = o.replace(/e\\+/,\"e\");\n\treturn o.replace(\"e\",\"E\");\n}\nfunction write_num_int(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/ {\n\tif(type.charCodeAt(0) === 40 && !fmt.match(closeparen)) {\n\t\tvar ffmt = fmt.replace(/\\( */,\"\").replace(/ \\)/,\"\").replace(/\\)/,\"\");\n\t\tif(val >= 0) return write_num_int('n', ffmt, val);\n\t\treturn '(' + write_num_int('n', ffmt, -val) + ')';\n\t}\n\tif(fmt.charCodeAt(fmt.length - 1) === 44) return write_num_cm2(type, fmt, val);\n\tif(fmt.indexOf('%') !== -1) return write_num_pct2(type, fmt, val);\n\tif(fmt.indexOf('E') !== -1) return write_num_exp2(fmt, val);\n\tif(fmt.charCodeAt(0) === 36) return \"$\"+write_num_int(type,fmt.substr(fmt.charAt(1)==' '?2:1),val);\n\tvar o;\n\tvar r/*:?Array<string>*/, ri, ff, aval = Math.abs(val), sign = val < 0 ? \"-\" : \"\";\n\tif(fmt.match(/^00+$/)) return sign + pad0(aval,fmt.length);\n\tif(fmt.match(/^[#?]+$/)) {\n\t\to = (\"\"+val); if(val === 0) o = \"\";\n\t\treturn o.length > fmt.length ? o : hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(frac1))) return write_num_f2(r, aval, sign);\n\tif(fmt.match(/^#+0+$/)) return sign + pad0(aval,fmt.length - fmt.indexOf(\"0\"));\n\tif((r = fmt.match(dec1))) {\n\t\t/*:: if(!Array.isArray(r)) throw new Error(\"unreachable\"); */\n\t\to = (\"\"+val).replace(/^([^\\.]+)$/,\"$1.\"+hashq(r[1])).replace(/\\.$/,\".\"+hashq(r[1]));\n\t\to = o.replace(/\\.(\\d*)$/,function($$, $1) {\n\t\t/*:: if(!Array.isArray(r)) throw new Error(\"unreachable\"); */\n\t\t\treturn \".\" + $1 + fill(\"0\", hashq(r[1]).length-$1.length); });\n\t\treturn fmt.indexOf(\"0.\") !== -1 ? o : o.replace(/^0\\./,\".\");\n\t}\n\tfmt = fmt.replace(/^#+([0.])/, \"$1\");\n\tif((r = fmt.match(/^(0*)\\.(#*)$/))) {\n\t\treturn sign + (\"\"+aval).replace(/\\.(\\d*[1-9])0*$/,\".$1\").replace(/^(-?\\d*)$/,\"$1.\").replace(/^0\\./,r[1].length?\"0.\":\".\");\n\t}\n\tif((r = fmt.match(/^#{1,3},##0(\\.?)$/))) return sign + commaify((\"\"+aval));\n\tif((r = fmt.match(/^#,##0\\.([#0]*0)$/))) {\n\t\treturn val < 0 ? \"-\" + write_num_int(type, fmt, -val) : commaify((\"\"+val)) + \".\" + fill('0',r[1].length);\n\t}\n\tif((r = fmt.match(/^#,#*,#0/))) return write_num_int(type,fmt.replace(/^#,#*,/,\"\"),val);\n\tif((r = fmt.match(/^([0#]+)(\\\\?-([0#]+))+$/))) {\n\t\to = _strrev(write_num_int(type, fmt.replace(/[\\\\-]/g,\"\"), val));\n\t\tri = 0;\n\t\treturn _strrev(_strrev(fmt.replace(/\\\\/g,\"\")).replace(/[0#]/g,function(x){return ri<o.length?o.charAt(ri++):x==='0'?'0':\"\";}));\n\t}\n\tif(fmt.match(phone)) {\n\t\to = write_num_int(type, \"##########\", val);\n\t\treturn \"(\" + o.substr(0,3) + \") \" + o.substr(3, 3) + \"-\" + o.substr(6);\n\t}\n\tvar oa = \"\";\n\tif((r = fmt.match(/^([#0?]+)( ?)\\/( ?)([#0?]+)/))) {\n\t\tri = Math.min(/*::String(*/r[4]/*::)*/.length,7);\n\t\tff = SSF_frac(aval, Math.pow(10,ri)-1, false);\n\t\to = \"\" + sign;\n\t\toa = write_num(\"n\", /*::String(*/r[1]/*::)*/, ff[1]);\n\t\tif(oa.charAt(oa.length-1) == \" \") oa = oa.substr(0,oa.length-1) + \"0\";\n\t\to += oa + /*::String(*/r[2]/*::)*/ + \"/\" + /*::String(*/r[3]/*::)*/;\n\t\toa = rpad_(ff[2],ri);\n\t\tif(oa.length < r[4].length) oa = hashq(r[4].substr(r[4].length-oa.length)) + oa;\n\t\to += oa;\n\t\treturn o;\n\t}\n\tif((r = fmt.match(/^# ([#0?]+)( ?)\\/( ?)([#0?]+)/))) {\n\t\tri = Math.min(Math.max(r[1].length, r[4].length),7);\n\t\tff = SSF_frac(aval, Math.pow(10,ri)-1, true);\n\t\treturn sign + (ff[0]||(ff[1] ? \"\" : \"0\")) + \" \" + (ff[1] ? pad_(ff[1],ri) + r[2] + \"/\" + r[3] + rpad_(ff[2],ri): fill(\" \", 2*ri+1 + r[2].length + r[3].length));\n\t}\n\tif((r = fmt.match(/^[#0?]+$/))) {\n\t\to = \"\" + val;\n\t\tif(fmt.length <= o.length) return o;\n\t\treturn hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(/^([#0]+)\\.([#0]+)$/))) {\n\t\to = \"\" + val.toFixed(Math.min(r[2].length,10)).replace(/([^0])0+$/,\"$1\");\n\t\tri = o.indexOf(\".\");\n\t\tvar lres = fmt.indexOf(\".\") - ri, rres = fmt.length - o.length - lres;\n\t\treturn hashq(fmt.substr(0,lres) + o + fmt.substr(fmt.length-rres));\n\t}\n\tif((r = fmt.match(/^00,000\\.([#0]*0)$/))) {\n\t\treturn val < 0 ? \"-\" + write_num_int(type, fmt, -val) : commaify(\"\"+val).replace(/^\\d,\\d{3}$/,\"0$&\").replace(/^\\d*$/,function($$) { return \"00,\" + ($$.length < 3 ? pad0(0,3-$$.length) : \"\") + $$; }) + \".\" + pad0(0,r[1].length);\n\t}\n\tswitch(fmt) {\n\t\tcase \"###,###\":\n\t\tcase \"##,###\":\n\t\tcase \"#,###\": var x = commaify(\"\"+aval); return x !== \"0\" ? sign + x : \"\";\n\t\tdefault:\n\t\t\tif(fmt.match(/\\.[0#?]*$/)) return write_num_int(type, fmt.slice(0,fmt.lastIndexOf(\".\")), val) + hashq(fmt.slice(fmt.lastIndexOf(\".\")));\n\t}\n\tthrow new Error(\"unsupported format |\" + fmt + \"|\");\n}\nfunction write_num(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/ {\n\treturn (val|0) === val ? write_num_int(type, fmt, val) : write_num_flt(type, fmt, val);\n}\nfunction SSF_split_fmt(fmt/*:string*/)/*:Array<string>*/ {\n\tvar out/*:Array<string>*/ = [];\n\tvar in_str = false/*, cc*/;\n\tfor(var i = 0, j = 0; i < fmt.length; ++i) switch((/*cc=*/fmt.charCodeAt(i))) {\n\t\tcase 34: /* '\"' */\n\t\t\tin_str = !in_str; break;\n\t\tcase 95: case 42: case 92: /* '_' '*' '\\\\' */\n\t\t\t++i; break;\n\t\tcase 59: /* ';' */\n\t\t\tout[out.length] = fmt.substr(j,i-j);\n\t\t\tj = i+1;\n\t}\n\tout[out.length] = fmt.substr(j);\n\tif(in_str === true) throw new Error(\"Format |\" + fmt + \"| unterminated string \");\n\treturn out;\n}\n\nvar SSF_abstime = /\\[[HhMmSs\\u0E0A\\u0E19\\u0E17]*\\]/;\nfunction fmt_is_date(fmt/*:string*/)/*:boolean*/ {\n\tvar i = 0, /*cc = 0,*/ c = \"\", o = \"\";\n\twhile(i < fmt.length) {\n\t\tswitch((c = fmt.charAt(i))) {\n\t\t\tcase 'G': if(SSF_isgeneral(fmt, i)) i+= 6; i++; break;\n\t\t\tcase '\"': for(;(/*cc=*/fmt.charCodeAt(++i)) !== 34 && i < fmt.length;){/*empty*/} ++i; break;\n\t\t\tcase '\\\\': i+=2; break;\n\t\t\tcase '_': i+=2; break;\n\t\t\tcase '@': ++i; break;\n\t\t\tcase 'B': case 'b':\n\t\t\t\tif(fmt.charAt(i+1) === \"1\" || fmt.charAt(i+1) === \"2\") return true;\n\t\t\t\t/* falls through */\n\t\t\tcase 'M': case 'D': case 'Y': case 'H': case 'S': case 'E':\n\t\t\t\t/* falls through */\n\t\t\tcase 'm': case 'd': case 'y': case 'h': case 's': case 'e': case 'g': return true;\n\t\t\tcase 'A': case 'a': case '上':\n\t\t\t\tif(fmt.substr(i, 3).toUpperCase() === \"A/P\") return true;\n\t\t\t\tif(fmt.substr(i, 5).toUpperCase() === \"AM/PM\") return true;\n\t\t\t\tif(fmt.substr(i, 5).toUpperCase() === \"上午/下午\") return true;\n\t\t\t\t++i; break;\n\t\t\tcase '[':\n\t\t\t\to = c;\n\t\t\t\twhile(fmt.charAt(i++) !== ']' && i < fmt.length) o += fmt.charAt(i);\n\t\t\t\tif(o.match(SSF_abstime)) return true;\n\t\t\t\tbreak;\n\t\t\tcase '.':\n\t\t\t\t/* falls through */\n\t\t\tcase '0': case '#':\n\t\t\t\twhile(i < fmt.length && (\"0#?.,E+-%\".indexOf(c=fmt.charAt(++i)) > -1 || (c=='\\\\' && fmt.charAt(i+1) == \"-\" && \"0#\".indexOf(fmt.charAt(i+2))>-1))){/* empty */}\n\t\t\t\tbreak;\n\t\t\tcase '?': while(fmt.charAt(++i) === c){/* empty */} break;\n\t\t\tcase '*': ++i; if(fmt.charAt(i) == ' ' || fmt.charAt(i) == '*') ++i; break;\n\t\t\tcase '(': case ')': ++i; break;\n\t\t\tcase '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9':\n\t\t\t\twhile(i < fmt.length && \"0123456789\".indexOf(fmt.charAt(++i)) > -1){/* empty */} break;\n\t\t\tcase ' ': ++i; break;\n\t\t\tdefault: ++i; break;\n\t\t}\n\t}\n\treturn false;\n}\n\nfunction eval_fmt(fmt/*:string*/, v/*:any*/, opts/*:any*/, flen/*:number*/) {\n\tvar out = [], o = \"\", i = 0, c = \"\", lst='t', dt, j, cc;\n\tvar hr='H';\n\t/* Tokenize */\n\twhile(i < fmt.length) {\n\t\tswitch((c = fmt.charAt(i))) {\n\t\t\tcase 'G': /* General */\n\t\t\t\tif(!SSF_isgeneral(fmt, i)) throw new Error('unrecognized character ' + c + ' in ' +fmt);\n\t\t\t\tout[out.length] = {t:'G', v:'General'}; i+=7; break;\n\t\t\tcase '\"': /* Literal text */\n\t\t\t\tfor(o=\"\";(cc=fmt.charCodeAt(++i)) !== 34 && i < fmt.length;) o += String.fromCharCode(cc);\n\t\t\t\tout[out.length] = {t:'t', v:o}; ++i; break;\n\t\t\tcase '\\\\': var w = fmt.charAt(++i), t = (w === \"(\" || w === \")\") ? w : 't';\n\t\t\t\tout[out.length] = {t:t, v:w}; ++i; break;\n\t\t\tcase '_': out[out.length] = {t:'t', v:\" \"}; i+=2; break;\n\t\t\tcase '@': /* Text Placeholder */\n\t\t\t\tout[out.length] = {t:'T', v:v}; ++i; break;\n\t\t\tcase 'B': case 'b':\n\t\t\t\tif(fmt.charAt(i+1) === \"1\" || fmt.charAt(i+1) === \"2\") {\n\t\t\t\t\tif(dt==null) { dt=SSF_parse_date_code(v, opts, fmt.charAt(i+1) === \"2\"); if(dt==null) return \"\"; }\n\t\t\t\t\tout[out.length] = {t:'X', v:fmt.substr(i,2)}; lst = c; i+=2; break;\n\t\t\t\t}\n\t\t\t\t/* falls through */\n\t\t\tcase 'M': case 'D': case 'Y': case 'H': case 'S': case 'E':\n\t\t\t\tc = c.toLowerCase();\n\t\t\t\t/* falls through */\n\t\t\tcase 'm': case 'd': case 'y': case 'h': case 's': case 'e': case 'g':\n\t\t\t\tif(v < 0) return \"\";\n\t\t\t\tif(dt==null) { dt=SSF_parse_date_code(v, opts); if(dt==null) return \"\"; }\n\t\t\t\to = c; while(++i < fmt.length && fmt.charAt(i).toLowerCase() === c) o+=c;\n\t\t\t\tif(c === 'm' && lst.toLowerCase() === 'h') c = 'M';\n\t\t\t\tif(c === 'h') c = hr;\n\t\t\t\tout[out.length] = {t:c, v:o}; lst = c; break;\n\t\t\tcase 'A': case 'a': case '上':\n\t\t\t\tvar q={t:c, v:c};\n\t\t\t\tif(dt==null) dt=SSF_parse_date_code(v, opts);\n\t\t\t\tif(fmt.substr(i, 3).toUpperCase() === \"A/P\") { if(dt!=null) q.v = dt.H >= 12 ? \"P\" : \"A\"; q.t = 'T'; hr='h';i+=3;}\n\t\t\t\telse if(fmt.substr(i,5).toUpperCase() === \"AM/PM\") { if(dt!=null) q.v = dt.H >= 12 ? \"PM\" : \"AM\"; q.t = 'T'; i+=5; hr='h'; }\n\t\t\t\telse if(fmt.substr(i,5).toUpperCase() === \"上午/下午\") { if(dt!=null) q.v = dt.H >= 12 ? \"下午\" : \"上午\"; q.t = 'T'; i+=5; hr='h'; }\n\t\t\t\telse { q.t = \"t\"; ++i; }\n\t\t\t\tif(dt==null && q.t === 'T') return \"\";\n\t\t\t\tout[out.length] = q; lst = c; break;\n\t\t\tcase '[':\n\t\t\t\to = c;\n\t\t\t\twhile(fmt.charAt(i++) !== ']' && i < fmt.length) o += fmt.charAt(i);\n\t\t\t\tif(o.slice(-1) !== ']') throw 'unterminated \"[\" block: |' + o + '|';\n\t\t\t\tif(o.match(SSF_abstime)) {\n\t\t\t\t\tif(dt==null) { dt=SSF_parse_date_code(v, opts); if(dt==null) return \"\"; }\n\t\t\t\t\tout[out.length] = {t:'Z', v:o.toLowerCase()};\n\t\t\t\t\tlst = o.charAt(1);\n\t\t\t\t} else if(o.indexOf(\"$\") > -1) {\n\t\t\t\t\to = (o.match(/\\$([^-\\[\\]]*)/)||[])[1]||\"$\";\n\t\t\t\t\tif(!fmt_is_date(fmt)) out[out.length] = {t:'t',v:o};\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t/* Numbers */\n\t\t\tcase '.':\n\t\t\t\tif(dt != null) {\n\t\t\t\t\to = c; while(++i < fmt.length && (c=fmt.charAt(i)) === \"0\") o += c;\n\t\t\t\t\tout[out.length] = {t:'s', v:o}; break;\n\t\t\t\t}\n\t\t\t\t/* falls through */\n\t\t\tcase '0': case '#':\n\t\t\t\to = c; while(++i < fmt.length && \"0#?.,E+-%\".indexOf(c=fmt.charAt(i)) > -1) o += c;\n\t\t\t\tout[out.length] = {t:'n', v:o}; break;\n\t\t\tcase '?':\n\t\t\t\to = c; while(fmt.charAt(++i) === c) o+=c;\n\t\t\t\tout[out.length] = {t:c, v:o}; lst = c; break;\n\t\t\tcase '*': ++i; if(fmt.charAt(i) == ' ' || fmt.charAt(i) == '*') ++i; break; // **\n\t\t\tcase '(': case ')': out[out.length] = {t:(flen===1?'t':c), v:c}; ++i; break;\n\t\t\tcase '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9':\n\t\t\t\to = c; while(i < fmt.length && \"0123456789\".indexOf(fmt.charAt(++i)) > -1) o+=fmt.charAt(i);\n\t\t\t\tout[out.length] = {t:'D', v:o}; break;\n\t\t\tcase ' ': out[out.length] = {t:c, v:c}; ++i; break;\n\t\t\tcase '$': out[out.length] = {t:'t', v:'$'}; ++i; break;\n\t\t\tdefault:\n\t\t\t\tif(\",$-+/():!^&'~{}<>=€acfijklopqrtuvwxzP\".indexOf(c) === -1) throw new Error('unrecognized character ' + c + ' in ' + fmt);\n\t\t\t\tout[out.length] = {t:'t', v:c}; ++i; break;\n\t\t}\n\t}\n\n\t/* Scan for date/time parts */\n\tvar bt = 0, ss0 = 0, ssm;\n\tfor(i=out.length-1, lst='t'; i >= 0; --i) {\n\t\tswitch(out[i].t) {\n\t\t\tcase 'h': case 'H': out[i].t = hr; lst='h'; if(bt < 1) bt = 1; break;\n\t\t\tcase 's':\n\t\t\t\tif((ssm=out[i].v.match(/\\.0+$/))) ss0=Math.max(ss0,ssm[0].length-1);\n\t\t\t\tif(bt < 3) bt = 3;\n\t\t\t/* falls through */\n\t\t\tcase 'd': case 'y': case 'M': case 'e': lst=out[i].t; break;\n\t\t\tcase 'm': if(lst === 's') { out[i].t = 'M'; if(bt < 2) bt = 2; } break;\n\t\t\tcase 'X': /*if(out[i].v === \"B2\");*/\n\t\t\t\tbreak;\n\t\t\tcase 'Z':\n\t\t\t\tif(bt < 1 && out[i].v.match(/[Hh]/)) bt = 1;\n\t\t\t\tif(bt < 2 && out[i].v.match(/[Mm]/)) bt = 2;\n\t\t\t\tif(bt < 3 && out[i].v.match(/[Ss]/)) bt = 3;\n\t\t}\n\t}\n\t/* time rounding depends on presence of minute / second / usec fields */\n\tswitch(bt) {\n\t\tcase 0: break;\n\t\tcase 1:\n\t\t\t/*::if(!dt) break;*/\n\t\t\tif(dt.u >= 0.5) { dt.u = 0; ++dt.S; }\n\t\t\tif(dt.S >= 60) { dt.S = 0; ++dt.M; }\n\t\t\tif(dt.M >= 60) { dt.M = 0; ++dt.H; }\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\t/*::if(!dt) break;*/\n\t\t\tif(dt.u >= 0.5) { dt.u = 0; ++dt.S; }\n\t\t\tif(dt.S >= 60) { dt.S = 0; ++dt.M; }\n\t\t\tbreak;\n\t}\n\n\t/* replace fields */\n\tvar nstr = \"\", jj;\n\tfor(i=0; i < out.length; ++i) {\n\t\tswitch(out[i].t) {\n\t\t\tcase 't': case 'T': case ' ': case 'D': break;\n\t\t\tcase 'X': out[i].v = \"\"; out[i].t = \";\"; break;\n\t\t\tcase 'd': case 'm': case 'y': case 'h': case 'H': case 'M': case 's': case 'e': case 'b': case 'Z':\n\t\t\t\t/*::if(!dt) throw \"unreachable\"; */\n\t\t\t\tout[i].v = SSF_write_date(out[i].t.charCodeAt(0), out[i].v, dt, ss0);\n\t\t\t\tout[i].t = 't'; break;\n\t\t\tcase 'n': case '?':\n\t\t\t\tjj = i+1;\n\t\t\t\twhile(out[jj] != null && (\n\t\t\t\t\t(c=out[jj].t) === \"?\" || c === \"D\" ||\n\t\t\t\t\t((c === \" \" || c === \"t\") && out[jj+1] != null && (out[jj+1].t === '?' || out[jj+1].t === \"t\" && out[jj+1].v === '/')) ||\n\t\t\t\t\t(out[i].t === '(' && (c === ' ' || c === 'n' || c === ')')) ||\n\t\t\t\t\t(c === 't' && (out[jj].v === '/' || out[jj].v === ' ' && out[jj+1] != null && out[jj+1].t == '?'))\n\t\t\t\t)) {\n\t\t\t\t\tout[i].v += out[jj].v;\n\t\t\t\t\tout[jj] = {v:\"\", t:\";\"}; ++jj;\n\t\t\t\t}\n\t\t\t\tnstr += out[i].v;\n\t\t\t\ti = jj-1; break;\n\t\t\tcase 'G': out[i].t = 't'; out[i].v = SSF_general(v,opts); break;\n\t\t}\n\t}\n\tvar vv = \"\", myv, ostr;\n\tif(nstr.length > 0) {\n\t\tif(nstr.charCodeAt(0) == 40) /* '(' */ {\n\t\t\tmyv = (v<0&&nstr.charCodeAt(0) === 45 ? -v : v);\n\t\t\tostr = write_num('n', nstr, myv);\n\t\t} else {\n\t\t\tmyv = (v<0 && flen > 1 ? -v : v);\n\t\t\tostr = write_num('n', nstr, myv);\n\t\t\tif(myv < 0 && out[0] && out[0].t == 't') {\n\t\t\t\tostr = ostr.substr(1);\n\t\t\t\tout[0].v = \"-\" + out[0].v;\n\t\t\t}\n\t\t}\n\t\tjj=ostr.length-1;\n\t\tvar decpt = out.length;\n\t\tfor(i=0; i < out.length; ++i) if(out[i] != null && out[i].t != 't' && out[i].v.indexOf(\".\") > -1) { decpt = i; break; }\n\t\tvar lasti=out.length;\n\t\tif(decpt === out.length && ostr.indexOf(\"E\") === -1) {\n\t\t\tfor(i=out.length-1; i>= 0;--i) {\n\t\t\t\tif(out[i] == null || 'n?'.indexOf(out[i].t) === -1) continue;\n\t\t\t\tif(jj>=out[i].v.length-1) { jj -= out[i].v.length; out[i].v = ostr.substr(jj+1, out[i].v.length); }\n\t\t\t\telse if(jj < 0) out[i].v = \"\";\n\t\t\t\telse { out[i].v = ostr.substr(0, jj+1); jj = -1; }\n\t\t\t\tout[i].t = 't';\n\t\t\t\tlasti = i;\n\t\t\t}\n\t\t\tif(jj>=0 && lasti<out.length) out[lasti].v = ostr.substr(0,jj+1) + out[lasti].v;\n\t\t}\n\t\telse if(decpt !== out.length && ostr.indexOf(\"E\") === -1) {\n\t\t\tjj = ostr.indexOf(\".\")-1;\n\t\t\tfor(i=decpt; i>= 0; --i) {\n\t\t\t\tif(out[i] == null || 'n?'.indexOf(out[i].t) === -1) continue;\n\t\t\t\tj=out[i].v.indexOf(\".\")>-1&&i===decpt?out[i].v.indexOf(\".\")-1:out[i].v.length-1;\n\t\t\t\tvv = out[i].v.substr(j+1);\n\t\t\t\tfor(; j>=0; --j) {\n\t\t\t\t\tif(jj>=0 && (out[i].v.charAt(j) === \"0\" || out[i].v.charAt(j) === \"#\")) vv = ostr.charAt(jj--) + vv;\n\t\t\t\t}\n\t\t\t\tout[i].v = vv;\n\t\t\t\tout[i].t = 't';\n\t\t\t\tlasti = i;\n\t\t\t}\n\t\t\tif(jj>=0 && lasti<out.length) out[lasti].v = ostr.substr(0,jj+1) + out[lasti].v;\n\t\t\tjj = ostr.indexOf(\".\")+1;\n\t\t\tfor(i=decpt; i<out.length; ++i) {\n\t\t\t\tif(out[i] == null || ('n?('.indexOf(out[i].t) === -1 && i !== decpt)) continue;\n\t\t\t\tj=out[i].v.indexOf(\".\")>-1&&i===decpt?out[i].v.indexOf(\".\")+1:0;\n\t\t\t\tvv = out[i].v.substr(0,j);\n\t\t\t\tfor(; j<out[i].v.length; ++j) {\n\t\t\t\t\tif(jj<ostr.length) vv += ostr.charAt(jj++);\n\t\t\t\t}\n\t\t\t\tout[i].v = vv;\n\t\t\t\tout[i].t = 't';\n\t\t\t\tlasti = i;\n\t\t\t}\n\t\t}\n\t}\n\tfor(i=0; i<out.length; ++i) if(out[i] != null && 'n?'.indexOf(out[i].t)>-1) {\n\t\tmyv = (flen >1 && v < 0 && i>0 && out[i-1].v === \"-\" ? -v:v);\n\t\tout[i].v = write_num(out[i].t, out[i].v, myv);\n\t\tout[i].t = 't';\n\t}\n\tvar retval = \"\";\n\tfor(i=0; i !== out.length; ++i) if(out[i] != null) retval += out[i].v;\n\treturn retval;\n}\n\nvar cfregex2 = /\\[(=|>[=]?|<[>=]?)(-?\\d+(?:\\.\\d*)?)\\]/;\nfunction chkcond(v, rr) {\n\tif(rr == null) return false;\n\tvar thresh = parseFloat(rr[2]);\n\tswitch(rr[1]) {\n\t\tcase \"=\": if(v == thresh) return true; break;\n\t\tcase \">\": if(v > thresh) return true; break;\n\t\tcase \"<\": if(v < thresh) return true; break;\n\t\tcase \"<>\": if(v != thresh) return true; break;\n\t\tcase \">=\": if(v >= thresh) return true; break;\n\t\tcase \"<=\": if(v <= thresh) return true; break;\n\t}\n\treturn false;\n}\nfunction choose_fmt(f/*:string*/, v/*:any*/) {\n\tvar fmt = SSF_split_fmt(f);\n\tvar l = fmt.length, lat = fmt[l-1].indexOf(\"@\");\n\tif(l<4 && lat>-1) --l;\n\tif(fmt.length > 4) throw new Error(\"cannot find right format for |\" + fmt.join(\"|\") + \"|\");\n\tif(typeof v !== \"number\") return [4, fmt.length === 4 || lat>-1?fmt[fmt.length-1]:\"@\"];\n\tswitch(fmt.length) {\n\t\tcase 1: fmt = lat>-1 ? [\"General\", \"General\", \"General\", fmt[0]] : [fmt[0], fmt[0], fmt[0], \"@\"]; break;\n\t\tcase 2: fmt = lat>-1 ? [fmt[0], fmt[0], fmt[0], fmt[1]] : [fmt[0], fmt[1], fmt[0], \"@\"]; break;\n\t\tcase 3: fmt = lat>-1 ? [fmt[0], fmt[1], fmt[0], fmt[2]] : [fmt[0], fmt[1], fmt[2], \"@\"]; break;\n\t\tcase 4: break;\n\t}\n\tvar ff = v > 0 ? fmt[0] : v < 0 ? fmt[1] : fmt[2];\n\tif(fmt[0].indexOf(\"[\") === -1 && fmt[1].indexOf(\"[\") === -1) return [l, ff];\n\tif(fmt[0].match(/\\[[=<>]/) != null || fmt[1].match(/\\[[=<>]/) != null) {\n\t\tvar m1 = fmt[0].match(cfregex2);\n\t\tvar m2 = fmt[1].match(cfregex2);\n\t\treturn chkcond(v, m1) ? [l, fmt[0]] : chkcond(v, m2) ? [l, fmt[1]] : [l, fmt[m1 != null && m2 != null ? 2 : 1]];\n\t}\n\treturn [l, ff];\n}\nfunction SSF_format(fmt/*:string|number*/,v/*:any*/,o/*:?any*/) {\n\tif(o == null) o = {};\n\tvar sfmt = \"\";\n\tswitch(typeof fmt) {\n\t\tcase \"string\":\n\t\t\tif(fmt == \"m/d/yy\" && o.dateNF) sfmt = o.dateNF;\n\t\t\telse sfmt = fmt;\n\t\t\tbreak;\n\t\tcase \"number\":\n\t\t\tif(fmt == 14 && o.dateNF) sfmt = o.dateNF;\n\t\t\telse sfmt = (o.table != null ? (o.table/*:any*/) : table_fmt)[fmt];\n\t\t\tif(sfmt == null) sfmt = (o.table && o.table[SSF_default_map[fmt]]) || table_fmt[SSF_default_map[fmt]];\n\t\t\tif(sfmt == null) sfmt = SSF_default_str[fmt] || \"General\";\n\t\t\tbreak;\n\t}\n\tif(SSF_isgeneral(sfmt,0)) return SSF_general(v, o);\n\tif(v instanceof Date) v = datenum_local(v, o.date1904);\n\tvar f = choose_fmt(sfmt, v);\n\tif(SSF_isgeneral(f[1])) return SSF_general(v, o);\n\tif(v === true) v = \"TRUE\"; else if(v === false) v = \"FALSE\";\n\telse if(v === \"\" || v == null) return \"\";\n\treturn eval_fmt(f[1], v, o, f[0]);\n}\nfunction SSF_load(fmt/*:string*/, idx/*:?number*/)/*:number*/ {\n\tif(typeof idx != 'number') {\n\t\tidx = +idx || -1;\n/*::if(typeof idx != 'number') return 0x188; */\n\t\tfor(var i = 0; i < 0x0188; ++i) {\n/*::if(typeof idx != 'number') return 0x188; */\n\t\t\tif(table_fmt[i] == undefined) { if(idx < 0) idx = i; continue; }\n\t\t\tif(table_fmt[i] == fmt) { idx = i; break; }\n\t\t}\n/*::if(typeof idx != 'number') return 0x188; */\n\t\tif(idx < 0) idx = 0x187;\n\t}\n/*::if(typeof idx != 'number') return 0x188; */\n\ttable_fmt[idx] = fmt;\n\treturn idx;\n}\nfunction SSF_load_table(tbl/*:SSFTable*/)/*:void*/ {\n\tfor(var i=0; i!=0x0188; ++i)\n\t\tif(tbl[i] !== undefined) SSF_load(tbl[i], i);\n}\n\nfunction make_ssf() {\n\ttable_fmt = SSF_init_table();\n}\n\nvar SSF = {\n\tformat: SSF_format,\n\tload: SSF_load,\n\t_table: table_fmt,\n\tload_table: SSF_load_table,\n\tparse_date_code: SSF_parse_date_code,\n\tis_date: fmt_is_date,\n\tget_table: function get_table() { return SSF._table = table_fmt; }\n};\n\nvar SSFImplicit/*{[number]:string}*/ = ({\n\t\"5\": '\"$\"#,##0_);\\\\(\"$\"#,##0\\\\)',\n\t\"6\": '\"$\"#,##0_);[Red]\\\\(\"$\"#,##0\\\\)',\n\t\"7\": '\"$\"#,##0.00_);\\\\(\"$\"#,##0.00\\\\)',\n\t\"8\": '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\t\"23\": 'General', \"24\": 'General', \"25\": 'General', \"26\": 'General',\n\t\"27\": 'm/d/yy', \"28\": 'm/d/yy', \"29\": 'm/d/yy', \"30\": 'm/d/yy', \"31\": 'm/d/yy',\n\t\"32\": 'h:mm:ss', \"33\": 'h:mm:ss', \"34\": 'h:mm:ss', \"35\": 'h:mm:ss',\n\t\"36\": 'm/d/yy',\n\t\"41\": '_(* #,##0_);_(* \\(#,##0\\);_(* \"-\"_);_(@_)',\n\t\"42\": '_(\"$\"* #,##0_);_(\"$\"* \\(#,##0\\);_(\"$\"* \"-\"_);_(@_)',\n\t\"43\": '_(* #,##0.00_);_(* \\(#,##0.00\\);_(* \"-\"??_);_(@_)',\n\t\"44\": '_(\"$\"* #,##0.00_);_(\"$\"* \\(#,##0.00\\);_(\"$\"* \"-\"??_);_(@_)',\n\t\"50\": 'm/d/yy', \"51\": 'm/d/yy', \"52\": 'm/d/yy', \"53\": 'm/d/yy', \"54\": 'm/d/yy',\n\t\"55\": 'm/d/yy', \"56\": 'm/d/yy', \"57\": 'm/d/yy', \"58\": 'm/d/yy',\n\t\"59\": '0',\n\t\"60\": '0.00',\n\t\"61\": '#,##0',\n\t\"62\": '#,##0.00',\n\t\"63\": '\"$\"#,##0_);\\\\(\"$\"#,##0\\\\)',\n\t\"64\": '\"$\"#,##0_);[Red]\\\\(\"$\"#,##0\\\\)',\n\t\"65\": '\"$\"#,##0.00_);\\\\(\"$\"#,##0.00\\\\)',\n\t\"66\": '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\t\"67\": '0%',\n\t\"68\": '0.00%',\n\t\"69\": '# ?/?',\n\t\"70\": '# ??/??',\n\t\"71\": 'm/d/yy',\n\t\"72\": 'm/d/yy',\n\t\"73\": 'd-mmm-yy',\n\t\"74\": 'd-mmm',\n\t\"75\": 'mmm-yy',\n\t\"76\": 'h:mm',\n\t\"77\": 'h:mm:ss',\n\t\"78\": 'm/d/yy h:mm',\n\t\"79\": 'mm:ss',\n\t\"80\": '[h]:mm:ss',\n\t\"81\": 'mmss.0'\n}/*:any*/);\n\n/* dateNF parse TODO: move to SSF */\nvar dateNFregex = /[dD]+|[mM]+|[yYeE]+|[Hh]+|[Ss]+/g;\nfunction dateNF_regex(dateNF/*:string|number*/)/*:RegExp*/ {\n\tvar fmt = typeof dateNF == \"number\" ? table_fmt[dateNF] : dateNF;\n\tfmt = fmt.replace(dateNFregex, \"(\\\\d+)\");\n\treturn new RegExp(\"^\" + fmt + \"$\");\n}\nfunction dateNF_fix(str/*:string*/, dateNF/*:string*/, match/*:Array<string>*/)/*:string*/ {\n\tvar Y = -1, m = -1, d = -1, H = -1, M = -1, S = -1;\n\t(dateNF.match(dateNFregex)||[]).forEach(function(n, i) {\n\t\tvar v = parseInt(match[i+1], 10);\n\t\tswitch(n.toLowerCase().charAt(0)) {\n\t\t\tcase 'y': Y = v; break; case 'd': d = v; break;\n\t\t\tcase 'h': H = v; break; case 's': S = v; break;\n\t\t\tcase 'm': if(H >= 0) M = v; else m = v; break;\n\t\t}\n\t});\n\tif(S >= 0 && M == -1 && m >= 0) { M = m; m = -1; }\n\tvar datestr = ((\"\" + (Y>=0?Y: new Date().getFullYear())).slice(-4) + \"-\" + (\"00\" + (m>=1?m:1)).slice(-2) + \"-\" + (\"00\" + (d>=1?d:1)).slice(-2));\n\tif(datestr.length == 7) datestr = \"0\" + datestr;\n\tif(datestr.length == 8) datestr = \"20\" + datestr;\n\tvar timestr = ((\"00\" + (H>=0?H:0)).slice(-2) + \":\" + (\"00\" + (M>=0?M:0)).slice(-2) + \":\" + (\"00\" + (S>=0?S:0)).slice(-2));\n\tif(H == -1 && M == -1 && S == -1) return datestr;\n\tif(Y == -1 && m == -1 && d == -1) return timestr;\n\treturn datestr + \"T\" + timestr;\n}\n\n/*::\ndeclare var ReadShift:any;\ndeclare var CheckField:any;\ndeclare var prep_blob:any;\ndeclare var __readUInt32LE:any;\ndeclare var __readInt32LE:any;\ndeclare var __toBuffer:any;\ndeclare var __utf16le:any;\ndeclare var bconcat:any;\ndeclare var s2a:any;\ndeclare var chr0:any;\ndeclare var chr1:any;\ndeclare var has_buf:boolean;\ndeclare var new_buf:any;\ndeclare var new_raw_buf:any;\ndeclare var new_unsafe_buf:any;\ndeclare var Buffer_from:any;\n*/\n/* cfb.js (C) 2013-present SheetJS -- http://sheetjs.com */\n/* vim: set ts=2: */\n/*jshint eqnull:true */\n/*exported CFB */\n/*global Uint8Array:false, Uint16Array:false */\n\n/*::\ntype SectorEntry = {\n\tname?:string;\n\tnodes?:Array<number>;\n\tdata:RawBytes;\n};\ntype SectorList = {\n\t[k:string|number]:SectorEntry;\n\tname:?string;\n\tfat_addrs:Array<number>;\n\tssz:number;\n}\ntype CFBFiles = {[n:string]:CFBEntry};\n*/\n/* crc32.js (C) 2014-present SheetJS -- http://sheetjs.com */\n/* vim: set ts=2: */\n/*exported CRC32 */\nvar CRC32 = /*#__PURE__*/(function() {\nvar CRC32 = {};\nCRC32.version = '1.2.0';\n/* see perf/crc32table.js */\n/*global Int32Array */\nfunction signed_crc_table()/*:any*/ {\n\tvar c = 0, table/*:Array<number>*/ = new Array(256);\n\n\tfor(var n =0; n != 256; ++n){\n\t\tc = n;\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\ttable[n] = c;\n\t}\n\n\treturn typeof Int32Array !== 'undefined' ? new Int32Array(table) : table;\n}\n\nvar T0 = signed_crc_table();\nfunction slice_by_16_tables(T) {\n\tvar c = 0, v = 0, n = 0, table/*:Array<number>*/ = typeof Int32Array !== 'undefined' ? new Int32Array(4096) : new Array(4096) ;\n\n\tfor(n = 0; n != 256; ++n) table[n] = T[n];\n\tfor(n = 0; n != 256; ++n) {\n\t\tv = T[n];\n\t\tfor(c = 256 + n; c < 4096; c += 256) v = table[c] = (v >>> 8) ^ T[v & 0xFF];\n\t}\n\tvar out = [];\n\tfor(n = 1; n != 16; ++n) out[n - 1] = typeof Int32Array !== 'undefined' ? table.subarray(n * 256, n * 256 + 256) : table.slice(n * 256, n * 256 + 256);\n\treturn out;\n}\nvar TT = slice_by_16_tables(T0);\nvar T1 = TT[0], T2 = TT[1], T3 = TT[2], T4 = TT[3], T5 = TT[4];\nvar T6 = TT[5], T7 = TT[6], T8 = TT[7], T9 = TT[8], Ta = TT[9];\nvar Tb = TT[10], Tc = TT[11], Td = TT[12], Te = TT[13], Tf = TT[14];\nfunction crc32_bstr(bstr/*:string*/, seed/*:number*/)/*:number*/ {\n\tvar C = seed/*:: ? 0 : 0 */ ^ -1;\n\tfor(var i = 0, L = bstr.length; i < L;) C = (C>>>8) ^ T0[(C^bstr.charCodeAt(i++))&0xFF];\n\treturn ~C;\n}\n\nfunction crc32_buf(B/*:Uint8Array|Array<number>*/, seed/*:number*/)/*:number*/ {\n\tvar C = seed/*:: ? 0 : 0 */ ^ -1, L = B.length - 15, i = 0;\n\tfor(; i < L;) C =\n\t\tTf[B[i++] ^ (C & 255)] ^\n\t\tTe[B[i++] ^ ((C >> 8) & 255)] ^\n\t\tTd[B[i++] ^ ((C >> 16) & 255)] ^\n\t\tTc[B[i++] ^ (C >>> 24)] ^\n\t\tTb[B[i++]] ^ Ta[B[i++]] ^ T9[B[i++]] ^ T8[B[i++]] ^\n\t\tT7[B[i++]] ^ T6[B[i++]] ^ T5[B[i++]] ^ T4[B[i++]] ^\n\t\tT3[B[i++]] ^ T2[B[i++]] ^ T1[B[i++]] ^ T0[B[i++]];\n\tL += 15;\n\twhile(i < L) C = (C>>>8) ^ T0[(C^B[i++])&0xFF];\n\treturn ~C;\n}\n\nfunction crc32_str(str/*:string*/, seed/*:number*/)/*:number*/ {\n\tvar C = seed ^ -1;\n\tfor(var i = 0, L = str.length, c = 0, d = 0; i < L;) {\n\t\tc = str.charCodeAt(i++);\n\t\tif(c < 0x80) {\n\t\t\tC = (C>>>8) ^ T0[(C^c)&0xFF];\n\t\t} else if(c < 0x800) {\n\t\t\tC = (C>>>8) ^ T0[(C ^ (192|((c>>6)&31)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|(c&63)))&0xFF];\n\t\t} else if(c >= 0xD800 && c < 0xE000) {\n\t\t\tc = (c&1023)+64; d = str.charCodeAt(i++)&1023;\n\t\t\tC = (C>>>8) ^ T0[(C ^ (240|((c>>8)&7)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|((c>>2)&63)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|((d>>6)&15)|((c&3)<<4)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|(d&63)))&0xFF];\n\t\t} else {\n\t\t\tC = (C>>>8) ^ T0[(C ^ (224|((c>>12)&15)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|((c>>6)&63)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|(c&63)))&0xFF];\n\t\t}\n\t}\n\treturn ~C;\n}\nCRC32.table = T0;\nCRC32.bstr = crc32_bstr;\nCRC32.buf = crc32_buf;\nCRC32.str = crc32_str;\nreturn CRC32;\n})();\n/* [MS-CFB] v20171201 */\nvar CFB = /*#__PURE__*/(function _CFB(){\nvar exports = {};\nexports.version = '1.2.1';\n/* [MS-CFB] 2.6.4 */\nfunction namecmp(l/*:string*/, r/*:string*/)/*:number*/ {\n\tvar L = l.split(\"/\"), R = r.split(\"/\");\n\tfor(var i = 0, c = 0, Z = Math.min(L.length, R.length); i < Z; ++i) {\n\t\tif((c = L[i].length - R[i].length)) return c;\n\t\tif(L[i] != R[i]) return L[i] < R[i] ? -1 : 1;\n\t}\n\treturn L.length - R.length;\n}\nfunction dirname(p/*:string*/)/*:string*/ {\n\tif(p.charAt(p.length - 1) == \"/\") return (p.slice(0,-1).indexOf(\"/\") === -1) ? p : dirname(p.slice(0, -1));\n\tvar c = p.lastIndexOf(\"/\");\n\treturn (c === -1) ? p : p.slice(0, c+1);\n}\n\nfunction filename(p/*:string*/)/*:string*/ {\n\tif(p.charAt(p.length - 1) == \"/\") return filename(p.slice(0, -1));\n\tvar c = p.lastIndexOf(\"/\");\n\treturn (c === -1) ? p : p.slice(c+1);\n}\n/* -------------------------------------------------------------------------- */\n/* DOS Date format:\n high|YYYYYYYm.mmmddddd.HHHHHMMM.MMMSSSSS|low\n add 1980 to stored year\n stored second should be doubled\n*/\n\n/* write JS date to buf as a DOS date */\nfunction write_dos_date(buf/*:CFBlob*/, date/*:Date|string*/) {\n\tif(typeof date === \"string\") date = new Date(date);\n\tvar hms/*:number*/ = date.getHours();\n\thms = hms << 6 | date.getMinutes();\n\thms = hms << 5 | (date.getSeconds()>>>1);\n\tbuf.write_shift(2, hms);\n\tvar ymd/*:number*/ = (date.getFullYear() - 1980);\n\tymd = ymd << 4 | (date.getMonth()+1);\n\tymd = ymd << 5 | date.getDate();\n\tbuf.write_shift(2, ymd);\n}\n\n/* read four bytes from buf and interpret as a DOS date */\nfunction parse_dos_date(buf/*:CFBlob*/)/*:Date*/ {\n\tvar hms = buf.read_shift(2) & 0xFFFF;\n\tvar ymd = buf.read_shift(2) & 0xFFFF;\n\tvar val = new Date();\n\tvar d = ymd & 0x1F; ymd >>>= 5;\n\tvar m = ymd & 0x0F; ymd >>>= 4;\n\tval.setMilliseconds(0);\n\tval.setFullYear(ymd + 1980);\n\tval.setMonth(m-1);\n\tval.setDate(d);\n\tvar S = hms & 0x1F; hms >>>= 5;\n\tvar M = hms & 0x3F; hms >>>= 6;\n\tval.setHours(hms);\n\tval.setMinutes(M);\n\tval.setSeconds(S<<1);\n\treturn val;\n}\nfunction parse_extra_field(blob/*:CFBlob*/)/*:any*/ {\n\tprep_blob(blob, 0);\n\tvar o = /*::(*/{}/*:: :any)*/;\n\tvar flags = 0;\n\twhile(blob.l <= blob.length - 4) {\n\t\tvar type = blob.read_shift(2);\n\t\tvar sz = blob.read_shift(2), tgt = blob.l + sz;\n\t\tvar p = {};\n\t\tswitch(type) {\n\t\t\t/* UNIX-style Timestamps */\n\t\t\tcase 0x5455: {\n\t\t\t\tflags = blob.read_shift(1);\n\t\t\t\tif(flags & 1) p.mtime = blob.read_shift(4);\n\t\t\t\t/* for some reason, CD flag corresponds to LFH */\n\t\t\t\tif(sz > 5) {\n\t\t\t\t\tif(flags & 2) p.atime = blob.read_shift(4);\n\t\t\t\t\tif(flags & 4) p.ctime = blob.read_shift(4);\n\t\t\t\t}\n\t\t\t\tif(p.mtime) p.mt = new Date(p.mtime*1000);\n\t\t\t}\n\t\t\tbreak;\n\t\t}\n\t\tblob.l = tgt;\n\t\to[type] = p;\n\t}\n\treturn o;\n}\nvar fs/*:: = require('fs'); */;\nfunction get_fs() { return fs || (fs = {}); }\nfunction parse(file/*:RawBytes*/, options/*:CFBReadOpts*/)/*:CFBContainer*/ {\nif(file[0] == 0x50 && file[1] == 0x4b) return parse_zip(file, options);\nif((file[0] | 0x20) == 0x6d && (file[1]|0x20) == 0x69) return parse_mad(file, options);\nif(file.length < 512) throw new Error(\"CFB file size \" + file.length + \" < 512\");\nvar mver = 3;\nvar ssz = 512;\nvar nmfs = 0; // number of mini FAT sectors\nvar difat_sec_cnt = 0;\nvar dir_start = 0;\nvar minifat_start = 0;\nvar difat_start = 0;\n\nvar fat_addrs/*:Array<number>*/ = []; // locations of FAT sectors\n\n/* [MS-CFB] 2.2 Compound File Header */\nvar blob/*:CFBlob*/ = /*::(*/file.slice(0,512)/*:: :any)*/;\nprep_blob(blob, 0);\n\n/* major version */\nvar mv = check_get_mver(blob);\nmver = mv[0];\nswitch(mver) {\n\tcase 3: ssz = 512; break; case 4: ssz = 4096; break;\n\tcase 0: if(mv[1] == 0) return parse_zip(file, options);\n\t/* falls through */\n\tdefault: throw new Error(\"Major Version: Expected 3 or 4 saw \" + mver);\n}\n\n/* reprocess header */\nif(ssz !== 512) { blob = /*::(*/file.slice(0,ssz)/*:: :any)*/; prep_blob(blob, 28 /* blob.l */); }\n/* Save header for final object */\nvar header/*:RawBytes*/ = file.slice(0,ssz);\n\ncheck_shifts(blob, mver);\n\n// Number of Directory Sectors\nvar dir_cnt/*:number*/ = blob.read_shift(4, 'i');\nif(mver === 3 && dir_cnt !== 0) throw new Error('# Directory Sectors: Expected 0 saw ' + dir_cnt);\n\n// Number of FAT Sectors\nblob.l += 4;\n\n// First Directory Sector Location\ndir_start = blob.read_shift(4, 'i');\n\n// Transaction Signature\nblob.l += 4;\n\n// Mini Stream Cutoff Size\nblob.chk('00100000', 'Mini Stream Cutoff Size: ');\n\n// First Mini FAT Sector Location\nminifat_start = blob.read_shift(4, 'i');\n\n// Number of Mini FAT Sectors\nnmfs = blob.read_shift(4, 'i');\n\n// First DIFAT sector location\ndifat_start = blob.read_shift(4, 'i');\n\n// Number of DIFAT Sectors\ndifat_sec_cnt = blob.read_shift(4, 'i');\n\n// Grab FAT Sector Locations\nfor(var q = -1, j = 0; j < 109; ++j) { /* 109 = (512 - blob.l)>>>2; */\n\tq = blob.read_shift(4, 'i');\n\tif(q<0) break;\n\tfat_addrs[j] = q;\n}\n\n/** Break the file up into sectors */\nvar sectors/*:Array<RawBytes>*/ = sectorify(file, ssz);\n\nsleuth_fat(difat_start, difat_sec_cnt, sectors, ssz, fat_addrs);\n\n/** Chains */\nvar sector_list/*:SectorList*/ = make_sector_list(sectors, dir_start, fat_addrs, ssz);\n\nsector_list[dir_start].name = \"!Directory\";\nif(nmfs > 0 && minifat_start !== ENDOFCHAIN) sector_list[minifat_start].name = \"!MiniFAT\";\nsector_list[fat_addrs[0]].name = \"!FAT\";\nsector_list.fat_addrs = fat_addrs;\nsector_list.ssz = ssz;\n\n/* [MS-CFB] 2.6.1 Compound File Directory Entry */\nvar files/*:CFBFiles*/ = {}, Paths/*:Array<string>*/ = [], FileIndex/*:CFBFileIndex*/ = [], FullPaths/*:Array<string>*/ = [];\nread_directory(dir_start, sector_list, sectors, Paths, nmfs, files, FileIndex, minifat_start);\n\nbuild_full_paths(FileIndex, FullPaths, Paths);\nPaths.shift();\n\nvar o = {\n\tFileIndex: FileIndex,\n\tFullPaths: FullPaths\n};\n\n// $FlowIgnore\nif(options && options.raw) o.raw = {header: header, sectors: sectors};\nreturn o;\n} // parse\n\n/* [MS-CFB] 2.2 Compound File Header -- read up to major version */\nfunction check_get_mver(blob/*:CFBlob*/)/*:[number, number]*/ {\n\tif(blob[blob.l] == 0x50 && blob[blob.l + 1] == 0x4b) return [0, 0];\n\t// header signature 8\n\tblob.chk(HEADER_SIGNATURE, 'Header Signature: ');\n\n\t// clsid 16\n\t//blob.chk(HEADER_CLSID, 'CLSID: ');\n\tblob.l += 16;\n\n\t// minor version 2\n\tvar mver/*:number*/ = blob.read_shift(2, 'u');\n\n\treturn [blob.read_shift(2,'u'), mver];\n}\nfunction check_shifts(blob/*:CFBlob*/, mver/*:number*/)/*:void*/ {\n\tvar shift = 0x09;\n\n\t// Byte Order\n\t//blob.chk('feff', 'Byte Order: '); // note: some writers put 0xffff\n\tblob.l += 2;\n\n\t// Sector Shift\n\tswitch((shift = blob.read_shift(2))) {\n\t\tcase 0x09: if(mver != 3) throw new Error('Sector Shift: Expected 9 saw ' + shift); break;\n\t\tcase 0x0c: if(mver != 4) throw new Error('Sector Shift: Expected 12 saw ' + shift); break;\n\t\tdefault: throw new Error('Sector Shift: Expected 9 or 12 saw ' + shift);\n\t}\n\n\t// Mini Sector Shift\n\tblob.chk('0600', 'Mini Sector Shift: ');\n\n\t// Reserved\n\tblob.chk('000000000000', 'Reserved: ');\n}\n\n/** Break the file up into sectors */\nfunction sectorify(file/*:RawBytes*/, ssz/*:number*/)/*:Array<RawBytes>*/ {\n\tvar nsectors = Math.ceil(file.length/ssz)-1;\n\tvar sectors/*:Array<RawBytes>*/ = [];\n\tfor(var i=1; i < nsectors; ++i) sectors[i-1] = file.slice(i*ssz,(i+1)*ssz);\n\tsectors[nsectors-1] = file.slice(nsectors*ssz);\n\treturn sectors;\n}\n\n/* [MS-CFB] 2.6.4 Red-Black Tree */\nfunction build_full_paths(FI/*:CFBFileIndex*/, FP/*:Array<string>*/, Paths/*:Array<string>*/)/*:void*/ {\n\tvar i = 0, L = 0, R = 0, C = 0, j = 0, pl = Paths.length;\n\tvar dad/*:Array<number>*/ = [], q/*:Array<number>*/ = [];\n\n\tfor(; i < pl; ++i) { dad[i]=q[i]=i; FP[i]=Paths[i]; }\n\n\tfor(; j < q.length; ++j) {\n\t\ti = q[j];\n\t\tL = FI[i].L; R = FI[i].R; C = FI[i].C;\n\t\tif(dad[i] === i) {\n\t\t\tif(L !== -1 /*NOSTREAM*/ && dad[L] !== L) dad[i] = dad[L];\n\t\t\tif(R !== -1 && dad[R] !== R) dad[i] = dad[R];\n\t\t}\n\t\tif(C !== -1 /*NOSTREAM*/) dad[C] = i;\n\t\tif(L !== -1 && i != dad[i]) { dad[L] = dad[i]; if(q.lastIndexOf(L) < j) q.push(L); }\n\t\tif(R !== -1 && i != dad[i]) { dad[R] = dad[i]; if(q.lastIndexOf(R) < j) q.push(R); }\n\t}\n\tfor(i=1; i < pl; ++i) if(dad[i] === i) {\n\t\tif(R !== -1 /*NOSTREAM*/ && dad[R] !== R) dad[i] = dad[R];\n\t\telse if(L !== -1 && dad[L] !== L) dad[i] = dad[L];\n\t}\n\n\tfor(i=1; i < pl; ++i) {\n\t\tif(FI[i].type === 0 /* unknown */) continue;\n\t\tj = i;\n\t\tif(j != dad[j]) do {\n\t\t\tj = dad[j];\n\t\t\tFP[i] = FP[j] + \"/\" + FP[i];\n\t\t} while (j !== 0 && -1 !== dad[j] && j != dad[j]);\n\t\tdad[i] = -1;\n\t}\n\n\tFP[0] += \"/\";\n\tfor(i=1; i < pl; ++i) {\n\t\tif(FI[i].type !== 2 /* stream */) FP[i] += \"/\";\n\t}\n}\n\nfunction get_mfat_entry(entry/*:CFBEntry*/, payload/*:RawBytes*/, mini/*:?RawBytes*/)/*:CFBlob*/ {\n\tvar start = entry.start, size = entry.size;\n\t//return (payload.slice(start*MSSZ, start*MSSZ + size)/*:any*/);\n\tvar o = [];\n\tvar idx = start;\n\twhile(mini && size > 0 && idx >= 0) {\n\t\to.push(payload.slice(idx * MSSZ, idx * MSSZ + MSSZ));\n\t\tsize -= MSSZ;\n\t\tidx = __readInt32LE(mini, idx * 4);\n\t}\n\tif(o.length === 0) return (new_buf(0)/*:any*/);\n\treturn (bconcat(o).slice(0, entry.size)/*:any*/);\n}\n\n/** Chase down the rest of the DIFAT chain to build a comprehensive list\n DIFAT chains by storing the next sector number as the last 32 bits */\nfunction sleuth_fat(idx/*:number*/, cnt/*:number*/, sectors/*:Array<RawBytes>*/, ssz/*:number*/, fat_addrs)/*:void*/ {\n\tvar q/*:number*/ = ENDOFCHAIN;\n\tif(idx === ENDOFCHAIN) {\n\t\tif(cnt !== 0) throw new Error(\"DIFAT chain shorter than expected\");\n\t} else if(idx !== -1 /*FREESECT*/) {\n\t\tvar sector = sectors[idx], m = (ssz>>>2)-1;\n\t\tif(!sector) return;\n\t\tfor(var i = 0; i < m; ++i) {\n\t\t\tif((q = __readInt32LE(sector,i*4)) === ENDOFCHAIN) break;\n\t\t\tfat_addrs.push(q);\n\t\t}\n\t\tsleuth_fat(__readInt32LE(sector,ssz-4),cnt - 1, sectors, ssz, fat_addrs);\n\t}\n}\n\n/** Follow the linked list of sectors for a given starting point */\nfunction get_sector_list(sectors/*:Array<RawBytes>*/, start/*:number*/, fat_addrs/*:Array<number>*/, ssz/*:number*/, chkd/*:?Array<boolean>*/)/*:SectorEntry*/ {\n\tvar buf/*:Array<number>*/ = [], buf_chain/*:Array<any>*/ = [];\n\tif(!chkd) chkd = [];\n\tvar modulus = ssz - 1, j = 0, jj = 0;\n\tfor(j=start; j>=0;) {\n\t\tchkd[j] = true;\n\t\tbuf[buf.length] = j;\n\t\tbuf_chain.push(sectors[j]);\n\t\tvar addr = fat_addrs[Math.floor(j*4/ssz)];\n\t\tjj = ((j*4) & modulus);\n\t\tif(ssz < 4 + jj) throw new Error(\"FAT boundary crossed: \" + j + \" 4 \"+ssz);\n\t\tif(!sectors[addr]) break;\n\t\tj = __readInt32LE(sectors[addr], jj);\n\t}\n\treturn {nodes: buf, data:__toBuffer([buf_chain])};\n}\n\n/** Chase down the sector linked lists */\nfunction make_sector_list(sectors/*:Array<RawBytes>*/, dir_start/*:number*/, fat_addrs/*:Array<number>*/, ssz/*:number*/)/*:SectorList*/ {\n\tvar sl = sectors.length, sector_list/*:SectorList*/ = ([]/*:any*/);\n\tvar chkd/*:Array<boolean>*/ = [], buf/*:Array<number>*/ = [], buf_chain/*:Array<RawBytes>*/ = [];\n\tvar modulus = ssz - 1, i=0, j=0, k=0, jj=0;\n\tfor(i=0; i < sl; ++i) {\n\t\tbuf = ([]/*:Array<number>*/);\n\t\tk = (i + dir_start); if(k >= sl) k-=sl;\n\t\tif(chkd[k]) continue;\n\t\tbuf_chain = [];\n\t\tvar seen = [];\n\t\tfor(j=k; j>=0;) {\n\t\t\tseen[j] = true;\n\t\t\tchkd[j] = true;\n\t\t\tbuf[buf.length] = j;\n\t\t\tbuf_chain.push(sectors[j]);\n\t\t\tvar addr/*:number*/ = fat_addrs[Math.floor(j*4/ssz)];\n\t\t\tjj = ((j*4) & modulus);\n\t\t\tif(ssz < 4 + jj) throw new Error(\"FAT boundary crossed: \" + j + \" 4 \"+ssz);\n\t\t\tif(!sectors[addr]) break;\n\t\t\tj = __readInt32LE(sectors[addr], jj);\n\t\t\tif(seen[j]) break;\n\t\t}\n\t\tsector_list[k] = ({nodes: buf, data:__toBuffer([buf_chain])}/*:SectorEntry*/);\n\t}\n\treturn sector_list;\n}\n\n/* [MS-CFB] 2.6.1 Compound File Directory Entry */\nfunction read_directory(dir_start/*:number*/, sector_list/*:SectorList*/, sectors/*:Array<RawBytes>*/, Paths/*:Array<string>*/, nmfs, files, FileIndex, mini) {\n\tvar minifat_store = 0, pl = (Paths.length?2:0);\n\tvar sector = sector_list[dir_start].data;\n\tvar i = 0, namelen = 0, name;\n\tfor(; i < sector.length; i+= 128) {\n\t\tvar blob/*:CFBlob*/ = /*::(*/sector.slice(i, i+128)/*:: :any)*/;\n\t\tprep_blob(blob, 64);\n\t\tnamelen = blob.read_shift(2);\n\t\tname = __utf16le(blob,0,namelen-pl);\n\t\tPaths.push(name);\n\t\tvar o/*:CFBEntry*/ = ({\n\t\t\tname: name,\n\t\t\ttype: blob.read_shift(1),\n\t\t\tcolor: blob.read_shift(1),\n\t\t\tL: blob.read_shift(4, 'i'),\n\t\t\tR: blob.read_shift(4, 'i'),\n\t\t\tC: blob.read_shift(4, 'i'),\n\t\t\tclsid: blob.read_shift(16),\n\t\t\tstate: blob.read_shift(4, 'i'),\n\t\t\tstart: 0,\n\t\t\tsize: 0\n\t\t});\n\t\tvar ctime/*:number*/ = blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2);\n\t\tif(ctime !== 0) o.ct = read_date(blob, blob.l-8);\n\t\tvar mtime/*:number*/ = blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2);\n\t\tif(mtime !== 0) o.mt = read_date(blob, blob.l-8);\n\t\to.start = blob.read_shift(4, 'i');\n\t\to.size = blob.read_shift(4, 'i');\n\t\tif(o.size < 0 && o.start < 0) { o.size = o.type = 0; o.start = ENDOFCHAIN; o.name = \"\"; }\n\t\tif(o.type === 5) { /* root */\n\t\t\tminifat_store = o.start;\n\t\t\tif(nmfs > 0 && minifat_store !== ENDOFCHAIN) sector_list[minifat_store].name = \"!StreamData\";\n\t\t\t/*minifat_size = o.size;*/\n\t\t} else if(o.size >= 4096 /* MSCSZ */) {\n\t\t\to.storage = 'fat';\n\t\t\tif(sector_list[o.start] === undefined) sector_list[o.start] = get_sector_list(sectors, o.start, sector_list.fat_addrs, sector_list.ssz);\n\t\t\tsector_list[o.start].name = o.name;\n\t\t\to.content = (sector_list[o.start].data.slice(0,o.size)/*:any*/);\n\t\t} else {\n\t\t\to.storage = 'minifat';\n\t\t\tif(o.size < 0) o.size = 0;\n\t\t\telse if(minifat_store !== ENDOFCHAIN && o.start !== ENDOFCHAIN && sector_list[minifat_store]) {\n\t\t\t\to.content = get_mfat_entry(o, sector_list[minifat_store].data, (sector_list[mini]||{}).data);\n\t\t\t}\n\t\t}\n\t\tif(o.content) prep_blob(o.content, 0);\n\t\tfiles[name] = o;\n\t\tFileIndex.push(o);\n\t}\n}\n\nfunction read_date(blob/*:RawBytes|CFBlob*/, offset/*:number*/)/*:Date*/ {\n\treturn new Date(( ( (__readUInt32LE(blob,offset+4)/1e7)*Math.pow(2,32)+__readUInt32LE(blob,offset)/1e7 ) - 11644473600)*1000);\n}\n\nfunction read_file(filename/*:string*/, options/*:CFBReadOpts*/) {\n\tget_fs();\n\treturn parse(fs.readFileSync(filename), options);\n}\n\nfunction read(blob/*:RawBytes|string*/, options/*:CFBReadOpts*/) {\n\tvar type = options && options.type;\n\tif(!type) {\n\t\tif(has_buf && Buffer.isBuffer(blob)) type = \"buffer\";\n\t}\n\tswitch(type || \"base64\") {\n\t\tcase \"file\": /*:: if(typeof blob !== 'string') throw \"Must pass a filename when type='file'\"; */return read_file(blob, options);\n\t\tcase \"base64\": /*:: if(typeof blob !== 'string') throw \"Must pass a base64-encoded binary string when type='file'\"; */return parse(s2a(Base64_decode(blob)), options);\n\t\tcase \"binary\": /*:: if(typeof blob !== 'string') throw \"Must pass a binary string when type='file'\"; */return parse(s2a(blob), options);\n\t}\n\treturn parse(/*::typeof blob == 'string' ? new Buffer(blob, 'utf-8') : */blob, options);\n}\n\nfunction init_cfb(cfb/*:CFBContainer*/, opts/*:?any*/)/*:void*/ {\n\tvar o = opts || {}, root = o.root || \"Root Entry\";\n\tif(!cfb.FullPaths) cfb.FullPaths = [];\n\tif(!cfb.FileIndex) cfb.FileIndex = [];\n\tif(cfb.FullPaths.length !== cfb.FileIndex.length) throw new Error(\"inconsistent CFB structure\");\n\tif(cfb.FullPaths.length === 0) {\n\t\tcfb.FullPaths[0] = root + \"/\";\n\t\tcfb.FileIndex[0] = ({ name: root, type: 5 }/*:any*/);\n\t}\n\tif(o.CLSID) cfb.FileIndex[0].clsid = o.CLSID;\n\tseed_cfb(cfb);\n}\nfunction seed_cfb(cfb/*:CFBContainer*/)/*:void*/ {\n\tvar nm = \"\\u0001Sh33tJ5\";\n\tif(CFB.find(cfb, \"/\" + nm)) return;\n\tvar p = new_buf(4); p[0] = 55; p[1] = p[3] = 50; p[2] = 54;\n\tcfb.FileIndex.push(({ name: nm, type: 2, content:p, size:4, L:69, R:69, C:69 }/*:any*/));\n\tcfb.FullPaths.push(cfb.FullPaths[0] + nm);\n\trebuild_cfb(cfb);\n}\nfunction rebuild_cfb(cfb/*:CFBContainer*/, f/*:?boolean*/)/*:void*/ {\n\tinit_cfb(cfb);\n\tvar gc = false, s = false;\n\tfor(var i = cfb.FullPaths.length - 1; i >= 0; --i) {\n\t\tvar _file = cfb.FileIndex[i];\n\t\tswitch(_file.type) {\n\t\t\tcase 0:\n\t\t\t\tif(s) gc = true;\n\t\t\t\telse { cfb.FileIndex.pop(); cfb.FullPaths.pop(); }\n\t\t\t\tbreak;\n\t\t\tcase 1: case 2: case 5:\n\t\t\t\ts = true;\n\t\t\t\tif(isNaN(_file.R * _file.L * _file.C)) gc = true;\n\t\t\t\tif(_file.R > -1 && _file.L > -1 && _file.R == _file.L) gc = true;\n\t\t\t\tbreak;\n\t\t\tdefault: gc = true; break;\n\t\t}\n\t}\n\tif(!gc && !f) return;\n\n\tvar now = new Date(1987, 1, 19), j = 0;\n\t// Track which names exist\n\tvar fullPaths = Object.create ? Object.create(null) : {};\n\tvar data/*:Array<[string, CFBEntry]>*/ = [];\n\tfor(i = 0; i < cfb.FullPaths.length; ++i) {\n\t\tfullPaths[cfb.FullPaths[i]] = true;\n\t\tif(cfb.FileIndex[i].type === 0) continue;\n\t\tdata.push([cfb.FullPaths[i], cfb.FileIndex[i]]);\n\t}\n\tfor(i = 0; i < data.length; ++i) {\n\t\tvar dad = dirname(data[i][0]);\n\t\ts = fullPaths[dad];\n\t\tif(!s) {\n\t\t\tdata.push([dad, ({\n\t\t\t\tname: filename(dad).replace(\"/\",\"\"),\n\t\t\t\ttype: 1,\n\t\t\t\tclsid: HEADER_CLSID,\n\t\t\t\tct: now, mt: now,\n\t\t\t\tcontent: null\n\t\t\t}/*:any*/)]);\n\t\t\t// Add name to set\n\t\t\tfullPaths[dad] = true;\n\t\t}\n\t}\n\n\tdata.sort(function(x,y) { return namecmp(x[0], y[0]); });\n\tcfb.FullPaths = []; cfb.FileIndex = [];\n\tfor(i = 0; i < data.length; ++i) { cfb.FullPaths[i] = data[i][0]; cfb.FileIndex[i] = data[i][1]; }\n\tfor(i = 0; i < data.length; ++i) {\n\t\tvar elt = cfb.FileIndex[i];\n\t\tvar nm = cfb.FullPaths[i];\n\n\t\telt.name = filename(nm).replace(\"/\",\"\");\n\t\telt.L = elt.R = elt.C = -(elt.color = 1);\n\t\telt.size = elt.content ? elt.content.length : 0;\n\t\telt.start = 0;\n\t\telt.clsid = (elt.clsid || HEADER_CLSID);\n\t\tif(i === 0) {\n\t\t\telt.C = data.length > 1 ? 1 : -1;\n\t\t\telt.size = 0;\n\t\t\telt.type = 5;\n\t\t} else if(nm.slice(-1) == \"/\") {\n\t\t\tfor(j=i+1;j < data.length; ++j) if(dirname(cfb.FullPaths[j])==nm) break;\n\t\t\telt.C = j >= data.length ? -1 : j;\n\t\t\tfor(j=i+1;j < data.length; ++j) if(dirname(cfb.FullPaths[j])==dirname(nm)) break;\n\t\t\telt.R = j >= data.length ? -1 : j;\n\t\t\telt.type = 1;\n\t\t} else {\n\t\t\tif(dirname(cfb.FullPaths[i+1]||\"\") == dirname(nm)) elt.R = i + 1;\n\t\t\telt.type = 2;\n\t\t}\n\t}\n\n}\n\nfunction _write(cfb/*:CFBContainer*/, options/*:CFBWriteOpts*/)/*:RawBytes|string*/ {\n\tvar _opts = options || {};\n\t/* MAD is order-sensitive, skip rebuild and sort */\n\tif(_opts.fileType == 'mad') return write_mad(cfb, _opts);\n\trebuild_cfb(cfb);\n\tswitch(_opts.fileType) {\n\t\tcase 'zip': return write_zip(cfb, _opts);\n\t\t//case 'mad': return write_mad(cfb, _opts);\n\t}\n\tvar L = (function(cfb/*:CFBContainer*/)/*:Array<number>*/{\n\t\tvar mini_size = 0, fat_size = 0;\n\t\tfor(var i = 0; i < cfb.FileIndex.length; ++i) {\n\t\t\tvar file = cfb.FileIndex[i];\n\t\t\tif(!file.content) continue;\n\t\t\t/*:: if(file.content == null) throw new Error(\"unreachable\"); */\n\t\t\tvar flen = file.content.length;\n\t\t\tif(flen > 0){\n\t\t\t\tif(flen < 0x1000) mini_size += (flen + 0x3F) >> 6;\n\t\t\t\telse fat_size += (flen + 0x01FF) >> 9;\n\t\t\t}\n\t\t}\n\t\tvar dir_cnt = (cfb.FullPaths.length +3) >> 2;\n\t\tvar mini_cnt = (mini_size + 7) >> 3;\n\t\tvar mfat_cnt = (mini_size + 0x7F) >> 7;\n\t\tvar fat_base = mini_cnt + fat_size + dir_cnt + mfat_cnt;\n\t\tvar fat_cnt = (fat_base + 0x7F) >> 7;\n\t\tvar difat_cnt = fat_cnt <= 109 ? 0 : Math.ceil((fat_cnt-109)/0x7F);\n\t\twhile(((fat_base + fat_cnt + difat_cnt + 0x7F) >> 7) > fat_cnt) difat_cnt = ++fat_cnt <= 109 ? 0 : Math.ceil((fat_cnt-109)/0x7F);\n\t\tvar L = [1, difat_cnt, fat_cnt, mfat_cnt, dir_cnt, fat_size, mini_size, 0];\n\t\tcfb.FileIndex[0].size = mini_size << 6;\n\t\tL[7] = (cfb.FileIndex[0].start=L[0]+L[1]+L[2]+L[3]+L[4]+L[5])+((L[6]+7) >> 3);\n\t\treturn L;\n\t})(cfb);\n\tvar o = new_buf(L[7] << 9);\n\tvar i = 0, T = 0;\n\t{\n\t\tfor(i = 0; i < 8; ++i) o.write_shift(1, HEADER_SIG[i]);\n\t\tfor(i = 0; i < 8; ++i) o.write_shift(2, 0);\n\t\to.write_shift(2, 0x003E);\n\t\to.write_shift(2, 0x0003);\n\t\to.write_shift(2, 0xFFFE);\n\t\to.write_shift(2, 0x0009);\n\t\to.write_shift(2, 0x0006);\n\t\tfor(i = 0; i < 3; ++i) o.write_shift(2, 0);\n\t\to.write_shift(4, 0);\n\t\to.write_shift(4, L[2]);\n\t\to.write_shift(4, L[0] + L[1] + L[2] + L[3] - 1);\n\t\to.write_shift(4, 0);\n\t\to.write_shift(4, 1<<12);\n\t\to.write_shift(4, L[3] ? L[0] + L[1] + L[2] - 1: ENDOFCHAIN);\n\t\to.write_shift(4, L[3]);\n\t\to.write_shift(-4, L[1] ? L[0] - 1: ENDOFCHAIN);\n\t\to.write_shift(4, L[1]);\n\t\tfor(i = 0; i < 109; ++i) o.write_shift(-4, i < L[2] ? L[1] + i : -1);\n\t}\n\tif(L[1]) {\n\t\tfor(T = 0; T < L[1]; ++T) {\n\t\t\tfor(; i < 236 + T * 127; ++i) o.write_shift(-4, i < L[2] ? L[1] + i : -1);\n\t\t\to.write_shift(-4, T === L[1] - 1 ? ENDOFCHAIN : T + 1);\n\t\t}\n\t}\n\tvar chainit = function(w/*:number*/)/*:void*/ {\n\t\tfor(T += w; i<T-1; ++i) o.write_shift(-4, i+1);\n\t\tif(w) { ++i; o.write_shift(-4, ENDOFCHAIN); }\n\t};\n\tT = i = 0;\n\tfor(T+=L[1]; i<T; ++i) o.write_shift(-4, consts.DIFSECT);\n\tfor(T+=L[2]; i<T; ++i) o.write_shift(-4, consts.FATSECT);\n\tchainit(L[3]);\n\tchainit(L[4]);\n\tvar j/*:number*/ = 0, flen/*:number*/ = 0;\n\tvar file/*:CFBEntry*/ = cfb.FileIndex[0];\n\tfor(; j < cfb.FileIndex.length; ++j) {\n\t\tfile = cfb.FileIndex[j];\n\t\tif(!file.content) continue;\n\t\t/*:: if(file.content == null) throw new Error(\"unreachable\"); */\n\t\tflen = file.content.length;\n\t\tif(flen < 0x1000) continue;\n\t\tfile.start = T;\n\t\tchainit((flen + 0x01FF) >> 9);\n\t}\n\tchainit((L[6] + 7) >> 3);\n\twhile(o.l & 0x1FF) o.write_shift(-4, consts.ENDOFCHAIN);\n\tT = i = 0;\n\tfor(j = 0; j < cfb.FileIndex.length; ++j) {\n\t\tfile = cfb.FileIndex[j];\n\t\tif(!file.content) continue;\n\t\t/*:: if(file.content == null) throw new Error(\"unreachable\"); */\n\t\tflen = file.content.length;\n\t\tif(!flen || flen >= 0x1000) continue;\n\t\tfile.start = T;\n\t\tchainit((flen + 0x3F) >> 6);\n\t}\n\twhile(o.l & 0x1FF) o.write_shift(-4, consts.ENDOFCHAIN);\n\tfor(i = 0; i < L[4]<<2; ++i) {\n\t\tvar nm = cfb.FullPaths[i];\n\t\tif(!nm || nm.length === 0) {\n\t\t\tfor(j = 0; j < 17; ++j) o.write_shift(4, 0);\n\t\t\tfor(j = 0; j < 3; ++j) o.write_shift(4, -1);\n\t\t\tfor(j = 0; j < 12; ++j) o.write_shift(4, 0);\n\t\t\tcontinue;\n\t\t}\n\t\tfile = cfb.FileIndex[i];\n\t\tif(i === 0) file.start = file.size ? file.start - 1 : ENDOFCHAIN;\n\t\tvar _nm/*:string*/ = (i === 0 && _opts.root) || file.name;\n\t\tflen = 2*(_nm.length+1);\n\t\to.write_shift(64, _nm, \"utf16le\");\n\t\to.write_shift(2, flen);\n\t\to.write_shift(1, file.type);\n\t\to.write_shift(1, file.color);\n\t\to.write_shift(-4, file.L);\n\t\to.write_shift(-4, file.R);\n\t\to.write_shift(-4, file.C);\n\t\tif(!file.clsid) for(j = 0; j < 4; ++j) o.write_shift(4, 0);\n\t\telse o.write_shift(16, file.clsid, \"hex\");\n\t\to.write_shift(4, file.state || 0);\n\t\to.write_shift(4, 0); o.write_shift(4, 0);\n\t\to.write_shift(4, 0); o.write_shift(4, 0);\n\t\to.write_shift(4, file.start);\n\t\to.write_shift(4, file.size); o.write_shift(4, 0);\n\t}\n\tfor(i = 1; i < cfb.FileIndex.length; ++i) {\n\t\tfile = cfb.FileIndex[i];\n\t\t/*:: if(!file.content) throw new Error(\"unreachable\"); */\n\t\tif(file.size >= 0x1000) {\n\t\t\to.l = (file.start+1) << 9;\n\t\t\tif (has_buf && Buffer.isBuffer(file.content)) {\n\t\t\t\tfile.content.copy(o, o.l, 0, file.size);\n\t\t\t\t// o is a 0-filled Buffer so just set next offset\n\t\t\t\to.l += (file.size + 511) & -512;\n\t\t\t} else {\n\t\t\t\tfor(j = 0; j < file.size; ++j) o.write_shift(1, file.content[j]);\n\t\t\t\tfor(; j & 0x1FF; ++j) o.write_shift(1, 0);\n\t\t\t}\n\t\t}\n\t}\n\tfor(i = 1; i < cfb.FileIndex.length; ++i) {\n\t\tfile = cfb.FileIndex[i];\n\t\t/*:: if(!file.content) throw new Error(\"unreachable\"); */\n\t\tif(file.size > 0 && file.size < 0x1000) {\n\t\t\tif (has_buf && Buffer.isBuffer(file.content)) {\n\t\t\t\tfile.content.copy(o, o.l, 0, file.size);\n\t\t\t\t// o is a 0-filled Buffer so just set next offset\n\t\t\t\to.l += (file.size + 63) & -64;\n\t\t\t} else {\n\t\t\t\tfor(j = 0; j < file.size; ++j) o.write_shift(1, file.content[j]);\n\t\t\t\tfor(; j & 0x3F; ++j) o.write_shift(1, 0);\n\t\t\t}\n\t\t}\n\t}\n\tif (has_buf) {\n\t\to.l = o.length;\n\t} else {\n\t\t// When using Buffer, already 0-filled\n\t\twhile(o.l < o.length) o.write_shift(1, 0);\n\t}\n\treturn o;\n}\n/* [MS-CFB] 2.6.4 (Unicode 3.0.1 case conversion) */\nfunction find(cfb/*:CFBContainer*/, path/*:string*/)/*:?CFBEntry*/ {\n\tvar UCFullPaths/*:Array<string>*/ = cfb.FullPaths.map(function(x) { return x.toUpperCase(); });\n\tvar UCPaths/*:Array<string>*/ = UCFullPaths.map(function(x) { var y = x.split(\"/\"); return y[y.length - (x.slice(-1) == \"/\" ? 2 : 1)]; });\n\tvar k/*:boolean*/ = false;\n\tif(path.charCodeAt(0) === 47 /* \"/\" */) { k = true; path = UCFullPaths[0].slice(0, -1) + path; }\n\telse k = path.indexOf(\"/\") !== -1;\n\tvar UCPath/*:string*/ = path.toUpperCase();\n\tvar w/*:number*/ = k === true ? UCFullPaths.indexOf(UCPath) : UCPaths.indexOf(UCPath);\n\tif(w !== -1) return cfb.FileIndex[w];\n\n\tvar m = !UCPath.match(chr1);\n\tUCPath = UCPath.replace(chr0,'');\n\tif(m) UCPath = UCPath.replace(chr1,'!');\n\tfor(w = 0; w < UCFullPaths.length; ++w) {\n\t\tif((m ? UCFullPaths[w].replace(chr1,'!') : UCFullPaths[w]).replace(chr0,'') == UCPath) return cfb.FileIndex[w];\n\t\tif((m ? UCPaths[w].replace(chr1,'!') : UCPaths[w]).replace(chr0,'') == UCPath) return cfb.FileIndex[w];\n\t}\n\treturn null;\n}\n/** CFB Constants */\nvar MSSZ = 64; /* Mini Sector Size = 1<<6 */\n//var MSCSZ = 4096; /* Mini Stream Cutoff Size */\n/* 2.1 Compound File Sector Numbers and Types */\nvar ENDOFCHAIN = -2;\n/* 2.2 Compound File Header */\nvar HEADER_SIGNATURE = 'd0cf11e0a1b11ae1';\nvar HEADER_SIG = [0xD0, 0xCF, 0x11, 0xE0, 0xA1, 0xB1, 0x1A, 0xE1];\nvar HEADER_CLSID = '00000000000000000000000000000000';\nvar consts = {\n\t/* 2.1 Compund File Sector Numbers and Types */\n\tMAXREGSECT: -6,\n\tDIFSECT: -4,\n\tFATSECT: -3,\n\tENDOFCHAIN: ENDOFCHAIN,\n\tFREESECT: -1,\n\t/* 2.2 Compound File Header */\n\tHEADER_SIGNATURE: HEADER_SIGNATURE,\n\tHEADER_MINOR_VERSION: '3e00',\n\tMAXREGSID: -6,\n\tNOSTREAM: -1,\n\tHEADER_CLSID: HEADER_CLSID,\n\t/* 2.6.1 Compound File Directory Entry */\n\tEntryTypes: ['unknown','storage','stream','lockbytes','property','root']\n};\n\nfunction write_file(cfb/*:CFBContainer*/, filename/*:string*/, options/*:CFBWriteOpts*/)/*:void*/ {\n\tget_fs();\n\tvar o = _write(cfb, options);\n\t/*:: if(typeof Buffer == 'undefined' || !Buffer.isBuffer(o) || !(o instanceof Buffer)) throw new Error(\"unreachable\"); */\n\tfs.writeFileSync(filename, o);\n}\n\nfunction a2s(o/*:RawBytes*/)/*:string*/ {\n\tvar out = new Array(o.length);\n\tfor(var i = 0; i < o.length; ++i) out[i] = String.fromCharCode(o[i]);\n\treturn out.join(\"\");\n}\n\nfunction write(cfb/*:CFBContainer*/, options/*:CFBWriteOpts*/)/*:RawBytes|string*/ {\n\tvar o = _write(cfb, options);\n\tswitch(options && options.type || \"buffer\") {\n\t\tcase \"file\": get_fs(); fs.writeFileSync(options.filename, (o/*:any*/)); return o;\n\t\tcase \"binary\": return typeof o == \"string\" ? o : a2s(o);\n\t\tcase \"base64\": return Base64_encode(typeof o == \"string\" ? o : a2s(o));\n\t\tcase \"buffer\": if(has_buf) return Buffer.isBuffer(o) ? o : Buffer_from(o);\n\t\t\t/* falls through */\n\t\tcase \"array\": return typeof o == \"string\" ? s2a(o) : o;\n\t}\n\treturn o;\n}\n/* node < 8.1 zlib does not expose bytesRead, so default to pure JS */\nvar _zlib;\nfunction use_zlib(zlib) { try {\n\tvar InflateRaw = zlib.InflateRaw;\n\tvar InflRaw = new InflateRaw();\n\tInflRaw._processChunk(new Uint8Array([3, 0]), InflRaw._finishFlushFlag);\n\tif(InflRaw.bytesRead) _zlib = zlib;\n\telse throw new Error(\"zlib does not expose bytesRead\");\n} catch(e) {console.error(\"cannot use native zlib: \" + (e.message || e)); } }\n\nfunction _inflateRawSync(payload, usz) {\n\tif(!_zlib) return _inflate(payload, usz);\n\tvar InflateRaw = _zlib.InflateRaw;\n\tvar InflRaw = new InflateRaw();\n\tvar out = InflRaw._processChunk(payload.slice(payload.l), InflRaw._finishFlushFlag);\n\tpayload.l += InflRaw.bytesRead;\n\treturn out;\n}\n\nfunction _deflateRawSync(payload) {\n\treturn _zlib ? _zlib.deflateRawSync(payload) : _deflate(payload);\n}\nvar CLEN_ORDER = [ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ];\n\n/* LEN_ID = [ 257, 258, 259, 260, 261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 280, 281, 282, 283, 284, 285 ]; */\nvar LEN_LN = [ 3, 4, 5, 6, 7, 8, 9, 10, 11, 13 , 15, 17, 19, 23, 27, 31, 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258 ];\n\n/* DST_ID = [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29 ]; */\nvar DST_LN = [ 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577 ];\n\nfunction bit_swap_8(n) { var t = (((((n<<1)|(n<<11)) & 0x22110) | (((n<<5)|(n<<15)) & 0x88440))); return ((t>>16) | (t>>8) |t)&0xFF; }\n\nvar use_typed_arrays = typeof Uint8Array !== 'undefined';\n\nvar bitswap8 = use_typed_arrays ? new Uint8Array(1<<8) : [];\nfor(var q = 0; q < (1<<8); ++q) bitswap8[q] = bit_swap_8(q);\n\nfunction bit_swap_n(n, b) {\n\tvar rev = bitswap8[n & 0xFF];\n\tif(b <= 8) return rev >>> (8-b);\n\trev = (rev << 8) | bitswap8[(n>>8)&0xFF];\n\tif(b <= 16) return rev >>> (16-b);\n\trev = (rev << 8) | bitswap8[(n>>16)&0xFF];\n\treturn rev >>> (24-b);\n}\n\n/* helpers for unaligned bit reads */\nfunction read_bits_2(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 6 ? 0 : buf[h+1]<<8))>>>w)& 0x03; }\nfunction read_bits_3(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 5 ? 0 : buf[h+1]<<8))>>>w)& 0x07; }\nfunction read_bits_4(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 4 ? 0 : buf[h+1]<<8))>>>w)& 0x0F; }\nfunction read_bits_5(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 3 ? 0 : buf[h+1]<<8))>>>w)& 0x1F; }\nfunction read_bits_7(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 1 ? 0 : buf[h+1]<<8))>>>w)& 0x7F; }\n\n/* works up to n = 3 * 8 + 1 = 25 */\nfunction read_bits_n(buf, bl, n) {\n\tvar w = (bl&7), h = (bl>>>3), f = ((1<<n)-1);\n\tvar v = buf[h] >>> w;\n\tif(n < 8 - w) return v & f;\n\tv |= buf[h+1]<<(8-w);\n\tif(n < 16 - w) return v & f;\n\tv |= buf[h+2]<<(16-w);\n\tif(n < 24 - w) return v & f;\n\tv |= buf[h+3]<<(24-w);\n\treturn v & f;\n}\n\n/* helpers for unaligned bit writes */\nfunction write_bits_3(buf, bl, v) { var w = bl & 7, h = bl >>> 3;\n\tif(w <= 5) buf[h] |= (v & 7) << w;\n\telse {\n\t\tbuf[h] |= (v << w) & 0xFF;\n\t\tbuf[h+1] = (v&7) >> (8-w);\n\t}\n\treturn bl + 3;\n}\n\nfunction write_bits_1(buf, bl, v) {\n\tvar w = bl & 7, h = bl >>> 3;\n\tv = (v&1) << w;\n\tbuf[h] |= v;\n\treturn bl + 1;\n}\nfunction write_bits_8(buf, bl, v) {\n\tvar w = bl & 7, h = bl >>> 3;\n\tv <<= w;\n\tbuf[h] |= v & 0xFF; v >>>= 8;\n\tbuf[h+1] = v;\n\treturn bl + 8;\n}\nfunction write_bits_16(buf, bl, v) {\n\tvar w = bl & 7, h = bl >>> 3;\n\tv <<= w;\n\tbuf[h] |= v & 0xFF; v >>>= 8;\n\tbuf[h+1] = v & 0xFF;\n\tbuf[h+2] = v >>> 8;\n\treturn bl + 16;\n}\n\n/* until ArrayBuffer#realloc is a thing, fake a realloc */\nfunction realloc(b, sz/*:number*/) {\n\tvar L = b.length, M = 2*L > sz ? 2*L : sz + 5, i = 0;\n\tif(L >= sz) return b;\n\tif(has_buf) {\n\t\tvar o = new_unsafe_buf(M);\n\t\t// $FlowIgnore\n\t\tif(b.copy) b.copy(o);\n\t\telse for(; i < b.length; ++i) o[i] = b[i];\n\t\treturn o;\n\t} else if(use_typed_arrays) {\n\t\tvar a = new Uint8Array(M);\n\t\tif(a.set) a.set(b);\n\t\telse for(; i < L; ++i) a[i] = b[i];\n\t\treturn a;\n\t}\n\tb.length = M;\n\treturn b;\n}\n\n/* zero-filled arrays for older browsers */\nfunction zero_fill_array(n) {\n\tvar o = new Array(n);\n\tfor(var i = 0; i < n; ++i) o[i] = 0;\n\treturn o;\n}\n\n/* build tree (used for literals and lengths) */\nfunction build_tree(clens, cmap, MAX/*:number*/)/*:number*/ {\n\tvar maxlen = 1, w = 0, i = 0, j = 0, ccode = 0, L = clens.length;\n\n\tvar bl_count = use_typed_arrays ? new Uint16Array(32) : zero_fill_array(32);\n\tfor(i = 0; i < 32; ++i) bl_count[i] = 0;\n\n\tfor(i = L; i < MAX; ++i) clens[i] = 0;\n\tL = clens.length;\n\n\tvar ctree = use_typed_arrays ? new Uint16Array(L) : zero_fill_array(L); // []\n\n\t/* build code tree */\n\tfor(i = 0; i < L; ++i) {\n\t\tbl_count[(w = clens[i])]++;\n\t\tif(maxlen < w) maxlen = w;\n\t\tctree[i] = 0;\n\t}\n\tbl_count[0] = 0;\n\tfor(i = 1; i <= maxlen; ++i) bl_count[i+16] = (ccode = (ccode + bl_count[i-1])<<1);\n\tfor(i = 0; i < L; ++i) {\n\t\tccode = clens[i];\n\t\tif(ccode != 0) ctree[i] = bl_count[ccode+16]++;\n\t}\n\n\t/* cmap[maxlen + 4 bits] = (off&15) + (lit<<4) reverse mapping */\n\tvar cleni = 0;\n\tfor(i = 0; i < L; ++i) {\n\t\tcleni = clens[i];\n\t\tif(cleni != 0) {\n\t\t\tccode = bit_swap_n(ctree[i], maxlen)>>(maxlen-cleni);\n\t\t\tfor(j = (1<<(maxlen + 4 - cleni)) - 1; j>=0; --j)\n\t\t\t\tcmap[ccode|(j<<cleni)] = (cleni&15) | (i<<4);\n\t\t}\n\t}\n\treturn maxlen;\n}\n\n/* Fixed Huffman */\nvar fix_lmap = use_typed_arrays ? new Uint16Array(512) : zero_fill_array(512);\nvar fix_dmap = use_typed_arrays ? new Uint16Array(32) : zero_fill_array(32);\nif(!use_typed_arrays) {\n\tfor(var i = 0; i < 512; ++i) fix_lmap[i] = 0;\n\tfor(i = 0; i < 32; ++i) fix_dmap[i] = 0;\n}\n(function() {\n\tvar dlens/*:Array<number>*/ = [];\n\tvar i = 0;\n\tfor(;i<32; i++) dlens.push(5);\n\tbuild_tree(dlens, fix_dmap, 32);\n\n\tvar clens/*:Array<number>*/ = [];\n\ti = 0;\n\tfor(; i<=143; i++) clens.push(8);\n\tfor(; i<=255; i++) clens.push(9);\n\tfor(; i<=279; i++) clens.push(7);\n\tfor(; i<=287; i++) clens.push(8);\n\tbuild_tree(clens, fix_lmap, 288);\n})();var _deflateRaw = /*#__PURE__*/(function _deflateRawIIFE() {\n\tvar DST_LN_RE = use_typed_arrays ? new Uint8Array(0x8000) : [];\n\tvar j = 0, k = 0;\n\tfor(; j < DST_LN.length - 1; ++j) {\n\t\tfor(; k < DST_LN[j+1]; ++k) DST_LN_RE[k] = j;\n\t}\n\tfor(;k < 32768; ++k) DST_LN_RE[k] = 29;\n\n\tvar LEN_LN_RE = use_typed_arrays ? new Uint8Array(0x103) : [];\n\tfor(j = 0, k = 0; j < LEN_LN.length - 1; ++j) {\n\t\tfor(; k < LEN_LN[j+1]; ++k) LEN_LN_RE[k] = j;\n\t}\n\n\tfunction write_stored(data, out) {\n\t\tvar boff = 0;\n\t\twhile(boff < data.length) {\n\t\t\tvar L = Math.min(0xFFFF, data.length - boff);\n\t\t\tvar h = boff + L == data.length;\n\t\t\tout.write_shift(1, +h);\n\t\t\tout.write_shift(2, L);\n\t\t\tout.write_shift(2, (~L) & 0xFFFF);\n\t\t\twhile(L-- > 0) out[out.l++] = data[boff++];\n\t\t}\n\t\treturn out.l;\n\t}\n\n\t/* Fixed Huffman */\n\tfunction write_huff_fixed(data, out) {\n\t\tvar bl = 0;\n\t\tvar boff = 0;\n\t\tvar addrs = use_typed_arrays ? new Uint16Array(0x8000) : [];\n\t\twhile(boff < data.length) {\n\t\t\tvar L = /* data.length - boff; */ Math.min(0xFFFF, data.length - boff);\n\n\t\t\t/* write a stored block for short data */\n\t\t\tif(L < 10) {\n\t\t\t\tbl = write_bits_3(out, bl, +!!(boff + L == data.length)); // jshint ignore:line\n\t\t\t\tif(bl & 7) bl += 8 - (bl & 7);\n\t\t\t\tout.l = (bl / 8) | 0;\n\t\t\t\tout.write_shift(2, L);\n\t\t\t\tout.write_shift(2, (~L) & 0xFFFF);\n\t\t\t\twhile(L-- > 0) out[out.l++] = data[boff++];\n\t\t\t\tbl = out.l * 8;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tbl = write_bits_3(out, bl, +!!(boff + L == data.length) + 2); // jshint ignore:line\n\t\t\tvar hash = 0;\n\t\t\twhile(L-- > 0) {\n\t\t\t\tvar d = data[boff];\n\t\t\t\thash = ((hash << 5) ^ d) & 0x7FFF;\n\n\t\t\t\tvar match = -1, mlen = 0;\n\n\t\t\t\tif((match = addrs[hash])) {\n\t\t\t\t\tmatch |= boff & ~0x7FFF;\n\t\t\t\t\tif(match > boff) match -= 0x8000;\n\t\t\t\t\tif(match < boff) while(data[match + mlen] == data[boff + mlen] && mlen < 250) ++mlen;\n\t\t\t\t}\n\n\t\t\t\tif(mlen > 2) {\n\t\t\t\t\t/* Copy Token */\n\t\t\t\t\td = LEN_LN_RE[mlen];\n\t\t\t\t\tif(d <= 22) bl = write_bits_8(out, bl, bitswap8[d+1]>>1) - 1;\n\t\t\t\t\telse {\n\t\t\t\t\t\twrite_bits_8(out, bl, 3);\n\t\t\t\t\t\tbl += 5;\n\t\t\t\t\t\twrite_bits_8(out, bl, bitswap8[d-23]>>5);\n\t\t\t\t\t\tbl += 3;\n\t\t\t\t\t}\n\t\t\t\t\tvar len_eb = (d < 8) ? 0 : ((d - 4)>>2);\n\t\t\t\t\tif(len_eb > 0) {\n\t\t\t\t\t\twrite_bits_16(out, bl, mlen - LEN_LN[d]);\n\t\t\t\t\t\tbl += len_eb;\n\t\t\t\t\t}\n\n\t\t\t\t\td = DST_LN_RE[boff - match];\n\t\t\t\t\tbl = write_bits_8(out, bl, bitswap8[d]>>3);\n\t\t\t\t\tbl -= 3;\n\n\t\t\t\t\tvar dst_eb = d < 4 ? 0 : (d-2)>>1;\n\t\t\t\t\tif(dst_eb > 0) {\n\t\t\t\t\t\twrite_bits_16(out, bl, boff - match - DST_LN[d]);\n\t\t\t\t\t\tbl += dst_eb;\n\t\t\t\t\t}\n\t\t\t\t\tfor(var q = 0; q < mlen; ++q) {\n\t\t\t\t\t\taddrs[hash] = boff & 0x7FFF;\n\t\t\t\t\t\thash = ((hash << 5) ^ data[boff]) & 0x7FFF;\n\t\t\t\t\t\t++boff;\n\t\t\t\t\t}\n\t\t\t\t\tL-= mlen - 1;\n\t\t\t\t} else {\n\t\t\t\t\t/* Literal Token */\n\t\t\t\t\tif(d <= 143) d = d + 48;\n\t\t\t\t\telse bl = write_bits_1(out, bl, 1);\n\t\t\t\t\tbl = write_bits_8(out, bl, bitswap8[d]);\n\t\t\t\t\taddrs[hash] = boff & 0x7FFF;\n\t\t\t\t\t++boff;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tbl = write_bits_8(out, bl, 0) - 1;\n\t\t}\n\t\tout.l = ((bl + 7)/8)|0;\n\t\treturn out.l;\n\t}\n\treturn function _deflateRaw(data, out) {\n\t\tif(data.length < 8) return write_stored(data, out);\n\t\treturn write_huff_fixed(data, out);\n\t};\n})();\n\nfunction _deflate(data) {\n\tvar buf = new_buf(50+Math.floor(data.length*1.1));\n\tvar off = _deflateRaw(data, buf);\n\treturn buf.slice(0, off);\n}\n/* modified inflate function also moves original read head */\n\nvar dyn_lmap = use_typed_arrays ? new Uint16Array(32768) : zero_fill_array(32768);\nvar dyn_dmap = use_typed_arrays ? new Uint16Array(32768) : zero_fill_array(32768);\nvar dyn_cmap = use_typed_arrays ? new Uint16Array(128) : zero_fill_array(128);\nvar dyn_len_1 = 1, dyn_len_2 = 1;\n\n/* 5.5.3 Expanding Huffman Codes */\nfunction dyn(data, boff/*:number*/) {\n\t/* nomenclature from RFC1951 refers to bit values; these are offset by the implicit constant */\n\tvar _HLIT = read_bits_5(data, boff) + 257; boff += 5;\n\tvar _HDIST = read_bits_5(data, boff) + 1; boff += 5;\n\tvar _HCLEN = read_bits_4(data, boff) + 4; boff += 4;\n\tvar w = 0;\n\n\t/* grab and store code lengths */\n\tvar clens = use_typed_arrays ? new Uint8Array(19) : zero_fill_array(19);\n\tvar ctree = [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 ];\n\tvar maxlen = 1;\n\tvar bl_count = use_typed_arrays ? new Uint8Array(8) : zero_fill_array(8);\n\tvar next_code = use_typed_arrays ? new Uint8Array(8) : zero_fill_array(8);\n\tvar L = clens.length; /* 19 */\n\tfor(var i = 0; i < _HCLEN; ++i) {\n\t\tclens[CLEN_ORDER[i]] = w = read_bits_3(data, boff);\n\t\tif(maxlen < w) maxlen = w;\n\t\tbl_count[w]++;\n\t\tboff += 3;\n\t}\n\n\t/* build code tree */\n\tvar ccode = 0;\n\tbl_count[0] = 0;\n\tfor(i = 1; i <= maxlen; ++i) next_code[i] = ccode = (ccode + bl_count[i-1])<<1;\n\tfor(i = 0; i < L; ++i) if((ccode = clens[i]) != 0) ctree[i] = next_code[ccode]++;\n\t/* cmap[7 bits from stream] = (off&7) + (lit<<3) */\n\tvar cleni = 0;\n\tfor(i = 0; i < L; ++i) {\n\t\tcleni = clens[i];\n\t\tif(cleni != 0) {\n\t\t\tccode = bitswap8[ctree[i]]>>(8-cleni);\n\t\t\tfor(var j = (1<<(7-cleni))-1; j>=0; --j) dyn_cmap[ccode|(j<<cleni)] = (cleni&7) | (i<<3);\n\t\t}\n\t}\n\n\t/* read literal and dist codes at once */\n\tvar hcodes/*:Array<number>*/ = [];\n\tmaxlen = 1;\n\tfor(; hcodes.length < _HLIT + _HDIST;) {\n\t\tccode = dyn_cmap[read_bits_7(data, boff)];\n\t\tboff += ccode & 7;\n\t\tswitch((ccode >>>= 3)) {\n\t\t\tcase 16:\n\t\t\t\tw = 3 + read_bits_2(data, boff); boff += 2;\n\t\t\t\tccode = hcodes[hcodes.length - 1];\n\t\t\t\twhile(w-- > 0) hcodes.push(ccode);\n\t\t\t\tbreak;\n\t\t\tcase 17:\n\t\t\t\tw = 3 + read_bits_3(data, boff); boff += 3;\n\t\t\t\twhile(w-- > 0) hcodes.push(0);\n\t\t\t\tbreak;\n\t\t\tcase 18:\n\t\t\t\tw = 11 + read_bits_7(data, boff); boff += 7;\n\t\t\t\twhile(w -- > 0) hcodes.push(0);\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\thcodes.push(ccode);\n\t\t\t\tif(maxlen < ccode) maxlen = ccode;\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\t/* build literal / length trees */\n\tvar h1 = hcodes.slice(0, _HLIT), h2 = hcodes.slice(_HLIT);\n\tfor(i = _HLIT; i < 286; ++i) h1[i] = 0;\n\tfor(i = _HDIST; i < 30; ++i) h2[i] = 0;\n\tdyn_len_1 = build_tree(h1, dyn_lmap, 286);\n\tdyn_len_2 = build_tree(h2, dyn_dmap, 30);\n\treturn boff;\n}\n\n/* return [ data, bytesRead ] */\nfunction inflate(data, usz/*:number*/) {\n\t/* shortcircuit for empty buffer [0x03, 0x00] */\n\tif(data[0] == 3 && !(data[1] & 0x3)) { return [new_raw_buf(usz), 2]; }\n\n\t/* bit offset */\n\tvar boff = 0;\n\n\t/* header includes final bit and type bits */\n\tvar header = 0;\n\n\tvar outbuf = new_unsafe_buf(usz ? usz : (1<<18));\n\tvar woff = 0;\n\tvar OL = outbuf.length>>>0;\n\tvar max_len_1 = 0, max_len_2 = 0;\n\n\twhile((header&1) == 0) {\n\t\theader = read_bits_3(data, boff); boff += 3;\n\t\tif((header >>> 1) == 0) {\n\t\t\t/* Stored block */\n\t\t\tif(boff & 7) boff += 8 - (boff&7);\n\t\t\t/* 2 bytes sz, 2 bytes bit inverse */\n\t\t\tvar sz = data[boff>>>3] | data[(boff>>>3)+1]<<8;\n\t\t\tboff += 32;\n\t\t\t/* push sz bytes */\n\t\t\tif(sz > 0) {\n\t\t\t\tif(!usz && OL < woff + sz) { outbuf = realloc(outbuf, woff + sz); OL = outbuf.length; }\n\t\t\t\twhile(sz-- > 0) { outbuf[woff++] = data[boff>>>3]; boff += 8; }\n\t\t\t}\n\t\t\tcontinue;\n\t\t} else if((header >> 1) == 1) {\n\t\t\t/* Fixed Huffman */\n\t\t\tmax_len_1 = 9; max_len_2 = 5;\n\t\t} else {\n\t\t\t/* Dynamic Huffman */\n\t\t\tboff = dyn(data, boff);\n\t\t\tmax_len_1 = dyn_len_1; max_len_2 = dyn_len_2;\n\t\t}\n\t\tfor(;;) { // while(true) is apparently out of vogue in modern JS circles\n\t\t\tif(!usz && (OL < woff + 32767)) { outbuf = realloc(outbuf, woff + 32767); OL = outbuf.length; }\n\t\t\t/* ingest code and move read head */\n\t\t\tvar bits = read_bits_n(data, boff, max_len_1);\n\t\t\tvar code = (header>>>1) == 1 ? fix_lmap[bits] : dyn_lmap[bits];\n\t\t\tboff += code & 15; code >>>= 4;\n\t\t\t/* 0-255 are literals, 256 is end of block token, 257+ are copy tokens */\n\t\t\tif(((code>>>8)&0xFF) === 0) outbuf[woff++] = code;\n\t\t\telse if(code == 256) break;\n\t\t\telse {\n\t\t\t\tcode -= 257;\n\t\t\t\tvar len_eb = (code < 8) ? 0 : ((code-4)>>2); if(len_eb > 5) len_eb = 0;\n\t\t\t\tvar tgt = woff + LEN_LN[code];\n\t\t\t\t/* length extra bits */\n\t\t\t\tif(len_eb > 0) {\n\t\t\t\t\ttgt += read_bits_n(data, boff, len_eb);\n\t\t\t\t\tboff += len_eb;\n\t\t\t\t}\n\n\t\t\t\t/* dist code */\n\t\t\t\tbits = read_bits_n(data, boff, max_len_2);\n\t\t\t\tcode = (header>>>1) == 1 ? fix_dmap[bits] : dyn_dmap[bits];\n\t\t\t\tboff += code & 15; code >>>= 4;\n\t\t\t\tvar dst_eb = (code < 4 ? 0 : (code-2)>>1);\n\t\t\t\tvar dst = DST_LN[code];\n\t\t\t\t/* dist extra bits */\n\t\t\t\tif(dst_eb > 0) {\n\t\t\t\t\tdst += read_bits_n(data, boff, dst_eb);\n\t\t\t\t\tboff += dst_eb;\n\t\t\t\t}\n\n\t\t\t\t/* in the common case, manual byte copy is faster than TA set / Buffer copy */\n\t\t\t\tif(!usz && OL < tgt) { outbuf = realloc(outbuf, tgt + 100); OL = outbuf.length; }\n\t\t\t\twhile(woff < tgt) { outbuf[woff] = outbuf[woff - dst]; ++woff; }\n\t\t\t}\n\t\t}\n\t}\n\tif(usz) return [outbuf, (boff+7)>>>3];\n\treturn [outbuf.slice(0, woff), (boff+7)>>>3];\n}\n\nfunction _inflate(payload, usz) {\n\tvar data = payload.slice(payload.l||0);\n\tvar out = inflate(data, usz);\n\tpayload.l += out[1];\n\treturn out[0];\n}\n\nfunction warn_or_throw(wrn, msg) {\n\tif(wrn) { if(typeof console !== 'undefined') console.error(msg); }\n\telse throw new Error(msg);\n}\n\nfunction parse_zip(file/*:RawBytes*/, options/*:CFBReadOpts*/)/*:CFBContainer*/ {\n\tvar blob/*:CFBlob*/ = /*::(*/file/*:: :any)*/;\n\tprep_blob(blob, 0);\n\n\tvar FileIndex/*:CFBFileIndex*/ = [], FullPaths/*:Array<string>*/ = [];\n\tvar o = {\n\t\tFileIndex: FileIndex,\n\t\tFullPaths: FullPaths\n\t};\n\tinit_cfb(o, { root: options.root });\n\n\t/* find end of central directory, start just after signature */\n\tvar i = blob.length - 4;\n\twhile((blob[i] != 0x50 || blob[i+1] != 0x4b || blob[i+2] != 0x05 || blob[i+3] != 0x06) && i >= 0) --i;\n\tblob.l = i + 4;\n\n\t/* parse end of central directory */\n\tblob.l += 4;\n\tvar fcnt = blob.read_shift(2);\n\tblob.l += 6;\n\tvar start_cd = blob.read_shift(4);\n\n\t/* parse central directory */\n\tblob.l = start_cd;\n\n\tfor(i = 0; i < fcnt; ++i) {\n\t\t/* trust local file header instead of CD entry */\n\t\tblob.l += 20;\n\t\tvar csz = blob.read_shift(4);\n\t\tvar usz = blob.read_shift(4);\n\t\tvar namelen = blob.read_shift(2);\n\t\tvar efsz = blob.read_shift(2);\n\t\tvar fcsz = blob.read_shift(2);\n\t\tblob.l += 8;\n\t\tvar offset = blob.read_shift(4);\n\t\tvar EF = parse_extra_field(/*::(*/blob.slice(blob.l+namelen, blob.l+namelen+efsz)/*:: :any)*/);\n\t\tblob.l += namelen + efsz + fcsz;\n\n\t\tvar L = blob.l;\n\t\tblob.l = offset + 4;\n\t\tparse_local_file(blob, csz, usz, o, EF);\n\t\tblob.l = L;\n\t}\n\treturn o;\n}\n\n\n/* head starts just after local file header signature */\nfunction parse_local_file(blob/*:CFBlob*/, csz/*:number*/, usz/*:number*/, o/*:CFBContainer*/, EF) {\n\t/* [local file header] */\n\tblob.l += 2;\n\tvar flags = blob.read_shift(2);\n\tvar meth = blob.read_shift(2);\n\tvar date = parse_dos_date(blob);\n\n\tif(flags & 0x2041) throw new Error(\"Unsupported ZIP encryption\");\n\tvar crc32 = blob.read_shift(4);\n\tvar _csz = blob.read_shift(4);\n\tvar _usz = blob.read_shift(4);\n\n\tvar namelen = blob.read_shift(2);\n\tvar efsz = blob.read_shift(2);\n\n\t// TODO: flags & (1<<11) // UTF8\n\tvar name = \"\"; for(var i = 0; i < namelen; ++i) name += String.fromCharCode(blob[blob.l++]);\n\tif(efsz) {\n\t\tvar ef = parse_extra_field(/*::(*/blob.slice(blob.l, blob.l + efsz)/*:: :any)*/);\n\t\tif((ef[0x5455]||{}).mt) date = ef[0x5455].mt;\n\t\tif(((EF||{})[0x5455]||{}).mt) date = EF[0x5455].mt;\n\t}\n\tblob.l += efsz;\n\n\t/* [encryption header] */\n\n\t/* [file data] */\n\tvar data = blob.slice(blob.l, blob.l + _csz);\n\tswitch(meth) {\n\t\tcase 8: data = _inflateRawSync(blob, _usz); break;\n\t\tcase 0: break; // TODO: scan for magic number\n\t\tdefault: throw new Error(\"Unsupported ZIP Compression method \" + meth);\n\t}\n\n\t/* [data descriptor] */\n\tvar wrn = false;\n\tif(flags & 8) {\n\t\tcrc32 = blob.read_shift(4);\n\t\tif(crc32 == 0x08074b50) { crc32 = blob.read_shift(4); wrn = true; }\n\t\t_csz = blob.read_shift(4);\n\t\t_usz = blob.read_shift(4);\n\t}\n\n\tif(_csz != csz) warn_or_throw(wrn, \"Bad compressed size: \" + csz + \" != \" + _csz);\n\tif(_usz != usz) warn_or_throw(wrn, \"Bad uncompressed size: \" + usz + \" != \" + _usz);\n\t//var _crc32 = CRC32.buf(data, 0);\n\t//if((crc32>>0) != (_crc32>>0)) warn_or_throw(wrn, \"Bad CRC32 checksum: \" + crc32 + \" != \" + _crc32);\n\tcfb_add(o, name, data, {unsafe: true, mt: date});\n}\nfunction write_zip(cfb/*:CFBContainer*/, options/*:CFBWriteOpts*/)/*:RawBytes*/ {\n\tvar _opts = options || {};\n\tvar out = [], cdirs = [];\n\tvar o/*:CFBlob*/ = new_buf(1);\n\tvar method = (_opts.compression ? 8 : 0), flags = 0;\n\tvar desc = false;\n\tif(desc) flags |= 8;\n\tvar i = 0, j = 0;\n\n\tvar start_cd = 0, fcnt = 0;\n\tvar root = cfb.FullPaths[0], fp = root, fi = cfb.FileIndex[0];\n\tvar crcs = [];\n\tvar sz_cd = 0;\n\n\tfor(i = 1; i < cfb.FullPaths.length; ++i) {\n\t\tfp = cfb.FullPaths[i].slice(root.length); fi = cfb.FileIndex[i];\n\t\tif(!fi.size || !fi.content || fp == \"\\u0001Sh33tJ5\") continue;\n\t\tvar start = start_cd;\n\n\t\t/* TODO: CP437 filename */\n\t\tvar namebuf = new_buf(fp.length);\n\t\tfor(j = 0; j < fp.length; ++j) namebuf.write_shift(1, fp.charCodeAt(j) & 0x7F);\n\t\tnamebuf = namebuf.slice(0, namebuf.l);\n\t\tcrcs[fcnt] = CRC32.buf(/*::((*/fi.content/*::||[]):any)*/, 0);\n\n\t\tvar outbuf = fi.content/*::||[]*/;\n\t\tif(method == 8) outbuf = _deflateRawSync(outbuf);\n\n\t\t/* local file header */\n\t\to = new_buf(30);\n\t\to.write_shift(4, 0x04034b50);\n\t\to.write_shift(2, 20);\n\t\to.write_shift(2, flags);\n\t\to.write_shift(2, method);\n\t\t/* TODO: last mod file time/date */\n\t\tif(fi.mt) write_dos_date(o, fi.mt);\n\t\telse o.write_shift(4, 0);\n\t\to.write_shift(-4, (flags & 8) ? 0 : crcs[fcnt]);\n\t\to.write_shift(4, (flags & 8) ? 0 : outbuf.length);\n\t\to.write_shift(4, (flags & 8) ? 0 : /*::(*/fi.content/*::||[])*/.length);\n\t\to.write_shift(2, namebuf.length);\n\t\to.write_shift(2, 0);\n\n\t\tstart_cd += o.length;\n\t\tout.push(o);\n\t\tstart_cd += namebuf.length;\n\t\tout.push(namebuf);\n\n\t\t/* TODO: extra fields? */\n\n\t\t/* TODO: encryption header ? */\n\n\t\tstart_cd += outbuf.length;\n\t\tout.push(outbuf);\n\n\t\t/* data descriptor */\n\t\tif(flags & 8) {\n\t\t\to = new_buf(12);\n\t\t\to.write_shift(-4, crcs[fcnt]);\n\t\t\to.write_shift(4, outbuf.length);\n\t\t\to.write_shift(4, /*::(*/fi.content/*::||[])*/.length);\n\t\t\tstart_cd += o.l;\n\t\t\tout.push(o);\n\t\t}\n\n\t\t/* central directory */\n\t\to = new_buf(46);\n\t\to.write_shift(4, 0x02014b50);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 20);\n\t\to.write_shift(2, flags);\n\t\to.write_shift(2, method);\n\t\to.write_shift(4, 0); /* TODO: last mod file time/date */\n\t\to.write_shift(-4, crcs[fcnt]);\n\n\t\to.write_shift(4, outbuf.length);\n\t\to.write_shift(4, /*::(*/fi.content/*::||[])*/.length);\n\t\to.write_shift(2, namebuf.length);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(4, 0);\n\t\to.write_shift(4, start);\n\n\t\tsz_cd += o.l;\n\t\tcdirs.push(o);\n\t\tsz_cd += namebuf.length;\n\t\tcdirs.push(namebuf);\n\t\t++fcnt;\n\t}\n\n\t/* end of central directory */\n\to = new_buf(22);\n\to.write_shift(4, 0x06054b50);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, fcnt);\n\to.write_shift(2, fcnt);\n\to.write_shift(4, sz_cd);\n\to.write_shift(4, start_cd);\n\to.write_shift(2, 0);\n\n\treturn bconcat(([bconcat((out/*:any*/)), bconcat(cdirs), o]/*:any*/));\n}\nvar ContentTypeMap = ({\n\t\"htm\": \"text/html\",\n\t\"xml\": \"text/xml\",\n\n\t\"gif\": \"image/gif\",\n\t\"jpg\": \"image/jpeg\",\n\t\"png\": \"image/png\",\n\n\t\"mso\": \"application/x-mso\",\n\t\"thmx\": \"application/vnd.ms-officetheme\",\n\t\"sh33tj5\": \"application/octet-stream\"\n}/*:any*/);\n\nfunction get_content_type(fi/*:CFBEntry*/, fp/*:string*/)/*:string*/ {\n\tif(fi.ctype) return fi.ctype;\n\n\tvar ext = fi.name || \"\", m = ext.match(/\\.([^\\.]+)$/);\n\tif(m && ContentTypeMap[m[1]]) return ContentTypeMap[m[1]];\n\n\tif(fp) {\n\t\tm = (ext = fp).match(/[\\.\\\\]([^\\.\\\\])+$/);\n\t\tif(m && ContentTypeMap[m[1]]) return ContentTypeMap[m[1]];\n\t}\n\n\treturn \"application/octet-stream\";\n}\n\n/* 76 character chunks TODO: intertwine encoding */\nfunction write_base64_76(bstr/*:string*/)/*:string*/ {\n\tvar data = Base64_encode(bstr);\n\tvar o = [];\n\tfor(var i = 0; i < data.length; i+= 76) o.push(data.slice(i, i+76));\n\treturn o.join(\"\\r\\n\") + \"\\r\\n\";\n}\n\n/*\nRules for QP:\n\t- escape =## applies for all non-display characters and literal \"=\"\n\t- space or tab at end of line must be encoded\n\t- \\r\\n newlines can be preserved, but bare \\r and \\n must be escaped\n\t- lines must not exceed 76 characters, use soft breaks =\\r\\n\n\nTODO: Some files from word appear to write line extensions with bare equals:\n\n```\n<table class=3DMsoTableGrid border=3D1 cellspacing=3D0 cellpadding=3D0 width=\n=\"70%\"\n```\n*/\nfunction write_quoted_printable(text/*:string*/)/*:string*/ {\n\tvar encoded = text.replace(/[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F\\x7E-\\xFF=]/g, function(c) {\n\t\tvar w = c.charCodeAt(0).toString(16).toUpperCase();\n\t\treturn \"=\" + (w.length == 1 ? \"0\" + w : w);\n\t});\n\n\tencoded = encoded.replace(/ $/mg, \"=20\").replace(/\\t$/mg, \"=09\");\n\n\tif(encoded.charAt(0) == \"\\n\") encoded = \"=0D\" + encoded.slice(1);\n\tencoded = encoded.replace(/\\r(?!\\n)/mg, \"=0D\").replace(/\\n\\n/mg, \"\\n=0A\").replace(/([^\\r\\n])\\n/mg, \"$1=0A\");\n\n\tvar o/*:Array<string>*/ = [], split = encoded.split(\"\\r\\n\");\n\tfor(var si = 0; si < split.length; ++si) {\n\t\tvar str = split[si];\n\t\tif(str.length == 0) { o.push(\"\"); continue; }\n\t\tfor(var i = 0; i < str.length;) {\n\t\t\tvar end = 76;\n\t\t\tvar tmp = str.slice(i, i + end);\n\t\t\tif(tmp.charAt(end - 1) == \"=\") end --;\n\t\t\telse if(tmp.charAt(end - 2) == \"=\") end -= 2;\n\t\t\telse if(tmp.charAt(end - 3) == \"=\") end -= 3;\n\t\t\ttmp = str.slice(i, i + end);\n\t\t\ti += end;\n\t\t\tif(i < str.length) tmp += \"=\";\n\t\t\to.push(tmp);\n\t\t}\n\t}\n\n\treturn o.join(\"\\r\\n\");\n}\nfunction parse_quoted_printable(data/*:Array<string>*/)/*:RawBytes*/ {\n\tvar o = [];\n\n\t/* unify long lines */\n\tfor(var di = 0; di < data.length; ++di) {\n\t\tvar line = data[di];\n\t\twhile(di <= data.length && line.charAt(line.length - 1) == \"=\") line = line.slice(0, line.length - 1) + data[++di];\n\t\to.push(line);\n\t}\n\n\t/* decode */\n\tfor(var oi = 0; oi < o.length; ++oi) o[oi] = o[oi].replace(/[=][0-9A-Fa-f]{2}/g, function($$) { return String.fromCharCode(parseInt($$.slice(1), 16)); });\n\treturn s2a(o.join(\"\\r\\n\"));\n}\n\n\nfunction parse_mime(cfb/*:CFBContainer*/, data/*:Array<string>*/, root/*:string*/)/*:void*/ {\n\tvar fname = \"\", cte = \"\", ctype = \"\", fdata;\n\tvar di = 0;\n\tfor(;di < 10; ++di) {\n\t\tvar line = data[di];\n\t\tif(!line || line.match(/^\\s*$/)) break;\n\t\tvar m = line.match(/^(.*?):\\s*([^\\s].*)$/);\n\t\tif(m) switch(m[1].toLowerCase()) {\n\t\t\tcase \"content-location\": fname = m[2].trim(); break;\n\t\t\tcase \"content-type\": ctype = m[2].trim(); break;\n\t\t\tcase \"content-transfer-encoding\": cte = m[2].trim(); break;\n\t\t}\n\t}\n\t++di;\n\tswitch(cte.toLowerCase()) {\n\t\tcase 'base64': fdata = s2a(Base64_decode(data.slice(di).join(\"\"))); break;\n\t\tcase 'quoted-printable': fdata = parse_quoted_printable(data.slice(di)); break;\n\t\tdefault: throw new Error(\"Unsupported Content-Transfer-Encoding \" + cte);\n\t}\n\tvar file = cfb_add(cfb, fname.slice(root.length), fdata, {unsafe: true});\n\tif(ctype) file.ctype = ctype;\n}\n\nfunction parse_mad(file/*:RawBytes*/, options/*:CFBReadOpts*/)/*:CFBContainer*/ {\n\tif(a2s(file.slice(0,13)).toLowerCase() != \"mime-version:\") throw new Error(\"Unsupported MAD header\");\n\tvar root = (options && options.root || \"\");\n\t// $FlowIgnore\n\tvar data = (has_buf && Buffer.isBuffer(file) ? file.toString(\"binary\") : a2s(file)).split(\"\\r\\n\");\n\tvar di = 0, row = \"\";\n\n\t/* if root is not specified, scan for the common prefix */\n\tfor(di = 0; di < data.length; ++di) {\n\t\trow = data[di];\n\t\tif(!/^Content-Location:/i.test(row)) continue;\n\t\trow = row.slice(row.indexOf(\"file\"));\n\t\tif(!root) root = row.slice(0, row.lastIndexOf(\"/\") + 1);\n\t\tif(row.slice(0, root.length) == root) continue;\n\t\twhile(root.length > 0) {\n\t\t\troot = root.slice(0, root.length - 1);\n\t\t\troot = root.slice(0, root.lastIndexOf(\"/\") + 1);\n\t\t\tif(row.slice(0,root.length) == root) break;\n\t\t}\n\t}\n\n\tvar mboundary = (data[1] || \"\").match(/boundary=\"(.*?)\"/);\n\tif(!mboundary) throw new Error(\"MAD cannot find boundary\");\n\tvar boundary = \"--\" + (mboundary[1] || \"\");\n\n\tvar FileIndex/*:CFBFileIndex*/ = [], FullPaths/*:Array<string>*/ = [];\n\tvar o = {\n\t\tFileIndex: FileIndex,\n\t\tFullPaths: FullPaths\n\t};\n\tinit_cfb(o);\n\tvar start_di, fcnt = 0;\n\tfor(di = 0; di < data.length; ++di) {\n\t\tvar line = data[di];\n\t\tif(line !== boundary && line !== boundary + \"--\") continue;\n\t\tif(fcnt++) parse_mime(o, data.slice(start_di, di), root);\n\t\tstart_di = di;\n\t}\n\treturn o;\n}\n\nfunction write_mad(cfb/*:CFBContainer*/, options/*:CFBWriteOpts*/)/*:string*/ {\n\tvar opts = options || {};\n\tvar boundary = opts.boundary || \"SheetJS\";\n\tboundary = '------=' + boundary;\n\n\tvar out = [\n\t\t'MIME-Version: 1.0',\n\t\t'Content-Type: multipart/related; boundary=\"' + boundary.slice(2) + '\"',\n\t\t'',\n\t\t'',\n\t\t''\n\t];\n\n\tvar root = cfb.FullPaths[0], fp = root, fi = cfb.FileIndex[0];\n\tfor(var i = 1; i < cfb.FullPaths.length; ++i) {\n\t\tfp = cfb.FullPaths[i].slice(root.length);\n\t\tfi = cfb.FileIndex[i];\n\t\tif(!fi.size || !fi.content || fp == \"\\u0001Sh33tJ5\") continue;\n\n\t\t/* Normalize filename */\n\t\tfp = fp.replace(/[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F\\x7E-\\xFF]/g, function(c) {\n\t\t\treturn \"_x\" + c.charCodeAt(0).toString(16) + \"_\";\n\t\t}).replace(/[\\u0080-\\uFFFF]/g, function(u) {\n\t\t\treturn \"_u\" + u.charCodeAt(0).toString(16) + \"_\";\n\t\t});\n\n\t\t/* Extract content as binary string */\n\t\tvar ca = fi.content;\n\t\t// $FlowIgnore\n\t\tvar cstr = has_buf && Buffer.isBuffer(ca) ? ca.toString(\"binary\") : a2s(ca);\n\n\t\t/* 4/5 of first 1024 chars ascii -> quoted printable, else base64 */\n\t\tvar dispcnt = 0, L = Math.min(1024, cstr.length), cc = 0;\n\t\tfor(var csl = 0; csl <= L; ++csl) if((cc=cstr.charCodeAt(csl)) >= 0x20 && cc < 0x80) ++dispcnt;\n\t\tvar qp = dispcnt >= L * 4 / 5;\n\n\t\tout.push(boundary);\n\t\tout.push('Content-Location: ' + (opts.root || 'file:///C:/SheetJS/') + fp);\n\t\tout.push('Content-Transfer-Encoding: ' + (qp ? 'quoted-printable' : 'base64'));\n\t\tout.push('Content-Type: ' + get_content_type(fi, fp));\n\t\tout.push('');\n\n\t\tout.push(qp ? write_quoted_printable(cstr) : write_base64_76(cstr));\n\t}\n\tout.push(boundary + '--\\r\\n');\n\treturn out.join(\"\\r\\n\");\n}\nfunction cfb_new(opts/*:?any*/)/*:CFBContainer*/ {\n\tvar o/*:CFBContainer*/ = ({}/*:any*/);\n\tinit_cfb(o, opts);\n\treturn o;\n}\n\nfunction cfb_add(cfb/*:CFBContainer*/, name/*:string*/, content/*:?RawBytes*/, opts/*:?any*/)/*:CFBEntry*/ {\n\tvar unsafe = opts && opts.unsafe;\n\tif(!unsafe) init_cfb(cfb);\n\tvar file = !unsafe && CFB.find(cfb, name);\n\tif(!file) {\n\t\tvar fpath/*:string*/ = cfb.FullPaths[0];\n\t\tif(name.slice(0, fpath.length) == fpath) fpath = name;\n\t\telse {\n\t\t\tif(fpath.slice(-1) != \"/\") fpath += \"/\";\n\t\t\tfpath = (fpath + name).replace(\"//\",\"/\");\n\t\t}\n\t\tfile = ({name: filename(name), type: 2}/*:any*/);\n\t\tcfb.FileIndex.push(file);\n\t\tcfb.FullPaths.push(fpath);\n\t\tif(!unsafe) CFB.utils.cfb_gc(cfb);\n\t}\n\t/*:: if(!file) throw new Error(\"unreachable\"); */\n\tfile.content = (content/*:any*/);\n\tfile.size = content ? content.length : 0;\n\tif(opts) {\n\t\tif(opts.CLSID) file.clsid = opts.CLSID;\n\t\tif(opts.mt) file.mt = opts.mt;\n\t\tif(opts.ct) file.ct = opts.ct;\n\t}\n\treturn file;\n}\n\nfunction cfb_del(cfb/*:CFBContainer*/, name/*:string*/)/*:boolean*/ {\n\tinit_cfb(cfb);\n\tvar file = CFB.find(cfb, name);\n\tif(file) for(var j = 0; j < cfb.FileIndex.length; ++j) if(cfb.FileIndex[j] == file) {\n\t\tcfb.FileIndex.splice(j, 1);\n\t\tcfb.FullPaths.splice(j, 1);\n\t\treturn true;\n\t}\n\treturn false;\n}\n\nfunction cfb_mov(cfb/*:CFBContainer*/, old_name/*:string*/, new_name/*:string*/)/*:boolean*/ {\n\tinit_cfb(cfb);\n\tvar file = CFB.find(cfb, old_name);\n\tif(file) for(var j = 0; j < cfb.FileIndex.length; ++j) if(cfb.FileIndex[j] == file) {\n\t\tcfb.FileIndex[j].name = filename(new_name);\n\t\tcfb.FullPaths[j] = new_name;\n\t\treturn true;\n\t}\n\treturn false;\n}\n\nfunction cfb_gc(cfb/*:CFBContainer*/)/*:void*/ { rebuild_cfb(cfb, true); }\n\nexports.find = find;\nexports.read = read;\nexports.parse = parse;\nexports.write = write;\nexports.writeFile = write_file;\nexports.utils = {\n\tcfb_new: cfb_new,\n\tcfb_add: cfb_add,\n\tcfb_del: cfb_del,\n\tcfb_mov: cfb_mov,\n\tcfb_gc: cfb_gc,\n\tReadShift: ReadShift,\n\tCheckField: CheckField,\n\tprep_blob: prep_blob,\n\tbconcat: bconcat,\n\tuse_zlib: use_zlib,\n\t_deflateRaw: _deflate,\n\t_inflateRaw: _inflate,\n\tconsts: consts\n};\n\nreturn exports;\n})();\n\nlet _fs = void 0;\nfunction set_fs(fs) { _fs = fs; }\nexport { set_fs };\n\n/* normalize data for blob ctor */\nfunction blobify(data) {\n\tif(typeof data === \"string\") return s2ab(data);\n\tif(Array.isArray(data)) return a2u(data);\n\treturn data;\n}\n/* write or download file */\nfunction write_dl(fname/*:string*/, payload/*:any*/, enc/*:?string*/) {\n\t/*global IE_SaveFile, Blob, navigator, saveAs, document, File, chrome */\n\tif(typeof _fs !== 'undefined' && _fs.writeFileSync) return enc ? _fs.writeFileSync(fname, payload, enc) : _fs.writeFileSync(fname, payload);\n\tif(typeof Deno !== 'undefined') {\n\t\t/* in this spot, it's safe to assume typed arrays and TextEncoder/TextDecoder exist */\n\t\tif(enc && typeof payload == \"string\") switch(enc) {\n\t\t\tcase \"utf8\": payload = new TextEncoder(enc).encode(payload); break;\n\t\t\tcase \"binary\": payload = s2ab(payload); break;\n\t\t\t/* TODO: binary equivalent */\n\t\t\tdefault: throw new Error(\"Unsupported encoding \" + enc);\n\t\t}\n\t\treturn Deno.writeFileSync(fname, payload);\n\t}\n\tvar data = (enc == \"utf8\") ? utf8write(payload) : payload;\n\t/*:: declare var IE_SaveFile: any; */\n\tif(typeof IE_SaveFile !== 'undefined') return IE_SaveFile(data, fname);\n\tif(typeof Blob !== 'undefined') {\n\t\tvar blob = new Blob([blobify(data)], {type:\"application/octet-stream\"});\n\t\t/*:: declare var navigator: any; */\n\t\tif(typeof navigator !== 'undefined' && navigator.msSaveBlob) return navigator.msSaveBlob(blob, fname);\n\t\t/*:: declare var saveAs: any; */\n\t\tif(typeof saveAs !== 'undefined') return saveAs(blob, fname);\n\t\tif(typeof URL !== 'undefined' && typeof document !== 'undefined' && document.createElement && URL.createObjectURL) {\n\t\t\tvar url = URL.createObjectURL(blob);\n\t\t\t/*:: declare var chrome: any; */\n\t\t\tif(typeof chrome === 'object' && typeof (chrome.downloads||{}).download == \"function\") {\n\t\t\t\tif(URL.revokeObjectURL && typeof setTimeout !== 'undefined') setTimeout(function() { URL.revokeObjectURL(url); }, 60000);\n\t\t\t\treturn chrome.downloads.download({ url: url, filename: fname, saveAs: true});\n\t\t\t}\n\t\t\tvar a = document.createElement(\"a\");\n\t\t\tif(a.download != null) {\n\t\t\t\t/*:: if(document.body == null) throw new Error(\"unreachable\"); */\n\t\t\t\ta.download = fname; a.href = url; document.body.appendChild(a); a.click();\n\t\t\t\t/*:: if(document.body == null) throw new Error(\"unreachable\"); */ document.body.removeChild(a);\n\t\t\t\tif(URL.revokeObjectURL && typeof setTimeout !== 'undefined') setTimeout(function() { URL.revokeObjectURL(url); }, 60000);\n\t\t\t\treturn url;\n\t\t\t}\n\t\t}\n\t}\n\t// $FlowIgnore\n\tif(typeof $ !== 'undefined' && typeof File !== 'undefined' && typeof Folder !== 'undefined') try { // extendscript\n\t\t// $FlowIgnore\n\t\tvar out = File(fname); out.open(\"w\"); out.encoding = \"binary\";\n\t\tif(Array.isArray(payload)) payload = a2s(payload);\n\t\tout.write(payload); out.close(); return payload;\n\t} catch(e) { if(!e.message || !e.message.match(/onstruct/)) throw e; }\n\tthrow new Error(\"cannot save file \" + fname);\n}\n\n/* read binary data from file */\nfunction read_binary(path/*:string*/) {\n\tif(typeof _fs !== 'undefined') return _fs.readFileSync(path);\n\tif(typeof Deno !== 'undefined') return Deno.readFileSync(path);\n\t// $FlowIgnore\n\tif(typeof $ !== 'undefined' && typeof File !== 'undefined' && typeof Folder !== 'undefined') try { // extendscript\n\t\t// $FlowIgnore\n\t\tvar infile = File(path); infile.open(\"r\"); infile.encoding = \"binary\";\n\t\tvar data = infile.read(); infile.close();\n\t\treturn data;\n\t} catch(e) { if(!e.message || !e.message.match(/onstruct/)) throw e; }\n\tthrow new Error(\"Cannot access file \" + path);\n}\nfunction keys(o/*:any*/)/*:Array<any>*/ {\n\tvar ks = Object.keys(o), o2 = [];\n\tfor(var i = 0; i < ks.length; ++i) if(Object.prototype.hasOwnProperty.call(o, ks[i])) o2.push(ks[i]);\n\treturn o2;\n}\n\nfunction evert_key(obj/*:any*/, key/*:string*/)/*:EvertType*/ {\n\tvar o = ([]/*:any*/), K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) if(o[obj[K[i]][key]] == null) o[obj[K[i]][key]] = K[i];\n\treturn o;\n}\n\nfunction evert(obj/*:any*/)/*:EvertType*/ {\n\tvar o = ([]/*:any*/), K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) o[obj[K[i]]] = K[i];\n\treturn o;\n}\n\nfunction evert_num(obj/*:any*/)/*:EvertNumType*/ {\n\tvar o = ([]/*:any*/), K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) o[obj[K[i]]] = parseInt(K[i],10);\n\treturn o;\n}\n\nfunction evert_arr(obj/*:any*/)/*:EvertArrType*/ {\n\tvar o/*:EvertArrType*/ = ([]/*:any*/), K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) {\n\t\tif(o[obj[K[i]]] == null) o[obj[K[i]]] = [];\n\t\to[obj[K[i]]].push(K[i]);\n\t}\n\treturn o;\n}\n\nvar basedate = /*#__PURE__*/new Date(1899, 11, 30, 0, 0, 0); // 2209161600000\nfunction datenum(v/*:Date*/, date1904/*:?boolean*/)/*:number*/ {\n\tvar epoch = /*#__PURE__*/v.getTime();\n\tif(date1904) epoch -= 1462*24*60*60*1000;\n\tvar dnthresh = /*#__PURE__*/basedate.getTime() + (/*#__PURE__*/v.getTimezoneOffset() - /*#__PURE__*/basedate.getTimezoneOffset()) * 60000;\n\treturn (epoch - dnthresh) / (24 * 60 * 60 * 1000);\n}\nvar refdate = /*#__PURE__*/new Date();\nvar dnthresh = /*#__PURE__*/basedate.getTime() + (/*#__PURE__*/refdate.getTimezoneOffset() - /*#__PURE__*/basedate.getTimezoneOffset()) * 60000;\nvar refoffset = /*#__PURE__*/refdate.getTimezoneOffset();\nfunction numdate(v/*:number*/)/*:Date*/ {\n\tvar out = new Date();\n\tout.setTime(v * 24 * 60 * 60 * 1000 + dnthresh);\n\tif (out.getTimezoneOffset() !== refoffset) {\n\t\tout.setTime(out.getTime() + (out.getTimezoneOffset() - refoffset) * 60000);\n\t}\n\treturn out;\n}\n\n/* ISO 8601 Duration */\nfunction parse_isodur(s) {\n\tvar sec = 0, mt = 0, time = false;\n\tvar m = s.match(/P([0-9\\.]+Y)?([0-9\\.]+M)?([0-9\\.]+D)?T([0-9\\.]+H)?([0-9\\.]+M)?([0-9\\.]+S)?/);\n\tif(!m) throw new Error(\"|\" + s + \"| is not an ISO8601 Duration\");\n\tfor(var i = 1; i != m.length; ++i) {\n\t\tif(!m[i]) continue;\n\t\tmt = 1;\n\t\tif(i > 3) time = true;\n\t\tswitch(m[i].slice(m[i].length-1)) {\n\t\t\tcase 'Y':\n\t\t\t\tthrow new Error(\"Unsupported ISO Duration Field: \" + m[i].slice(m[i].length-1));\n\t\t\tcase 'D': mt *= 24;\n\t\t\t\t/* falls through */\n\t\t\tcase 'H': mt *= 60;\n\t\t\t\t/* falls through */\n\t\t\tcase 'M':\n\t\t\t\tif(!time) throw new Error(\"Unsupported ISO Duration Field: M\");\n\t\t\t\telse mt *= 60;\n\t\t\t\t/* falls through */\n\t\t\tcase 'S': break;\n\t\t}\n\t\tsec += mt * parseInt(m[i], 10);\n\t}\n\treturn sec;\n}\n\nvar good_pd_date_1 = /*#__PURE__*/new Date('2017-02-19T19:06:09.000Z');\nvar good_pd_date = /*#__PURE__*/isNaN(/*#__PURE__*/good_pd_date_1.getFullYear()) ? /*#__PURE__*/new Date('2/19/17') : good_pd_date_1;\nvar good_pd = /*#__PURE__*/good_pd_date.getFullYear() == 2017;\n/* parses a date as a local date */\nfunction parseDate(str/*:string|Date*/, fixdate/*:?number*/)/*:Date*/ {\n\tvar d = new Date(str);\n\tif(good_pd) {\n\t\t/*:: if(fixdate == null) fixdate = 0; */\n\t\tif(fixdate > 0) d.setTime(d.getTime() + d.getTimezoneOffset() * 60 * 1000);\n\t\telse if(fixdate < 0) d.setTime(d.getTime() - d.getTimezoneOffset() * 60 * 1000);\n\t\treturn d;\n\t}\n\tif(str instanceof Date) return str;\n\tif(good_pd_date.getFullYear() == 1917 && !isNaN(d.getFullYear())) {\n\t\tvar s = d.getFullYear();\n\t\tif(str.indexOf(\"\" + s) > -1) return d;\n\t\td.setFullYear(d.getFullYear() + 100); return d;\n\t}\n\tvar n = str.match(/\\d+/g)||[\"2017\",\"2\",\"19\",\"0\",\"0\",\"0\"];\n\tvar out = new Date(+n[0], +n[1] - 1, +n[2], (+n[3]||0), (+n[4]||0), (+n[5]||0));\n\tif(str.indexOf(\"Z\") > -1) out = new Date(out.getTime() - out.getTimezoneOffset() * 60 * 1000);\n\treturn out;\n}\n\nfunction cc2str(arr/*:Array<number>*/, debomit)/*:string*/ {\n\tif(has_buf && Buffer.isBuffer(arr)) {\n\t\tif(debomit) {\n\t\t\tif(arr[0] == 0xFF && arr[1] == 0xFE) return utf8write(arr.slice(2).toString(\"utf16le\"));\n\t\t\tif(arr[1] == 0xFE && arr[2] == 0xFF) return utf8write(utf16beread(arr.slice(2).toString(\"binary\")));\n\t\t}\n\t\treturn arr.toString(\"binary\");\n\t}\n\n\tif(typeof TextDecoder !== \"undefined\") try {\n\t\tif(debomit) {\n\t\t\tif(arr[0] == 0xFF && arr[1] == 0xFE) return utf8write(new TextDecoder(\"utf-16le\").decode(arr.slice(2)));\n\t\t\tif(arr[0] == 0xFE && arr[1] == 0xFF) return utf8write(new TextDecoder(\"utf-16be\").decode(arr.slice(2)));\n\t\t}\n\t\tvar rev = {\n\t\t\t\"\\u20ac\": \"\\x80\", \"\\u201a\": \"\\x82\", \"\\u0192\": \"\\x83\", \"\\u201e\": \"\\x84\",\n\t\t\t\"\\u2026\": \"\\x85\", \"\\u2020\": \"\\x86\", \"\\u2021\": \"\\x87\", \"\\u02c6\": \"\\x88\",\n\t\t\t\"\\u2030\": \"\\x89\", \"\\u0160\": \"\\x8a\", \"\\u2039\": \"\\x8b\", \"\\u0152\": \"\\x8c\",\n\t\t\t\"\\u017d\": \"\\x8e\", \"\\u2018\": \"\\x91\", \"\\u2019\": \"\\x92\", \"\\u201c\": \"\\x93\",\n\t\t\t\"\\u201d\": \"\\x94\", \"\\u2022\": \"\\x95\", \"\\u2013\": \"\\x96\", \"\\u2014\": \"\\x97\",\n\t\t\t\"\\u02dc\": \"\\x98\", \"\\u2122\": \"\\x99\", \"\\u0161\": \"\\x9a\", \"\\u203a\": \"\\x9b\",\n\t\t\t\"\\u0153\": \"\\x9c\", \"\\u017e\": \"\\x9e\", \"\\u0178\": \"\\x9f\"\n\t\t};\n\t\tif(Array.isArray(arr)) arr = new Uint8Array(arr);\n\t\treturn new TextDecoder(\"latin1\").decode(arr).replace(/[€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ]/g, function(c) { return rev[c] || c; });\n\t} catch(e) {}\n\n\tvar o = [];\n\tfor(var i = 0; i != arr.length; ++i) o.push(String.fromCharCode(arr[i]));\n\treturn o.join(\"\");\n}\n\nfunction dup(o/*:any*/)/*:any*/ {\n\tif(typeof JSON != 'undefined' && !Array.isArray(o)) return JSON.parse(JSON.stringify(o));\n\tif(typeof o != 'object' || o == null) return o;\n\tif(o instanceof Date) return new Date(o.getTime());\n\tvar out = {};\n\tfor(var k in o) if(Object.prototype.hasOwnProperty.call(o, k)) out[k] = dup(o[k]);\n\treturn out;\n}\n\nfunction fill(c/*:string*/,l/*:number*/)/*:string*/ { var o = \"\"; while(o.length < l) o+=c; return o; }\n\n/* TODO: stress test */\nfunction fuzzynum(s/*:string*/)/*:number*/ {\n\tvar v/*:number*/ = Number(s);\n\tif(!isNaN(v)) return isFinite(v) ? v : NaN;\n\tif(!/\\d/.test(s)) return v;\n\tvar wt = 1;\n\tvar ss = s.replace(/([\\d]),([\\d])/g,\"$1$2\").replace(/[$]/g,\"\").replace(/[%]/g, function() { wt *= 100; return \"\";});\n\tif(!isNaN(v = Number(ss))) return v / wt;\n\tss = ss.replace(/[(](.*)[)]/,function($$, $1) { wt = -wt; return $1;});\n\tif(!isNaN(v = Number(ss))) return v / wt;\n\treturn v;\n}\nvar lower_months = ['january', 'february', 'march', 'april', 'may', 'june', 'july', 'august', 'september', 'october', 'november', 'december'];\nfunction fuzzydate(s/*:string*/)/*:Date*/ {\n\tvar o = new Date(s), n = new Date(NaN);\n\tvar y = o.getYear(), m = o.getMonth(), d = o.getDate();\n\tif(isNaN(d)) return n;\n\tvar lower = s.toLowerCase();\n\tif(lower.match(/jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec/)) {\n\t\tlower = lower.replace(/[^a-z]/g,\"\").replace(/([^a-z]|^)[ap]m?([^a-z]|$)/,\"\");\n\t\tif(lower.length > 3 && lower_months.indexOf(lower) == -1) return n;\n\t} else if(lower.match(/[a-z]/)) return n;\n\tif(y < 0 || y > 8099) return n;\n\tif((m > 0 || d > 1) && y != 101) return o;\n\tif(s.match(/[^-0-9:,\\/\\\\]/)) return n;\n\treturn o;\n}\n\nvar split_regex = /*#__PURE__*/(function() {\n\tvar safe_split_regex = \"abacaba\".split(/(:?b)/i).length == 5;\n\treturn function split_regex(str/*:string*/, re, def/*:string*/)/*:Array<string>*/ {\n\t\tif(safe_split_regex || typeof re == \"string\") return str.split(re);\n\t\tvar p = str.split(re), o = [p[0]];\n\t\tfor(var i = 1; i < p.length; ++i) { o.push(def); o.push(p[i]); }\n\t\treturn o;\n\t};\n})();\nfunction getdatastr(data)/*:?string*/ {\n\tif(!data) return null;\n\tif(data.content && data.type) return cc2str(data.content, true);\n\tif(data.data) return debom(data.data);\n\tif(data.asNodeBuffer && has_buf) return debom(data.asNodeBuffer().toString('binary'));\n\tif(data.asBinary) return debom(data.asBinary());\n\tif(data._data && data._data.getContent) return debom(cc2str(Array.prototype.slice.call(data._data.getContent(),0)));\n\treturn null;\n}\n\nfunction getdatabin(data) {\n\tif(!data) return null;\n\tif(data.data) return char_codes(data.data);\n\tif(data.asNodeBuffer && has_buf) return data.asNodeBuffer();\n\tif(data._data && data._data.getContent) {\n\t\tvar o = data._data.getContent();\n\t\tif(typeof o == \"string\") return char_codes(o);\n\t\treturn Array.prototype.slice.call(o);\n\t}\n\tif(data.content && data.type) return data.content;\n\treturn null;\n}\n\nfunction getdata(data) { return (data && data.name.slice(-4) === \".bin\") ? getdatabin(data) : getdatastr(data); }\n\n/* Part 2 Section 10.1.2 \"Mapping Content Types\" Names are case-insensitive */\n/* OASIS does not comment on filename case sensitivity */\nfunction safegetzipfile(zip, file/*:string*/) {\n\tvar k = zip.FullPaths || keys(zip.files);\n\tvar f = file.toLowerCase().replace(/[\\/]/g, '\\\\'), g = f.replace(/\\\\/g,'\\/');\n\tfor(var i=0; i<k.length; ++i) {\n\t\tvar n = k[i].replace(/^Root Entry[\\/]/,\"\").toLowerCase();\n\t\tif(f == n || g == n) return zip.files ? zip.files[k[i]] : zip.FileIndex[i];\n\t}\n\treturn null;\n}\n\nfunction getzipfile(zip, file/*:string*/) {\n\tvar o = safegetzipfile(zip, file);\n\tif(o == null) throw new Error(\"Cannot find file \" + file + \" in zip\");\n\treturn o;\n}\n\nfunction getzipdata(zip, file/*:string*/, safe/*:?boolean*/)/*:any*/ {\n\tif(!safe) return getdata(getzipfile(zip, file));\n\tif(!file) return null;\n\ttry { return getzipdata(zip, file); } catch(e) { return null; }\n}\n\nfunction getzipstr(zip, file/*:string*/, safe/*:?boolean*/)/*:?string*/ {\n\tif(!safe) return getdatastr(getzipfile(zip, file));\n\tif(!file) return null;\n\ttry { return getzipstr(zip, file); } catch(e) { return null; }\n}\n\nfunction getzipbin(zip, file/*:string*/, safe/*:?boolean*/)/*:any*/ {\n\tif(!safe) return getdatabin(getzipfile(zip, file));\n\tif(!file) return null;\n\ttry { return getzipbin(zip, file); } catch(e) { return null; }\n}\n\nfunction zipentries(zip) {\n\tvar k = zip.FullPaths || keys(zip.files), o = [];\n\tfor(var i = 0; i < k.length; ++i) if(k[i].slice(-1) != '/') o.push(k[i].replace(/^Root Entry[\\/]/, \"\"));\n\treturn o.sort();\n}\n\nfunction zip_add_file(zip, path, content) {\n\tif(zip.FullPaths) {\n\t\tif(typeof content == \"string\") {\n\t\t\tvar res;\n\t\t\tif(has_buf) res = Buffer_from(content);\n\t\t\t/* TODO: investigate performance in Edge 13 */\n\t\t\t//else if(typeof TextEncoder !== \"undefined\") res = new TextEncoder().encode(content);\n\t\t\telse res = utf8decode(content);\n\t\t\treturn CFB.utils.cfb_add(zip, path, res);\n\t\t}\n\t\tCFB.utils.cfb_add(zip, path, content);\n\t}\n\telse zip.file(path, content);\n}\n\nfunction zip_new() { return CFB.utils.cfb_new(); }\n\nfunction zip_read(d, o) {\n\tswitch(o.type) {\n\t\tcase \"base64\": return CFB.read(d, { type: \"base64\" });\n\t\tcase \"binary\": return CFB.read(d, { type: \"binary\" });\n\t\tcase \"buffer\": case \"array\": return CFB.read(d, { type: \"buffer\" });\n\t}\n\tthrow new Error(\"Unrecognized type \" + o.type);\n}\n\nfunction resolve_path(path/*:string*/, base/*:string*/)/*:string*/ {\n\tif(path.charAt(0) == \"/\") return path.slice(1);\n\tvar result = base.split('/');\n\tif(base.slice(-1) != \"/\") result.pop(); // folder path\n\tvar target = path.split('/');\n\twhile (target.length !== 0) {\n\t\tvar step = target.shift();\n\t\tif (step === '..') result.pop();\n\t\telse if (step !== '.') result.push(step);\n\t}\n\treturn result.join('/');\n}\nvar XML_HEADER = '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\\r\\n';\nvar attregexg=/([^\"\\s?>\\/]+)\\s*=\\s*((?:\")([^\"]*)(?:\")|(?:')([^']*)(?:')|([^'\">\\s]+))/g;\nvar tagregex1=/<[\\/\\?]?[a-zA-Z0-9:_-]+(?:\\s+[^\"\\s?>\\/]+\\s*=\\s*(?:\"[^\"]*\"|'[^']*'|[^'\">\\s=]+))*\\s*[\\/\\?]?>/mg, tagregex2 = /<[^>]*>/g;\nvar tagregex = /*#__PURE__*/XML_HEADER.match(tagregex1) ? tagregex1 : tagregex2;\nvar nsregex=/<\\w*:/, nsregex2 = /<(\\/?)\\w+:/;\nfunction parsexmltag(tag/*:string*/, skip_root/*:?boolean*/, skip_LC/*:?boolean*/)/*:any*/ {\n\tvar z = ({}/*:any*/);\n\tvar eq = 0, c = 0;\n\tfor(; eq !== tag.length; ++eq) if((c = tag.charCodeAt(eq)) === 32 || c === 10 || c === 13) break;\n\tif(!skip_root) z[0] = tag.slice(0, eq);\n\tif(eq === tag.length) return z;\n\tvar m = tag.match(attregexg), j=0, v=\"\", i=0, q=\"\", cc=\"\", quot = 1;\n\tif(m) for(i = 0; i != m.length; ++i) {\n\t\tcc = m[i];\n\t\tfor(c=0; c != cc.length; ++c) if(cc.charCodeAt(c) === 61) break;\n\t\tq = cc.slice(0,c).trim();\n\t\twhile(cc.charCodeAt(c+1) == 32) ++c;\n\t\tquot = ((eq=cc.charCodeAt(c+1)) == 34 || eq == 39) ? 1 : 0;\n\t\tv = cc.slice(c+1+quot, cc.length-quot);\n\t\tfor(j=0;j!=q.length;++j) if(q.charCodeAt(j) === 58) break;\n\t\tif(j===q.length) {\n\t\t\tif(q.indexOf(\"_\") > 0) q = q.slice(0, q.indexOf(\"_\")); // from ods\n\t\t\tz[q] = v;\n\t\t\tif(!skip_LC) z[q.toLowerCase()] = v;\n\t\t}\n\t\telse {\n\t\t\tvar k = (j===5 && q.slice(0,5)===\"xmlns\"?\"xmlns\":\"\")+q.slice(j+1);\n\t\t\tif(z[k] && q.slice(j-3,j) == \"ext\") continue; // from ods\n\t\t\tz[k] = v;\n\t\t\tif(!skip_LC) z[k.toLowerCase()] = v;\n\t\t}\n\t}\n\treturn z;\n}\nfunction strip_ns(x/*:string*/)/*:string*/ { return x.replace(nsregex2, \"<$1\"); }\n\nvar encodings = {\n\t'&quot;': '\"',\n\t'&apos;': \"'\",\n\t'&gt;': '>',\n\t'&lt;': '<',\n\t'&amp;': '&'\n};\nvar rencoding = /*#__PURE__*/evert(encodings);\n//var rencstr = \"&<>'\\\"\".split(\"\");\n\n// TODO: CP remap (need to read file version to determine OS)\nvar unescapexml/*:StringConv*/ = /*#__PURE__*/(function() {\n\t/* 22.4.2.4 bstr (Basic String) */\n\tvar encregex = /&(?:quot|apos|gt|lt|amp|#x?([\\da-fA-F]+));/ig, coderegex = /_x([\\da-fA-F]{4})_/ig;\n\treturn function unescapexml(text/*:string*/)/*:string*/ {\n\t\tvar s = text + '', i = s.indexOf(\"<![CDATA[\");\n\t\tif(i == -1) return s.replace(encregex, function($$, $1) { return encodings[$$]||String.fromCharCode(parseInt($1,$$.indexOf(\"x\")>-1?16:10))||$$; }).replace(coderegex,function(m,c) {return String.fromCharCode(parseInt(c,16));});\n\t\tvar j = s.indexOf(\"]]>\");\n\t\treturn unescapexml(s.slice(0, i)) + s.slice(i+9,j) + unescapexml(s.slice(j+3));\n\t};\n})();\n\nvar decregex=/[&<>'\"]/g, charegex = /[\\u0000-\\u0008\\u000b-\\u001f]/g;\nfunction escapexml(text/*:string*/)/*:string*/{\n\tvar s = text + '';\n\treturn s.replace(decregex, function(y) { return rencoding[y]; }).replace(charegex,function(s) { return \"_x\" + (\"000\"+s.charCodeAt(0).toString(16)).slice(-4) + \"_\";});\n}\nfunction escapexmltag(text/*:string*/)/*:string*/{ return escapexml(text).replace(/ /g,\"_x0020_\"); }\n\nvar htmlcharegex = /[\\u0000-\\u001f]/g;\nfunction escapehtml(text/*:string*/)/*:string*/{\n\tvar s = text + '';\n\treturn s.replace(decregex, function(y) { return rencoding[y]; }).replace(/\\n/g, \"<br/>\").replace(htmlcharegex,function(s) { return \"&#x\" + (\"000\"+s.charCodeAt(0).toString(16)).slice(-4) + \";\"; });\n}\n\nfunction escapexlml(text/*:string*/)/*:string*/{\n\tvar s = text + '';\n\treturn s.replace(decregex, function(y) { return rencoding[y]; }).replace(htmlcharegex,function(s) { return \"&#x\" + (s.charCodeAt(0).toString(16)).toUpperCase() + \";\"; });\n}\n\n/* TODO: handle codepages */\nvar xlml_fixstr/*:StringConv*/ = /*#__PURE__*/(function() {\n\tvar entregex = /&#(\\d+);/g;\n\tfunction entrepl($$/*:string*/,$1/*:string*/)/*:string*/ { return String.fromCharCode(parseInt($1,10)); }\n\treturn function xlml_fixstr(str/*:string*/)/*:string*/ { return str.replace(entregex,entrepl); };\n})();\nfunction xlml_unfixstr(str/*:string*/)/*:string*/ { return str.replace(/(\\r\\n|[\\r\\n])/g,\"\\&#10;\"); }\n\nfunction parsexmlbool(value/*:any*/)/*:boolean*/ {\n\tswitch(value) {\n\t\tcase 1: case true: case '1': case 'true': case 'TRUE': return true;\n\t\t/* case '0': case 'false': case 'FALSE':*/\n\t\tdefault: return false;\n\t}\n}\n\nfunction utf8reada(orig/*:string*/)/*:string*/ {\n\tvar out = \"\", i = 0, c = 0, d = 0, e = 0, f = 0, w = 0;\n\twhile (i < orig.length) {\n\t\tc = orig.charCodeAt(i++);\n\t\tif (c < 128) { out += String.fromCharCode(c); continue; }\n\t\td = orig.charCodeAt(i++);\n\t\tif (c>191 && c<224) { f = ((c & 31) << 6); f |= (d & 63); out += String.fromCharCode(f); continue; }\n\t\te = orig.charCodeAt(i++);\n\t\tif (c < 240) { out += String.fromCharCode(((c & 15) << 12) | ((d & 63) << 6) | (e & 63)); continue; }\n\t\tf = orig.charCodeAt(i++);\n\t\tw = (((c & 7) << 18) | ((d & 63) << 12) | ((e & 63) << 6) | (f & 63))-65536;\n\t\tout += String.fromCharCode(0xD800 + ((w>>>10)&1023));\n\t\tout += String.fromCharCode(0xDC00 + (w&1023));\n\t}\n\treturn out;\n}\n\nfunction utf8readb(data) {\n\tvar out = new_raw_buf(2*data.length), w, i, j = 1, k = 0, ww=0, c;\n\tfor(i = 0; i < data.length; i+=j) {\n\t\tj = 1;\n\t\tif((c=data.charCodeAt(i)) < 128) w = c;\n\t\telse if(c < 224) { w = (c&31)*64+(data.charCodeAt(i+1)&63); j=2; }\n\t\telse if(c < 240) { w=(c&15)*4096+(data.charCodeAt(i+1)&63)*64+(data.charCodeAt(i+2)&63); j=3; }\n\t\telse { j = 4;\n\t\t\tw = (c & 7)*262144+(data.charCodeAt(i+1)&63)*4096+(data.charCodeAt(i+2)&63)*64+(data.charCodeAt(i+3)&63);\n\t\t\tw -= 65536; ww = 0xD800 + ((w>>>10)&1023); w = 0xDC00 + (w&1023);\n\t\t}\n\t\tif(ww !== 0) { out[k++] = ww&255; out[k++] = ww>>>8; ww = 0; }\n\t\tout[k++] = w%256; out[k++] = w>>>8;\n\t}\n\treturn out.slice(0,k).toString('ucs2');\n}\n\nfunction utf8readc(data) { return Buffer_from(data, 'binary').toString('utf8'); }\n\nvar utf8corpus = \"foo bar baz\\u00e2\\u0098\\u0083\\u00f0\\u009f\\u008d\\u00a3\";\nvar utf8read = has_buf && (/*#__PURE__*/utf8readc(utf8corpus) == /*#__PURE__*/utf8reada(utf8corpus) && utf8readc || /*#__PURE__*/utf8readb(utf8corpus) == /*#__PURE__*/utf8reada(utf8corpus) && utf8readb) || utf8reada;\n\nvar utf8write/*:StringConv*/ = has_buf ? function(data) { return Buffer_from(data, 'utf8').toString(\"binary\"); } : function(orig/*:string*/)/*:string*/ {\n\tvar out/*:Array<string>*/ = [], i = 0, c = 0, d = 0;\n\twhile(i < orig.length) {\n\t\tc = orig.charCodeAt(i++);\n\t\tswitch(true) {\n\t\t\tcase c < 128: out.push(String.fromCharCode(c)); break;\n\t\t\tcase c < 2048:\n\t\t\t\tout.push(String.fromCharCode(192 + (c >> 6)));\n\t\t\t\tout.push(String.fromCharCode(128 + (c & 63)));\n\t\t\t\tbreak;\n\t\t\tcase c >= 55296 && c < 57344:\n\t\t\t\tc -= 55296; d = orig.charCodeAt(i++) - 56320 + (c<<10);\n\t\t\t\tout.push(String.fromCharCode(240 + ((d >>18) & 7)));\n\t\t\t\tout.push(String.fromCharCode(144 + ((d >>12) & 63)));\n\t\t\t\tout.push(String.fromCharCode(128 + ((d >> 6) & 63)));\n\t\t\t\tout.push(String.fromCharCode(128 + (d & 63)));\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tout.push(String.fromCharCode(224 + (c >> 12)));\n\t\t\t\tout.push(String.fromCharCode(128 + ((c >> 6) & 63)));\n\t\t\t\tout.push(String.fromCharCode(128 + (c & 63)));\n\t\t}\n\t}\n\treturn out.join(\"\");\n};\n\n// matches <foo>...</foo> extracts content\nvar matchtag = /*#__PURE__*/(function() {\n\tvar mtcache/*:{[k:string]:RegExp}*/ = ({}/*:any*/);\n\treturn function matchtag(f/*:string*/,g/*:?string*/)/*:RegExp*/ {\n\t\tvar t = f+\"|\"+(g||\"\");\n\t\tif(mtcache[t]) return mtcache[t];\n\t\treturn (mtcache[t] = new RegExp('<(?:\\\\w+:)?'+f+'(?: xml:space=\"preserve\")?(?:[^>]*)>([\\\\s\\\\S]*?)</(?:\\\\w+:)?'+f+'>',((g||\"\")/*:any*/)));\n\t};\n})();\n\nvar htmldecode/*:{(s:string):string}*/ = /*#__PURE__*/(function() {\n\tvar entities/*:Array<[RegExp, string]>*/ = [\n\t\t['nbsp', ' '], ['middot', '·'],\n\t\t['quot', '\"'], ['apos', \"'\"], ['gt', '>'], ['lt', '<'], ['amp', '&']\n\t].map(function(x/*:[string, string]*/) { return [new RegExp('&' + x[0] + ';', \"ig\"), x[1]]; });\n\treturn function htmldecode(str/*:string*/)/*:string*/ {\n\t\tvar o = str\n\t\t\t\t// Remove new lines and spaces from start of content\n\t\t\t\t.replace(/^[\\t\\n\\r ]+/, \"\")\n\t\t\t\t// Remove new lines and spaces from end of content\n\t\t\t\t.replace(/[\\t\\n\\r ]+$/,\"\")\n\t\t\t\t// Added line which removes any white space characters after and before html tags\n\t\t\t\t.replace(/>\\s+/g,\">\").replace(/\\s+</g,\"<\")\n\t\t\t\t// Replace remaining new lines and spaces with space\n\t\t\t\t.replace(/[\\t\\n\\r ]+/g, \" \")\n\t\t\t\t// Replace <br> tags with new lines\n\t\t\t\t.replace(/<\\s*[bB][rR]\\s*\\/?>/g,\"\\n\")\n\t\t\t\t// Strip HTML elements\n\t\t\t\t.replace(/<[^>]*>/g,\"\");\n\t\tfor(var i = 0; i < entities.length; ++i) o = o.replace(entities[i][0], entities[i][1]);\n\t\treturn o;\n\t};\n})();\n\nvar vtregex = /*#__PURE__*/(function(){ var vt_cache = {};\n\treturn function vt_regex(bt) {\n\t\tif(vt_cache[bt] !== undefined) return vt_cache[bt];\n\t\treturn (vt_cache[bt] = new RegExp(\"<(?:vt:)?\" + bt + \">([\\\\s\\\\S]*?)</(?:vt:)?\" + bt + \">\", 'g') );\n};})();\nvar vtvregex = /<\\/?(?:vt:)?variant>/g, vtmregex = /<(?:vt:)([^>]*)>([\\s\\S]*)</;\nfunction parseVector(data/*:string*/, opts)/*:Array<{v:string,t:string}>*/ {\n\tvar h = parsexmltag(data);\n\n\tvar matches/*:Array<string>*/ = data.match(vtregex(h.baseType))||[];\n\tvar res/*:Array<any>*/ = [];\n\tif(matches.length != h.size) {\n\t\tif(opts.WTF) throw new Error(\"unexpected vector length \" + matches.length + \" != \" + h.size);\n\t\treturn res;\n\t}\n\tmatches.forEach(function(x/*:string*/) {\n\t\tvar v = x.replace(vtvregex,\"\").match(vtmregex);\n\t\tif(v) res.push({v:utf8read(v[2]), t:v[1]});\n\t});\n\treturn res;\n}\n\nvar wtregex = /(^\\s|\\s$|\\n)/;\nfunction writetag(f/*:string*/,g/*:string*/)/*:string*/ { return '<' + f + (g.match(wtregex)?' xml:space=\"preserve\"' : \"\") + '>' + g + '</' + f + '>'; }\n\nfunction wxt_helper(h)/*:string*/ { return keys(h).map(function(k) { return \" \" + k + '=\"' + h[k] + '\"';}).join(\"\"); }\nfunction writextag(f/*:string*/,g/*:?string*/,h) { return '<' + f + ((h != null) ? wxt_helper(h) : \"\") + ((g != null) ? (g.match(wtregex)?' xml:space=\"preserve\"' : \"\") + '>' + g + '</' + f : \"/\") + '>';}\n\nfunction write_w3cdtf(d/*:Date*/, t/*:?boolean*/)/*:string*/ { try { return d.toISOString().replace(/\\.\\d*/,\"\"); } catch(e) { if(t) throw e; } return \"\"; }\n\nfunction write_vt(s, xlsx/*:?boolean*/)/*:string*/ {\n\tswitch(typeof s) {\n\t\tcase 'string':\n\t\t\tvar o = writextag('vt:lpwstr', escapexml(s));\n\t\t\tif(xlsx) o = o.replace(/&quot;/g, \"_x0022_\");\n\t\t\treturn o;\n\t\tcase 'number': return writextag((s|0)==s?'vt:i4':'vt:r8', escapexml(String(s)));\n\t\tcase 'boolean': return writextag('vt:bool',s?'true':'false');\n\t}\n\tif(s instanceof Date) return writextag('vt:filetime', write_w3cdtf(s));\n\tthrow new Error(\"Unable to serialize \" + s);\n}\n\nfunction xlml_normalize(d)/*:string*/ {\n\tif(has_buf &&/*::typeof Buffer !== \"undefined\" && d != null && d instanceof Buffer &&*/ Buffer.isBuffer(d)) return d.toString('utf8');\n\tif(typeof d === 'string') return d;\n\t/* duktape */\n\tif(typeof Uint8Array !== 'undefined' && d instanceof Uint8Array) return utf8read(a2s(ab2a(d)));\n\tthrow new Error(\"Bad input format: expected Buffer or string\");\n}\n/* UOS uses CJK in tags */\nvar xlmlregex = /<(\\/?)([^\\s?><!\\/:]*:|)([^\\s?<>:\\/]+)(?:[\\s?:\\/][^>]*)?>/mg;\n//var xlmlregex = /<(\\/?)([a-z0-9]*:|)(\\w+)[^>]*>/mg;\n\nvar XMLNS = ({\n\tCORE_PROPS: 'http://schemas.openxmlformats.org/package/2006/metadata/core-properties',\n\tCUST_PROPS: \"http://schemas.openxmlformats.org/officeDocument/2006/custom-properties\",\n\tEXT_PROPS: \"http://schemas.openxmlformats.org/officeDocument/2006/extended-properties\",\n\tCT: 'http://schemas.openxmlformats.org/package/2006/content-types',\n\tRELS: 'http://schemas.openxmlformats.org/package/2006/relationships',\n\tTCMNT: 'http://schemas.microsoft.com/office/spreadsheetml/2018/threadedcomments',\n\t'dc': 'http://purl.org/dc/elements/1.1/',\n\t'dcterms': 'http://purl.org/dc/terms/',\n\t'dcmitype': 'http://purl.org/dc/dcmitype/',\n\t'mx': 'http://schemas.microsoft.com/office/mac/excel/2008/main',\n\t'r': 'http://schemas.openxmlformats.org/officeDocument/2006/relationships',\n\t'sjs': 'http://schemas.openxmlformats.org/package/2006/sheetjs/core-properties',\n\t'vt': 'http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes',\n\t'xsi': 'http://www.w3.org/2001/XMLSchema-instance',\n\t'xsd': 'http://www.w3.org/2001/XMLSchema'\n}/*:any*/);\n\nvar XMLNS_main = [\n\t'http://schemas.openxmlformats.org/spreadsheetml/2006/main',\n\t'http://purl.oclc.org/ooxml/spreadsheetml/main',\n\t'http://schemas.microsoft.com/office/excel/2006/main',\n\t'http://schemas.microsoft.com/office/excel/2006/2'\n];\n\nvar XLMLNS = ({\n\t'o': 'urn:schemas-microsoft-com:office:office',\n\t'x': 'urn:schemas-microsoft-com:office:excel',\n\t'ss': 'urn:schemas-microsoft-com:office:spreadsheet',\n\t'dt': 'uuid:C2F41010-65B3-11d1-A29F-00AA00C14882',\n\t'mv': 'http://macVmlSchemaUri',\n\t'v': 'urn:schemas-microsoft-com:vml',\n\t'html': 'http://www.w3.org/TR/REC-html40'\n}/*:any*/);\nfunction read_double_le(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ {\n\tvar s = 1 - 2 * (b[idx + 7] >>> 7);\n\tvar e = ((b[idx + 7] & 0x7f) << 4) + ((b[idx + 6] >>> 4) & 0x0f);\n\tvar m = (b[idx+6]&0x0f);\n\tfor(var i = 5; i >= 0; --i) m = m * 256 + b[idx + i];\n\tif(e == 0x7ff) return m == 0 ? (s * Infinity) : NaN;\n\tif(e == 0) e = -1022;\n\telse { e -= 1023; m += Math.pow(2,52); }\n\treturn s * Math.pow(2, e - 52) * m;\n}\n\nfunction write_double_le(b/*:RawBytes|CFBlob*/, v/*:number*/, idx/*:number*/) {\n\tvar bs = ((((v < 0) || (1/v == -Infinity)) ? 1 : 0) << 7), e = 0, m = 0;\n\tvar av = bs ? (-v) : v;\n\tif(!isFinite(av)) { e = 0x7ff; m = isNaN(v) ? 0x6969 : 0; }\n\telse if(av == 0) e = m = 0;\n\telse {\n\t\te = Math.floor(Math.log(av) / Math.LN2);\n\t\tm = av * Math.pow(2, 52 - e);\n\t\tif((e <= -1023) && (!isFinite(m) || (m < Math.pow(2,52)))) { e = -1022; }\n\t\telse { m -= Math.pow(2,52); e+=1023; }\n\t}\n\tfor(var i = 0; i <= 5; ++i, m/=256) b[idx + i] = m & 0xff;\n\tb[idx + 6] = ((e & 0x0f) << 4) | (m & 0xf);\n\tb[idx + 7] = (e >> 4) | bs;\n}\n\nvar ___toBuffer = function(bufs/*:Array<Array<RawBytes> >*/)/*:RawBytes*/ { var x=[],w=10240; for(var i=0;i<bufs[0].length;++i) if(bufs[0][i]) for(var j=0,L=bufs[0][i].length;j<L;j+=w) x.push.apply(x, bufs[0][i].slice(j,j+w)); return x; };\nvar __toBuffer = has_buf ? function(bufs) { return (bufs[0].length > 0 && Buffer.isBuffer(bufs[0][0])) ? Buffer.concat(bufs[0].map(function(x) { return Buffer.isBuffer(x) ? x : Buffer_from(x); })) : ___toBuffer(bufs);} : ___toBuffer;\n\nvar ___utf16le = function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/)/*:string*/ { var ss/*:Array<string>*/=[]; for(var i=s; i<e; i+=2) ss.push(String.fromCharCode(__readUInt16LE(b,i))); return ss.join(\"\").replace(chr0,''); };\nvar __utf16le = has_buf ? function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/)/*:string*/ { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___utf16le(b,s,e); return b.toString('utf16le',s,e).replace(chr0,'')/*.replace(chr1,'!')*/; } : ___utf16le;\n\nvar ___hexlify = function(b/*:RawBytes|CFBlob*/,s/*:number*/,l/*:number*/)/*:string*/ { var ss/*:Array<string>*/=[]; for(var i=s; i<s+l; ++i) ss.push((\"0\" + b[i].toString(16)).slice(-2)); return ss.join(\"\"); };\nvar __hexlify = has_buf ? function(b/*:RawBytes|CFBlob*/,s/*:number*/,l/*:number*/)/*:string*/ { return Buffer.isBuffer(b)/*:: && b instanceof Buffer*/ ? b.toString('hex',s,s+l) : ___hexlify(b,s,l); } : ___hexlify;\n\nvar ___utf8 = function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/) { var ss=[]; for(var i=s; i<e; i++) ss.push(String.fromCharCode(__readUInt8(b,i))); return ss.join(\"\"); };\nvar __utf8 = has_buf ? function utf8_b(b/*:RawBytes|CFBlob*/, s/*:number*/, e/*:number*/) { return (Buffer.isBuffer(b)/*:: && (b instanceof Buffer)*/) ? b.toString('utf8',s,e) : ___utf8(b,s,e); } : ___utf8;\n\nvar ___lpstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len-1) : \"\";};\nvar __lpstr = ___lpstr;\n\nvar ___cpstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len-1) : \"\";};\nvar __cpstr = ___cpstr;\n\nvar ___lpwstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = 2*__readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len-1) : \"\";};\nvar __lpwstr = ___lpwstr;\n\nvar ___lpp4 = function lpp4_(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? __utf16le(b, i+4,i+4+len) : \"\";};\nvar __lpp4 = ___lpp4;\n\nvar ___8lpp4 = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len) : \"\";};\nvar __8lpp4 = ___8lpp4;\n\nvar ___double = function(b/*:RawBytes|CFBlob*/, idx/*:number*/) { return read_double_le(b, idx);};\nvar __double = ___double;\n\nvar is_buf = function is_buf_a(a) { return Array.isArray(a) || (typeof Uint8Array !== \"undefined\" && a instanceof Uint8Array); };\n\nif(has_buf/*:: && typeof Buffer !== 'undefined'*/) {\n\t__lpstr = function lpstr_b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___lpstr(b, i); var len = b.readUInt32LE(i); return len > 0 ? b.toString('utf8',i+4,i+4+len-1) : \"\";};\n\t__cpstr = function cpstr_b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___cpstr(b, i); var len = b.readUInt32LE(i); return len > 0 ? b.toString('utf8',i+4,i+4+len-1) : \"\";};\n\t__lpwstr = function lpwstr_b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___lpwstr(b, i); var len = 2*b.readUInt32LE(i); return b.toString('utf16le',i+4,i+4+len-1);};\n\t__lpp4 = function lpp4_b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___lpp4(b, i); var len = b.readUInt32LE(i); return b.toString('utf16le',i+4,i+4+len);};\n\t__8lpp4 = function lpp4_8b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___8lpp4(b, i); var len = b.readUInt32LE(i); return b.toString('utf8',i+4,i+4+len);};\n\t__double = function double_(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(Buffer.isBuffer(b)/*::&& b instanceof Buffer*/) return b.readDoubleLE(i); return ___double(b,i); };\n\tis_buf = function is_buf_b(a) { return Buffer.isBuffer(a) || Array.isArray(a) || (typeof Uint8Array !== \"undefined\" && a instanceof Uint8Array); };\n}\n\n/* from js-xls */\nfunction cpdoit() {\n\t__utf16le = function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/) { return $cptable.utils.decode(1200, b.slice(s,e)).replace(chr0, ''); };\n\t__utf8 = function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/) { return $cptable.utils.decode(65001, b.slice(s,e)); };\n\t__lpstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(current_ansi, b.slice(i+4, i+4+len-1)) : \"\";};\n\t__cpstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(current_codepage, b.slice(i+4, i+4+len-1)) : \"\";};\n\t__lpwstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = 2*__readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(1200, b.slice(i+4,i+4+len-1)) : \"\";};\n\t__lpp4 = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(1200, b.slice(i+4,i+4+len)) : \"\";};\n\t__8lpp4 = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(65001, b.slice(i+4,i+4+len)) : \"\";};\n}\nif(typeof $cptable !== 'undefined') cpdoit();\n\nvar __readUInt8 = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return b[idx]; };\nvar __readUInt16LE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return (b[idx+1]*(1<<8))+b[idx]; };\nvar __readInt16LE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { var u = (b[idx+1]*(1<<8))+b[idx]; return (u < 0x8000) ? u : ((0xffff - u + 1) * -1); };\nvar __readUInt32LE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return b[idx+3]*(1<<24)+(b[idx+2]<<16)+(b[idx+1]<<8)+b[idx]; };\nvar __readInt32LE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return (b[idx+3]<<24)|(b[idx+2]<<16)|(b[idx+1]<<8)|b[idx]; };\nvar __readInt32BE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return (b[idx]<<24)|(b[idx+1]<<16)|(b[idx+2]<<8)|b[idx+3]; };\n\nfunction ReadShift(size/*:number*/, t/*:?string*/)/*:number|string*/ {\n\tvar o=\"\", oI/*:: :number = 0*/, oR, oo=[], w, vv, i, loc;\n\tswitch(t) {\n\t\tcase 'dbcs':\n\t\t\tloc = this.l;\n\t\t\tif(has_buf && Buffer.isBuffer(this)) o = this.slice(this.l, this.l+2*size).toString(\"utf16le\");\n\t\t\telse for(i = 0; i < size; ++i) { o+=String.fromCharCode(__readUInt16LE(this, loc)); loc+=2; }\n\t\t\tsize *= 2;\n\t\t\tbreak;\n\n\t\tcase 'utf8': o = __utf8(this, this.l, this.l + size); break;\n\t\tcase 'utf16le': size *= 2; o = __utf16le(this, this.l, this.l + size); break;\n\n\t\tcase 'wstr':\n\t\t\tif(typeof $cptable !== 'undefined') o = $cptable.utils.decode(current_codepage, this.slice(this.l, this.l+2*size));\n\t\t\telse return ReadShift.call(this, size, 'dbcs');\n\t\t\tsize = 2 * size; break;\n\n\t\t/* [MS-OLEDS] 2.1.4 LengthPrefixedAnsiString */\n\t\tcase 'lpstr-ansi': o = __lpstr(this, this.l); size = 4 + __readUInt32LE(this, this.l); break;\n\t\tcase 'lpstr-cp': o = __cpstr(this, this.l); size = 4 + __readUInt32LE(this, this.l); break;\n\t\t/* [MS-OLEDS] 2.1.5 LengthPrefixedUnicodeString */\n\t\tcase 'lpwstr': o = __lpwstr(this, this.l); size = 4 + 2 * __readUInt32LE(this, this.l); break;\n\t\t/* [MS-OFFCRYPTO] 2.1.2 Length-Prefixed Padded Unicode String (UNICODE-LP-P4) */\n\t\tcase 'lpp4': size = 4 + __readUInt32LE(this, this.l); o = __lpp4(this, this.l); if(size & 0x02) size += 2; break;\n\t\t/* [MS-OFFCRYPTO] 2.1.3 Length-Prefixed UTF-8 String (UTF-8-LP-P4) */\n\t\tcase '8lpp4': size = 4 + __readUInt32LE(this, this.l); o = __8lpp4(this, this.l); if(size & 0x03) size += 4 - (size & 0x03); break;\n\n\t\tcase 'cstr': size = 0; o = \"\";\n\t\t\twhile((w=__readUInt8(this, this.l + size++))!==0) oo.push(_getchar(w));\n\t\t\to = oo.join(\"\"); break;\n\t\tcase '_wstr': size = 0; o = \"\";\n\t\t\twhile((w=__readUInt16LE(this,this.l +size))!==0){oo.push(_getchar(w));size+=2;}\n\t\t\tsize+=2; o = oo.join(\"\"); break;\n\n\t\t/* sbcs and dbcs support continue records in the SST way TODO codepages */\n\t\tcase 'dbcs-cont': o = \"\"; loc = this.l;\n\t\t\tfor(i = 0; i < size; ++i) {\n\t\t\t\tif(this.lens && this.lens.indexOf(loc) !== -1) {\n\t\t\t\t\tw = __readUInt8(this, loc);\n\t\t\t\t\tthis.l = loc + 1;\n\t\t\t\t\tvv = ReadShift.call(this, size-i, w ? 'dbcs-cont' : 'sbcs-cont');\n\t\t\t\t\treturn oo.join(\"\") + vv;\n\t\t\t\t}\n\t\t\t\too.push(_getchar(__readUInt16LE(this, loc)));\n\t\t\t\tloc+=2;\n\t\t\t} o = oo.join(\"\"); size *= 2; break;\n\n\t\tcase 'cpstr':\n\t\t\tif(typeof $cptable !== 'undefined') {\n\t\t\t\to = $cptable.utils.decode(current_codepage, this.slice(this.l, this.l + size));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t/* falls through */\n\t\tcase 'sbcs-cont': o = \"\"; loc = this.l;\n\t\t\tfor(i = 0; i != size; ++i) {\n\t\t\t\tif(this.lens && this.lens.indexOf(loc) !== -1) {\n\t\t\t\t\tw = __readUInt8(this, loc);\n\t\t\t\t\tthis.l = loc + 1;\n\t\t\t\t\tvv = ReadShift.call(this, size-i, w ? 'dbcs-cont' : 'sbcs-cont');\n\t\t\t\t\treturn oo.join(\"\") + vv;\n\t\t\t\t}\n\t\t\t\too.push(_getchar(__readUInt8(this, loc)));\n\t\t\t\tloc+=1;\n\t\t\t} o = oo.join(\"\"); break;\n\n\t\tdefault:\n\tswitch(size) {\n\t\tcase 1: oI = __readUInt8(this, this.l); this.l++; return oI;\n\t\tcase 2: oI = (t === 'i' ? __readInt16LE : __readUInt16LE)(this, this.l); this.l += 2; return oI;\n\t\tcase 4: case -4:\n\t\t\tif(t === 'i' || ((this[this.l+3] & 0x80)===0)) { oI = ((size > 0) ? __readInt32LE : __readInt32BE)(this, this.l); this.l += 4; return oI; }\n\t\t\telse { oR = __readUInt32LE(this, this.l); this.l += 4; } return oR;\n\t\tcase 8: case -8:\n\t\t\tif(t === 'f') {\n\t\t\t\tif(size == 8) oR = __double(this, this.l);\n\t\t\t\telse oR = __double([this[this.l+7],this[this.l+6],this[this.l+5],this[this.l+4],this[this.l+3],this[this.l+2],this[this.l+1],this[this.l+0]], 0);\n\t\t\t\tthis.l += 8; return oR;\n\t\t\t} else size = 8;\n\t\t/* falls through */\n\t\tcase 16: o = __hexlify(this, this.l, size); break;\n\t}}\n\tthis.l+=size; return o;\n}\n\nvar __writeUInt32LE = function(b/*:RawBytes|CFBlob*/, val/*:number*/, idx/*:number*/)/*:void*/ { b[idx] = (val & 0xFF); b[idx+1] = ((val >>> 8) & 0xFF); b[idx+2] = ((val >>> 16) & 0xFF); b[idx+3] = ((val >>> 24) & 0xFF); };\nvar __writeInt32LE = function(b/*:RawBytes|CFBlob*/, val/*:number*/, idx/*:number*/)/*:void*/ { b[idx] = (val & 0xFF); b[idx+1] = ((val >> 8) & 0xFF); b[idx+2] = ((val >> 16) & 0xFF); b[idx+3] = ((val >> 24) & 0xFF); };\nvar __writeUInt16LE = function(b/*:RawBytes|CFBlob*/, val/*:number*/, idx/*:number*/)/*:void*/ { b[idx] = (val & 0xFF); b[idx+1] = ((val >>> 8) & 0xFF); };\n\nfunction WriteShift(t/*:number*/, val/*:string|number*/, f/*:?string*/)/*:any*/ {\n\tvar size = 0, i = 0;\n\tif(f === 'dbcs') {\n\t\t/*:: if(typeof val !== 'string') throw new Error(\"unreachable\"); */\n\t\tfor(i = 0; i != val.length; ++i) __writeUInt16LE(this, val.charCodeAt(i), this.l + 2 * i);\n\t\tsize = 2 * val.length;\n\t} else if(f === 'sbcs') {\n\t\tif(typeof $cptable !== 'undefined' && current_ansi == 874) {\n\t\t\t/* TODO: use tables directly, don't encode */\n\t\t\t/*:: if(typeof val !== \"string\") throw new Error(\"unreachable\"); */\n\t\t\tfor(i = 0; i != val.length; ++i) {\n\t\t\t\tvar cppayload = $cptable.utils.encode(current_ansi, val.charAt(i));\n\t\t\t\tthis[this.l + i] = cppayload[0];\n\t\t\t}\n\t\t} else {\n\t\t\t/*:: if(typeof val !== 'string') throw new Error(\"unreachable\"); */\n\t\t\tval = val.replace(/[^\\x00-\\x7F]/g, \"_\");\n\t\t\t/*:: if(typeof val !== 'string') throw new Error(\"unreachable\"); */\n\t\t\tfor(i = 0; i != val.length; ++i) this[this.l + i] = (val.charCodeAt(i) & 0xFF);\n\t\t}\n\t\tsize = val.length;\n\t} else if(f === 'hex') {\n\t\tfor(; i < t; ++i) {\n\t\t\t/*:: if(typeof val !== \"string\") throw new Error(\"unreachable\"); */\n\t\t\tthis[this.l++] = (parseInt(val.slice(2*i, 2*i+2), 16)||0);\n\t\t} return this;\n\t} else if(f === 'utf16le') {\n\t\t\t/*:: if(typeof val !== \"string\") throw new Error(\"unreachable\"); */\n\t\t\tvar end/*:number*/ = Math.min(this.l + t, this.length);\n\t\t\tfor(i = 0; i < Math.min(val.length, t); ++i) {\n\t\t\t\tvar cc = val.charCodeAt(i);\n\t\t\t\tthis[this.l++] = (cc & 0xff);\n\t\t\t\tthis[this.l++] = (cc >> 8);\n\t\t\t}\n\t\t\twhile(this.l < end) this[this.l++] = 0;\n\t\t\treturn this;\n\t} else /*:: if(typeof val === 'number') */ switch(t) {\n\t\tcase 1: size = 1; this[this.l] = val&0xFF; break;\n\t\tcase 2: size = 2; this[this.l] = val&0xFF; val >>>= 8; this[this.l+1] = val&0xFF; break;\n\t\tcase 3: size = 3; this[this.l] = val&0xFF; val >>>= 8; this[this.l+1] = val&0xFF; val >>>= 8; this[this.l+2] = val&0xFF; break;\n\t\tcase 4: size = 4; __writeUInt32LE(this, val, this.l); break;\n\t\tcase 8: size = 8; if(f === 'f') { write_double_le(this, val, this.l); break; }\n\t\t/* falls through */\n\t\tcase 16: break;\n\t\tcase -4: size = 4; __writeInt32LE(this, val, this.l); break;\n\t}\n\tthis.l += size; return this;\n}\n\nfunction CheckField(hexstr/*:string*/, fld/*:string*/)/*:void*/ {\n\tvar m = __hexlify(this,this.l,hexstr.length>>1);\n\tif(m !== hexstr) throw new Error(fld + 'Expected ' + hexstr + ' saw ' + m);\n\tthis.l += hexstr.length>>1;\n}\n\nfunction prep_blob(blob, pos/*:number*/)/*:void*/ {\n\tblob.l = pos;\n\tblob.read_shift = /*::(*/ReadShift/*:: :any)*/;\n\tblob.chk = CheckField;\n\tblob.write_shift = WriteShift;\n}\n\nfunction parsenoop(blob, length/*:: :number, opts?:any */) { blob.l += length; }\n\nfunction new_buf(sz/*:number*/)/*:Block*/ {\n\tvar o = new_raw_buf(sz);\n\tprep_blob(o, 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.1.4 Record */\nfunction recordhopper(data, cb/*:RecordHopperCB*/, opts/*:?any*/) {\n\tif(!data) return;\n\tvar tmpbyte, cntbyte, length;\n\tprep_blob(data, data.l || 0);\n\tvar L = data.length, RT = 0, tgt = 0;\n\twhile(data.l < L) {\n\t\tRT = data.read_shift(1);\n\t\tif(RT & 0x80) RT = (RT & 0x7F) + ((data.read_shift(1) & 0x7F)<<7);\n\t\tvar R = XLSBRecordEnum[RT] || XLSBRecordEnum[0xFFFF];\n\t\ttmpbyte = data.read_shift(1);\n\t\tlength = tmpbyte & 0x7F;\n\t\tfor(cntbyte = 1; cntbyte <4 && (tmpbyte & 0x80); ++cntbyte) length += ((tmpbyte = data.read_shift(1)) & 0x7F)<<(7*cntbyte);\n\t\ttgt = data.l + length;\n\t\tvar d = R.f && R.f(data, length, opts);\n\t\tdata.l = tgt;\n\t\tif(cb(d, R, RT)) return;\n\t}\n}\n\n/* control buffer usage for fixed-length buffers */\nfunction buf_array()/*:BufArray*/ {\n\tvar bufs/*:Array<Block>*/ = [], blksz = has_buf ? 256 : 2048;\n\tvar newblk = function ba_newblk(sz/*:number*/)/*:Block*/ {\n\t\tvar o/*:Block*/ = (new_buf(sz)/*:any*/);\n\t\tprep_blob(o, 0);\n\t\treturn o;\n\t};\n\n\tvar curbuf/*:Block*/ = newblk(blksz);\n\n\tvar endbuf = function ba_endbuf() {\n\t\tif(!curbuf) return;\n\t\tif(curbuf.length > curbuf.l) { curbuf = curbuf.slice(0, curbuf.l); curbuf.l = curbuf.length; }\n\t\tif(curbuf.length > 0) bufs.push(curbuf);\n\t\tcurbuf = null;\n\t};\n\n\tvar next = function ba_next(sz/*:number*/)/*:Block*/ {\n\t\tif(curbuf && (sz < (curbuf.length - curbuf.l))) return curbuf;\n\t\tendbuf();\n\t\treturn (curbuf = newblk(Math.max(sz+1, blksz)));\n\t};\n\n\tvar end = function ba_end() {\n\t\tendbuf();\n\t\treturn bconcat(bufs);\n\t};\n\n\tvar push = function ba_push(buf) { endbuf(); curbuf = buf; if(curbuf.l == null) curbuf.l = curbuf.length; next(blksz); };\n\n\treturn ({ next:next, push:push, end:end, _bufs:bufs }/*:any*/);\n}\n\nfunction write_record(ba/*:BufArray*/, type/*:number*/, payload, length/*:?number*/) {\n\tvar t/*:number*/ = +type, l;\n\tif(isNaN(t)) return; // TODO: throw something here?\n\tif(!length) length = XLSBRecordEnum[t].p || (payload||[]).length || 0;\n\tl = 1 + (t >= 0x80 ? 1 : 0) + 1/* + length*/;\n\tif(length >= 0x80) ++l; if(length >= 0x4000) ++l; if(length >= 0x200000) ++l;\n\tvar o = ba.next(l);\n\tif(t <= 0x7F) o.write_shift(1, t);\n\telse {\n\t\to.write_shift(1, (t & 0x7F) + 0x80);\n\t\to.write_shift(1, (t >> 7));\n\t}\n\tfor(var i = 0; i != 4; ++i) {\n\t\tif(length >= 0x80) { o.write_shift(1, (length & 0x7F)+0x80); length >>= 7; }\n\t\telse { o.write_shift(1, length); break; }\n\t}\n\tif(/*:: length != null &&*/length > 0 && is_buf(payload)) ba.push(payload);\n}\n/* XLS ranges enforced */\nfunction shift_cell_xls(cell/*:CellAddress*/, tgt/*:any*/, opts/*:?any*/)/*:CellAddress*/ {\n\tvar out = dup(cell);\n\tif(tgt.s) {\n\t\tif(out.cRel) out.c += tgt.s.c;\n\t\tif(out.rRel) out.r += tgt.s.r;\n\t} else {\n\t\tif(out.cRel) out.c += tgt.c;\n\t\tif(out.rRel) out.r += tgt.r;\n\t}\n\tif(!opts || opts.biff < 12) {\n\t\twhile(out.c >= 0x100) out.c -= 0x100;\n\t\twhile(out.r >= 0x10000) out.r -= 0x10000;\n\t}\n\treturn out;\n}\n\nfunction shift_range_xls(cell, range, opts) {\n\tvar out = dup(cell);\n\tout.s = shift_cell_xls(out.s, range.s, opts);\n\tout.e = shift_cell_xls(out.e, range.s, opts);\n\treturn out;\n}\n\nfunction encode_cell_xls(c/*:CellAddress*/, biff/*:number*/)/*:string*/ {\n\tif(c.cRel && c.c < 0) { c = dup(c); while(c.c < 0) c.c += (biff > 8) ? 0x4000 : 0x100; }\n\tif(c.rRel && c.r < 0) { c = dup(c); while(c.r < 0) c.r += (biff > 8) ? 0x100000 : ((biff > 5) ? 0x10000 : 0x4000); }\n\tvar s = encode_cell(c);\n\tif(!c.cRel && c.cRel != null) s = fix_col(s);\n\tif(!c.rRel && c.rRel != null) s = fix_row(s);\n\treturn s;\n}\n\nfunction encode_range_xls(r, opts)/*:string*/ {\n\tif(r.s.r == 0 && !r.s.rRel) {\n\t\tif(r.e.r == (opts.biff >= 12 ? 0xFFFFF : (opts.biff >= 8 ? 0x10000 : 0x4000)) && !r.e.rRel) {\n\t\t\treturn (r.s.cRel ? \"\" : \"$\") + encode_col(r.s.c) + \":\" + (r.e.cRel ? \"\" : \"$\") + encode_col(r.e.c);\n\t\t}\n\t}\n\tif(r.s.c == 0 && !r.s.cRel) {\n\t\tif(r.e.c == (opts.biff >= 12 ? 0x3FFF : 0xFF) && !r.e.cRel) {\n\t\t\treturn (r.s.rRel ? \"\" : \"$\") + encode_row(r.s.r) + \":\" + (r.e.rRel ? \"\" : \"$\") + encode_row(r.e.r);\n\t\t}\n\t}\n\treturn encode_cell_xls(r.s, opts.biff) + \":\" + encode_cell_xls(r.e, opts.biff);\n}\nfunction decode_row(rowstr/*:string*/)/*:number*/ { return parseInt(unfix_row(rowstr),10) - 1; }\nfunction encode_row(row/*:number*/)/*:string*/ { return \"\" + (row + 1); }\nfunction fix_row(cstr/*:string*/)/*:string*/ { return cstr.replace(/([A-Z]|^)(\\d+)$/,\"$1$$$2\"); }\nfunction unfix_row(cstr/*:string*/)/*:string*/ { return cstr.replace(/\\$(\\d+)$/,\"$1\"); }\n\nfunction decode_col(colstr/*:string*/)/*:number*/ { var c = unfix_col(colstr), d = 0, i = 0; for(; i !== c.length; ++i) d = 26*d + c.charCodeAt(i) - 64; return d - 1; }\nfunction encode_col(col/*:number*/)/*:string*/ { if(col < 0) throw new Error(\"invalid column \" + col); var s=\"\"; for(++col; col; col=Math.floor((col-1)/26)) s = String.fromCharCode(((col-1)%26) + 65) + s; return s; }\nfunction fix_col(cstr/*:string*/)/*:string*/ { return cstr.replace(/^([A-Z])/,\"$$$1\"); }\nfunction unfix_col(cstr/*:string*/)/*:string*/ { return cstr.replace(/^\\$([A-Z])/,\"$1\"); }\n\nfunction split_cell(cstr/*:string*/)/*:Array<string>*/ { return cstr.replace(/(\\$?[A-Z]*)(\\$?\\d*)/,\"$1,$2\").split(\",\"); }\n//function decode_cell(cstr/*:string*/)/*:CellAddress*/ { var splt = split_cell(cstr); return { c:decode_col(splt[0]), r:decode_row(splt[1]) }; }\nfunction decode_cell(cstr/*:string*/)/*:CellAddress*/ {\n\tvar R = 0, C = 0;\n\tfor(var i = 0; i < cstr.length; ++i) {\n\t\tvar cc = cstr.charCodeAt(i);\n\t\tif(cc >= 48 && cc <= 57) R = 10 * R + (cc - 48);\n\t\telse if(cc >= 65 && cc <= 90) C = 26 * C + (cc - 64);\n\t}\n\treturn { c: C - 1, r:R - 1 };\n}\n//function encode_cell(cell/*:CellAddress*/)/*:string*/ { return encode_col(cell.c) + encode_row(cell.r); }\nfunction encode_cell(cell/*:CellAddress*/)/*:string*/ {\n\tvar col = cell.c + 1;\n\tvar s=\"\";\n\tfor(; col; col=((col-1)/26)|0) s = String.fromCharCode(((col-1)%26) + 65) + s;\n\treturn s + (cell.r + 1);\n}\nfunction decode_range(range/*:string*/)/*:Range*/ {\n\tvar idx = range.indexOf(\":\");\n\tif(idx == -1) return { s: decode_cell(range), e: decode_cell(range) };\n\treturn { s: decode_cell(range.slice(0, idx)), e: decode_cell(range.slice(idx + 1)) };\n}\n/*# if only one arg, it is assumed to be a Range. If 2 args, both are cell addresses */\nfunction encode_range(cs/*:CellAddrSpec|Range*/,ce/*:?CellAddrSpec*/)/*:string*/ {\n\tif(typeof ce === 'undefined' || typeof ce === 'number') {\n/*:: if(!(cs instanceof Range)) throw \"unreachable\"; */\n\t\treturn encode_range(cs.s, cs.e);\n\t}\n/*:: if((cs instanceof Range)) throw \"unreachable\"; */\n\tif(typeof cs !== 'string') cs = encode_cell((cs/*:any*/));\n\tif(typeof ce !== 'string') ce = encode_cell((ce/*:any*/));\n/*:: if(typeof cs !== 'string') throw \"unreachable\"; */\n/*:: if(typeof ce !== 'string') throw \"unreachable\"; */\n\treturn cs == ce ? cs : cs + \":\" + ce;\n}\n\nfunction safe_decode_range(range/*:string*/)/*:Range*/ {\n\tvar o = {s:{c:0,r:0},e:{c:0,r:0}};\n\tvar idx = 0, i = 0, cc = 0;\n\tvar len = range.length;\n\tfor(idx = 0; i < len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-64) < 1 || cc > 26) break;\n\t\tidx = 26*idx + cc;\n\t}\n\to.s.c = --idx;\n\n\tfor(idx = 0; i < len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-48) < 0 || cc > 9) break;\n\t\tidx = 10*idx + cc;\n\t}\n\to.s.r = --idx;\n\n\tif(i === len || cc != 10) { o.e.c=o.s.c; o.e.r=o.s.r; return o; }\n\t++i;\n\n\tfor(idx = 0; i != len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-64) < 1 || cc > 26) break;\n\t\tidx = 26*idx + cc;\n\t}\n\to.e.c = --idx;\n\n\tfor(idx = 0; i != len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-48) < 0 || cc > 9) break;\n\t\tidx = 10*idx + cc;\n\t}\n\to.e.r = --idx;\n\treturn o;\n}\n\nfunction safe_format_cell(cell/*:Cell*/, v/*:any*/) {\n\tvar q = (cell.t == 'd' && v instanceof Date);\n\tif(cell.z != null) try { return (cell.w = SSF_format(cell.z, q ? datenum(v) : v)); } catch(e) { }\n\ttry { return (cell.w = SSF_format((cell.XF||{}).numFmtId||(q ? 14 : 0), q ? datenum(v) : v)); } catch(e) { return ''+v; }\n}\n\nfunction format_cell(cell/*:Cell*/, v/*:any*/, o/*:any*/) {\n\tif(cell == null || cell.t == null || cell.t == 'z') return \"\";\n\tif(cell.w !== undefined) return cell.w;\n\tif(cell.t == 'd' && !cell.z && o && o.dateNF) cell.z = o.dateNF;\n\tif(cell.t == \"e\") return BErr[cell.v] || cell.v;\n\tif(v == undefined) return safe_format_cell(cell, cell.v);\n\treturn safe_format_cell(cell, v);\n}\n\nfunction sheet_to_workbook(sheet/*:Worksheet*/, opts)/*:Workbook*/ {\n\tvar n = opts && opts.sheet ? opts.sheet : \"Sheet1\";\n\tvar sheets = {}; sheets[n] = sheet;\n\treturn { SheetNames: [n], Sheets: sheets };\n}\n\nfunction sheet_add_aoa(_ws/*:?Worksheet*/, data/*:AOA*/, opts/*:?any*/)/*:Worksheet*/ {\n\tvar o = opts || {};\n\tvar dense = _ws ? Array.isArray(_ws) : o.dense;\n\tif(DENSE != null && dense == null) dense = DENSE;\n\tvar ws/*:Worksheet*/ = _ws || (dense ? ([]/*:any*/) : ({}/*:any*/));\n\tvar _R = 0, _C = 0;\n\tif(ws && o.origin != null) {\n\t\tif(typeof o.origin == 'number') _R = o.origin;\n\t\telse {\n\t\t\tvar _origin/*:CellAddress*/ = typeof o.origin == \"string\" ? decode_cell(o.origin) : o.origin;\n\t\t\t_R = _origin.r; _C = _origin.c;\n\t\t}\n\t\tif(!ws[\"!ref\"]) ws[\"!ref\"] = \"A1:A1\";\n\t}\n\tvar range/*:Range*/ = ({s: {c:10000000, r:10000000}, e: {c:0, r:0}}/*:any*/);\n\tif(ws['!ref']) {\n\t\tvar _range = safe_decode_range(ws['!ref']);\n\t\trange.s.c = _range.s.c;\n\t\trange.s.r = _range.s.r;\n\t\trange.e.c = Math.max(range.e.c, _range.e.c);\n\t\trange.e.r = Math.max(range.e.r, _range.e.r);\n\t\tif(_R == -1) range.e.r = _R = _range.e.r + 1;\n\t}\n\tfor(var R = 0; R != data.length; ++R) {\n\t\tif(!data[R]) continue;\n\t\tif(!Array.isArray(data[R])) throw new Error(\"aoa_to_sheet expects an array of arrays\");\n\t\tfor(var C = 0; C != data[R].length; ++C) {\n\t\t\tif(typeof data[R][C] === 'undefined') continue;\n\t\t\tvar cell/*:Cell*/ = ({v: data[R][C] }/*:any*/);\n\t\t\tvar __R = _R + R, __C = _C + C;\n\t\t\tif(range.s.r > __R) range.s.r = __R;\n\t\t\tif(range.s.c > __C) range.s.c = __C;\n\t\t\tif(range.e.r < __R) range.e.r = __R;\n\t\t\tif(range.e.c < __C) range.e.c = __C;\n\t\t\tif(data[R][C] && typeof data[R][C] === 'object' && !Array.isArray(data[R][C]) && !(data[R][C] instanceof Date)) cell = data[R][C];\n\t\t\telse {\n\t\t\t\tif(Array.isArray(cell.v)) { cell.f = data[R][C][1]; cell.v = cell.v[0]; }\n\t\t\t\tif(cell.v === null) {\n\t\t\t\t\tif(cell.f) cell.t = 'n';\n\t\t\t\t\telse if(o.nullError) { cell.t = 'e'; cell.v = 0; }\n\t\t\t\t\telse if(!o.sheetStubs) continue;\n\t\t\t\t\telse cell.t = 'z';\n\t\t\t\t}\n\t\t\t\telse if(typeof cell.v === 'number') cell.t = 'n';\n\t\t\t\telse if(typeof cell.v === 'boolean') cell.t = 'b';\n\t\t\t\telse if(cell.v instanceof Date) {\n\t\t\t\t\tcell.z = o.dateNF || table_fmt[14];\n\t\t\t\t\tif(o.cellDates) { cell.t = 'd'; cell.w = SSF_format(cell.z, datenum(cell.v)); }\n\t\t\t\t\telse { cell.t = 'n'; cell.v = datenum(cell.v); cell.w = SSF_format(cell.z, cell.v); }\n\t\t\t\t}\n\t\t\t\telse cell.t = 's';\n\t\t\t}\n\t\t\tif(dense) {\n\t\t\t\tif(!ws[__R]) ws[__R] = [];\n\t\t\t\tif(ws[__R][__C] && ws[__R][__C].z) cell.z = ws[__R][__C].z;\n\t\t\t\tws[__R][__C] = cell;\n\t\t\t} else {\n\t\t\t\tvar cell_ref = encode_cell(({c:__C,r:__R}/*:any*/));\n\t\t\t\tif(ws[cell_ref] && ws[cell_ref].z) cell.z = ws[cell_ref].z;\n\t\t\t\tws[cell_ref] = cell;\n\t\t\t}\n\t\t}\n\t}\n\tif(range.s.c < 10000000) ws['!ref'] = encode_range(range);\n\treturn ws;\n}\nfunction aoa_to_sheet(data/*:AOA*/, opts/*:?any*/)/*:Worksheet*/ { return sheet_add_aoa(null, data, opts); }\n\nfunction parse_Int32LE(data) {\n\treturn data.read_shift(4, 'i');\n}\nfunction write_UInt32LE(x/*:number*/, o) {\n\tif (!o) o = new_buf(4);\n\to.write_shift(4, x);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.168 */\nfunction parse_XLWideString(data/*::, length*/)/*:string*/ {\n\tvar cchCharacters = data.read_shift(4);\n\treturn cchCharacters === 0 ? \"\" : data.read_shift(cchCharacters, 'dbcs');\n}\nfunction write_XLWideString(data/*:string*/, o) {\n\tvar _null = false; if (o == null) { _null = true; o = new_buf(4 + 2 * data.length); }\n\to.write_shift(4, data.length);\n\tif (data.length > 0) o.write_shift(0, data, 'dbcs');\n\treturn _null ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.5.91 */\n//function parse_LPWideString(data/*::, length*/)/*:string*/ {\n//\tvar cchCharacters = data.read_shift(2);\n//\treturn cchCharacters === 0 ? \"\" : data.read_shift(cchCharacters, \"utf16le\");\n//}\n\n/* [MS-XLSB] 2.5.143 */\nfunction parse_StrRun(data) {\n\treturn { ich: data.read_shift(2), ifnt: data.read_shift(2) };\n}\nfunction write_StrRun(run, o) {\n\tif (!o) o = new_buf(4);\n\to.write_shift(2, run.ich || 0);\n\to.write_shift(2, run.ifnt || 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.121 */\nfunction parse_RichStr(data, length/*:number*/)/*:XLString*/ {\n\tvar start = data.l;\n\tvar flags = data.read_shift(1);\n\tvar str = parse_XLWideString(data);\n\tvar rgsStrRun = [];\n\tvar z = ({ t: str, h: str }/*:any*/);\n\tif ((flags & 1) !== 0) { /* fRichStr */\n\t\t/* TODO: formatted string */\n\t\tvar dwSizeStrRun = data.read_shift(4);\n\t\tfor (var i = 0; i != dwSizeStrRun; ++i) rgsStrRun.push(parse_StrRun(data));\n\t\tz.r = rgsStrRun;\n\t}\n\telse z.r = [{ ich: 0, ifnt: 0 }];\n\t//if((flags & 2) !== 0) { /* fExtStr */\n\t//\t/* TODO: phonetic string */\n\t//}\n\tdata.l = start + length;\n\treturn z;\n}\nfunction write_RichStr(str/*:XLString*/, o/*:?Block*/)/*:Block*/ {\n\t/* TODO: formatted string */\n\tvar _null = false; if (o == null) { _null = true; o = new_buf(15 + 4 * str.t.length); }\n\to.write_shift(1, 0);\n\twrite_XLWideString(str.t, o);\n\treturn _null ? o.slice(0, o.l) : o;\n}\n/* [MS-XLSB] 2.4.328 BrtCommentText (RichStr w/1 run) */\nvar parse_BrtCommentText = parse_RichStr;\nfunction write_BrtCommentText(str/*:XLString*/, o/*:?Block*/)/*:Block*/ {\n\t/* TODO: formatted string */\n\tvar _null = false; if (o == null) { _null = true; o = new_buf(23 + 4 * str.t.length); }\n\to.write_shift(1, 1);\n\twrite_XLWideString(str.t, o);\n\to.write_shift(4, 1);\n\twrite_StrRun({ ich: 0, ifnt: 0 }, o);\n\treturn _null ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.5.9 */\nfunction parse_XLSBCell(data)/*:any*/ {\n\tvar col = data.read_shift(4);\n\tvar iStyleRef = data.read_shift(2);\n\tiStyleRef += data.read_shift(1) << 16;\n\tdata.l++; //var fPhShow = data.read_shift(1);\n\treturn { c: col, iStyleRef: iStyleRef };\n}\nfunction write_XLSBCell(cell/*:any*/, o/*:?Block*/) {\n\tif (o == null) o = new_buf(8);\n\to.write_shift(-4, cell.c);\n\to.write_shift(3, cell.iStyleRef || cell.s);\n\to.write_shift(1, 0); /* fPhShow */\n\treturn o;\n}\n\n/* Short XLSB Cell does not include column */\nfunction parse_XLSBShortCell(data)/*:any*/ {\n\tvar iStyleRef = data.read_shift(2);\n\tiStyleRef += data.read_shift(1) <<16;\n\tdata.l++; //var fPhShow = data.read_shift(1);\n\treturn { c:-1, iStyleRef: iStyleRef };\n}\nfunction write_XLSBShortCell(cell/*:any*/, o/*:?Block*/) {\n\tif(o == null) o = new_buf(4);\n\to.write_shift(3, cell.iStyleRef || cell.s);\n\to.write_shift(1, 0); /* fPhShow */\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.21 */\nvar parse_XLSBCodeName = parse_XLWideString;\nvar write_XLSBCodeName = write_XLWideString;\n\n/* [MS-XLSB] 2.5.166 */\nfunction parse_XLNullableWideString(data/*::, length*/)/*:string*/ {\n\tvar cchCharacters = data.read_shift(4);\n\treturn cchCharacters === 0 || cchCharacters === 0xFFFFFFFF ? \"\" : data.read_shift(cchCharacters, 'dbcs');\n}\nfunction write_XLNullableWideString(data/*:string*/, o) {\n\tvar _null = false; if (o == null) { _null = true; o = new_buf(127); }\n\to.write_shift(4, data.length > 0 ? data.length : 0xFFFFFFFF);\n\tif (data.length > 0) o.write_shift(0, data, 'dbcs');\n\treturn _null ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.5.165 */\nvar parse_XLNameWideString = parse_XLWideString;\n//var write_XLNameWideString = write_XLWideString;\n\n/* [MS-XLSB] 2.5.114 */\nvar parse_RelID = parse_XLNullableWideString;\nvar write_RelID = write_XLNullableWideString;\n\n\n/* [MS-XLS] 2.5.217 ; [MS-XLSB] 2.5.122 */\nfunction parse_RkNumber(data)/*:number*/ {\n\tvar b = data.slice(data.l, data.l + 4);\n\tvar fX100 = (b[0] & 1), fInt = (b[0] & 2);\n\tdata.l += 4;\n\tvar RK = fInt === 0 ? __double([0, 0, 0, 0, (b[0] & 0xFC), b[1], b[2], b[3]], 0) : __readInt32LE(b, 0) >> 2;\n\treturn fX100 ? (RK / 100) : RK;\n}\nfunction write_RkNumber(data/*:number*/, o) {\n\tif (o == null) o = new_buf(4);\n\tvar fX100 = 0, fInt = 0, d100 = data * 100;\n\tif ((data == (data | 0)) && (data >= -(1 << 29)) && (data < (1 << 29))) { fInt = 1; }\n\telse if ((d100 == (d100 | 0)) && (d100 >= -(1 << 29)) && (d100 < (1 << 29))) { fInt = 1; fX100 = 1; }\n\tif (fInt) o.write_shift(-4, ((fX100 ? d100 : data) << 2) + (fX100 + 2));\n\telse throw new Error(\"unsupported RkNumber \" + data); // TODO\n}\n\n\n/* [MS-XLSB] 2.5.117 RfX */\nfunction parse_RfX(data /*::, length*/)/*:Range*/ {\n\tvar cell/*:Range*/ = ({ s: {}, e: {} }/*:any*/);\n\tcell.s.r = data.read_shift(4);\n\tcell.e.r = data.read_shift(4);\n\tcell.s.c = data.read_shift(4);\n\tcell.e.c = data.read_shift(4);\n\treturn cell;\n}\nfunction write_RfX(r/*:Range*/, o) {\n\tif (!o) o = new_buf(16);\n\to.write_shift(4, r.s.r);\n\to.write_shift(4, r.e.r);\n\to.write_shift(4, r.s.c);\n\to.write_shift(4, r.e.c);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.153 UncheckedRfX */\nvar parse_UncheckedRfX = parse_RfX;\nvar write_UncheckedRfX = write_RfX;\n\n/* [MS-XLSB] 2.5.155 UncheckedSqRfX */\n//function parse_UncheckedSqRfX(data) {\n//\tvar cnt = data.read_shift(4);\n//\tvar out = [];\n//\tfor(var i = 0; i < cnt; ++i) {\n//\t\tvar rng = parse_UncheckedRfX(data);\n//\t\tout.push(encode_range(rng));\n//\t}\n//\treturn out.join(\",\");\n//}\n//function write_UncheckedSqRfX(sqrfx/*:string*/) {\n//\tvar parts = sqrfx.split(/\\s*,\\s*/);\n//\tvar o = new_buf(4); o.write_shift(4, parts.length);\n//\tvar out = [o];\n//\tparts.forEach(function(rng) {\n//\t\tout.push(write_UncheckedRfX(safe_decode_range(rng)));\n//\t});\n//\treturn bconcat(out);\n//}\n\n/* [MS-XLS] 2.5.342 ; [MS-XLSB] 2.5.171 */\n/* TODO: error checking, NaN and Infinity values are not valid Xnum */\nfunction parse_Xnum(data/*::, length*/) {\n\tif(data.length - data.l < 8) throw \"XLS Xnum Buffer underflow\";\n\treturn data.read_shift(8, 'f');\n}\nfunction write_Xnum(data, o) { return (o || new_buf(8)).write_shift(8, data, 'f'); }\n\n/* [MS-XLSB] 2.4.324 BrtColor */\nfunction parse_BrtColor(data/*::, length*/) {\n\tvar out = {};\n\tvar d = data.read_shift(1);\n\n\t//var fValidRGB = d & 1;\n\tvar xColorType = d >>> 1;\n\n\tvar index = data.read_shift(1);\n\tvar nTS = data.read_shift(2, 'i');\n\tvar bR = data.read_shift(1);\n\tvar bG = data.read_shift(1);\n\tvar bB = data.read_shift(1);\n\tdata.l++; //var bAlpha = data.read_shift(1);\n\n\tswitch (xColorType) {\n\t\tcase 0: out.auto = 1; break;\n\t\tcase 1:\n\t\t\tout.index = index;\n\t\t\tvar icv = XLSIcv[index];\n\t\t\t/* automatic pseudo index 81 */\n\t\t\tif (icv) out.rgb = rgb2Hex(icv);\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\t/* if(!fValidRGB) throw new Error(\"invalid\"); */\n\t\t\tout.rgb = rgb2Hex([bR, bG, bB]);\n\t\t\tbreak;\n\t\tcase 3: out.theme = index; break;\n\t}\n\tif (nTS != 0) out.tint = nTS > 0 ? nTS / 32767 : nTS / 32768;\n\n\treturn out;\n}\nfunction write_BrtColor(color, o) {\n\tif (!o) o = new_buf(8);\n\tif (!color || color.auto) { o.write_shift(4, 0); o.write_shift(4, 0); return o; }\n\tif (color.index != null) {\n\t\to.write_shift(1, 0x02);\n\t\to.write_shift(1, color.index);\n\t} else if (color.theme != null) {\n\t\to.write_shift(1, 0x06);\n\t\to.write_shift(1, color.theme);\n\t} else {\n\t\to.write_shift(1, 0x05);\n\t\to.write_shift(1, 0);\n\t}\n\tvar nTS = color.tint || 0;\n\tif (nTS > 0) nTS *= 32767;\n\telse if (nTS < 0) nTS *= 32768;\n\to.write_shift(2, nTS);\n\tif (!color.rgb || color.theme != null) {\n\t\to.write_shift(2, 0);\n\t\to.write_shift(1, 0);\n\t\to.write_shift(1, 0);\n\t} else {\n\t\tvar rgb = (color.rgb || 'FFFFFF');\n\t\tif (typeof rgb == 'number') rgb = (\"000000\" + rgb.toString(16)).slice(-6);\n\t\to.write_shift(1, parseInt(rgb.slice(0, 2), 16));\n\t\to.write_shift(1, parseInt(rgb.slice(2, 4), 16));\n\t\to.write_shift(1, parseInt(rgb.slice(4, 6), 16));\n\t\to.write_shift(1, 0xFF);\n\t}\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.52 */\nfunction parse_FontFlags(data/*::, length, opts*/) {\n\tvar d = data.read_shift(1);\n\tdata.l++;\n\tvar out = {\n\t\tfBold: d & 0x01,\n\t\tfItalic: d & 0x02,\n\t\tfUnderline: d & 0x04,\n\t\tfStrikeout: d & 0x08,\n\t\tfOutline: d & 0x10,\n\t\tfShadow: d & 0x20,\n\t\tfCondense: d & 0x40,\n\t\tfExtend: d & 0x80\n\t};\n\treturn out;\n}\nfunction write_FontFlags(font, o) {\n\tif (!o) o = new_buf(2);\n\tvar grbit =\n\t\t(font.italic ? 0x02 : 0) |\n\t\t(font.strike ? 0x08 : 0) |\n\t\t(font.outline ? 0x10 : 0) |\n\t\t(font.shadow ? 0x20 : 0) |\n\t\t(font.condense ? 0x40 : 0) |\n\t\t(font.extend ? 0x80 : 0);\n\to.write_shift(1, grbit);\n\to.write_shift(1, 0);\n\treturn o;\n}\n\n/* [MS-OLEDS] 2.3.1 and 2.3.2 */\nfunction parse_ClipboardFormatOrString(o, w/*:number*/)/*:string*/ {\n\t// $FlowIgnore\n\tvar ClipFmt = { 2: \"BITMAP\", 3: \"METAFILEPICT\", 8: \"DIB\", 14: \"ENHMETAFILE\" };\n\tvar m/*:number*/ = o.read_shift(4);\n\tswitch (m) {\n\t\tcase 0x00000000: return \"\";\n\t\tcase 0xffffffff: case 0xfffffffe: return ClipFmt[o.read_shift(4)] || \"\";\n\t}\n\tif (m > 0x190) throw new Error(\"Unsupported Clipboard: \" + m.toString(16));\n\to.l -= 4;\n\treturn o.read_shift(0, w == 1 ? \"lpstr\" : \"lpwstr\");\n}\nfunction parse_ClipboardFormatOrAnsiString(o) { return parse_ClipboardFormatOrString(o, 1); }\nfunction parse_ClipboardFormatOrUnicodeString(o) { return parse_ClipboardFormatOrString(o, 2); }\n\n/* [MS-OLEPS] 2.2 PropertyType */\n// Note: some tree shakers cannot handle VT_VECTOR | $CONST, hence extra vars\n//var VT_EMPTY = 0x0000;\n//var VT_NULL = 0x0001;\nvar VT_I2 = 0x0002;\nvar VT_I4 = 0x0003;\n//var VT_R4 = 0x0004;\n//var VT_R8 = 0x0005;\n//var VT_CY = 0x0006;\n//var VT_DATE = 0x0007;\n//var VT_BSTR = 0x0008;\n//var VT_ERROR = 0x000A;\nvar VT_BOOL = 0x000B;\nvar VT_VARIANT = 0x000C;\n//var VT_DECIMAL = 0x000E;\n//var VT_I1 = 0x0010;\n//var VT_UI1 = 0x0011;\n//var VT_UI2 = 0x0012;\nvar VT_UI4 = 0x0013;\n//var VT_I8 = 0x0014;\n//var VT_UI8 = 0x0015;\n//var VT_INT = 0x0016;\n//var VT_UINT = 0x0017;\nvar VT_LPSTR = 0x001E;\n//var VT_LPWSTR = 0x001F;\nvar VT_FILETIME = 0x0040;\nvar VT_BLOB = 0x0041;\n//var VT_STREAM = 0x0042;\n//var VT_STORAGE = 0x0043;\n//var VT_STREAMED_Object = 0x0044;\n//var VT_STORED_Object = 0x0045;\n//var VT_BLOB_Object = 0x0046;\nvar VT_CF = 0x0047;\n//var VT_CLSID = 0x0048;\n//var VT_VERSIONED_STREAM = 0x0049;\nvar VT_VECTOR = 0x1000;\nvar VT_VECTOR_VARIANT = 0x100C;\nvar VT_VECTOR_LPSTR = 0x101E;\n//var VT_ARRAY = 0x2000;\n\nvar VT_STRING = 0x0050; // 2.3.3.1.11 VtString\nvar VT_USTR = 0x0051; // 2.3.3.1.12 VtUnalignedString\nvar VT_CUSTOM = [VT_STRING, VT_USTR];\n\n/* [MS-OSHARED] 2.3.3.2.2.1 Document Summary Information PIDDSI */\nvar DocSummaryPIDDSI = {\n\t/*::[*/0x01/*::]*/: { n: 'CodePage', t: VT_I2 },\n\t/*::[*/0x02/*::]*/: { n: 'Category', t: VT_STRING },\n\t/*::[*/0x03/*::]*/: { n: 'PresentationFormat', t: VT_STRING },\n\t/*::[*/0x04/*::]*/: { n: 'ByteCount', t: VT_I4 },\n\t/*::[*/0x05/*::]*/: { n: 'LineCount', t: VT_I4 },\n\t/*::[*/0x06/*::]*/: { n: 'ParagraphCount', t: VT_I4 },\n\t/*::[*/0x07/*::]*/: { n: 'SlideCount', t: VT_I4 },\n\t/*::[*/0x08/*::]*/: { n: 'NoteCount', t: VT_I4 },\n\t/*::[*/0x09/*::]*/: { n: 'HiddenCount', t: VT_I4 },\n\t/*::[*/0x0a/*::]*/: { n: 'MultimediaClipCount', t: VT_I4 },\n\t/*::[*/0x0b/*::]*/: { n: 'ScaleCrop', t: VT_BOOL },\n\t/*::[*/0x0c/*::]*/: { n: 'HeadingPairs', t: VT_VECTOR_VARIANT /* VT_VECTOR | VT_VARIANT */ },\n\t/*::[*/0x0d/*::]*/: { n: 'TitlesOfParts', t: VT_VECTOR_LPSTR /* VT_VECTOR | VT_LPSTR */ },\n\t/*::[*/0x0e/*::]*/: { n: 'Manager', t: VT_STRING },\n\t/*::[*/0x0f/*::]*/: { n: 'Company', t: VT_STRING },\n\t/*::[*/0x10/*::]*/: { n: 'LinksUpToDate', t: VT_BOOL },\n\t/*::[*/0x11/*::]*/: { n: 'CharacterCount', t: VT_I4 },\n\t/*::[*/0x13/*::]*/: { n: 'SharedDoc', t: VT_BOOL },\n\t/*::[*/0x16/*::]*/: { n: 'HyperlinksChanged', t: VT_BOOL },\n\t/*::[*/0x17/*::]*/: { n: 'AppVersion', t: VT_I4, p: 'version' },\n\t/*::[*/0x18/*::]*/: { n: 'DigSig', t: VT_BLOB },\n\t/*::[*/0x1A/*::]*/: { n: 'ContentType', t: VT_STRING },\n\t/*::[*/0x1B/*::]*/: { n: 'ContentStatus', t: VT_STRING },\n\t/*::[*/0x1C/*::]*/: { n: 'Language', t: VT_STRING },\n\t/*::[*/0x1D/*::]*/: { n: 'Version', t: VT_STRING },\n\t/*::[*/0xFF/*::]*/: {},\n\t/* [MS-OLEPS] 2.18 */\n\t/*::[*/0x80000000/*::]*/: { n: 'Locale', t: VT_UI4 },\n\t/*::[*/0x80000003/*::]*/: { n: 'Behavior', t: VT_UI4 },\n\t/*::[*/0x72627262/*::]*/: {}\n};\n\n/* [MS-OSHARED] 2.3.3.2.1.1 Summary Information Property Set PIDSI */\nvar SummaryPIDSI = {\n\t/*::[*/0x01/*::]*/: { n: 'CodePage', t: VT_I2 },\n\t/*::[*/0x02/*::]*/: { n: 'Title', t: VT_STRING },\n\t/*::[*/0x03/*::]*/: { n: 'Subject', t: VT_STRING },\n\t/*::[*/0x04/*::]*/: { n: 'Author', t: VT_STRING },\n\t/*::[*/0x05/*::]*/: { n: 'Keywords', t: VT_STRING },\n\t/*::[*/0x06/*::]*/: { n: 'Comments', t: VT_STRING },\n\t/*::[*/0x07/*::]*/: { n: 'Template', t: VT_STRING },\n\t/*::[*/0x08/*::]*/: { n: 'LastAuthor', t: VT_STRING },\n\t/*::[*/0x09/*::]*/: { n: 'RevNumber', t: VT_STRING },\n\t/*::[*/0x0A/*::]*/: { n: 'EditTime', t: VT_FILETIME },\n\t/*::[*/0x0B/*::]*/: { n: 'LastPrinted', t: VT_FILETIME },\n\t/*::[*/0x0C/*::]*/: { n: 'CreatedDate', t: VT_FILETIME },\n\t/*::[*/0x0D/*::]*/: { n: 'ModifiedDate', t: VT_FILETIME },\n\t/*::[*/0x0E/*::]*/: { n: 'PageCount', t: VT_I4 },\n\t/*::[*/0x0F/*::]*/: { n: 'WordCount', t: VT_I4 },\n\t/*::[*/0x10/*::]*/: { n: 'CharCount', t: VT_I4 },\n\t/*::[*/0x11/*::]*/: { n: 'Thumbnail', t: VT_CF },\n\t/*::[*/0x12/*::]*/: { n: 'Application', t: VT_STRING },\n\t/*::[*/0x13/*::]*/: { n: 'DocSecurity', t: VT_I4 },\n\t/*::[*/0xFF/*::]*/: {},\n\t/* [MS-OLEPS] 2.18 */\n\t/*::[*/0x80000000/*::]*/: { n: 'Locale', t: VT_UI4 },\n\t/*::[*/0x80000003/*::]*/: { n: 'Behavior', t: VT_UI4 },\n\t/*::[*/0x72627262/*::]*/: {}\n};\n\n/* [MS-XLS] 2.4.63 Country/Region codes */\nvar CountryEnum = {\n\t/*::[*/0x0001/*::]*/: \"US\", // United States\n\t/*::[*/0x0002/*::]*/: \"CA\", // Canada\n\t/*::[*/0x0003/*::]*/: \"\", // Latin America (except Brazil)\n\t/*::[*/0x0007/*::]*/: \"RU\", // Russia\n\t/*::[*/0x0014/*::]*/: \"EG\", // Egypt\n\t/*::[*/0x001E/*::]*/: \"GR\", // Greece\n\t/*::[*/0x001F/*::]*/: \"NL\", // Netherlands\n\t/*::[*/0x0020/*::]*/: \"BE\", // Belgium\n\t/*::[*/0x0021/*::]*/: \"FR\", // France\n\t/*::[*/0x0022/*::]*/: \"ES\", // Spain\n\t/*::[*/0x0024/*::]*/: \"HU\", // Hungary\n\t/*::[*/0x0027/*::]*/: \"IT\", // Italy\n\t/*::[*/0x0029/*::]*/: \"CH\", // Switzerland\n\t/*::[*/0x002B/*::]*/: \"AT\", // Austria\n\t/*::[*/0x002C/*::]*/: \"GB\", // United Kingdom\n\t/*::[*/0x002D/*::]*/: \"DK\", // Denmark\n\t/*::[*/0x002E/*::]*/: \"SE\", // Sweden\n\t/*::[*/0x002F/*::]*/: \"NO\", // Norway\n\t/*::[*/0x0030/*::]*/: \"PL\", // Poland\n\t/*::[*/0x0031/*::]*/: \"DE\", // Germany\n\t/*::[*/0x0034/*::]*/: \"MX\", // Mexico\n\t/*::[*/0x0037/*::]*/: \"BR\", // Brazil\n\t/*::[*/0x003d/*::]*/: \"AU\", // Australia\n\t/*::[*/0x0040/*::]*/: \"NZ\", // New Zealand\n\t/*::[*/0x0042/*::]*/: \"TH\", // Thailand\n\t/*::[*/0x0051/*::]*/: \"JP\", // Japan\n\t/*::[*/0x0052/*::]*/: \"KR\", // Korea\n\t/*::[*/0x0054/*::]*/: \"VN\", // Viet Nam\n\t/*::[*/0x0056/*::]*/: \"CN\", // China\n\t/*::[*/0x005A/*::]*/: \"TR\", // Turkey\n\t/*::[*/0x0069/*::]*/: \"JS\", // Ramastan\n\t/*::[*/0x00D5/*::]*/: \"DZ\", // Algeria\n\t/*::[*/0x00D8/*::]*/: \"MA\", // Morocco\n\t/*::[*/0x00DA/*::]*/: \"LY\", // Libya\n\t/*::[*/0x015F/*::]*/: \"PT\", // Portugal\n\t/*::[*/0x0162/*::]*/: \"IS\", // Iceland\n\t/*::[*/0x0166/*::]*/: \"FI\", // Finland\n\t/*::[*/0x01A4/*::]*/: \"CZ\", // Czech Republic\n\t/*::[*/0x0376/*::]*/: \"TW\", // Taiwan\n\t/*::[*/0x03C1/*::]*/: \"LB\", // Lebanon\n\t/*::[*/0x03C2/*::]*/: \"JO\", // Jordan\n\t/*::[*/0x03C3/*::]*/: \"SY\", // Syria\n\t/*::[*/0x03C4/*::]*/: \"IQ\", // Iraq\n\t/*::[*/0x03C5/*::]*/: \"KW\", // Kuwait\n\t/*::[*/0x03C6/*::]*/: \"SA\", // Saudi Arabia\n\t/*::[*/0x03CB/*::]*/: \"AE\", // United Arab Emirates\n\t/*::[*/0x03CC/*::]*/: \"IL\", // Israel\n\t/*::[*/0x03CE/*::]*/: \"QA\", // Qatar\n\t/*::[*/0x03D5/*::]*/: \"IR\", // Iran\n\t/*::[*/0xFFFF/*::]*/: \"US\" // United States\n};\n\n/* [MS-XLS] 2.5.127 */\nvar XLSFillPattern = [\n\tnull,\n\t'solid',\n\t'mediumGray',\n\t'darkGray',\n\t'lightGray',\n\t'darkHorizontal',\n\t'darkVertical',\n\t'darkDown',\n\t'darkUp',\n\t'darkGrid',\n\t'darkTrellis',\n\t'lightHorizontal',\n\t'lightVertical',\n\t'lightDown',\n\t'lightUp',\n\t'lightGrid',\n\t'lightTrellis',\n\t'gray125',\n\t'gray0625'\n];\n\nfunction rgbify(arr/*:Array<number>*/)/*:Array<[number, number, number]>*/ { return arr.map(function(x) { return [(x>>16)&255,(x>>8)&255,x&255]; }); }\n\n/* [MS-XLS] 2.5.161 */\n/* [MS-XLSB] 2.5.75 Icv */\nvar _XLSIcv = /*#__PURE__*/ rgbify([\n\t/* Color Constants */\n\t0x000000,\n\t0xFFFFFF,\n\t0xFF0000,\n\t0x00FF00,\n\t0x0000FF,\n\t0xFFFF00,\n\t0xFF00FF,\n\t0x00FFFF,\n\n\t/* Overridable Defaults */\n\t0x000000,\n\t0xFFFFFF,\n\t0xFF0000,\n\t0x00FF00,\n\t0x0000FF,\n\t0xFFFF00,\n\t0xFF00FF,\n\t0x00FFFF,\n\n\t0x800000,\n\t0x008000,\n\t0x000080,\n\t0x808000,\n\t0x800080,\n\t0x008080,\n\t0xC0C0C0,\n\t0x808080,\n\t0x9999FF,\n\t0x993366,\n\t0xFFFFCC,\n\t0xCCFFFF,\n\t0x660066,\n\t0xFF8080,\n\t0x0066CC,\n\t0xCCCCFF,\n\n\t0x000080,\n\t0xFF00FF,\n\t0xFFFF00,\n\t0x00FFFF,\n\t0x800080,\n\t0x800000,\n\t0x008080,\n\t0x0000FF,\n\t0x00CCFF,\n\t0xCCFFFF,\n\t0xCCFFCC,\n\t0xFFFF99,\n\t0x99CCFF,\n\t0xFF99CC,\n\t0xCC99FF,\n\t0xFFCC99,\n\n\t0x3366FF,\n\t0x33CCCC,\n\t0x99CC00,\n\t0xFFCC00,\n\t0xFF9900,\n\t0xFF6600,\n\t0x666699,\n\t0x969696,\n\t0x003366,\n\t0x339966,\n\t0x003300,\n\t0x333300,\n\t0x993300,\n\t0x993366,\n\t0x333399,\n\t0x333333,\n\n\t/* Other entries to appease BIFF8/12 */\n\t0xFFFFFF, /* 0x40 icvForeground ?? */\n\t0x000000, /* 0x41 icvBackground ?? */\n\t0x000000, /* 0x42 icvFrame ?? */\n\t0x000000, /* 0x43 icv3D ?? */\n\t0x000000, /* 0x44 icv3DText ?? */\n\t0x000000, /* 0x45 icv3DHilite ?? */\n\t0x000000, /* 0x46 icv3DShadow ?? */\n\t0x000000, /* 0x47 icvHilite ?? */\n\t0x000000, /* 0x48 icvCtlText ?? */\n\t0x000000, /* 0x49 icvCtlScrl ?? */\n\t0x000000, /* 0x4A icvCtlInv ?? */\n\t0x000000, /* 0x4B icvCtlBody ?? */\n\t0x000000, /* 0x4C icvCtlFrame ?? */\n\t0x000000, /* 0x4D icvCtlFore ?? */\n\t0x000000, /* 0x4E icvCtlBack ?? */\n\t0x000000, /* 0x4F icvCtlNeutral */\n\t0x000000, /* 0x50 icvInfoBk ?? */\n\t0x000000 /* 0x51 icvInfoText ?? */\n]);\nvar XLSIcv = /*#__PURE__*/dup(_XLSIcv);\n\n/* [MS-XLSB] 2.5.97.2 */\nvar BErr = {\n\t/*::[*/0x00/*::]*/: \"#NULL!\",\n\t/*::[*/0x07/*::]*/: \"#DIV/0!\",\n\t/*::[*/0x0F/*::]*/: \"#VALUE!\",\n\t/*::[*/0x17/*::]*/: \"#REF!\",\n\t/*::[*/0x1D/*::]*/: \"#NAME?\",\n\t/*::[*/0x24/*::]*/: \"#NUM!\",\n\t/*::[*/0x2A/*::]*/: \"#N/A\",\n\t/*::[*/0x2B/*::]*/: \"#GETTING_DATA\",\n\t/*::[*/0xFF/*::]*/: \"#WTF?\"\n};\n//var RBErr = evert_num(BErr);\nvar RBErr = {\n\t\"#NULL!\": 0x00,\n\t\"#DIV/0!\": 0x07,\n\t\"#VALUE!\": 0x0F,\n\t\"#REF!\": 0x17,\n\t\"#NAME?\": 0x1D,\n\t\"#NUM!\": 0x24,\n\t\"#N/A\": 0x2A,\n\t\"#GETTING_DATA\": 0x2B,\n\t\"#WTF?\": 0xFF\n};\n\n/* Parts enumerated in OPC spec, MS-XLSB and MS-XLSX */\n/* 12.3 Part Summary <SpreadsheetML> */\n/* 14.2 Part Summary <DrawingML> */\n/* [MS-XLSX] 2.1 Part Enumerations ; [MS-XLSB] 2.1.7 Part Enumeration */\nvar ct2type/*{[string]:string}*/ = ({\n\t/* Workbook */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml\": \"workbooks\",\n\t\"application/vnd.ms-excel.sheet.macroEnabled.main+xml\": \"workbooks\",\n\t\"application/vnd.ms-excel.sheet.binary.macroEnabled.main\": \"workbooks\",\n\t\"application/vnd.ms-excel.addin.macroEnabled.main+xml\": \"workbooks\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml\": \"workbooks\",\n\n\t/* Worksheet */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml\": \"sheets\",\n\t\"application/vnd.ms-excel.worksheet\": \"sheets\",\n\t\"application/vnd.ms-excel.binIndexWs\": \"TODO\", /* Binary Index */\n\n\t/* Chartsheet */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml\": \"charts\",\n\t\"application/vnd.ms-excel.chartsheet\": \"charts\",\n\n\t/* Macrosheet */\n\t\"application/vnd.ms-excel.macrosheet+xml\": \"macros\",\n\t\"application/vnd.ms-excel.macrosheet\": \"macros\",\n\t\"application/vnd.ms-excel.intlmacrosheet\": \"TODO\",\n\t\"application/vnd.ms-excel.binIndexMs\": \"TODO\", /* Binary Index */\n\n\t/* Dialogsheet */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml\": \"dialogs\",\n\t\"application/vnd.ms-excel.dialogsheet\": \"dialogs\",\n\n\t/* Shared Strings */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml\": \"strs\",\n\t\"application/vnd.ms-excel.sharedStrings\": \"strs\",\n\n\t/* Styles */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml\": \"styles\",\n\t\"application/vnd.ms-excel.styles\": \"styles\",\n\n\t/* File Properties */\n\t\"application/vnd.openxmlformats-package.core-properties+xml\": \"coreprops\",\n\t\"application/vnd.openxmlformats-officedocument.custom-properties+xml\": \"custprops\",\n\t\"application/vnd.openxmlformats-officedocument.extended-properties+xml\": \"extprops\",\n\n\t/* Custom Data Properties */\n\t\"application/vnd.openxmlformats-officedocument.customXmlProperties+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.customProperty\": \"TODO\",\n\n\t/* Comments */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml\": \"comments\",\n\t\"application/vnd.ms-excel.comments\": \"comments\",\n\t\"application/vnd.ms-excel.threadedcomments+xml\": \"threadedcomments\",\n\t\"application/vnd.ms-excel.person+xml\": \"people\",\n\n\t/* Metadata (Stock/Geography and Dynamic Array) */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetMetadata+xml\": \"metadata\",\n\t\"application/vnd.ms-excel.sheetMetadata\": \"metadata\",\n\n\t/* PivotTable */\n\t\"application/vnd.ms-excel.pivotTable\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotTable+xml\": \"TODO\",\n\n\t/* Chart Objects */\n\t\"application/vnd.openxmlformats-officedocument.drawingml.chart+xml\": \"TODO\",\n\n\t/* Chart Colors */\n\t\"application/vnd.ms-office.chartcolorstyle+xml\": \"TODO\",\n\n\t/* Chart Style */\n\t\"application/vnd.ms-office.chartstyle+xml\": \"TODO\",\n\n\t/* Chart Advanced */\n\t\"application/vnd.ms-office.chartex+xml\": \"TODO\",\n\n\t/* Calculation Chain */\n\t\"application/vnd.ms-excel.calcChain\": \"calcchains\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.calcChain+xml\": \"calcchains\",\n\n\t/* Printer Settings */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.printerSettings\": \"TODO\",\n\n\t/* ActiveX */\n\t\"application/vnd.ms-office.activeX\": \"TODO\",\n\t\"application/vnd.ms-office.activeX+xml\": \"TODO\",\n\n\t/* Custom Toolbars */\n\t\"application/vnd.ms-excel.attachedToolbars\": \"TODO\",\n\n\t/* External Data Connections */\n\t\"application/vnd.ms-excel.connections\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml\": \"TODO\",\n\n\t/* External Links */\n\t\"application/vnd.ms-excel.externalLink\": \"links\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.externalLink+xml\": \"links\",\n\n\t/* PivotCache */\n\t\"application/vnd.ms-excel.pivotCacheDefinition\": \"TODO\",\n\t\"application/vnd.ms-excel.pivotCacheRecords\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotCacheDefinition+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotCacheRecords+xml\": \"TODO\",\n\n\t/* Query Table */\n\t\"application/vnd.ms-excel.queryTable\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.queryTable+xml\": \"TODO\",\n\n\t/* Shared Workbook */\n\t\"application/vnd.ms-excel.userNames\": \"TODO\",\n\t\"application/vnd.ms-excel.revisionHeaders\": \"TODO\",\n\t\"application/vnd.ms-excel.revisionLog\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionHeaders+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionLog+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.userNames+xml\": \"TODO\",\n\n\t/* Single Cell Table */\n\t\"application/vnd.ms-excel.tableSingleCells\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.tableSingleCells+xml\": \"TODO\",\n\n\t/* Slicer */\n\t\"application/vnd.ms-excel.slicer\": \"TODO\",\n\t\"application/vnd.ms-excel.slicerCache\": \"TODO\",\n\t\"application/vnd.ms-excel.slicer+xml\": \"TODO\",\n\t\"application/vnd.ms-excel.slicerCache+xml\": \"TODO\",\n\n\t/* Sort Map */\n\t\"application/vnd.ms-excel.wsSortMap\": \"TODO\",\n\n\t/* Table */\n\t\"application/vnd.ms-excel.table\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml\": \"TODO\",\n\n\t/* Themes */\n\t\"application/vnd.openxmlformats-officedocument.theme+xml\": \"themes\",\n\n\t/* Theme Override */\n\t\"application/vnd.openxmlformats-officedocument.themeOverride+xml\": \"TODO\",\n\n\t/* Timeline */\n\t\"application/vnd.ms-excel.Timeline+xml\": \"TODO\", /* verify */\n\t\"application/vnd.ms-excel.TimelineCache+xml\": \"TODO\", /* verify */\n\n\t/* VBA */\n\t\"application/vnd.ms-office.vbaProject\": \"vba\",\n\t\"application/vnd.ms-office.vbaProjectSignature\": \"TODO\",\n\n\t/* Volatile Dependencies */\n\t\"application/vnd.ms-office.volatileDependencies\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.volatileDependencies+xml\": \"TODO\",\n\n\t/* Control Properties */\n\t\"application/vnd.ms-excel.controlproperties+xml\": \"TODO\",\n\n\t/* Data Model */\n\t\"application/vnd.openxmlformats-officedocument.model+data\": \"TODO\",\n\n\t/* Survey */\n\t\"application/vnd.ms-excel.Survey+xml\": \"TODO\",\n\n\t/* Drawing */\n\t\"application/vnd.openxmlformats-officedocument.drawing+xml\": \"drawings\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.chartshapes+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramColors+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramData+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramLayout+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramStyle+xml\": \"TODO\",\n\n\t/* VML */\n\t\"application/vnd.openxmlformats-officedocument.vmlDrawing\": \"TODO\",\n\n\t\"application/vnd.openxmlformats-package.relationships+xml\": \"rels\",\n\t\"application/vnd.openxmlformats-officedocument.oleObject\": \"TODO\",\n\n\t/* Image */\n\t\"image/png\": \"TODO\",\n\n\t\"sheet\": \"js\"\n}/*:any*/);\n\nvar CT_LIST = {\n\t\tworkbooks: {\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml\",\n\t\t\txlsm: \"application/vnd.ms-excel.sheet.macroEnabled.main+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.sheet.binary.macroEnabled.main\",\n\t\t\txlam: \"application/vnd.ms-excel.addin.macroEnabled.main+xml\",\n\t\t\txltx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml\"\n\t\t},\n\t\tstrs: { /* Shared Strings */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.sharedStrings\"\n\t\t},\n\t\tcomments: { /* Comments */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.comments\"\n\t\t},\n\t\tsheets: { /* Worksheet */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.worksheet\"\n\t\t},\n\t\tcharts: { /* Chartsheet */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.chartsheet\"\n\t\t},\n\t\tdialogs: { /* Dialogsheet */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.dialogsheet\"\n\t\t},\n\t\tmacros: { /* Macrosheet (Excel 4.0 Macros) */\n\t\t\txlsx: \"application/vnd.ms-excel.macrosheet+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.macrosheet\"\n\t\t},\n\t\tmetadata: { /* Metadata (Stock/Geography and Dynamic Array) */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetMetadata+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.sheetMetadata\"\n\t\t},\n\t\tstyles: { /* Styles */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.styles\"\n\t\t}\n};\n\nfunction new_ct()/*:any*/ {\n\treturn ({\n\t\tworkbooks:[], sheets:[], charts:[], dialogs:[], macros:[],\n\t\trels:[], strs:[], comments:[], threadedcomments:[], links:[],\n\t\tcoreprops:[], extprops:[], custprops:[], themes:[], styles:[],\n\t\tcalcchains:[], vba: [], drawings: [], metadata: [], people:[],\n\t\tTODO:[], xmlns: \"\" }/*:any*/);\n}\n\nfunction parse_ct(data/*:?string*/) {\n\tvar ct = new_ct();\n\tif(!data || !data.match) return ct;\n\tvar ctext = {};\n\t(data.match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0].replace(nsregex,\"<\")) {\n\t\t\tcase '<?xml': break;\n\t\t\tcase '<Types': ct.xmlns = y['xmlns' + (y[0].match(/<(\\w+):/)||[\"\",\"\"])[1] ]; break;\n\t\t\tcase '<Default': ctext[y.Extension] = y.ContentType; break;\n\t\t\tcase '<Override':\n\t\t\t\tif(ct[ct2type[y.ContentType]] !== undefined) ct[ct2type[y.ContentType]].push(y.PartName);\n\t\t\t\tbreak;\n\t\t}\n\t});\n\tif(ct.xmlns !== XMLNS.CT) throw new Error(\"Unknown Namespace: \" + ct.xmlns);\n\tct.calcchain = ct.calcchains.length > 0 ? ct.calcchains[0] : \"\";\n\tct.sst = ct.strs.length > 0 ? ct.strs[0] : \"\";\n\tct.style = ct.styles.length > 0 ? ct.styles[0] : \"\";\n\tct.defaults = ctext;\n\tdelete ct.calcchains;\n\treturn ct;\n}\n\nfunction write_ct(ct, opts)/*:string*/ {\n\tvar type2ct/*{[string]:Array<string>}*/ = evert_arr(ct2type);\n\n\tvar o/*:Array<string>*/ = [], v;\n\to[o.length] = (XML_HEADER);\n\to[o.length] = writextag('Types', null, {\n\t\t'xmlns': XMLNS.CT,\n\t\t'xmlns:xsd': XMLNS.xsd,\n\t\t'xmlns:xsi': XMLNS.xsi\n\t});\n\n\to = o.concat([\n\t\t['xml', 'application/xml'],\n\t\t['bin', 'application/vnd.ms-excel.sheet.binary.macroEnabled.main'],\n\t\t['vml', 'application/vnd.openxmlformats-officedocument.vmlDrawing'],\n\t\t['data', 'application/vnd.openxmlformats-officedocument.model+data'],\n\t\t/* from test files */\n\t\t['bmp', 'image/bmp'],\n\t\t['png', 'image/png'],\n\t\t['gif', 'image/gif'],\n\t\t['emf', 'image/x-emf'],\n\t\t['wmf', 'image/x-wmf'],\n\t\t['jpg', 'image/jpeg'], ['jpeg', 'image/jpeg'],\n\t\t['tif', 'image/tiff'], ['tiff', 'image/tiff'],\n\t\t['pdf', 'application/pdf'],\n\t\t['rels', 'application/vnd.openxmlformats-package.relationships+xml']\n\t].map(function(x) {\n\t\treturn writextag('Default', null, {'Extension':x[0], 'ContentType': x[1]});\n\t}));\n\n\t/* only write first instance */\n\tvar f1 = function(w) {\n\t\tif(ct[w] && ct[w].length > 0) {\n\t\t\tv = ct[w][0];\n\t\t\to[o.length] = (writextag('Override', null, {\n\t\t\t\t'PartName': (v[0] == '/' ? \"\":\"/\") + v,\n\t\t\t\t'ContentType': CT_LIST[w][opts.bookType] || CT_LIST[w]['xlsx']\n\t\t\t}));\n\t\t}\n\t};\n\n\t/* book type-specific */\n\tvar f2 = function(w) {\n\t\t(ct[w]||[]).forEach(function(v) {\n\t\t\to[o.length] = (writextag('Override', null, {\n\t\t\t\t'PartName': (v[0] == '/' ? \"\":\"/\") + v,\n\t\t\t\t'ContentType': CT_LIST[w][opts.bookType] || CT_LIST[w]['xlsx']\n\t\t\t}));\n\t\t});\n\t};\n\n\t/* standard type */\n\tvar f3 = function(t) {\n\t\t(ct[t]||[]).forEach(function(v) {\n\t\t\to[o.length] = (writextag('Override', null, {\n\t\t\t\t'PartName': (v[0] == '/' ? \"\":\"/\") + v,\n\t\t\t\t'ContentType': type2ct[t][0]\n\t\t\t}));\n\t\t});\n\t};\n\n\tf1('workbooks');\n\tf2('sheets');\n\tf2('charts');\n\tf3('themes');\n\t['strs', 'styles'].forEach(f1);\n\t['coreprops', 'extprops', 'custprops'].forEach(f3);\n\tf3('vba');\n\tf3('comments');\n\tf3('threadedcomments');\n\tf3('drawings');\n\tf2('metadata');\n\tf3('people');\n\tif(o.length>2){ o[o.length] = ('</Types>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* 9.3 Relationships */\nvar RELS = ({\n\tWB: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument\",\n\tSHEET: \"http://sheetjs.openxmlformats.org/officeDocument/2006/relationships/officeDocument\",\n\tHLINK: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink\",\n\tVML: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/vmlDrawing\",\n\tXPATH: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/externalLinkPath\",\n\tXMISS: \"http://schemas.microsoft.com/office/2006/relationships/xlExternalLinkPath/xlPathMissing\",\n\tXLINK: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/externalLink\",\n\tCXML: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/customXml\",\n\tCXMLP: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/customXmlProps\",\n\tCMNT: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/comments\",\n\tCORE_PROPS: \"http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties\",\n\tEXT_PROPS: 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties',\n\tCUST_PROPS: 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/custom-properties',\n\tSST: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings\",\n\tSTY: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles\",\n\tTHEME: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme\",\n\tCHART: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart\",\n\tCHARTEX: \"http://schemas.microsoft.com/office/2014/relationships/chartEx\",\n\tCS: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chartsheet\",\n\tWS: [\n\t\t\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet\",\n\t\t\"http://purl.oclc.org/ooxml/officeDocument/relationships/worksheet\"\n\t],\n\tDS: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/dialogsheet\",\n\tMS: \"http://schemas.microsoft.com/office/2006/relationships/xlMacrosheet\",\n\tIMG: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/image\",\n\tDRAW: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing\",\n\tXLMETA: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sheetMetadata\",\n\tTCMNT: \"http://schemas.microsoft.com/office/2017/10/relationships/threadedComment\",\n\tPEOPLE: \"http://schemas.microsoft.com/office/2017/10/relationships/person\",\n\tVBA: \"http://schemas.microsoft.com/office/2006/relationships/vbaProject\"\n}/*:any*/);\n\n\n/* 9.3.3 Representing Relationships */\nfunction get_rels_path(file/*:string*/)/*:string*/ {\n\tvar n = file.lastIndexOf(\"/\");\n\treturn file.slice(0,n+1) + '_rels/' + file.slice(n+1) + \".rels\";\n}\n\nfunction parse_rels(data/*:?string*/, currentFilePath/*:string*/) {\n\tvar rels = {\"!id\":{}};\n\tif (!data) return rels;\n\tif (currentFilePath.charAt(0) !== '/') {\n\t\tcurrentFilePath = '/'+currentFilePath;\n\t}\n\tvar hash = {};\n\n\t(data.match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\t/* 9.3.2.2 OPC_Relationships */\n\t\tif (y[0] === '<Relationship') {\n\t\t\tvar rel = {}; rel.Type = y.Type; rel.Target = y.Target; rel.Id = y.Id; if(y.TargetMode) rel.TargetMode = y.TargetMode;\n\t\t\tvar canonictarget = y.TargetMode === 'External' ? y.Target : resolve_path(y.Target, currentFilePath);\n\t\t\trels[canonictarget] = rel;\n\t\t\thash[y.Id] = rel;\n\t\t}\n\t});\n\trels[\"!id\"] = hash;\n\treturn rels;\n}\n\n\n/* TODO */\nfunction write_rels(rels)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('Relationships', null, {\n\t\t//'xmlns:ns0': XMLNS.RELS,\n\t\t'xmlns': XMLNS.RELS\n\t})];\n\tkeys(rels['!id']).forEach(function(rid) {\n\t\to[o.length] = (writextag('Relationship', null, rels['!id'][rid]));\n\t});\n\tif(o.length>2){ o[o.length] = ('</Relationships>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n\nfunction add_rels(rels, rId/*:number*/, f, type, relobj, targetmode/*:?string*/)/*:number*/ {\n\tif(!relobj) relobj = {};\n\tif(!rels['!id']) rels['!id'] = {};\n\tif(!rels['!idx']) rels['!idx'] = 1;\n\tif(rId < 0) for(rId = rels['!idx']; rels['!id']['rId' + rId]; ++rId){/* empty */}\n\trels['!idx'] = rId + 1;\n\trelobj.Id = 'rId' + rId;\n\trelobj.Type = type;\n\trelobj.Target = f;\n\tif(targetmode) relobj.TargetMode = targetmode;\n\telse if([RELS.HLINK, RELS.XPATH, RELS.XMISS].indexOf(relobj.Type) > -1) relobj.TargetMode = \"External\";\n\tif(rels['!id'][relobj.Id]) throw new Error(\"Cannot rewrite rId \" + rId);\n\trels['!id'][relobj.Id] = relobj;\n\trels[('/' + relobj.Target).replace(\"//\",\"/\")] = relobj;\n\treturn rId;\n}\n/* Open Document Format for Office Applications (OpenDocument) Version 1.2 */\n/* Part 3 Section 4 Manifest File */\nvar CT_ODS = \"application/vnd.oasis.opendocument.spreadsheet\";\nfunction parse_manifest(d, opts) {\n\tvar str = xlml_normalize(d);\n\tvar Rn;\n\tvar FEtag;\n\twhile((Rn = xlmlregex.exec(str))) switch(Rn[3]) {\n\t\tcase 'manifest': break; // 4.2 <manifest:manifest>\n\t\tcase 'file-entry': // 4.3 <manifest:file-entry>\n\t\t\tFEtag = parsexmltag(Rn[0], false);\n\t\t\tif(FEtag.path == '/' && FEtag.type !== CT_ODS) throw new Error(\"This OpenDocument is not a spreadsheet\");\n\t\t\tbreak;\n\t\tcase 'encryption-data': // 4.4 <manifest:encryption-data>\n\t\tcase 'algorithm': // 4.5 <manifest:algorithm>\n\t\tcase 'start-key-generation': // 4.6 <manifest:start-key-generation>\n\t\tcase 'key-derivation': // 4.7 <manifest:key-derivation>\n\t\t\tthrow new Error(\"Unsupported ODS Encryption\");\n\t\tdefault: if(opts && opts.WTF) throw Rn;\n\t}\n}\n\nfunction write_manifest(manifest/*:Array<Array<string> >*/)/*:string*/ {\n\tvar o = [XML_HEADER];\n\to.push('<manifest:manifest xmlns:manifest=\"urn:oasis:names:tc:opendocument:xmlns:manifest:1.0\" manifest:version=\"1.2\">\\n');\n\to.push(' <manifest:file-entry manifest:full-path=\"/\" manifest:version=\"1.2\" manifest:media-type=\"application/vnd.oasis.opendocument.spreadsheet\"/>\\n');\n\tfor(var i = 0; i < manifest.length; ++i) o.push(' <manifest:file-entry manifest:full-path=\"' + manifest[i][0] + '\" manifest:media-type=\"' + manifest[i][1] + '\"/>\\n');\n\to.push('</manifest:manifest>');\n\treturn o.join(\"\");\n}\n\n/* Part 3 Section 6 Metadata Manifest File */\nfunction write_rdf_type(file/*:string*/, res/*:string*/, tag/*:?string*/) {\n\treturn [\n\t\t' <rdf:Description rdf:about=\"' + file + '\">\\n',\n\t\t' <rdf:type rdf:resource=\"http://docs.oasis-open.org/ns/office/1.2/meta/' + (tag || \"odf\") + '#' + res + '\"/>\\n',\n\t\t' </rdf:Description>\\n'\n\t].join(\"\");\n}\nfunction write_rdf_has(base/*:string*/, file/*:string*/) {\n\treturn [\n\t\t' <rdf:Description rdf:about=\"' + base + '\">\\n',\n\t\t' <ns0:hasPart xmlns:ns0=\"http://docs.oasis-open.org/ns/office/1.2/meta/pkg#\" rdf:resource=\"' + file + '\"/>\\n',\n\t\t' </rdf:Description>\\n'\n\t].join(\"\");\n}\nfunction write_rdf(rdf) {\n\tvar o = [XML_HEADER];\n\to.push('<rdf:RDF xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\\n');\n\tfor(var i = 0; i != rdf.length; ++i) {\n\t\to.push(write_rdf_type(rdf[i][0], rdf[i][1]));\n\t\to.push(write_rdf_has(\"\",rdf[i][0]));\n\t}\n\to.push(write_rdf_type(\"\",\"Document\", \"pkg\"));\n\to.push('</rdf:RDF>');\n\treturn o.join(\"\");\n}\n/* TODO: pull properties */\nfunction write_meta_ods(/*:: wb: Workbook, opts: any*/)/*:string*/ {\n\treturn '<office:document-meta xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\" xmlns:meta=\"urn:oasis:names:tc:opendocument:xmlns:meta:1.0\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" office:version=\"1.2\"><office:meta><meta:generator>Sheet' + 'JS ' + XLSX.version + '</meta:generator></office:meta></office:document-meta>';\n}\n\n/* ECMA-376 Part II 11.1 Core Properties Part */\n/* [MS-OSHARED] 2.3.3.2.[1-2].1 (PIDSI/PIDDSI) */\nvar CORE_PROPS/*:Array<Array<string> >*/ = [\n\t[\"cp:category\", \"Category\"],\n\t[\"cp:contentStatus\", \"ContentStatus\"],\n\t[\"cp:keywords\", \"Keywords\"],\n\t[\"cp:lastModifiedBy\", \"LastAuthor\"],\n\t[\"cp:lastPrinted\", \"LastPrinted\"],\n\t[\"cp:revision\", \"RevNumber\"],\n\t[\"cp:version\", \"Version\"],\n\t[\"dc:creator\", \"Author\"],\n\t[\"dc:description\", \"Comments\"],\n\t[\"dc:identifier\", \"Identifier\"],\n\t[\"dc:language\", \"Language\"],\n\t[\"dc:subject\", \"Subject\"],\n\t[\"dc:title\", \"Title\"],\n\t[\"dcterms:created\", \"CreatedDate\", 'date'],\n\t[\"dcterms:modified\", \"ModifiedDate\", 'date']\n];\n\nvar CORE_PROPS_REGEX/*:Array<RegExp>*/ = /*#__PURE__*/(function() {\n\tvar r = new Array(CORE_PROPS.length);\n\tfor(var i = 0; i < CORE_PROPS.length; ++i) {\n\t\tvar f = CORE_PROPS[i];\n\t\tvar g = \"(?:\"+ f[0].slice(0,f[0].indexOf(\":\")) +\":)\"+ f[0].slice(f[0].indexOf(\":\")+1);\n\t\tr[i] = new RegExp(\"<\" + g + \"[^>]*>([\\\\s\\\\S]*?)<\\/\" + g + \">\");\n\t}\n\treturn r;\n})();\n\nfunction parse_core_props(data) {\n\tvar p = {};\n\tdata = utf8read(data);\n\n\tfor(var i = 0; i < CORE_PROPS.length; ++i) {\n\t\tvar f = CORE_PROPS[i], cur = data.match(CORE_PROPS_REGEX[i]);\n\t\tif(cur != null && cur.length > 0) p[f[1]] = unescapexml(cur[1]);\n\t\tif(f[2] === 'date' && p[f[1]]) p[f[1]] = parseDate(p[f[1]]);\n\t}\n\n\treturn p;\n}\n\nfunction cp_doit(f, g, h, o, p) {\n\tif(p[f] != null || g == null || g === \"\") return;\n\tp[f] = g;\n\tg = escapexml(g);\n\to[o.length] = (h ? writextag(f,g,h) : writetag(f,g));\n}\n\nfunction write_core_props(cp, _opts) {\n\tvar opts = _opts || {};\n\tvar o = [XML_HEADER, writextag('cp:coreProperties', null, {\n\t\t//'xmlns': XMLNS.CORE_PROPS,\n\t\t'xmlns:cp': XMLNS.CORE_PROPS,\n\t\t'xmlns:dc': XMLNS.dc,\n\t\t'xmlns:dcterms': XMLNS.dcterms,\n\t\t'xmlns:dcmitype': XMLNS.dcmitype,\n\t\t'xmlns:xsi': XMLNS.xsi\n\t})], p = {};\n\tif(!cp && !opts.Props) return o.join(\"\");\n\n\tif(cp) {\n\t\tif(cp.CreatedDate != null) cp_doit(\"dcterms:created\", typeof cp.CreatedDate === \"string\" ? cp.CreatedDate : write_w3cdtf(cp.CreatedDate, opts.WTF), {\"xsi:type\":\"dcterms:W3CDTF\"}, o, p);\n\t\tif(cp.ModifiedDate != null) cp_doit(\"dcterms:modified\", typeof cp.ModifiedDate === \"string\" ? cp.ModifiedDate : write_w3cdtf(cp.ModifiedDate, opts.WTF), {\"xsi:type\":\"dcterms:W3CDTF\"}, o, p);\n\t}\n\n\tfor(var i = 0; i != CORE_PROPS.length; ++i) {\n\t\tvar f = CORE_PROPS[i];\n\t\tvar v = opts.Props && opts.Props[f[1]] != null ? opts.Props[f[1]] : cp ? cp[f[1]] : null;\n\t\tif(v === true) v = \"1\";\n\t\telse if(v === false) v = \"0\";\n\t\telse if(typeof v == \"number\") v = String(v);\n\t\tif(v != null) cp_doit(f[0], v, null, o, p);\n\t}\n\tif(o.length>2){ o[o.length] = ('</cp:coreProperties>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* 15.2.12.3 Extended File Properties Part */\n/* [MS-OSHARED] 2.3.3.2.[1-2].1 (PIDSI/PIDDSI) */\nvar EXT_PROPS/*:Array<Array<string> >*/ = [\n\t[\"Application\", \"Application\", \"string\"],\n\t[\"AppVersion\", \"AppVersion\", \"string\"],\n\t[\"Company\", \"Company\", \"string\"],\n\t[\"DocSecurity\", \"DocSecurity\", \"string\"],\n\t[\"Manager\", \"Manager\", \"string\"],\n\t[\"HyperlinksChanged\", \"HyperlinksChanged\", \"bool\"],\n\t[\"SharedDoc\", \"SharedDoc\", \"bool\"],\n\t[\"LinksUpToDate\", \"LinksUpToDate\", \"bool\"],\n\t[\"ScaleCrop\", \"ScaleCrop\", \"bool\"],\n\t[\"HeadingPairs\", \"HeadingPairs\", \"raw\"],\n\t[\"TitlesOfParts\", \"TitlesOfParts\", \"raw\"]\n];\n\nvar PseudoPropsPairs = [\n\t\"Worksheets\", \"SheetNames\",\n\t\"NamedRanges\", \"DefinedNames\",\n\t\"Chartsheets\", \"ChartNames\"\n];\nfunction load_props_pairs(HP/*:string|Array<Array<any>>*/, TOP, props, opts) {\n\tvar v = [];\n\tif(typeof HP == \"string\") v = parseVector(HP, opts);\n\telse for(var j = 0; j < HP.length; ++j) v = v.concat(HP[j].map(function(hp) { return {v:hp}; }));\n\tvar parts = (typeof TOP == \"string\") ? parseVector(TOP, opts).map(function (x) { return x.v; }) : TOP;\n\tvar idx = 0, len = 0;\n\tif(parts.length > 0) for(var i = 0; i !== v.length; i += 2) {\n\t\tlen = +(v[i+1].v);\n\t\tswitch(v[i].v) {\n\t\t\tcase \"Worksheets\":\n\t\t\tcase \"工作表\":\n\t\t\tcase \"Листы\":\n\t\t\tcase \"أوراق العمل\":\n\t\t\tcase \"ワークシート\":\n\t\t\tcase \"גליונות עבודה\":\n\t\t\tcase \"Arbeitsblätter\":\n\t\t\tcase \"Çalışma Sayfaları\":\n\t\t\tcase \"Feuilles de calcul\":\n\t\t\tcase \"Fogli di lavoro\":\n\t\t\tcase \"Folhas de cálculo\":\n\t\t\tcase \"Planilhas\":\n\t\t\tcase \"Regneark\":\n\t\t\tcase \"Hojas de cálculo\":\n\t\t\tcase \"Werkbladen\":\n\t\t\t\tprops.Worksheets = len;\n\t\t\t\tprops.SheetNames = parts.slice(idx, idx + len);\n\t\t\t\tbreak;\n\n\t\t\tcase \"Named Ranges\":\n\t\t\tcase \"Rangos con nombre\":\n\t\t\tcase \"名前付き一覧\":\n\t\t\tcase \"Benannte Bereiche\":\n\t\t\tcase \"Navngivne områder\":\n\t\t\t\tprops.NamedRanges = len;\n\t\t\t\tprops.DefinedNames = parts.slice(idx, idx + len);\n\t\t\t\tbreak;\n\n\t\t\tcase \"Charts\":\n\t\t\tcase \"Diagramme\":\n\t\t\t\tprops.Chartsheets = len;\n\t\t\t\tprops.ChartNames = parts.slice(idx, idx + len);\n\t\t\t\tbreak;\n\t\t}\n\t\tidx += len;\n\t}\n}\n\nfunction parse_ext_props(data, p, opts) {\n\tvar q = {}; if(!p) p = {};\n\tdata = utf8read(data);\n\n\tEXT_PROPS.forEach(function(f) {\n\t\tvar xml = (data.match(matchtag(f[0]))||[])[1];\n\t\tswitch(f[2]) {\n\t\t\tcase \"string\": if(xml) p[f[1]] = unescapexml(xml); break;\n\t\t\tcase \"bool\": p[f[1]] = xml === \"true\"; break;\n\t\t\tcase \"raw\":\n\t\t\t\tvar cur = data.match(new RegExp(\"<\" + f[0] + \"[^>]*>([\\\\s\\\\S]*?)<\\/\" + f[0] + \">\"));\n\t\t\t\tif(cur && cur.length > 0) q[f[1]] = cur[1];\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tif(q.HeadingPairs && q.TitlesOfParts) load_props_pairs(q.HeadingPairs, q.TitlesOfParts, p, opts);\n\n\treturn p;\n}\n\nfunction write_ext_props(cp/*::, opts*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [], W = writextag;\n\tif(!cp) cp = {};\n\tcp.Application = \"SheetJS\";\n\to[o.length] = (XML_HEADER);\n\to[o.length] = (writextag('Properties', null, {\n\t\t'xmlns': XMLNS.EXT_PROPS,\n\t\t'xmlns:vt': XMLNS.vt\n\t}));\n\n\tEXT_PROPS.forEach(function(f) {\n\t\tif(cp[f[1]] === undefined) return;\n\t\tvar v;\n\t\tswitch(f[2]) {\n\t\t\tcase 'string': v = escapexml(String(cp[f[1]])); break;\n\t\t\tcase 'bool': v = cp[f[1]] ? 'true' : 'false'; break;\n\t\t}\n\t\tif(v !== undefined) o[o.length] = (W(f[0], v));\n\t});\n\n\t/* TODO: HeadingPairs, TitlesOfParts */\n\to[o.length] = (W('HeadingPairs', W('vt:vector', W('vt:variant', '<vt:lpstr>Worksheets</vt:lpstr>')+W('vt:variant', W('vt:i4', String(cp.Worksheets))), {size:2, baseType:\"variant\"})));\n\to[o.length] = (W('TitlesOfParts', W('vt:vector', cp.SheetNames.map(function(s) { return \"<vt:lpstr>\" + escapexml(s) + \"</vt:lpstr>\"; }).join(\"\"), {size: cp.Worksheets, baseType:\"lpstr\"})));\n\tif(o.length>2){ o[o.length] = ('</Properties>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* 15.2.12.2 Custom File Properties Part */\nvar custregex = /<[^>]+>[^<]*/g;\nfunction parse_cust_props(data/*:string*/, opts) {\n\tvar p = {}, name = \"\";\n\tvar m = data.match(custregex);\n\tif(m) for(var i = 0; i != m.length; ++i) {\n\t\tvar x = m[i], y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\tcase '<?xml': break;\n\t\t\tcase '<Properties': break;\n\t\t\tcase '<property': name = unescapexml(y.name); break;\n\t\t\tcase '</property>': name = null; break;\n\t\t\tdefault: if (x.indexOf('<vt:') === 0) {\n\t\t\t\tvar toks = x.split('>');\n\t\t\t\tvar type = toks[0].slice(4), text = toks[1];\n\t\t\t\t/* 22.4.2.32 (CT_Variant). Omit the binary types from 22.4 (Variant Types) */\n\t\t\t\tswitch(type) {\n\t\t\t\t\tcase 'lpstr': case 'bstr': case 'lpwstr':\n\t\t\t\t\t\tp[name] = unescapexml(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'bool':\n\t\t\t\t\t\tp[name] = parsexmlbool(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'i1': case 'i2': case 'i4': case 'i8': case 'int': case 'uint':\n\t\t\t\t\t\tp[name] = parseInt(text, 10);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'r4': case 'r8': case 'decimal':\n\t\t\t\t\t\tp[name] = parseFloat(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'filetime': case 'date':\n\t\t\t\t\t\tp[name] = parseDate(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'cy': case 'error':\n\t\t\t\t\t\tp[name] = unescapexml(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tif(type.slice(-1) == '/') break;\n\t\t\t\t\t\tif(opts.WTF && typeof console !== 'undefined') console.warn('Unexpected', x, type, toks);\n\t\t\t\t}\n\t\t\t} else if(x.slice(0,2) === \"</\") {/* empty */\n\t\t\t} else if(opts.WTF) throw new Error(x);\n\t\t}\n\t}\n\treturn p;\n}\n\nfunction write_cust_props(cp/*::, opts*/)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('Properties', null, {\n\t\t'xmlns': XMLNS.CUST_PROPS,\n\t\t'xmlns:vt': XMLNS.vt\n\t})];\n\tif(!cp) return o.join(\"\");\n\tvar pid = 1;\n\tkeys(cp).forEach(function custprop(k) { ++pid;\n\t\to[o.length] = (writextag('property', write_vt(cp[k], true), {\n\t\t\t'fmtid': '{D5CDD505-2E9C-101B-9397-08002B2CF9AE}',\n\t\t\t'pid': pid,\n\t\t\t'name': escapexml(k)\n\t\t}));\n\t});\n\tif(o.length>2){ o[o.length] = '</Properties>'; o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* Common Name -> XLML Name */\nvar XLMLDocPropsMap = {\n\tTitle: 'Title',\n\tSubject: 'Subject',\n\tAuthor: 'Author',\n\tKeywords: 'Keywords',\n\tComments: 'Description',\n\tLastAuthor: 'LastAuthor',\n\tRevNumber: 'Revision',\n\tApplication: 'AppName',\n\t/* TotalTime: 'TotalTime', */\n\tLastPrinted: 'LastPrinted',\n\tCreatedDate: 'Created',\n\tModifiedDate: 'LastSaved',\n\t/* Pages */\n\t/* Words */\n\t/* Characters */\n\tCategory: 'Category',\n\t/* PresentationFormat */\n\tManager: 'Manager',\n\tCompany: 'Company',\n\t/* Guid */\n\t/* HyperlinkBase */\n\t/* Bytes */\n\t/* Lines */\n\t/* Paragraphs */\n\t/* CharactersWithSpaces */\n\tAppVersion: 'Version',\n\n\tContentStatus: 'ContentStatus', /* NOTE: missing from schema */\n\tIdentifier: 'Identifier', /* NOTE: missing from schema */\n\tLanguage: 'Language' /* NOTE: missing from schema */\n};\nvar evert_XLMLDPM;\n\nfunction xlml_set_prop(Props, tag/*:string*/, val) {\n\tif(!evert_XLMLDPM) evert_XLMLDPM = evert(XLMLDocPropsMap);\n\ttag = evert_XLMLDPM[tag] || tag;\n\tProps[tag] = val;\n}\n\nfunction xlml_write_docprops(Props, opts) {\n\tvar o/*:Array<string>*/ = [];\n\tkeys(XLMLDocPropsMap).map(function(m) {\n\t\tfor(var i = 0; i < CORE_PROPS.length; ++i) if(CORE_PROPS[i][1] == m) return CORE_PROPS[i];\n\t\tfor(i = 0; i < EXT_PROPS.length; ++i) if(EXT_PROPS[i][1] == m) return EXT_PROPS[i];\n\t\tthrow m;\n\t}).forEach(function(p) {\n\t\tif(Props[p[1]] == null) return;\n\t\tvar m = opts && opts.Props && opts.Props[p[1]] != null ? opts.Props[p[1]] : Props[p[1]];\n\t\tswitch(p[2]) {\n\t\t\tcase 'date': m = new Date(m).toISOString().replace(/\\.\\d*Z/,\"Z\"); break;\n\t\t}\n\t\tif(typeof m == 'number') m = String(m);\n\t\telse if(m === true || m === false) { m = m ? \"1\" : \"0\"; }\n\t\telse if(m instanceof Date) m = new Date(m).toISOString().replace(/\\.\\d*Z/,\"\");\n\t\to.push(writetag(XLMLDocPropsMap[p[1]] || p[1], m));\n\t});\n\treturn writextag('DocumentProperties', o.join(\"\"), {xmlns:XLMLNS.o });\n}\nfunction xlml_write_custprops(Props, Custprops/*::, opts*/) {\n\tvar BLACKLIST = [\"Worksheets\",\"SheetNames\"];\n\tvar T = 'CustomDocumentProperties';\n\tvar o/*:Array<string>*/ = [];\n\tif(Props) keys(Props).forEach(function(k) {\n\t\t/*:: if(!Props) return; */\n\t\tif(!Object.prototype.hasOwnProperty.call(Props, k)) return;\n\t\tfor(var i = 0; i < CORE_PROPS.length; ++i) if(k == CORE_PROPS[i][1]) return;\n\t\tfor(i = 0; i < EXT_PROPS.length; ++i) if(k == EXT_PROPS[i][1]) return;\n\t\tfor(i = 0; i < BLACKLIST.length; ++i) if(k == BLACKLIST[i]) return;\n\n\t\tvar m = Props[k];\n\t\tvar t = \"string\";\n\t\tif(typeof m == 'number') { t = \"float\"; m = String(m); }\n\t\telse if(m === true || m === false) { t = \"boolean\"; m = m ? \"1\" : \"0\"; }\n\t\telse m = String(m);\n\t\to.push(writextag(escapexmltag(k), m, {\"dt:dt\":t}));\n\t});\n\tif(Custprops) keys(Custprops).forEach(function(k) {\n\t\t/*:: if(!Custprops) return; */\n\t\tif(!Object.prototype.hasOwnProperty.call(Custprops, k)) return;\n\t\tif(Props && Object.prototype.hasOwnProperty.call(Props, k)) return;\n\t\tvar m = Custprops[k];\n\t\tvar t = \"string\";\n\t\tif(typeof m == 'number') { t = \"float\"; m = String(m); }\n\t\telse if(m === true || m === false) { t = \"boolean\"; m = m ? \"1\" : \"0\"; }\n\t\telse if(m instanceof Date) { t = \"dateTime.tz\"; m = m.toISOString(); }\n\t\telse m = String(m);\n\t\to.push(writextag(escapexmltag(k), m, {\"dt:dt\":t}));\n\t});\n\treturn '<' + T + ' xmlns=\"' + XLMLNS.o + '\">' + o.join(\"\") + '</' + T + '>';\n}\n/* [MS-DTYP] 2.3.3 FILETIME */\n/* [MS-OLEDS] 2.1.3 FILETIME (Packet Version) */\n/* [MS-OLEPS] 2.8 FILETIME (Packet Version) */\nfunction parse_FILETIME(blob) {\n\tvar dwLowDateTime = blob.read_shift(4), dwHighDateTime = blob.read_shift(4);\n\treturn new Date(((dwHighDateTime/1e7*Math.pow(2,32) + dwLowDateTime/1e7) - 11644473600)*1000).toISOString().replace(/\\.000/,\"\");\n}\nfunction write_FILETIME(time/*:string|Date*/) {\n\tvar date = (typeof time == \"string\") ? new Date(Date.parse(time)) : time;\n\tvar t = date.getTime() / 1000 + 11644473600;\n\tvar l = t % Math.pow(2,32), h = (t - l) / Math.pow(2,32);\n\tl *= 1e7; h *= 1e7;\n\tvar w = (l / Math.pow(2,32)) | 0;\n\tif(w > 0) { l = l % Math.pow(2,32); h += w; }\n\tvar o = new_buf(8); o.write_shift(4, l); o.write_shift(4, h); return o;\n}\n\n/* [MS-OSHARED] 2.3.3.1.4 Lpstr */\nfunction parse_lpstr(blob, type, pad/*:?number*/) {\n\tvar start = blob.l;\n\tvar str = blob.read_shift(0, 'lpstr-cp');\n\tif(pad) while((blob.l - start) & 3) ++blob.l;\n\treturn str;\n}\n\n/* [MS-OSHARED] 2.3.3.1.6 Lpwstr */\nfunction parse_lpwstr(blob, type, pad) {\n\tvar str = blob.read_shift(0, 'lpwstr');\n\tif(pad) blob.l += (4 - ((str.length+1) & 3)) & 3;\n\treturn str;\n}\n\n\n/* [MS-OSHARED] 2.3.3.1.11 VtString */\n/* [MS-OSHARED] 2.3.3.1.12 VtUnalignedString */\nfunction parse_VtStringBase(blob, stringType, pad) {\n\tif(stringType === 0x1F /*VT_LPWSTR*/) return parse_lpwstr(blob);\n\treturn parse_lpstr(blob, stringType, pad);\n}\n\nfunction parse_VtString(blob, t/*:number*/, pad/*:?boolean*/) { return parse_VtStringBase(blob, t, pad === false ? 0: 4); }\nfunction parse_VtUnalignedString(blob, t/*:number*/) { if(!t) throw new Error(\"VtUnalignedString must have positive length\"); return parse_VtStringBase(blob, t, 0); }\n\n/* [MS-OSHARED] 2.3.3.1.7 VtVecLpwstrValue */\nfunction parse_VtVecLpwstrValue(blob)/*:Array<string>*/ {\n\tvar length = blob.read_shift(4);\n\tvar ret/*:Array<string>*/ = [];\n\tfor(var i = 0; i != length; ++i) {\n\t\tvar start = blob.l;\n\t\tret[i] = blob.read_shift(0, 'lpwstr').replace(chr0,'');\n\t\tif((blob.l - start) & 0x02) blob.l += 2;\n\t}\n\treturn ret;\n}\n\n/* [MS-OSHARED] 2.3.3.1.9 VtVecUnalignedLpstrValue */\nfunction parse_VtVecUnalignedLpstrValue(blob)/*:Array<string>*/ {\n\tvar length = blob.read_shift(4);\n\tvar ret/*:Array<string>*/ = [];\n\tfor(var i = 0; i != length; ++i) ret[i] = blob.read_shift(0, 'lpstr-cp').replace(chr0,'');\n\treturn ret;\n}\n\n\n/* [MS-OSHARED] 2.3.3.1.13 VtHeadingPair */\nfunction parse_VtHeadingPair(blob) {\n\tvar start = blob.l;\n\tvar headingString = parse_TypedPropertyValue(blob, VT_USTR);\n\tif(blob[blob.l] == 0x00 && blob[blob.l+1] == 0x00 && ((blob.l - start) & 0x02)) blob.l += 2;\n\tvar headerParts = parse_TypedPropertyValue(blob, VT_I4);\n\treturn [headingString, headerParts];\n}\n\n/* [MS-OSHARED] 2.3.3.1.14 VtVecHeadingPairValue */\nfunction parse_VtVecHeadingPairValue(blob) {\n\tvar cElements = blob.read_shift(4);\n\tvar out = [];\n\tfor(var i = 0; i < cElements / 2; ++i) out.push(parse_VtHeadingPair(blob));\n\treturn out;\n}\n\n/* [MS-OLEPS] 2.18.1 Dictionary (uses 2.17, 2.16) */\nfunction parse_dictionary(blob,CodePage) {\n\tvar cnt = blob.read_shift(4);\n\tvar dict/*:{[number]:string}*/ = ({}/*:any*/);\n\tfor(var j = 0; j != cnt; ++j) {\n\t\tvar pid = blob.read_shift(4);\n\t\tvar len = blob.read_shift(4);\n\t\tdict[pid] = blob.read_shift(len, (CodePage === 0x4B0 ?'utf16le':'utf8')).replace(chr0,'').replace(chr1,'!');\n\t\tif(CodePage === 0x4B0 && (len % 2)) blob.l += 2;\n\t}\n\tif(blob.l & 3) blob.l = (blob.l>>2+1)<<2;\n\treturn dict;\n}\n\n/* [MS-OLEPS] 2.9 BLOB */\nfunction parse_BLOB(blob) {\n\tvar size = blob.read_shift(4);\n\tvar bytes = blob.slice(blob.l,blob.l+size);\n\tblob.l += size;\n\tif((size & 3) > 0) blob.l += (4 - (size & 3)) & 3;\n\treturn bytes;\n}\n\n/* [MS-OLEPS] 2.11 ClipboardData */\nfunction parse_ClipboardData(blob) {\n\t// TODO\n\tvar o = {};\n\to.Size = blob.read_shift(4);\n\t//o.Format = blob.read_shift(4);\n\tblob.l += o.Size + 3 - (o.Size - 1) % 4;\n\treturn o;\n}\n\n/* [MS-OLEPS] 2.15 TypedPropertyValue */\nfunction parse_TypedPropertyValue(blob, type/*:number*/, _opts)/*:any*/ {\n\tvar t = blob.read_shift(2), ret, opts = _opts||{};\n\tblob.l += 2;\n\tif(type !== VT_VARIANT)\n\tif(t !== type && VT_CUSTOM.indexOf(type)===-1 && !((type & 0xFFFE) == 0x101E && (t & 0xFFFE) == 0x101E)) throw new Error('Expected type ' + type + ' saw ' + t);\n\tswitch(type === VT_VARIANT ? t : type) {\n\t\tcase 0x02 /*VT_I2*/: ret = blob.read_shift(2, 'i'); if(!opts.raw) blob.l += 2; return ret;\n\t\tcase 0x03 /*VT_I4*/: ret = blob.read_shift(4, 'i'); return ret;\n\t\tcase 0x0B /*VT_BOOL*/: return blob.read_shift(4) !== 0x0;\n\t\tcase 0x13 /*VT_UI4*/: ret = blob.read_shift(4); return ret;\n\t\tcase 0x1E /*VT_LPSTR*/: return parse_lpstr(blob, t, 4).replace(chr0,'');\n\t\tcase 0x1F /*VT_LPWSTR*/: return parse_lpwstr(blob);\n\t\tcase 0x40 /*VT_FILETIME*/: return parse_FILETIME(blob);\n\t\tcase 0x41 /*VT_BLOB*/: return parse_BLOB(blob);\n\t\tcase 0x47 /*VT_CF*/: return parse_ClipboardData(blob);\n\t\tcase 0x50 /*VT_STRING*/: return parse_VtString(blob, t, !opts.raw).replace(chr0,'');\n\t\tcase 0x51 /*VT_USTR*/: return parse_VtUnalignedString(blob, t/*, 4*/).replace(chr0,'');\n\t\tcase 0x100C /*VT_VECTOR|VT_VARIANT*/: return parse_VtVecHeadingPairValue(blob);\n\t\tcase 0x101E /*VT_VECTOR|VT_LPSTR*/:\n\t\tcase 0x101F /*VT_VECTOR|VT_LPWSTR*/:\n\t\t\treturn t == 0x101F ? parse_VtVecLpwstrValue(blob) : parse_VtVecUnalignedLpstrValue(blob);\n\t\tdefault: throw new Error(\"TypedPropertyValue unrecognized type \" + type + \" \" + t);\n\t}\n}\nfunction write_TypedPropertyValue(type/*:number*/, value) {\n\tvar o = new_buf(4), p = new_buf(4);\n\to.write_shift(4, type == 0x50 ? 0x1F : type);\n\tswitch(type) {\n\t\tcase 0x03 /*VT_I4*/: p.write_shift(-4, value); break;\n\t\tcase 0x05 /*VT_I4*/: p = new_buf(8); p.write_shift(8, value, 'f'); break;\n\t\tcase 0x0B /*VT_BOOL*/: p.write_shift(4, value ? 0x01 : 0x00); break;\n\t\tcase 0x40 /*VT_FILETIME*/: /*:: if(typeof value !== \"string\" && !(value instanceof Date)) throw \"unreachable\"; */ p = write_FILETIME(value); break;\n\t\tcase 0x1F /*VT_LPWSTR*/:\n\t\tcase 0x50 /*VT_STRING*/:\n\t\t\t/*:: if(typeof value !== \"string\") throw \"unreachable\"; */\n\t\t\tp = new_buf(4 + 2 * (value.length + 1) + (value.length % 2 ? 0 : 2));\n\t\t\tp.write_shift(4, value.length + 1);\n\t\t\tp.write_shift(0, value, \"dbcs\");\n\t\t\twhile(p.l != p.length) p.write_shift(1, 0);\n\t\t\tbreak;\n\t\tdefault: throw new Error(\"TypedPropertyValue unrecognized type \" + type + \" \" + value);\n\t}\n\treturn bconcat([o, p]);\n}\n\n/* [MS-OLEPS] 2.20 PropertySet */\nfunction parse_PropertySet(blob, PIDSI) {\n\tvar start_addr = blob.l;\n\tvar size = blob.read_shift(4);\n\tvar NumProps = blob.read_shift(4);\n\tvar Props = [], i = 0;\n\tvar CodePage = 0;\n\tvar Dictionary = -1, DictObj/*:{[number]:string}*/ = ({}/*:any*/);\n\tfor(i = 0; i != NumProps; ++i) {\n\t\tvar PropID = blob.read_shift(4);\n\t\tvar Offset = blob.read_shift(4);\n\t\tProps[i] = [PropID, Offset + start_addr];\n\t}\n\tProps.sort(function(x,y) { return x[1] - y[1]; });\n\tvar PropH = {};\n\tfor(i = 0; i != NumProps; ++i) {\n\t\tif(blob.l !== Props[i][1]) {\n\t\t\tvar fail = true;\n\t\t\tif(i>0 && PIDSI) switch(PIDSI[Props[i-1][0]].t) {\n\t\t\t\tcase 0x02 /*VT_I2*/: if(blob.l+2 === Props[i][1]) { blob.l+=2; fail = false; } break;\n\t\t\t\tcase 0x50 /*VT_STRING*/: if(blob.l <= Props[i][1]) { blob.l=Props[i][1]; fail = false; } break;\n\t\t\t\tcase 0x100C /*VT_VECTOR|VT_VARIANT*/: if(blob.l <= Props[i][1]) { blob.l=Props[i][1]; fail = false; } break;\n\t\t\t}\n\t\t\tif((!PIDSI||i==0) && blob.l <= Props[i][1]) { fail=false; blob.l = Props[i][1]; }\n\t\t\tif(fail) throw new Error(\"Read Error: Expected address \" + Props[i][1] + ' at ' + blob.l + ' :' + i);\n\t\t}\n\t\tif(PIDSI) {\n\t\t\tvar piddsi = PIDSI[Props[i][0]];\n\t\t\tPropH[piddsi.n] = parse_TypedPropertyValue(blob, piddsi.t, {raw:true});\n\t\t\tif(piddsi.p === 'version') PropH[piddsi.n] = String(PropH[piddsi.n] >> 16) + \".\" + (\"0000\" + String(PropH[piddsi.n] & 0xFFFF)).slice(-4);\n\t\t\tif(piddsi.n == \"CodePage\") switch(PropH[piddsi.n]) {\n\t\t\t\tcase 0: PropH[piddsi.n] = 1252;\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 874:\n\t\t\t\tcase 932:\n\t\t\t\tcase 936:\n\t\t\t\tcase 949:\n\t\t\t\tcase 950:\n\t\t\t\tcase 1250:\n\t\t\t\tcase 1251:\n\t\t\t\tcase 1253:\n\t\t\t\tcase 1254:\n\t\t\t\tcase 1255:\n\t\t\t\tcase 1256:\n\t\t\t\tcase 1257:\n\t\t\t\tcase 1258:\n\t\t\t\tcase 10000:\n\t\t\t\tcase 1200:\n\t\t\t\tcase 1201:\n\t\t\t\tcase 1252:\n\t\t\t\tcase 65000: case -536:\n\t\t\t\tcase 65001: case -535:\n\t\t\t\t\tset_cp(CodePage = (PropH[piddsi.n]>>>0) & 0xFFFF); break;\n\t\t\t\tdefault: throw new Error(\"Unsupported CodePage: \" + PropH[piddsi.n]);\n\t\t\t}\n\t\t} else {\n\t\t\tif(Props[i][0] === 0x1) {\n\t\t\t\tCodePage = PropH.CodePage = (parse_TypedPropertyValue(blob, VT_I2)/*:number*/);\n\t\t\t\tset_cp(CodePage);\n\t\t\t\tif(Dictionary !== -1) {\n\t\t\t\t\tvar oldpos = blob.l;\n\t\t\t\t\tblob.l = Props[Dictionary][1];\n\t\t\t\t\tDictObj = parse_dictionary(blob,CodePage);\n\t\t\t\t\tblob.l = oldpos;\n\t\t\t\t}\n\t\t\t} else if(Props[i][0] === 0) {\n\t\t\t\tif(CodePage === 0) { Dictionary = i; blob.l = Props[i+1][1]; continue; }\n\t\t\t\tDictObj = parse_dictionary(blob,CodePage);\n\t\t\t} else {\n\t\t\t\tvar name = DictObj[Props[i][0]];\n\t\t\t\tvar val;\n\t\t\t\t/* [MS-OSHARED] 2.3.3.2.3.1.2 + PROPVARIANT */\n\t\t\t\tswitch(blob[blob.l]) {\n\t\t\t\t\tcase 0x41 /*VT_BLOB*/: blob.l += 4; val = parse_BLOB(blob); break;\n\t\t\t\t\tcase 0x1E /*VT_LPSTR*/: blob.l += 4; val = parse_VtString(blob, blob[blob.l-4]).replace(/\\u0000+$/,\"\"); break;\n\t\t\t\t\tcase 0x1F /*VT_LPWSTR*/: blob.l += 4; val = parse_VtString(blob, blob[blob.l-4]).replace(/\\u0000+$/,\"\"); break;\n\t\t\t\t\tcase 0x03 /*VT_I4*/: blob.l += 4; val = blob.read_shift(4, 'i'); break;\n\t\t\t\t\tcase 0x13 /*VT_UI4*/: blob.l += 4; val = blob.read_shift(4); break;\n\t\t\t\t\tcase 0x05 /*VT_R8*/: blob.l += 4; val = blob.read_shift(8, 'f'); break;\n\t\t\t\t\tcase 0x0B /*VT_BOOL*/: blob.l += 4; val = parsebool(blob, 4); break;\n\t\t\t\t\tcase 0x40 /*VT_FILETIME*/: blob.l += 4; val = parseDate(parse_FILETIME(blob)); break;\n\t\t\t\t\tdefault: throw new Error(\"unparsed value: \" + blob[blob.l]);\n\t\t\t\t}\n\t\t\t\tPropH[name] = val;\n\t\t\t}\n\t\t}\n\t}\n\tblob.l = start_addr + size; /* step ahead to skip padding */\n\treturn PropH;\n}\nvar XLSPSSkip = [ \"CodePage\", \"Thumbnail\", \"_PID_LINKBASE\", \"_PID_HLINKS\", \"SystemIdentifier\", \"FMTID\" ]; //.concat(PseudoPropsPairs);\nfunction guess_property_type(val/*:any*/)/*:number*/ {\n\tswitch(typeof val) {\n\t\tcase \"boolean\": return 0x0B;\n\t\tcase \"number\": return ((val|0)==val) ? 0x03 : 0x05;\n\t\tcase \"string\": return 0x1F;\n\t\tcase \"object\": if(val instanceof Date) return 0x40; break;\n\t}\n\treturn -1;\n}\nfunction write_PropertySet(entries, RE, PIDSI) {\n\tvar hdr = new_buf(8), piao = [], prop = [];\n\tvar sz = 8, i = 0;\n\n\tvar pr = new_buf(8), pio = new_buf(8);\n\tpr.write_shift(4, 0x0002);\n\tpr.write_shift(4, 0x04B0);\n\tpio.write_shift(4, 0x0001);\n\tprop.push(pr); piao.push(pio);\n\tsz += 8 + pr.length;\n\n\tif(!RE) {\n\t\tpio = new_buf(8);\n\t\tpio.write_shift(4, 0);\n\t\tpiao.unshift(pio);\n\n\t\tvar bufs = [new_buf(4)];\n\t\tbufs[0].write_shift(4, entries.length);\n\t\tfor(i = 0; i < entries.length; ++i) {\n\t\t\tvar value = entries[i][0];\n\t\t\tpr = new_buf(4 + 4 + 2 * (value.length + 1) + (value.length % 2 ? 0 : 2));\n\t\t\tpr.write_shift(4, i+2);\n\t\t\tpr.write_shift(4, value.length + 1);\n\t\t\tpr.write_shift(0, value, \"dbcs\");\n\t\t\twhile(pr.l != pr.length) pr.write_shift(1, 0);\n\t\t\tbufs.push(pr);\n\t\t}\n\t\tpr = bconcat(bufs);\n\t\tprop.unshift(pr);\n\t\tsz += 8 + pr.length;\n\t}\n\n\tfor(i = 0; i < entries.length; ++i) {\n\t\tif(RE && !RE[entries[i][0]]) continue;\n\t\tif(XLSPSSkip.indexOf(entries[i][0]) > -1 || PseudoPropsPairs.indexOf(entries[i][0]) > -1) continue;\n\t\tif(entries[i][1] == null) continue;\n\n\t\tvar val = entries[i][1], idx = 0;\n\t\tif(RE) {\n\t\t\tidx = +RE[entries[i][0]];\n\t\t\tvar pinfo = (PIDSI/*:: || {}*/)[idx]/*:: || {} */;\n\t\t\tif(pinfo.p == \"version\" && typeof val == \"string\") {\n\t\t\t\t/*:: if(typeof val !== \"string\") throw \"unreachable\"; */\n\t\t\t\tvar arr = val.split(\".\");\n\t\t\t\tval = ((+arr[0])<<16) + ((+arr[1])||0);\n\t\t\t}\n\t\t\tpr = write_TypedPropertyValue(pinfo.t, val);\n\t\t} else {\n\t\t\tvar T = guess_property_type(val);\n\t\t\tif(T == -1) { T = 0x1F; val = String(val); }\n\t\t\tpr = write_TypedPropertyValue(T, val);\n\t\t}\n\t\tprop.push(pr);\n\n\t\tpio = new_buf(8);\n\t\tpio.write_shift(4, !RE ? 2+i : idx);\n\t\tpiao.push(pio);\n\n\t\tsz += 8 + pr.length;\n\t}\n\n\tvar w = 8 * (prop.length + 1);\n\tfor(i = 0; i < prop.length; ++i) { piao[i].write_shift(4, w); w += prop[i].length; }\n\thdr.write_shift(4, sz);\n\thdr.write_shift(4, prop.length);\n\treturn bconcat([hdr].concat(piao).concat(prop));\n}\n\n/* [MS-OLEPS] 2.21 PropertySetStream */\nfunction parse_PropertySetStream(file, PIDSI, clsid) {\n\tvar blob = file.content;\n\tif(!blob) return ({}/*:any*/);\n\tprep_blob(blob, 0);\n\n\tvar NumSets, FMTID0, FMTID1, Offset0, Offset1 = 0;\n\tblob.chk('feff', 'Byte Order: ');\n\n\t/*var vers = */blob.read_shift(2); // TODO: check version\n\tvar SystemIdentifier = blob.read_shift(4);\n\tvar CLSID = blob.read_shift(16);\n\tif(CLSID !== CFB.utils.consts.HEADER_CLSID && CLSID !== clsid) throw new Error(\"Bad PropertySet CLSID \" + CLSID);\n\tNumSets = blob.read_shift(4);\n\tif(NumSets !== 1 && NumSets !== 2) throw new Error(\"Unrecognized #Sets: \" + NumSets);\n\tFMTID0 = blob.read_shift(16); Offset0 = blob.read_shift(4);\n\n\tif(NumSets === 1 && Offset0 !== blob.l) throw new Error(\"Length mismatch: \" + Offset0 + \" !== \" + blob.l);\n\telse if(NumSets === 2) { FMTID1 = blob.read_shift(16); Offset1 = blob.read_shift(4); }\n\tvar PSet0 = parse_PropertySet(blob, PIDSI);\n\n\tvar rval = ({ SystemIdentifier: SystemIdentifier }/*:any*/);\n\tfor(var y in PSet0) rval[y] = PSet0[y];\n\t//rval.blob = blob;\n\trval.FMTID = FMTID0;\n\t//rval.PSet0 = PSet0;\n\tif(NumSets === 1) return rval;\n\tif(Offset1 - blob.l == 2) blob.l += 2;\n\tif(blob.l !== Offset1) throw new Error(\"Length mismatch 2: \" + blob.l + \" !== \" + Offset1);\n\tvar PSet1;\n\ttry { PSet1 = parse_PropertySet(blob, null); } catch(e) {/* empty */}\n\tfor(y in PSet1) rval[y] = PSet1[y];\n\trval.FMTID = [FMTID0, FMTID1]; // TODO: verify FMTID0/1\n\treturn rval;\n}\nfunction write_PropertySetStream(entries, clsid, RE, PIDSI/*:{[key:string|number]:any}*/, entries2/*:?any*/, clsid2/*:?any*/) {\n\tvar hdr = new_buf(entries2 ? 68 : 48);\n\tvar bufs = [hdr];\n\thdr.write_shift(2, 0xFFFE);\n\thdr.write_shift(2, 0x0000); /* TODO: type 1 props */\n\thdr.write_shift(4, 0x32363237);\n\thdr.write_shift(16, CFB.utils.consts.HEADER_CLSID, \"hex\");\n\thdr.write_shift(4, (entries2 ? 2 : 1));\n\thdr.write_shift(16, clsid, \"hex\");\n\thdr.write_shift(4, (entries2 ? 68 : 48));\n\tvar ps0 = write_PropertySet(entries, RE, PIDSI);\n\tbufs.push(ps0);\n\n\tif(entries2) {\n\t\tvar ps1 = write_PropertySet(entries2, null, null);\n\t\thdr.write_shift(16, clsid2, \"hex\");\n\t\thdr.write_shift(4, 68 + ps0.length);\n\t\tbufs.push(ps1);\n\t}\n\treturn bconcat(bufs);\n}\n\nfunction parsenoop2(blob, length) { blob.read_shift(length); return null; }\nfunction writezeroes(n, o) { if(!o) o=new_buf(n); for(var j=0; j<n; ++j) o.write_shift(1, 0); return o; }\n\nfunction parslurp(blob, length, cb) {\n\tvar arr = [], target = blob.l + length;\n\twhile(blob.l < target) arr.push(cb(blob, target - blob.l));\n\tif(target !== blob.l) throw new Error(\"Slurp error\");\n\treturn arr;\n}\n\nfunction parsebool(blob, length/*:number*/) { return blob.read_shift(length) === 0x1; }\nfunction writebool(v/*:any*/, o) { if(!o) o=new_buf(2); o.write_shift(2, +!!v); return o; }\n\nfunction parseuint16(blob/*::, length:?number, opts:?any*/) { return blob.read_shift(2, 'u'); }\nfunction writeuint16(v/*:number*/, o) { if(!o) o=new_buf(2); o.write_shift(2, v); return o; }\nfunction parseuint16a(blob, length/*:: :?number, opts:?any*/) { return parslurp(blob,length,parseuint16);}\n\n/* --- 2.5 Structures --- */\n\n/* [MS-XLS] 2.5.10 Bes (boolean or error) */\nfunction parse_Bes(blob/*::, length*/) {\n\tvar v = blob.read_shift(1), t = blob.read_shift(1);\n\treturn t === 0x01 ? v : v === 0x01;\n}\nfunction write_Bes(v, t/*:string*/, o) {\n\tif(!o) o = new_buf(2);\n\to.write_shift(1, ((t == 'e') ? +v : +!!v));\n\to.write_shift(1, ((t == 'e') ? 1 : 0));\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.240 ShortXLUnicodeString */\nfunction parse_ShortXLUnicodeString(blob, length, opts) {\n\tvar cch = blob.read_shift(opts && opts.biff >= 12 ? 2 : 1);\n\tvar encoding = 'sbcs-cont';\n\tvar cp = current_codepage;\n\tif(opts && opts.biff >= 8) current_codepage = 1200;\n\tif(!opts || opts.biff == 8 ) {\n\t\tvar fHighByte = blob.read_shift(1);\n\t\tif(fHighByte) { encoding = 'dbcs-cont'; }\n\t} else if(opts.biff == 12) {\n\t\tencoding = 'wstr';\n\t}\n\tif(opts.biff >= 2 && opts.biff <= 5) encoding = 'cpstr';\n\tvar o = cch ? blob.read_shift(cch, encoding) : \"\";\n\tcurrent_codepage = cp;\n\treturn o;\n}\n\n/* 2.5.293 XLUnicodeRichExtendedString */\nfunction parse_XLUnicodeRichExtendedString(blob) {\n\tvar cp = current_codepage;\n\tcurrent_codepage = 1200;\n\tvar cch = blob.read_shift(2), flags = blob.read_shift(1);\n\tvar /*fHighByte = flags & 0x1,*/ fExtSt = flags & 0x4, fRichSt = flags & 0x8;\n\tvar width = 1 + (flags & 0x1); // 0x0 -> utf8, 0x1 -> dbcs\n\tvar cRun = 0, cbExtRst;\n\tvar z = {};\n\tif(fRichSt) cRun = blob.read_shift(2);\n\tif(fExtSt) cbExtRst = blob.read_shift(4);\n\tvar encoding = width == 2 ? 'dbcs-cont' : 'sbcs-cont';\n\tvar msg = cch === 0 ? \"\" : blob.read_shift(cch, encoding);\n\tif(fRichSt) blob.l += 4 * cRun; //TODO: parse this\n\tif(fExtSt) blob.l += cbExtRst; //TODO: parse this\n\tz.t = msg;\n\tif(!fRichSt) { z.raw = \"<t>\" + z.t + \"</t>\"; z.r = z.t; }\n\tcurrent_codepage = cp;\n\treturn z;\n}\nfunction write_XLUnicodeRichExtendedString(xlstr/*:: :XLString, opts*/) {\n\tvar str = (xlstr.t||\"\"), nfmts = 1;\n\n\tvar hdr = new_buf(3 + (nfmts > 1 ? 2 : 0));\n\thdr.write_shift(2, str.length);\n\thdr.write_shift(1, (nfmts > 1 ? 0x08 : 0x00) | 0x01);\n\tif(nfmts > 1) hdr.write_shift(2, nfmts);\n\n\tvar otext = new_buf(2 * str.length);\n\totext.write_shift(2 * str.length, str, 'utf16le');\n\n\tvar out = [hdr, otext];\n\n\treturn bconcat(out);\n}\n\n/* 2.5.296 XLUnicodeStringNoCch */\nfunction parse_XLUnicodeStringNoCch(blob, cch, opts) {\n\tvar retval;\n\tif(opts) {\n\t\tif(opts.biff >= 2 && opts.biff <= 5) return blob.read_shift(cch, 'cpstr');\n\t\tif(opts.biff >= 12) return blob.read_shift(cch, 'dbcs-cont');\n\t}\n\tvar fHighByte = blob.read_shift(1);\n\tif(fHighByte===0) { retval = blob.read_shift(cch, 'sbcs-cont'); }\n\telse { retval = blob.read_shift(cch, 'dbcs-cont'); }\n\treturn retval;\n}\n\n/* 2.5.294 XLUnicodeString */\nfunction parse_XLUnicodeString(blob, length, opts) {\n\tvar cch = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\tif(cch === 0) { blob.l++; return \"\"; }\n\treturn parse_XLUnicodeStringNoCch(blob, cch, opts);\n}\n/* BIFF5 override */\nfunction parse_XLUnicodeString2(blob, length, opts) {\n\tif(opts.biff > 5) return parse_XLUnicodeString(blob, length, opts);\n\tvar cch = blob.read_shift(1);\n\tif(cch === 0) { blob.l++; return \"\"; }\n\treturn blob.read_shift(cch, (opts.biff <= 4 || !blob.lens ) ? 'cpstr' : 'sbcs-cont');\n}\n/* TODO: BIFF5 and lower, codepage awareness */\nfunction write_XLUnicodeString(str, opts, o) {\n\tif(!o) o = new_buf(3 + 2 * str.length);\n\to.write_shift(2, str.length);\n\to.write_shift(1, 1);\n\to.write_shift(31, str, 'utf16le');\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.61 ControlInfo */\nfunction parse_ControlInfo(blob/*::, length, opts*/) {\n\tvar flags = blob.read_shift(1);\n\tblob.l++;\n\tvar accel = blob.read_shift(2);\n\tblob.l += 2;\n\treturn [flags, accel];\n}\n\n/* [MS-OSHARED] 2.3.7.6 URLMoniker TODO: flags */\nfunction parse_URLMoniker(blob/*::, length, opts*/) {\n\tvar len = blob.read_shift(4), start = blob.l;\n\tvar extra = false;\n\tif(len > 24) {\n\t\t/* look ahead */\n\t\tblob.l += len - 24;\n\t\tif(blob.read_shift(16) === \"795881f43b1d7f48af2c825dc4852763\") extra = true;\n\t\tblob.l = start;\n\t}\n\tvar url = blob.read_shift((extra?len-24:len)>>1, 'utf16le').replace(chr0,\"\");\n\tif(extra) blob.l += 24;\n\treturn url;\n}\n\n/* [MS-OSHARED] 2.3.7.8 FileMoniker TODO: all fields */\nfunction parse_FileMoniker(blob/*::, length*/) {\n\tvar cAnti = blob.read_shift(2);\n\tvar preamble = \"\"; while(cAnti-- > 0) preamble += \"../\";\n\tvar ansiPath = blob.read_shift(0, 'lpstr-ansi');\n\tblob.l += 2; //var endServer = blob.read_shift(2);\n\tif(blob.read_shift(2) != 0xDEAD) throw new Error(\"Bad FileMoniker\");\n\tvar sz = blob.read_shift(4);\n\tif(sz === 0) return preamble + ansiPath.replace(/\\\\/g,\"/\");\n\tvar bytes = blob.read_shift(4);\n\tif(blob.read_shift(2) != 3) throw new Error(\"Bad FileMoniker\");\n\tvar unicodePath = blob.read_shift(bytes>>1, 'utf16le').replace(chr0,\"\");\n\treturn preamble + unicodePath;\n}\n\n/* [MS-OSHARED] 2.3.7.2 HyperlinkMoniker TODO: all the monikers */\nfunction parse_HyperlinkMoniker(blob, length) {\n\tvar clsid = blob.read_shift(16); length -= 16;\n\tswitch(clsid) {\n\t\tcase \"e0c9ea79f9bace118c8200aa004ba90b\": return parse_URLMoniker(blob, length);\n\t\tcase \"0303000000000000c000000000000046\": return parse_FileMoniker(blob, length);\n\t\tdefault: throw new Error(\"Unsupported Moniker \" + clsid);\n\t}\n}\n\n/* [MS-OSHARED] 2.3.7.9 HyperlinkString */\nfunction parse_HyperlinkString(blob/*::, length*/) {\n\tvar len = blob.read_shift(4);\n\tvar o = len > 0 ? blob.read_shift(len, 'utf16le').replace(chr0, \"\") : \"\";\n\treturn o;\n}\nfunction write_HyperlinkString(str/*:string*/, o) {\n\tif(!o) o = new_buf(6 + str.length * 2);\n\to.write_shift(4, 1 + str.length);\n\tfor(var i = 0; i < str.length; ++i) o.write_shift(2, str.charCodeAt(i));\n\to.write_shift(2, 0);\n\treturn o;\n}\n\n/* [MS-OSHARED] 2.3.7.1 Hyperlink Object */\nfunction parse_Hyperlink(blob, length)/*:Hyperlink*/ {\n\tvar end = blob.l + length;\n\tvar sVer = blob.read_shift(4);\n\tif(sVer !== 2) throw new Error(\"Unrecognized streamVersion: \" + sVer);\n\tvar flags = blob.read_shift(2);\n\tblob.l += 2;\n\tvar displayName, targetFrameName, moniker, oleMoniker, Loc=\"\", guid, fileTime;\n\tif(flags & 0x0010) displayName = parse_HyperlinkString(blob, end - blob.l);\n\tif(flags & 0x0080) targetFrameName = parse_HyperlinkString(blob, end - blob.l);\n\tif((flags & 0x0101) === 0x0101) moniker = parse_HyperlinkString(blob, end - blob.l);\n\tif((flags & 0x0101) === 0x0001) oleMoniker = parse_HyperlinkMoniker(blob, end - blob.l);\n\tif(flags & 0x0008) Loc = parse_HyperlinkString(blob, end - blob.l);\n\tif(flags & 0x0020) guid = blob.read_shift(16);\n\tif(flags & 0x0040) fileTime = parse_FILETIME(blob/*, 8*/);\n\tblob.l = end;\n\tvar target = targetFrameName||moniker||oleMoniker||\"\";\n\tif(target && Loc) target+=\"#\"+Loc;\n\tif(!target) target = \"#\" + Loc;\n\tif((flags & 0x0002) && target.charAt(0) == \"/\" && target.charAt(1) != \"/\") target = \"file://\" + target;\n\tvar out = ({Target:target}/*:any*/);\n\tif(guid) out.guid = guid;\n\tif(fileTime) out.time = fileTime;\n\tif(displayName) out.Tooltip = displayName;\n\treturn out;\n}\nfunction write_Hyperlink(hl) {\n\tvar out = new_buf(512), i = 0;\n\tvar Target = hl.Target;\n\tif(Target.slice(0,7) == \"file://\") Target = Target.slice(7);\n\tvar hashidx = Target.indexOf(\"#\");\n\tvar F = hashidx > -1 ? 0x1f : 0x17;\n\tswitch(Target.charAt(0)) { case \"#\": F=0x1c; break; case \".\": F&=~2; break; }\n\tout.write_shift(4,2); out.write_shift(4, F);\n\tvar data = [8,6815827,6619237,4849780,83]; for(i = 0; i < data.length; ++i) out.write_shift(4, data[i]);\n\tif(F == 0x1C) {\n\t\tTarget = Target.slice(1);\n\t\twrite_HyperlinkString(Target, out);\n\t} else if(F & 0x02) {\n\t\tdata = \"e0 c9 ea 79 f9 ba ce 11 8c 82 00 aa 00 4b a9 0b\".split(\" \");\n\t\tfor(i = 0; i < data.length; ++i) out.write_shift(1, parseInt(data[i], 16));\n\t\tvar Pretarget = hashidx > -1 ? Target.slice(0, hashidx) : Target;\n\t\tout.write_shift(4, 2*(Pretarget.length + 1));\n\t\tfor(i = 0; i < Pretarget.length; ++i) out.write_shift(2, Pretarget.charCodeAt(i));\n\t\tout.write_shift(2, 0);\n\t\tif(F & 0x08) write_HyperlinkString(hashidx > -1 ? Target.slice(hashidx+1): \"\", out);\n\t} else {\n\t\tdata = \"03 03 00 00 00 00 00 00 c0 00 00 00 00 00 00 46\".split(\" \");\n\t\tfor(i = 0; i < data.length; ++i) out.write_shift(1, parseInt(data[i], 16));\n\t\tvar P = 0;\n\t\twhile(Target.slice(P*3,P*3+3)==\"../\"||Target.slice(P*3,P*3+3)==\"..\\\\\") ++P;\n\t\tout.write_shift(2, P);\n\t\tout.write_shift(4, Target.length - 3 * P + 1);\n\t\tfor(i = 0; i < Target.length - 3 * P; ++i) out.write_shift(1, Target.charCodeAt(i + 3 * P) & 0xFF);\n\t\tout.write_shift(1, 0);\n\t\tout.write_shift(2, 0xFFFF);\n\t\tout.write_shift(2, 0xDEAD);\n\t\tfor(i = 0; i < 6; ++i) out.write_shift(4, 0);\n\t}\n\treturn out.slice(0, out.l);\n}\n\n/* 2.5.178 LongRGBA */\nfunction parse_LongRGBA(blob/*::, length*/) { var r = blob.read_shift(1), g = blob.read_shift(1), b = blob.read_shift(1), a = blob.read_shift(1); return [r,g,b,a]; }\n\n/* 2.5.177 LongRGB */\nfunction parse_LongRGB(blob, length) { var x = parse_LongRGBA(blob, length); x[3] = 0; return x; }\n\n\n/* [MS-XLS] 2.5.19 */\nfunction parse_XLSCell(blob/*::, length*/)/*:Cell*/ {\n\tvar rw = blob.read_shift(2); // 0-indexed\n\tvar col = blob.read_shift(2);\n\tvar ixfe = blob.read_shift(2);\n\treturn ({r:rw, c:col, ixfe:ixfe}/*:any*/);\n}\nfunction write_XLSCell(R/*:number*/, C/*:number*/, ixfe/*:?number*/, o) {\n\tif(!o) o = new_buf(6);\n\to.write_shift(2, R);\n\to.write_shift(2, C);\n\to.write_shift(2, ixfe||0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.134 */\nfunction parse_frtHeader(blob) {\n\tvar rt = blob.read_shift(2);\n\tvar flags = blob.read_shift(2); // TODO: parse these flags\n\tblob.l += 8;\n\treturn {type: rt, flags: flags};\n}\n\n\n\nfunction parse_OptXLUnicodeString(blob, length, opts) { return length === 0 ? \"\" : parse_XLUnicodeString2(blob, length, opts); }\n\n/* [MS-XLS] 2.5.344 */\nfunction parse_XTI(blob, length, opts) {\n\tvar w = opts.biff > 8 ? 4 : 2;\n\tvar iSupBook = blob.read_shift(w), itabFirst = blob.read_shift(w,'i'), itabLast = blob.read_shift(w,'i');\n\treturn [iSupBook, itabFirst, itabLast];\n}\n\n/* [MS-XLS] 2.5.218 */\nfunction parse_RkRec(blob) {\n\tvar ixfe = blob.read_shift(2);\n\tvar RK = parse_RkNumber(blob);\n\treturn [ixfe, RK];\n}\n\n/* [MS-XLS] 2.5.1 */\nfunction parse_AddinUdf(blob, length, opts) {\n\tblob.l += 4; length -= 4;\n\tvar l = blob.l + length;\n\tvar udfName = parse_ShortXLUnicodeString(blob, length, opts);\n\tvar cb = blob.read_shift(2);\n\tl -= blob.l;\n\tif(cb !== l) throw new Error(\"Malformed AddinUdf: padding = \" + l + \" != \" + cb);\n\tblob.l += cb;\n\treturn udfName;\n}\n\n/* [MS-XLS] 2.5.209 TODO: Check sizes */\nfunction parse_Ref8U(blob/*::, length*/) {\n\tvar rwFirst = blob.read_shift(2);\n\tvar rwLast = blob.read_shift(2);\n\tvar colFirst = blob.read_shift(2);\n\tvar colLast = blob.read_shift(2);\n\treturn {s:{c:colFirst, r:rwFirst}, e:{c:colLast,r:rwLast}};\n}\nfunction write_Ref8U(r/*:Range*/, o) {\n\tif(!o) o = new_buf(8);\n\to.write_shift(2, r.s.r);\n\to.write_shift(2, r.e.r);\n\to.write_shift(2, r.s.c);\n\to.write_shift(2, r.e.c);\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.211 */\nfunction parse_RefU(blob/*::, length*/) {\n\tvar rwFirst = blob.read_shift(2);\n\tvar rwLast = blob.read_shift(2);\n\tvar colFirst = blob.read_shift(1);\n\tvar colLast = blob.read_shift(1);\n\treturn {s:{c:colFirst, r:rwFirst}, e:{c:colLast,r:rwLast}};\n}\n\n/* [MS-XLS] 2.5.207 */\nvar parse_Ref = parse_RefU;\n\n/* [MS-XLS] 2.5.143 */\nfunction parse_FtCmo(blob/*::, length*/) {\n\tblob.l += 4;\n\tvar ot = blob.read_shift(2);\n\tvar id = blob.read_shift(2);\n\tvar flags = blob.read_shift(2);\n\tblob.l+=12;\n\treturn [id, ot, flags];\n}\n\n/* [MS-XLS] 2.5.149 */\nfunction parse_FtNts(blob) {\n\tvar out = {};\n\tblob.l += 4;\n\tblob.l += 16; // GUID TODO\n\tout.fSharedNote = blob.read_shift(2);\n\tblob.l += 4;\n\treturn out;\n}\n\n/* [MS-XLS] 2.5.142 */\nfunction parse_FtCf(blob) {\n\tvar out = {};\n\tblob.l += 4;\n\tblob.cf = blob.read_shift(2);\n\treturn out;\n}\n\n/* [MS-XLS] 2.5.140 - 2.5.154 and friends */\nfunction parse_FtSkip(blob) { blob.l += 2; blob.l += blob.read_shift(2); }\nvar FtTab = {\n\t/*::[*/0x00/*::]*/: parse_FtSkip, /* FtEnd */\n\t/*::[*/0x04/*::]*/: parse_FtSkip, /* FtMacro */\n\t/*::[*/0x05/*::]*/: parse_FtSkip, /* FtButton */\n\t/*::[*/0x06/*::]*/: parse_FtSkip, /* FtGmo */\n\t/*::[*/0x07/*::]*/: parse_FtCf, /* FtCf */\n\t/*::[*/0x08/*::]*/: parse_FtSkip, /* FtPioGrbit */\n\t/*::[*/0x09/*::]*/: parse_FtSkip, /* FtPictFmla */\n\t/*::[*/0x0A/*::]*/: parse_FtSkip, /* FtCbls */\n\t/*::[*/0x0B/*::]*/: parse_FtSkip, /* FtRbo */\n\t/*::[*/0x0C/*::]*/: parse_FtSkip, /* FtSbs */\n\t/*::[*/0x0D/*::]*/: parse_FtNts, /* FtNts */\n\t/*::[*/0x0E/*::]*/: parse_FtSkip, /* FtSbsFmla */\n\t/*::[*/0x0F/*::]*/: parse_FtSkip, /* FtGboData */\n\t/*::[*/0x10/*::]*/: parse_FtSkip, /* FtEdoData */\n\t/*::[*/0x11/*::]*/: parse_FtSkip, /* FtRboData */\n\t/*::[*/0x12/*::]*/: parse_FtSkip, /* FtCblsData */\n\t/*::[*/0x13/*::]*/: parse_FtSkip, /* FtLbsData */\n\t/*::[*/0x14/*::]*/: parse_FtSkip, /* FtCblsFmla */\n\t/*::[*/0x15/*::]*/: parse_FtCmo\n};\nfunction parse_FtArray(blob, length/*::, ot*/) {\n\tvar tgt = blob.l + length;\n\tvar fts = [];\n\twhile(blob.l < tgt) {\n\t\tvar ft = blob.read_shift(2);\n\t\tblob.l-=2;\n\t\ttry {\n\t\t\tfts.push(FtTab[ft](blob, tgt - blob.l));\n\t\t} catch(e) { blob.l = tgt; return fts; }\n\t}\n\tif(blob.l != tgt) blob.l = tgt; //throw new Error(\"bad Object Ft-sequence\");\n\treturn fts;\n}\n\n/* --- 2.4 Records --- */\n\n/* [MS-XLS] 2.4.21 */\nfunction parse_BOF(blob, length) {\n\tvar o = {BIFFVer:0, dt:0};\n\to.BIFFVer = blob.read_shift(2); length -= 2;\n\tif(length >= 2) { o.dt = blob.read_shift(2); blob.l -= 2; }\n\tswitch(o.BIFFVer) {\n\t\tcase 0x0600: /* BIFF8 */\n\t\tcase 0x0500: /* BIFF5 */\n\t\tcase 0x0400: /* BIFF4 */\n\t\tcase 0x0300: /* BIFF3 */\n\t\tcase 0x0200: /* BIFF2 */\n\t\tcase 0x0002: case 0x0007: /* BIFF2 */\n\t\t\tbreak;\n\t\tdefault: if(length > 6) throw new Error(\"Unexpected BIFF Ver \" + o.BIFFVer);\n\t}\n\n\tblob.read_shift(length);\n\treturn o;\n}\nfunction write_BOF(wb/*:Workbook*/, t/*:number*/, o) {\n\tvar h = 0x0600, w = 16;\n\tswitch(o.bookType) {\n\t\tcase 'biff8': break;\n\t\tcase 'biff5': h = 0x0500; w = 8; break;\n\t\tcase 'biff4': h = 0x0004; w = 6; break;\n\t\tcase 'biff3': h = 0x0003; w = 6; break;\n\t\tcase 'biff2': h = 0x0002; w = 4; break;\n\t\tcase 'xla': break;\n\t\tdefault: throw new Error(\"unsupported BIFF version\");\n\t}\n\tvar out = new_buf(w);\n\tout.write_shift(2, h);\n\tout.write_shift(2, t);\n\tif(w > 4) out.write_shift(2, 0x7262);\n\tif(w > 6) out.write_shift(2, 0x07CD);\n\tif(w > 8) {\n\t\tout.write_shift(2, 0xC009);\n\t\tout.write_shift(2, 0x0001);\n\t\tout.write_shift(2, 0x0706);\n\t\tout.write_shift(2, 0x0000);\n\t}\n\treturn out;\n}\n\n\n/* [MS-XLS] 2.4.146 */\nfunction parse_InterfaceHdr(blob, length) {\n\tif(length === 0) return 0x04b0;\n\tif((blob.read_shift(2))!==0x04b0){/* empty */}\n\treturn 0x04b0;\n}\n\n\n/* [MS-XLS] 2.4.349 */\nfunction parse_WriteAccess(blob, length, opts) {\n\tif(opts.enc) { blob.l += length; return \"\"; }\n\tvar l = blob.l;\n\t// TODO: make sure XLUnicodeString doesnt overrun\n\tvar UserName = parse_XLUnicodeString2(blob, 0, opts);\n\tblob.read_shift(length + l - blob.l);\n\treturn UserName;\n}\nfunction write_WriteAccess(s/*:string*/, opts) {\n\tvar b8 = !opts || opts.biff == 8;\n\tvar o = new_buf(b8 ? 112 : 54);\n\to.write_shift(opts.biff == 8 ? 2 : 1, 7);\n\tif(b8) o.write_shift(1, 0);\n\to.write_shift(4, 0x33336853);\n\to.write_shift(4, (0x00534A74 | (b8 ? 0 : 0x20000000)));\n\twhile(o.l < o.length) o.write_shift(1, (b8 ? 0 : 32));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.351 */\nfunction parse_WsBool(blob, length, opts) {\n\tvar flags = opts && opts.biff == 8 || length == 2 ? blob.read_shift(2) : (blob.l += length, 0);\n\treturn { fDialog: flags & 0x10, fBelow: flags & 0x40, fRight: flags & 0x80 };\n}\n\n/* [MS-XLS] 2.4.28 */\nfunction parse_BoundSheet8(blob, length, opts) {\n\tvar pos = blob.read_shift(4);\n\tvar hidden = blob.read_shift(1) & 0x03;\n\tvar dt = blob.read_shift(1);\n\tswitch(dt) {\n\t\tcase 0: dt = 'Worksheet'; break;\n\t\tcase 1: dt = 'Macrosheet'; break;\n\t\tcase 2: dt = 'Chartsheet'; break;\n\t\tcase 6: dt = 'VBAModule'; break;\n\t}\n\tvar name = parse_ShortXLUnicodeString(blob, 0, opts);\n\tif(name.length === 0) name = \"Sheet1\";\n\treturn { pos:pos, hs:hidden, dt:dt, name:name };\n}\nfunction write_BoundSheet8(data, opts) {\n\tvar w = (!opts || opts.biff >= 8 ? 2 : 1);\n\tvar o = new_buf(8 + w * data.name.length);\n\to.write_shift(4, data.pos);\n\to.write_shift(1, data.hs || 0);\n\to.write_shift(1, data.dt);\n\to.write_shift(1, data.name.length);\n\tif(opts.biff >= 8) o.write_shift(1, 1);\n\to.write_shift(w * data.name.length, data.name, opts.biff < 8 ? 'sbcs' : 'utf16le');\n\tvar out = o.slice(0, o.l);\n\tout.l = o.l; return out;\n}\n\n/* [MS-XLS] 2.4.265 TODO */\nfunction parse_SST(blob, length)/*:SST*/ {\n\tvar end = blob.l + length;\n\tvar cnt = blob.read_shift(4);\n\tvar ucnt = blob.read_shift(4);\n\tvar strs/*:SST*/ = ([]/*:any*/);\n\tfor(var i = 0; i != ucnt && blob.l < end; ++i) {\n\t\tstrs.push(parse_XLUnicodeRichExtendedString(blob));\n\t}\n\tstrs.Count = cnt; strs.Unique = ucnt;\n\treturn strs;\n}\nfunction write_SST(sst, opts) {\n\tvar header = new_buf(8);\n\theader.write_shift(4, sst.Count);\n\theader.write_shift(4, sst.Unique);\n\tvar strs = [];\n\tfor(var j = 0; j < sst.length; ++j) strs[j] = write_XLUnicodeRichExtendedString(sst[j], opts);\n\tvar o = bconcat([header].concat(strs));\n\t/*::(*/o/*:: :any)*/.parts = [header.length].concat(strs.map(function(str) { return str.length; }));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.107 */\nfunction parse_ExtSST(blob, length) {\n\tvar extsst = {};\n\textsst.dsst = blob.read_shift(2);\n\tblob.l += length-2;\n\treturn extsst;\n}\n\n\n/* [MS-XLS] 2.4.221 TODO: check BIFF2-4 */\nfunction parse_Row(blob) {\n\tvar z = ({}/*:any*/);\n\tz.r = blob.read_shift(2);\n\tz.c = blob.read_shift(2);\n\tz.cnt = blob.read_shift(2) - z.c;\n\tvar miyRw = blob.read_shift(2);\n\tblob.l += 4; // reserved(2), unused(2)\n\tvar flags = blob.read_shift(1); // various flags\n\tblob.l += 3; // reserved(8), ixfe(12), flags(4)\n\tif(flags & 0x07) z.level = flags & 0x07;\n\t// collapsed: flags & 0x10\n\tif(flags & 0x20) z.hidden = true;\n\tif(flags & 0x40) z.hpt = miyRw / 20;\n\treturn z;\n}\n\n\n/* [MS-XLS] 2.4.125 */\nfunction parse_ForceFullCalculation(blob) {\n\tvar header = parse_frtHeader(blob);\n\tif(header.type != 0x08A3) throw new Error(\"Invalid Future Record \" + header.type);\n\tvar fullcalc = blob.read_shift(4);\n\treturn fullcalc !== 0x0;\n}\n\n\n\n\n\n/* [MS-XLS] 2.4.215 rt */\nfunction parse_RecalcId(blob) {\n\tblob.read_shift(2);\n\treturn blob.read_shift(4);\n}\n\n/* [MS-XLS] 2.4.87 */\nfunction parse_DefaultRowHeight(blob, length, opts) {\n\tvar f = 0;\n\tif(!(opts && opts.biff == 2)) {\n\t\tf = blob.read_shift(2);\n\t}\n\tvar miyRw = blob.read_shift(2);\n\tif((opts && opts.biff == 2)) {\n\t\tf = 1 - (miyRw >> 15); miyRw &= 0x7fff;\n\t}\n\tvar fl = {Unsynced:f&1,DyZero:(f&2)>>1,ExAsc:(f&4)>>2,ExDsc:(f&8)>>3};\n\treturn [fl, miyRw];\n}\n\n/* [MS-XLS] 2.4.345 TODO */\nfunction parse_Window1(blob) {\n\tvar xWn = blob.read_shift(2), yWn = blob.read_shift(2), dxWn = blob.read_shift(2), dyWn = blob.read_shift(2);\n\tvar flags = blob.read_shift(2), iTabCur = blob.read_shift(2), iTabFirst = blob.read_shift(2);\n\tvar ctabSel = blob.read_shift(2), wTabRatio = blob.read_shift(2);\n\treturn { Pos: [xWn, yWn], Dim: [dxWn, dyWn], Flags: flags, CurTab: iTabCur,\n\t\tFirstTab: iTabFirst, Selected: ctabSel, TabRatio: wTabRatio };\n}\nfunction write_Window1(/*::opts*/) {\n\tvar o = new_buf(18);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0x7260);\n\to.write_shift(2, 0x44c0);\n\to.write_shift(2, 0x38);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, 1);\n\to.write_shift(2, 0x01f4);\n\treturn o;\n}\n/* [MS-XLS] 2.4.346 TODO */\nfunction parse_Window2(blob, length, opts) {\n\tif(opts && opts.biff >= 2 && opts.biff < 5) return {};\n\tvar f = blob.read_shift(2);\n\treturn { RTL: f & 0x40 };\n}\nfunction write_Window2(view) {\n\tvar o = new_buf(18), f = 0x6b6;\n\tif(view && view.RTL) f |= 0x40;\n\to.write_shift(2, f);\n\to.write_shift(4, 0);\n\to.write_shift(4, 64);\n\to.write_shift(4, 0);\n\to.write_shift(4, 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.189 TODO */\nfunction parse_Pane(/*blob, length, opts*/) {\n}\n\n/* [MS-XLS] 2.4.122 TODO */\nfunction parse_Font(blob, length, opts) {\n\tvar o/*:any*/ = {\n\t\tdyHeight: blob.read_shift(2),\n\t\tfl: blob.read_shift(2)\n\t};\n\tswitch((opts && opts.biff) || 8) {\n\t\tcase 2: break;\n\t\tcase 3: case 4: blob.l += 2; break;\n\t\tdefault: blob.l += 10; break;\n\t}\n\to.name = parse_ShortXLUnicodeString(blob, 0, opts);\n\treturn o;\n}\nfunction write_Font(data, opts) {\n\tvar name = data.name || \"Arial\";\n\tvar b5 = (opts && (opts.biff == 5)), w = (b5 ? (15 + name.length) : (16 + 2 * name.length));\n\tvar o = new_buf(w);\n\to.write_shift(2, (data.sz || 12) * 20);\n\to.write_shift(4, 0);\n\to.write_shift(2, 400);\n\to.write_shift(4, 0);\n\to.write_shift(2, 0);\n\to.write_shift(1, name.length);\n\tif(!b5) o.write_shift(1, 1);\n\to.write_shift((b5 ? 1 : 2) * name.length, name, (b5 ? \"sbcs\" : \"utf16le\"));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.149 */\nfunction parse_LabelSst(blob) {\n\tvar cell = parse_XLSCell(blob);\n\tcell.isst = blob.read_shift(4);\n\treturn cell;\n}\nfunction write_LabelSst(R/*:number*/, C/*:number*/, v/*:number*/, os/*:number*/ /*::, opts*/) {\n\tvar o = new_buf(10);\n\twrite_XLSCell(R, C, os, o);\n\to.write_shift(4, v);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.148 */\nfunction parse_Label(blob, length, opts) {\n\tif(opts.biffguess && opts.biff == 2) opts.biff = 5;\n\tvar target = blob.l + length;\n\tvar cell = parse_XLSCell(blob, 6);\n\tif(opts.biff == 2) blob.l++;\n\tvar str = parse_XLUnicodeString(blob, target - blob.l, opts);\n\tcell.val = str;\n\treturn cell;\n}\nfunction write_Label(R/*:number*/, C/*:number*/, v/*:string*/, os/*:number*/, opts) {\n\tvar b8 = !opts || opts.biff == 8;\n\tvar o = new_buf(6 + 2 + (+b8) + (1 + b8) * v.length);\n\twrite_XLSCell(R, C, os, o);\n\to.write_shift(2, v.length);\n\tif(b8) o.write_shift(1, 1);\n\to.write_shift((1 + b8) * v.length, v, b8 ? 'utf16le' : 'sbcs');\n\treturn o;\n}\n\n\n/* [MS-XLS] 2.4.126 Number Formats */\nfunction parse_Format(blob, length, opts) {\n\tvar numFmtId = blob.read_shift(2);\n\tvar fmtstr = parse_XLUnicodeString2(blob, 0, opts);\n\treturn [numFmtId, fmtstr];\n}\nfunction write_Format(i/*:number*/, f/*:string*/, opts, o) {\n\tvar b5 = (opts && (opts.biff == 5));\n\tif(!o) o = new_buf(b5 ? (3 + f.length) : (5 + 2 * f.length));\n\to.write_shift(2, i);\n\to.write_shift((b5 ? 1 : 2), f.length);\n\tif(!b5) o.write_shift(1, 1);\n\to.write_shift((b5 ? 1 : 2) * f.length, f, (b5 ? 'sbcs' : 'utf16le'));\n\tvar out = (o.length > o.l) ? o.slice(0, o.l) : o;\n\tif(out.l == null) out.l = out.length;\n\treturn out;\n}\nvar parse_BIFF2Format = parse_XLUnicodeString2;\n\n/* [MS-XLS] 2.4.90 */\nfunction parse_Dimensions(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar w = opts.biff == 8 || !opts.biff ? 4 : 2;\n\tvar r = blob.read_shift(w), R = blob.read_shift(w);\n\tvar c = blob.read_shift(2), C = blob.read_shift(2);\n\tblob.l = end;\n\treturn {s: {r:r, c:c}, e: {r:R, c:C}};\n}\nfunction write_Dimensions(range, opts) {\n\tvar w = opts.biff == 8 || !opts.biff ? 4 : 2;\n\tvar o = new_buf(2*w + 6);\n\to.write_shift(w, range.s.r);\n\to.write_shift(w, range.e.r + 1);\n\to.write_shift(2, range.s.c);\n\to.write_shift(2, range.e.c + 1);\n\to.write_shift(2, 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.220 */\nfunction parse_RK(blob) {\n\tvar rw = blob.read_shift(2), col = blob.read_shift(2);\n\tvar rkrec = parse_RkRec(blob);\n\treturn {r:rw, c:col, ixfe:rkrec[0], rknum:rkrec[1]};\n}\n\n/* [MS-XLS] 2.4.175 */\nfunction parse_MulRk(blob, length) {\n\tvar target = blob.l + length - 2;\n\tvar rw = blob.read_shift(2), col = blob.read_shift(2);\n\tvar rkrecs = [];\n\twhile(blob.l < target) rkrecs.push(parse_RkRec(blob));\n\tif(blob.l !== target) throw new Error(\"MulRK read error\");\n\tvar lastcol = blob.read_shift(2);\n\tif(rkrecs.length != lastcol - col + 1) throw new Error(\"MulRK length mismatch\");\n\treturn {r:rw, c:col, C:lastcol, rkrec:rkrecs};\n}\n/* [MS-XLS] 2.4.174 */\nfunction parse_MulBlank(blob, length) {\n\tvar target = blob.l + length - 2;\n\tvar rw = blob.read_shift(2), col = blob.read_shift(2);\n\tvar ixfes = [];\n\twhile(blob.l < target) ixfes.push(blob.read_shift(2));\n\tif(blob.l !== target) throw new Error(\"MulBlank read error\");\n\tvar lastcol = blob.read_shift(2);\n\tif(ixfes.length != lastcol - col + 1) throw new Error(\"MulBlank length mismatch\");\n\treturn {r:rw, c:col, C:lastcol, ixfe:ixfes};\n}\n\n/* [MS-XLS] 2.5.20 2.5.249 TODO: interpret values here */\nfunction parse_CellStyleXF(blob, length, style, opts) {\n\tvar o = {};\n\tvar a = blob.read_shift(4), b = blob.read_shift(4);\n\tvar c = blob.read_shift(4), d = blob.read_shift(2);\n\to.patternType = XLSFillPattern[c >> 26];\n\n\tif(!opts.cellStyles) return o;\n\to.alc = a & 0x07;\n\to.fWrap = (a >> 3) & 0x01;\n\to.alcV = (a >> 4) & 0x07;\n\to.fJustLast = (a >> 7) & 0x01;\n\to.trot = (a >> 8) & 0xFF;\n\to.cIndent = (a >> 16) & 0x0F;\n\to.fShrinkToFit = (a >> 20) & 0x01;\n\to.iReadOrder = (a >> 22) & 0x02;\n\to.fAtrNum = (a >> 26) & 0x01;\n\to.fAtrFnt = (a >> 27) & 0x01;\n\to.fAtrAlc = (a >> 28) & 0x01;\n\to.fAtrBdr = (a >> 29) & 0x01;\n\to.fAtrPat = (a >> 30) & 0x01;\n\to.fAtrProt = (a >> 31) & 0x01;\n\n\to.dgLeft = b & 0x0F;\n\to.dgRight = (b >> 4) & 0x0F;\n\to.dgTop = (b >> 8) & 0x0F;\n\to.dgBottom = (b >> 12) & 0x0F;\n\to.icvLeft = (b >> 16) & 0x7F;\n\to.icvRight = (b >> 23) & 0x7F;\n\to.grbitDiag = (b >> 30) & 0x03;\n\n\to.icvTop = c & 0x7F;\n\to.icvBottom = (c >> 7) & 0x7F;\n\to.icvDiag = (c >> 14) & 0x7F;\n\to.dgDiag = (c >> 21) & 0x0F;\n\n\to.icvFore = d & 0x7F;\n\to.icvBack = (d >> 7) & 0x7F;\n\to.fsxButton = (d >> 14) & 0x01;\n\treturn o;\n}\n//function parse_CellXF(blob, length, opts) {return parse_CellStyleXF(blob,length,0, opts);}\n//function parse_StyleXF(blob, length, opts) {return parse_CellStyleXF(blob,length,1, opts);}\n\n/* [MS-XLS] 2.4.353 TODO: actually do this right */\nfunction parse_XF(blob, length, opts) {\n\tvar o = {};\n\to.ifnt = blob.read_shift(2); o.numFmtId = blob.read_shift(2); o.flags = blob.read_shift(2);\n\to.fStyle = (o.flags >> 2) & 0x01;\n\tlength -= 6;\n\to.data = parse_CellStyleXF(blob, length, o.fStyle, opts);\n\treturn o;\n}\nfunction write_XF(data, ixfeP, opts, o) {\n\tvar b5 = (opts && (opts.biff == 5));\n\tif(!o) o = new_buf(b5 ? 16 : 20);\n\to.write_shift(2, 0);\n\tif(data.style) {\n\t\to.write_shift(2, (data.numFmtId||0));\n\t\to.write_shift(2, 0xFFF4);\n\t} else {\n\t\to.write_shift(2, (data.numFmtId||0));\n\t\to.write_shift(2, (ixfeP<<4));\n\t}\n\tvar f = 0;\n\tif(data.numFmtId > 0 && b5) f |= 0x0400;\n\to.write_shift(4, f);\n\to.write_shift(4, 0);\n\tif(!b5) o.write_shift(4, 0);\n\to.write_shift(2, 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.134 */\nfunction parse_Guts(blob) {\n\tblob.l += 4;\n\tvar out = [blob.read_shift(2), blob.read_shift(2)];\n\tif(out[0] !== 0) out[0]--;\n\tif(out[1] !== 0) out[1]--;\n\tif(out[0] > 7 || out[1] > 7) throw new Error(\"Bad Gutters: \" + out.join(\"|\"));\n\treturn out;\n}\nfunction write_Guts(guts/*:Array<number>*/) {\n\tvar o = new_buf(8);\n\to.write_shift(4, 0);\n\to.write_shift(2, guts[0] ? guts[0] + 1 : 0);\n\to.write_shift(2, guts[1] ? guts[1] + 1 : 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.24 */\nfunction parse_BoolErr(blob, length, opts) {\n\tvar cell = parse_XLSCell(blob, 6);\n\tif(opts.biff == 2 || length == 9) ++blob.l;\n\tvar val = parse_Bes(blob, 2);\n\tcell.val = val;\n\tcell.t = (val === true || val === false) ? 'b' : 'e';\n\treturn cell;\n}\nfunction write_BoolErr(R/*:number*/, C/*:number*/, v, os/*:number*/, opts, t/*:string*/) {\n\tvar o = new_buf(8);\n\twrite_XLSCell(R, C, os, o);\n\twrite_Bes(v, t, o);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.180 Number */\nfunction parse_Number(blob, length, opts) {\n\tif(opts.biffguess && opts.biff == 2) opts.biff = 5;\n\tvar cell = parse_XLSCell(blob, 6);\n\tvar xnum = parse_Xnum(blob, 8);\n\tcell.val = xnum;\n\treturn cell;\n}\nfunction write_Number(R/*:number*/, C/*:number*/, v, os/*:: :number, opts*/) {\n\tvar o = new_buf(14);\n\twrite_XLSCell(R, C, os, o);\n\twrite_Xnum(v, o);\n\treturn o;\n}\n\nvar parse_XLHeaderFooter = parse_OptXLUnicodeString; // TODO: parse 2.4.136\n\n/* [MS-XLS] 2.4.271 */\nfunction parse_SupBook(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar ctab = blob.read_shift(2);\n\tvar cch = blob.read_shift(2);\n\topts.sbcch = cch;\n\tif(cch == 0x0401 || cch == 0x3A01) return [cch, ctab];\n\tif(cch < 0x01 || cch >0xff) throw new Error(\"Unexpected SupBook type: \"+cch);\n\tvar virtPath = parse_XLUnicodeStringNoCch(blob, cch);\n\t/* TODO: 2.5.277 Virtual Path */\n\tvar rgst = [];\n\twhile(end > blob.l) rgst.push(parse_XLUnicodeString(blob));\n\treturn [cch, ctab, virtPath, rgst];\n}\n\n/* [MS-XLS] 2.4.105 TODO */\nfunction parse_ExternName(blob, length, opts) {\n\tvar flags = blob.read_shift(2);\n\tvar body;\n\tvar o = ({\n\t\tfBuiltIn: flags & 0x01,\n\t\tfWantAdvise: (flags >>> 1) & 0x01,\n\t\tfWantPict: (flags >>> 2) & 0x01,\n\t\tfOle: (flags >>> 3) & 0x01,\n\t\tfOleLink: (flags >>> 4) & 0x01,\n\t\tcf: (flags >>> 5) & 0x3FF,\n\t\tfIcon: flags >>> 15 & 0x01\n\t}/*:any*/);\n\tif(opts.sbcch === 0x3A01) body = parse_AddinUdf(blob, length-2, opts);\n\t//else throw new Error(\"unsupported SupBook cch: \" + opts.sbcch);\n\to.body = body || blob.read_shift(length-2);\n\tif(typeof body === \"string\") o.Name = body;\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.150 TODO */\nvar XLSLblBuiltIn = [\n\t\"_xlnm.Consolidate_Area\",\n\t\"_xlnm.Auto_Open\",\n\t\"_xlnm.Auto_Close\",\n\t\"_xlnm.Extract\",\n\t\"_xlnm.Database\",\n\t\"_xlnm.Criteria\",\n\t\"_xlnm.Print_Area\",\n\t\"_xlnm.Print_Titles\",\n\t\"_xlnm.Recorder\",\n\t\"_xlnm.Data_Form\",\n\t\"_xlnm.Auto_Activate\",\n\t\"_xlnm.Auto_Deactivate\",\n\t\"_xlnm.Sheet_Title\",\n\t\"_xlnm._FilterDatabase\"\n];\nfunction parse_Lbl(blob, length, opts) {\n\tvar target = blob.l + length;\n\tvar flags = blob.read_shift(2);\n\tvar chKey = blob.read_shift(1);\n\tvar cch = blob.read_shift(1);\n\tvar cce = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\tvar itab = 0;\n\tif(!opts || opts.biff >= 5) {\n\t\tif(opts.biff != 5) blob.l += 2;\n\t\titab = blob.read_shift(2);\n\t\tif(opts.biff == 5) blob.l += 2;\n\t\tblob.l += 4;\n\t}\n\tvar name = parse_XLUnicodeStringNoCch(blob, cch, opts);\n\tif(flags & 0x20) name = XLSLblBuiltIn[name.charCodeAt(0)];\n\tvar npflen = target - blob.l; if(opts && opts.biff == 2) --npflen;\n\t/*jshint -W018 */\n\tvar rgce = (target == blob.l || cce === 0 || !(npflen > 0)) ? [] : parse_NameParsedFormula(blob, npflen, opts, cce);\n\t/*jshint +W018 */\n\treturn {\n\t\tchKey: chKey,\n\t\tName: name,\n\t\titab: itab,\n\t\trgce: rgce\n\t};\n}\n\n/* [MS-XLS] 2.4.106 TODO: verify filename encoding */\nfunction parse_ExternSheet(blob, length, opts) {\n\tif(opts.biff < 8) return parse_BIFF5ExternSheet(blob, length, opts);\n\tvar o = [], target = blob.l + length, len = blob.read_shift(opts.biff > 8 ? 4 : 2);\n\twhile(len-- !== 0) o.push(parse_XTI(blob, opts.biff > 8 ? 12 : 6, opts));\n\t\t// [iSupBook, itabFirst, itabLast];\n\tif(blob.l != target) throw new Error(\"Bad ExternSheet: \" + blob.l + \" != \" + target);\n\treturn o;\n}\nfunction parse_BIFF5ExternSheet(blob, length, opts) {\n\tif(blob[blob.l + 1] == 0x03) blob[blob.l]++;\n\tvar o = parse_ShortXLUnicodeString(blob, length, opts);\n\treturn o.charCodeAt(0) == 0x03 ? o.slice(1) : o;\n}\n\n/* [MS-XLS] 2.4.176 TODO: check older biff */\nfunction parse_NameCmt(blob, length, opts) {\n\tif(opts.biff < 8) { blob.l += length; return; }\n\tvar cchName = blob.read_shift(2);\n\tvar cchComment = blob.read_shift(2);\n\tvar name = parse_XLUnicodeStringNoCch(blob, cchName, opts);\n\tvar comment = parse_XLUnicodeStringNoCch(blob, cchComment, opts);\n\treturn [name, comment];\n}\n\n/* [MS-XLS] 2.4.260 */\nfunction parse_ShrFmla(blob, length, opts) {\n\tvar ref = parse_RefU(blob, 6);\n\tblob.l++;\n\tvar cUse = blob.read_shift(1);\n\tlength -= 8;\n\treturn [parse_SharedParsedFormula(blob, length, opts), cUse, ref];\n}\n\n/* [MS-XLS] 2.4.4 TODO */\nfunction parse_Array(blob, length, opts) {\n\tvar ref = parse_Ref(blob, 6);\n\t/* TODO: fAlwaysCalc */\n\tswitch(opts.biff) {\n\t\tcase 2: blob.l ++; length -= 7; break;\n\t\tcase 3: case 4: blob.l += 2; length -= 8; break;\n\t\tdefault: blob.l += 6; length -= 12;\n\t}\n\treturn [ref, parse_ArrayParsedFormula(blob, length, opts, ref)];\n}\n\n/* [MS-XLS] 2.4.173 */\nfunction parse_MTRSettings(blob) {\n\tvar fMTREnabled = blob.read_shift(4) !== 0x00;\n\tvar fUserSetThreadCount = blob.read_shift(4) !== 0x00;\n\tvar cUserThreadCount = blob.read_shift(4);\n\treturn [fMTREnabled, fUserSetThreadCount, cUserThreadCount];\n}\n\n/* [MS-XLS] 2.5.186 TODO: BIFF5 */\nfunction parse_NoteSh(blob, length, opts) {\n\tif(opts.biff < 8) return;\n\tvar row = blob.read_shift(2), col = blob.read_shift(2);\n\tvar flags = blob.read_shift(2), idObj = blob.read_shift(2);\n\tvar stAuthor = parse_XLUnicodeString2(blob, 0, opts);\n\tif(opts.biff < 8) blob.read_shift(1);\n\treturn [{r:row,c:col}, stAuthor, idObj, flags];\n}\n\n/* [MS-XLS] 2.4.179 */\nfunction parse_Note(blob, length, opts) {\n\t/* TODO: Support revisions */\n\treturn parse_NoteSh(blob, length, opts);\n}\n\n/* [MS-XLS] 2.4.168 */\nfunction parse_MergeCells(blob, length)/*:Array<Range>*/ {\n\tvar merges/*:Array<Range>*/ = [];\n\tvar cmcs = blob.read_shift(2);\n\twhile (cmcs--) merges.push(parse_Ref8U(blob,length));\n\treturn merges;\n}\nfunction write_MergeCells(merges/*:Array<Range>*/) {\n\tvar o = new_buf(2 + merges.length * 8);\n\to.write_shift(2, merges.length);\n\tfor(var i = 0; i < merges.length; ++i) write_Ref8U(merges[i], o);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.181 TODO: parse all the things! */\nfunction parse_Obj(blob, length, opts) {\n\tif(opts && opts.biff < 8) return parse_BIFF5Obj(blob, length, opts);\n\tvar cmo = parse_FtCmo(blob, 22); // id, ot, flags\n\tvar fts = parse_FtArray(blob, length-22, cmo[1]);\n\treturn { cmo: cmo, ft:fts };\n}\n/* from older spec */\nvar parse_BIFF5OT = {\n0x08: function(blob, length) {\n\tvar tgt = blob.l + length;\n\tblob.l += 10; // todo\n\tvar cf = blob.read_shift(2);\n\tblob.l += 4;\n\tblob.l += 2; //var cbPictFmla = blob.read_shift(2);\n\tblob.l += 2;\n\tblob.l += 2; //var grbit = blob.read_shift(2);\n\tblob.l += 4;\n\tvar cchName = blob.read_shift(1);\n\tblob.l += cchName; // TODO: stName\n\tblob.l = tgt; // TODO: fmla\n\treturn { fmt:cf };\n}\n};\n\nfunction parse_BIFF5Obj(blob, length, opts) {\n\tblob.l += 4; //var cnt = blob.read_shift(4);\n\tvar ot = blob.read_shift(2);\n\tvar id = blob.read_shift(2);\n\tvar grbit = blob.read_shift(2);\n\tblob.l += 2; //var colL = blob.read_shift(2);\n\tblob.l += 2; //var dxL = blob.read_shift(2);\n\tblob.l += 2; //var rwT = blob.read_shift(2);\n\tblob.l += 2; //var dyT = blob.read_shift(2);\n\tblob.l += 2; //var colR = blob.read_shift(2);\n\tblob.l += 2; //var dxR = blob.read_shift(2);\n\tblob.l += 2; //var rwB = blob.read_shift(2);\n\tblob.l += 2; //var dyB = blob.read_shift(2);\n\tblob.l += 2; //var cbMacro = blob.read_shift(2);\n\tblob.l += 6;\n\tlength -= 36;\n\tvar fts = [];\n\tfts.push((parse_BIFF5OT[ot]||parsenoop)(blob, length, opts));\n\treturn { cmo: [id, ot, grbit], ft:fts };\n}\n\n/* [MS-XLS] 2.4.329 TODO: parse properly */\nfunction parse_TxO(blob, length, opts) {\n\tvar s = blob.l;\n\tvar texts = \"\";\ntry {\n\tblob.l += 4;\n\tvar ot = (opts.lastobj||{cmo:[0,0]}).cmo[1];\n\tvar controlInfo; // eslint-disable-line no-unused-vars\n\tif([0,5,7,11,12,14].indexOf(ot) == -1) blob.l += 6;\n\telse controlInfo = parse_ControlInfo(blob, 6, opts); // eslint-disable-line no-unused-vars\n\tvar cchText = blob.read_shift(2);\n\t/*var cbRuns = */blob.read_shift(2);\n\t/*var ifntEmpty = */parseuint16(blob, 2);\n\tvar len = blob.read_shift(2);\n\tblob.l += len;\n\t//var fmla = parse_ObjFmla(blob, s + length - blob.l);\n\n\tfor(var i = 1; i < blob.lens.length-1; ++i) {\n\t\tif(blob.l-s != blob.lens[i]) throw new Error(\"TxO: bad continue record\");\n\t\tvar hdr = blob[blob.l];\n\t\tvar t = parse_XLUnicodeStringNoCch(blob, blob.lens[i+1]-blob.lens[i]-1);\n\t\ttexts += t;\n\t\tif(texts.length >= (hdr ? cchText : 2*cchText)) break;\n\t}\n\tif(texts.length !== cchText && texts.length !== cchText*2) {\n\t\tthrow new Error(\"cchText: \" + cchText + \" != \" + texts.length);\n\t}\n\n\tblob.l = s + length;\n\t/* [MS-XLS] 2.5.272 TxORuns */\n//\tvar rgTxoRuns = [];\n//\tfor(var j = 0; j != cbRuns/8-1; ++j) blob.l += 8;\n//\tvar cchText2 = blob.read_shift(2);\n//\tif(cchText2 !== cchText) throw new Error(\"TxOLastRun mismatch: \" + cchText2 + \" \" + cchText);\n//\tblob.l += 6;\n//\tif(s + length != blob.l) throw new Error(\"TxO \" + (s + length) + \", at \" + blob.l);\n\treturn { t: texts };\n} catch(e) { blob.l = s + length; return { t: texts }; }\n}\n\n/* [MS-XLS] 2.4.140 */\nfunction parse_HLink(blob, length) {\n\tvar ref = parse_Ref8U(blob, 8);\n\tblob.l += 16; /* CLSID */\n\tvar hlink = parse_Hyperlink(blob, length-24);\n\treturn [ref, hlink];\n}\nfunction write_HLink(hl) {\n\tvar O = new_buf(24);\n\tvar ref = decode_cell(hl[0]);\n\tO.write_shift(2, ref.r); O.write_shift(2, ref.r);\n\tO.write_shift(2, ref.c); O.write_shift(2, ref.c);\n\tvar clsid = \"d0 c9 ea 79 f9 ba ce 11 8c 82 00 aa 00 4b a9 0b\".split(\" \");\n\tfor(var i = 0; i < 16; ++i) O.write_shift(1, parseInt(clsid[i], 16));\n\treturn bconcat([O, write_Hyperlink(hl[1])]);\n}\n\n\n/* [MS-XLS] 2.4.141 */\nfunction parse_HLinkTooltip(blob, length) {\n\tblob.read_shift(2);\n\tvar ref = parse_Ref8U(blob, 8);\n\tvar wzTooltip = blob.read_shift((length-10)/2, 'dbcs-cont');\n\twzTooltip = wzTooltip.replace(chr0,\"\");\n\treturn [ref, wzTooltip];\n}\nfunction write_HLinkTooltip(hl) {\n\tvar TT = hl[1].Tooltip;\n\tvar O = new_buf(10 + 2 * (TT.length + 1));\n\tO.write_shift(2, 0x0800);\n\tvar ref = decode_cell(hl[0]);\n\tO.write_shift(2, ref.r); O.write_shift(2, ref.r);\n\tO.write_shift(2, ref.c); O.write_shift(2, ref.c);\n\tfor(var i = 0; i < TT.length; ++i) O.write_shift(2, TT.charCodeAt(i));\n\tO.write_shift(2, 0);\n\treturn O;\n}\n\n/* [MS-XLS] 2.4.63 */\nfunction parse_Country(blob)/*:[string|number, string|number]*/ {\n\tvar o = [0,0], d;\n\td = blob.read_shift(2); o[0] = CountryEnum[d] || d;\n\td = blob.read_shift(2); o[1] = CountryEnum[d] || d;\n\treturn o;\n}\nfunction write_Country(o) {\n\tif(!o) o = new_buf(4);\n\to.write_shift(2, 0x01);\n\to.write_shift(2, 0x01);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.50 ClrtClient */\nfunction parse_ClrtClient(blob) {\n\tvar ccv = blob.read_shift(2);\n\tvar o = [];\n\twhile(ccv-->0) o.push(parse_LongRGB(blob, 8));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.188 */\nfunction parse_Palette(blob) {\n\tvar ccv = blob.read_shift(2);\n\tvar o = [];\n\twhile(ccv-->0) o.push(parse_LongRGB(blob, 8));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.354 */\nfunction parse_XFCRC(blob) {\n\tblob.l += 2;\n\tvar o = {cxfs:0, crc:0};\n\to.cxfs = blob.read_shift(2);\n\to.crc = blob.read_shift(4);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.53 TODO: parse flags */\n/* [MS-XLSB] 2.4.323 TODO: parse flags */\nfunction parse_ColInfo(blob, length, opts) {\n\tif(!opts.cellStyles) return parsenoop(blob, length);\n\tvar w = opts && opts.biff >= 12 ? 4 : 2;\n\tvar colFirst = blob.read_shift(w);\n\tvar colLast = blob.read_shift(w);\n\tvar coldx = blob.read_shift(w);\n\tvar ixfe = blob.read_shift(w);\n\tvar flags = blob.read_shift(2);\n\tif(w == 2) blob.l += 2;\n\tvar o = ({s:colFirst, e:colLast, w:coldx, ixfe:ixfe, flags:flags}/*:any*/);\n\tif(opts.biff >= 5 || !opts.biff) o.level = (flags >> 8) & 0x7;\n\treturn o;\n}\nfunction write_ColInfo(col, idx) {\n\tvar o = new_buf(12);\n\to.write_shift(2, idx);\n\to.write_shift(2, idx);\n\to.write_shift(2, col.width * 256);\n\to.write_shift(2, 0);\n\tvar f = 0;\n\tif(col.hidden) f |= 1;\n\to.write_shift(1, f);\n\tf = col.level || 0;\n\to.write_shift(1, f);\n\to.write_shift(2, 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.257 */\nfunction parse_Setup(blob, length) {\n\tvar o = {};\n\tif(length < 32) return o;\n\tblob.l += 16;\n\to.header = parse_Xnum(blob, 8);\n\to.footer = parse_Xnum(blob, 8);\n\tblob.l += 2;\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.261 */\nfunction parse_ShtProps(blob, length, opts) {\n\tvar def = {area:false};\n\tif(opts.biff != 5) { blob.l += length; return def; }\n\tvar d = blob.read_shift(1); blob.l += 3;\n\tif((d & 0x10)) def.area = true;\n\treturn def;\n}\n\n/* [MS-XLS] 2.4.241 */\nfunction write_RRTabId(n/*:number*/) {\n\tvar out = new_buf(2 * n);\n\tfor(var i = 0; i < n; ++i) out.write_shift(2, i+1);\n\treturn out;\n}\n\nvar parse_Blank = parse_XLSCell; /* [MS-XLS] 2.4.20 Just the cell */\nvar parse_Scl = parseuint16a; /* [MS-XLS] 2.4.247 num, den */\nvar parse_String = parse_XLUnicodeString; /* [MS-XLS] 2.4.268 */\n\n/* --- Specific to versions before BIFF8 --- */\nfunction parse_ImData(blob) {\n\tvar cf = blob.read_shift(2);\n\tvar env = blob.read_shift(2);\n\tvar lcb = blob.read_shift(4);\n\tvar o = {fmt:cf, env:env, len:lcb, data:blob.slice(blob.l,blob.l+lcb)};\n\tblob.l += lcb;\n\treturn o;\n}\n\n/* BIFF2_??? where ??? is the name from [XLS] */\nfunction parse_BIFF2STR(blob, length, opts) {\n\tif(opts.biffguess && opts.biff == 5) opts.biff = 2;\n\tvar cell = parse_XLSCell(blob, 6);\n\t++blob.l;\n\tvar str = parse_XLUnicodeString2(blob, length-7, opts);\n\tcell.t = 'str';\n\tcell.val = str;\n\treturn cell;\n}\n\nfunction parse_BIFF2NUM(blob/*::, length*/) {\n\tvar cell = parse_XLSCell(blob, 6);\n\t++blob.l;\n\tvar num = parse_Xnum(blob, 8);\n\tcell.t = 'n';\n\tcell.val = num;\n\treturn cell;\n}\nfunction write_BIFF2NUM(r/*:number*/, c/*:number*/, val/*:number*/) {\n\tvar out = new_buf(15);\n\twrite_BIFF2Cell(out, r, c);\n\tout.write_shift(8, val, 'f');\n\treturn out;\n}\n\nfunction parse_BIFF2INT(blob) {\n\tvar cell = parse_XLSCell(blob, 6);\n\t++blob.l;\n\tvar num = blob.read_shift(2);\n\tcell.t = 'n';\n\tcell.val = num;\n\treturn cell;\n}\nfunction write_BIFF2INT(r/*:number*/, c/*:number*/, val/*:number*/) {\n\tvar out = new_buf(9);\n\twrite_BIFF2Cell(out, r, c);\n\tout.write_shift(2, val);\n\treturn out;\n}\n\nfunction parse_BIFF2STRING(blob) {\n\tvar cch = blob.read_shift(1);\n\tif(cch === 0) { blob.l++; return \"\"; }\n\treturn blob.read_shift(cch, 'sbcs-cont');\n}\n\n/* TODO: convert to BIFF8 font struct */\nfunction parse_BIFF2FONTXTRA(blob, length) {\n\tblob.l += 6; // unknown\n\tblob.l += 2; // font weight \"bls\"\n\tblob.l += 1; // charset\n\tblob.l += 3; // unknown\n\tblob.l += 1; // font family\n\tblob.l += length - 13;\n}\n\n/* TODO: parse rich text runs */\nfunction parse_RString(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar cell = parse_XLSCell(blob, 6);\n\tvar cch = blob.read_shift(2);\n\tvar str = parse_XLUnicodeStringNoCch(blob, cch, opts);\n\tblob.l = end;\n\tcell.t = 'str';\n\tcell.val = str;\n\treturn cell;\n}\n/* from js-harb (C) 2014-present SheetJS */\nvar DBF_SUPPORTED_VERSIONS = [0x02, 0x03, 0x30, 0x31, 0x83, 0x8B, 0x8C, 0xF5];\nvar DBF = /*#__PURE__*/(function() {\nvar dbf_codepage_map = {\n\t/* Code Pages Supported by Visual FoxPro */\n\t/*::[*/0x01/*::]*/: 437, /*::[*/0x02/*::]*/: 850,\n\t/*::[*/0x03/*::]*/: 1252, /*::[*/0x04/*::]*/: 10000,\n\t/*::[*/0x64/*::]*/: 852, /*::[*/0x65/*::]*/: 866,\n\t/*::[*/0x66/*::]*/: 865, /*::[*/0x67/*::]*/: 861,\n\t/*::[*/0x68/*::]*/: 895, /*::[*/0x69/*::]*/: 620,\n\t/*::[*/0x6A/*::]*/: 737, /*::[*/0x6B/*::]*/: 857,\n\t/*::[*/0x78/*::]*/: 950, /*::[*/0x79/*::]*/: 949,\n\t/*::[*/0x7A/*::]*/: 936, /*::[*/0x7B/*::]*/: 932,\n\t/*::[*/0x7C/*::]*/: 874, /*::[*/0x7D/*::]*/: 1255,\n\t/*::[*/0x7E/*::]*/: 1256, /*::[*/0x96/*::]*/: 10007,\n\t/*::[*/0x97/*::]*/: 10029, /*::[*/0x98/*::]*/: 10006,\n\t/*::[*/0xC8/*::]*/: 1250, /*::[*/0xC9/*::]*/: 1251,\n\t/*::[*/0xCA/*::]*/: 1254, /*::[*/0xCB/*::]*/: 1253,\n\n\t/* shapefile DBF extension */\n\t/*::[*/0x00/*::]*/: 20127, /*::[*/0x08/*::]*/: 865,\n\t/*::[*/0x09/*::]*/: 437, /*::[*/0x0A/*::]*/: 850,\n\t/*::[*/0x0B/*::]*/: 437, /*::[*/0x0D/*::]*/: 437,\n\t/*::[*/0x0E/*::]*/: 850, /*::[*/0x0F/*::]*/: 437,\n\t/*::[*/0x10/*::]*/: 850, /*::[*/0x11/*::]*/: 437,\n\t/*::[*/0x12/*::]*/: 850, /*::[*/0x13/*::]*/: 932,\n\t/*::[*/0x14/*::]*/: 850, /*::[*/0x15/*::]*/: 437,\n\t/*::[*/0x16/*::]*/: 850, /*::[*/0x17/*::]*/: 865,\n\t/*::[*/0x18/*::]*/: 437, /*::[*/0x19/*::]*/: 437,\n\t/*::[*/0x1A/*::]*/: 850, /*::[*/0x1B/*::]*/: 437,\n\t/*::[*/0x1C/*::]*/: 863, /*::[*/0x1D/*::]*/: 850,\n\t/*::[*/0x1F/*::]*/: 852, /*::[*/0x22/*::]*/: 852,\n\t/*::[*/0x23/*::]*/: 852, /*::[*/0x24/*::]*/: 860,\n\t/*::[*/0x25/*::]*/: 850, /*::[*/0x26/*::]*/: 866,\n\t/*::[*/0x37/*::]*/: 850, /*::[*/0x40/*::]*/: 852,\n\t/*::[*/0x4D/*::]*/: 936, /*::[*/0x4E/*::]*/: 949,\n\t/*::[*/0x4F/*::]*/: 950, /*::[*/0x50/*::]*/: 874,\n\t/*::[*/0x57/*::]*/: 1252, /*::[*/0x58/*::]*/: 1252,\n\t/*::[*/0x59/*::]*/: 1252, /*::[*/0x6C/*::]*/: 863,\n\t/*::[*/0x86/*::]*/: 737, /*::[*/0x87/*::]*/: 852,\n\t/*::[*/0x88/*::]*/: 857, /*::[*/0xCC/*::]*/: 1257,\n\n\t/*::[*/0xFF/*::]*/: 16969\n};\nvar dbf_reverse_map = evert({\n\t/*::[*/0x01/*::]*/: 437, /*::[*/0x02/*::]*/: 850,\n\t/*::[*/0x03/*::]*/: 1252, /*::[*/0x04/*::]*/: 10000,\n\t/*::[*/0x64/*::]*/: 852, /*::[*/0x65/*::]*/: 866,\n\t/*::[*/0x66/*::]*/: 865, /*::[*/0x67/*::]*/: 861,\n\t/*::[*/0x68/*::]*/: 895, /*::[*/0x69/*::]*/: 620,\n\t/*::[*/0x6A/*::]*/: 737, /*::[*/0x6B/*::]*/: 857,\n\t/*::[*/0x78/*::]*/: 950, /*::[*/0x79/*::]*/: 949,\n\t/*::[*/0x7A/*::]*/: 936, /*::[*/0x7B/*::]*/: 932,\n\t/*::[*/0x7C/*::]*/: 874, /*::[*/0x7D/*::]*/: 1255,\n\t/*::[*/0x7E/*::]*/: 1256, /*::[*/0x96/*::]*/: 10007,\n\t/*::[*/0x97/*::]*/: 10029, /*::[*/0x98/*::]*/: 10006,\n\t/*::[*/0xC8/*::]*/: 1250, /*::[*/0xC9/*::]*/: 1251,\n\t/*::[*/0xCA/*::]*/: 1254, /*::[*/0xCB/*::]*/: 1253,\n\t/*::[*/0x00/*::]*/: 20127\n});\n/* TODO: find an actual specification */\nfunction dbf_to_aoa(buf, opts)/*:AOA*/ {\n\tvar out/*:AOA*/ = [];\n\tvar d/*:Block*/ = (new_raw_buf(1)/*:any*/);\n\tswitch(opts.type) {\n\t\tcase 'base64': d = s2a(Base64_decode(buf)); break;\n\t\tcase 'binary': d = s2a(buf); break;\n\t\tcase 'buffer':\n\t\tcase 'array': d = buf; break;\n\t}\n\tprep_blob(d, 0);\n\n\t/* header */\n\tvar ft = d.read_shift(1);\n\tvar memo = !!(ft & 0x88);\n\tvar vfp = false, l7 = false;\n\tswitch(ft) {\n\t\tcase 0x02: break; // dBASE II\n\t\tcase 0x03: break; // dBASE III\n\t\tcase 0x30: vfp = true; memo = true; break; // VFP\n\t\tcase 0x31: vfp = true; memo = true; break; // VFP with autoincrement\n\t\t// 0x43 dBASE IV SQL table files\n\t\t// 0x63 dBASE IV SQL system files\n\t\tcase 0x83: break; // dBASE III with memo\n\t\tcase 0x8B: break; // dBASE IV with memo\n\t\tcase 0x8C: l7 = true; break; // dBASE Level 7 with memo\n\t\t// case 0xCB dBASE IV SQL table files with memo\n\t\tcase 0xF5: break; // FoxPro 2.x with memo\n\t\t// case 0xFB FoxBASE\n\t\tdefault: throw new Error(\"DBF Unsupported Version: \" + ft.toString(16));\n\t}\n\n\tvar nrow = 0, fpos = 0x0209;\n\tif(ft == 0x02) nrow = d.read_shift(2);\n\td.l += 3; // dBASE II stores DDMMYY date, others use YYMMDD\n\tif(ft != 0x02) nrow = d.read_shift(4);\n\tif(nrow > 1048576) nrow = 1e6;\n\n\tif(ft != 0x02) fpos = d.read_shift(2); // header length\n\tvar rlen = d.read_shift(2); // record length\n\n\tvar /*flags = 0,*/ current_cp = opts.codepage || 1252;\n\tif(ft != 0x02) { // 20 reserved bytes\n\t\td.l+=16;\n\t\t/*flags = */d.read_shift(1);\n\t\t//if(memo && ((flags & 0x02) === 0)) throw new Error(\"DBF Flags \" + flags.toString(16) + \" ft \" + ft.toString(16));\n\n\t\t/* codepage present in FoxPro and dBASE Level 7 */\n\t\tif(d[d.l] !== 0) current_cp = dbf_codepage_map[d[d.l]];\n\t\td.l+=1;\n\n\t\td.l+=2;\n\t}\n\tif(l7) d.l += 36; // Level 7: 32 byte \"Language driver name\", 4 byte reserved\n\n/*:: type DBFField = { name:string; len:number; type:string; } */\n\tvar fields/*:Array<DBFField>*/ = [], field/*:DBFField*/ = ({}/*:any*/);\n\tvar hend = Math.min(d.length, (ft == 0x02 ? 0x209 : (fpos - 10 - (vfp ? 264 : 0))));\n\tvar ww = l7 ? 32 : 11;\n\twhile(d.l < hend && d[d.l] != 0x0d) {\n\t\tfield = ({}/*:any*/);\n\t\tfield.name = $cptable.utils.decode(current_cp, d.slice(d.l, d.l+ww)).replace(/[\\u0000\\r\\n].*$/g,\"\");\n\t\td.l += ww;\n\t\tfield.type = String.fromCharCode(d.read_shift(1));\n\t\tif(ft != 0x02 && !l7) field.offset = d.read_shift(4);\n\t\tfield.len = d.read_shift(1);\n\t\tif(ft == 0x02) field.offset = d.read_shift(2);\n\t\tfield.dec = d.read_shift(1);\n\t\tif(field.name.length) fields.push(field);\n\t\tif(ft != 0x02) d.l += l7 ? 13 : 14;\n\t\tswitch(field.type) {\n\t\t\tcase 'B': // Double (VFP) / Binary (dBASE L7)\n\t\t\t\tif((!vfp || field.len != 8) && opts.WTF) console.log('Skipping ' + field.name + ':' + field.type);\n\t\t\t\tbreak;\n\t\t\tcase 'G': // General (FoxPro and dBASE L7)\n\t\t\tcase 'P': // Picture (FoxPro and dBASE L7)\n\t\t\t\tif(opts.WTF) console.log('Skipping ' + field.name + ':' + field.type);\n\t\t\t\tbreak;\n\t\t\tcase '+': // Autoincrement (dBASE L7 only)\n\t\t\tcase '0': // _NullFlags (VFP only)\n\t\t\tcase '@': // Timestamp (dBASE L7 only)\n\t\t\tcase 'C': // Character (dBASE II)\n\t\t\tcase 'D': // Date (dBASE III)\n\t\t\tcase 'F': // Float (dBASE IV)\n\t\t\tcase 'I': // Long (VFP and dBASE L7)\n\t\t\tcase 'L': // Logical (dBASE II)\n\t\t\tcase 'M': // Memo (dBASE III)\n\t\t\tcase 'N': // Number (dBASE II)\n\t\t\tcase 'O': // Double (dBASE L7 only)\n\t\t\tcase 'T': // Datetime (VFP only)\n\t\t\tcase 'Y': // Currency (VFP only)\n\t\t\t\tbreak;\n\t\t\tdefault: throw new Error('Unknown Field Type: ' + field.type);\n\t\t}\n\t}\n\n\tif(d[d.l] !== 0x0D) d.l = fpos-1;\n\tif(d.read_shift(1) !== 0x0D) throw new Error(\"DBF Terminator not found \" + d.l + \" \" + d[d.l]);\n\td.l = fpos;\n\n\t/* data */\n\tvar R = 0, C = 0;\n\tout[0] = [];\n\tfor(C = 0; C != fields.length; ++C) out[0][C] = fields[C].name;\n\twhile(nrow-- > 0) {\n\t\tif(d[d.l] === 0x2A) {\n\t\t\t// TODO: record marked as deleted -- create a hidden row?\n\t\t\td.l+=rlen;\n\t\t\tcontinue;\n\t\t}\n\t\t++d.l;\n\t\tout[++R] = []; C = 0;\n\t\tfor(C = 0; C != fields.length; ++C) {\n\t\t\tvar dd = d.slice(d.l, d.l+fields[C].len); d.l+=fields[C].len;\n\t\t\tprep_blob(dd, 0);\n\t\t\tvar s = $cptable.utils.decode(current_cp, dd);\n\t\t\tswitch(fields[C].type) {\n\t\t\t\tcase 'C':\n\t\t\t\t\t// NOTE: it is conventional to write ' / / ' for empty dates\n\t\t\t\t\tif(s.trim().length) out[R][C] = s.replace(/\\s+$/,\"\");\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'D':\n\t\t\t\t\tif(s.length === 8) out[R][C] = new Date(+s.slice(0,4), +s.slice(4,6)-1, +s.slice(6,8));\n\t\t\t\t\telse out[R][C] = s;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'F': out[R][C] = parseFloat(s.trim()); break;\n\t\t\t\tcase '+': case 'I': out[R][C] = l7 ? dd.read_shift(-4, 'i') ^ 0x80000000 : dd.read_shift(4, 'i'); break;\n\t\t\t\tcase 'L': switch(s.trim().toUpperCase()) {\n\t\t\t\t\tcase 'Y': case 'T': out[R][C] = true; break;\n\t\t\t\t\tcase 'N': case 'F': out[R][C] = false; break;\n\t\t\t\t\tcase '': case '?': break;\n\t\t\t\t\tdefault: throw new Error(\"DBF Unrecognized L:|\" + s + \"|\");\n\t\t\t\t\t} break;\n\t\t\t\tcase 'M': /* TODO: handle memo files */\n\t\t\t\t\tif(!memo) throw new Error(\"DBF Unexpected MEMO for type \" + ft.toString(16));\n\t\t\t\t\tout[R][C] = \"##MEMO##\" + (l7 ? parseInt(s.trim(), 10): dd.read_shift(4));\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'N':\n\t\t\t\t\ts = s.replace(/\\u0000/g,\"\").trim();\n\t\t\t\t\t// NOTE: dBASE II interprets \" . \" as 0\n\t\t\t\t\tif(s && s != \".\") out[R][C] = +s || 0; break;\n\t\t\t\tcase '@':\n\t\t\t\t\t// NOTE: dBASE specs appear to be incorrect\n\t\t\t\t\tout[R][C] = new Date(dd.read_shift(-8, 'f') - 0x388317533400);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'T': out[R][C] = new Date((dd.read_shift(4) - 0x253D8C) * 0x5265C00 + dd.read_shift(4)); break;\n\t\t\t\tcase 'Y': out[R][C] = dd.read_shift(4,'i')/1e4 + (dd.read_shift(4, 'i')/1e4)*Math.pow(2,32); break;\n\t\t\t\tcase 'O': out[R][C] = -dd.read_shift(-8, 'f'); break;\n\t\t\t\tcase 'B': if(vfp && fields[C].len == 8) { out[R][C] = dd.read_shift(8,'f'); break; }\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 'G': case 'P': dd.l += fields[C].len; break;\n\t\t\t\tcase '0':\n\t\t\t\t\tif(fields[C].name === '_NullFlags') break;\n\t\t\t\t\t/* falls through */\n\t\t\t\tdefault: throw new Error(\"DBF Unsupported data type \" + fields[C].type);\n\t\t\t}\n\t\t}\n\t}\n\tif(ft != 0x02) if(d.l < d.length && d[d.l++] != 0x1A) throw new Error(\"DBF EOF Marker missing \" + (d.l-1) + \" of \" + d.length + \" \" + d[d.l-1].toString(16));\n\tif(opts && opts.sheetRows) out = out.slice(0, opts.sheetRows);\n\topts.DBF = fields;\n\treturn out;\n}\n\nfunction dbf_to_sheet(buf, opts)/*:Worksheet*/ {\n\tvar o = opts || {};\n\tif(!o.dateNF) o.dateNF = \"yyyymmdd\";\n\tvar ws = aoa_to_sheet(dbf_to_aoa(buf, o), o);\n\tws[\"!cols\"] = o.DBF.map(function(field) { return {\n\t\twch: field.len,\n\t\tDBF: field\n\t};});\n\tdelete o.DBF;\n\treturn ws;\n}\n\nfunction dbf_to_workbook(buf, opts)/*:Workbook*/ {\n\ttry { return sheet_to_workbook(dbf_to_sheet(buf, opts), opts); }\n\tcatch(e) { if(opts && opts.WTF) throw e; }\n\treturn ({SheetNames:[],Sheets:{}});\n}\n\nvar _RLEN = { 'B': 8, 'C': 250, 'L': 1, 'D': 8, '?': 0, '': 0 };\nfunction sheet_to_dbf(ws/*:Worksheet*/, opts/*:WriteOpts*/) {\n\tvar o = opts || {};\n\tif(+o.codepage >= 0) set_cp(+o.codepage);\n\tif(o.type == \"string\") throw new Error(\"Cannot write DBF to JS string\");\n\tvar ba = buf_array();\n\tvar aoa/*:AOA*/ = sheet_to_json(ws, {header:1, raw:true, cellDates:true});\n\tvar headers = aoa[0], data = aoa.slice(1), cols = ws[\"!cols\"] || [];\n\tvar i = 0, j = 0, hcnt = 0, rlen = 1;\n\tfor(i = 0; i < headers.length; ++i) {\n\t\tif(((cols[i]||{}).DBF||{}).name) { headers[i] = cols[i].DBF.name; ++hcnt; continue; }\n\t\tif(headers[i] == null) continue;\n\t\t++hcnt;\n\t\tif(typeof headers[i] === 'number') headers[i] = headers[i].toString(10);\n\t\tif(typeof headers[i] !== 'string') throw new Error(\"DBF Invalid column name \" + headers[i] + \" |\" + (typeof headers[i]) + \"|\");\n\t\tif(headers.indexOf(headers[i]) !== i) for(j=0; j<1024;++j)\n\t\t\tif(headers.indexOf(headers[i] + \"_\" + j) == -1) { headers[i] += \"_\" + j; break; }\n\t}\n\tvar range = safe_decode_range(ws['!ref']);\n\tvar coltypes/*:Array<string>*/ = [];\n\tvar colwidths/*:Array<number>*/ = [];\n\tvar coldecimals/*:Array<number>*/ = [];\n\tfor(i = 0; i <= range.e.c - range.s.c; ++i) {\n\t\tvar guess = '', _guess = '', maxlen = 0;\n\t\tvar col/*:Array<any>*/ = [];\n\t\tfor(j=0; j < data.length; ++j) {\n\t\t\tif(data[j][i] != null) col.push(data[j][i]);\n\t\t}\n\t\tif(col.length == 0 || headers[i] == null) { coltypes[i] = '?'; continue; }\n\t\tfor(j = 0; j < col.length; ++j) {\n\t\t\tswitch(typeof col[j]) {\n\t\t\t\t/* TODO: check if L2 compat is desired */\n\t\t\t\tcase 'number': _guess = 'B'; break;\n\t\t\t\tcase 'string': _guess = 'C'; break;\n\t\t\t\tcase 'boolean': _guess = 'L'; break;\n\t\t\t\tcase 'object': _guess = col[j] instanceof Date ? 'D' : 'C'; break;\n\t\t\t\tdefault: _guess = 'C';\n\t\t\t}\n\t\t\tmaxlen = Math.max(maxlen, String(col[j]).length);\n\t\t\tguess = guess && guess != _guess ? 'C' : _guess;\n\t\t\t//if(guess == 'C') break;\n\t\t}\n\t\tif(maxlen > 250) maxlen = 250;\n\t\t_guess = ((cols[i]||{}).DBF||{}).type;\n\t\t/* TODO: more fine grained control over DBF type resolution */\n\t\tif(_guess == 'C') {\n\t\t\tif(cols[i].DBF.len > maxlen) maxlen = cols[i].DBF.len;\n\t\t}\n\t\tif(guess == 'B' && _guess == 'N') {\n\t\t\tguess = 'N';\n\t\t\tcoldecimals[i] = cols[i].DBF.dec;\n\t\t\tmaxlen = cols[i].DBF.len;\n\t\t}\n\t\tcolwidths[i] = guess == 'C' || _guess == 'N' ? maxlen : (_RLEN[guess] || 0);\n\t\trlen += colwidths[i];\n\t\tcoltypes[i] = guess;\n\t}\n\n\tvar h = ba.next(32);\n\th.write_shift(4, 0x13021130);\n\th.write_shift(4, data.length);\n\th.write_shift(2, 296 + 32 * hcnt);\n\th.write_shift(2, rlen);\n\tfor(i=0; i < 4; ++i) h.write_shift(4, 0);\n\th.write_shift(4, 0x00000000 | ((+dbf_reverse_map[/*::String(*/current_ansi/*::)*/] || 0x03)<<8));\n\n\tfor(i = 0, j = 0; i < headers.length; ++i) {\n\t\tif(headers[i] == null) continue;\n\t\tvar hf = ba.next(32);\n\t\tvar _f = (headers[i].slice(-10) + \"\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\").slice(0, 11);\n\t\thf.write_shift(1, _f, \"sbcs\");\n\t\thf.write_shift(1, coltypes[i] == '?' ? 'C' : coltypes[i], \"sbcs\");\n\t\thf.write_shift(4, j);\n\t\thf.write_shift(1, colwidths[i] || _RLEN[coltypes[i]] || 0);\n\t\thf.write_shift(1, coldecimals[i] || 0);\n\t\thf.write_shift(1, 0x02);\n\t\thf.write_shift(4, 0);\n\t\thf.write_shift(1, 0);\n\t\thf.write_shift(4, 0);\n\t\thf.write_shift(4, 0);\n\t\tj += (colwidths[i] || _RLEN[coltypes[i]] || 0);\n\t}\n\n\tvar hb = ba.next(264);\n\thb.write_shift(4, 0x0000000D);\n\tfor(i=0; i < 65;++i) hb.write_shift(4, 0x00000000);\n\tfor(i=0; i < data.length; ++i) {\n\t\tvar rout = ba.next(rlen);\n\t\trout.write_shift(1, 0);\n\t\tfor(j=0; j<headers.length; ++j) {\n\t\t\tif(headers[j] == null) continue;\n\t\t\tswitch(coltypes[j]) {\n\t\t\t\tcase 'L': rout.write_shift(1, data[i][j] == null ? 0x3F : data[i][j] ? 0x54 : 0x46); break;\n\t\t\t\tcase 'B': rout.write_shift(8, data[i][j]||0, 'f'); break;\n\t\t\t\tcase 'N':\n\t\t\t\t\tvar _n = \"0\";\n\t\t\t\t\tif(typeof data[i][j] == \"number\") _n = data[i][j].toFixed(coldecimals[j]||0);\n\t\t\t\t\tfor(hcnt=0; hcnt < colwidths[j]-_n.length; ++hcnt) rout.write_shift(1, 0x20);\n\t\t\t\t\trout.write_shift(1, _n, \"sbcs\");\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'D':\n\t\t\t\t\tif(!data[i][j]) rout.write_shift(8, \"00000000\", \"sbcs\");\n\t\t\t\t\telse {\n\t\t\t\t\t\trout.write_shift(4, (\"0000\"+data[i][j].getFullYear()).slice(-4), \"sbcs\");\n\t\t\t\t\t\trout.write_shift(2, (\"00\"+(data[i][j].getMonth()+1)).slice(-2), \"sbcs\");\n\t\t\t\t\t\trout.write_shift(2, (\"00\"+data[i][j].getDate()).slice(-2), \"sbcs\");\n\t\t\t\t\t} break;\n\t\t\t\tcase 'C':\n\t\t\t\t\tvar _s = String(data[i][j] != null ? data[i][j] : \"\").slice(0, colwidths[j]);\n\t\t\t\t\trout.write_shift(1, _s, \"sbcs\");\n\t\t\t\t\tfor(hcnt=0; hcnt < colwidths[j]-_s.length; ++hcnt) rout.write_shift(1, 0x20); break;\n\t\t\t}\n\t\t}\n\t\t// data\n\t}\n\tba.next(1).write_shift(1, 0x1A);\n\treturn ba.end();\n}\n\treturn {\n\t\tto_workbook: dbf_to_workbook,\n\t\tto_sheet: dbf_to_sheet,\n\t\tfrom_sheet: sheet_to_dbf\n\t};\n})();\n\nvar SYLK = /*#__PURE__*/(function() {\n\t/* TODO: stress test sequences */\n\tvar sylk_escapes = ({\n\t\tAA:'À', BA:'Á', CA:'Â', DA:195, HA:'Ä', JA:197,\n\t\tAE:'È', BE:'É', CE:'Ê', HE:'Ë',\n\t\tAI:'Ì', BI:'Í', CI:'Î', HI:'Ï',\n\t\tAO:'Ò', BO:'Ó', CO:'Ô', DO:213, HO:'Ö',\n\t\tAU:'Ù', BU:'Ú', CU:'Û', HU:'Ü',\n\t\tAa:'à', Ba:'á', Ca:'â', Da:227, Ha:'ä', Ja:229,\n\t\tAe:'è', Be:'é', Ce:'ê', He:'ë',\n\t\tAi:'ì', Bi:'í', Ci:'î', Hi:'ï',\n\t\tAo:'ò', Bo:'ó', Co:'ô', Do:245, Ho:'ö',\n\t\tAu:'ù', Bu:'ú', Cu:'û', Hu:'ü',\n\t\tKC:'Ç', Kc:'ç', q:'æ', z:'œ', a:'Æ', j:'Œ',\n\t\tDN:209, Dn:241, Hy:255,\n\t\tS:169, c:170, R:174, \"B \":180,\n\t\t/*::[*/0/*::]*/:176, /*::[*/1/*::]*/:177, /*::[*/2/*::]*/:178,\n\t\t/*::[*/3/*::]*/:179, /*::[*/5/*::]*/:181, /*::[*/6/*::]*/:182,\n\t\t/*::[*/7/*::]*/:183, Q:185, k:186, b:208, i:216, l:222, s:240, y:248,\n\t\t\"!\":161, '\"':162, \"#\":163, \"(\":164, \"%\":165, \"'\":167, \"H \":168,\n\t\t\"+\":171, \";\":187, \"<\":188, \"=\":189, \">\":190, \"?\":191, \"{\":223\n\t}/*:any*/);\n\tvar sylk_char_regex = new RegExp(\"\\u001BN(\" + keys(sylk_escapes).join(\"|\").replace(/\\|\\|\\|/, \"|\\\\||\").replace(/([?()+])/g,\"\\\\$1\") + \"|\\\\|)\", \"gm\");\n\tvar sylk_char_fn = function(_, $1){ var o = sylk_escapes[$1]; return typeof o == \"number\" ? _getansi(o) : o; };\n\tvar decode_sylk_char = function($$, $1, $2) { var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30); return newcc == 59 ? $$ : _getansi(newcc); };\n\tsylk_escapes[\"|\"] = 254;\n\t/* TODO: find an actual specification */\n\tfunction sylk_to_aoa(d/*:RawData*/, opts)/*:[AOA, Worksheet]*/ {\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': return sylk_to_aoa_str(Base64_decode(d), opts);\n\t\t\tcase 'binary': return sylk_to_aoa_str(d, opts);\n\t\t\tcase 'buffer': return sylk_to_aoa_str(has_buf && Buffer.isBuffer(d) ? d.toString('binary') : a2s(d), opts);\n\t\t\tcase 'array': return sylk_to_aoa_str(cc2str(d), opts);\n\t\t}\n\t\tthrow new Error(\"Unrecognized type \" + opts.type);\n\t}\n\tfunction sylk_to_aoa_str(str/*:string*/, opts)/*:[AOA, Worksheet]*/ {\n\t\tvar records = str.split(/[\\n\\r]+/), R = -1, C = -1, ri = 0, rj = 0, arr/*:AOA*/ = [];\n\t\tvar formats/*:Array<string>*/ = [];\n\t\tvar next_cell_format/*:string|null*/ = null;\n\t\tvar sht = {}, rowinfo/*:Array<RowInfo>*/ = [], colinfo/*:Array<ColInfo>*/ = [], cw/*:Array<string>*/ = [];\n\t\tvar Mval = 0, j;\n\t\tif(+opts.codepage >= 0) set_cp(+opts.codepage);\n\t\tfor (; ri !== records.length; ++ri) {\n\t\t\tMval = 0;\n\t\t\tvar rstr=records[ri].trim().replace(/\\x1B([\\x20-\\x2F])([\\x30-\\x3F])/g, decode_sylk_char).replace(sylk_char_regex, sylk_char_fn);\n\t\t\tvar record=rstr.replace(/;;/g, \"\\u0000\").split(\";\").map(function(x) { return x.replace(/\\u0000/g, \";\"); });\n\t\t\tvar RT=record[0], val;\n\t\t\tif(rstr.length > 0) switch(RT) {\n\t\t\tcase 'ID': break; /* header */\n\t\t\tcase 'E': break; /* EOF */\n\t\t\tcase 'B': break; /* dimensions */\n\t\t\tcase 'O': break; /* options? */\n\t\t\tcase 'W': break; /* window? */\n\t\t\tcase 'P':\n\t\t\t\tif(record[1].charAt(0) == 'P')\n\t\t\t\t\tformats.push(rstr.slice(3).replace(/;;/g, \";\"));\n\t\t\t\tbreak;\n\t\t\tcase 'C':\n\t\t\tvar C_seen_K = false, C_seen_X = false, C_seen_S = false, C_seen_E = false, _R = -1, _C = -1;\n\t\t\tfor(rj=1; rj<record.length; ++rj) switch(record[rj].charAt(0)) {\n\t\t\t\tcase 'A': break; // TODO: comment\n\t\t\t\tcase 'X': C = parseInt(record[rj].slice(1))-1; C_seen_X = true; break;\n\t\t\t\tcase 'Y':\n\t\t\t\t\tR = parseInt(record[rj].slice(1))-1; if(!C_seen_X) C = 0;\n\t\t\t\t\tfor(j = arr.length; j <= R; ++j) arr[j] = [];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'K':\n\t\t\t\t\tval = record[rj].slice(1);\n\t\t\t\t\tif(val.charAt(0) === '\"') val = val.slice(1,val.length - 1);\n\t\t\t\t\telse if(val === 'TRUE') val = true;\n\t\t\t\t\telse if(val === 'FALSE') val = false;\n\t\t\t\t\telse if(!isNaN(fuzzynum(val))) {\n\t\t\t\t\t\tval = fuzzynum(val);\n\t\t\t\t\t\tif(next_cell_format !== null && fmt_is_date(next_cell_format)) val = numdate(val);\n\t\t\t\t\t} else if(!isNaN(fuzzydate(val).getDate())) {\n\t\t\t\t\t\tval = parseDate(val);\n\t\t\t\t\t}\n\t\t\t\t\tif(typeof $cptable !== 'undefined' && typeof val == \"string\" && ((opts||{}).type != \"string\") && (opts||{}).codepage) val = $cptable.utils.decode(opts.codepage, val);\n\t\t\t\t\tC_seen_K = true;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'E':\n\t\t\t\t\tC_seen_E = true;\n\t\t\t\t\tvar formula = rc_to_a1(record[rj].slice(1), {r:R,c:C});\n\t\t\t\t\tarr[R][C] = [arr[R][C], formula];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'S':\n\t\t\t\t\tC_seen_S = true;\n\t\t\t\t\tarr[R][C] = [arr[R][C], \"S5S\"];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'G': break; // unknown\n\t\t\t\tcase 'R': _R = parseInt(record[rj].slice(1))-1; break;\n\t\t\t\tcase 'C': _C = parseInt(record[rj].slice(1))-1; break;\n\t\t\t\tdefault: if(opts && opts.WTF) throw new Error(\"SYLK bad record \" + rstr);\n\t\t\t}\n\t\t\tif(C_seen_K) {\n\t\t\t\tif(arr[R][C] && arr[R][C].length == 2) arr[R][C][0] = val;\n\t\t\t\telse arr[R][C] = val;\n\t\t\t\tnext_cell_format = null;\n\t\t\t}\n\t\t\tif(C_seen_S) {\n\t\t\t\tif(C_seen_E) throw new Error(\"SYLK shared formula cannot have own formula\");\n\t\t\t\tvar shrbase = _R > -1 && arr[_R][_C];\n\t\t\t\tif(!shrbase || !shrbase[1]) throw new Error(\"SYLK shared formula cannot find base\");\n\t\t\t\tarr[R][C][1] = shift_formula_str(shrbase[1], {r: R - _R, c: C - _C});\n\t\t\t}\n\t\t\tbreak;\n\t\t\tcase 'F':\n\t\t\tvar F_seen = 0;\n\t\t\tfor(rj=1; rj<record.length; ++rj) switch(record[rj].charAt(0)) {\n\t\t\t\tcase 'X': C = parseInt(record[rj].slice(1))-1; ++F_seen; break;\n\t\t\t\tcase 'Y':\n\t\t\t\t\tR = parseInt(record[rj].slice(1))-1; /*C = 0;*/\n\t\t\t\t\tfor(j = arr.length; j <= R; ++j) arr[j] = [];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'M': Mval = parseInt(record[rj].slice(1)) / 20; break;\n\t\t\t\tcase 'F': break; /* ??? */\n\t\t\t\tcase 'G': break; /* hide grid */\n\t\t\t\tcase 'P':\n\t\t\t\t\tnext_cell_format = formats[parseInt(record[rj].slice(1))];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'S': break; /* cell style */\n\t\t\t\tcase 'D': break; /* column */\n\t\t\t\tcase 'N': break; /* font */\n\t\t\t\tcase 'W':\n\t\t\t\t\tcw = record[rj].slice(1).split(\" \");\n\t\t\t\t\tfor(j = parseInt(cw[0], 10); j <= parseInt(cw[1], 10); ++j) {\n\t\t\t\t\t\tMval = parseInt(cw[2], 10);\n\t\t\t\t\t\tcolinfo[j-1] = Mval === 0 ? {hidden:true}: {wch:Mval}; process_col(colinfo[j-1]);\n\t\t\t\t\t} break;\n\t\t\t\tcase 'C': /* default column format */\n\t\t\t\t\tC = parseInt(record[rj].slice(1))-1;\n\t\t\t\t\tif(!colinfo[C]) colinfo[C] = {};\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'R': /* row properties */\n\t\t\t\t\tR = parseInt(record[rj].slice(1))-1;\n\t\t\t\t\tif(!rowinfo[R]) rowinfo[R] = {};\n\t\t\t\t\tif(Mval > 0) { rowinfo[R].hpt = Mval; rowinfo[R].hpx = pt2px(Mval); }\n\t\t\t\t\telse if(Mval === 0) rowinfo[R].hidden = true;\n\t\t\t\t\tbreak;\n\t\t\t\tdefault: if(opts && opts.WTF) throw new Error(\"SYLK bad record \" + rstr);\n\t\t\t}\n\t\t\tif(F_seen < 1) next_cell_format = null; break;\n\t\t\tdefault: if(opts && opts.WTF) throw new Error(\"SYLK bad record \" + rstr);\n\t\t\t}\n\t\t}\n\t\tif(rowinfo.length > 0) sht['!rows'] = rowinfo;\n\t\tif(colinfo.length > 0) sht['!cols'] = colinfo;\n\t\tif(opts && opts.sheetRows) arr = arr.slice(0, opts.sheetRows);\n\t\treturn [arr, sht];\n\t}\n\n\tfunction sylk_to_sheet(d/*:RawData*/, opts)/*:Worksheet*/ {\n\t\tvar aoasht = sylk_to_aoa(d, opts);\n\t\tvar aoa = aoasht[0], ws = aoasht[1];\n\t\tvar o = aoa_to_sheet(aoa, opts);\n\t\tkeys(ws).forEach(function(k) { o[k] = ws[k]; });\n\t\treturn o;\n\t}\n\n\tfunction sylk_to_workbook(d/*:RawData*/, opts)/*:Workbook*/ { return sheet_to_workbook(sylk_to_sheet(d, opts), opts); }\n\n\tfunction write_ws_cell_sylk(cell/*:Cell*/, ws/*:Worksheet*/, R/*:number*/, C/*:number*//*::, opts*/)/*:string*/ {\n\t\tvar o = \"C;Y\" + (R+1) + \";X\" + (C+1) + \";K\";\n\t\tswitch(cell.t) {\n\t\t\tcase 'n':\n\t\t\t\to += (cell.v||0);\n\t\t\t\tif(cell.f && !cell.F) o += \";E\" + a1_to_rc(cell.f, {r:R, c:C}); break;\n\t\t\tcase 'b': o += cell.v ? \"TRUE\" : \"FALSE\"; break;\n\t\t\tcase 'e': o += cell.w || cell.v; break;\n\t\t\tcase 'd': o += '\"' + (cell.w || cell.v) + '\"'; break;\n\t\t\tcase 's': o += '\"' + cell.v.replace(/\"/g,\"\").replace(/;/g, \";;\") + '\"'; break;\n\t\t}\n\t\treturn o;\n\t}\n\n\tfunction write_ws_cols_sylk(out, cols) {\n\t\tcols.forEach(function(col, i) {\n\t\t\tvar rec = \"F;W\" + (i+1) + \" \" + (i+1) + \" \";\n\t\t\tif(col.hidden) rec += \"0\";\n\t\t\telse {\n\t\t\t\tif(typeof col.width == 'number' && !col.wpx) col.wpx = width2px(col.width);\n\t\t\t\tif(typeof col.wpx == 'number' && !col.wch) col.wch = px2char(col.wpx);\n\t\t\t\tif(typeof col.wch == 'number') rec += Math.round(col.wch);\n\t\t\t}\n\t\t\tif(rec.charAt(rec.length - 1) != \" \") out.push(rec);\n\t\t});\n\t}\n\n\tfunction write_ws_rows_sylk(out/*:Array<string>*/, rows/*:Array<RowInfo>*/) {\n\t\trows.forEach(function(row, i) {\n\t\t\tvar rec = \"F;\";\n\t\t\tif(row.hidden) rec += \"M0;\";\n\t\t\telse if(row.hpt) rec += \"M\" + 20 * row.hpt + \";\";\n\t\t\telse if(row.hpx) rec += \"M\" + 20 * px2pt(row.hpx) + \";\";\n\t\t\tif(rec.length > 2) out.push(rec + \"R\" + (i+1));\n\t\t});\n\t}\n\n\tfunction sheet_to_sylk(ws/*:Worksheet*/, opts/*:?any*/)/*:string*/ {\n\t\tvar preamble/*:Array<string>*/ = [\"ID;PWXL;N;E\"], o/*:Array<string>*/ = [];\n\t\tvar r = safe_decode_range(ws['!ref']), cell/*:Cell*/;\n\t\tvar dense = Array.isArray(ws);\n\t\tvar RS = \"\\r\\n\";\n\n\t\tpreamble.push(\"P;PGeneral\");\n\t\tpreamble.push(\"F;P0;DG0G8;M255\");\n\t\tif(ws['!cols']) write_ws_cols_sylk(preamble, ws['!cols']);\n\t\tif(ws['!rows']) write_ws_rows_sylk(preamble, ws['!rows']);\n\n\t\tpreamble.push(\"B;Y\" + (r.e.r - r.s.r + 1) + \";X\" + (r.e.c - r.s.c + 1) + \";D\" + [r.s.c,r.s.r,r.e.c,r.e.r].join(\" \"));\n\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\tvar coord = encode_cell({r:R,c:C});\n\t\t\t\tcell = dense ? (ws[R]||[])[C]: ws[coord];\n\t\t\t\tif(!cell || (cell.v == null && (!cell.f || cell.F))) continue;\n\t\t\t\to.push(write_ws_cell_sylk(cell, ws, R, C, opts));\n\t\t\t}\n\t\t}\n\t\treturn preamble.join(RS) + RS + o.join(RS) + RS + \"E\" + RS;\n\t}\n\n\treturn {\n\t\tto_workbook: sylk_to_workbook,\n\t\tto_sheet: sylk_to_sheet,\n\t\tfrom_sheet: sheet_to_sylk\n\t};\n})();\n\nvar DIF = /*#__PURE__*/(function() {\n\tfunction dif_to_aoa(d/*:RawData*/, opts)/*:AOA*/ {\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': return dif_to_aoa_str(Base64_decode(d), opts);\n\t\t\tcase 'binary': return dif_to_aoa_str(d, opts);\n\t\t\tcase 'buffer': return dif_to_aoa_str(has_buf && Buffer.isBuffer(d) ? d.toString('binary') : a2s(d), opts);\n\t\t\tcase 'array': return dif_to_aoa_str(cc2str(d), opts);\n\t\t}\n\t\tthrow new Error(\"Unrecognized type \" + opts.type);\n\t}\n\tfunction dif_to_aoa_str(str/*:string*/, opts)/*:AOA*/ {\n\t\tvar records = str.split('\\n'), R = -1, C = -1, ri = 0, arr/*:AOA*/ = [];\n\t\tfor (; ri !== records.length; ++ri) {\n\t\t\tif (records[ri].trim() === 'BOT') { arr[++R] = []; C = 0; continue; }\n\t\t\tif (R < 0) continue;\n\t\t\tvar metadata = records[ri].trim().split(\",\");\n\t\t\tvar type = metadata[0], value = metadata[1];\n\t\t\t++ri;\n\t\t\tvar data = records[ri] || \"\";\n\t\t\twhile(((data.match(/[\"]/g)||[]).length & 1) && ri < records.length - 1) data += \"\\n\" + records[++ri];\n\t\t\tdata = data.trim();\n\t\t\tswitch (+type) {\n\t\t\t\tcase -1:\n\t\t\t\t\tif (data === 'BOT') { arr[++R] = []; C = 0; continue; }\n\t\t\t\t\telse if (data !== 'EOD') throw new Error(\"Unrecognized DIF special command \" + data);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0:\n\t\t\t\t\tif(data === 'TRUE') arr[R][C] = true;\n\t\t\t\t\telse if(data === 'FALSE') arr[R][C] = false;\n\t\t\t\t\telse if(!isNaN(fuzzynum(value))) arr[R][C] = fuzzynum(value);\n\t\t\t\t\telse if(!isNaN(fuzzydate(value).getDate())) arr[R][C] = parseDate(value);\n\t\t\t\t\telse arr[R][C] = value;\n\t\t\t\t\t++C; break;\n\t\t\t\tcase 1:\n\t\t\t\t\tdata = data.slice(1,data.length-1);\n\t\t\t\t\tdata = data.replace(/\"\"/g, '\"');\n\t\t\t\t\tif(DIF_XL && data && data.match(/^=\".*\"$/)) data = data.slice(2, -1);\n\t\t\t\t\tarr[R][C++] = data !== '' ? data : null;\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif (data === 'EOD') break;\n\t\t}\n\t\tif(opts && opts.sheetRows) arr = arr.slice(0, opts.sheetRows);\n\t\treturn arr;\n\t}\n\n\tfunction dif_to_sheet(str/*:string*/, opts)/*:Worksheet*/ { return aoa_to_sheet(dif_to_aoa(str, opts), opts); }\n\tfunction dif_to_workbook(str/*:string*/, opts)/*:Workbook*/ { return sheet_to_workbook(dif_to_sheet(str, opts), opts); }\n\n\tvar sheet_to_dif = /*#__PURE__*/(function() {\n\t\tvar push_field = function pf(o/*:Array<string>*/, topic/*:string*/, v/*:number*/, n/*:number*/, s/*:string*/) {\n\t\t\to.push(topic);\n\t\t\to.push(v + \",\" + n);\n\t\t\to.push('\"' + s.replace(/\"/g,'\"\"') + '\"');\n\t\t};\n\t\tvar push_value = function po(o/*:Array<string>*/, type/*:number*/, v/*:any*/, s/*:string*/) {\n\t\t\to.push(type + \",\" + v);\n\t\t\to.push(type == 1 ? '\"' + s.replace(/\"/g,'\"\"') + '\"' : s);\n\t\t};\n\t\treturn function sheet_to_dif(ws/*:Worksheet*//*::, opts:?any*/)/*:string*/ {\n\t\t\tvar o/*:Array<string>*/ = [];\n\t\t\tvar r = safe_decode_range(ws['!ref']), cell/*:Cell*/;\n\t\t\tvar dense = Array.isArray(ws);\n\t\t\tpush_field(o, \"TABLE\", 0, 1, \"sheetjs\");\n\t\t\tpush_field(o, \"VECTORS\", 0, r.e.r - r.s.r + 1,\"\");\n\t\t\tpush_field(o, \"TUPLES\", 0, r.e.c - r.s.c + 1,\"\");\n\t\t\tpush_field(o, \"DATA\", 0, 0,\"\");\n\t\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\t\tpush_value(o, -1, 0, \"BOT\");\n\t\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\t\tvar coord = encode_cell({r:R,c:C});\n\t\t\t\t\tcell = dense ? (ws[R]||[])[C] : ws[coord];\n\t\t\t\t\tif(!cell) { push_value(o, 1, 0, \"\"); continue;}\n\t\t\t\t\tswitch(cell.t) {\n\t\t\t\t\t\tcase 'n':\n\t\t\t\t\t\t\tvar val = DIF_XL ? cell.w : cell.v;\n\t\t\t\t\t\t\tif(!val && cell.v != null) val = cell.v;\n\t\t\t\t\t\t\tif(val == null) {\n\t\t\t\t\t\t\t\tif(DIF_XL && cell.f && !cell.F) push_value(o, 1, 0, \"=\" + cell.f);\n\t\t\t\t\t\t\t\telse push_value(o, 1, 0, \"\");\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse push_value(o, 0, val, \"V\");\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tcase 'b':\n\t\t\t\t\t\t\tpush_value(o, 0, cell.v ? 1 : 0, cell.v ? \"TRUE\" : \"FALSE\");\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tcase 's':\n\t\t\t\t\t\t\tpush_value(o, 1, 0, (!DIF_XL || isNaN(cell.v)) ? cell.v : '=\"' + cell.v + '\"');\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tcase 'd':\n\t\t\t\t\t\t\tif(!cell.w) cell.w = SSF_format(cell.z || table_fmt[14], datenum(parseDate(cell.v)));\n\t\t\t\t\t\t\tif(DIF_XL) push_value(o, 0, cell.w, \"V\");\n\t\t\t\t\t\t\telse push_value(o, 1, 0, cell.w);\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tdefault: push_value(o, 1, 0, \"\");\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tpush_value(o, -1, 0, \"EOD\");\n\t\t\tvar RS = \"\\r\\n\";\n\t\t\tvar oo = o.join(RS);\n\t\t\t//while((oo.length & 0x7F) != 0) oo += \"\\0\";\n\t\t\treturn oo;\n\t\t};\n\t})();\n\treturn {\n\t\tto_workbook: dif_to_workbook,\n\t\tto_sheet: dif_to_sheet,\n\t\tfrom_sheet: sheet_to_dif\n\t};\n})();\n\nvar ETH = /*#__PURE__*/(function() {\n\tfunction decode(s/*:string*/)/*:string*/ { return s.replace(/\\\\b/g,\"\\\\\").replace(/\\\\c/g,\":\").replace(/\\\\n/g,\"\\n\"); }\n\tfunction encode(s/*:string*/)/*:string*/ { return s.replace(/\\\\/g, \"\\\\b\").replace(/:/g, \"\\\\c\").replace(/\\n/g,\"\\\\n\"); }\n\n\tfunction eth_to_aoa(str/*:string*/, opts)/*:AOA*/ {\n\t\tvar records = str.split('\\n'), R = -1, C = -1, ri = 0, arr/*:AOA*/ = [];\n\t\tfor (; ri !== records.length; ++ri) {\n\t\t\tvar record = records[ri].trim().split(\":\");\n\t\t\tif(record[0] !== 'cell') continue;\n\t\t\tvar addr = decode_cell(record[1]);\n\t\t\tif(arr.length <= addr.r) for(R = arr.length; R <= addr.r; ++R) if(!arr[R]) arr[R] = [];\n\t\t\tR = addr.r; C = addr.c;\n\t\t\tswitch(record[2]) {\n\t\t\t\tcase 't': arr[R][C] = decode(record[3]); break;\n\t\t\t\tcase 'v': arr[R][C] = +record[3]; break;\n\t\t\t\tcase 'vtf': var _f = record[record.length - 1];\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 'vtc':\n\t\t\t\t\tswitch(record[3]) {\n\t\t\t\t\t\tcase 'nl': arr[R][C] = +record[4] ? true : false; break;\n\t\t\t\t\t\tdefault: arr[R][C] = +record[4]; break;\n\t\t\t\t\t}\n\t\t\t\t\tif(record[2] == 'vtf') arr[R][C] = [arr[R][C], _f];\n\t\t\t}\n\t\t}\n\t\tif(opts && opts.sheetRows) arr = arr.slice(0, opts.sheetRows);\n\t\treturn arr;\n\t}\n\n\tfunction eth_to_sheet(d/*:string*/, opts)/*:Worksheet*/ { return aoa_to_sheet(eth_to_aoa(d, opts), opts); }\n\tfunction eth_to_workbook(d/*:string*/, opts)/*:Workbook*/ { return sheet_to_workbook(eth_to_sheet(d, opts), opts); }\n\n\tvar header = [\n\t\t\"socialcalc:version:1.5\",\n\t\t\"MIME-Version: 1.0\",\n\t\t\"Content-Type: multipart/mixed; boundary=SocialCalcSpreadsheetControlSave\"\n\t].join(\"\\n\");\n\n\tvar sep = [\n\t\t\"--SocialCalcSpreadsheetControlSave\",\n\t\t\"Content-type: text/plain; charset=UTF-8\"\n\t].join(\"\\n\") + \"\\n\";\n\n\t/* TODO: the other parts */\n\tvar meta = [\n\t\t\"# SocialCalc Spreadsheet Control Save\",\n\t\t\"part:sheet\"\n\t].join(\"\\n\");\n\n\tvar end = \"--SocialCalcSpreadsheetControlSave--\";\n\n\tfunction sheet_to_eth_data(ws/*:Worksheet*/)/*:string*/ {\n\t\tif(!ws || !ws['!ref']) return \"\";\n\t\tvar o/*:Array<string>*/ = [], oo/*:Array<string>*/ = [], cell, coord = \"\";\n\t\tvar r = decode_range(ws['!ref']);\n\t\tvar dense = Array.isArray(ws);\n\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\tcoord = encode_cell({r:R,c:C});\n\t\t\t\tcell = dense ? (ws[R]||[])[C] : ws[coord];\n\t\t\t\tif(!cell || cell.v == null || cell.t === 'z') continue;\n\t\t\t\too = [\"cell\", coord, 't'];\n\t\t\t\tswitch(cell.t) {\n\t\t\t\t\tcase 's': case 'str': oo.push(encode(cell.v)); break;\n\t\t\t\t\tcase 'n':\n\t\t\t\t\t\tif(!cell.f) { oo[2]='v'; oo[3]=cell.v; }\n\t\t\t\t\t\telse { oo[2]='vtf'; oo[3]='n'; oo[4]=cell.v; oo[5]=encode(cell.f); }\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'b':\n\t\t\t\t\t\too[2] = 'vt'+(cell.f?'f':'c'); oo[3]='nl'; oo[4]=cell.v?\"1\":\"0\";\n\t\t\t\t\t\too[5] = encode(cell.f||(cell.v?'TRUE':'FALSE'));\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'd':\n\t\t\t\t\t\tvar t = datenum(parseDate(cell.v));\n\t\t\t\t\t\too[2] = 'vtc'; oo[3] = 'nd'; oo[4] = \"\"+t;\n\t\t\t\t\t\too[5] = cell.w || SSF_format(cell.z || table_fmt[14], t);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'e': continue;\n\t\t\t\t}\n\t\t\t\to.push(oo.join(\":\"));\n\t\t\t}\n\t\t}\n\t\to.push(\"sheet:c:\" + (r.e.c-r.s.c+1) + \":r:\" + (r.e.r-r.s.r+1) + \":tvf:1\");\n\t\to.push(\"valueformat:1:text-wiki\");\n\t\t//o.push(\"copiedfrom:\" + ws['!ref']); // clipboard only\n\t\treturn o.join(\"\\n\");\n\t}\n\n\tfunction sheet_to_eth(ws/*:Worksheet*//*::, opts:?any*/)/*:string*/ {\n\t\treturn [header, sep, meta, sep, sheet_to_eth_data(ws), end].join(\"\\n\");\n\t\t// return [\"version:1.5\", sheet_to_eth_data(ws)].join(\"\\n\"); // clipboard form\n\t}\n\n\treturn {\n\t\tto_workbook: eth_to_workbook,\n\t\tto_sheet: eth_to_sheet,\n\t\tfrom_sheet: sheet_to_eth\n\t};\n})();\n\nvar PRN = /*#__PURE__*/(function() {\n\tfunction set_text_arr(data/*:string*/, arr/*:AOA*/, R/*:number*/, C/*:number*/, o/*:any*/) {\n\t\tif(o.raw) arr[R][C] = data;\n\t\telse if(data === \"\"){/* empty */}\n\t\telse if(data === 'TRUE') arr[R][C] = true;\n\t\telse if(data === 'FALSE') arr[R][C] = false;\n\t\telse if(!isNaN(fuzzynum(data))) arr[R][C] = fuzzynum(data);\n\t\telse if(!isNaN(fuzzydate(data).getDate())) arr[R][C] = parseDate(data);\n\t\telse arr[R][C] = data;\n\t}\n\n\tfunction prn_to_aoa_str(f/*:string*/, opts)/*:AOA*/ {\n\t\tvar o = opts || {};\n\t\tvar arr/*:AOA*/ = ([]/*:any*/);\n\t\tif(!f || f.length === 0) return arr;\n\t\tvar lines = f.split(/[\\r\\n]/);\n\t\tvar L = lines.length - 1;\n\t\twhile(L >= 0 && lines[L].length === 0) --L;\n\t\tvar start = 10, idx = 0;\n\t\tvar R = 0;\n\t\tfor(; R <= L; ++R) {\n\t\t\tidx = lines[R].indexOf(\" \");\n\t\t\tif(idx == -1) idx = lines[R].length; else idx++;\n\t\t\tstart = Math.max(start, idx);\n\t\t}\n\t\tfor(R = 0; R <= L; ++R) {\n\t\t\tarr[R] = [];\n\t\t\t/* TODO: confirm that widths are always 10 */\n\t\t\tvar C = 0;\n\t\t\tset_text_arr(lines[R].slice(0, start).trim(), arr, R, C, o);\n\t\t\tfor(C = 1; C <= (lines[R].length - start)/10 + 1; ++C)\n\t\t\t\tset_text_arr(lines[R].slice(start+(C-1)*10,start+C*10).trim(),arr,R,C,o);\n\t\t}\n\t\tif(o.sheetRows) arr = arr.slice(0, o.sheetRows);\n\t\treturn arr;\n\t}\n\n\t// List of accepted CSV separators\n\tvar guess_seps = {\n\t\t/*::[*/0x2C/*::]*/: ',',\n\t\t/*::[*/0x09/*::]*/: \"\\t\",\n\t\t/*::[*/0x3B/*::]*/: ';',\n\t\t/*::[*/0x7C/*::]*/: '|'\n\t};\n\n\t// CSV separator weights to be used in case of equal numbers\n\tvar guess_sep_weights = {\n\t\t/*::[*/0x2C/*::]*/: 3,\n\t\t/*::[*/0x09/*::]*/: 2,\n\t\t/*::[*/0x3B/*::]*/: 1,\n\t\t/*::[*/0x7C/*::]*/: 0\n\t};\n\n\tfunction guess_sep(str) {\n\t\tvar cnt = {}, instr = false, end = 0, cc = 0;\n\t\tfor(;end < str.length;++end) {\n\t\t\tif((cc=str.charCodeAt(end)) == 0x22) instr = !instr;\n\t\t\telse if(!instr && cc in guess_seps) cnt[cc] = (cnt[cc]||0)+1;\n\t\t}\n\n\t\tcc = [];\n\t\tfor(end in cnt) if ( Object.prototype.hasOwnProperty.call(cnt, end) ) {\n\t\t\tcc.push([ cnt[end], end ]);\n\t\t}\n\n\t\tif ( !cc.length ) {\n\t\t\tcnt = guess_sep_weights;\n\t\t\tfor(end in cnt) if ( Object.prototype.hasOwnProperty.call(cnt, end) ) {\n\t\t\t\tcc.push([ cnt[end], end ]);\n\t\t\t}\n\t\t}\n\n\t\tcc.sort(function(a, b) { return a[0] - b[0] || guess_sep_weights[a[1]] - guess_sep_weights[b[1]]; });\n\n\t\treturn guess_seps[cc.pop()[1]] || 0x2C;\n\t}\n\n\tfunction dsv_to_sheet_str(str/*:string*/, opts)/*:Worksheet*/ {\n\t\tvar o = opts || {};\n\t\tvar sep = \"\";\n\t\tif(DENSE != null && o.dense == null) o.dense = DENSE;\n\t\tvar ws/*:Worksheet*/ = o.dense ? ([]/*:any*/) : ({}/*:any*/);\n\t\tvar range/*:Range*/ = ({s: {c:0, r:0}, e: {c:0, r:0}}/*:any*/);\n\n\t\tif(str.slice(0,4) == \"sep=\") {\n\t\t\t// If the line ends in \\r\\n\n\t\t\tif(str.charCodeAt(5) == 13 && str.charCodeAt(6) == 10 ) {\n\t\t\t\tsep = str.charAt(4); str = str.slice(7);\n\t\t\t}\n\t\t\t// If line ends in \\r OR \\n\n\t\t\telse if(str.charCodeAt(5) == 13 || str.charCodeAt(5) == 10 ) {\n\t\t\t\tsep = str.charAt(4); str = str.slice(6);\n\t\t\t}\n\t\t\telse sep = guess_sep(str.slice(0,1024));\n\t\t}\n\t\telse if(o && o.FS) sep = o.FS;\n\t\telse sep = guess_sep(str.slice(0,1024));\n\t\tvar R = 0, C = 0, v = 0;\n\t\tvar start = 0, end = 0, sepcc = sep.charCodeAt(0), instr = false, cc=0, startcc=str.charCodeAt(0);\n\t\tstr = str.replace(/\\r\\n/mg, \"\\n\");\n\t\tvar _re/*:?RegExp*/ = o.dateNF != null ? dateNF_regex(o.dateNF) : null;\n\t\tfunction finish_cell() {\n\t\t\tvar s = str.slice(start, end);\n\t\t\tvar cell = ({}/*:any*/);\n\t\t\tif(s.charAt(0) == '\"' && s.charAt(s.length - 1) == '\"') s = s.slice(1,-1).replace(/\"\"/g,'\"');\n\t\t\tif(s.length === 0) cell.t = 'z';\n\t\t\telse if(o.raw) { cell.t = 's'; cell.v = s; }\n\t\t\telse if(s.trim().length === 0) { cell.t = 's'; cell.v = s; }\n\t\t\telse if(s.charCodeAt(0) == 0x3D) {\n\t\t\t\tif(s.charCodeAt(1) == 0x22 && s.charCodeAt(s.length - 1) == 0x22) { cell.t = 's'; cell.v = s.slice(2,-1).replace(/\"\"/g,'\"'); }\n\t\t\t\telse if(fuzzyfmla(s)) { cell.t = 'n'; cell.f = s.slice(1); }\n\t\t\t\telse { cell.t = 's'; cell.v = s; } }\n\t\t\telse if(s == \"TRUE\") { cell.t = 'b'; cell.v = true; }\n\t\t\telse if(s == \"FALSE\") { cell.t = 'b'; cell.v = false; }\n\t\t\telse if(!isNaN(v = fuzzynum(s))) { cell.t = 'n'; if(o.cellText !== false) cell.w = s; cell.v = v; }\n\t\t\telse if(!isNaN(fuzzydate(s).getDate()) || _re && s.match(_re)) {\n\t\t\t\tcell.z = o.dateNF || table_fmt[14];\n\t\t\t\tvar k = 0;\n\t\t\t\tif(_re && s.match(_re)){ s=dateNF_fix(s, o.dateNF, (s.match(_re)||[])); k=1; }\n\t\t\t\tif(o.cellDates) { cell.t = 'd'; cell.v = parseDate(s, k); }\n\t\t\t\telse { cell.t = 'n'; cell.v = datenum(parseDate(s, k)); }\n\t\t\t\tif(o.cellText !== false) cell.w = SSF_format(cell.z, cell.v instanceof Date ? datenum(cell.v):cell.v);\n\t\t\t\tif(!o.cellNF) delete cell.z;\n\t\t\t} else {\n\t\t\t\tcell.t = 's';\n\t\t\t\tcell.v = s;\n\t\t\t}\n\t\t\tif(cell.t == 'z'){}\n\t\t\telse if(o.dense) { if(!ws[R]) ws[R] = []; ws[R][C] = cell; }\n\t\t\telse ws[encode_cell({c:C,r:R})] = cell;\n\t\t\tstart = end+1; startcc = str.charCodeAt(start);\n\t\t\tif(range.e.c < C) range.e.c = C;\n\t\t\tif(range.e.r < R) range.e.r = R;\n\t\t\tif(cc == sepcc) ++C; else { C = 0; ++R; if(o.sheetRows && o.sheetRows <= R) return true; }\n\t\t}\n\t\touter: for(;end < str.length;++end) switch((cc=str.charCodeAt(end))) {\n\t\t\tcase 0x22: if(startcc === 0x22) instr = !instr; break;\n\t\t\tcase sepcc: case 0x0a: case 0x0d: if(!instr && finish_cell()) break outer; break;\n\t\t\tdefault: break;\n\t\t}\n\t\tif(end - start > 0) finish_cell();\n\n\t\tws['!ref'] = encode_range(range);\n\t\treturn ws;\n\t}\n\n\tfunction prn_to_sheet_str(str/*:string*/, opts)/*:Worksheet*/ {\n\t\tif(!(opts && opts.PRN)) return dsv_to_sheet_str(str, opts);\n\t\tif(opts.FS) return dsv_to_sheet_str(str, opts);\n\t\tif(str.slice(0,4) == \"sep=\") return dsv_to_sheet_str(str, opts);\n\t\tif(str.indexOf(\"\\t\") >= 0 || str.indexOf(\",\") >= 0 || str.indexOf(\";\") >= 0) return dsv_to_sheet_str(str, opts);\n\t\treturn aoa_to_sheet(prn_to_aoa_str(str, opts), opts);\n\t}\n\n\tfunction prn_to_sheet(d/*:RawData*/, opts)/*:Worksheet*/ {\n\t\tvar str = \"\", bytes = opts.type == 'string' ? [0,0,0,0] : firstbyte(d, opts);\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': str = Base64_decode(d); break;\n\t\t\tcase 'binary': str = d; break;\n\t\t\tcase 'buffer':\n\t\t\t\tif(opts.codepage == 65001) str = d.toString('utf8'); // TODO: test if buf\n\t\t\t\telse if(opts.codepage && typeof $cptable !== 'undefined') str = $cptable.utils.decode(opts.codepage, d);\n\t\t\t\telse str = has_buf && Buffer.isBuffer(d) ? d.toString('binary') : a2s(d);\n\t\t\t\tbreak;\n\t\t\tcase 'array': str = cc2str(d); break;\n\t\t\tcase 'string': str = d; break;\n\t\t\tdefault: throw new Error(\"Unrecognized type \" + opts.type);\n\t\t}\n\t\tif(bytes[0] == 0xEF && bytes[1] == 0xBB && bytes[2] == 0xBF) str = utf8read(str.slice(3));\n\t\telse if(opts.type != 'string' && opts.type != 'buffer' && opts.codepage == 65001) str = utf8read(str);\n\t\telse if((opts.type == 'binary') && typeof $cptable !== 'undefined' && opts.codepage) str = $cptable.utils.decode(opts.codepage, $cptable.utils.encode(28591,str));\n\t\tif(str.slice(0,19) == \"socialcalc:version:\") return ETH.to_sheet(opts.type == 'string' ? str : utf8read(str), opts);\n\t\treturn prn_to_sheet_str(str, opts);\n\t}\n\n\tfunction prn_to_workbook(d/*:RawData*/, opts)/*:Workbook*/ { return sheet_to_workbook(prn_to_sheet(d, opts), opts); }\n\n\tfunction sheet_to_prn(ws/*:Worksheet*//*::, opts:?any*/)/*:string*/ {\n\t\tvar o/*:Array<string>*/ = [];\n\t\tvar r = safe_decode_range(ws['!ref']), cell/*:Cell*/;\n\t\tvar dense = Array.isArray(ws);\n\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\tvar oo/*:Array<string>*/ = [];\n\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\tvar coord = encode_cell({r:R,c:C});\n\t\t\t\tcell = dense ? (ws[R]||[])[C] : ws[coord];\n\t\t\t\tif(!cell || cell.v == null) { oo.push(\" \"); continue; }\n\t\t\t\tvar w = (cell.w || (format_cell(cell), cell.w) || \"\").slice(0,10);\n\t\t\t\twhile(w.length < 10) w += \" \";\n\t\t\t\too.push(w + (C === 0 ? \" \" : \"\"));\n\t\t\t}\n\t\t\to.push(oo.join(\"\"));\n\t\t}\n\t\treturn o.join(\"\\n\");\n\t}\n\n\treturn {\n\t\tto_workbook: prn_to_workbook,\n\t\tto_sheet: prn_to_sheet,\n\t\tfrom_sheet: sheet_to_prn\n\t};\n})();\n\n/* Excel defaults to SYLK but warns if data is not valid */\nfunction read_wb_ID(d, opts) {\n\tvar o = opts || {}, OLD_WTF = !!o.WTF; o.WTF = true;\n\ttry {\n\t\tvar out = SYLK.to_workbook(d, o);\n\t\to.WTF = OLD_WTF;\n\t\treturn out;\n\t} catch(e) {\n\t\to.WTF = OLD_WTF;\n\t\tif(!e.message.match(/SYLK bad record ID/) && OLD_WTF) throw e;\n\t\treturn PRN.to_workbook(d, opts);\n\t}\n}\n\nvar WK_ = /*#__PURE__*/(function() {\n\tfunction lotushopper(data, cb/*:RecordHopperCB*/, opts/*:any*/) {\n\t\tif(!data) return;\n\t\tprep_blob(data, data.l || 0);\n\t\tvar Enum = opts.Enum || WK1Enum;\n\t\twhile(data.l < data.length) {\n\t\t\tvar RT = data.read_shift(2);\n\t\t\tvar R = Enum[RT] || Enum[0xFFFF];\n\t\t\tvar length = data.read_shift(2);\n\t\t\tvar tgt = data.l + length;\n\t\t\tvar d = R.f && R.f(data, length, opts);\n\t\t\tdata.l = tgt;\n\t\t\tif(cb(d, R, RT)) return;\n\t\t}\n\t}\n\n\tfunction lotus_to_workbook(d/*:RawData*/, opts) {\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': return lotus_to_workbook_buf(s2a(Base64_decode(d)), opts);\n\t\t\tcase 'binary': return lotus_to_workbook_buf(s2a(d), opts);\n\t\t\tcase 'buffer':\n\t\t\tcase 'array': return lotus_to_workbook_buf(d, opts);\n\t\t}\n\t\tthrow \"Unsupported type \" + opts.type;\n\t}\n\n\tfunction lotus_to_workbook_buf(d, opts)/*:Workbook*/ {\n\t\tif(!d) return d;\n\t\tvar o = opts || {};\n\t\tif(DENSE != null && o.dense == null) o.dense = DENSE;\n\t\tvar s/*:Worksheet*/ = ((o.dense ? [] : {})/*:any*/), n = \"Sheet1\", next_n = \"\", sidx = 0;\n\t\tvar sheets = {}, snames = [], realnames = [];\n\n\t\tvar refguess = {s: {r:0, c:0}, e: {r:0, c:0} };\n\t\tvar sheetRows = o.sheetRows || 0;\n\n\t\tif(d[2] == 0x00) {\n\t\t\tif(d[3] == 0x08 || d[3] == 0x09) {\n\t\t\t\tif(d.length >= 16 && d[14] == 0x05 && d[15] === 0x6c) throw new Error(\"Unsupported Works 3 for Mac file\");\n\t\t\t}\n\t\t}\n\n\t\tif(d[2] == 0x02) {\n\t\t\to.Enum = WK1Enum;\n\t\t\tlotushopper(d, function(val, R, RT) { switch(RT) {\n\t\t\t\tcase 0x00: /* BOF */\n\t\t\t\t\to.vers = val;\n\t\t\t\t\tif(val >= 0x1000) o.qpro = true;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x06: refguess = val; break; /* RANGE */\n\t\t\t\tcase 0xCC: if(val) next_n = val; break; /* SHEETNAMECS */\n\t\t\t\tcase 0xDE: next_n = val; break; /* SHEETNAMELP */\n\t\t\t\tcase 0x0F: /* LABEL */\n\t\t\t\tcase 0x33: /* STRING */\n\t\t\t\t\tif(!o.qpro) val[1].v = val[1].v.slice(1);\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 0x0D: /* INTEGER */\n\t\t\t\tcase 0x0E: /* NUMBER */\n\t\t\t\tcase 0x10: /* FORMULA */\n\t\t\t\t\t/* TODO: actual translation of the format code */\n\t\t\t\t\tif(RT == 0x0E && (val[2] & 0x70) == 0x70 && (val[2] & 0x0F) > 1 && (val[2] & 0x0F) < 15) {\n\t\t\t\t\t\tval[1].z = o.dateNF || table_fmt[14];\n\t\t\t\t\t\tif(o.cellDates) { val[1].t = 'd'; val[1].v = numdate(val[1].v); }\n\t\t\t\t\t}\n\n\t\t\t\t\tif(o.qpro) {\n\t\t\t\t\t\tif(val[3] > sidx) {\n\t\t\t\t\t\t\ts[\"!ref\"] = encode_range(refguess);\n\t\t\t\t\t\t\tsheets[n] = s;\n\t\t\t\t\t\t\tsnames.push(n);\n\t\t\t\t\t\t\ts = (o.dense ? [] : {});\n\t\t\t\t\t\t\trefguess = {s: {r:0, c:0}, e: {r:0, c:0} };\n\t\t\t\t\t\t\tsidx = val[3]; n = next_n || \"Sheet\" + (sidx + 1); next_n = \"\";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tvar tmpcell = o.dense ? (s[val[0].r]||[])[val[0].c] : s[encode_cell(val[0])];\n\t\t\t\t\tif(tmpcell) {\n\t\t\t\t\t\ttmpcell.t = val[1].t; tmpcell.v = val[1].v;\n\t\t\t\t\t\tif(val[1].z != null) tmpcell.z = val[1].z;\n\t\t\t\t\t\tif(val[1].f != null) tmpcell.f = val[1].f;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tif(o.dense) {\n\t\t\t\t\t\tif(!s[val[0].r]) s[val[0].r] = [];\n\t\t\t\t\t\ts[val[0].r][val[0].c] = val[1];\n\t\t\t\t\t} else s[encode_cell(val[0])] = val[1];\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t}}, o);\n\t\t} else if(d[2] == 0x1A || d[2] == 0x0E) {\n\t\t\to.Enum = WK3Enum;\n\t\t\tif(d[2] == 0x0E) { o.qpro = true; d.l = 0; }\n\t\t\tlotushopper(d, function(val, R, RT) { switch(RT) {\n\t\t\t\tcase 0xCC: n = val; break; /* SHEETNAMECS */\n\t\t\t\tcase 0x16: /* LABEL16 */\n\t\t\t\t\tval[1].v = val[1].v.slice(1);\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 0x17: /* NUMBER17 */\n\t\t\t\tcase 0x18: /* NUMBER18 */\n\t\t\t\tcase 0x19: /* FORMULA19 */\n\t\t\t\tcase 0x25: /* NUMBER25 */\n\t\t\t\tcase 0x27: /* NUMBER27 */\n\t\t\t\tcase 0x28: /* FORMULA28 */\n\t\t\t\t\tif(val[3] > sidx) {\n\t\t\t\t\t\ts[\"!ref\"] = encode_range(refguess);\n\t\t\t\t\t\tsheets[n] = s;\n\t\t\t\t\t\tsnames.push(n);\n\t\t\t\t\t\ts = (o.dense ? [] : {});\n\t\t\t\t\t\trefguess = {s: {r:0, c:0}, e: {r:0, c:0} };\n\t\t\t\t\t\tsidx = val[3]; n = \"Sheet\" + (sidx + 1);\n\t\t\t\t\t}\n\t\t\t\t\tif(sheetRows > 0 && val[0].r >= sheetRows) break;\n\t\t\t\t\tif(o.dense) {\n\t\t\t\t\t\tif(!s[val[0].r]) s[val[0].r] = [];\n\t\t\t\t\t\ts[val[0].r][val[0].c] = val[1];\n\t\t\t\t\t} else s[encode_cell(val[0])] = val[1];\n\t\t\t\t\tif(refguess.e.c < val[0].c) refguess.e.c = val[0].c;\n\t\t\t\t\tif(refguess.e.r < val[0].r) refguess.e.r = val[0].r;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x1B: /* XFORMAT */\n\t\t\t\t\tif(val[0x36b0]) realnames[val[0x36b0][0]] = val[0x36b0][1];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0601: /* SHEETINFOQP */\n\t\t\t\t\trealnames[val[0]] = val[1]; if(val[0] == sidx) n = val[1]; break;\n\t\t\t\tdefault: break;\n\t\t\t}}, o);\n\t\t} else throw new Error(\"Unrecognized LOTUS BOF \" + d[2]);\n\t\ts[\"!ref\"] = encode_range(refguess);\n\t\tsheets[next_n || n] = s;\n\t\tsnames.push(next_n || n);\n\t\tif(!realnames.length) return { SheetNames: snames, Sheets: sheets };\n\t\tvar osheets = {}, rnames = [];\n\t\t/* TODO: verify no collisions */\n\t\tfor(var i = 0; i < realnames.length; ++i) if(sheets[snames[i]]) {\n\t\t\trnames.push(realnames[i] || snames[i]);\n\t\t\tosheets[realnames[i]] = sheets[realnames[i]] || sheets[snames[i]];\n\t\t} else {\n\t\t\trnames.push(realnames[i]);\n\t\t\tosheets[realnames[i]] = ({ \"!ref\": \"A1\" });\n\t\t}\n\t\treturn { SheetNames: rnames, Sheets: osheets };\n\t}\n\n\tfunction sheet_to_wk1(ws/*:Worksheet*/, opts/*:WriteOpts*/) {\n\t\tvar o = opts || {};\n\t\tif(+o.codepage >= 0) set_cp(+o.codepage);\n\t\tif(o.type == \"string\") throw new Error(\"Cannot write WK1 to JS string\");\n\t\tvar ba = buf_array();\n\t\tvar range = safe_decode_range(ws[\"!ref\"]);\n\t\tvar dense = Array.isArray(ws);\n\t\tvar cols = [];\n\n\t\twrite_biff_rec(ba, 0x00, write_BOF_WK1(0x0406));\n\t\twrite_biff_rec(ba, 0x06, write_RANGE(range));\n\t\tvar max_R = Math.min(range.e.r, 8191);\n\t\tfor(var R = range.s.r; R <= max_R; ++R) {\n\t\t\tvar rr = encode_row(R);\n\t\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\t\tvar ref = cols[C] + rr;\n\t\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\t\tif(!cell || cell.t == \"z\") continue;\n\t\t\t\t/* TODO: formula records */\n\t\t\t\tif(cell.t == \"n\") {\n\t\t\t\t\tif((cell.v|0)==cell.v && cell.v >= -32768 && cell.v <= 32767) write_biff_rec(ba, 0x0d, write_INTEGER(R, C, cell.v));\n\t\t\t\t\telse write_biff_rec(ba, 0x0e, write_NUMBER(R, C, cell.v));\n\t\t\t\t} else {\n\t\t\t\t\tvar str = format_cell(cell);\n\t\t\t\t\twrite_biff_rec(ba, 0x0F, write_LABEL(R, C, str.slice(0, 239)));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\twrite_biff_rec(ba, 0x01);\n\t\treturn ba.end();\n\t}\n\n\tfunction book_to_wk3(wb/*:Workbook*/, opts/*:WriteOpts*/) {\n\t\tvar o = opts || {};\n\t\tif(+o.codepage >= 0) set_cp(+o.codepage);\n\t\tif(o.type == \"string\") throw new Error(\"Cannot write WK3 to JS string\");\n\t\tvar ba = buf_array();\n\n\t\twrite_biff_rec(ba, 0x00, write_BOF_WK3(wb));\n\n\t\tfor(var i = 0, cnt = 0; i < wb.SheetNames.length; ++i) if((wb.Sheets[wb.SheetNames[i]] || {})[\"!ref\"]) write_biff_rec(ba, 0x1b, write_XFORMAT_SHEETNAME(wb.SheetNames[i], cnt++));\n\n\t\tvar wsidx = 0;\n\t\tfor(i = 0; i < wb.SheetNames.length; ++i) {\n\t\t\tvar ws = wb.Sheets[wb.SheetNames[i]];\n\t\t\tif(!ws || !ws[\"!ref\"]) continue;\n\t\t\tvar range = safe_decode_range(ws[\"!ref\"]);\n\t\t\tvar dense = Array.isArray(ws);\n\t\t\tvar cols = [];\n\t\t\tvar max_R = Math.min(range.e.r, 8191);\n\t\t\tfor(var R = range.s.r; R <= max_R; ++R) {\n\t\t\t\tvar rr = encode_row(R);\n\t\t\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\t\t\tvar ref = cols[C] + rr;\n\t\t\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\t\t\tif(!cell || cell.t == \"z\") continue;\n\t\t\t\t\t/* TODO: FORMULA19 NUMBER18 records */\n\t\t\t\t\tif(cell.t == \"n\") {\n\t\t\t\t\t\twrite_biff_rec(ba, 0x17, write_NUMBER_17(R, C, wsidx, cell.v));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvar str = format_cell(cell);\n\t\t\t\t\t\t/* TODO: max len? */\n\t\t\t\t\t\twrite_biff_rec(ba, 0x16, write_LABEL_16(R, C, wsidx, str.slice(0, 239)));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t++wsidx;\n\t\t}\n\n\t\twrite_biff_rec(ba, 0x01);\n\t\treturn ba.end();\n\t}\n\n\n\tfunction write_BOF_WK1(v/*:number*/) {\n\t\tvar out = new_buf(2);\n\t\tout.write_shift(2, v);\n\t\treturn out;\n\t}\n\n\tfunction write_BOF_WK3(wb/*:Workbook*/) {\n\t\tvar out = new_buf(26);\n\t\tout.write_shift(2, 0x1000);\n\t\tout.write_shift(2, 0x0004);\n\t\tout.write_shift(4, 0x0000);\n\t\tvar rows = 0, cols = 0, wscnt = 0;\n\t\tfor(var i = 0; i < wb.SheetNames.length; ++i) {\n\t\t\tvar name = wb.SheetNames[i];\n\t\t\tvar ws = wb.Sheets[name];\n\t\t\tif(!ws || !ws[\"!ref\"]) continue;\n\t\t\t++wscnt;\n\t\t\tvar range = decode_range(ws[\"!ref\"]);\n\t\t\tif(rows < range.e.r) rows = range.e.r;\n\t\t\tif(cols < range.e.c) cols = range.e.c;\n\t\t}\n\t\tif(rows > 8191) rows = 8191;\n\t\tout.write_shift(2, rows);\n\t\tout.write_shift(1, wscnt);\n\t\tout.write_shift(1, cols);\n\t\tout.write_shift(2, 0x00);\n\t\tout.write_shift(2, 0x00);\n\t\tout.write_shift(1, 0x01);\n\t\tout.write_shift(1, 0x02);\n\t\tout.write_shift(4, 0);\n\t\tout.write_shift(4, 0);\n\t\treturn out;\n\t}\n\n\tfunction parse_RANGE(blob, length, opts) {\n\t\tvar o = {s:{c:0,r:0},e:{c:0,r:0}};\n\t\tif(length == 8 && opts.qpro) {\n\t\t\to.s.c = blob.read_shift(1);\n\t\t\tblob.l++;\n\t\t\to.s.r = blob.read_shift(2);\n\t\t\to.e.c = blob.read_shift(1);\n\t\t\tblob.l++;\n\t\t\to.e.r = blob.read_shift(2);\n\t\t\treturn o;\n\t\t}\n\t\to.s.c = blob.read_shift(2);\n\t\to.s.r = blob.read_shift(2);\n\t\tif(length == 12 && opts.qpro) blob.l += 2;\n\t\to.e.c = blob.read_shift(2);\n\t\to.e.r = blob.read_shift(2);\n\t\tif(length == 12 && opts.qpro) blob.l += 2;\n\t\tif(o.s.c == 0xFFFF) o.s.c = o.e.c = o.s.r = o.e.r = 0;\n\t\treturn o;\n\t}\n\tfunction write_RANGE(range) {\n\t\tvar out = new_buf(8);\n\t\tout.write_shift(2, range.s.c);\n\t\tout.write_shift(2, range.s.r);\n\t\tout.write_shift(2, range.e.c);\n\t\tout.write_shift(2, range.e.r);\n\t\treturn out;\n\t}\n\n\tfunction parse_cell(blob, length, opts) {\n\t\tvar o = [{c:0,r:0}, {t:'n',v:0}, 0, 0];\n\t\tif(opts.qpro && opts.vers != 0x5120) {\n\t\t\to[0].c = blob.read_shift(1);\n\t\t\to[3] = blob.read_shift(1);\n\t\t\to[0].r = blob.read_shift(2);\n\t\t\tblob.l+=2;\n\t\t} else {\n\t\t\to[2] = blob.read_shift(1);\n\t\t\to[0].c = blob.read_shift(2); o[0].r = blob.read_shift(2);\n\t\t}\n\t\treturn o;\n\t}\n\n\tfunction parse_LABEL(blob, length, opts) {\n\t\tvar tgt = blob.l + length;\n\t\tvar o = parse_cell(blob, length, opts);\n\t\to[1].t = 's';\n\t\tif(opts.vers == 0x5120) {\n\t\t\tblob.l++;\n\t\t\tvar len = blob.read_shift(1);\n\t\t\to[1].v = blob.read_shift(len, 'utf8');\n\t\t\treturn o;\n\t\t}\n\t\tif(opts.qpro) blob.l++;\n\t\to[1].v = blob.read_shift(tgt - blob.l, 'cstr');\n\t\treturn o;\n\t}\n\tfunction write_LABEL(R, C, s) {\n\t\t/* TODO: encoding */\n\t\tvar o = new_buf(7 + s.length);\n\t\to.write_shift(1, 0xFF);\n\t\to.write_shift(2, C);\n\t\to.write_shift(2, R);\n\t\to.write_shift(1, 0x27); // ??\n\t\tfor(var i = 0; i < o.length; ++i) {\n\t\t\tvar cc = s.charCodeAt(i);\n\t\t\to.write_shift(1, cc >= 0x80 ? 0x5F : cc);\n\t\t}\n\t\to.write_shift(1, 0);\n\t\treturn o;\n\t}\n\n\tfunction parse_INTEGER(blob, length, opts) {\n\t\tvar o = parse_cell(blob, length, opts);\n\t\to[1].v = blob.read_shift(2, 'i');\n\t\treturn o;\n\t}\n\tfunction write_INTEGER(R, C, v) {\n\t\tvar o = new_buf(7);\n\t\to.write_shift(1, 0xFF);\n\t\to.write_shift(2, C);\n\t\to.write_shift(2, R);\n\t\to.write_shift(2, v, 'i');\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER(blob, length, opts) {\n\t\tvar o = parse_cell(blob, length, opts);\n\t\to[1].v = blob.read_shift(8, 'f');\n\t\treturn o;\n\t}\n\tfunction write_NUMBER(R, C, v) {\n\t\tvar o = new_buf(13);\n\t\to.write_shift(1, 0xFF);\n\t\to.write_shift(2, C);\n\t\to.write_shift(2, R);\n\t\to.write_shift(8, v, 'f');\n\t\treturn o;\n\t}\n\n\tfunction parse_FORMULA(blob, length, opts) {\n\t\tvar tgt = blob.l + length;\n\t\tvar o = parse_cell(blob, length, opts);\n\t\t/* TODO: formula */\n\t\to[1].v = blob.read_shift(8, 'f');\n\t\tif(opts.qpro) blob.l = tgt;\n\t\telse {\n\t\t\tvar flen = blob.read_shift(2);\n\t\t\twk1_fmla_to_csf(blob.slice(blob.l, blob.l + flen), o);\n\t\t\tblob.l += flen;\n\t\t}\n\t\treturn o;\n\t}\n\n\tfunction wk1_parse_rc(B, V, col) {\n\t\tvar rel = V & 0x8000;\n\t\tV &= ~0x8000;\n\t\tV = (rel ? B : 0) + ((V >= 0x2000) ? V - 0x4000 : V);\n\t\treturn (rel ? \"\" : \"$\") + (col ? encode_col(V) : encode_row(V));\n\t}\n\t/* var oprec = [\n\t\t8, 8, 8, 8, 8, 8, 8, 8, 6, 4, 4, 5, 5, 7, 3, 3,\n\t\t3, 3, 3, 3, 1, 1, 2, 6, 8, 8, 8, 8, 8, 8, 8, 8\n\t]; */\n\t/* TODO: flesh out */\n\tvar FuncTab = {\n\t\t0x33: [\"FALSE\", 0],\n\t\t0x34: [\"TRUE\", 0],\n\t\t0x46: [\"LEN\", 1],\n\t\t0x50: [\"SUM\", 69],\n\t\t0x51: [\"AVERAGEA\", 69],\n\t\t0x52: [\"COUNTA\", 69],\n\t\t0x53: [\"MINA\", 69],\n\t\t0x54: [\"MAXA\", 69],\n\t\t0x6F: [\"T\", 1]\n\t};\n\tvar BinOpTab = [\n\t\t \"\", \"\", \"\", \"\", \"\", \"\", \"\", \"\", // eslint-disable-line no-mixed-spaces-and-tabs\n\t\t \"\", \"+\", \"-\", \"*\", \"/\", \"^\", \"=\", \"<>\", // eslint-disable-line no-mixed-spaces-and-tabs\n\t\t\"<=\", \">=\", \"<\", \">\", \"\", \"\", \"\", \"\", // eslint-disable-line no-mixed-spaces-and-tabs\n\t\t \"&\", \"\", \"\", \"\", \"\", \"\", \"\", \"\" // eslint-disable-line no-mixed-spaces-and-tabs\n\t];\n\n\tfunction wk1_fmla_to_csf(blob, o) {\n\t\tprep_blob(blob, 0);\n\t\tvar out = [], argc = 0, R = \"\", C = \"\", argL = \"\", argR = \"\";\n\t\twhile(blob.l < blob.length) {\n\t\t\tvar cc = blob[blob.l++];\n\t\t\tswitch(cc) {\n\t\t\t\tcase 0x00: out.push(blob.read_shift(8, 'f')); break;\n\t\t\t\tcase 0x01: {\n\t\t\t\t\tC = wk1_parse_rc(o[0].c, blob.read_shift(2), true);\n\t\t\t\t\tR = wk1_parse_rc(o[0].r, blob.read_shift(2), false);\n\t\t\t\t\tout.push(C + R);\n\t\t\t\t} break;\n\t\t\t\tcase 0x02: {\n\t\t\t\t\tvar c = wk1_parse_rc(o[0].c, blob.read_shift(2), true);\n\t\t\t\t\tvar r = wk1_parse_rc(o[0].r, blob.read_shift(2), false);\n\t\t\t\t\tC = wk1_parse_rc(o[0].c, blob.read_shift(2), true);\n\t\t\t\t\tR = wk1_parse_rc(o[0].r, blob.read_shift(2), false);\n\t\t\t\t\tout.push(c + r + \":\" + C + R);\n\t\t\t\t} break;\n\t\t\t\tcase 0x03:\n\t\t\t\t\tif(blob.l < blob.length) { console.error(\"WK1 premature formula end\"); return; }\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x04: out.push(\"(\" + out.pop() + \")\"); break;\n\t\t\t\tcase 0x05: out.push(blob.read_shift(2)); break;\n\t\t\t\tcase 0x06: {\n\t\t\t\t\t/* TODO: text encoding */\n\t\t\t\t\tvar Z = \"\"; while((cc = blob[blob.l++])) Z += String.fromCharCode(cc);\n\t\t\t\t\tout.push('\"' + Z.replace(/\"/g, '\"\"') + '\"');\n\t\t\t\t} break;\n\n\t\t\t\tcase 0x08: out.push(\"-\" + out.pop()); break;\n\t\t\t\tcase 0x17: out.push(\"+\" + out.pop()); break;\n\t\t\t\tcase 0x16: out.push(\"NOT(\" + out.pop() + \")\"); break;\n\n\t\t\t\tcase 0x14: case 0x15: {\n\t\t\t\t\targR = out.pop(); argL = out.pop();\n\t\t\t\t\tout.push([\"AND\", \"OR\"][cc - 0x14] + \"(\" + argL + \",\" + argR + \")\");\n\t\t\t\t} break;\n\n\t\t\t\tdefault:\n\t\t\t\t\tif(cc < 0x20 && BinOpTab[cc]) {\n\t\t\t\t\t\targR = out.pop(); argL = out.pop();\n\t\t\t\t\t\tout.push(argL + BinOpTab[cc] + argR);\n\t\t\t\t\t} else if(FuncTab[cc]) {\n\t\t\t\t\t\targc = FuncTab[cc][1];\n\t\t\t\t\t\tif(argc == 69) argc = blob[blob.l++];\n\t\t\t\t\t\tif(argc > out.length) { console.error(\"WK1 bad formula parse 0x\" + cc.toString(16) + \":|\" + out.join(\"|\") + \"|\"); return; }\n\t\t\t\t\t\tvar args = out.slice(-argc);\n\t\t\t\t\t\tout.length -= argc;\n\t\t\t\t\t\tout.push(FuncTab[cc][0] + \"(\" + args.join(\",\") + \")\");\n\t\t\t\t\t}\n\t\t\t\t\telse if(cc <= 0x07) return console.error(\"WK1 invalid opcode \" + cc.toString(16));\n\t\t\t\t\telse if(cc <= 0x18) return console.error(\"WK1 unsupported op \" + cc.toString(16));\n\t\t\t\t\telse if(cc <= 0x1E) return console.error(\"WK1 invalid opcode \" + cc.toString(16));\n\t\t\t\t\telse if(cc <= 0x73) return console.error(\"WK1 unsupported function opcode \" + cc.toString(16));\n\t\t\t\t\t// possible future functions ??\n\t\t\t\t\telse return console.error(\"WK1 unrecognized opcode \" + cc.toString(16));\n\t\t\t}\n\t\t}\n\t\tif(out.length == 1) o[1].f = \"\" + out[0];\n\t\telse console.error(\"WK1 bad formula parse |\" + out.join(\"|\") + \"|\");\n\t}\n\n\n\tfunction parse_cell_3(blob/*::, length*/) {\n\t\tvar o = [{c:0,r:0}, {t:'n',v:0}, 0];\n\t\to[0].r = blob.read_shift(2); o[3] = blob[blob.l++]; o[0].c = blob[blob.l++];\n\t\treturn o;\n\t}\n\n\tfunction parse_LABEL_16(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\to[1].t = 's';\n\t\to[1].v = blob.read_shift(length - 4, 'cstr');\n\t\treturn o;\n\t}\n\tfunction write_LABEL_16(R, C, wsidx, s) {\n\t\t/* TODO: encoding */\n\t\tvar o = new_buf(6 + s.length);\n\t\to.write_shift(2, R);\n\t\to.write_shift(1, wsidx);\n\t\to.write_shift(1, C);\n\t\to.write_shift(1, 0x27);\n\t\tfor(var i = 0; i < s.length; ++i) {\n\t\t\tvar cc = s.charCodeAt(i);\n\t\t\to.write_shift(1, cc >= 0x80 ? 0x5F : cc);\n\t\t}\n\t\to.write_shift(1, 0);\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER_18(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\to[1].v = blob.read_shift(2);\n\t\tvar v = o[1].v >> 1;\n\t\tif(o[1].v & 0x1) {\n\t\t\tswitch(v & 0x07) {\n\t\t\t\tcase 0: v = (v >> 3) * 5000; break;\n\t\t\t\tcase 1: v = (v >> 3) * 500; break;\n\t\t\t\tcase 2: v = (v >> 3) / 20; break;\n\t\t\t\tcase 3: v = (v >> 3) / 200; break;\n\t\t\t\tcase 4: v = (v >> 3) / 2000; break;\n\t\t\t\tcase 5: v = (v >> 3) / 20000; break;\n\t\t\t\tcase 6: v = (v >> 3) / 16; break;\n\t\t\t\tcase 7: v = (v >> 3) / 64; break;\n\t\t\t}\n\t\t}\n\t\to[1].v = v;\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER_17(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\tvar v1 = blob.read_shift(4);\n\t\tvar v2 = blob.read_shift(4);\n\t\tvar e = blob.read_shift(2);\n\t\tif(e == 0xFFFF) {\n\t\t\tif(v1 === 0 && v2 === 0xC0000000) { o[1].t = \"e\"; o[1].v = 0x0F; } // ERR -> #VALUE!\n\t\t\telse if(v1 === 0 && v2 === 0xD0000000) { o[1].t = \"e\"; o[1].v = 0x2A; } // NA -> #N/A\n\t\t\telse o[1].v = 0;\n\t\t\treturn o;\n\t\t}\n\t\tvar s = e & 0x8000; e = (e&0x7FFF) - 16446;\n\t\to[1].v = (1 - s*2) * (v2 * Math.pow(2, e+32) + v1 * Math.pow(2, e));\n\t\treturn o;\n\t}\n\tfunction write_NUMBER_17(R, C, wsidx, v) {\n\t\tvar o = new_buf(14);\n\t\to.write_shift(2, R);\n\t\to.write_shift(1, wsidx);\n\t\to.write_shift(1, C);\n\t\tif(v == 0) {\n\t\t\to.write_shift(4, 0);\n\t\t\to.write_shift(4, 0);\n\t\t\to.write_shift(2, 0xFFFF);\n\t\t\treturn o;\n\t\t}\n\t\tvar s = 0, e = 0, v1 = 0, v2 = 0;\n\t\tif(v < 0) { s = 1; v = -v; }\n\t\te = Math.log2(v) | 0;\n\t\tv /= Math.pow(2, e-31);\n\t\tv2 = (v)>>>0;\n\t\tif((v2&0x80000000) == 0) { v/=2; ++e; v2 = v >>> 0; }\n\t\tv -= v2;\n\t\tv2 |= 0x80000000;\n\t\tv2 >>>= 0;\n\t\tv *= Math.pow(2, 32);\n\t\tv1 = v>>>0;\n\t\to.write_shift(4, v1);\n\t\to.write_shift(4, v2);\n\t\te += 0x3FFF + (s ? 0x8000 : 0);\n\t\to.write_shift(2, e);\n\t\treturn o;\n\t}\n\n\tfunction parse_FORMULA_19(blob, length) {\n\t\tvar o = parse_NUMBER_17(blob, 14);\n\t\tblob.l += length - 14; /* TODO: WK3 formula */\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER_25(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\tvar v1 = blob.read_shift(4);\n\t\to[1].v = v1 >> 6;\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER_27(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\tvar v1 = blob.read_shift(8,'f');\n\t\to[1].v = v1;\n\t\treturn o;\n\t}\n\n\tfunction parse_FORMULA_28(blob, length) {\n\t\tvar o = parse_NUMBER_27(blob, 14);\n\t\tblob.l += length - 10; /* TODO: formula */\n\t\treturn o;\n\t}\n\n\tfunction parse_SHEETNAMECS(blob, length) {\n\t\treturn blob[blob.l + length - 1] == 0 ? blob.read_shift(length, 'cstr') : \"\";\n\t}\n\n\tfunction parse_SHEETNAMELP(blob, length) {\n\t\tvar len = blob[blob.l++];\n\t\tif(len > length - 1) len = length - 1;\n\t\tvar o = \"\"; while(o.length < len) o += String.fromCharCode(blob[blob.l++]);\n\t\treturn o;\n\t}\n\n\tfunction parse_SHEETINFOQP(blob, length, opts) {\n\t\tif(!opts.qpro || length < 21) return;\n\t\tvar id = blob.read_shift(1);\n\t\tblob.l += 17;\n\t\tblob.l += 1; //var len = blob.read_shift(1);\n\t\tblob.l += 2;\n\t\tvar nm = blob.read_shift(length - 21, 'cstr');\n\t\treturn [id, nm];\n\t}\n\n\tfunction parse_XFORMAT(blob, length) {\n\t\tvar o = {}, tgt = blob.l + length;\n\t\twhile(blob.l < tgt) {\n\t\t\tvar dt = blob.read_shift(2);\n\t\t\tif(dt == 0x36b0) {\n\t\t\t\to[dt] = [0, \"\"];\n\t\t\t\to[dt][0] = blob.read_shift(2);\n\t\t\t\twhile(blob[blob.l]) { o[dt][1] += String.fromCharCode(blob[blob.l]); blob.l++; } blob.l++;\n\t\t\t}\n\t\t\t// TODO: 0x3a99 ??\n\t\t}\n\t\treturn o;\n\t}\n\tfunction write_XFORMAT_SHEETNAME(name, wsidx) {\n\t\tvar out = new_buf(5 + name.length);\n\t\tout.write_shift(2, 0x36b0);\n\t\tout.write_shift(2, wsidx);\n\t\tfor(var i = 0; i < name.length; ++i) {\n\t\t\tvar cc = name.charCodeAt(i);\n\t\t\tout[out.l++] = cc > 0x7F ? 0x5F : cc;\n\t\t}\n\t\tout[out.l++] = 0;\n\t\treturn out;\n\t}\n\n\tvar WK1Enum = {\n\t\t/*::[*/0x0000/*::]*/: { n:\"BOF\", f:parseuint16 },\n\t\t/*::[*/0x0001/*::]*/: { n:\"EOF\" },\n\t\t/*::[*/0x0002/*::]*/: { n:\"CALCMODE\" },\n\t\t/*::[*/0x0003/*::]*/: { n:\"CALCORDER\" },\n\t\t/*::[*/0x0004/*::]*/: { n:\"SPLIT\" },\n\t\t/*::[*/0x0005/*::]*/: { n:\"SYNC\" },\n\t\t/*::[*/0x0006/*::]*/: { n:\"RANGE\", f:parse_RANGE },\n\t\t/*::[*/0x0007/*::]*/: { n:\"WINDOW1\" },\n\t\t/*::[*/0x0008/*::]*/: { n:\"COLW1\" },\n\t\t/*::[*/0x0009/*::]*/: { n:\"WINTWO\" },\n\t\t/*::[*/0x000A/*::]*/: { n:\"COLW2\" },\n\t\t/*::[*/0x000B/*::]*/: { n:\"NAME\" },\n\t\t/*::[*/0x000C/*::]*/: { n:\"BLANK\" },\n\t\t/*::[*/0x000D/*::]*/: { n:\"INTEGER\", f:parse_INTEGER },\n\t\t/*::[*/0x000E/*::]*/: { n:\"NUMBER\", f:parse_NUMBER },\n\t\t/*::[*/0x000F/*::]*/: { n:\"LABEL\", f:parse_LABEL },\n\t\t/*::[*/0x0010/*::]*/: { n:\"FORMULA\", f:parse_FORMULA },\n\t\t/*::[*/0x0018/*::]*/: { n:\"TABLE\" },\n\t\t/*::[*/0x0019/*::]*/: { n:\"ORANGE\" },\n\t\t/*::[*/0x001A/*::]*/: { n:\"PRANGE\" },\n\t\t/*::[*/0x001B/*::]*/: { n:\"SRANGE\" },\n\t\t/*::[*/0x001C/*::]*/: { n:\"FRANGE\" },\n\t\t/*::[*/0x001D/*::]*/: { n:\"KRANGE1\" },\n\t\t/*::[*/0x0020/*::]*/: { n:\"HRANGE\" },\n\t\t/*::[*/0x0023/*::]*/: { n:\"KRANGE2\" },\n\t\t/*::[*/0x0024/*::]*/: { n:\"PROTEC\" },\n\t\t/*::[*/0x0025/*::]*/: { n:\"FOOTER\" },\n\t\t/*::[*/0x0026/*::]*/: { n:\"HEADER\" },\n\t\t/*::[*/0x0027/*::]*/: { n:\"SETUP\" },\n\t\t/*::[*/0x0028/*::]*/: { n:\"MARGINS\" },\n\t\t/*::[*/0x0029/*::]*/: { n:\"LABELFMT\" },\n\t\t/*::[*/0x002A/*::]*/: { n:\"TITLES\" },\n\t\t/*::[*/0x002B/*::]*/: { n:\"SHEETJS\" },\n\t\t/*::[*/0x002D/*::]*/: { n:\"GRAPH\" },\n\t\t/*::[*/0x002E/*::]*/: { n:\"NGRAPH\" },\n\t\t/*::[*/0x002F/*::]*/: { n:\"CALCCOUNT\" },\n\t\t/*::[*/0x0030/*::]*/: { n:\"UNFORMATTED\" },\n\t\t/*::[*/0x0031/*::]*/: { n:\"CURSORW12\" },\n\t\t/*::[*/0x0032/*::]*/: { n:\"WINDOW\" },\n\t\t/*::[*/0x0033/*::]*/: { n:\"STRING\", f:parse_LABEL },\n\t\t/*::[*/0x0037/*::]*/: { n:\"PASSWORD\" },\n\t\t/*::[*/0x0038/*::]*/: { n:\"LOCKED\" },\n\t\t/*::[*/0x003C/*::]*/: { n:\"QUERY\" },\n\t\t/*::[*/0x003D/*::]*/: { n:\"QUERYNAME\" },\n\t\t/*::[*/0x003E/*::]*/: { n:\"PRINT\" },\n\t\t/*::[*/0x003F/*::]*/: { n:\"PRINTNAME\" },\n\t\t/*::[*/0x0040/*::]*/: { n:\"GRAPH2\" },\n\t\t/*::[*/0x0041/*::]*/: { n:\"GRAPHNAME\" },\n\t\t/*::[*/0x0042/*::]*/: { n:\"ZOOM\" },\n\t\t/*::[*/0x0043/*::]*/: { n:\"SYMSPLIT\" },\n\t\t/*::[*/0x0044/*::]*/: { n:\"NSROWS\" },\n\t\t/*::[*/0x0045/*::]*/: { n:\"NSCOLS\" },\n\t\t/*::[*/0x0046/*::]*/: { n:\"RULER\" },\n\t\t/*::[*/0x0047/*::]*/: { n:\"NNAME\" },\n\t\t/*::[*/0x0048/*::]*/: { n:\"ACOMM\" },\n\t\t/*::[*/0x0049/*::]*/: { n:\"AMACRO\" },\n\t\t/*::[*/0x004A/*::]*/: { n:\"PARSE\" },\n\t\t/*::[*/0x0066/*::]*/: { n:\"PRANGES??\" },\n\t\t/*::[*/0x0067/*::]*/: { n:\"RRANGES??\" },\n\t\t/*::[*/0x0068/*::]*/: { n:\"FNAME??\" },\n\t\t/*::[*/0x0069/*::]*/: { n:\"MRANGES??\" },\n\t\t/*::[*/0x00CC/*::]*/: { n:\"SHEETNAMECS\", f:parse_SHEETNAMECS },\n\t\t/*::[*/0x00DE/*::]*/: { n:\"SHEETNAMELP\", f:parse_SHEETNAMELP },\n\t\t/*::[*/0xFFFF/*::]*/: { n:\"\" }\n\t};\n\n\tvar WK3Enum = {\n\t\t/*::[*/0x0000/*::]*/: { n:\"BOF\" },\n\t\t/*::[*/0x0001/*::]*/: { n:\"EOF\" },\n\t\t/*::[*/0x0002/*::]*/: { n:\"PASSWORD\" },\n\t\t/*::[*/0x0003/*::]*/: { n:\"CALCSET\" },\n\t\t/*::[*/0x0004/*::]*/: { n:\"WINDOWSET\" },\n\t\t/*::[*/0x0005/*::]*/: { n:\"SHEETCELLPTR\" },\n\t\t/*::[*/0x0006/*::]*/: { n:\"SHEETLAYOUT\" },\n\t\t/*::[*/0x0007/*::]*/: { n:\"COLUMNWIDTH\" },\n\t\t/*::[*/0x0008/*::]*/: { n:\"HIDDENCOLUMN\" },\n\t\t/*::[*/0x0009/*::]*/: { n:\"USERRANGE\" },\n\t\t/*::[*/0x000A/*::]*/: { n:\"SYSTEMRANGE\" },\n\t\t/*::[*/0x000B/*::]*/: { n:\"ZEROFORCE\" },\n\t\t/*::[*/0x000C/*::]*/: { n:\"SORTKEYDIR\" },\n\t\t/*::[*/0x000D/*::]*/: { n:\"FILESEAL\" },\n\t\t/*::[*/0x000E/*::]*/: { n:\"DATAFILLNUMS\" },\n\t\t/*::[*/0x000F/*::]*/: { n:\"PRINTMAIN\" },\n\t\t/*::[*/0x0010/*::]*/: { n:\"PRINTSTRING\" },\n\t\t/*::[*/0x0011/*::]*/: { n:\"GRAPHMAIN\" },\n\t\t/*::[*/0x0012/*::]*/: { n:\"GRAPHSTRING\" },\n\t\t/*::[*/0x0013/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0014/*::]*/: { n:\"ERRCELL\" },\n\t\t/*::[*/0x0015/*::]*/: { n:\"NACELL\" },\n\t\t/*::[*/0x0016/*::]*/: { n:\"LABEL16\", f:parse_LABEL_16},\n\t\t/*::[*/0x0017/*::]*/: { n:\"NUMBER17\", f:parse_NUMBER_17 },\n\t\t/*::[*/0x0018/*::]*/: { n:\"NUMBER18\", f:parse_NUMBER_18 },\n\t\t/*::[*/0x0019/*::]*/: { n:\"FORMULA19\", f:parse_FORMULA_19},\n\t\t/*::[*/0x001A/*::]*/: { n:\"FORMULA1A\" },\n\t\t/*::[*/0x001B/*::]*/: { n:\"XFORMAT\", f:parse_XFORMAT },\n\t\t/*::[*/0x001C/*::]*/: { n:\"DTLABELMISC\" },\n\t\t/*::[*/0x001D/*::]*/: { n:\"DTLABELCELL\" },\n\t\t/*::[*/0x001E/*::]*/: { n:\"GRAPHWINDOW\" },\n\t\t/*::[*/0x001F/*::]*/: { n:\"CPA\" },\n\t\t/*::[*/0x0020/*::]*/: { n:\"LPLAUTO\" },\n\t\t/*::[*/0x0021/*::]*/: { n:\"QUERY\" },\n\t\t/*::[*/0x0022/*::]*/: { n:\"HIDDENSHEET\" },\n\t\t/*::[*/0x0023/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0025/*::]*/: { n:\"NUMBER25\", f:parse_NUMBER_25 },\n\t\t/*::[*/0x0026/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0027/*::]*/: { n:\"NUMBER27\", f:parse_NUMBER_27 },\n\t\t/*::[*/0x0028/*::]*/: { n:\"FORMULA28\", f:parse_FORMULA_28 },\n\t\t/*::[*/0x008E/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0093/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0096/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0097/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0098/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0099/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x009A/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x009B/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x009C/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00A3/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00AE/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00AF/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00B0/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00B1/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00B8/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00B9/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00BA/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00BB/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00BC/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00C3/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00C9/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00CC/*::]*/: { n:\"SHEETNAMECS\", f:parse_SHEETNAMECS },\n\t\t/*::[*/0x00CD/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00CE/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00CF/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00D0/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0100/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0103/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0104/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0105/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0106/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0107/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0109/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010A/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010B/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010C/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010E/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010F/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0180/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0185/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0186/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0189/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x018C/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0200/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0202/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0201/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0204/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0205/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0280/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0281/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0282/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0283/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0284/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0285/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0286/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0287/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0288/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0292/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0293/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0294/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0295/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0296/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0299/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x029A/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0300/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0304/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0601/*::]*/: { n:\"SHEETINFOQP\", f:parse_SHEETINFOQP },\n\t\t/*::[*/0x0640/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0642/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0701/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0702/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0703/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0704/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0780/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0800/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0801/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0804/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0A80/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x2AF6/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x3231/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x6E49/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x6F44/*::]*/: { n:\"??\" },\n\t\t/*::[*/0xFFFF/*::]*/: { n:\"\" }\n\t};\n\treturn {\n\t\tsheet_to_wk1: sheet_to_wk1,\n\t\tbook_to_wk3: book_to_wk3,\n\t\tto_workbook: lotus_to_workbook\n\t};\n})();\n/* 18.4.7 rPr CT_RPrElt */\nfunction parse_rpr(rpr) {\n\tvar font = {}, m = rpr.match(tagregex), i = 0;\n\tvar pass = false;\n\tif(m) for(;i!=m.length; ++i) {\n\t\tvar y = parsexmltag(m[i]);\n\t\tswitch(y[0].replace(/\\w*:/g,\"\")) {\n\t\t\t/* 18.8.12 condense CT_BooleanProperty */\n\t\t\t/* ** not required . */\n\t\t\tcase '<condense': break;\n\t\t\t/* 18.8.17 extend CT_BooleanProperty */\n\t\t\t/* ** not required . */\n\t\t\tcase '<extend': break;\n\t\t\t/* 18.8.36 shadow CT_BooleanProperty */\n\t\t\t/* ** not required . */\n\t\t\tcase '<shadow':\n\t\t\t\tif(!y.val) break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<shadow>':\n\t\t\tcase '<shadow/>': font.shadow = 1; break;\n\t\t\tcase '</shadow>': break;\n\n\t\t\t/* 18.4.1 charset CT_IntProperty TODO */\n\t\t\tcase '<charset':\n\t\t\t\tif(y.val == '1') break;\n\t\t\t\tfont.cp = CS2CP[parseInt(y.val, 10)];\n\t\t\t\tbreak;\n\n\t\t\t/* 18.4.2 outline CT_BooleanProperty TODO */\n\t\t\tcase '<outline':\n\t\t\t\tif(!y.val) break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<outline>':\n\t\t\tcase '<outline/>': font.outline = 1; break;\n\t\t\tcase '</outline>': break;\n\n\t\t\t/* 18.4.5 rFont CT_FontName */\n\t\t\tcase '<rFont': font.name = y.val; break;\n\n\t\t\t/* 18.4.11 sz CT_FontSize */\n\t\t\tcase '<sz': font.sz = y.val; break;\n\n\t\t\t/* 18.4.10 strike CT_BooleanProperty */\n\t\t\tcase '<strike':\n\t\t\t\tif(!y.val) break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<strike>':\n\t\t\tcase '<strike/>': font.strike = 1; break;\n\t\t\tcase '</strike>': break;\n\n\t\t\t/* 18.4.13 u CT_UnderlineProperty */\n\t\t\tcase '<u':\n\t\t\t\tif(!y.val) break;\n\t\t\t\tswitch(y.val) {\n\t\t\t\t\tcase 'double': font.uval = \"double\"; break;\n\t\t\t\t\tcase 'singleAccounting': font.uval = \"single-accounting\"; break;\n\t\t\t\t\tcase 'doubleAccounting': font.uval = \"double-accounting\"; break;\n\t\t\t\t}\n\t\t\t\t/* falls through */\n\t\t\tcase '<u>':\n\t\t\tcase '<u/>': font.u = 1; break;\n\t\t\tcase '</u>': break;\n\n\t\t\t/* 18.8.2 b */\n\t\t\tcase '<b':\n\t\t\t\tif(y.val == '0') break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<b>':\n\t\t\tcase '<b/>': font.b = 1; break;\n\t\t\tcase '</b>': break;\n\n\t\t\t/* 18.8.26 i */\n\t\t\tcase '<i':\n\t\t\t\tif(y.val == '0') break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<i>':\n\t\t\tcase '<i/>': font.i = 1; break;\n\t\t\tcase '</i>': break;\n\n\t\t\t/* 18.3.1.15 color CT_Color TODO: tint, theme, auto, indexed */\n\t\t\tcase '<color':\n\t\t\t\tif(y.rgb) font.color = y.rgb.slice(2,8);\n\t\t\t\tbreak;\n\t\t\tcase '<color>': case '<color/>': case '</color>': break;\n\n\t\t\t/* 18.8.18 family ST_FontFamily */\n\t\t\tcase '<family': font.family = y.val; break;\n\t\t\tcase '<family>': case '<family/>': case '</family>': break;\n\n\t\t\t/* 18.4.14 vertAlign CT_VerticalAlignFontProperty TODO */\n\t\t\tcase '<vertAlign': font.valign = y.val; break;\n\t\t\tcase '<vertAlign>': case '<vertAlign/>': case '</vertAlign>': break;\n\n\t\t\t/* 18.8.35 scheme CT_FontScheme TODO */\n\t\t\tcase '<scheme': break;\n\t\t\tcase '<scheme>': case '<scheme/>': case '</scheme>': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault:\n\t\t\t\tif(y[0].charCodeAt(1) !== 47 && !pass) throw new Error('Unrecognized rich format ' + y[0]);\n\t\t}\n\t}\n\treturn font;\n}\n\nvar parse_rs = /*#__PURE__*/(function() {\n\tvar tregex = matchtag(\"t\"), rpregex = matchtag(\"rPr\");\n\t/* 18.4.4 r CT_RElt */\n\tfunction parse_r(r) {\n\t\t/* 18.4.12 t ST_Xstring */\n\t\tvar t = r.match(tregex)/*, cp = 65001*/;\n\t\tif(!t) return {t:\"s\", v:\"\"};\n\n\t\tvar o/*:Cell*/ = ({t:'s', v:unescapexml(t[1])}/*:any*/);\n\t\tvar rpr = r.match(rpregex);\n\t\tif(rpr) o.s = parse_rpr(rpr[1]);\n\t\treturn o;\n\t}\n\tvar rregex = /<(?:\\w+:)?r>/g, rend = /<\\/(?:\\w+:)?r>/;\n\treturn function parse_rs(rs) {\n\t\treturn rs.replace(rregex,\"\").split(rend).map(parse_r).filter(function(r) { return r.v; });\n\t};\n})();\n\n\n/* Parse a list of <r> tags */\nvar rs_to_html = /*#__PURE__*/(function parse_rs_factory() {\n\tvar nlregex = /(\\r\\n|\\n)/g;\n\tfunction parse_rpr2(font, intro, outro) {\n\t\tvar style/*:Array<string>*/ = [];\n\n\t\tif(font.u) style.push(\"text-decoration: underline;\");\n\t\tif(font.uval) style.push(\"text-underline-style:\" + font.uval + \";\");\n\t\tif(font.sz) style.push(\"font-size:\" + font.sz + \"pt;\");\n\t\tif(font.outline) style.push(\"text-effect: outline;\");\n\t\tif(font.shadow) style.push(\"text-shadow: auto;\");\n\t\tintro.push('<span style=\"' + style.join(\"\") + '\">');\n\n\t\tif(font.b) { intro.push(\"<b>\"); outro.push(\"</b>\"); }\n\t\tif(font.i) { intro.push(\"<i>\"); outro.push(\"</i>\"); }\n\t\tif(font.strike) { intro.push(\"<s>\"); outro.push(\"</s>\"); }\n\n\t\tvar align = font.valign || \"\";\n\t\tif(align == \"superscript\" || align == \"super\") align = \"sup\";\n\t\telse if(align == \"subscript\") align = \"sub\";\n\t\tif(align != \"\") { intro.push(\"<\" + align + \">\"); outro.push(\"</\" + align + \">\"); }\n\n\t\toutro.push(\"</span>\");\n\t\treturn font;\n\t}\n\n\t/* 18.4.4 r CT_RElt */\n\tfunction r_to_html(r) {\n\t\tvar terms/*:[Array<string>, string, Array<string>]*/ = [[],r.v,[]];\n\t\tif(!r.v) return \"\";\n\n\t\tif(r.s) parse_rpr2(r.s, terms[0], terms[2]);\n\n\t\treturn terms[0].join(\"\") + terms[1].replace(nlregex,'<br/>') + terms[2].join(\"\");\n\t}\n\n\treturn function parse_rs(rs) {\n\t\treturn rs.map(r_to_html).join(\"\");\n\t};\n})();\n\n/* 18.4.8 si CT_Rst */\nvar sitregex = /<(?:\\w+:)?t[^>]*>([^<]*)<\\/(?:\\w+:)?t>/g, sirregex = /<(?:\\w+:)?r>/;\nvar sirphregex = /<(?:\\w+:)?rPh.*?>([\\s\\S]*?)<\\/(?:\\w+:)?rPh>/g;\nfunction parse_si(x, opts) {\n\tvar html = opts ? opts.cellHTML : true;\n\tvar z = {};\n\tif(!x) return { t: \"\" };\n\t//var y;\n\t/* 18.4.12 t ST_Xstring (Plaintext String) */\n\t// TODO: is whitespace actually valid here?\n\tif(x.match(/^\\s*<(?:\\w+:)?t[^>]*>/)) {\n\t\tz.t = unescapexml(utf8read(x.slice(x.indexOf(\">\")+1).split(/<\\/(?:\\w+:)?t>/)[0]||\"\"));\n\t\tz.r = utf8read(x);\n\t\tif(html) z.h = escapehtml(z.t);\n\t}\n\t/* 18.4.4 r CT_RElt (Rich Text Run) */\n\telse if((/*y = */x.match(sirregex))) {\n\t\tz.r = utf8read(x);\n\t\tz.t = unescapexml(utf8read((x.replace(sirphregex, '').match(sitregex)||[]).join(\"\").replace(tagregex,\"\")));\n\t\tif(html) z.h = rs_to_html(parse_rs(z.r));\n\t}\n\t/* 18.4.3 phoneticPr CT_PhoneticPr (TODO: needed for Asian support) */\n\t/* 18.4.6 rPh CT_PhoneticRun (TODO: needed for Asian support) */\n\treturn z;\n}\n\n/* 18.4 Shared String Table */\nvar sstr0 = /<(?:\\w+:)?sst([^>]*)>([\\s\\S]*)<\\/(?:\\w+:)?sst>/;\nvar sstr1 = /<(?:\\w+:)?(?:si|sstItem)>/g;\nvar sstr2 = /<\\/(?:\\w+:)?(?:si|sstItem)>/;\nfunction parse_sst_xml(data/*:string*/, opts)/*:SST*/ {\n\tvar s/*:SST*/ = ([]/*:any*/), ss = \"\";\n\tif(!data) return s;\n\t/* 18.4.9 sst CT_Sst */\n\tvar sst = data.match(sstr0);\n\tif(sst) {\n\t\tss = sst[2].replace(sstr1,\"\").split(sstr2);\n\t\tfor(var i = 0; i != ss.length; ++i) {\n\t\t\tvar o = parse_si(ss[i].trim(), opts);\n\t\t\tif(o != null) s[s.length] = o;\n\t\t}\n\t\tsst = parsexmltag(sst[1]); s.Count = sst.count; s.Unique = sst.uniqueCount;\n\t}\n\treturn s;\n}\n\nvar straywsregex = /^\\s|\\s$|[\\t\\n\\r]/;\nfunction write_sst_xml(sst/*:SST*/, opts)/*:string*/ {\n\tif(!opts.bookSST) return \"\";\n\tvar o = [XML_HEADER];\n\to[o.length] = (writextag('sst', null, {\n\t\txmlns: XMLNS_main[0],\n\t\tcount: sst.Count,\n\t\tuniqueCount: sst.Unique\n\t}));\n\tfor(var i = 0; i != sst.length; ++i) { if(sst[i] == null) continue;\n\t\tvar s/*:XLString*/ = sst[i];\n\t\tvar sitag = \"<si>\";\n\t\tif(s.r) sitag += s.r;\n\t\telse {\n\t\t\tsitag += \"<t\";\n\t\t\tif(!s.t) s.t = \"\";\n\t\t\tif(s.t.match(straywsregex)) sitag += ' xml:space=\"preserve\"';\n\t\t\tsitag += \">\" + escapexml(s.t) + \"</t>\";\n\t\t}\n\t\tsitag += \"</si>\";\n\t\to[o.length] = (sitag);\n\t}\n\tif(o.length>2){ o[o.length] = ('</sst>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.221 BrtBeginSst */\nfunction parse_BrtBeginSst(data) {\n\treturn [data.read_shift(4), data.read_shift(4)];\n}\n\n/* [MS-XLSB] 2.1.7.45 Shared Strings */\nfunction parse_sst_bin(data, opts)/*:SST*/ {\n\tvar s/*:SST*/ = ([]/*:any*/);\n\tvar pass = false;\n\trecordhopper(data, function hopper_sst(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x009F: /* BrtBeginSst */\n\t\t\t\ts.Count = val[0]; s.Unique = val[1]; break;\n\t\t\tcase 0x0013: /* BrtSSTItem */\n\t\t\t\ts.push(val); break;\n\t\t\tcase 0x00A0: /* BrtEndSst */\n\t\t\t\treturn true;\n\n\t\t\tcase 0x0023: /* BrtFRTBegin */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* BrtFRTEnd */\n\t\t\t\tpass = false; break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){}\n\t\t\t\tif(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t});\n\treturn s;\n}\n\nfunction write_BrtBeginSst(sst, o) {\n\tif(!o) o = new_buf(8);\n\to.write_shift(4, sst.Count);\n\to.write_shift(4, sst.Unique);\n\treturn o;\n}\n\nvar write_BrtSSTItem = write_RichStr;\n\nfunction write_sst_bin(sst/*::, opts*/) {\n\tvar ba = buf_array();\n\twrite_record(ba, 0x009F /* BrtBeginSst */, write_BrtBeginSst(sst));\n\tfor(var i = 0; i < sst.length; ++i) write_record(ba, 0x0013 /* BrtSSTItem */, write_BrtSSTItem(sst[i]));\n\t/* FRTSST */\n\twrite_record(ba, 0x00A0 /* BrtEndSst */);\n\treturn ba.end();\n}\nfunction _JS2ANSI(str/*:string*/)/*:Array<number>*/ {\n\tif(typeof $cptable !== 'undefined') return $cptable.utils.encode(current_ansi, str);\n\tvar o/*:Array<number>*/ = [], oo = str.split(\"\");\n\tfor(var i = 0; i < oo.length; ++i) o[i] = oo[i].charCodeAt(0);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.4 Version */\nfunction parse_CRYPTOVersion(blob, length/*:?number*/) {\n\tvar o/*:any*/ = {};\n\to.Major = blob.read_shift(2);\n\to.Minor = blob.read_shift(2);\n\t/*:: if(length == null) return o; */\n\tif(length >= 4) blob.l += length - 4;\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.5 DataSpaceVersionInfo */\nfunction parse_DataSpaceVersionInfo(blob) {\n\tvar o = {};\n\to.id = blob.read_shift(0, 'lpp4');\n\to.R = parse_CRYPTOVersion(blob, 4);\n\to.U = parse_CRYPTOVersion(blob, 4);\n\to.W = parse_CRYPTOVersion(blob, 4);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.6.1 DataSpaceMapEntry Structure */\nfunction parse_DataSpaceMapEntry(blob) {\n\tvar len = blob.read_shift(4);\n\tvar end = blob.l + len - 4;\n\tvar o = {};\n\tvar cnt = blob.read_shift(4);\n\tvar comps/*:Array<{t:number, v:string}>*/ = [];\n\t/* [MS-OFFCRYPTO] 2.1.6.2 DataSpaceReferenceComponent Structure */\n\twhile(cnt-- > 0) comps.push({ t: blob.read_shift(4), v: blob.read_shift(0, 'lpp4') });\n\to.name = blob.read_shift(0, 'lpp4');\n\to.comps = comps;\n\tif(blob.l != end) throw new Error(\"Bad DataSpaceMapEntry: \" + blob.l + \" != \" + end);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.6 DataSpaceMap */\nfunction parse_DataSpaceMap(blob) {\n\tvar o = [];\n\tblob.l += 4; // must be 0x8\n\tvar cnt = blob.read_shift(4);\n\twhile(cnt-- > 0) o.push(parse_DataSpaceMapEntry(blob));\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.7 DataSpaceDefinition */\nfunction parse_DataSpaceDefinition(blob)/*:Array<string>*/ {\n\tvar o/*:Array<string>*/ = [];\n\tblob.l += 4; // must be 0x8\n\tvar cnt = blob.read_shift(4);\n\twhile(cnt-- > 0) o.push(blob.read_shift(0, 'lpp4'));\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.8 DataSpaceDefinition */\nfunction parse_TransformInfoHeader(blob) {\n\tvar o = {};\n\t/*var len = */blob.read_shift(4);\n\tblob.l += 4; // must be 0x1\n\to.id = blob.read_shift(0, 'lpp4');\n\to.name = blob.read_shift(0, 'lpp4');\n\to.R = parse_CRYPTOVersion(blob, 4);\n\to.U = parse_CRYPTOVersion(blob, 4);\n\to.W = parse_CRYPTOVersion(blob, 4);\n\treturn o;\n}\n\nfunction parse_Primary(blob) {\n\t/* [MS-OFFCRYPTO] 2.2.6 IRMDSTransformInfo */\n\tvar hdr = parse_TransformInfoHeader(blob);\n\t/* [MS-OFFCRYPTO] 2.1.9 EncryptionTransformInfo */\n\thdr.ename = blob.read_shift(0, '8lpp4');\n\thdr.blksz = blob.read_shift(4);\n\thdr.cmode = blob.read_shift(4);\n\tif(blob.read_shift(4) != 0x04) throw new Error(\"Bad !Primary record\");\n\treturn hdr;\n}\n\n/* [MS-OFFCRYPTO] 2.3.2 Encryption Header */\nfunction parse_EncryptionHeader(blob, length/*:number*/) {\n\tvar tgt = blob.l + length;\n\tvar o = {};\n\to.Flags = (blob.read_shift(4) & 0x3F);\n\tblob.l += 4;\n\to.AlgID = blob.read_shift(4);\n\tvar valid = false;\n\tswitch(o.AlgID) {\n\t\tcase 0x660E: case 0x660F: case 0x6610: valid = (o.Flags == 0x24); break;\n\t\tcase 0x6801: valid = (o.Flags == 0x04); break;\n\t\tcase 0: valid = (o.Flags == 0x10 || o.Flags == 0x04 || o.Flags == 0x24); break;\n\t\tdefault: throw 'Unrecognized encryption algorithm: ' + o.AlgID;\n\t}\n\tif(!valid) throw new Error(\"Encryption Flags/AlgID mismatch\");\n\to.AlgIDHash = blob.read_shift(4);\n\to.KeySize = blob.read_shift(4);\n\to.ProviderType = blob.read_shift(4);\n\tblob.l += 8;\n\to.CSPName = blob.read_shift((tgt-blob.l)>>1, 'utf16le');\n\tblob.l = tgt;\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.3 Encryption Verifier */\nfunction parse_EncryptionVerifier(blob, length/*:number*/) {\n\tvar o = {}, tgt = blob.l + length;\n\tblob.l += 4; // SaltSize must be 0x10\n\to.Salt = blob.slice(blob.l, blob.l+16); blob.l += 16;\n\to.Verifier = blob.slice(blob.l, blob.l+16); blob.l += 16;\n\t/*var sz = */blob.read_shift(4);\n\to.VerifierHash = blob.slice(blob.l, tgt); blob.l = tgt;\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.4.* EncryptionInfo Stream */\nfunction parse_EncryptionInfo(blob) {\n\tvar vers = parse_CRYPTOVersion(blob);\n\tswitch(vers.Minor) {\n\t\tcase 0x02: return [vers.Minor, parse_EncInfoStd(blob, vers)];\n\t\tcase 0x03: return [vers.Minor, parse_EncInfoExt(blob, vers)];\n\t\tcase 0x04: return [vers.Minor, parse_EncInfoAgl(blob, vers)];\n\t}\n\tthrow new Error(\"ECMA-376 Encrypted file unrecognized Version: \" + vers.Minor);\n}\n\n/* [MS-OFFCRYPTO] 2.3.4.5 EncryptionInfo Stream (Standard Encryption) */\nfunction parse_EncInfoStd(blob/*::, vers*/) {\n\tvar flags = blob.read_shift(4);\n\tif((flags & 0x3F) != 0x24) throw new Error(\"EncryptionInfo mismatch\");\n\tvar sz = blob.read_shift(4);\n\t//var tgt = blob.l + sz;\n\tvar hdr = parse_EncryptionHeader(blob, sz);\n\tvar verifier = parse_EncryptionVerifier(blob, blob.length - blob.l);\n\treturn { t:\"Std\", h:hdr, v:verifier };\n}\n/* [MS-OFFCRYPTO] 2.3.4.6 EncryptionInfo Stream (Extensible Encryption) */\nfunction parse_EncInfoExt(/*::blob, vers*/) { throw new Error(\"File is password-protected: ECMA-376 Extensible\"); }\n/* [MS-OFFCRYPTO] 2.3.4.10 EncryptionInfo Stream (Agile Encryption) */\nfunction parse_EncInfoAgl(blob/*::, vers*/) {\n\tvar KeyData = [\"saltSize\",\"blockSize\",\"keyBits\",\"hashSize\",\"cipherAlgorithm\",\"cipherChaining\",\"hashAlgorithm\",\"saltValue\"];\n\tblob.l+=4;\n\tvar xml = blob.read_shift(blob.length - blob.l, 'utf8');\n\tvar o = {};\n\txml.replace(tagregex, function xml_agile(x) {\n\t\tvar y/*:any*/ = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<?xml': break;\n\t\t\tcase '<encryption': case '</encryption>': break;\n\t\t\tcase '<keyData': KeyData.forEach(function(k) { o[k] = y[k]; }); break;\n\t\t\tcase '<dataIntegrity': o.encryptedHmacKey = y.encryptedHmacKey; o.encryptedHmacValue = y.encryptedHmacValue; break;\n\t\t\tcase '<keyEncryptors>': case '<keyEncryptors': o.encs = []; break;\n\t\t\tcase '</keyEncryptors>': break;\n\n\t\t\tcase '<keyEncryptor': o.uri = y.uri; break;\n\t\t\tcase '</keyEncryptor>': break;\n\t\t\tcase '<encryptedKey': o.encs.push(y); break;\n\t\t\tdefault: throw y[0];\n\t\t}\n\t});\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.5.1 RC4 CryptoAPI Encryption Header */\nfunction parse_RC4CryptoHeader(blob, length/*:number*/) {\n\tvar o = {};\n\tvar vers = o.EncryptionVersionInfo = parse_CRYPTOVersion(blob, 4); length -= 4;\n\tif(vers.Minor != 2) throw new Error('unrecognized minor version code: ' + vers.Minor);\n\tif(vers.Major > 4 || vers.Major < 2) throw new Error('unrecognized major version code: ' + vers.Major);\n\to.Flags = blob.read_shift(4); length -= 4;\n\tvar sz = blob.read_shift(4); length -= 4;\n\to.EncryptionHeader = parse_EncryptionHeader(blob, sz); length -= sz;\n\to.EncryptionVerifier = parse_EncryptionVerifier(blob, length);\n\treturn o;\n}\n/* [MS-OFFCRYPTO] 2.3.6.1 RC4 Encryption Header */\nfunction parse_RC4Header(blob/*::, length*/) {\n\tvar o = {};\n\tvar vers = o.EncryptionVersionInfo = parse_CRYPTOVersion(blob, 4);\n\tif(vers.Major != 1 || vers.Minor != 1) throw 'unrecognized version code ' + vers.Major + ' : ' + vers.Minor;\n\to.Salt = blob.read_shift(16);\n\to.EncryptedVerifier = blob.read_shift(16);\n\to.EncryptedVerifierHash = blob.read_shift(16);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.7.1 Binary Document Password Verifier Derivation */\nfunction crypto_CreatePasswordVerifier_Method1(Password/*:string*/) {\n\tvar Verifier = 0x0000, PasswordArray;\n\tvar PasswordDecoded = _JS2ANSI(Password);\n\tvar len = PasswordDecoded.length + 1, i, PasswordByte;\n\tvar Intermediate1, Intermediate2, Intermediate3;\n\tPasswordArray = new_raw_buf(len);\n\tPasswordArray[0] = PasswordDecoded.length;\n\tfor(i = 1; i != len; ++i) PasswordArray[i] = PasswordDecoded[i-1];\n\tfor(i = len-1; i >= 0; --i) {\n\t\tPasswordByte = PasswordArray[i];\n\t\tIntermediate1 = ((Verifier & 0x4000) === 0x0000) ? 0 : 1;\n\t\tIntermediate2 = (Verifier << 1) & 0x7FFF;\n\t\tIntermediate3 = Intermediate1 | Intermediate2;\n\t\tVerifier = Intermediate3 ^ PasswordByte;\n\t}\n\treturn Verifier ^ 0xCE4B;\n}\n\n/* [MS-OFFCRYPTO] 2.3.7.2 Binary Document XOR Array Initialization */\nvar crypto_CreateXorArray_Method1 = /*#__PURE__*/(function() {\n\tvar PadArray = [0xBB, 0xFF, 0xFF, 0xBA, 0xFF, 0xFF, 0xB9, 0x80, 0x00, 0xBE, 0x0F, 0x00, 0xBF, 0x0F, 0x00];\n\tvar InitialCode = [0xE1F0, 0x1D0F, 0xCC9C, 0x84C0, 0x110C, 0x0E10, 0xF1CE, 0x313E, 0x1872, 0xE139, 0xD40F, 0x84F9, 0x280C, 0xA96A, 0x4EC3];\n\tvar XorMatrix = [0xAEFC, 0x4DD9, 0x9BB2, 0x2745, 0x4E8A, 0x9D14, 0x2A09, 0x7B61, 0xF6C2, 0xFDA5, 0xEB6B, 0xC6F7, 0x9DCF, 0x2BBF, 0x4563, 0x8AC6, 0x05AD, 0x0B5A, 0x16B4, 0x2D68, 0x5AD0, 0x0375, 0x06EA, 0x0DD4, 0x1BA8, 0x3750, 0x6EA0, 0xDD40, 0xD849, 0xA0B3, 0x5147, 0xA28E, 0x553D, 0xAA7A, 0x44D5, 0x6F45, 0xDE8A, 0xAD35, 0x4A4B, 0x9496, 0x390D, 0x721A, 0xEB23, 0xC667, 0x9CEF, 0x29FF, 0x53FE, 0xA7FC, 0x5FD9, 0x47D3, 0x8FA6, 0x0F6D, 0x1EDA, 0x3DB4, 0x7B68, 0xF6D0, 0xB861, 0x60E3, 0xC1C6, 0x93AD, 0x377B, 0x6EF6, 0xDDEC, 0x45A0, 0x8B40, 0x06A1, 0x0D42, 0x1A84, 0x3508, 0x6A10, 0xAA51, 0x4483, 0x8906, 0x022D, 0x045A, 0x08B4, 0x1168, 0x76B4, 0xED68, 0xCAF1, 0x85C3, 0x1BA7, 0x374E, 0x6E9C, 0x3730, 0x6E60, 0xDCC0, 0xA9A1, 0x4363, 0x86C6, 0x1DAD, 0x3331, 0x6662, 0xCCC4, 0x89A9, 0x0373, 0x06E6, 0x0DCC, 0x1021, 0x2042, 0x4084, 0x8108, 0x1231, 0x2462, 0x48C4];\n\tvar Ror = function(Byte) { return ((Byte/2) | (Byte*128)) & 0xFF; };\n\tvar XorRor = function(byte1, byte2) { return Ror(byte1 ^ byte2); };\n\tvar CreateXorKey_Method1 = function(Password) {\n\t\tvar XorKey = InitialCode[Password.length - 1];\n\t\tvar CurrentElement = 0x68;\n\t\tfor(var i = Password.length-1; i >= 0; --i) {\n\t\t\tvar Char = Password[i];\n\t\t\tfor(var j = 0; j != 7; ++j) {\n\t\t\t\tif(Char & 0x40) XorKey ^= XorMatrix[CurrentElement];\n\t\t\t\tChar *= 2; --CurrentElement;\n\t\t\t}\n\t\t}\n\t\treturn XorKey;\n\t};\n\treturn function(password/*:string*/) {\n\t\tvar Password = _JS2ANSI(password);\n\t\tvar XorKey = CreateXorKey_Method1(Password);\n\t\tvar Index = Password.length;\n\t\tvar ObfuscationArray = new_raw_buf(16);\n\t\tfor(var i = 0; i != 16; ++i) ObfuscationArray[i] = 0x00;\n\t\tvar Temp, PasswordLastChar, PadIndex;\n\t\tif((Index & 1) === 1) {\n\t\t\tTemp = XorKey >> 8;\n\t\t\tObfuscationArray[Index] = XorRor(PadArray[0], Temp);\n\t\t\t--Index;\n\t\t\tTemp = XorKey & 0xFF;\n\t\t\tPasswordLastChar = Password[Password.length - 1];\n\t\t\tObfuscationArray[Index] = XorRor(PasswordLastChar, Temp);\n\t\t}\n\t\twhile(Index > 0) {\n\t\t\t--Index;\n\t\t\tTemp = XorKey >> 8;\n\t\t\tObfuscationArray[Index] = XorRor(Password[Index], Temp);\n\t\t\t--Index;\n\t\t\tTemp = XorKey & 0xFF;\n\t\t\tObfuscationArray[Index] = XorRor(Password[Index], Temp);\n\t\t}\n\t\tIndex = 15;\n\t\tPadIndex = 15 - Password.length;\n\t\twhile(PadIndex > 0) {\n\t\t\tTemp = XorKey >> 8;\n\t\t\tObfuscationArray[Index] = XorRor(PadArray[PadIndex], Temp);\n\t\t\t--Index;\n\t\t\t--PadIndex;\n\t\t\tTemp = XorKey & 0xFF;\n\t\t\tObfuscationArray[Index] = XorRor(Password[Index], Temp);\n\t\t\t--Index;\n\t\t\t--PadIndex;\n\t\t}\n\t\treturn ObfuscationArray;\n\t};\n})();\n\n/* [MS-OFFCRYPTO] 2.3.7.3 Binary Document XOR Data Transformation Method 1 */\nvar crypto_DecryptData_Method1 = function(password/*:string*/, Data, XorArrayIndex, XorArray, O) {\n\t/* If XorArray is set, use it; if O is not set, make changes in-place */\n\tif(!O) O = Data;\n\tif(!XorArray) XorArray = crypto_CreateXorArray_Method1(password);\n\tvar Index, Value;\n\tfor(Index = 0; Index != Data.length; ++Index) {\n\t\tValue = Data[Index];\n\t\tValue ^= XorArray[XorArrayIndex];\n\t\tValue = ((Value>>5) | (Value<<3)) & 0xFF;\n\t\tO[Index] = Value;\n\t\t++XorArrayIndex;\n\t}\n\treturn [O, XorArrayIndex, XorArray];\n};\n\nvar crypto_MakeXorDecryptor = function(password/*:string*/) {\n\tvar XorArrayIndex = 0, XorArray = crypto_CreateXorArray_Method1(password);\n\treturn function(Data) {\n\t\tvar O = crypto_DecryptData_Method1(\"\", Data, XorArrayIndex, XorArray);\n\t\tXorArrayIndex = O[1];\n\t\treturn O[0];\n\t};\n};\n\n/* 2.5.343 */\nfunction parse_XORObfuscation(blob, length, opts, out) {\n\tvar o = ({ key: parseuint16(blob), verificationBytes: parseuint16(blob) }/*:any*/);\n\tif(opts.password) o.verifier = crypto_CreatePasswordVerifier_Method1(opts.password);\n\tout.valid = o.verificationBytes === o.verifier;\n\tif(out.valid) out.insitu = crypto_MakeXorDecryptor(opts.password);\n\treturn o;\n}\n\n/* 2.4.117 */\nfunction parse_FilePassHeader(blob, length/*:number*/, oo) {\n\tvar o = oo || {}; o.Info = blob.read_shift(2); blob.l -= 2;\n\tif(o.Info === 1) o.Data = parse_RC4Header(blob, length);\n\telse o.Data = parse_RC4CryptoHeader(blob, length);\n\treturn o;\n}\nfunction parse_FilePass(blob, length/*:number*/, opts) {\n\tvar o = ({ Type: opts.biff >= 8 ? blob.read_shift(2) : 0 }/*:any*/); /* wEncryptionType */\n\tif(o.Type) parse_FilePassHeader(blob, length-2, o);\n\telse parse_XORObfuscation(blob, opts.biff >= 8 ? length : length - 2, opts, o);\n\treturn o;\n}\n\n\nvar RTF = /*#__PURE__*/(function() {\n\tfunction rtf_to_sheet(d/*:RawData*/, opts)/*:Worksheet*/ {\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': return rtf_to_sheet_str(Base64_decode(d), opts);\n\t\t\tcase 'binary': return rtf_to_sheet_str(d, opts);\n\t\t\tcase 'buffer': return rtf_to_sheet_str(has_buf && Buffer.isBuffer(d) ? d.toString('binary') : a2s(d), opts);\n\t\t\tcase 'array': return rtf_to_sheet_str(cc2str(d), opts);\n\t\t}\n\t\tthrow new Error(\"Unrecognized type \" + opts.type);\n\t}\n\n\t/* TODO: this is a stub */\n\tfunction rtf_to_sheet_str(str/*:string*/, opts)/*:Worksheet*/ {\n\t\tvar o = opts || {};\n\t\tvar ws/*:Worksheet*/ = o.dense ? ([]/*:any*/) : ({}/*:any*/);\n\n\t\tvar rows = str.match(/\\\\trowd.*?\\\\row\\b/g);\n\t\tif(!rows.length) throw new Error(\"RTF missing table\");\n\t\tvar range/*:Range*/ = ({s: {c:0, r:0}, e: {c:0, r:rows.length - 1}}/*:any*/);\n\t\trows.forEach(function(rowtf, R) {\n\t\t\tif(Array.isArray(ws)) ws[R] = [];\n\t\t\tvar rtfre = /\\\\\\w+\\b/g;\n\t\t\tvar last_index = 0;\n\t\t\tvar res;\n\t\t\tvar C = -1;\n\t\t\twhile((res = rtfre.exec(rowtf))) {\n\t\t\t\tswitch(res[0]) {\n\t\t\t\t\tcase \"\\\\cell\":\n\t\t\t\t\t\tvar data = rowtf.slice(last_index, rtfre.lastIndex - res[0].length);\n\t\t\t\t\t\tif(data[0] == \" \") data = data.slice(1);\n\t\t\t\t\t\t++C;\n\t\t\t\t\t\tif(data.length) {\n\t\t\t\t\t\t\t// TODO: value parsing, including codepage adjustments\n\t\t\t\t\t\t\tvar cell = {v: data, t:\"s\"};\n\t\t\t\t\t\t\tif(Array.isArray(ws)) ws[R][C] = cell;\n\t\t\t\t\t\t\telse ws[encode_cell({r:R, c:C})] = cell;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tlast_index = rtfre.lastIndex;\n\t\t\t}\n\t\t\tif(C > range.e.c) range.e.c = C;\n\t\t});\n\t\tws['!ref'] = encode_range(range);\n\t\treturn ws;\n\t}\n\n\tfunction rtf_to_workbook(d/*:RawData*/, opts)/*:Workbook*/ { return sheet_to_workbook(rtf_to_sheet(d, opts), opts); }\n\n\t/* TODO: this is a stub */\n\tfunction sheet_to_rtf(ws/*:Worksheet*//*::, opts*/)/*:string*/ {\n\t\tvar o = [\"{\\\\rtf1\\\\ansi\"];\n\t\tvar r = safe_decode_range(ws['!ref']), cell/*:Cell*/;\n\t\tvar dense = Array.isArray(ws);\n\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\to.push(\"\\\\trowd\\\\trautofit1\");\n\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) o.push(\"\\\\cellx\" + (C+1));\n\t\t\to.push(\"\\\\pard\\\\intbl\");\n\t\t\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\tvar coord = encode_cell({r:R,c:C});\n\t\t\t\tcell = dense ? (ws[R]||[])[C]: ws[coord];\n\t\t\t\tif(!cell || cell.v == null && (!cell.f || cell.F)) continue;\n\t\t\t\to.push(\" \" + (cell.w || (format_cell(cell), cell.w)));\n\t\t\t\to.push(\"\\\\cell\");\n\t\t\t}\n\t\t\to.push(\"\\\\pard\\\\intbl\\\\row\");\n\t\t}\n\t\treturn o.join(\"\") + \"}\";\n\t}\n\n\treturn {\n\t\tto_workbook: rtf_to_workbook,\n\t\tto_sheet: rtf_to_sheet,\n\t\tfrom_sheet: sheet_to_rtf\n\t};\n})();\nfunction hex2RGB(h) {\n\tvar o = h.slice(h[0]===\"#\"?1:0).slice(0,6);\n\treturn [parseInt(o.slice(0,2),16),parseInt(o.slice(2,4),16),parseInt(o.slice(4,6),16)];\n}\nfunction rgb2Hex(rgb) {\n\tfor(var i=0,o=1; i!=3; ++i) o = o*256 + (rgb[i]>255?255:rgb[i]<0?0:rgb[i]);\n\treturn o.toString(16).toUpperCase().slice(1);\n}\n\nfunction rgb2HSL(rgb) {\n\tvar R = rgb[0]/255, G = rgb[1]/255, B=rgb[2]/255;\n\tvar M = Math.max(R, G, B), m = Math.min(R, G, B), C = M - m;\n\tif(C === 0) return [0, 0, R];\n\n\tvar H6 = 0, S = 0, L2 = (M + m);\n\tS = C / (L2 > 1 ? 2 - L2 : L2);\n\tswitch(M){\n\t\tcase R: H6 = ((G - B) / C + 6)%6; break;\n\t\tcase G: H6 = ((B - R) / C + 2); break;\n\t\tcase B: H6 = ((R - G) / C + 4); break;\n\t}\n\treturn [H6 / 6, S, L2 / 2];\n}\n\nfunction hsl2RGB(hsl){\n\tvar H = hsl[0], S = hsl[1], L = hsl[2];\n\tvar C = S * 2 * (L < 0.5 ? L : 1 - L), m = L - C/2;\n\tvar rgb = [m,m,m], h6 = 6*H;\n\n\tvar X;\n\tif(S !== 0) switch(h6|0) {\n\t\tcase 0: case 6: X = C * h6; rgb[0] += C; rgb[1] += X; break;\n\t\tcase 1: X = C * (2 - h6); rgb[0] += X; rgb[1] += C; break;\n\t\tcase 2: X = C * (h6 - 2); rgb[1] += C; rgb[2] += X; break;\n\t\tcase 3: X = C * (4 - h6); rgb[1] += X; rgb[2] += C; break;\n\t\tcase 4: X = C * (h6 - 4); rgb[2] += C; rgb[0] += X; break;\n\t\tcase 5: X = C * (6 - h6); rgb[2] += X; rgb[0] += C; break;\n\t}\n\tfor(var i = 0; i != 3; ++i) rgb[i] = Math.round(rgb[i]*255);\n\treturn rgb;\n}\n\n/* 18.8.3 bgColor tint algorithm */\nfunction rgb_tint(hex, tint) {\n\tif(tint === 0) return hex;\n\tvar hsl = rgb2HSL(hex2RGB(hex));\n\tif (tint < 0) hsl[2] = hsl[2] * (1 + tint);\n\telse hsl[2] = 1 - (1 - hsl[2]) * (1 - tint);\n\treturn rgb2Hex(hsl2RGB(hsl));\n}\n\n/* 18.3.1.13 width calculations */\n/* [MS-OI29500] 2.1.595 Column Width & Formatting */\nvar DEF_MDW = 6, MAX_MDW = 15, MIN_MDW = 1, MDW = DEF_MDW;\nfunction width2px(width) { return Math.floor(( width + (Math.round(128/MDW))/256 )* MDW ); }\nfunction px2char(px) { return (Math.floor((px - 5)/MDW * 100 + 0.5))/100; }\nfunction char2width(chr) { return (Math.round((chr * MDW + 5)/MDW*256))/256; }\n//function px2char_(px) { return (((px - 5)/MDW * 100 + 0.5))/100; }\n//function char2width_(chr) { return (((chr * MDW + 5)/MDW*256))/256; }\nfunction cycle_width(collw) { return char2width(px2char(width2px(collw))); }\n/* XLSX/XLSB/XLS specify width in units of MDW */\nfunction find_mdw_colw(collw) {\n\tvar delta = Math.abs(collw - cycle_width(collw)), _MDW = MDW;\n\tif(delta > 0.005) for(MDW=MIN_MDW; MDW<MAX_MDW; ++MDW) if(Math.abs(collw - cycle_width(collw)) <= delta) { delta = Math.abs(collw - cycle_width(collw)); _MDW = MDW; }\n\tMDW = _MDW;\n}\n/* XLML specifies width in terms of pixels */\n/*function find_mdw_wpx(wpx) {\n\tvar delta = Infinity, guess = 0, _MDW = MIN_MDW;\n\tfor(MDW=MIN_MDW; MDW<MAX_MDW; ++MDW) {\n\t\tguess = char2width_(px2char_(wpx))*256;\n\t\tguess = (guess) % 1;\n\t\tif(guess > 0.5) guess--;\n\t\tif(Math.abs(guess) < delta) { delta = Math.abs(guess); _MDW = MDW; }\n\t}\n\tMDW = _MDW;\n}*/\n\nfunction process_col(coll/*:ColInfo*/) {\n\tif(coll.width) {\n\t\tcoll.wpx = width2px(coll.width);\n\t\tcoll.wch = px2char(coll.wpx);\n\t\tcoll.MDW = MDW;\n\t} else if(coll.wpx) {\n\t\tcoll.wch = px2char(coll.wpx);\n\t\tcoll.width = char2width(coll.wch);\n\t\tcoll.MDW = MDW;\n\t} else if(typeof coll.wch == 'number') {\n\t\tcoll.width = char2width(coll.wch);\n\t\tcoll.wpx = width2px(coll.width);\n\t\tcoll.MDW = MDW;\n\t}\n\tif(coll.customWidth) delete coll.customWidth;\n}\n\nvar DEF_PPI = 96, PPI = DEF_PPI;\nfunction px2pt(px) { return px * 96 / PPI; }\nfunction pt2px(pt) { return pt * PPI / 96; }\n\n/* [MS-EXSPXML3] 2.4.54 ST_enmPattern */\nvar XLMLPatternTypeMap = {\n\t\"None\": \"none\",\n\t\"Solid\": \"solid\",\n\t\"Gray50\": \"mediumGray\",\n\t\"Gray75\": \"darkGray\",\n\t\"Gray25\": \"lightGray\",\n\t\"HorzStripe\": \"darkHorizontal\",\n\t\"VertStripe\": \"darkVertical\",\n\t\"ReverseDiagStripe\": \"darkDown\",\n\t\"DiagStripe\": \"darkUp\",\n\t\"DiagCross\": \"darkGrid\",\n\t\"ThickDiagCross\": \"darkTrellis\",\n\t\"ThinHorzStripe\": \"lightHorizontal\",\n\t\"ThinVertStripe\": \"lightVertical\",\n\t\"ThinReverseDiagStripe\": \"lightDown\",\n\t\"ThinHorzCross\": \"lightGrid\"\n};\n\n/* 18.8.5 borders CT_Borders */\nfunction parse_borders(t, styles, themes, opts) {\n\tstyles.Borders = [];\n\tvar border = {};\n\tvar pass = false;\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<borders': case '<borders>': case '</borders>': break;\n\n\t\t\t/* 18.8.4 border CT_Border */\n\t\t\tcase '<border': case '<border>': case '<border/>':\n\t\t\t\tborder = /*::(*/{}/*:: :any)*/;\n\t\t\t\tif(y.diagonalUp) border.diagonalUp = parsexmlbool(y.diagonalUp);\n\t\t\t\tif(y.diagonalDown) border.diagonalDown = parsexmlbool(y.diagonalDown);\n\t\t\t\tstyles.Borders.push(border);\n\t\t\t\tbreak;\n\t\t\tcase '</border>': break;\n\n\t\t\t/* note: not in spec, appears to be CT_BorderPr */\n\t\t\tcase '<left/>': break;\n\t\t\tcase '<left': case '<left>': break;\n\t\t\tcase '</left>': break;\n\n\t\t\t/* note: not in spec, appears to be CT_BorderPr */\n\t\t\tcase '<right/>': break;\n\t\t\tcase '<right': case '<right>': break;\n\t\t\tcase '</right>': break;\n\n\t\t\t/* 18.8.43 top CT_BorderPr */\n\t\t\tcase '<top/>': break;\n\t\t\tcase '<top': case '<top>': break;\n\t\t\tcase '</top>': break;\n\n\t\t\t/* 18.8.6 bottom CT_BorderPr */\n\t\t\tcase '<bottom/>': break;\n\t\t\tcase '<bottom': case '<bottom>': break;\n\t\t\tcase '</bottom>': break;\n\n\t\t\t/* 18.8.13 diagonal CT_BorderPr */\n\t\t\tcase '<diagonal': case '<diagonal>': case '<diagonal/>': break;\n\t\t\tcase '</diagonal>': break;\n\n\t\t\t/* 18.8.25 horizontal CT_BorderPr */\n\t\t\tcase '<horizontal': case '<horizontal>': case '<horizontal/>': break;\n\t\t\tcase '</horizontal>': break;\n\n\t\t\t/* 18.8.44 vertical CT_BorderPr */\n\t\t\tcase '<vertical': case '<vertical>': case '<vertical/>': break;\n\t\t\tcase '</vertical>': break;\n\n\t\t\t/* 18.8.37 start CT_BorderPr */\n\t\t\tcase '<start': case '<start>': case '<start/>': break;\n\t\t\tcase '</start>': break;\n\n\t\t\t/* 18.8.16 end CT_BorderPr */\n\t\t\tcase '<end': case '<end>': case '<end/>': break;\n\t\t\tcase '</end>': break;\n\n\t\t\t/* 18.8.? color CT_Color */\n\t\t\tcase '<color': case '<color>':\n\t\t\t\tbreak;\n\t\t\tcase '<color/>': case '</color>': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault: if(opts && opts.WTF) {\n\t\t\t\tif(!pass) throw new Error('unrecognized ' + y[0] + ' in borders');\n\t\t\t}\n\t\t}\n\t});\n}\n\n/* 18.8.21 fills CT_Fills */\nfunction parse_fills(t, styles, themes, opts) {\n\tstyles.Fills = [];\n\tvar fill = {};\n\tvar pass = false;\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<fills': case '<fills>': case '</fills>': break;\n\n\t\t\t/* 18.8.20 fill CT_Fill */\n\t\t\tcase '<fill>': case '<fill': case '<fill/>':\n\t\t\t\tfill = {}; styles.Fills.push(fill); break;\n\t\t\tcase '</fill>': break;\n\n\t\t\t/* 18.8.24 gradientFill CT_GradientFill */\n\t\t\tcase '<gradientFill>': break;\n\t\t\tcase '<gradientFill':\n\t\t\tcase '</gradientFill>': styles.Fills.push(fill); fill = {}; break;\n\n\t\t\t/* 18.8.32 patternFill CT_PatternFill */\n\t\t\tcase '<patternFill': case '<patternFill>':\n\t\t\t\tif(y.patternType) fill.patternType = y.patternType;\n\t\t\t\tbreak;\n\t\t\tcase '<patternFill/>': case '</patternFill>': break;\n\n\t\t\t/* 18.8.3 bgColor CT_Color */\n\t\t\tcase '<bgColor':\n\t\t\t\tif(!fill.bgColor) fill.bgColor = {};\n\t\t\t\tif(y.indexed) fill.bgColor.indexed = parseInt(y.indexed, 10);\n\t\t\t\tif(y.theme) fill.bgColor.theme = parseInt(y.theme, 10);\n\t\t\t\tif(y.tint) fill.bgColor.tint = parseFloat(y.tint);\n\t\t\t\t/* Excel uses ARGB strings */\n\t\t\t\tif(y.rgb) fill.bgColor.rgb = y.rgb.slice(-6);\n\t\t\t\tbreak;\n\t\t\tcase '<bgColor/>': case '</bgColor>': break;\n\n\t\t\t/* 18.8.19 fgColor CT_Color */\n\t\t\tcase '<fgColor':\n\t\t\t\tif(!fill.fgColor) fill.fgColor = {};\n\t\t\t\tif(y.theme) fill.fgColor.theme = parseInt(y.theme, 10);\n\t\t\t\tif(y.tint) fill.fgColor.tint = parseFloat(y.tint);\n\t\t\t\t/* Excel uses ARGB strings */\n\t\t\t\tif(y.rgb != null) fill.fgColor.rgb = y.rgb.slice(-6);\n\t\t\t\tbreak;\n\t\t\tcase '<fgColor/>': case '</fgColor>': break;\n\n\t\t\t/* 18.8.38 stop CT_GradientStop */\n\t\t\tcase '<stop': case '<stop/>': break;\n\t\t\tcase '</stop>': break;\n\n\t\t\t/* 18.8.? color CT_Color */\n\t\t\tcase '<color': case '<color/>': break;\n\t\t\tcase '</color>': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault: if(opts && opts.WTF) {\n\t\t\t\tif(!pass) throw new Error('unrecognized ' + y[0] + ' in fills');\n\t\t\t}\n\t\t}\n\t});\n}\n\n/* 18.8.23 fonts CT_Fonts */\nfunction parse_fonts(t, styles, themes, opts) {\n\tstyles.Fonts = [];\n\tvar font = {};\n\tvar pass = false;\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<fonts': case '<fonts>': case '</fonts>': break;\n\n\t\t\t/* 18.8.22 font CT_Font */\n\t\t\tcase '<font': case '<font>': break;\n\t\t\tcase '</font>': case '<font/>':\n\t\t\t\tstyles.Fonts.push(font);\n\t\t\t\tfont = {};\n\t\t\t\tbreak;\n\n\t\t\t/* 18.8.29 name CT_FontName */\n\t\t\tcase '<name': if(y.val) font.name = utf8read(y.val); break;\n\t\t\tcase '<name/>': case '</name>': break;\n\n\t\t\t/* 18.8.2 b CT_BooleanProperty */\n\t\t\tcase '<b': font.bold = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<b/>': font.bold = 1; break;\n\n\t\t\t/* 18.8.26 i CT_BooleanProperty */\n\t\t\tcase '<i': font.italic = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<i/>': font.italic = 1; break;\n\n\t\t\t/* 18.4.13 u CT_UnderlineProperty */\n\t\t\tcase '<u':\n\t\t\t\tswitch(y.val) {\n\t\t\t\t\tcase \"none\": font.underline = 0x00; break;\n\t\t\t\t\tcase \"single\": font.underline = 0x01; break;\n\t\t\t\t\tcase \"double\": font.underline = 0x02; break;\n\t\t\t\t\tcase \"singleAccounting\": font.underline = 0x21; break;\n\t\t\t\t\tcase \"doubleAccounting\": font.underline = 0x22; break;\n\t\t\t\t} break;\n\t\t\tcase '<u/>': font.underline = 1; break;\n\n\t\t\t/* 18.4.10 strike CT_BooleanProperty */\n\t\t\tcase '<strike': font.strike = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<strike/>': font.strike = 1; break;\n\n\t\t\t/* 18.4.2 outline CT_BooleanProperty */\n\t\t\tcase '<outline': font.outline = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<outline/>': font.outline = 1; break;\n\n\t\t\t/* 18.8.36 shadow CT_BooleanProperty */\n\t\t\tcase '<shadow': font.shadow = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<shadow/>': font.shadow = 1; break;\n\n\t\t\t/* 18.8.12 condense CT_BooleanProperty */\n\t\t\tcase '<condense': font.condense = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<condense/>': font.condense = 1; break;\n\n\t\t\t/* 18.8.17 extend CT_BooleanProperty */\n\t\t\tcase '<extend': font.extend = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<extend/>': font.extend = 1; break;\n\n\t\t\t/* 18.4.11 sz CT_FontSize */\n\t\t\tcase '<sz': if(y.val) font.sz = +y.val; break;\n\t\t\tcase '<sz/>': case '</sz>': break;\n\n\t\t\t/* 18.4.14 vertAlign CT_VerticalAlignFontProperty */\n\t\t\tcase '<vertAlign': if(y.val) font.vertAlign = y.val; break;\n\t\t\tcase '<vertAlign/>': case '</vertAlign>': break;\n\n\t\t\t/* 18.8.18 family CT_FontFamily */\n\t\t\tcase '<family': if(y.val) font.family = parseInt(y.val,10); break;\n\t\t\tcase '<family/>': case '</family>': break;\n\n\t\t\t/* 18.8.35 scheme CT_FontScheme */\n\t\t\tcase '<scheme': if(y.val) font.scheme = y.val; break;\n\t\t\tcase '<scheme/>': case '</scheme>': break;\n\n\t\t\t/* 18.4.1 charset CT_IntProperty */\n\t\t\tcase '<charset':\n\t\t\t\tif(y.val == '1') break;\n\t\t\t\ty.codepage = CS2CP[parseInt(y.val, 10)];\n\t\t\t\tbreak;\n\n\t\t\t/* 18.?.? color CT_Color */\n\t\t\tcase '<color':\n\t\t\t\tif(!font.color) font.color = {};\n\t\t\t\tif(y.auto) font.color.auto = parsexmlbool(y.auto);\n\n\t\t\t\tif(y.rgb) font.color.rgb = y.rgb.slice(-6);\n\t\t\t\telse if(y.indexed) {\n\t\t\t\t\tfont.color.index = parseInt(y.indexed, 10);\n\t\t\t\t\tvar icv = XLSIcv[font.color.index];\n\t\t\t\t\tif(font.color.index == 81) icv = XLSIcv[1];\n\t\t\t\t\tif(!icv) icv = XLSIcv[1]; //throw new Error(x); // note: 206 is valid\n\t\t\t\t\tfont.color.rgb = icv[0].toString(16) + icv[1].toString(16) + icv[2].toString(16);\n\t\t\t\t} else if(y.theme) {\n\t\t\t\t\tfont.color.theme = parseInt(y.theme, 10);\n\t\t\t\t\tif(y.tint) font.color.tint = parseFloat(y.tint);\n\t\t\t\t\tif(y.theme && themes.themeElements && themes.themeElements.clrScheme) {\n\t\t\t\t\t\tfont.color.rgb = rgb_tint(themes.themeElements.clrScheme[font.color.theme].rgb, font.color.tint || 0);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\t\t\tcase '<color/>': case '</color>': break;\n\n\t\t\t/* note: sometimes mc:AlternateContent appears bare */\n\t\t\tcase '<AlternateContent': pass = true; break;\n\t\t\tcase '</AlternateContent>': pass = false; break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault: if(opts && opts.WTF) {\n\t\t\t\tif(!pass) throw new Error('unrecognized ' + y[0] + ' in fonts');\n\t\t\t}\n\t\t}\n\t});\n}\n\n/* 18.8.31 numFmts CT_NumFmts */\nfunction parse_numFmts(t, styles, opts) {\n\tstyles.NumberFmt = [];\n\tvar k/*Array<number>*/ = (keys(table_fmt)/*:any*/);\n\tfor(var i=0; i < k.length; ++i) styles.NumberFmt[k[i]] = table_fmt[k[i]];\n\tvar m = t[0].match(tagregex);\n\tif(!m) return;\n\tfor(i=0; i < m.length; ++i) {\n\t\tvar y = parsexmltag(m[i]);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<numFmts': case '</numFmts>': case '<numFmts/>': case '<numFmts>': break;\n\t\t\tcase '<numFmt': {\n\t\t\t\tvar f=unescapexml(utf8read(y.formatCode)), j=parseInt(y.numFmtId,10);\n\t\t\t\tstyles.NumberFmt[j] = f;\n\t\t\t\tif(j>0) {\n\t\t\t\t\tif(j > 0x188) {\n\t\t\t\t\t\tfor(j = 0x188; j > 0x3c; --j) if(styles.NumberFmt[j] == null) break;\n\t\t\t\t\t\tstyles.NumberFmt[j] = f;\n\t\t\t\t\t}\n\t\t\t\t\tSSF_load(f,j);\n\t\t\t\t}\n\t\t\t} break;\n\t\t\tcase '</numFmt>': break;\n\t\t\tdefault: if(opts.WTF) throw new Error('unrecognized ' + y[0] + ' in numFmts');\n\t\t}\n\t}\n}\n\nfunction write_numFmts(NF/*:{[n:number|string]:string}*//*::, opts*/) {\n\tvar o = [\"<numFmts>\"];\n\t[[5,8],[23,26],[41,44],[/*63*/50,/*66],[164,*/392]].forEach(function(r) {\n\t\tfor(var i = r[0]; i <= r[1]; ++i) if(NF[i] != null) o[o.length] = (writextag('numFmt',null,{numFmtId:i,formatCode:escapexml(NF[i])}));\n\t});\n\tif(o.length === 1) return \"\";\n\to[o.length] = (\"</numFmts>\");\n\to[0] = writextag('numFmts', null, { count:o.length-2 }).replace(\"/>\", \">\");\n\treturn o.join(\"\");\n}\n\n/* 18.8.10 cellXfs CT_CellXfs */\nvar cellXF_uint = [ \"numFmtId\", \"fillId\", \"fontId\", \"borderId\", \"xfId\" ];\nvar cellXF_bool = [ \"applyAlignment\", \"applyBorder\", \"applyFill\", \"applyFont\", \"applyNumberFormat\", \"applyProtection\", \"pivotButton\", \"quotePrefix\" ];\nfunction parse_cellXfs(t, styles, opts) {\n\tstyles.CellXf = [];\n\tvar xf;\n\tvar pass = false;\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x), i = 0;\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<cellXfs': case '<cellXfs>': case '<cellXfs/>': case '</cellXfs>': break;\n\n\t\t\t/* 18.8.45 xf CT_Xf */\n\t\t\tcase '<xf': case '<xf/>':\n\t\t\t\txf = y;\n\t\t\t\tdelete xf[0];\n\t\t\t\tfor(i = 0; i < cellXF_uint.length; ++i) if(xf[cellXF_uint[i]])\n\t\t\t\t\txf[cellXF_uint[i]] = parseInt(xf[cellXF_uint[i]], 10);\n\t\t\t\tfor(i = 0; i < cellXF_bool.length; ++i) if(xf[cellXF_bool[i]])\n\t\t\t\t\txf[cellXF_bool[i]] = parsexmlbool(xf[cellXF_bool[i]]);\n\t\t\t\tif(styles.NumberFmt && xf.numFmtId > 0x188) {\n\t\t\t\t\tfor(i = 0x188; i > 0x3c; --i) if(styles.NumberFmt[xf.numFmtId] == styles.NumberFmt[i]) { xf.numFmtId = i; break; }\n\t\t\t\t}\n\t\t\t\tstyles.CellXf.push(xf); break;\n\t\t\tcase '</xf>': break;\n\n\t\t\t/* 18.8.1 alignment CT_CellAlignment */\n\t\t\tcase '<alignment': case '<alignment/>':\n\t\t\t\tvar alignment = {};\n\t\t\t\tif(y.vertical) alignment.vertical = y.vertical;\n\t\t\t\tif(y.horizontal) alignment.horizontal = y.horizontal;\n\t\t\t\tif(y.textRotation != null) alignment.textRotation = y.textRotation;\n\t\t\t\tif(y.indent) alignment.indent = y.indent;\n\t\t\t\tif(y.wrapText) alignment.wrapText = parsexmlbool(y.wrapText);\n\t\t\t\txf.alignment = alignment;\n\t\t\t\tbreak;\n\t\t\tcase '</alignment>': break;\n\n\t\t\t/* 18.8.33 protection CT_CellProtection */\n\t\t\tcase '<protection':\n\t\t\t\tbreak;\n\t\t\tcase '</protection>': case '<protection/>': break;\n\n\t\t\t/* note: sometimes mc:AlternateContent appears bare */\n\t\t\tcase '<AlternateContent': pass = true; break;\n\t\t\tcase '</AlternateContent>': pass = false; break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault: if(opts && opts.WTF) {\n\t\t\t\tif(!pass) throw new Error('unrecognized ' + y[0] + ' in cellXfs');\n\t\t\t}\n\t\t}\n\t});\n}\n\nfunction write_cellXfs(cellXfs)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\to[o.length] = (writextag('cellXfs',null));\n\tcellXfs.forEach(function(c) {\n\t\to[o.length] = (writextag('xf', null, c));\n\t});\n\to[o.length] = (\"</cellXfs>\");\n\tif(o.length === 2) return \"\";\n\to[0] = writextag('cellXfs',null, {count:o.length-2}).replace(\"/>\",\">\");\n\treturn o.join(\"\");\n}\n\n/* 18.8 Styles CT_Stylesheet*/\nvar parse_sty_xml= /*#__PURE__*/(function make_pstyx() {\nvar numFmtRegex = /<(?:\\w+:)?numFmts([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?numFmts>/;\nvar cellXfRegex = /<(?:\\w+:)?cellXfs([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?cellXfs>/;\nvar fillsRegex = /<(?:\\w+:)?fills([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?fills>/;\nvar fontsRegex = /<(?:\\w+:)?fonts([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?fonts>/;\nvar bordersRegex = /<(?:\\w+:)?borders([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?borders>/;\n\nreturn function parse_sty_xml(data, themes, opts) {\n\tvar styles = {};\n\tif(!data) return styles;\n\tdata = data.replace(/<!--([\\s\\S]*?)-->/mg,\"\").replace(/<!DOCTYPE[^\\[]*\\[[^\\]]*\\]>/gm,\"\");\n\t/* 18.8.39 styleSheet CT_Stylesheet */\n\tvar t;\n\n\t/* 18.8.31 numFmts CT_NumFmts ? */\n\tif((t=data.match(numFmtRegex))) parse_numFmts(t, styles, opts);\n\n\t/* 18.8.23 fonts CT_Fonts ? */\n\tif((t=data.match(fontsRegex))) parse_fonts(t, styles, themes, opts);\n\n\t/* 18.8.21 fills CT_Fills ? */\n\tif((t=data.match(fillsRegex))) parse_fills(t, styles, themes, opts);\n\n\t/* 18.8.5 borders CT_Borders ? */\n\tif((t=data.match(bordersRegex))) parse_borders(t, styles, themes, opts);\n\n\t/* 18.8.9 cellStyleXfs CT_CellStyleXfs ? */\n\t/* 18.8.8 cellStyles CT_CellStyles ? */\n\n\t/* 18.8.10 cellXfs CT_CellXfs ? */\n\tif((t=data.match(cellXfRegex))) parse_cellXfs(t, styles, opts);\n\n\t/* 18.8.15 dxfs CT_Dxfs ? */\n\t/* 18.8.42 tableStyles CT_TableStyles ? */\n\t/* 18.8.11 colors CT_Colors ? */\n\t/* 18.2.10 extLst CT_ExtensionList ? */\n\n\treturn styles;\n};\n})();\n\nfunction write_sty_xml(wb/*:Workbook*/, opts)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('styleSheet', null, {\n\t\t'xmlns': XMLNS_main[0],\n\t\t'xmlns:vt': XMLNS.vt\n\t})], w;\n\tif(wb.SSF && (w = write_numFmts(wb.SSF)) != null) o[o.length] = w;\n\to[o.length] = ('<fonts count=\"1\"><font><sz val=\"12\"/><color theme=\"1\"/><name val=\"Calibri\"/><family val=\"2\"/><scheme val=\"minor\"/></font></fonts>');\n\to[o.length] = ('<fills count=\"2\"><fill><patternFill patternType=\"none\"/></fill><fill><patternFill patternType=\"gray125\"/></fill></fills>');\n\to[o.length] = ('<borders count=\"1\"><border><left/><right/><top/><bottom/><diagonal/></border></borders>');\n\to[o.length] = ('<cellStyleXfs count=\"1\"><xf numFmtId=\"0\" fontId=\"0\" fillId=\"0\" borderId=\"0\"/></cellStyleXfs>');\n\tif((w = write_cellXfs(opts.cellXfs))) o[o.length] = (w);\n\to[o.length] = ('<cellStyles count=\"1\"><cellStyle name=\"Normal\" xfId=\"0\" builtinId=\"0\"/></cellStyles>');\n\to[o.length] = ('<dxfs count=\"0\"/>');\n\to[o.length] = ('<tableStyles count=\"0\" defaultTableStyle=\"TableStyleMedium9\" defaultPivotStyle=\"PivotStyleMedium4\"/>');\n\n\tif(o.length>2){ o[o.length] = ('</styleSheet>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.657 BrtFmt */\nfunction parse_BrtFmt(data, length/*:number*/) {\n\tvar numFmtId = data.read_shift(2);\n\tvar stFmtCode = parse_XLWideString(data,length-2);\n\treturn [numFmtId, stFmtCode];\n}\nfunction write_BrtFmt(i/*:number*/, f/*:string*/, o) {\n\tif(!o) o = new_buf(6 + 4 * f.length);\n\to.write_shift(2, i);\n\twrite_XLWideString(f, o);\n\tvar out = (o.length > o.l) ? o.slice(0, o.l) : o;\n\tif(o.l == null) o.l = o.length;\n\treturn out;\n}\n\n/* [MS-XLSB] 2.4.659 BrtFont TODO */\nfunction parse_BrtFont(data, length/*:number*/, opts) {\n\tvar out = ({}/*:any*/);\n\n\tout.sz = data.read_shift(2) / 20;\n\n\tvar grbit = parse_FontFlags(data, 2, opts);\n\tif(grbit.fItalic) out.italic = 1;\n\tif(grbit.fCondense) out.condense = 1;\n\tif(grbit.fExtend) out.extend = 1;\n\tif(grbit.fShadow) out.shadow = 1;\n\tif(grbit.fOutline) out.outline = 1;\n\tif(grbit.fStrikeout) out.strike = 1;\n\n\tvar bls = data.read_shift(2);\n\tif(bls === 0x02BC) out.bold = 1;\n\n\tswitch(data.read_shift(2)) {\n\t\t/* case 0: out.vertAlign = \"baseline\"; break; */\n\t\tcase 1: out.vertAlign = \"superscript\"; break;\n\t\tcase 2: out.vertAlign = \"subscript\"; break;\n\t}\n\n\tvar underline = data.read_shift(1);\n\tif(underline != 0) out.underline = underline;\n\n\tvar family = data.read_shift(1);\n\tif(family > 0) out.family = family;\n\n\tvar bCharSet = data.read_shift(1);\n\tif(bCharSet > 0) out.charset = bCharSet;\n\n\tdata.l++;\n\tout.color = parse_BrtColor(data, 8);\n\n\tswitch(data.read_shift(1)) {\n\t\t/* case 0: out.scheme = \"none\": break; */\n\t\tcase 1: out.scheme = \"major\"; break;\n\t\tcase 2: out.scheme = \"minor\"; break;\n\t}\n\n\tout.name = parse_XLWideString(data, length - 21);\n\n\treturn out;\n}\nfunction write_BrtFont(font/*:any*/, o) {\n\tif(!o) o = new_buf(25+4*32);\n\to.write_shift(2, font.sz * 20);\n\twrite_FontFlags(font, o);\n\to.write_shift(2, font.bold ? 0x02BC : 0x0190);\n\tvar sss = 0;\n\tif(font.vertAlign == \"superscript\") sss = 1;\n\telse if(font.vertAlign == \"subscript\") sss = 2;\n\to.write_shift(2, sss);\n\to.write_shift(1, font.underline || 0);\n\to.write_shift(1, font.family || 0);\n\to.write_shift(1, font.charset || 0);\n\to.write_shift(1, 0);\n\twrite_BrtColor(font.color, o);\n\tvar scheme = 0;\n\tif(font.scheme == \"major\") scheme = 1;\n\tif(font.scheme == \"minor\") scheme = 2;\n\to.write_shift(1, scheme);\n\twrite_XLWideString(font.name, o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.650 BrtFill */\nvar XLSBFillPTNames = [\n\t\"none\",\n\t\"solid\",\n\t\"mediumGray\",\n\t\"darkGray\",\n\t\"lightGray\",\n\t\"darkHorizontal\",\n\t\"darkVertical\",\n\t\"darkDown\",\n\t\"darkUp\",\n\t\"darkGrid\",\n\t\"darkTrellis\",\n\t\"lightHorizontal\",\n\t\"lightVertical\",\n\t\"lightDown\",\n\t\"lightUp\",\n\t\"lightGrid\",\n\t\"lightTrellis\",\n\t\"gray125\",\n\t\"gray0625\"\n];\nvar rev_XLSBFillPTNames/*:EvertNumType*/;\n/* TODO: gradient fill representation */\nvar parse_BrtFill = parsenoop;\nfunction write_BrtFill(fill, o) {\n\tif(!o) o = new_buf(4*3 + 8*7 + 16*1);\n\tif(!rev_XLSBFillPTNames) rev_XLSBFillPTNames = (evert(XLSBFillPTNames)/*:any*/);\n\tvar fls/*:number*/ = rev_XLSBFillPTNames[fill.patternType];\n\tif(fls == null) fls = 0x28;\n\to.write_shift(4, fls);\n\tvar j = 0;\n\tif(fls != 0x28) {\n\t\t/* TODO: custom FG Color */\n\t\twrite_BrtColor({auto:1}, o);\n\t\t/* TODO: custom BG Color */\n\t\twrite_BrtColor({auto:1}, o);\n\n\t\tfor(; j < 12; ++j) o.write_shift(4, 0);\n\t} else {\n\t\tfor(; j < 4; ++j) o.write_shift(4, 0);\n\n\t\tfor(; j < 12; ++j) o.write_shift(4, 0); /* TODO */\n\t\t/* iGradientType */\n\t\t/* xnumDegree */\n\t\t/* xnumFillToLeft */\n\t\t/* xnumFillToRight */\n\t\t/* xnumFillToTop */\n\t\t/* xnumFillToBottom */\n\t\t/* cNumStop */\n\t\t/* xfillGradientStop */\n\t}\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.824 BrtXF */\nfunction parse_BrtXF(data, length/*:number*/) {\n\tvar tgt = data.l + length;\n\tvar ixfeParent = data.read_shift(2);\n\tvar ifmt = data.read_shift(2);\n\tdata.l = tgt;\n\treturn {ixfe:ixfeParent, numFmtId:ifmt };\n}\nfunction write_BrtXF(data, ixfeP, o) {\n\tif(!o) o = new_buf(16);\n\to.write_shift(2, ixfeP||0);\n\to.write_shift(2, data.numFmtId||0);\n\to.write_shift(2, 0); /* iFont */\n\to.write_shift(2, 0); /* iFill */\n\to.write_shift(2, 0); /* ixBorder */\n\to.write_shift(1, 0); /* trot */\n\to.write_shift(1, 0); /* indent */\n\tvar flow = 0;\n\to.write_shift(1, flow); /* flags */\n\to.write_shift(1, 0); /* flags */\n\to.write_shift(1, 0); /* xfGrbitAtr */\n\to.write_shift(1, 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.4 Blxf TODO */\nfunction write_Blxf(data, o) {\n\tif(!o) o = new_buf(10);\n\to.write_shift(1, 0); /* dg */\n\to.write_shift(1, 0);\n\to.write_shift(4, 0); /* color */\n\to.write_shift(4, 0); /* color */\n\treturn o;\n}\n/* [MS-XLSB] 2.4.302 BrtBorder TODO */\nvar parse_BrtBorder = parsenoop;\nfunction write_BrtBorder(border, o) {\n\tif(!o) o = new_buf(51);\n\to.write_shift(1, 0); /* diagonal */\n\twrite_Blxf(null, o); /* top */\n\twrite_Blxf(null, o); /* bottom */\n\twrite_Blxf(null, o); /* left */\n\twrite_Blxf(null, o); /* right */\n\twrite_Blxf(null, o); /* diag */\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.763 BrtStyle TODO */\nfunction write_BrtStyle(style, o) {\n\tif(!o) o = new_buf(12+4*10);\n\to.write_shift(4, style.xfId);\n\to.write_shift(2, 1);\n\to.write_shift(1, +style.builtinId);\n\to.write_shift(1, 0); /* iLevel */\n\twrite_XLNullableWideString(style.name || \"\", o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.272 BrtBeginTableStyles */\nfunction write_BrtBeginTableStyles(cnt, defTableStyle, defPivotStyle) {\n\tvar o = new_buf(4+256*2*4);\n\to.write_shift(4, cnt);\n\twrite_XLNullableWideString(defTableStyle, o);\n\twrite_XLNullableWideString(defPivotStyle, o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.1.7.50 Styles */\nfunction parse_sty_bin(data, themes, opts) {\n\tvar styles = {};\n\tstyles.NumberFmt = ([]/*:any*/);\n\tfor(var y in table_fmt) styles.NumberFmt[y] = table_fmt[y];\n\n\tstyles.CellXf = [];\n\tstyles.Fonts = [];\n\tvar state/*:Array<string>*/ = [];\n\tvar pass = false;\n\trecordhopper(data, function hopper_sty(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x002C: /* BrtFmt */\n\t\t\t\tstyles.NumberFmt[val[0]] = val[1]; SSF_load(val[1], val[0]);\n\t\t\t\tbreak;\n\t\t\tcase 0x002B: /* BrtFont */\n\t\t\t\tstyles.Fonts.push(val);\n\t\t\t\tif(val.color.theme != null && themes && themes.themeElements && themes.themeElements.clrScheme) {\n\t\t\t\t\tval.color.rgb = rgb_tint(themes.themeElements.clrScheme[val.color.theme].rgb, val.color.tint || 0);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase 0x0401: /* BrtKnownFonts */ break;\n\t\t\tcase 0x002D: /* BrtFill */\n\t\t\t\tbreak;\n\t\t\tcase 0x002E: /* BrtBorder */\n\t\t\t\tbreak;\n\t\t\tcase 0x002F: /* BrtXF */\n\t\t\t\tif(state[state.length - 1] == 0x0269 /* BrtBeginCellXFs */) {\n\t\t\t\t\tstyles.CellXf.push(val);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase 0x0030: /* BrtStyle */\n\t\t\tcase 0x01FB: /* BrtDXF */\n\t\t\tcase 0x023C: /* BrtMRUColor */\n\t\t\tcase 0x01DB: /* BrtIndexedColor */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0493: /* BrtDXF14 */\n\t\t\tcase 0x0836: /* BrtDXF15 */\n\t\t\tcase 0x046A: /* BrtSlicerStyleElement */\n\t\t\tcase 0x0200: /* BrtTableStyleElement */\n\t\t\tcase 0x082F: /* BrtTimelineStyleElement */\n\t\t\tcase 0x0C00: /* BrtUid */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* BrtFRTBegin */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* BrtFRTEnd */\n\t\t\t\tpass = false; break;\n\t\t\tcase 0x0025: /* BrtACBegin */\n\t\t\t\tstate.push(RT); pass = true; break;\n\t\t\tcase 0x0026: /* BrtACEnd */\n\t\t\t\tstate.pop(); pass = false; break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T > 0) state.push(RT);\n\t\t\t\telse if(R.T < 0) state.pop();\n\t\t\t\telse if(!pass || (opts.WTF && state[state.length-1] != 0x0025 /* BrtACBegin */)) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t});\n\treturn styles;\n}\n\nfunction write_FMTS_bin(ba, NF/*:?SSFTable*/) {\n\tif(!NF) return;\n\tvar cnt = 0;\n\t[[5,8],[23,26],[41,44],[/*63*/50,/*66],[164,*/392]].forEach(function(r) {\n\t\t/*:: if(!NF) return; */\n\t\tfor(var i = r[0]; i <= r[1]; ++i) if(NF[i] != null) ++cnt;\n\t});\n\n\tif(cnt == 0) return;\n\twrite_record(ba, 0x0267 /* BrtBeginFmts */, write_UInt32LE(cnt));\n\t[[5,8],[23,26],[41,44],[/*63*/50,/*66],[164,*/392]].forEach(function(r) {\n\t\t/*:: if(!NF) return; */\n\t\tfor(var i = r[0]; i <= r[1]; ++i) if(NF[i] != null) write_record(ba, 0x002C /* BrtFmt */, write_BrtFmt(i, NF[i]));\n\t});\n\twrite_record(ba, 0x0268 /* BrtEndFmts */);\n}\n\nfunction write_FONTS_bin(ba/*::, data*/) {\n\tvar cnt = 1;\n\n\tif(cnt == 0) return;\n\twrite_record(ba, 0x0263 /* BrtBeginFonts */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x002B /* BrtFont */, write_BrtFont({\n\t\tsz:12,\n\t\tcolor: {theme:1},\n\t\tname: \"Calibri\",\n\t\tfamily: 2,\n\t\tscheme: \"minor\"\n\t}));\n\t/* 1*65491BrtFont [ACFONTS] */\n\twrite_record(ba, 0x0264 /* BrtEndFonts */);\n}\n\nfunction write_FILLS_bin(ba/*::, data*/) {\n\tvar cnt = 2;\n\n\tif(cnt == 0) return;\n\twrite_record(ba, 0x025B /* BrtBeginFills */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x002D /* BrtFill */, write_BrtFill({patternType:\"none\"}));\n\twrite_record(ba, 0x002D /* BrtFill */, write_BrtFill({patternType:\"gray125\"}));\n\t/* 1*65431BrtFill */\n\twrite_record(ba, 0x025C /* BrtEndFills */);\n}\n\nfunction write_BORDERS_bin(ba/*::, data*/) {\n\tvar cnt = 1;\n\n\tif(cnt == 0) return;\n\twrite_record(ba, 0x0265 /* BrtBeginBorders */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x002E /* BrtBorder */, write_BrtBorder({}));\n\t/* 1*65430BrtBorder */\n\twrite_record(ba, 0x0266 /* BrtEndBorders */);\n}\n\nfunction write_CELLSTYLEXFS_bin(ba/*::, data*/) {\n\tvar cnt = 1;\n\twrite_record(ba, 0x0272 /* BrtBeginCellStyleXFs */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x002F /* BrtXF */, write_BrtXF({\n\t\tnumFmtId: 0,\n\t\tfontId: 0,\n\t\tfillId: 0,\n\t\tborderId: 0\n\t}, 0xFFFF));\n\t/* 1*65430(BrtXF *FRT) */\n\twrite_record(ba, 0x0273 /* BrtEndCellStyleXFs */);\n}\n\nfunction write_CELLXFS_bin(ba, data) {\n\twrite_record(ba, 0x0269 /* BrtBeginCellXFs */, write_UInt32LE(data.length));\n\tdata.forEach(function(c) { write_record(ba, 0x002F /* BrtXF */, write_BrtXF(c,0)); });\n\t/* 1*65430(BrtXF *FRT) */\n\twrite_record(ba, 0x026A /* BrtEndCellXFs */);\n}\n\nfunction write_STYLES_bin(ba/*::, data*/) {\n\tvar cnt = 1;\n\n\twrite_record(ba, 0x026B /* BrtBeginStyles */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x0030 /* BrtStyle */, write_BrtStyle({\n\t\txfId:0,\n\t\tbuiltinId:0,\n\t\tname:\"Normal\"\n\t}));\n\t/* 1*65430(BrtStyle *FRT) */\n\twrite_record(ba, 0x026C /* BrtEndStyles */);\n}\n\nfunction write_DXFS_bin(ba/*::, data*/) {\n\tvar cnt = 0;\n\n\twrite_record(ba, 0x01F9 /* BrtBeginDXFs */, write_UInt32LE(cnt));\n\t/* *2147483647(BrtDXF *FRT) */\n\twrite_record(ba, 0x01FA /* BrtEndDXFs */);\n}\n\nfunction write_TABLESTYLES_bin(ba/*::, data*/) {\n\tvar cnt = 0;\n\n\twrite_record(ba, 0x01FC /* BrtBeginTableStyles */, write_BrtBeginTableStyles(cnt, \"TableStyleMedium9\", \"PivotStyleMedium4\"));\n\t/* *TABLESTYLE */\n\twrite_record(ba, 0x01FD /* BrtEndTableStyles */);\n}\n\nfunction write_COLORPALETTE_bin(/*::ba, data*/) {\n\treturn;\n\t/* BrtBeginColorPalette [INDEXEDCOLORS] [MRUCOLORS] BrtEndColorPalette */\n}\n\n/* [MS-XLSB] 2.1.7.50 Styles */\nfunction write_sty_bin(wb, opts) {\n\tvar ba = buf_array();\n\twrite_record(ba, 0x0116 /* BrtBeginStyleSheet */);\n\twrite_FMTS_bin(ba, wb.SSF);\n\twrite_FONTS_bin(ba, wb);\n\twrite_FILLS_bin(ba, wb);\n\twrite_BORDERS_bin(ba, wb);\n\twrite_CELLSTYLEXFS_bin(ba, wb);\n\twrite_CELLXFS_bin(ba, opts.cellXfs);\n\twrite_STYLES_bin(ba, wb);\n\twrite_DXFS_bin(ba, wb);\n\twrite_TABLESTYLES_bin(ba, wb);\n\twrite_COLORPALETTE_bin(ba, wb);\n\t/* FRTSTYLESHEET*/\n\twrite_record(ba, 0x0117 /* BrtEndStyleSheet */);\n\treturn ba.end();\n}\n/* Even though theme layout is dk1 lt1 dk2 lt2, true order is lt1 dk1 lt2 dk2 */\nvar XLSXThemeClrScheme = [\n\t'</a:lt1>', '</a:dk1>', '</a:lt2>', '</a:dk2>',\n\t'</a:accent1>', '</a:accent2>', '</a:accent3>',\n\t'</a:accent4>', '</a:accent5>', '</a:accent6>',\n\t'</a:hlink>', '</a:folHlink>'\n];\n/* 20.1.6.2 clrScheme CT_ColorScheme */\nfunction parse_clrScheme(t, themes, opts) {\n\tthemes.themeElements.clrScheme = [];\n\tvar color = {};\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\t/* 20.1.6.2 clrScheme (Color Scheme) CT_ColorScheme */\n\t\t\tcase '<a:clrScheme': case '</a:clrScheme>': break;\n\n\t\t\t/* 20.1.2.3.32 srgbClr CT_SRgbColor */\n\t\t\tcase '<a:srgbClr':\n\t\t\t\tcolor.rgb = y.val; break;\n\n\t\t\t/* 20.1.2.3.33 sysClr CT_SystemColor */\n\t\t\tcase '<a:sysClr':\n\t\t\t\tcolor.rgb = y.lastClr; break;\n\n\t\t\t/* 20.1.4.1.1 accent1 (Accent 1) */\n\t\t\t/* 20.1.4.1.2 accent2 (Accent 2) */\n\t\t\t/* 20.1.4.1.3 accent3 (Accent 3) */\n\t\t\t/* 20.1.4.1.4 accent4 (Accent 4) */\n\t\t\t/* 20.1.4.1.5 accent5 (Accent 5) */\n\t\t\t/* 20.1.4.1.6 accent6 (Accent 6) */\n\t\t\t/* 20.1.4.1.9 dk1 (Dark 1) */\n\t\t\t/* 20.1.4.1.10 dk2 (Dark 2) */\n\t\t\t/* 20.1.4.1.15 folHlink (Followed Hyperlink) */\n\t\t\t/* 20.1.4.1.19 hlink (Hyperlink) */\n\t\t\t/* 20.1.4.1.22 lt1 (Light 1) */\n\t\t\t/* 20.1.4.1.23 lt2 (Light 2) */\n\t\t\tcase '<a:dk1>': case '</a:dk1>':\n\t\t\tcase '<a:lt1>': case '</a:lt1>':\n\t\t\tcase '<a:dk2>': case '</a:dk2>':\n\t\t\tcase '<a:lt2>': case '</a:lt2>':\n\t\t\tcase '<a:accent1>': case '</a:accent1>':\n\t\t\tcase '<a:accent2>': case '</a:accent2>':\n\t\t\tcase '<a:accent3>': case '</a:accent3>':\n\t\t\tcase '<a:accent4>': case '</a:accent4>':\n\t\t\tcase '<a:accent5>': case '</a:accent5>':\n\t\t\tcase '<a:accent6>': case '</a:accent6>':\n\t\t\tcase '<a:hlink>': case '</a:hlink>':\n\t\t\tcase '<a:folHlink>': case '</a:folHlink>':\n\t\t\t\tif (y[0].charAt(1) === '/') {\n\t\t\t\t\tthemes.themeElements.clrScheme[XLSXThemeClrScheme.indexOf(y[0])] = color;\n\t\t\t\t\tcolor = {};\n\t\t\t\t} else {\n\t\t\t\t\tcolor.name = y[0].slice(3, y[0].length - 1);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tdefault: if(opts && opts.WTF) throw new Error('Unrecognized ' + y[0] + ' in clrScheme');\n\t\t}\n\t});\n}\n\n/* 20.1.4.1.18 fontScheme CT_FontScheme */\nfunction parse_fontScheme(/*::t, themes, opts*/) { }\n\n/* 20.1.4.1.15 fmtScheme CT_StyleMatrix */\nfunction parse_fmtScheme(/*::t, themes, opts*/) { }\n\nvar clrsregex = /<a:clrScheme([^>]*)>[\\s\\S]*<\\/a:clrScheme>/;\nvar fntsregex = /<a:fontScheme([^>]*)>[\\s\\S]*<\\/a:fontScheme>/;\nvar fmtsregex = /<a:fmtScheme([^>]*)>[\\s\\S]*<\\/a:fmtScheme>/;\n\n/* 20.1.6.10 themeElements CT_BaseStyles */\nfunction parse_themeElements(data, themes, opts) {\n\tthemes.themeElements = {};\n\n\tvar t;\n\n\t[\n\t\t/* clrScheme CT_ColorScheme */\n\t\t['clrScheme', clrsregex, parse_clrScheme],\n\t\t/* fontScheme CT_FontScheme */\n\t\t['fontScheme', fntsregex, parse_fontScheme],\n\t\t/* fmtScheme CT_StyleMatrix */\n\t\t['fmtScheme', fmtsregex, parse_fmtScheme]\n\t].forEach(function(m) {\n\t\tif(!(t=data.match(m[1]))) throw new Error(m[0] + ' not found in themeElements');\n\t\tm[2](t, themes, opts);\n\t});\n}\n\nvar themeltregex = /<a:themeElements([^>]*)>[\\s\\S]*<\\/a:themeElements>/;\n\n/* 14.2.7 Theme Part */\nfunction parse_theme_xml(data/*:string*/, opts) {\n\t/* 20.1.6.9 theme CT_OfficeStyleSheet */\n\tif(!data || data.length === 0) data = write_theme();\n\n\tvar t;\n\tvar themes = {};\n\n\t/* themeElements CT_BaseStyles */\n\tif(!(t=data.match(themeltregex))) throw new Error('themeElements not found in theme');\n\tparse_themeElements(t[0], themes, opts);\n\tthemes.raw = data;\n\treturn themes;\n}\n\nfunction write_theme(Themes, opts)/*:string*/ {\n\tif(opts && opts.themeXLSX) return opts.themeXLSX;\n\tif(Themes && typeof Themes.raw == \"string\") return Themes.raw;\n\tvar o = [XML_HEADER];\n\to[o.length] = '<a:theme xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\" name=\"Office Theme\">';\n\to[o.length] = '<a:themeElements>';\n\n\to[o.length] = '<a:clrScheme name=\"Office\">';\n\to[o.length] = '<a:dk1><a:sysClr val=\"windowText\" lastClr=\"000000\"/></a:dk1>';\n\to[o.length] = '<a:lt1><a:sysClr val=\"window\" lastClr=\"FFFFFF\"/></a:lt1>';\n\to[o.length] = '<a:dk2><a:srgbClr val=\"1F497D\"/></a:dk2>';\n\to[o.length] = '<a:lt2><a:srgbClr val=\"EEECE1\"/></a:lt2>';\n\to[o.length] = '<a:accent1><a:srgbClr val=\"4F81BD\"/></a:accent1>';\n\to[o.length] = '<a:accent2><a:srgbClr val=\"C0504D\"/></a:accent2>';\n\to[o.length] = '<a:accent3><a:srgbClr val=\"9BBB59\"/></a:accent3>';\n\to[o.length] = '<a:accent4><a:srgbClr val=\"8064A2\"/></a:accent4>';\n\to[o.length] = '<a:accent5><a:srgbClr val=\"4BACC6\"/></a:accent5>';\n\to[o.length] = '<a:accent6><a:srgbClr val=\"F79646\"/></a:accent6>';\n\to[o.length] = '<a:hlink><a:srgbClr val=\"0000FF\"/></a:hlink>';\n\to[o.length] = '<a:folHlink><a:srgbClr val=\"800080\"/></a:folHlink>';\n\to[o.length] = '</a:clrScheme>';\n\n\to[o.length] = '<a:fontScheme name=\"Office\">';\n\to[o.length] = '<a:majorFont>';\n\to[o.length] = '<a:latin typeface=\"Cambria\"/>';\n\to[o.length] = '<a:ea typeface=\"\"/>';\n\to[o.length] = '<a:cs typeface=\"\"/>';\n\to[o.length] = '<a:font script=\"Jpan\" typeface=\"MS Pゴシック\"/>';\n\to[o.length] = '<a:font script=\"Hang\" typeface=\"맑은 고딕\"/>';\n\to[o.length] = '<a:font script=\"Hans\" typeface=\"宋体\"/>';\n\to[o.length] = '<a:font script=\"Hant\" typeface=\"新細明體\"/>';\n\to[o.length] = '<a:font script=\"Arab\" typeface=\"Times New Roman\"/>';\n\to[o.length] = '<a:font script=\"Hebr\" typeface=\"Times New Roman\"/>';\n\to[o.length] = '<a:font script=\"Thai\" typeface=\"Tahoma\"/>';\n\to[o.length] = '<a:font script=\"Ethi\" typeface=\"Nyala\"/>';\n\to[o.length] = '<a:font script=\"Beng\" typeface=\"Vrinda\"/>';\n\to[o.length] = '<a:font script=\"Gujr\" typeface=\"Shruti\"/>';\n\to[o.length] = '<a:font script=\"Khmr\" typeface=\"MoolBoran\"/>';\n\to[o.length] = '<a:font script=\"Knda\" typeface=\"Tunga\"/>';\n\to[o.length] = '<a:font script=\"Guru\" typeface=\"Raavi\"/>';\n\to[o.length] = '<a:font script=\"Cans\" typeface=\"Euphemia\"/>';\n\to[o.length] = '<a:font script=\"Cher\" typeface=\"Plantagenet Cherokee\"/>';\n\to[o.length] = '<a:font script=\"Yiii\" typeface=\"Microsoft Yi Baiti\"/>';\n\to[o.length] = '<a:font script=\"Tibt\" typeface=\"Microsoft Himalaya\"/>';\n\to[o.length] = '<a:font script=\"Thaa\" typeface=\"MV Boli\"/>';\n\to[o.length] = '<a:font script=\"Deva\" typeface=\"Mangal\"/>';\n\to[o.length] = '<a:font script=\"Telu\" typeface=\"Gautami\"/>';\n\to[o.length] = '<a:font script=\"Taml\" typeface=\"Latha\"/>';\n\to[o.length] = '<a:font script=\"Syrc\" typeface=\"Estrangelo Edessa\"/>';\n\to[o.length] = '<a:font script=\"Orya\" typeface=\"Kalinga\"/>';\n\to[o.length] = '<a:font script=\"Mlym\" typeface=\"Kartika\"/>';\n\to[o.length] = '<a:font script=\"Laoo\" typeface=\"DokChampa\"/>';\n\to[o.length] = '<a:font script=\"Sinh\" typeface=\"Iskoola Pota\"/>';\n\to[o.length] = '<a:font script=\"Mong\" typeface=\"Mongolian Baiti\"/>';\n\to[o.length] = '<a:font script=\"Viet\" typeface=\"Times New Roman\"/>';\n\to[o.length] = '<a:font script=\"Uigh\" typeface=\"Microsoft Uighur\"/>';\n\to[o.length] = '<a:font script=\"Geor\" typeface=\"Sylfaen\"/>';\n\to[o.length] = '</a:majorFont>';\n\to[o.length] = '<a:minorFont>';\n\to[o.length] = '<a:latin typeface=\"Calibri\"/>';\n\to[o.length] = '<a:ea typeface=\"\"/>';\n\to[o.length] = '<a:cs typeface=\"\"/>';\n\to[o.length] = '<a:font script=\"Jpan\" typeface=\"MS Pゴシック\"/>';\n\to[o.length] = '<a:font script=\"Hang\" typeface=\"맑은 고딕\"/>';\n\to[o.length] = '<a:font script=\"Hans\" typeface=\"宋体\"/>';\n\to[o.length] = '<a:font script=\"Hant\" typeface=\"新細明體\"/>';\n\to[o.length] = '<a:font script=\"Arab\" typeface=\"Arial\"/>';\n\to[o.length] = '<a:font script=\"Hebr\" typeface=\"Arial\"/>';\n\to[o.length] = '<a:font script=\"Thai\" typeface=\"Tahoma\"/>';\n\to[o.length] = '<a:font script=\"Ethi\" typeface=\"Nyala\"/>';\n\to[o.length] = '<a:font script=\"Beng\" typeface=\"Vrinda\"/>';\n\to[o.length] = '<a:font script=\"Gujr\" typeface=\"Shruti\"/>';\n\to[o.length] = '<a:font script=\"Khmr\" typeface=\"DaunPenh\"/>';\n\to[o.length] = '<a:font script=\"Knda\" typeface=\"Tunga\"/>';\n\to[o.length] = '<a:font script=\"Guru\" typeface=\"Raavi\"/>';\n\to[o.length] = '<a:font script=\"Cans\" typeface=\"Euphemia\"/>';\n\to[o.length] = '<a:font script=\"Cher\" typeface=\"Plantagenet Cherokee\"/>';\n\to[o.length] = '<a:font script=\"Yiii\" typeface=\"Microsoft Yi Baiti\"/>';\n\to[o.length] = '<a:font script=\"Tibt\" typeface=\"Microsoft Himalaya\"/>';\n\to[o.length] = '<a:font script=\"Thaa\" typeface=\"MV Boli\"/>';\n\to[o.length] = '<a:font script=\"Deva\" typeface=\"Mangal\"/>';\n\to[o.length] = '<a:font script=\"Telu\" typeface=\"Gautami\"/>';\n\to[o.length] = '<a:font script=\"Taml\" typeface=\"Latha\"/>';\n\to[o.length] = '<a:font script=\"Syrc\" typeface=\"Estrangelo Edessa\"/>';\n\to[o.length] = '<a:font script=\"Orya\" typeface=\"Kalinga\"/>';\n\to[o.length] = '<a:font script=\"Mlym\" typeface=\"Kartika\"/>';\n\to[o.length] = '<a:font script=\"Laoo\" typeface=\"DokChampa\"/>';\n\to[o.length] = '<a:font script=\"Sinh\" typeface=\"Iskoola Pota\"/>';\n\to[o.length] = '<a:font script=\"Mong\" typeface=\"Mongolian Baiti\"/>';\n\to[o.length] = '<a:font script=\"Viet\" typeface=\"Arial\"/>';\n\to[o.length] = '<a:font script=\"Uigh\" typeface=\"Microsoft Uighur\"/>';\n\to[o.length] = '<a:font script=\"Geor\" typeface=\"Sylfaen\"/>';\n\to[o.length] = '</a:minorFont>';\n\to[o.length] = '</a:fontScheme>';\n\n\to[o.length] = '<a:fmtScheme name=\"Office\">';\n\to[o.length] = '<a:fillStyleLst>';\n\to[o.length] = '<a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill>';\n\to[o.length] = '<a:gradFill rotWithShape=\"1\">';\n\to[o.length] = '<a:gsLst>';\n\to[o.length] = '<a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"50000\"/><a:satMod val=\"300000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '<a:gs pos=\"35000\"><a:schemeClr val=\"phClr\"><a:tint val=\"37000\"/><a:satMod val=\"300000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '<a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:tint val=\"15000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '</a:gsLst>';\n\to[o.length] = '<a:lin ang=\"16200000\" scaled=\"1\"/>';\n\to[o.length] = '</a:gradFill>';\n\to[o.length] = '<a:gradFill rotWithShape=\"1\">';\n\to[o.length] = '<a:gsLst>';\n\to[o.length] = '<a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"100000\"/><a:shade val=\"100000\"/><a:satMod val=\"130000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '<a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:tint val=\"50000\"/><a:shade val=\"100000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '</a:gsLst>';\n\to[o.length] = '<a:lin ang=\"16200000\" scaled=\"0\"/>';\n\to[o.length] = '</a:gradFill>';\n\to[o.length] = '</a:fillStyleLst>';\n\to[o.length] = '<a:lnStyleLst>';\n\to[o.length] = '<a:ln w=\"9525\" cap=\"flat\" cmpd=\"sng\" algn=\"ctr\"><a:solidFill><a:schemeClr val=\"phClr\"><a:shade val=\"95000\"/><a:satMod val=\"105000\"/></a:schemeClr></a:solidFill><a:prstDash val=\"solid\"/></a:ln>';\n\to[o.length] = '<a:ln w=\"25400\" cap=\"flat\" cmpd=\"sng\" algn=\"ctr\"><a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill><a:prstDash val=\"solid\"/></a:ln>';\n\to[o.length] = '<a:ln w=\"38100\" cap=\"flat\" cmpd=\"sng\" algn=\"ctr\"><a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill><a:prstDash val=\"solid\"/></a:ln>';\n\to[o.length] = '</a:lnStyleLst>';\n\to[o.length] = '<a:effectStyleLst>';\n\to[o.length] = '<a:effectStyle>';\n\to[o.length] = '<a:effectLst>';\n\to[o.length] = '<a:outerShdw blurRad=\"40000\" dist=\"20000\" dir=\"5400000\" rotWithShape=\"0\"><a:srgbClr val=\"000000\"><a:alpha val=\"38000\"/></a:srgbClr></a:outerShdw>';\n\to[o.length] = '</a:effectLst>';\n\to[o.length] = '</a:effectStyle>';\n\to[o.length] = '<a:effectStyle>';\n\to[o.length] = '<a:effectLst>';\n\to[o.length] = '<a:outerShdw blurRad=\"40000\" dist=\"23000\" dir=\"5400000\" rotWithShape=\"0\"><a:srgbClr val=\"000000\"><a:alpha val=\"35000\"/></a:srgbClr></a:outerShdw>';\n\to[o.length] = '</a:effectLst>';\n\to[o.length] = '</a:effectStyle>';\n\to[o.length] = '<a:effectStyle>';\n\to[o.length] = '<a:effectLst>';\n\to[o.length] = '<a:outerShdw blurRad=\"40000\" dist=\"23000\" dir=\"5400000\" rotWithShape=\"0\"><a:srgbClr val=\"000000\"><a:alpha val=\"35000\"/></a:srgbClr></a:outerShdw>';\n\to[o.length] = '</a:effectLst>';\n\to[o.length] = '<a:scene3d><a:camera prst=\"orthographicFront\"><a:rot lat=\"0\" lon=\"0\" rev=\"0\"/></a:camera><a:lightRig rig=\"threePt\" dir=\"t\"><a:rot lat=\"0\" lon=\"0\" rev=\"1200000\"/></a:lightRig></a:scene3d>';\n\to[o.length] = '<a:sp3d><a:bevelT w=\"63500\" h=\"25400\"/></a:sp3d>';\n\to[o.length] = '</a:effectStyle>';\n\to[o.length] = '</a:effectStyleLst>';\n\to[o.length] = '<a:bgFillStyleLst>';\n\to[o.length] = '<a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill>';\n\to[o.length] = '<a:gradFill rotWithShape=\"1\">';\n\to[o.length] = '<a:gsLst>';\n\to[o.length] = '<a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"40000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '<a:gs pos=\"40000\"><a:schemeClr val=\"phClr\"><a:tint val=\"45000\"/><a:shade val=\"99000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '<a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:shade val=\"20000\"/><a:satMod val=\"255000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '</a:gsLst>';\n\to[o.length] = '<a:path path=\"circle\"><a:fillToRect l=\"50000\" t=\"-80000\" r=\"50000\" b=\"180000\"/></a:path>';\n\to[o.length] = '</a:gradFill>';\n\to[o.length] = '<a:gradFill rotWithShape=\"1\">';\n\to[o.length] = '<a:gsLst>';\n\to[o.length] = '<a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"80000\"/><a:satMod val=\"300000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '<a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:shade val=\"30000\"/><a:satMod val=\"200000\"/></a:schemeClr></a:gs>';\n\to[o.length] = '</a:gsLst>';\n\to[o.length] = '<a:path path=\"circle\"><a:fillToRect l=\"50000\" t=\"50000\" r=\"50000\" b=\"50000\"/></a:path>';\n\to[o.length] = '</a:gradFill>';\n\to[o.length] = '</a:bgFillStyleLst>';\n\to[o.length] = '</a:fmtScheme>';\n\to[o.length] = '</a:themeElements>';\n\n\to[o.length] = '<a:objectDefaults>';\n\to[o.length] = '<a:spDef>';\n\to[o.length] = '<a:spPr/><a:bodyPr/><a:lstStyle/><a:style><a:lnRef idx=\"1\"><a:schemeClr val=\"accent1\"/></a:lnRef><a:fillRef idx=\"3\"><a:schemeClr val=\"accent1\"/></a:fillRef><a:effectRef idx=\"2\"><a:schemeClr val=\"accent1\"/></a:effectRef><a:fontRef idx=\"minor\"><a:schemeClr val=\"lt1\"/></a:fontRef></a:style>';\n\to[o.length] = '</a:spDef>';\n\to[o.length] = '<a:lnDef>';\n\to[o.length] = '<a:spPr/><a:bodyPr/><a:lstStyle/><a:style><a:lnRef idx=\"2\"><a:schemeClr val=\"accent1\"/></a:lnRef><a:fillRef idx=\"0\"><a:schemeClr val=\"accent1\"/></a:fillRef><a:effectRef idx=\"1\"><a:schemeClr val=\"accent1\"/></a:effectRef><a:fontRef idx=\"minor\"><a:schemeClr val=\"tx1\"/></a:fontRef></a:style>';\n\to[o.length] = '</a:lnDef>';\n\to[o.length] = '</a:objectDefaults>';\n\to[o.length] = '<a:extraClrSchemeLst/>';\n\to[o.length] = '</a:theme>';\n\treturn o.join(\"\");\n}\n/* [MS-XLS] 2.4.326 TODO: payload is a zip file */\nfunction parse_Theme(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar dwThemeVersion = blob.read_shift(4);\n\tif(dwThemeVersion === 124226) return;\n\tif(!opts.cellStyles) { blob.l = end; return; }\n\tvar data = blob.slice(blob.l);\n\tblob.l = end;\n\tvar zip; try { zip = zip_read(data, {type: \"array\"}); } catch(e) { return; }\n\tvar themeXML = getzipstr(zip, \"theme/theme/theme1.xml\", true);\n\tif(!themeXML) return;\n\treturn parse_theme_xml(themeXML, opts);\n}\n\n/* 2.5.49 */\nfunction parse_ColorTheme(blob/*::, length*/) { return blob.read_shift(4); }\n\n/* 2.5.155 */\nfunction parse_FullColorExt(blob/*::, length*/) {\n\tvar o = {};\n\to.xclrType = blob.read_shift(2);\n\to.nTintShade = blob.read_shift(2);\n\tswitch(o.xclrType) {\n\t\tcase 0: blob.l += 4; break;\n\t\tcase 1: o.xclrValue = parse_IcvXF(blob, 4); break;\n\t\tcase 2: o.xclrValue = parse_LongRGBA(blob, 4); break;\n\t\tcase 3: o.xclrValue = parse_ColorTheme(blob, 4); break;\n\t\tcase 4: blob.l += 4; break;\n\t}\n\tblob.l += 8;\n\treturn o;\n}\n\n/* 2.5.164 TODO: read 7 bits*/\nfunction parse_IcvXF(blob, length) {\n\treturn parsenoop(blob, length);\n}\n\n/* 2.5.280 */\nfunction parse_XFExtGradient(blob, length) {\n\treturn parsenoop(blob, length);\n}\n\n/* [MS-XLS] 2.5.108 */\nfunction parse_ExtProp(blob/*::, length*/)/*:Array<any>*/ {\n\tvar extType = blob.read_shift(2);\n\tvar cb = blob.read_shift(2) - 4;\n\tvar o = [extType];\n\tswitch(extType) {\n\t\tcase 0x04: case 0x05: case 0x07: case 0x08:\n\t\tcase 0x09: case 0x0A: case 0x0B: case 0x0D:\n\t\t\to[1] = parse_FullColorExt(blob, cb); break;\n\t\tcase 0x06: o[1] = parse_XFExtGradient(blob, cb); break;\n\t\tcase 0x0E: case 0x0F: o[1] = blob.read_shift(cb === 1 ? 1 : 2); break;\n\t\tdefault: throw new Error(\"Unrecognized ExtProp type: \" + extType + \" \" + cb);\n\t}\n\treturn o;\n}\n\n/* 2.4.355 */\nfunction parse_XFExt(blob, length) {\n\tvar end = blob.l + length;\n\tblob.l += 2;\n\tvar ixfe = blob.read_shift(2);\n\tblob.l += 2;\n\tvar cexts = blob.read_shift(2);\n\tvar ext/*:AOA*/ = [];\n\twhile(cexts-- > 0) ext.push(parse_ExtProp(blob, end-blob.l));\n\treturn {ixfe:ixfe, ext:ext};\n}\n\n/* xf is an XF, see parse_XFExt for xfext */\nfunction update_xfext(xf, xfext) {\n\txfext.forEach(function(xfe) {\n\t\tswitch(xfe[0]) { /* 2.5.108 extPropData */\n\t\t\tcase 0x04: break; /* foreground color */\n\t\t\tcase 0x05: break; /* background color */\n\t\t\tcase 0x06: break; /* gradient fill */\n\t\t\tcase 0x07: break; /* top cell border color */\n\t\t\tcase 0x08: break; /* bottom cell border color */\n\t\t\tcase 0x09: break; /* left cell border color */\n\t\t\tcase 0x0a: break; /* right cell border color */\n\t\t\tcase 0x0b: break; /* diagonal cell border color */\n\t\t\tcase 0x0d: /* text color */\n\t\t\t\tbreak;\n\t\t\tcase 0x0e: break; /* font scheme */\n\t\t\tcase 0x0f: break; /* indentation level */\n\t\t}\n\t});\n}\n\nfunction parse_BrtMdtinfo(data, length) {\n return {\n flags: data.read_shift(4),\n version: data.read_shift(4),\n name: parse_XLWideString(data, length - 8)\n };\n}\nfunction write_BrtMdtinfo(data) {\n var o = new_buf(12 + 2 * data.name.length);\n o.write_shift(4, data.flags);\n o.write_shift(4, data.version);\n write_XLWideString(data.name, o);\n return o.slice(0, o.l);\n}\nfunction parse_BrtMdb(data) {\n var out = [];\n var cnt = data.read_shift(4);\n while (cnt-- > 0)\n out.push([data.read_shift(4), data.read_shift(4)]);\n return out;\n}\nfunction write_BrtMdb(mdb) {\n var o = new_buf(4 + 8 * mdb.length);\n o.write_shift(4, mdb.length);\n for (var i = 0; i < mdb.length; ++i) {\n o.write_shift(4, mdb[i][0]);\n o.write_shift(4, mdb[i][1]);\n }\n return o;\n}\nfunction write_BrtBeginEsfmd(cnt, name) {\n var o = new_buf(8 + 2 * name.length);\n o.write_shift(4, cnt);\n write_XLWideString(name, o);\n return o.slice(0, o.l);\n}\nfunction parse_BrtBeginEsmdb(data) {\n data.l += 4;\n return data.read_shift(4) != 0;\n}\nfunction write_BrtBeginEsmdb(cnt, cm) {\n var o = new_buf(8);\n o.write_shift(4, cnt);\n o.write_shift(4, cm ? 1 : 0);\n return o;\n}\nfunction parse_xlmeta_bin(data, name, _opts) {\n var out = { Types: [], Cell: [], Value: [] };\n var opts = _opts || {};\n var state = [];\n var pass = false;\n var metatype = 2;\n recordhopper(data, function(val, R, RT) {\n switch (RT) {\n case 335:\n out.Types.push({ name: val.name });\n break;\n case 51:\n val.forEach(function(r) {\n if (metatype == 1)\n out.Cell.push({ type: out.Types[r[0] - 1].name, index: r[1] });\n else if (metatype == 0)\n out.Value.push({ type: out.Types[r[0] - 1].name, index: r[1] });\n });\n break;\n case 337:\n metatype = val ? 1 : 0;\n break;\n case 338:\n metatype = 2;\n break;\n case 35:\n state.push(RT);\n pass = true;\n break;\n case 36:\n state.pop();\n pass = false;\n break;\n default:\n if (R.T) {\n } else if (!pass || opts.WTF && state[state.length - 1] != 35)\n throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n }\n });\n return out;\n}\nfunction write_xlmeta_bin() {\n var ba = buf_array();\n write_record(ba, 332);\n write_record(ba, 334, write_UInt32LE(1));\n write_record(ba, 335, write_BrtMdtinfo({\n name: \"XLDAPR\",\n version: 12e4,\n flags: 3496657072\n }));\n write_record(ba, 336);\n write_record(ba, 339, write_BrtBeginEsfmd(1, \"XLDAPR\"));\n write_record(ba, 52);\n write_record(ba, 35, write_UInt32LE(514));\n write_record(ba, 4096, write_UInt32LE(0));\n write_record(ba, 4097, writeuint16(1));\n write_record(ba, 36);\n write_record(ba, 53);\n write_record(ba, 340);\n write_record(ba, 337, write_BrtBeginEsmdb(1, true));\n write_record(ba, 51, write_BrtMdb([[1, 0]]));\n write_record(ba, 338);\n write_record(ba, 333);\n return ba.end();\n}\nfunction parse_xlmeta_xml(data, name, opts) {\n var out = { Types: [], Cell: [], Value: [] };\n if (!data)\n return out;\n var pass = false;\n var metatype = 2;\n var lastmeta;\n data.replace(tagregex, function(x) {\n var y = parsexmltag(x);\n switch (strip_ns(y[0])) {\n case \"<?xml\":\n break;\n case \"<metadata\":\n case \"</metadata>\":\n break;\n case \"<metadataTypes\":\n case \"</metadataTypes>\":\n break;\n case \"<metadataType\":\n out.Types.push({ name: y.name });\n break;\n case \"</metadataType>\":\n break;\n case \"<futureMetadata\":\n for (var j = 0; j < out.Types.length; ++j)\n if (out.Types[j].name == y.name)\n lastmeta = out.Types[j];\n break;\n case \"</futureMetadata>\":\n break;\n case \"<bk>\":\n break;\n case \"</bk>\":\n break;\n case \"<rc\":\n if (metatype == 1)\n out.Cell.push({ type: out.Types[y.t - 1].name, index: +y.v });\n else if (metatype == 0)\n out.Value.push({ type: out.Types[y.t - 1].name, index: +y.v });\n break;\n case \"</rc>\":\n break;\n case \"<cellMetadata\":\n metatype = 1;\n break;\n case \"</cellMetadata>\":\n metatype = 2;\n break;\n case \"<valueMetadata\":\n metatype = 0;\n break;\n case \"</valueMetadata>\":\n metatype = 2;\n break;\n case \"<extLst\":\n case \"<extLst>\":\n case \"</extLst>\":\n case \"<extLst/>\":\n break;\n case \"<ext\":\n pass = true;\n break;\n case \"</ext>\":\n pass = false;\n break;\n case \"<rvb\":\n if (!lastmeta)\n break;\n if (!lastmeta.offsets)\n lastmeta.offsets = [];\n lastmeta.offsets.push(+y.i);\n break;\n default:\n if (!pass && opts.WTF)\n throw new Error(\"unrecognized \" + y[0] + \" in metadata\");\n }\n return x;\n });\n return out;\n}\nfunction write_xlmeta_xml() {\n var o = [XML_HEADER];\n o.push('<metadata xmlns=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" xmlns:xlrd=\"http://schemas.microsoft.com/office/spreadsheetml/2017/richdata\" xmlns:xda=\"http://schemas.microsoft.com/office/spreadsheetml/2017/dynamicarray\">\\n <metadataTypes count=\"1\">\\n <metadataType name=\"XLDAPR\" minSupportedVersion=\"120000\" copy=\"1\" pasteAll=\"1\" pasteValues=\"1\" merge=\"1\" splitFirst=\"1\" rowColShift=\"1\" clearFormats=\"1\" clearComments=\"1\" assign=\"1\" coerce=\"1\" cellMeta=\"1\"/>\\n </metadataTypes>\\n <futureMetadata name=\"XLDAPR\" count=\"1\">\\n <bk>\\n <extLst>\\n <ext uri=\"{bdbb8cdc-fa1e-496e-a857-3c3f30c029c3}\">\\n <xda:dynamicArrayProperties fDynamic=\"1\" fCollapsed=\"0\"/>\\n </ext>\\n </extLst>\\n </bk>\\n </futureMetadata>\\n <cellMetadata count=\"1\">\\n <bk>\\n <rc t=\"1\" v=\"0\"/>\\n </bk>\\n </cellMetadata>\\n</metadata>');\n return o.join(\"\");\n}\n/* 18.6 Calculation Chain */\nfunction parse_cc_xml(data/*::, name, opts*/)/*:Array<any>*/ {\n\tvar d = [];\n\tif(!data) return d;\n\tvar i = 1;\n\t(data.match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\tcase '<?xml': break;\n\t\t\t/* 18.6.2 calcChain CT_CalcChain 1 */\n\t\t\tcase '<calcChain': case '<calcChain>': case '</calcChain>': break;\n\t\t\t/* 18.6.1 c CT_CalcCell 1 */\n\t\t\tcase '<c': delete y[0]; if(y.i) i = y.i; else y.i = i; d.push(y); break;\n\t\t}\n\t});\n\treturn d;\n}\n\n//function write_cc_xml(data, opts) { }\n\n/* [MS-XLSB] 2.6.4.1 */\nfunction parse_BrtCalcChainItem$(data) {\n\tvar out = {};\n\tout.i = data.read_shift(4);\n\tvar cell = {};\n\tcell.r = data.read_shift(4);\n\tcell.c = data.read_shift(4);\n\tout.r = encode_cell(cell);\n\tvar flags = data.read_shift(1);\n\tif(flags & 0x2) out.l = '1';\n\tif(flags & 0x8) out.a = '1';\n\treturn out;\n}\n\n/* 18.6 Calculation Chain */\nfunction parse_cc_bin(data, name, opts) {\n\tvar out = [];\n\tvar pass = false;\n\trecordhopper(data, function hopper_cc(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x003F: /* 'BrtCalcChainItem$' */\n\t\t\t\tout.push(val); break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){/* empty */}\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t});\n\treturn out;\n}\n\n//function write_cc_bin(data, opts) { }\n/* 18.14 Supplementary Workbook Data */\nfunction parse_xlink_xml(/*::data, rel, name:string, _opts*/) {\n\t//var opts = _opts || {};\n\t//if(opts.WTF) throw \"XLSX External Link\";\n}\n\n/* [MS-XLSB] 2.1.7.25 External Link */\nfunction parse_xlink_bin(data, rel, name/*:string*/, _opts) {\n\tif(!data) return data;\n\tvar opts = _opts || {};\n\n\tvar pass = false, end = false;\n\n\trecordhopper(data, function xlink_parse(val, R, RT) {\n\t\tif(end) return;\n\t\tswitch(RT) {\n\t\t\tcase 0x0167: /* 'BrtSupTabs' */\n\t\t\tcase 0x016B: /* 'BrtExternTableStart' */\n\t\t\tcase 0x016C: /* 'BrtExternTableEnd' */\n\t\t\tcase 0x016E: /* 'BrtExternRowHdr' */\n\t\t\tcase 0x016F: /* 'BrtExternCellBlank' */\n\t\t\tcase 0x0170: /* 'BrtExternCellReal' */\n\t\t\tcase 0x0171: /* 'BrtExternCellBool' */\n\t\t\tcase 0x0172: /* 'BrtExternCellError' */\n\t\t\tcase 0x0173: /* 'BrtExternCellString' */\n\t\t\tcase 0x01D8: /* 'BrtExternValueMeta' */\n\t\t\tcase 0x0241: /* 'BrtSupNameStart' */\n\t\t\tcase 0x0242: /* 'BrtSupNameValueStart' */\n\t\t\tcase 0x0243: /* 'BrtSupNameValueEnd' */\n\t\t\tcase 0x0244: /* 'BrtSupNameNum' */\n\t\t\tcase 0x0245: /* 'BrtSupNameErr' */\n\t\t\tcase 0x0246: /* 'BrtSupNameSt' */\n\t\t\tcase 0x0247: /* 'BrtSupNameNil' */\n\t\t\tcase 0x0248: /* 'BrtSupNameBool' */\n\t\t\tcase 0x0249: /* 'BrtSupNameFmla' */\n\t\t\tcase 0x024A: /* 'BrtSupNameBits' */\n\t\t\tcase 0x024B: /* 'BrtSupNameEnd' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tpass = false; break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){/* empty */}\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t}, opts);\n}\n/* 20.5 DrawingML - SpreadsheetML Drawing */\n/* 20.5.2.35 wsDr CT_Drawing */\nfunction parse_drawing(data, rels/*:any*/) {\n\tif(!data) return \"??\";\n\t/*\n\t Chartsheet Drawing:\n\t - 20.5.2.35 wsDr CT_Drawing\n\t - 20.5.2.1 absoluteAnchor CT_AbsoluteAnchor\n\t - 20.5.2.16 graphicFrame CT_GraphicalObjectFrame\n\t - 20.1.2.2.16 graphic CT_GraphicalObject\n\t - 20.1.2.2.17 graphicData CT_GraphicalObjectData\n - chart reference\n\t the actual type is based on the URI of the graphicData\n\t\tTODO: handle embedded charts and other types of graphics\n\t*/\n\tvar id = (data.match(/<c:chart [^>]*r:id=\"([^\"]*)\"/)||[\"\",\"\"])[1];\n\n\treturn rels['!id'][id].Target;\n}\n\n/* L.5.5.2 SpreadsheetML Comments + VML Schema */\nvar _shapeid = 1024;\nfunction write_comments_vml(rId/*:number*/, comments) {\n\tvar csize = [21600, 21600];\n\t/* L.5.2.1.2 Path Attribute */\n\tvar bbox = [\"m0,0l0\",csize[1],csize[0],csize[1],csize[0],\"0xe\"].join(\",\");\n\tvar o = [\n\t\twritextag(\"xml\", null, { 'xmlns:v': XLMLNS.v, 'xmlns:o': XLMLNS.o, 'xmlns:x': XLMLNS.x, 'xmlns:mv': XLMLNS.mv }).replace(/\\/>/,\">\"),\n\t\twritextag(\"o:shapelayout\", writextag(\"o:idmap\", null, {'v:ext':\"edit\", 'data':rId}), {'v:ext':\"edit\"}),\n\t\twritextag(\"v:shapetype\", [\n\t\t\twritextag(\"v:stroke\", null, {joinstyle:\"miter\"}),\n\t\t\twritextag(\"v:path\", null, {gradientshapeok:\"t\", 'o:connecttype':\"rect\"})\n\t\t].join(\"\"), {id:\"_x0000_t202\", 'o:spt':202, coordsize:csize.join(\",\"),path:bbox})\n\t];\n\twhile(_shapeid < rId * 1000) _shapeid += 1000;\n\n\tcomments.forEach(function(x) {\n\tvar c = decode_cell(x[0]);\n\tvar fillopts = /*::(*/{'color2':\"#BEFF82\", 'type':\"gradient\"}/*:: :any)*/;\n\tif(fillopts.type == \"gradient\") fillopts.angle = \"-180\";\n\tvar fillparm = fillopts.type == \"gradient\" ? writextag(\"o:fill\", null, {type:\"gradientUnscaled\", 'v:ext':\"view\"}) : null;\n\tvar fillxml = writextag('v:fill', fillparm, fillopts);\n\n\tvar shadata = ({on:\"t\", 'obscured':\"t\"}/*:any*/);\n\t++_shapeid;\n\n\to = o.concat([\n\t'<v:shape' + wxt_helper({\n\t\tid:'_x0000_s' + _shapeid,\n\t\ttype:\"#_x0000_t202\",\n\t\tstyle:\"position:absolute; margin-left:80pt;margin-top:5pt;width:104pt;height:64pt;z-index:10\" + (x[1].hidden ? \";visibility:hidden\" : \"\") ,\n\t\tfillcolor:\"#ECFAD4\",\n\t\tstrokecolor:\"#edeaa1\"\n\t}) + '>',\n\t\tfillxml,\n\t\twritextag(\"v:shadow\", null, shadata),\n\t\twritextag(\"v:path\", null, {'o:connecttype':\"none\"}),\n\t\t'<v:textbox><div style=\"text-align:left\"></div></v:textbox>',\n\t\t'<x:ClientData ObjectType=\"Note\">',\n\t\t\t'<x:MoveWithCells/>',\n\t\t\t'<x:SizeWithCells/>',\n\t\t\t/* Part 4 19.4.2.3 Anchor (Anchor) */\n\t\t\twritetag('x:Anchor', [c.c+1, 0, c.r+1, 0, c.c+3, 20, c.r+5, 20].join(\",\")),\n\t\t\twritetag('x:AutoFill', \"False\"),\n\t\t\twritetag('x:Row', String(c.r)),\n\t\t\twritetag('x:Column', String(c.c)),\n\t\t\tx[1].hidden ? '' : '<x:Visible/>',\n\t\t'</x:ClientData>',\n\t'</v:shape>'\n\t]); });\n\to.push('</xml>');\n\treturn o.join(\"\");\n}\nfunction sheet_insert_comments(sheet, comments/*:Array<RawComment>*/, threaded/*:boolean*/, people/*:?Array<any>*/) {\n\tvar dense = Array.isArray(sheet);\n\tvar cell/*:Cell*/;\n\tcomments.forEach(function(comment) {\n\t\tvar r = decode_cell(comment.ref);\n\t\tif(dense) {\n\t\t\tif(!sheet[r.r]) sheet[r.r] = [];\n\t\t\tcell = sheet[r.r][r.c];\n\t\t} else cell = sheet[comment.ref];\n\t\tif (!cell) {\n\t\t\tcell = ({t:\"z\"}/*:any*/);\n\t\t\tif(dense) sheet[r.r][r.c] = cell;\n\t\t\telse sheet[comment.ref] = cell;\n\t\t\tvar range = safe_decode_range(sheet[\"!ref\"]||\"BDWGO1000001:A1\");\n\t\t\tif(range.s.r > r.r) range.s.r = r.r;\n\t\t\tif(range.e.r < r.r) range.e.r = r.r;\n\t\t\tif(range.s.c > r.c) range.s.c = r.c;\n\t\t\tif(range.e.c < r.c) range.e.c = r.c;\n\t\t\tvar encoded = encode_range(range);\n\t\t\tif (encoded !== sheet[\"!ref\"]) sheet[\"!ref\"] = encoded;\n\t\t}\n\n\t\tif (!cell.c) cell.c = [];\n\t\tvar o/*:Comment*/ = ({a: comment.author, t: comment.t, r: comment.r, T: threaded});\n\t\tif(comment.h) o.h = comment.h;\n\n\t\t/* threaded comments always override */\n\t\tfor(var i = cell.c.length - 1; i >= 0; --i) {\n\t\t\tif(!threaded && cell.c[i].T) return;\n\t\t\tif(threaded && !cell.c[i].T) cell.c.splice(i, 1);\n\t\t}\n\t\tif(threaded && people) for(i = 0; i < people.length; ++i) {\n\t\t\tif(o.a == people[i].id) { o.a = people[i].name || o.a; break; }\n\t\t}\n\t\tcell.c.push(o);\n\t});\n}\n\n/* 18.7 Comments */\nfunction parse_comments_xml(data/*:string*/, opts)/*:Array<RawComment>*/ {\n\t/* 18.7.6 CT_Comments */\n\tif(data.match(/<(?:\\w+:)?comments *\\/>/)) return [];\n\tvar authors/*:Array<string>*/ = [];\n\tvar commentList/*:Array<RawComment>*/ = [];\n\tvar authtag = data.match(/<(?:\\w+:)?authors>([\\s\\S]*)<\\/(?:\\w+:)?authors>/);\n\tif(authtag && authtag[1]) authtag[1].split(/<\\/\\w*:?author>/).forEach(function(x) {\n\t\tif(x === \"\" || x.trim() === \"\") return;\n\t\tvar a = x.match(/<(?:\\w+:)?author[^>]*>(.*)/);\n\t\tif(a) authors.push(a[1]);\n\t});\n\tvar cmnttag = data.match(/<(?:\\w+:)?commentList>([\\s\\S]*)<\\/(?:\\w+:)?commentList>/);\n\tif(cmnttag && cmnttag[1]) cmnttag[1].split(/<\\/\\w*:?comment>/).forEach(function(x) {\n\t\tif(x === \"\" || x.trim() === \"\") return;\n\t\tvar cm = x.match(/<(?:\\w+:)?comment[^>]*>/);\n\t\tif(!cm) return;\n\t\tvar y = parsexmltag(cm[0]);\n\t\tvar comment/*:RawComment*/ = ({ author: y.authorId && authors[y.authorId] || \"sheetjsghost\", ref: y.ref, guid: y.guid }/*:any*/);\n\t\tvar cell = decode_cell(y.ref);\n\t\tif(opts.sheetRows && opts.sheetRows <= cell.r) return;\n\t\tvar textMatch = x.match(/<(?:\\w+:)?text>([\\s\\S]*)<\\/(?:\\w+:)?text>/);\n\t\tvar rt = !!textMatch && !!textMatch[1] && parse_si(textMatch[1]) || {r:\"\",t:\"\",h:\"\"};\n\t\tcomment.r = rt.r;\n\t\tif(rt.r == \"<t></t>\") rt.t = rt.h = \"\";\n\t\tcomment.t = (rt.t||\"\").replace(/\\r\\n/g,\"\\n\").replace(/\\r/g,\"\\n\");\n\t\tif(opts.cellHTML) comment.h = rt.h;\n\t\tcommentList.push(comment);\n\t});\n\treturn commentList;\n}\n\nfunction write_comments_xml(data/*::, opts*/) {\n\tvar o = [XML_HEADER, writextag('comments', null, { 'xmlns': XMLNS_main[0] })];\n\n\tvar iauthor/*:Array<string>*/ = [];\n\to.push(\"<authors>\");\n\tdata.forEach(function(x) { x[1].forEach(function(w) { var a = escapexml(w.a);\n\t\tif(iauthor.indexOf(a) == -1) {\n\t\t\tiauthor.push(a);\n\t\t\to.push(\"<author>\" + a + \"</author>\");\n\t\t}\n\t\tif(w.T && w.ID && iauthor.indexOf(\"tc=\" + w.ID) == -1) {\n\t\t\tiauthor.push(\"tc=\" + w.ID);\n\t\t\to.push(\"<author>\" + \"tc=\" + w.ID + \"</author>\");\n\t\t}\n\t}); });\n\tif(iauthor.length == 0) { iauthor.push(\"SheetJ5\"); o.push(\"<author>SheetJ5</author>\"); }\n\to.push(\"</authors>\");\n\to.push(\"<commentList>\");\n\tdata.forEach(function(d) {\n\t\t/* 18.7.3 CT_Comment */\n\t\tvar lastauthor = 0, ts = [];\n\t\tif(d[1][0] && d[1][0].T && d[1][0].ID) lastauthor = iauthor.indexOf(\"tc=\" + d[1][0].ID);\n\t\telse d[1].forEach(function(c) {\n\t\t\tif(c.a) lastauthor = iauthor.indexOf(escapexml(c.a));\n\t\t\tts.push(c.t||\"\");\n\t\t});\n\t\to.push('<comment ref=\"' + d[0] + '\" authorId=\"' + lastauthor + '\"><text>');\n\t\tif(ts.length <= 1) o.push(writetag(\"t\", escapexml(ts[0]||\"\")));\n\t\telse {\n\t\t\t/* based on Threaded Comments -> Comments projection */\n\t\t\tvar t = \"Comment:\\n \" + (ts[0]) + \"\\n\";\n\t\t\tfor(var i = 1; i < ts.length; ++i) t += \"Reply:\\n \" + ts[i] + \"\\n\";\n\t\t\to.push(writetag(\"t\", escapexml(t)));\n\t\t}\n\t\to.push('</text></comment>');\n\t});\n\to.push(\"</commentList>\");\n\tif(o.length>2) { o[o.length] = ('</comments>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n\n/* [MS-XLSX] 2.1.17 */\nfunction parse_tcmnt_xml(data/*:string*/, opts)/*:Array<RawComment>*/ {\n\tvar out = [];\n\tvar pass = false, comment = {}, tidx = 0;\n\tdata.replace(tagregex, function xml_tcmnt(x, idx) {\n\t\tvar y/*:any*/ = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<?xml': break;\n\n\t\t\t/* 2.6.207 ThreadedComments CT_ThreadedComments */\n\t\t\tcase '<ThreadedComments': break;\n\t\t\tcase '</ThreadedComments>': break;\n\n\t\t\t/* 2.6.205 threadedComment CT_ThreadedComment */\n\t\t\tcase '<threadedComment': comment = {author: y.personId, guid: y.id, ref: y.ref, T: 1}; break;\n\t\t\tcase '</threadedComment>': if(comment.t != null) out.push(comment); break;\n\n\t\t\tcase '<text>': case '<text': tidx = idx + x.length; break;\n\t\t\tcase '</text>': comment.t = data.slice(tidx, idx).replace(/\\r\\n/g, \"\\n\").replace(/\\r/g, \"\\n\"); break;\n\n\t\t\t/* 2.6.206 mentions CT_ThreadedCommentMentions TODO */\n\t\t\tcase '<mentions': case '<mentions>': pass = true; break;\n\t\t\tcase '</mentions>': pass = false; break;\n\n\t\t\t/* 2.6.202 mention CT_Mention TODO */\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': case '<extLst/>': break;\n\t\t\t/* 18.2.7 ext CT_Extension + */\n\t\t\tcase '<ext': pass=true; break;\n\t\t\tcase '</ext>': pass=false; break;\n\n\t\t\tdefault: if(!pass && opts.WTF) throw new Error('unrecognized ' + y[0] + ' in threaded comments');\n\t\t}\n\t\treturn x;\n\t});\n\treturn out;\n}\n\nfunction write_tcmnt_xml(comments, people, opts) {\n\tvar o = [XML_HEADER, writextag('ThreadedComments', null, { 'xmlns': XMLNS.TCMNT }).replace(/[\\/]>/, \">\")];\n\tcomments.forEach(function(carr) {\n\t\tvar rootid = \"\";\n\t\t(carr[1] || []).forEach(function(c, idx) {\n\t\t\tif(!c.T) { delete c.ID; return; }\n\t\t\tif(c.a && people.indexOf(c.a) == -1) people.push(c.a);\n\t\t\tvar tcopts = {\n\t\t\t\tref: carr[0],\n\t\t\t\tid: \"{54EE7951-7262-4200-6969-\" + (\"000000000000\" + opts.tcid++).slice(-12) + \"}\"\n\t\t\t};\n\t\t\tif(idx == 0) rootid = tcopts.id;\n\t\t\telse tcopts.parentId = rootid;\n\t\t\tc.ID = tcopts.id;\n\t\t\tif(c.a) tcopts.personId = \"{54EE7950-7262-4200-6969-\" + (\"000000000000\" + people.indexOf(c.a)).slice(-12) + \"}\";\n\t\t\to.push(writextag('threadedComment', writetag('text', c.t||\"\"), tcopts));\n\t\t});\n\t});\n\to.push('</ThreadedComments>');\n\treturn o.join(\"\");\n}\n\n/* [MS-XLSX] 2.1.18 */\nfunction parse_people_xml(data/*:string*/, opts) {\n\tvar out = [];\n\tvar pass = false;\n\tdata.replace(tagregex, function xml_tcmnt(x) {\n\t\tvar y/*:any*/ = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<?xml': break;\n\n\t\t\t/* 2.4.85 personList CT_PersonList */\n\t\t\tcase '<personList': break;\n\t\t\tcase '</personList>': break;\n\n\t\t\t/* 2.6.203 person CT_Person TODO: providers */\n\t\t\tcase '<person': out.push({name: y.displayname, id: y.id }); break;\n\t\t\tcase '</person>': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': case '<extLst/>': break;\n\t\t\t/* 18.2.7 ext CT_Extension + */\n\t\t\tcase '<ext': pass=true; break;\n\t\t\tcase '</ext>': pass=false; break;\n\n\t\t\tdefault: if(!pass && opts.WTF) throw new Error('unrecognized ' + y[0] + ' in threaded comments');\n\t\t}\n\t\treturn x;\n\t});\n\treturn out;\n}\nfunction write_people_xml(people/*, opts*/) {\n\tvar o = [XML_HEADER, writextag('personList', null, {\n\t\t'xmlns': XMLNS.TCMNT,\n\t\t'xmlns:x': XMLNS_main[0]\n\t}).replace(/[\\/]>/, \">\")];\n\tpeople.forEach(function(person, idx) {\n\t\to.push(writextag('person', null, {\n\t\t\tdisplayName: person,\n\t\t\tid: \"{54EE7950-7262-4200-6969-\" + (\"000000000000\" + idx).slice(-12) + \"}\",\n\t\t\tuserId: person,\n\t\t\tproviderId: \"None\"\n\t\t}));\n\t});\n\to.push(\"</personList>\");\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.28 BrtBeginComment */\nfunction parse_BrtBeginComment(data) {\n\tvar out = {};\n\tout.iauthor = data.read_shift(4);\n\tvar rfx = parse_UncheckedRfX(data, 16);\n\tout.rfx = rfx.s;\n\tout.ref = encode_cell(rfx.s);\n\tdata.l += 16; /*var guid = parse_GUID(data); */\n\treturn out;\n}\nfunction write_BrtBeginComment(data, o) {\n\tif(o == null) o = new_buf(36);\n\to.write_shift(4, data[1].iauthor);\n\twrite_UncheckedRfX((data[0]/*:any*/), o);\n\to.write_shift(4, 0);\n\to.write_shift(4, 0);\n\to.write_shift(4, 0);\n\to.write_shift(4, 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.327 BrtCommentAuthor */\nvar parse_BrtCommentAuthor = parse_XLWideString;\nfunction write_BrtCommentAuthor(data) { return write_XLWideString(data.slice(0, 54)); }\n\n/* [MS-XLSB] 2.1.7.8 Comments */\nfunction parse_comments_bin(data, opts)/*:Array<RawComment>*/ {\n\tvar out/*:Array<RawComment>*/ = [];\n\tvar authors/*:Array<string>*/ = [];\n\tvar c = {};\n\tvar pass = false;\n\trecordhopper(data, function hopper_cmnt(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x0278: /* 'BrtCommentAuthor' */\n\t\t\t\tauthors.push(val); break;\n\t\t\tcase 0x027B: /* 'BrtBeginComment' */\n\t\t\t\tc = val; break;\n\t\t\tcase 0x027D: /* 'BrtCommentText' */\n\t\t\t\tc.t = val.t; c.h = val.h; c.r = val.r; break;\n\t\t\tcase 0x027C: /* 'BrtEndComment' */\n\t\t\t\tc.author = authors[c.iauthor];\n\t\t\t\tdelete (c/*:any*/).iauthor;\n\t\t\t\tif(opts.sheetRows && c.rfx && opts.sheetRows <= c.rfx.r) break;\n\t\t\t\tif(!c.t) c.t = \"\";\n\t\t\t\tdelete c.rfx; out.push(c); break;\n\n\t\t\tcase 0x0C00: /* 'BrtUid' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tpass = false; break;\n\t\t\tcase 0x0025: /* 'BrtACBegin' */ break;\n\t\t\tcase 0x0026: /* 'BrtACEnd' */ break;\n\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){/* empty */}\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t});\n\treturn out;\n}\n\nfunction write_comments_bin(data/*::, opts*/) {\n\tvar ba = buf_array();\n\tvar iauthor/*:Array<string>*/ = [];\n\twrite_record(ba, 0x0274 /* BrtBeginComments */);\n\n\twrite_record(ba, 0x0276 /* BrtBeginCommentAuthors */);\n\tdata.forEach(function(comment) {\n\t\tcomment[1].forEach(function(c) {\n\t\t\tif(iauthor.indexOf(c.a) > -1) return;\n\t\t\tiauthor.push(c.a.slice(0,54));\n\t\t\twrite_record(ba, 0x0278 /* BrtCommentAuthor */, write_BrtCommentAuthor(c.a));\n\t\t});\n\t});\n\twrite_record(ba, 0x0277 /* BrtEndCommentAuthors */);\n\n\twrite_record(ba, 0x0279 /* BrtBeginCommentList */);\n\tdata.forEach(function(comment) {\n\t\tcomment[1].forEach(function(c) {\n\t\t\tc.iauthor = iauthor.indexOf(c.a);\n\t\t\tvar range = {s:decode_cell(comment[0]),e:decode_cell(comment[0])};\n\t\t\twrite_record(ba, 0x027B /* BrtBeginComment */, write_BrtBeginComment([range, c]));\n\t\t\tif(c.t && c.t.length > 0) write_record(ba, 0x027D /* BrtCommentText */, write_BrtCommentText(c));\n\t\t\twrite_record(ba, 0x027C /* BrtEndComment */);\n\t\t\tdelete c.iauthor;\n\t\t});\n\t});\n\twrite_record(ba, 0x027A /* BrtEndCommentList */);\n\n\twrite_record(ba, 0x0275 /* BrtEndComments */);\n\treturn ba.end();\n}\nvar CT_VBA = \"application/vnd.ms-office.vbaProject\";\nfunction make_vba_xls(cfb) {\n var newcfb = CFB.utils.cfb_new({ root: \"R\" });\n cfb.FullPaths.forEach(function(p, i) {\n if (p.slice(-1) === \"/\" || !p.match(/_VBA_PROJECT_CUR/))\n return;\n var newpath = p.replace(/^[^\\/]*/, \"R\").replace(/\\/_VBA_PROJECT_CUR\\u0000*/, \"\");\n CFB.utils.cfb_add(newcfb, newpath, cfb.FileIndex[i].content);\n });\n return CFB.write(newcfb);\n}\nfunction fill_vba_xls(cfb, vba) {\n vba.FullPaths.forEach(function(p, i) {\n if (i == 0)\n return;\n var newpath = p.replace(/[^\\/]*[\\/]/, \"/_VBA_PROJECT_CUR/\");\n if (newpath.slice(-1) !== \"/\")\n CFB.utils.cfb_add(cfb, newpath, vba.FileIndex[i].content);\n });\n}\nvar VBAFMTS = [\"xlsb\", \"xlsm\", \"xlam\", \"biff8\", \"xla\"];\n/* macro and dialog sheet stubs */\nfunction parse_ds_bin(/*::data:any, opts, idx:number, rels, wb, themes, styles*/)/*:Worksheet*/ { return {'!type':'dialog'}; }\nfunction parse_ds_xml(/*::data:any, opts, idx:number, rels, wb, themes, styles*/)/*:Worksheet*/ { return {'!type':'dialog'}; }\nfunction parse_ms_bin(/*::data:any, opts, idx:number, rels, wb, themes, styles*/)/*:Worksheet*/ { return {'!type':'macro'}; }\nfunction parse_ms_xml(/*::data:any, opts, idx:number, rels, wb, themes, styles*/)/*:Worksheet*/ { return {'!type':'macro'}; }\n/* TODO: it will be useful to parse the function str */\nvar rc_to_a1 = /*#__PURE__*/(function(){\n\tvar rcregex = /(^|[^A-Za-z_])R(\\[?-?\\d+\\]|[1-9]\\d*|)C(\\[?-?\\d+\\]|[1-9]\\d*|)(?![A-Za-z0-9_])/g;\n\tvar rcbase/*:Cell*/ = ({r:0,c:0}/*:any*/);\n\tfunction rcfunc($$,$1,$2,$3) {\n\t\tvar cRel = false, rRel = false;\n\n\t\tif($2.length == 0) rRel = true;\n\t\telse if($2.charAt(0) == \"[\") { rRel = true; $2 = $2.slice(1, -1); }\n\n\t\tif($3.length == 0) cRel = true;\n\t\telse if($3.charAt(0) == \"[\") { cRel = true; $3 = $3.slice(1, -1); }\n\n\t\tvar R = $2.length>0?parseInt($2,10)|0:0, C = $3.length>0?parseInt($3,10)|0:0;\n\n\t\tif(cRel) C += rcbase.c; else --C;\n\t\tif(rRel) R += rcbase.r; else --R;\n\t\treturn $1 + (cRel ? \"\" : \"$\") + encode_col(C) + (rRel ? \"\" : \"$\") + encode_row(R);\n\t}\n\treturn function rc_to_a1(fstr/*:string*/, base/*:Cell*/)/*:string*/ {\n\t\trcbase = base;\n\t\treturn fstr.replace(rcregex, rcfunc);\n\t};\n})();\n\nvar crefregex = /(^|[^._A-Z0-9])([$]?)([A-Z]{1,2}|[A-W][A-Z]{2}|X[A-E][A-Z]|XF[A-D])([$]?)(10[0-3]\\d{4}|104[0-7]\\d{3}|1048[0-4]\\d{2}|10485[0-6]\\d|104857[0-6]|[1-9]\\d{0,5})(?![_.\\(A-Za-z0-9])/g;\nvar a1_to_rc = /*#__PURE__*/(function(){\n\treturn function a1_to_rc(fstr/*:string*/, base/*:CellAddress*/) {\n\t\treturn fstr.replace(crefregex, function($0, $1, $2, $3, $4, $5) {\n\t\t\tvar c = decode_col($3) - ($2 ? 0 : base.c);\n\t\t\tvar r = decode_row($5) - ($4 ? 0 : base.r);\n\t\t\tvar R = (r == 0 ? \"\" : !$4 ? \"[\" + r + \"]\" : (r+1));\n\t\t\tvar C = (c == 0 ? \"\" : !$2 ? \"[\" + c + \"]\" : (c+1));\n\t\t\treturn $1 + \"R\" + R + \"C\" + C;\n\t\t});\n\t};\n})();\n\n/* no defined name can collide with a valid cell address A1:XFD1048576 ... except LOG10! */\nfunction shift_formula_str(f/*:string*/, delta/*:Cell*/)/*:string*/ {\n\treturn f.replace(crefregex, function($0, $1, $2, $3, $4, $5) {\n\t\treturn $1+($2==\"$\" ? $2+$3 : encode_col(decode_col($3)+delta.c))+($4==\"$\" ? $4+$5 : encode_row(decode_row($5) + delta.r));\n\t});\n}\n\nfunction shift_formula_xlsx(f/*:string*/, range/*:string*/, cell/*:string*/)/*:string*/ {\n\tvar r = decode_range(range), s = r.s, c = decode_cell(cell);\n\tvar delta = {r:c.r - s.r, c:c.c - s.c};\n\treturn shift_formula_str(f, delta);\n}\n\n/* TODO: parse formula */\nfunction fuzzyfmla(f/*:string*/)/*:boolean*/ {\n\tif(f.length == 1) return false;\n\treturn true;\n}\n\nfunction _xlfn(f/*:string*/)/*:string*/ {\n\treturn f.replace(/_xlfn\\./g,\"\");\n}\nfunction parseread1(blob) { blob.l+=1; return; }\n\n/* [MS-XLS] 2.5.51 */\nfunction parse_ColRelU(blob, length) {\n\tvar c = blob.read_shift(length == 1 ? 1 : 2);\n\treturn [c & 0x3FFF, (c >> 14) & 1, (c >> 15) & 1];\n}\n\n/* [MS-XLS] 2.5.198.105 ; [MS-XLSB] 2.5.97.89 */\nfunction parse_RgceArea(blob, length, opts) {\n\tvar w = 2;\n\tif(opts) {\n\t\tif(opts.biff >= 2 && opts.biff <= 5) return parse_RgceArea_BIFF2(blob, length, opts);\n\t\telse if(opts.biff == 12) w = 4;\n\t}\n\tvar r=blob.read_shift(w), R=blob.read_shift(w);\n\tvar c=parse_ColRelU(blob, 2);\n\tvar C=parse_ColRelU(blob, 2);\n\treturn { s:{r:r, c:c[0], cRel:c[1], rRel:c[2]}, e:{r:R, c:C[0], cRel:C[1], rRel:C[2]} };\n}\n/* BIFF 2-5 encodes flags in the row field */\nfunction parse_RgceArea_BIFF2(blob/*::, length, opts*/) {\n\tvar r=parse_ColRelU(blob, 2), R=parse_ColRelU(blob, 2);\n\tvar c=blob.read_shift(1);\n\tvar C=blob.read_shift(1);\n\treturn { s:{r:r[0], c:c, cRel:r[1], rRel:r[2]}, e:{r:R[0], c:C, cRel:R[1], rRel:R[2]} };\n}\n\n/* [MS-XLS] 2.5.198.105 ; [MS-XLSB] 2.5.97.90 */\nfunction parse_RgceAreaRel(blob, length, opts) {\n\tif(opts.biff < 8) return parse_RgceArea_BIFF2(blob, length, opts);\n\tvar r=blob.read_shift(opts.biff == 12 ? 4 : 2), R=blob.read_shift(opts.biff == 12 ? 4 : 2);\n\tvar c=parse_ColRelU(blob, 2);\n\tvar C=parse_ColRelU(blob, 2);\n\treturn { s:{r:r, c:c[0], cRel:c[1], rRel:c[2]}, e:{r:R, c:C[0], cRel:C[1], rRel:C[2]} };\n}\n\n/* [MS-XLS] 2.5.198.109 ; [MS-XLSB] 2.5.97.91 */\nfunction parse_RgceLoc(blob, length, opts) {\n\tif(opts && opts.biff >= 2 && opts.biff <= 5) return parse_RgceLoc_BIFF2(blob, length, opts);\n\tvar r = blob.read_shift(opts && opts.biff == 12 ? 4 : 2);\n\tvar c = parse_ColRelU(blob, 2);\n\treturn {r:r, c:c[0], cRel:c[1], rRel:c[2]};\n}\nfunction parse_RgceLoc_BIFF2(blob/*::, length, opts*/) {\n\tvar r = parse_ColRelU(blob, 2);\n\tvar c = blob.read_shift(1);\n\treturn {r:r[0], c:c, cRel:r[1], rRel:r[2]};\n}\n\n/* [MS-XLS] 2.5.198.107, 2.5.47 */\nfunction parse_RgceElfLoc(blob/*::, length, opts*/) {\n\tvar r = blob.read_shift(2);\n\tvar c = blob.read_shift(2);\n\treturn {r:r, c:c & 0xFF, fQuoted:!!(c & 0x4000), cRel:c>>15, rRel:c>>15 };\n}\n\n/* [MS-XLS] 2.5.198.111 ; [MS-XLSB] 2.5.97.92 TODO */\nfunction parse_RgceLocRel(blob, length, opts) {\n\tvar biff = opts && opts.biff ? opts.biff : 8;\n\tif(biff >= 2 && biff <= 5) return parse_RgceLocRel_BIFF2(blob, length, opts);\n\tvar r = blob.read_shift(biff >= 12 ? 4 : 2);\n\tvar cl = blob.read_shift(2);\n\tvar cRel = (cl & 0x4000) >> 14, rRel = (cl & 0x8000) >> 15;\n\tcl &= 0x3FFF;\n\tif(rRel == 1) while(r > 0x7FFFF) r -= 0x100000;\n\tif(cRel == 1) while(cl > 0x1FFF) cl = cl - 0x4000;\n\treturn {r:r,c:cl,cRel:cRel,rRel:rRel};\n}\nfunction parse_RgceLocRel_BIFF2(blob/*::, length:number, opts*/) {\n\tvar rl = blob.read_shift(2);\n\tvar c = blob.read_shift(1);\n\tvar rRel = (rl & 0x8000) >> 15, cRel = (rl & 0x4000) >> 14;\n\trl &= 0x3FFF;\n\tif(rRel == 1 && rl >= 0x2000) rl = rl - 0x4000;\n\tif(cRel == 1 && c >= 0x80) c = c - 0x100;\n\treturn {r:rl,c:c,cRel:cRel,rRel:rRel};\n}\n\n/* [MS-XLS] 2.5.198.27 ; [MS-XLSB] 2.5.97.18 */\nfunction parse_PtgArea(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar area = parse_RgceArea(blob, opts.biff >= 2 && opts.biff <= 5 ? 6 : 8, opts);\n\treturn [type, area];\n}\n\n/* [MS-XLS] 2.5.198.28 ; [MS-XLSB] 2.5.97.19 */\nfunction parse_PtgArea3d(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar ixti = blob.read_shift(2, 'i');\n\tvar w = 8;\n\tif(opts) switch(opts.biff) {\n\t\tcase 5: blob.l += 12; w = 6; break;\n\t\tcase 12: w = 12; break;\n\t}\n\tvar area = parse_RgceArea(blob, w, opts);\n\treturn [type, ixti, area];\n}\n\n/* [MS-XLS] 2.5.198.29 ; [MS-XLSB] 2.5.97.20 */\nfunction parse_PtgAreaErr(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tblob.l += opts && (opts.biff > 8) ? 12 : (opts.biff < 8 ? 6 : 8);\n\treturn [type];\n}\n/* [MS-XLS] 2.5.198.30 ; [MS-XLSB] 2.5.97.21 */\nfunction parse_PtgAreaErr3d(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar ixti = blob.read_shift(2);\n\tvar w = 8;\n\tif(opts) switch(opts.biff) {\n\t\tcase 5: blob.l += 12; w = 6; break;\n\t\tcase 12: w = 12; break;\n\t}\n\tblob.l += w;\n\treturn [type, ixti];\n}\n\n/* [MS-XLS] 2.5.198.31 ; [MS-XLSB] 2.5.97.22 */\nfunction parse_PtgAreaN(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar area = parse_RgceAreaRel(blob, length - 1, opts);\n\treturn [type, area];\n}\n\n/* [MS-XLS] 2.5.198.32 ; [MS-XLSB] 2.5.97.23 */\nfunction parse_PtgArray(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tblob.l += opts.biff == 2 ? 6 : opts.biff == 12 ? 14 : 7;\n\treturn [type];\n}\n\n/* [MS-XLS] 2.5.198.33 ; [MS-XLSB] 2.5.97.24 */\nfunction parse_PtgAttrBaxcel(blob) {\n\tvar bitSemi = blob[blob.l+1] & 0x01; /* 1 = volatile */\n\tvar bitBaxcel = 1;\n\tblob.l += 4;\n\treturn [bitSemi, bitBaxcel];\n}\n\n/* [MS-XLS] 2.5.198.34 ; [MS-XLSB] 2.5.97.25 */\nfunction parse_PtgAttrChoose(blob, length, opts)/*:Array<number>*/ {\n\tblob.l +=2;\n\tvar offset = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\tvar o/*:Array<number>*/ = [];\n\t/* offset is 1 less than the number of elements */\n\tfor(var i = 0; i <= offset; ++i) o.push(blob.read_shift(opts && opts.biff == 2 ? 1 : 2));\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.198.35 ; [MS-XLSB] 2.5.97.26 */\nfunction parse_PtgAttrGoto(blob, length, opts) {\n\tvar bitGoto = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += 2;\n\treturn [bitGoto, blob.read_shift(opts && opts.biff == 2 ? 1 : 2)];\n}\n\n/* [MS-XLS] 2.5.198.36 ; [MS-XLSB] 2.5.97.27 */\nfunction parse_PtgAttrIf(blob, length, opts) {\n\tvar bitIf = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += 2;\n\treturn [bitIf, blob.read_shift(opts && opts.biff == 2 ? 1 : 2)];\n}\n\n/* [MS-XLSB] 2.5.97.28 */\nfunction parse_PtgAttrIfError(blob) {\n\tvar bitIf = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += 2;\n\treturn [bitIf, blob.read_shift(2)];\n}\n\n/* [MS-XLS] 2.5.198.37 ; [MS-XLSB] 2.5.97.29 */\nfunction parse_PtgAttrSemi(blob, length, opts) {\n\tvar bitSemi = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += opts && opts.biff == 2 ? 3 : 4;\n\treturn [bitSemi];\n}\n\n/* [MS-XLS] 2.5.198.40 ; [MS-XLSB] 2.5.97.32 */\nfunction parse_PtgAttrSpaceType(blob/*::, length*/) {\n\tvar type = blob.read_shift(1), cch = blob.read_shift(1);\n\treturn [type, cch];\n}\n\n/* [MS-XLS] 2.5.198.38 ; [MS-XLSB] 2.5.97.30 */\nfunction parse_PtgAttrSpace(blob) {\n\tblob.read_shift(2);\n\treturn parse_PtgAttrSpaceType(blob, 2);\n}\n\n/* [MS-XLS] 2.5.198.39 ; [MS-XLSB] 2.5.97.31 */\nfunction parse_PtgAttrSpaceSemi(blob) {\n\tblob.read_shift(2);\n\treturn parse_PtgAttrSpaceType(blob, 2);\n}\n\n/* [MS-XLS] 2.5.198.84 ; [MS-XLSB] 2.5.97.68 TODO */\nfunction parse_PtgRef(blob, length, opts) {\n\t//var ptg = blob[blob.l] & 0x1F;\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar loc = parse_RgceLoc(blob, 0, opts);\n\treturn [type, loc];\n}\n\n/* [MS-XLS] 2.5.198.88 ; [MS-XLSB] 2.5.97.72 TODO */\nfunction parse_PtgRefN(blob, length, opts) {\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar loc = parse_RgceLocRel(blob, 0, opts);\n\treturn [type, loc];\n}\n\n/* [MS-XLS] 2.5.198.85 ; [MS-XLSB] 2.5.97.69 TODO */\nfunction parse_PtgRef3d(blob, length, opts) {\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar ixti = blob.read_shift(2); // XtiIndex\n\tif(opts && opts.biff == 5) blob.l += 12;\n\tvar loc = parse_RgceLoc(blob, 0, opts); // TODO: or RgceLocRel\n\treturn [type, ixti, loc];\n}\n\n\n/* [MS-XLS] 2.5.198.62 ; [MS-XLSB] 2.5.97.45 TODO */\nfunction parse_PtgFunc(blob, length, opts) {\n\t//var ptg = blob[blob.l] & 0x1F;\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar iftab = blob.read_shift(opts && opts.biff <= 3 ? 1 : 2);\n\treturn [FtabArgc[iftab], Ftab[iftab], type];\n}\n/* [MS-XLS] 2.5.198.63 ; [MS-XLSB] 2.5.97.46 TODO */\nfunction parse_PtgFuncVar(blob, length, opts) {\n\tvar type = blob[blob.l++];\n\tvar cparams = blob.read_shift(1), tab = opts && opts.biff <= 3 ? [(type == 0x58 ? -1 : 0), blob.read_shift(1)]: parsetab(blob);\n\treturn [cparams, (tab[0] === 0 ? Ftab : Cetab)[tab[1]]];\n}\n\nfunction parsetab(blob) {\n\treturn [blob[blob.l+1]>>7, blob.read_shift(2) & 0x7FFF];\n}\n\n/* [MS-XLS] 2.5.198.41 ; [MS-XLSB] 2.5.97.33 */\nfunction parse_PtgAttrSum(blob, length, opts) {\n\tblob.l += opts && opts.biff == 2 ? 3 : 4; return;\n}\n\n/* [MS-XLS] 2.5.198.58 ; [MS-XLSB] 2.5.97.40 */\nfunction parse_PtgExp(blob, length, opts) {\n\tblob.l++;\n\tif(opts && opts.biff == 12) return [blob.read_shift(4, 'i'), 0];\n\tvar row = blob.read_shift(2);\n\tvar col = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\treturn [row, col];\n}\n\n/* [MS-XLS] 2.5.198.57 ; [MS-XLSB] 2.5.97.39 */\nfunction parse_PtgErr(blob) { blob.l++; return BErr[blob.read_shift(1)]; }\n\n/* [MS-XLS] 2.5.198.66 ; [MS-XLSB] 2.5.97.49 */\nfunction parse_PtgInt(blob) { blob.l++; return blob.read_shift(2); }\n\n/* [MS-XLS] 2.5.198.42 ; [MS-XLSB] 2.5.97.34 */\nfunction parse_PtgBool(blob) { blob.l++; return blob.read_shift(1)!==0;}\n\n/* [MS-XLS] 2.5.198.79 ; [MS-XLSB] 2.5.97.63 */\nfunction parse_PtgNum(blob) { blob.l++; return parse_Xnum(blob, 8); }\n\n/* [MS-XLS] 2.5.198.89 ; [MS-XLSB] 2.5.97.74 */\nfunction parse_PtgStr(blob, length, opts) { blob.l++; return parse_ShortXLUnicodeString(blob, length-1, opts); }\n\n/* [MS-XLS] 2.5.192.112 + 2.5.192.11{3,4,5,6,7} */\n/* [MS-XLSB] 2.5.97.93 + 2.5.97.9{4,5,6,7} */\nfunction parse_SerAr(blob, biff/*:number*/) {\n\tvar val = [blob.read_shift(1)];\n\tif(biff == 12) switch(val[0]) {\n\t\tcase 0x02: val[0] = 0x04; break; /* SerBool */\n\t\tcase 0x04: val[0] = 0x10; break; /* SerErr */\n\t\tcase 0x00: val[0] = 0x01; break; /* SerNum */\n\t\tcase 0x01: val[0] = 0x02; break; /* SerStr */\n\t}\n\tswitch(val[0]) {\n\t\tcase 0x04: /* SerBool -- boolean */\n\t\t\tval[1] = parsebool(blob, 1) ? 'TRUE' : 'FALSE';\n\t\t\tif(biff != 12) blob.l += 7; break;\n\t\tcase 0x25: /* appears to be an alias */\n\t\tcase 0x10: /* SerErr -- error */\n\t\t\tval[1] = BErr[blob[blob.l]];\n\t\t\tblob.l += ((biff == 12) ? 4 : 8); break;\n\t\tcase 0x00: /* SerNil -- honestly, I'm not sure how to reproduce this */\n\t\t\tblob.l += 8; break;\n\t\tcase 0x01: /* SerNum -- Xnum */\n\t\t\tval[1] = parse_Xnum(blob, 8); break;\n\t\tcase 0x02: /* SerStr -- XLUnicodeString (<256 chars) */\n\t\t\tval[1] = parse_XLUnicodeString2(blob, 0, {biff:biff > 0 && biff < 8 ? 2 : biff}); break;\n\t\tdefault: throw new Error(\"Bad SerAr: \" + val[0]); /* Unreachable */\n\t}\n\treturn val;\n}\n\n/* [MS-XLS] 2.5.198.61 ; [MS-XLSB] 2.5.97.44 */\nfunction parse_PtgExtraMem(blob, cce, opts) {\n\tvar count = blob.read_shift((opts.biff == 12) ? 4 : 2);\n\tvar out/*:Array<Range>*/ = [];\n\tfor(var i = 0; i != count; ++i) out.push(((opts.biff == 12) ? parse_UncheckedRfX : parse_Ref8U)(blob, 8));\n\treturn out;\n}\n\n/* [MS-XLS] 2.5.198.59 ; [MS-XLSB] 2.5.97.41 */\nfunction parse_PtgExtraArray(blob, length, opts) {\n\tvar rows = 0, cols = 0;\n\tif(opts.biff == 12) {\n\t\trows = blob.read_shift(4); // DRw\n\t\tcols = blob.read_shift(4); // DCol\n\t} else {\n\t\tcols = 1 + blob.read_shift(1); //DColByteU\n\t\trows = 1 + blob.read_shift(2); //DRw\n\t}\n\tif(opts.biff >= 2 && opts.biff < 8) { --rows; if(--cols == 0) cols = 0x100; }\n\t// $FlowIgnore\n\tfor(var i = 0, o/*:Array<Array<any>>*/ = []; i != rows && (o[i] = []); ++i)\n\t\tfor(var j = 0; j != cols; ++j) o[i][j] = parse_SerAr(blob, opts.biff);\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.198.76 ; [MS-XLSB] 2.5.97.60 */\nfunction parse_PtgName(blob, length, opts) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar w = (!opts || (opts.biff >= 8)) ? 4 : 2;\n\tvar nameindex = blob.read_shift(w);\n\tswitch(opts.biff) {\n\t\tcase 2: blob.l += 5; break;\n\t\tcase 3: case 4: blob.l += 8; break;\n\t\tcase 5: blob.l += 12; break;\n\t}\n\treturn [type, 0, nameindex];\n}\n\n/* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 */\nfunction parse_PtgNameX(blob, length, opts) {\n\tif(opts.biff == 5) return parse_PtgNameX_BIFF5(blob, length, opts);\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar ixti = blob.read_shift(2); // XtiIndex\n\tvar nameindex = blob.read_shift(4);\n\treturn [type, ixti, nameindex];\n}\nfunction parse_PtgNameX_BIFF5(blob/*::, length, opts*/) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar ixti = blob.read_shift(2, 'i'); // XtiIndex\n\tblob.l += 8;\n\tvar nameindex = blob.read_shift(2);\n\tblob.l += 12;\n\treturn [type, ixti, nameindex];\n}\n\n/* [MS-XLS] 2.5.198.70 ; [MS-XLSB] 2.5.97.54 */\nfunction parse_PtgMemArea(blob, length, opts) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tblob.l += (opts && opts.biff == 2 ? 3 : 4);\n\tvar cce = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\treturn [type, cce];\n}\n\n/* [MS-XLS] 2.5.198.72 ; [MS-XLSB] 2.5.97.56 */\nfunction parse_PtgMemFunc(blob, length, opts) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar cce = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\treturn [type, cce];\n}\n\n\n/* [MS-XLS] 2.5.198.86 ; [MS-XLSB] 2.5.97.69 */\nfunction parse_PtgRefErr(blob, length, opts) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tblob.l += 4;\n\tif(opts.biff < 8) blob.l--;\n\tif(opts.biff == 12) blob.l += 2;\n\treturn [type];\n}\n\n/* [MS-XLS] 2.5.198.87 ; [MS-XLSB] 2.5.97.71 */\nfunction parse_PtgRefErr3d(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar ixti = blob.read_shift(2);\n\tvar w = 4;\n\tif(opts) switch(opts.biff) {\n\t\tcase 5: w = 15; break;\n\t\tcase 12: w = 6; break;\n\t}\n\tblob.l += w;\n\treturn [type, ixti];\n}\n\n/* [MS-XLS] 2.5.198.71 ; [MS-XLSB] 2.5.97.55 */\nvar parse_PtgMemErr = parsenoop;\n/* [MS-XLS] 2.5.198.73 ; [MS-XLSB] 2.5.97.57 */\nvar parse_PtgMemNoMem = parsenoop;\n/* [MS-XLS] 2.5.198.92 */\nvar parse_PtgTbl = parsenoop;\n\nfunction parse_PtgElfLoc(blob, length, opts) {\n\tblob.l += 2;\n\treturn [parse_RgceElfLoc(blob, 4, opts)];\n}\nfunction parse_PtgElfNoop(blob/*::, length, opts*/) {\n\tblob.l += 6;\n\treturn [];\n}\n/* [MS-XLS] 2.5.198.46 */\nvar parse_PtgElfCol = parse_PtgElfLoc;\n/* [MS-XLS] 2.5.198.47 */\nvar parse_PtgElfColS = parse_PtgElfNoop;\n/* [MS-XLS] 2.5.198.48 */\nvar parse_PtgElfColSV = parse_PtgElfNoop;\n/* [MS-XLS] 2.5.198.49 */\nvar parse_PtgElfColV = parse_PtgElfLoc;\n/* [MS-XLS] 2.5.198.50 */\nfunction parse_PtgElfLel(blob/*::, length, opts*/) {\n\tblob.l += 2;\n\treturn [parseuint16(blob), blob.read_shift(2) & 0x01];\n}\n/* [MS-XLS] 2.5.198.51 */\nvar parse_PtgElfRadical = parse_PtgElfLoc;\n/* [MS-XLS] 2.5.198.52 */\nvar parse_PtgElfRadicalLel = parse_PtgElfLel;\n/* [MS-XLS] 2.5.198.53 */\nvar parse_PtgElfRadicalS = parse_PtgElfNoop;\n/* [MS-XLS] 2.5.198.54 */\nvar parse_PtgElfRw = parse_PtgElfLoc;\n/* [MS-XLS] 2.5.198.55 */\nvar parse_PtgElfRwV = parse_PtgElfLoc;\n\n/* [MS-XLSB] 2.5.97.52 TODO */\nvar PtgListRT = [\n\t\"Data\",\n\t\"All\",\n\t\"Headers\",\n\t\"??\",\n\t\"?Data2\",\n\t\"??\",\n\t\"?DataHeaders\",\n\t\"??\",\n\t\"Totals\",\n\t\"??\",\n\t\"??\",\n\t\"??\",\n\t\"?DataTotals\",\n\t\"??\",\n\t\"??\",\n\t\"??\",\n\t\"?Current\"\n];\nfunction parse_PtgList(blob/*::, length, opts*/) {\n\tblob.l += 2;\n\tvar ixti = blob.read_shift(2);\n\tvar flags = blob.read_shift(2);\n\tvar idx = blob.read_shift(4);\n\tvar c = blob.read_shift(2);\n\tvar C = blob.read_shift(2);\n\tvar rt = PtgListRT[(flags >> 2) & 0x1F];\n\treturn {ixti: ixti, coltype:(flags&0x3), rt:rt, idx:idx, c:c, C:C};\n}\n/* [MS-XLS] 2.5.198.91 ; [MS-XLSB] 2.5.97.76 */\nfunction parse_PtgSxName(blob/*::, length, opts*/) {\n\tblob.l += 2;\n\treturn [blob.read_shift(4)];\n}\n\n/* [XLS] old spec */\nfunction parse_PtgSheet(blob, length, opts) {\n\tblob.l += 5;\n\tblob.l += 2;\n\tblob.l += (opts.biff == 2 ? 1 : 4);\n\treturn [\"PTGSHEET\"];\n}\nfunction parse_PtgEndSheet(blob, length, opts) {\n\tblob.l += (opts.biff == 2 ? 4 : 5);\n\treturn [\"PTGENDSHEET\"];\n}\nfunction parse_PtgMemAreaN(blob/*::, length, opts*/) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar cce = blob.read_shift(2);\n\treturn [type, cce];\n}\nfunction parse_PtgMemNoMemN(blob/*::, length, opts*/) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar cce = blob.read_shift(2);\n\treturn [type, cce];\n}\nfunction parse_PtgAttrNoop(blob/*::, length, opts*/) {\n\tblob.l += 4;\n\treturn [0, 0];\n}\n\n/* [MS-XLS] 2.5.198.25 ; [MS-XLSB] 2.5.97.16 */\nvar PtgTypes = {\n\t/*::[*/0x01/*::]*/: { n:'PtgExp', f:parse_PtgExp },\n\t/*::[*/0x02/*::]*/: { n:'PtgTbl', f:parse_PtgTbl },\n\t/*::[*/0x03/*::]*/: { n:'PtgAdd', f:parseread1 },\n\t/*::[*/0x04/*::]*/: { n:'PtgSub', f:parseread1 },\n\t/*::[*/0x05/*::]*/: { n:'PtgMul', f:parseread1 },\n\t/*::[*/0x06/*::]*/: { n:'PtgDiv', f:parseread1 },\n\t/*::[*/0x07/*::]*/: { n:'PtgPower', f:parseread1 },\n\t/*::[*/0x08/*::]*/: { n:'PtgConcat', f:parseread1 },\n\t/*::[*/0x09/*::]*/: { n:'PtgLt', f:parseread1 },\n\t/*::[*/0x0A/*::]*/: { n:'PtgLe', f:parseread1 },\n\t/*::[*/0x0B/*::]*/: { n:'PtgEq', f:parseread1 },\n\t/*::[*/0x0C/*::]*/: { n:'PtgGe', f:parseread1 },\n\t/*::[*/0x0D/*::]*/: { n:'PtgGt', f:parseread1 },\n\t/*::[*/0x0E/*::]*/: { n:'PtgNe', f:parseread1 },\n\t/*::[*/0x0F/*::]*/: { n:'PtgIsect', f:parseread1 },\n\t/*::[*/0x10/*::]*/: { n:'PtgUnion', f:parseread1 },\n\t/*::[*/0x11/*::]*/: { n:'PtgRange', f:parseread1 },\n\t/*::[*/0x12/*::]*/: { n:'PtgUplus', f:parseread1 },\n\t/*::[*/0x13/*::]*/: { n:'PtgUminus', f:parseread1 },\n\t/*::[*/0x14/*::]*/: { n:'PtgPercent', f:parseread1 },\n\t/*::[*/0x15/*::]*/: { n:'PtgParen', f:parseread1 },\n\t/*::[*/0x16/*::]*/: { n:'PtgMissArg', f:parseread1 },\n\t/*::[*/0x17/*::]*/: { n:'PtgStr', f:parse_PtgStr },\n\t/*::[*/0x1A/*::]*/: { n:'PtgSheet', f:parse_PtgSheet },\n\t/*::[*/0x1B/*::]*/: { n:'PtgEndSheet', f:parse_PtgEndSheet },\n\t/*::[*/0x1C/*::]*/: { n:'PtgErr', f:parse_PtgErr },\n\t/*::[*/0x1D/*::]*/: { n:'PtgBool', f:parse_PtgBool },\n\t/*::[*/0x1E/*::]*/: { n:'PtgInt', f:parse_PtgInt },\n\t/*::[*/0x1F/*::]*/: { n:'PtgNum', f:parse_PtgNum },\n\t/*::[*/0x20/*::]*/: { n:'PtgArray', f:parse_PtgArray },\n\t/*::[*/0x21/*::]*/: { n:'PtgFunc', f:parse_PtgFunc },\n\t/*::[*/0x22/*::]*/: { n:'PtgFuncVar', f:parse_PtgFuncVar },\n\t/*::[*/0x23/*::]*/: { n:'PtgName', f:parse_PtgName },\n\t/*::[*/0x24/*::]*/: { n:'PtgRef', f:parse_PtgRef },\n\t/*::[*/0x25/*::]*/: { n:'PtgArea', f:parse_PtgArea },\n\t/*::[*/0x26/*::]*/: { n:'PtgMemArea', f:parse_PtgMemArea },\n\t/*::[*/0x27/*::]*/: { n:'PtgMemErr', f:parse_PtgMemErr },\n\t/*::[*/0x28/*::]*/: { n:'PtgMemNoMem', f:parse_PtgMemNoMem },\n\t/*::[*/0x29/*::]*/: { n:'PtgMemFunc', f:parse_PtgMemFunc },\n\t/*::[*/0x2A/*::]*/: { n:'PtgRefErr', f:parse_PtgRefErr },\n\t/*::[*/0x2B/*::]*/: { n:'PtgAreaErr', f:parse_PtgAreaErr },\n\t/*::[*/0x2C/*::]*/: { n:'PtgRefN', f:parse_PtgRefN },\n\t/*::[*/0x2D/*::]*/: { n:'PtgAreaN', f:parse_PtgAreaN },\n\t/*::[*/0x2E/*::]*/: { n:'PtgMemAreaN', f:parse_PtgMemAreaN },\n\t/*::[*/0x2F/*::]*/: { n:'PtgMemNoMemN', f:parse_PtgMemNoMemN },\n\t/*::[*/0x39/*::]*/: { n:'PtgNameX', f:parse_PtgNameX },\n\t/*::[*/0x3A/*::]*/: { n:'PtgRef3d', f:parse_PtgRef3d },\n\t/*::[*/0x3B/*::]*/: { n:'PtgArea3d', f:parse_PtgArea3d },\n\t/*::[*/0x3C/*::]*/: { n:'PtgRefErr3d', f:parse_PtgRefErr3d },\n\t/*::[*/0x3D/*::]*/: { n:'PtgAreaErr3d', f:parse_PtgAreaErr3d },\n\t/*::[*/0xFF/*::]*/: {}\n};\n/* These are duplicated in the PtgTypes table */\nvar PtgDupes = {\n\t/*::[*/0x40/*::]*/: 0x20, /*::[*/0x60/*::]*/: 0x20,\n\t/*::[*/0x41/*::]*/: 0x21, /*::[*/0x61/*::]*/: 0x21,\n\t/*::[*/0x42/*::]*/: 0x22, /*::[*/0x62/*::]*/: 0x22,\n\t/*::[*/0x43/*::]*/: 0x23, /*::[*/0x63/*::]*/: 0x23,\n\t/*::[*/0x44/*::]*/: 0x24, /*::[*/0x64/*::]*/: 0x24,\n\t/*::[*/0x45/*::]*/: 0x25, /*::[*/0x65/*::]*/: 0x25,\n\t/*::[*/0x46/*::]*/: 0x26, /*::[*/0x66/*::]*/: 0x26,\n\t/*::[*/0x47/*::]*/: 0x27, /*::[*/0x67/*::]*/: 0x27,\n\t/*::[*/0x48/*::]*/: 0x28, /*::[*/0x68/*::]*/: 0x28,\n\t/*::[*/0x49/*::]*/: 0x29, /*::[*/0x69/*::]*/: 0x29,\n\t/*::[*/0x4A/*::]*/: 0x2A, /*::[*/0x6A/*::]*/: 0x2A,\n\t/*::[*/0x4B/*::]*/: 0x2B, /*::[*/0x6B/*::]*/: 0x2B,\n\t/*::[*/0x4C/*::]*/: 0x2C, /*::[*/0x6C/*::]*/: 0x2C,\n\t/*::[*/0x4D/*::]*/: 0x2D, /*::[*/0x6D/*::]*/: 0x2D,\n\t/*::[*/0x4E/*::]*/: 0x2E, /*::[*/0x6E/*::]*/: 0x2E,\n\t/*::[*/0x4F/*::]*/: 0x2F, /*::[*/0x6F/*::]*/: 0x2F,\n\t/*::[*/0x58/*::]*/: 0x22, /*::[*/0x78/*::]*/: 0x22,\n\t/*::[*/0x59/*::]*/: 0x39, /*::[*/0x79/*::]*/: 0x39,\n\t/*::[*/0x5A/*::]*/: 0x3A, /*::[*/0x7A/*::]*/: 0x3A,\n\t/*::[*/0x5B/*::]*/: 0x3B, /*::[*/0x7B/*::]*/: 0x3B,\n\t/*::[*/0x5C/*::]*/: 0x3C, /*::[*/0x7C/*::]*/: 0x3C,\n\t/*::[*/0x5D/*::]*/: 0x3D, /*::[*/0x7D/*::]*/: 0x3D\n};\n\nvar Ptg18 = {\n\t/*::[*/0x01/*::]*/: { n:'PtgElfLel', f:parse_PtgElfLel },\n\t/*::[*/0x02/*::]*/: { n:'PtgElfRw', f:parse_PtgElfRw },\n\t/*::[*/0x03/*::]*/: { n:'PtgElfCol', f:parse_PtgElfCol },\n\t/*::[*/0x06/*::]*/: { n:'PtgElfRwV', f:parse_PtgElfRwV },\n\t/*::[*/0x07/*::]*/: { n:'PtgElfColV', f:parse_PtgElfColV },\n\t/*::[*/0x0A/*::]*/: { n:'PtgElfRadical', f:parse_PtgElfRadical },\n\t/*::[*/0x0B/*::]*/: { n:'PtgElfRadicalS', f:parse_PtgElfRadicalS },\n\t/*::[*/0x0D/*::]*/: { n:'PtgElfColS', f:parse_PtgElfColS },\n\t/*::[*/0x0F/*::]*/: { n:'PtgElfColSV', f:parse_PtgElfColSV },\n\t/*::[*/0x10/*::]*/: { n:'PtgElfRadicalLel', f:parse_PtgElfRadicalLel },\n\t/*::[*/0x19/*::]*/: { n:'PtgList', f:parse_PtgList },\n\t/*::[*/0x1D/*::]*/: { n:'PtgSxName', f:parse_PtgSxName },\n\t/*::[*/0xFF/*::]*/: {}\n};\nvar Ptg19 = {\n\t/*::[*/0x00/*::]*/: { n:'PtgAttrNoop', f:parse_PtgAttrNoop },\n\t/*::[*/0x01/*::]*/: { n:'PtgAttrSemi', f:parse_PtgAttrSemi },\n\t/*::[*/0x02/*::]*/: { n:'PtgAttrIf', f:parse_PtgAttrIf },\n\t/*::[*/0x04/*::]*/: { n:'PtgAttrChoose', f:parse_PtgAttrChoose },\n\t/*::[*/0x08/*::]*/: { n:'PtgAttrGoto', f:parse_PtgAttrGoto },\n\t/*::[*/0x10/*::]*/: { n:'PtgAttrSum', f:parse_PtgAttrSum },\n\t/*::[*/0x20/*::]*/: { n:'PtgAttrBaxcel', f:parse_PtgAttrBaxcel },\n\t/*::[*/0x21/*::]*/: { n:'PtgAttrBaxcel', f:parse_PtgAttrBaxcel },\n\t/*::[*/0x40/*::]*/: { n:'PtgAttrSpace', f:parse_PtgAttrSpace },\n\t/*::[*/0x41/*::]*/: { n:'PtgAttrSpaceSemi', f:parse_PtgAttrSpaceSemi },\n\t/*::[*/0x80/*::]*/: { n:'PtgAttrIfError', f:parse_PtgAttrIfError },\n\t/*::[*/0xFF/*::]*/: {}\n};\n\n/* [MS-XLS] 2.5.198.103 ; [MS-XLSB] 2.5.97.87 */\nfunction parse_RgbExtra(blob, length, rgce, opts) {\n\tif(opts.biff < 8) return parsenoop(blob, length);\n\tvar target = blob.l + length;\n\tvar o = [];\n\tfor(var i = 0; i !== rgce.length; ++i) {\n\t\tswitch(rgce[i][0]) {\n\t\t\tcase 'PtgArray': /* PtgArray -> PtgExtraArray */\n\t\t\t\trgce[i][1] = parse_PtgExtraArray(blob, 0, opts);\n\t\t\t\to.push(rgce[i][1]);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgMemArea': /* PtgMemArea -> PtgExtraMem */\n\t\t\t\trgce[i][2] = parse_PtgExtraMem(blob, rgce[i][1], opts);\n\t\t\t\to.push(rgce[i][2]);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgExp': /* PtgExp -> PtgExtraCol */\n\t\t\t\tif(opts && opts.biff == 12) {\n\t\t\t\t\trgce[i][1][1] = blob.read_shift(4);\n\t\t\t\t\to.push(rgce[i][1]);\n\t\t\t\t} break;\n\t\t\tcase 'PtgList': /* TODO: PtgList -> PtgExtraList */\n\t\t\tcase 'PtgElfRadicalS': /* TODO: PtgElfRadicalS -> PtgExtraElf */\n\t\t\tcase 'PtgElfColS': /* TODO: PtgElfColS -> PtgExtraElf */\n\t\t\tcase 'PtgElfColSV': /* TODO: PtgElfColSV -> PtgExtraElf */\n\t\t\t\tthrow \"Unsupported \" + rgce[i][0];\n\t\t\tdefault: break;\n\t\t}\n\t}\n\tlength = target - blob.l;\n\t/* note: this is technically an error but Excel disregards */\n\t//if(target !== blob.l && blob.l !== target - length) throw new Error(target + \" != \" + blob.l);\n\tif(length !== 0) o.push(parsenoop(blob, length));\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.198.104 ; [MS-XLSB] 2.5.97.88 */\nfunction parse_Rgce(blob, length, opts) {\n\tvar target = blob.l + length;\n\tvar R, id, ptgs = [];\n\twhile(target != blob.l) {\n\t\tlength = target - blob.l;\n\t\tid = blob[blob.l];\n\t\tR = PtgTypes[id] || PtgTypes[PtgDupes[id]];\n\t\tif(id === 0x18 || id === 0x19) R = (id === 0x18 ? Ptg18 : Ptg19)[blob[blob.l + 1]];\n\t\tif(!R || !R.f) { /*ptgs.push*/(parsenoop(blob, length)); }\n\t\telse { ptgs.push([R.n, R.f(blob, length, opts)]); }\n\t}\n\treturn ptgs;\n}\n\nfunction stringify_array(f/*:Array<Array<string>>*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\tfor(var i = 0; i < f.length; ++i) {\n\t\tvar x = f[i], r/*:Array<string>*/ = [];\n\t\tfor(var j = 0; j < x.length; ++j) {\n\t\t\tvar y = x[j];\n\t\t\tif(y) switch(y[0]) {\n\t\t\t\t// TODO: handle embedded quotes\n\t\t\t\tcase 0x02:\n\t\t\t\t\t/*:: if(typeof y[1] != 'string') throw \"unreachable\"; */\n\t\t\t\t\tr.push('\"' + y[1].replace(/\"/g,'\"\"') + '\"'); break;\n\t\t\t\tdefault: r.push(y[1]);\n\t\t\t} else r.push(\"\");\n\t\t}\n\t\to.push(r.join(\",\"));\n\t}\n\treturn o.join(\";\");\n}\n\n/* [MS-XLS] 2.2.2 ; [MS-XLSB] 2.2.2 TODO */\nvar PtgBinOp = {\n\tPtgAdd: \"+\",\n\tPtgConcat: \"&\",\n\tPtgDiv: \"/\",\n\tPtgEq: \"=\",\n\tPtgGe: \">=\",\n\tPtgGt: \">\",\n\tPtgLe: \"<=\",\n\tPtgLt: \"<\",\n\tPtgMul: \"*\",\n\tPtgNe: \"<>\",\n\tPtgPower: \"^\",\n\tPtgSub: \"-\"\n};\n\n// List of invalid characters needs to be tested further\nfunction formula_quote_sheet_name(sname/*:string*/, opts)/*:string*/ {\n\tif(!sname && !(opts && opts.biff <= 5 && opts.biff >= 2)) throw new Error(\"empty sheet name\");\n\tif (/[^\\w\\u4E00-\\u9FFF\\u3040-\\u30FF]/.test(sname)) return \"'\" + sname + \"'\";\n\treturn sname;\n}\nfunction get_ixti_raw(supbooks, ixti/*:number*/, opts)/*:string*/ {\n\tif(!supbooks) return \"SH33TJSERR0\";\n\tif(opts.biff > 8 && (!supbooks.XTI || !supbooks.XTI[ixti])) return supbooks.SheetNames[ixti];\n\tif(!supbooks.XTI) return \"SH33TJSERR6\";\n\tvar XTI = supbooks.XTI[ixti];\n\tif(opts.biff < 8) {\n\t\tif(ixti > 10000) ixti-= 65536;\n\t\tif(ixti < 0) ixti = -ixti;\n\t\treturn ixti == 0 ? \"\" : supbooks.XTI[ixti - 1];\n\t}\n\tif(!XTI) return \"SH33TJSERR1\";\n\tvar o = \"\";\n\tif(opts.biff > 8) switch(supbooks[XTI[0]][0]) {\n\t\tcase 0x0165: /* 'BrtSupSelf' */\n\t\t\to = XTI[1] == -1 ? \"#REF\" : supbooks.SheetNames[XTI[1]];\n\t\t\treturn XTI[1] == XTI[2] ? o : o + \":\" + supbooks.SheetNames[XTI[2]];\n\t\tcase 0x0166: /* 'BrtSupSame' */\n\t\t\tif(opts.SID != null) return supbooks.SheetNames[opts.SID];\n\t\t\treturn \"SH33TJSSAME\" + supbooks[XTI[0]][0];\n\t\tcase 0x0163: /* 'BrtSupBookSrc' */\n\t\t\t/* falls through */\n\t\tdefault: return \"SH33TJSSRC\" + supbooks[XTI[0]][0];\n\t}\n\tswitch(supbooks[XTI[0]][0][0]) {\n\t\tcase 0x0401:\n\t\t\to = XTI[1] == -1 ? \"#REF\" : (supbooks.SheetNames[XTI[1]] || \"SH33TJSERR3\");\n\t\t\treturn XTI[1] == XTI[2] ? o : o + \":\" + supbooks.SheetNames[XTI[2]];\n\t\tcase 0x3A01: return supbooks[XTI[0]].slice(1).map(function(name) { return name.Name; }).join(\";;\"); //return \"SH33TJSERR8\";\n\t\tdefault:\n\t\t\tif(!supbooks[XTI[0]][0][3]) return \"SH33TJSERR2\";\n\t\t\to = XTI[1] == -1 ? \"#REF\" : (supbooks[XTI[0]][0][3][XTI[1]] || \"SH33TJSERR4\");\n\t\t\treturn XTI[1] == XTI[2] ? o : o + \":\" + supbooks[XTI[0]][0][3][XTI[2]];\n\t}\n}\nfunction get_ixti(supbooks, ixti/*:number*/, opts)/*:string*/ {\n\tvar ixtiraw = get_ixti_raw(supbooks, ixti, opts);\n\treturn ixtiraw == \"#REF\" ? ixtiraw : formula_quote_sheet_name(ixtiraw, opts);\n}\nfunction stringify_formula(formula/*Array<any>*/, range, cell/*:any*/, supbooks, opts)/*:string*/ {\n\tvar biff = (opts && opts.biff) || 8;\n\tvar _range = /*range != null ? range :*/ {s:{c:0, r:0},e:{c:0, r:0}};\n\tvar stack/*:Array<string>*/ = [], e1, e2, /*::type,*/ c/*:CellAddress*/, ixti=0, nameidx=0, r, sname=\"\";\n\tif(!formula[0] || !formula[0][0]) return \"\";\n\tvar last_sp = -1, sp = \"\";\n\tfor(var ff = 0, fflen = formula[0].length; ff < fflen; ++ff) {\n\t\tvar f = formula[0][ff];\n\t\tswitch(f[0]) {\n\t\t\tcase 'PtgUminus': /* [MS-XLS] 2.5.198.93 */\n\t\t\t\tstack.push(\"-\" + stack.pop()); break;\n\t\t\tcase 'PtgUplus': /* [MS-XLS] 2.5.198.95 */\n\t\t\t\tstack.push(\"+\" + stack.pop()); break;\n\t\t\tcase 'PtgPercent': /* [MS-XLS] 2.5.198.81 */\n\t\t\t\tstack.push(stack.pop() + \"%\"); break;\n\n\t\t\tcase 'PtgAdd': /* [MS-XLS] 2.5.198.26 */\n\t\t\tcase 'PtgConcat': /* [MS-XLS] 2.5.198.43 */\n\t\t\tcase 'PtgDiv': /* [MS-XLS] 2.5.198.45 */\n\t\t\tcase 'PtgEq': /* [MS-XLS] 2.5.198.56 */\n\t\t\tcase 'PtgGe': /* [MS-XLS] 2.5.198.64 */\n\t\t\tcase 'PtgGt': /* [MS-XLS] 2.5.198.65 */\n\t\t\tcase 'PtgLe': /* [MS-XLS] 2.5.198.68 */\n\t\t\tcase 'PtgLt': /* [MS-XLS] 2.5.198.69 */\n\t\t\tcase 'PtgMul': /* [MS-XLS] 2.5.198.75 */\n\t\t\tcase 'PtgNe': /* [MS-XLS] 2.5.198.78 */\n\t\t\tcase 'PtgPower': /* [MS-XLS] 2.5.198.82 */\n\t\t\tcase 'PtgSub': /* [MS-XLS] 2.5.198.90 */\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tif(last_sp >= 0) {\n\t\t\t\t\tswitch(formula[0][last_sp][1][0]) {\n\t\t\t\t\t\tcase 0:\n\t\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\t\tsp = fill(\" \", formula[0][last_sp][1][1]); break;\n\t\t\t\t\t\tcase 1:\n\t\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\t\tsp = fill(\"\\r\", formula[0][last_sp][1][1]); break;\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tsp = \"\";\n\t\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\t\tif(opts.WTF) throw new Error(\"Unexpected PtgAttrSpaceType \" + formula[0][last_sp][1][0]);\n\t\t\t\t\t}\n\t\t\t\t\te2 = e2 + sp;\n\t\t\t\t\tlast_sp = -1;\n\t\t\t\t}\n\t\t\t\tstack.push(e2+PtgBinOp[f[0]]+e1);\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgIsect': /* [MS-XLS] 2.5.198.67 */\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\" \"+e1);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgUnion': /* [MS-XLS] 2.5.198.94 */\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\",\"+e1);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgRange': /* [MS-XLS] 2.5.198.83 */\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\":\"+e1);\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgAttrChoose': /* [MS-XLS] 2.5.198.34 */\n\t\t\t\tbreak;\n\t\t\tcase 'PtgAttrGoto': /* [MS-XLS] 2.5.198.35 */\n\t\t\t\tbreak;\n\t\t\tcase 'PtgAttrIf': /* [MS-XLS] 2.5.198.36 */\n\t\t\t\tbreak;\n\t\t\tcase 'PtgAttrIfError': /* [MS-XLSB] 2.5.97.28 */\n\t\t\t\tbreak;\n\n\n\t\t\tcase 'PtgRef': /* [MS-XLS] 2.5.198.84 */\n\t\t\t\t/*::type = f[1][0]; */c = shift_cell_xls((f[1][1]/*:any*/), _range, opts);\n\t\t\t\tstack.push(encode_cell_xls(c, biff));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgRefN': /* [MS-XLS] 2.5.198.88 */\n\t\t\t\t/*::type = f[1][0]; */c = cell ? shift_cell_xls((f[1][1]/*:any*/), cell, opts) : (f[1][1]/*:any*/);\n\t\t\t\tstack.push(encode_cell_xls(c, biff));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgRef3d': /* [MS-XLS] 2.5.198.85 */\n\t\t\t\t/*::type = f[1][0]; */ixti = /*::Number(*/f[1][1]/*::)*/; c = shift_cell_xls((f[1][2]/*:any*/), _range, opts);\n\t\t\t\tsname = get_ixti(supbooks, ixti, opts);\n\t\t\t\tvar w = sname; /* IE9 fails on defined names */ // eslint-disable-line no-unused-vars\n\t\t\t\tstack.push(sname + \"!\" + encode_cell_xls(c, biff));\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgFunc': /* [MS-XLS] 2.5.198.62 */\n\t\t\tcase 'PtgFuncVar': /* [MS-XLS] 2.5.198.63 */\n\t\t\t\t/* f[1] = [argc, func, type] */\n\t\t\t\tvar argc/*:number*/ = (f[1][0]/*:any*/), func/*:string*/ = (f[1][1]/*:any*/);\n\t\t\t\tif(!argc) argc = 0;\n\t\t\t\targc &= 0x7F;\n\t\t\t\tvar args = argc == 0 ? [] : stack.slice(-argc);\n\t\t\t\tstack.length -= argc;\n\t\t\t\tif(func === 'User') func = args.shift();\n\t\t\t\tstack.push(func + \"(\" + args.join(\",\") + \")\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgBool': /* [MS-XLS] 2.5.198.42 */\n\t\t\t\tstack.push(f[1] ? \"TRUE\" : \"FALSE\"); break;\n\t\t\tcase 'PtgInt': /* [MS-XLS] 2.5.198.66 */\n\t\t\t\tstack.push(/*::String(*/f[1]/*::)*/); break;\n\t\t\tcase 'PtgNum': /* [MS-XLS] 2.5.198.79 TODO: precision? */\n\t\t\t\tstack.push(String(f[1])); break;\n\t\t\tcase 'PtgStr': /* [MS-XLS] 2.5.198.89 */\n\t\t\t\t// $FlowIgnore\n\t\t\t\tstack.push('\"' + f[1].replace(/\"/g, '\"\"') + '\"'); break;\n\t\t\tcase 'PtgErr': /* [MS-XLS] 2.5.198.57 */\n\t\t\t\tstack.push(/*::String(*/f[1]/*::)*/); break;\n\t\t\tcase 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */\n\t\t\t\t/*::type = f[1][0]; */r = shift_range_xls(f[1][1], cell ? {s:cell} : _range, opts);\n\t\t\t\tstack.push(encode_range_xls((r/*:any*/), opts));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgArea': /* [MS-XLS] 2.5.198.27 TODO: fixed points */\n\t\t\t\t/*::type = f[1][0]; */r = shift_range_xls(f[1][1], _range, opts);\n\t\t\t\tstack.push(encode_range_xls((r/*:any*/), opts));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgArea3d': /* [MS-XLS] 2.5.198.28 TODO */\n\t\t\t\t/*::type = f[1][0]; */ixti = /*::Number(*/f[1][1]/*::)*/; r = f[1][2];\n\t\t\t\tsname = get_ixti(supbooks, ixti, opts);\n\t\t\t\tstack.push(sname + \"!\" + encode_range_xls((r/*:any*/), opts));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgAttrSum': /* [MS-XLS] 2.5.198.41 */\n\t\t\t\tstack.push(\"SUM(\" + stack.pop() + \")\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgAttrBaxcel': /* [MS-XLS] 2.5.198.33 */\n\t\t\tcase 'PtgAttrSemi': /* [MS-XLS] 2.5.198.37 */\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgName': /* [MS-XLS] 2.5.198.76 ; [MS-XLSB] 2.5.97.60 TODO: revisions */\n\t\t\t\t/* f[1] = type, 0, nameindex */\n\t\t\t\tnameidx = (f[1][2]/*:any*/);\n\t\t\t\tvar lbl = (supbooks.names||[])[nameidx-1] || (supbooks[0]||[])[nameidx];\n\t\t\t\tvar name = lbl ? lbl.Name : \"SH33TJSNAME\" + String(nameidx);\n\t\t\t\t/* [MS-XLSB] 2.5.97.10 Ftab -- last verified 20220204 */\n\t\t\t\tif(name && name.slice(0,6) == \"_xlfn.\" && !opts.xlfn) name = name.slice(6);\n\t\t\t\tstack.push(name);\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */\n\t\t\t\t/* f[1] = type, ixti, nameindex */\n\t\t\t\tvar bookidx/*:number*/ = (f[1][1]/*:any*/); nameidx = (f[1][2]/*:any*/); var externbook;\n\t\t\t\t/* TODO: Properly handle missing values -- this should be using get_ixti_raw primarily */\n\t\t\t\tif(opts.biff <= 5) {\n\t\t\t\t\tif(bookidx < 0) bookidx = -bookidx;\n\t\t\t\t\tif(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];\n\t\t\t\t} else {\n\t\t\t\t\tvar o = \"\";\n\t\t\t\t\tif(((supbooks[bookidx]||[])[0]||[])[0] == 0x3A01){/* empty */}\n\t\t\t\t\telse if(((supbooks[bookidx]||[])[0]||[])[0] == 0x0401){\n\t\t\t\t\t\tif(supbooks[bookidx][nameidx] && supbooks[bookidx][nameidx].itab > 0) {\n\t\t\t\t\t\t\to = supbooks.SheetNames[supbooks[bookidx][nameidx].itab-1] + \"!\";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse o = supbooks.SheetNames[nameidx-1]+ \"!\";\n\t\t\t\t\tif(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;\n\t\t\t\t\telse if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;\n\t\t\t\t\telse {\n\t\t\t\t\t\tvar ixtidata = (get_ixti_raw(supbooks, bookidx, opts)||\"\").split(\";;\");\n\t\t\t\t\t\tif(ixtidata[nameidx - 1]) o = ixtidata[nameidx - 1]; // TODO: confirm this is correct\n\t\t\t\t\t\telse o += \"SH33TJSERRX\";\n\t\t\t\t\t}\n\t\t\t\t\tstack.push(o);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tif(!externbook) externbook = {Name: \"SH33TJSERRY\"};\n\t\t\t\tstack.push(externbook.Name);\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgParen': /* [MS-XLS] 2.5.198.80 */\n\t\t\t\tvar lp = '(', rp = ')';\n\t\t\t\tif(last_sp >= 0) {\n\t\t\t\t\tsp = \"\";\n\t\t\t\t\tswitch(formula[0][last_sp][1][0]) {\n\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\tcase 2: lp = fill(\" \", formula[0][last_sp][1][1]) + lp; break;\n\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\tcase 3: lp = fill(\"\\r\", formula[0][last_sp][1][1]) + lp; break;\n\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\tcase 4: rp = fill(\" \", formula[0][last_sp][1][1]) + rp; break;\n\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\tcase 5: rp = fill(\"\\r\", formula[0][last_sp][1][1]) + rp; break;\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\t\tif(opts.WTF) throw new Error(\"Unexpected PtgAttrSpaceType \" + formula[0][last_sp][1][0]);\n\t\t\t\t\t}\n\t\t\t\t\tlast_sp = -1;\n\t\t\t\t}\n\t\t\t\tstack.push(lp + stack.pop() + rp); break;\n\n\t\t\tcase 'PtgRefErr': /* [MS-XLS] 2.5.198.86 */\n\t\t\t\tstack.push('#REF!'); break;\n\n\t\t\tcase 'PtgRefErr3d': /* [MS-XLS] 2.5.198.87 */\n\t\t\t\tstack.push('#REF!'); break;\n\n\t\t\tcase 'PtgExp': /* [MS-XLS] 2.5.198.58 TODO */\n\t\t\t\tc = {c:(f[1][1]/*:any*/),r:(f[1][0]/*:any*/)};\n\t\t\t\tvar q = ({c: cell.c, r:cell.r}/*:any*/);\n\t\t\t\tif(supbooks.sharedf[encode_cell(c)]) {\n\t\t\t\t\tvar parsedf = (supbooks.sharedf[encode_cell(c)]);\n\t\t\t\t\tstack.push(stringify_formula(parsedf, _range, q, supbooks, opts));\n\t\t\t\t} else {\n\t\t\t\t\tvar fnd = false;\n\t\t\t\t\tfor(e1=0;e1!=supbooks.arrayf.length; ++e1) {\n\t\t\t\t\t\t/* TODO: should be something like range_has */\n\t\t\t\t\t\te2 = supbooks.arrayf[e1];\n\t\t\t\t\t\tif(c.c < e2[0].s.c || c.c > e2[0].e.c) continue;\n\t\t\t\t\t\tif(c.r < e2[0].s.r || c.r > e2[0].e.r) continue;\n\t\t\t\t\t\tstack.push(stringify_formula(e2[1], _range, q, supbooks, opts));\n\t\t\t\t\t\tfnd = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tif(!fnd) stack.push(/*::String(*/f[1]/*::)*/);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgArray': /* [MS-XLS] 2.5.198.32 TODO */\n\t\t\t\tstack.push(\"{\" + stringify_array(/*::(*/f[1]/*:: :any)*/) + \"}\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMemArea': /* [MS-XLS] 2.5.198.70 TODO: confirm this is a non-display */\n\t\t\t\t//stack.push(\"(\" + f[2].map(encode_range).join(\",\") + \")\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgAttrSpace': /* [MS-XLS] 2.5.198.38 */\n\t\t\tcase 'PtgAttrSpaceSemi': /* [MS-XLS] 2.5.198.39 */\n\t\t\t\tlast_sp = ff;\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgTbl': /* [MS-XLS] 2.5.198.92 TODO */\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMemErr': /* [MS-XLS] 2.5.198.71 */\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMissArg': /* [MS-XLS] 2.5.198.74 */\n\t\t\t\tstack.push(\"\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgAreaErr': /* [MS-XLS] 2.5.198.29 */\n\t\t\t\tstack.push(\"#REF!\"); break;\n\n\t\t\tcase 'PtgAreaErr3d': /* [MS-XLS] 2.5.198.30 */\n\t\t\t\tstack.push(\"#REF!\"); break;\n\n\t\t\tcase 'PtgList': /* [MS-XLSB] 2.5.97.52 */\n\t\t\t\t// $FlowIgnore\n\t\t\t\tstack.push(\"Table\" + f[1].idx + \"[#\" + f[1].rt + \"]\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMemAreaN':\n\t\t\tcase 'PtgMemNoMemN':\n\t\t\tcase 'PtgAttrNoop':\n\t\t\tcase 'PtgSheet':\n\t\t\tcase 'PtgEndSheet':\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMemFunc': /* [MS-XLS] 2.5.198.72 TODO */\n\t\t\t\tbreak;\n\t\t\tcase 'PtgMemNoMem': /* [MS-XLS] 2.5.198.73 TODO */\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgElfCol': /* [MS-XLS] 2.5.198.46 */\n\t\t\tcase 'PtgElfColS': /* [MS-XLS] 2.5.198.47 */\n\t\t\tcase 'PtgElfColSV': /* [MS-XLS] 2.5.198.48 */\n\t\t\tcase 'PtgElfColV': /* [MS-XLS] 2.5.198.49 */\n\t\t\tcase 'PtgElfLel': /* [MS-XLS] 2.5.198.50 */\n\t\t\tcase 'PtgElfRadical': /* [MS-XLS] 2.5.198.51 */\n\t\t\tcase 'PtgElfRadicalLel': /* [MS-XLS] 2.5.198.52 */\n\t\t\tcase 'PtgElfRadicalS': /* [MS-XLS] 2.5.198.53 */\n\t\t\tcase 'PtgElfRw': /* [MS-XLS] 2.5.198.54 */\n\t\t\tcase 'PtgElfRwV': /* [MS-XLS] 2.5.198.55 */\n\t\t\t\tthrow new Error(\"Unsupported ELFs\");\n\n\t\t\tcase 'PtgSxName': /* [MS-XLS] 2.5.198.91 TODO -- find a test case */\n\t\t\t\tthrow new Error('Unrecognized Formula Token: ' + String(f));\n\t\t\tdefault: throw new Error('Unrecognized Formula Token: ' + String(f));\n\t\t}\n\t\tvar PtgNonDisp = ['PtgAttrSpace', 'PtgAttrSpaceSemi', 'PtgAttrGoto'];\n\t\tif(opts.biff != 3) if(last_sp >= 0 && PtgNonDisp.indexOf(formula[0][ff][0]) == -1) {\n\t\t\tf = formula[0][last_sp];\n\t\t\tvar _left = true;\n\t\t\tswitch(f[1][0]) {\n\t\t\t\t/* note: some bad XLSB files omit the PtgParen */\n\t\t\t\tcase 4: _left = false;\n\t\t\t\t/* falls through */\n\t\t\t\tcase 0:\n\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\tsp = fill(\" \", f[1][1]); break;\n\t\t\t\tcase 5: _left = false;\n\t\t\t\t/* falls through */\n\t\t\t\tcase 1:\n\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\tsp = fill(\"\\r\", f[1][1]); break;\n\t\t\t\tdefault:\n\t\t\t\t\tsp = \"\";\n\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\tif(opts.WTF) throw new Error(\"Unexpected PtgAttrSpaceType \" + f[1][0]);\n\t\t\t}\n\t\t\tstack.push((_left ? sp : \"\") + stack.pop() + (_left ? \"\" : sp));\n\t\t\tlast_sp = -1;\n\t\t}\n\t}\n\tif(stack.length > 1 && opts.WTF) throw new Error(\"bad formula stack\");\n\treturn stack[0];\n}\n\n/* [MS-XLS] 2.5.198.1 TODO */\nfunction parse_ArrayParsedFormula(blob, length, opts/*::, ref*/) {\n\tvar target = blob.l + length, len = opts.biff == 2 ? 1 : 2;\n\tvar rgcb, cce = blob.read_shift(len); // length of rgce\n\tif(cce == 0xFFFF) return [[],parsenoop(blob, length-2)];\n\tvar rgce = parse_Rgce(blob, cce, opts);\n\tif(length !== cce + len) rgcb = parse_RgbExtra(blob, length - cce - len, rgce, opts);\n\tblob.l = target;\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLS] 2.5.198.3 TODO */\nfunction parse_XLSCellParsedFormula(blob, length, opts) {\n\tvar target = blob.l + length, len = opts.biff == 2 ? 1 : 2;\n\tvar rgcb, cce = blob.read_shift(len); // length of rgce\n\tif(cce == 0xFFFF) return [[],parsenoop(blob, length-2)];\n\tvar rgce = parse_Rgce(blob, cce, opts);\n\tif(length !== cce + len) rgcb = parse_RgbExtra(blob, length - cce - len, rgce, opts);\n\tblob.l = target;\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLS] 2.5.198.21 */\nfunction parse_NameParsedFormula(blob, length, opts, cce) {\n\tvar target = blob.l + length;\n\tvar rgce = parse_Rgce(blob, cce, opts);\n\tvar rgcb;\n\tif(target !== blob.l) rgcb = parse_RgbExtra(blob, target - blob.l, rgce, opts);\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLS] 2.5.198.118 TODO */\nfunction parse_SharedParsedFormula(blob, length, opts) {\n\tvar target = blob.l + length;\n\tvar rgcb, cce = blob.read_shift(2); // length of rgce\n\tvar rgce = parse_Rgce(blob, cce, opts);\n\tif(cce == 0xFFFF) return [[],parsenoop(blob, length-2)];\n\tif(length !== cce + 2) rgcb = parse_RgbExtra(blob, target - cce - 2, rgce, opts);\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLS] 2.5.133 TODO: how to emit empty strings? */\nfunction parse_FormulaValue(blob/*::, length*/) {\n\tvar b;\n\tif(__readUInt16LE(blob,blob.l + 6) !== 0xFFFF) return [parse_Xnum(blob),'n'];\n\tswitch(blob[blob.l]) {\n\t\tcase 0x00: blob.l += 8; return [\"String\", 's'];\n\t\tcase 0x01: b = blob[blob.l+2] === 0x1; blob.l += 8; return [b,'b'];\n\t\tcase 0x02: b = blob[blob.l+2]; blob.l += 8; return [b,'e'];\n\t\tcase 0x03: blob.l += 8; return [\"\",'s'];\n\t}\n\treturn [];\n}\nfunction write_FormulaValue(value) {\n\tif(value == null) {\n\t\t// Blank String Value\n\t\tvar o = new_buf(8);\n\t\to.write_shift(1, 0x03);\n\t\to.write_shift(1, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0xFFFF);\n\t\treturn o;\n\t} else if(typeof value == \"number\") return write_Xnum(value);\n\treturn write_Xnum(0);\n}\n\n/* [MS-XLS] 2.4.127 TODO */\nfunction parse_Formula(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar cell = parse_XLSCell(blob, 6);\n\tif(opts.biff == 2) ++blob.l;\n\tvar val = parse_FormulaValue(blob,8);\n\tvar flags = blob.read_shift(1);\n\tif(opts.biff != 2) {\n\t\tblob.read_shift(1);\n\t\tif(opts.biff >= 5) {\n\t\t\t/*var chn = */blob.read_shift(4);\n\t\t}\n\t}\n\tvar cbf = parse_XLSCellParsedFormula(blob, end - blob.l, opts);\n\treturn {cell:cell, val:val[0], formula:cbf, shared: (flags >> 3) & 1, tt:val[1]};\n}\nfunction write_Formula(cell/*:Cell*/, R/*:number*/, C/*:number*/, opts, os/*:number*/) {\n\t// Cell\n\tvar o1 = write_XLSCell(R, C, os);\n\n\t// FormulaValue\n\tvar o2 = write_FormulaValue(cell.v);\n\n\t// flags + cache\n\tvar o3 = new_buf(6);\n\tvar flags = 0x01 | 0x20;\n\to3.write_shift(2, flags);\n\to3.write_shift(4, 0);\n\n\t// CellParsedFormula\n\tvar bf = new_buf(cell.bf.length);\n\tfor(var i = 0; i < cell.bf.length; ++i) bf[i] = cell.bf[i];\n\n\tvar out = bconcat([o1, o2, o3, bf]);\n\treturn out;\n}\n\n\n/* XLSB Parsed Formula records have the same shape */\nfunction parse_XLSBParsedFormula(data, length, opts) {\n\tvar cce = data.read_shift(4);\n\tvar rgce = parse_Rgce(data, cce, opts);\n\tvar cb = data.read_shift(4);\n\tvar rgcb = cb > 0 ? parse_RgbExtra(data, cb, rgce, opts) : null;\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLSB] 2.5.97.1 ArrayParsedFormula */\nvar parse_XLSBArrayParsedFormula = parse_XLSBParsedFormula;\n/* [MS-XLSB] 2.5.97.4 CellParsedFormula */\nvar parse_XLSBCellParsedFormula = parse_XLSBParsedFormula;\n/* [MS-XLSB] 2.5.97.8 DVParsedFormula */\n//var parse_XLSBDVParsedFormula = parse_XLSBParsedFormula;\n/* [MS-XLSB] 2.5.97.9 FRTParsedFormula */\n//var parse_XLSBFRTParsedFormula = parse_XLSBParsedFormula2;\n/* [MS-XLSB] 2.5.97.12 NameParsedFormula */\nvar parse_XLSBNameParsedFormula = parse_XLSBParsedFormula;\n/* [MS-XLSB] 2.5.97.98 SharedParsedFormula */\nvar parse_XLSBSharedParsedFormula = parse_XLSBParsedFormula;\nvar Cetab = {\n 0: \"BEEP\",\n 1: \"OPEN\",\n 2: \"OPEN.LINKS\",\n 3: \"CLOSE.ALL\",\n 4: \"SAVE\",\n 5: \"SAVE.AS\",\n 6: \"FILE.DELETE\",\n 7: \"PAGE.SETUP\",\n 8: \"PRINT\",\n 9: \"PRINTER.SETUP\",\n 10: \"QUIT\",\n 11: \"NEW.WINDOW\",\n 12: \"ARRANGE.ALL\",\n 13: \"WINDOW.SIZE\",\n 14: \"WINDOW.MOVE\",\n 15: \"FULL\",\n 16: \"CLOSE\",\n 17: \"RUN\",\n 22: \"SET.PRINT.AREA\",\n 23: \"SET.PRINT.TITLES\",\n 24: \"SET.PAGE.BREAK\",\n 25: \"REMOVE.PAGE.BREAK\",\n 26: \"FONT\",\n 27: \"DISPLAY\",\n 28: \"PROTECT.DOCUMENT\",\n 29: \"PRECISION\",\n 30: \"A1.R1C1\",\n 31: \"CALCULATE.NOW\",\n 32: \"CALCULATION\",\n 34: \"DATA.FIND\",\n 35: \"EXTRACT\",\n 36: \"DATA.DELETE\",\n 37: \"SET.DATABASE\",\n 38: \"SET.CRITERIA\",\n 39: \"SORT\",\n 40: \"DATA.SERIES\",\n 41: \"TABLE\",\n 42: \"FORMAT.NUMBER\",\n 43: \"ALIGNMENT\",\n 44: \"STYLE\",\n 45: \"BORDER\",\n 46: \"CELL.PROTECTION\",\n 47: \"COLUMN.WIDTH\",\n 48: \"UNDO\",\n 49: \"CUT\",\n 50: \"COPY\",\n 51: \"PASTE\",\n 52: \"CLEAR\",\n 53: \"PASTE.SPECIAL\",\n 54: \"EDIT.DELETE\",\n 55: \"INSERT\",\n 56: \"FILL.RIGHT\",\n 57: \"FILL.DOWN\",\n 61: \"DEFINE.NAME\",\n 62: \"CREATE.NAMES\",\n 63: \"FORMULA.GOTO\",\n 64: \"FORMULA.FIND\",\n 65: \"SELECT.LAST.CELL\",\n 66: \"SHOW.ACTIVE.CELL\",\n 67: \"GALLERY.AREA\",\n 68: \"GALLERY.BAR\",\n 69: \"GALLERY.COLUMN\",\n 70: \"GALLERY.LINE\",\n 71: \"GALLERY.PIE\",\n 72: \"GALLERY.SCATTER\",\n 73: \"COMBINATION\",\n 74: \"PREFERRED\",\n 75: \"ADD.OVERLAY\",\n 76: \"GRIDLINES\",\n 77: \"SET.PREFERRED\",\n 78: \"AXES\",\n 79: \"LEGEND\",\n 80: \"ATTACH.TEXT\",\n 81: \"ADD.ARROW\",\n 82: \"SELECT.CHART\",\n 83: \"SELECT.PLOT.AREA\",\n 84: \"PATTERNS\",\n 85: \"MAIN.CHART\",\n 86: \"OVERLAY\",\n 87: \"SCALE\",\n 88: \"FORMAT.LEGEND\",\n 89: \"FORMAT.TEXT\",\n 90: \"EDIT.REPEAT\",\n 91: \"PARSE\",\n 92: \"JUSTIFY\",\n 93: \"HIDE\",\n 94: \"UNHIDE\",\n 95: \"WORKSPACE\",\n 96: \"FORMULA\",\n 97: \"FORMULA.FILL\",\n 98: \"FORMULA.ARRAY\",\n 99: \"DATA.FIND.NEXT\",\n 100: \"DATA.FIND.PREV\",\n 101: \"FORMULA.FIND.NEXT\",\n 102: \"FORMULA.FIND.PREV\",\n 103: \"ACTIVATE\",\n 104: \"ACTIVATE.NEXT\",\n 105: \"ACTIVATE.PREV\",\n 106: \"UNLOCKED.NEXT\",\n 107: \"UNLOCKED.PREV\",\n 108: \"COPY.PICTURE\",\n 109: \"SELECT\",\n 110: \"DELETE.NAME\",\n 111: \"DELETE.FORMAT\",\n 112: \"VLINE\",\n 113: \"HLINE\",\n 114: \"VPAGE\",\n 115: \"HPAGE\",\n 116: \"VSCROLL\",\n 117: \"HSCROLL\",\n 118: \"ALERT\",\n 119: \"NEW\",\n 120: \"CANCEL.COPY\",\n 121: \"SHOW.CLIPBOARD\",\n 122: \"MESSAGE\",\n 124: \"PASTE.LINK\",\n 125: \"APP.ACTIVATE\",\n 126: \"DELETE.ARROW\",\n 127: \"ROW.HEIGHT\",\n 128: \"FORMAT.MOVE\",\n 129: \"FORMAT.SIZE\",\n 130: \"FORMULA.REPLACE\",\n 131: \"SEND.KEYS\",\n 132: \"SELECT.SPECIAL\",\n 133: \"APPLY.NAMES\",\n 134: \"REPLACE.FONT\",\n 135: \"FREEZE.PANES\",\n 136: \"SHOW.INFO\",\n 137: \"SPLIT\",\n 138: \"ON.WINDOW\",\n 139: \"ON.DATA\",\n 140: \"DISABLE.INPUT\",\n 142: \"OUTLINE\",\n 143: \"LIST.NAMES\",\n 144: \"FILE.CLOSE\",\n 145: \"SAVE.WORKBOOK\",\n 146: \"DATA.FORM\",\n 147: \"COPY.CHART\",\n 148: \"ON.TIME\",\n 149: \"WAIT\",\n 150: \"FORMAT.FONT\",\n 151: \"FILL.UP\",\n 152: \"FILL.LEFT\",\n 153: \"DELETE.OVERLAY\",\n 155: \"SHORT.MENUS\",\n 159: \"SET.UPDATE.STATUS\",\n 161: \"COLOR.PALETTE\",\n 162: \"DELETE.STYLE\",\n 163: \"WINDOW.RESTORE\",\n 164: \"WINDOW.MAXIMIZE\",\n 166: \"CHANGE.LINK\",\n 167: \"CALCULATE.DOCUMENT\",\n 168: \"ON.KEY\",\n 169: \"APP.RESTORE\",\n 170: \"APP.MOVE\",\n 171: \"APP.SIZE\",\n 172: \"APP.MINIMIZE\",\n 173: \"APP.MAXIMIZE\",\n 174: \"BRING.TO.FRONT\",\n 175: \"SEND.TO.BACK\",\n 185: \"MAIN.CHART.TYPE\",\n 186: \"OVERLAY.CHART.TYPE\",\n 187: \"SELECT.END\",\n 188: \"OPEN.MAIL\",\n 189: \"SEND.MAIL\",\n 190: \"STANDARD.FONT\",\n 191: \"CONSOLIDATE\",\n 192: \"SORT.SPECIAL\",\n 193: \"GALLERY.3D.AREA\",\n 194: \"GALLERY.3D.COLUMN\",\n 195: \"GALLERY.3D.LINE\",\n 196: \"GALLERY.3D.PIE\",\n 197: \"VIEW.3D\",\n 198: \"GOAL.SEEK\",\n 199: \"WORKGROUP\",\n 200: \"FILL.GROUP\",\n 201: \"UPDATE.LINK\",\n 202: \"PROMOTE\",\n 203: \"DEMOTE\",\n 204: \"SHOW.DETAIL\",\n 206: \"UNGROUP\",\n 207: \"OBJECT.PROPERTIES\",\n 208: \"SAVE.NEW.OBJECT\",\n 209: \"SHARE\",\n 210: \"SHARE.NAME\",\n 211: \"DUPLICATE\",\n 212: \"APPLY.STYLE\",\n 213: \"ASSIGN.TO.OBJECT\",\n 214: \"OBJECT.PROTECTION\",\n 215: \"HIDE.OBJECT\",\n 216: \"SET.EXTRACT\",\n 217: \"CREATE.PUBLISHER\",\n 218: \"SUBSCRIBE.TO\",\n 219: \"ATTRIBUTES\",\n 220: \"SHOW.TOOLBAR\",\n 222: \"PRINT.PREVIEW\",\n 223: \"EDIT.COLOR\",\n 224: \"SHOW.LEVELS\",\n 225: \"FORMAT.MAIN\",\n 226: \"FORMAT.OVERLAY\",\n 227: \"ON.RECALC\",\n 228: \"EDIT.SERIES\",\n 229: \"DEFINE.STYLE\",\n 240: \"LINE.PRINT\",\n 243: \"ENTER.DATA\",\n 249: \"GALLERY.RADAR\",\n 250: \"MERGE.STYLES\",\n 251: \"EDITION.OPTIONS\",\n 252: \"PASTE.PICTURE\",\n 253: \"PASTE.PICTURE.LINK\",\n 254: \"SPELLING\",\n 256: \"ZOOM\",\n 259: \"INSERT.OBJECT\",\n 260: \"WINDOW.MINIMIZE\",\n 265: \"SOUND.NOTE\",\n 266: \"SOUND.PLAY\",\n 267: \"FORMAT.SHAPE\",\n 268: \"EXTEND.POLYGON\",\n 269: \"FORMAT.AUTO\",\n 272: \"GALLERY.3D.BAR\",\n 273: \"GALLERY.3D.SURFACE\",\n 274: \"FILL.AUTO\",\n 276: \"CUSTOMIZE.TOOLBAR\",\n 277: \"ADD.TOOL\",\n 278: \"EDIT.OBJECT\",\n 279: \"ON.DOUBLECLICK\",\n 280: \"ON.ENTRY\",\n 281: \"WORKBOOK.ADD\",\n 282: \"WORKBOOK.MOVE\",\n 283: \"WORKBOOK.COPY\",\n 284: \"WORKBOOK.OPTIONS\",\n 285: \"SAVE.WORKSPACE\",\n 288: \"CHART.WIZARD\",\n 289: \"DELETE.TOOL\",\n 290: \"MOVE.TOOL\",\n 291: \"WORKBOOK.SELECT\",\n 292: \"WORKBOOK.ACTIVATE\",\n 293: \"ASSIGN.TO.TOOL\",\n 295: \"COPY.TOOL\",\n 296: \"RESET.TOOL\",\n 297: \"CONSTRAIN.NUMERIC\",\n 298: \"PASTE.TOOL\",\n 302: \"WORKBOOK.NEW\",\n 305: \"SCENARIO.CELLS\",\n 306: \"SCENARIO.DELETE\",\n 307: \"SCENARIO.ADD\",\n 308: \"SCENARIO.EDIT\",\n 309: \"SCENARIO.SHOW\",\n 310: \"SCENARIO.SHOW.NEXT\",\n 311: \"SCENARIO.SUMMARY\",\n 312: \"PIVOT.TABLE.WIZARD\",\n 313: \"PIVOT.FIELD.PROPERTIES\",\n 314: \"PIVOT.FIELD\",\n 315: \"PIVOT.ITEM\",\n 316: \"PIVOT.ADD.FIELDS\",\n 318: \"OPTIONS.CALCULATION\",\n 319: \"OPTIONS.EDIT\",\n 320: \"OPTIONS.VIEW\",\n 321: \"ADDIN.MANAGER\",\n 322: \"MENU.EDITOR\",\n 323: \"ATTACH.TOOLBARS\",\n 324: \"VBAActivate\",\n 325: \"OPTIONS.CHART\",\n 328: \"VBA.INSERT.FILE\",\n 330: \"VBA.PROCEDURE.DEFINITION\",\n 336: \"ROUTING.SLIP\",\n 338: \"ROUTE.DOCUMENT\",\n 339: \"MAIL.LOGON\",\n 342: \"INSERT.PICTURE\",\n 343: \"EDIT.TOOL\",\n 344: \"GALLERY.DOUGHNUT\",\n 350: \"CHART.TREND\",\n 352: \"PIVOT.ITEM.PROPERTIES\",\n 354: \"WORKBOOK.INSERT\",\n 355: \"OPTIONS.TRANSITION\",\n 356: \"OPTIONS.GENERAL\",\n 370: \"FILTER.ADVANCED\",\n 373: \"MAIL.ADD.MAILER\",\n 374: \"MAIL.DELETE.MAILER\",\n 375: \"MAIL.REPLY\",\n 376: \"MAIL.REPLY.ALL\",\n 377: \"MAIL.FORWARD\",\n 378: \"MAIL.NEXT.LETTER\",\n 379: \"DATA.LABEL\",\n 380: \"INSERT.TITLE\",\n 381: \"FONT.PROPERTIES\",\n 382: \"MACRO.OPTIONS\",\n 383: \"WORKBOOK.HIDE\",\n 384: \"WORKBOOK.UNHIDE\",\n 385: \"WORKBOOK.DELETE\",\n 386: \"WORKBOOK.NAME\",\n 388: \"GALLERY.CUSTOM\",\n 390: \"ADD.CHART.AUTOFORMAT\",\n 391: \"DELETE.CHART.AUTOFORMAT\",\n 392: \"CHART.ADD.DATA\",\n 393: \"AUTO.OUTLINE\",\n 394: \"TAB.ORDER\",\n 395: \"SHOW.DIALOG\",\n 396: \"SELECT.ALL\",\n 397: \"UNGROUP.SHEETS\",\n 398: \"SUBTOTAL.CREATE\",\n 399: \"SUBTOTAL.REMOVE\",\n 400: \"RENAME.OBJECT\",\n 412: \"WORKBOOK.SCROLL\",\n 413: \"WORKBOOK.NEXT\",\n 414: \"WORKBOOK.PREV\",\n 415: \"WORKBOOK.TAB.SPLIT\",\n 416: \"FULL.SCREEN\",\n 417: \"WORKBOOK.PROTECT\",\n 420: \"SCROLLBAR.PROPERTIES\",\n 421: \"PIVOT.SHOW.PAGES\",\n 422: \"TEXT.TO.COLUMNS\",\n 423: \"FORMAT.CHARTTYPE\",\n 424: \"LINK.FORMAT\",\n 425: \"TRACER.DISPLAY\",\n 430: \"TRACER.NAVIGATE\",\n 431: \"TRACER.CLEAR\",\n 432: \"TRACER.ERROR\",\n 433: \"PIVOT.FIELD.GROUP\",\n 434: \"PIVOT.FIELD.UNGROUP\",\n 435: \"CHECKBOX.PROPERTIES\",\n 436: \"LABEL.PROPERTIES\",\n 437: \"LISTBOX.PROPERTIES\",\n 438: \"EDITBOX.PROPERTIES\",\n 439: \"PIVOT.REFRESH\",\n 440: \"LINK.COMBO\",\n 441: \"OPEN.TEXT\",\n 442: \"HIDE.DIALOG\",\n 443: \"SET.DIALOG.FOCUS\",\n 444: \"ENABLE.OBJECT\",\n 445: \"PUSHBUTTON.PROPERTIES\",\n 446: \"SET.DIALOG.DEFAULT\",\n 447: \"FILTER\",\n 448: \"FILTER.SHOW.ALL\",\n 449: \"CLEAR.OUTLINE\",\n 450: \"FUNCTION.WIZARD\",\n 451: \"ADD.LIST.ITEM\",\n 452: \"SET.LIST.ITEM\",\n 453: \"REMOVE.LIST.ITEM\",\n 454: \"SELECT.LIST.ITEM\",\n 455: \"SET.CONTROL.VALUE\",\n 456: \"SAVE.COPY.AS\",\n 458: \"OPTIONS.LISTS.ADD\",\n 459: \"OPTIONS.LISTS.DELETE\",\n 460: \"SERIES.AXES\",\n 461: \"SERIES.X\",\n 462: \"SERIES.Y\",\n 463: \"ERRORBAR.X\",\n 464: \"ERRORBAR.Y\",\n 465: \"FORMAT.CHART\",\n 466: \"SERIES.ORDER\",\n 467: \"MAIL.LOGOFF\",\n 468: \"CLEAR.ROUTING.SLIP\",\n 469: \"APP.ACTIVATE.MICROSOFT\",\n 470: \"MAIL.EDIT.MAILER\",\n 471: \"ON.SHEET\",\n 472: \"STANDARD.WIDTH\",\n 473: \"SCENARIO.MERGE\",\n 474: \"SUMMARY.INFO\",\n 475: \"FIND.FILE\",\n 476: \"ACTIVE.CELL.FONT\",\n 477: \"ENABLE.TIPWIZARD\",\n 478: \"VBA.MAKE.ADDIN\",\n 480: \"INSERTDATATABLE\",\n 481: \"WORKGROUP.OPTIONS\",\n 482: \"MAIL.SEND.MAILER\",\n 485: \"AUTOCORRECT\",\n 489: \"POST.DOCUMENT\",\n 491: \"PICKLIST\",\n 493: \"VIEW.SHOW\",\n 494: \"VIEW.DEFINE\",\n 495: \"VIEW.DELETE\",\n 509: \"SHEET.BACKGROUND\",\n 510: \"INSERT.MAP.OBJECT\",\n 511: \"OPTIONS.MENONO\",\n 517: \"MSOCHECKS\",\n 518: \"NORMAL\",\n 519: \"LAYOUT\",\n 520: \"RM.PRINT.AREA\",\n 521: \"CLEAR.PRINT.AREA\",\n 522: \"ADD.PRINT.AREA\",\n 523: \"MOVE.BRK\",\n 545: \"HIDECURR.NOTE\",\n 546: \"HIDEALL.NOTES\",\n 547: \"DELETE.NOTE\",\n 548: \"TRAVERSE.NOTES\",\n 549: \"ACTIVATE.NOTES\",\n 620: \"PROTECT.REVISIONS\",\n 621: \"UNPROTECT.REVISIONS\",\n 647: \"OPTIONS.ME\",\n 653: \"WEB.PUBLISH\",\n 667: \"NEWWEBQUERY\",\n 673: \"PIVOT.TABLE.CHART\",\n 753: \"OPTIONS.SAVE\",\n 755: \"OPTIONS.SPELL\",\n 808: \"HIDEALL.INKANNOTS\"\n};\nvar Ftab = {\n 0: \"COUNT\",\n 1: \"IF\",\n 2: \"ISNA\",\n 3: \"ISERROR\",\n 4: \"SUM\",\n 5: \"AVERAGE\",\n 6: \"MIN\",\n 7: \"MAX\",\n 8: \"ROW\",\n 9: \"COLUMN\",\n 10: \"NA\",\n 11: \"NPV\",\n 12: \"STDEV\",\n 13: \"DOLLAR\",\n 14: \"FIXED\",\n 15: \"SIN\",\n 16: \"COS\",\n 17: \"TAN\",\n 18: \"ATAN\",\n 19: \"PI\",\n 20: \"SQRT\",\n 21: \"EXP\",\n 22: \"LN\",\n 23: \"LOG10\",\n 24: \"ABS\",\n 25: \"INT\",\n 26: \"SIGN\",\n 27: \"ROUND\",\n 28: \"LOOKUP\",\n 29: \"INDEX\",\n 30: \"REPT\",\n 31: \"MID\",\n 32: \"LEN\",\n 33: \"VALUE\",\n 34: \"TRUE\",\n 35: \"FALSE\",\n 36: \"AND\",\n 37: \"OR\",\n 38: \"NOT\",\n 39: \"MOD\",\n 40: \"DCOUNT\",\n 41: \"DSUM\",\n 42: \"DAVERAGE\",\n 43: \"DMIN\",\n 44: \"DMAX\",\n 45: \"DSTDEV\",\n 46: \"VAR\",\n 47: \"DVAR\",\n 48: \"TEXT\",\n 49: \"LINEST\",\n 50: \"TREND\",\n 51: \"LOGEST\",\n 52: \"GROWTH\",\n 53: \"GOTO\",\n 54: \"HALT\",\n 55: \"RETURN\",\n 56: \"PV\",\n 57: \"FV\",\n 58: \"NPER\",\n 59: \"PMT\",\n 60: \"RATE\",\n 61: \"MIRR\",\n 62: \"IRR\",\n 63: \"RAND\",\n 64: \"MATCH\",\n 65: \"DATE\",\n 66: \"TIME\",\n 67: \"DAY\",\n 68: \"MONTH\",\n 69: \"YEAR\",\n 70: \"WEEKDAY\",\n 71: \"HOUR\",\n 72: \"MINUTE\",\n 73: \"SECOND\",\n 74: \"NOW\",\n 75: \"AREAS\",\n 76: \"ROWS\",\n 77: \"COLUMNS\",\n 78: \"OFFSET\",\n 79: \"ABSREF\",\n 80: \"RELREF\",\n 81: \"ARGUMENT\",\n 82: \"SEARCH\",\n 83: \"TRANSPOSE\",\n 84: \"ERROR\",\n 85: \"STEP\",\n 86: \"TYPE\",\n 87: \"ECHO\",\n 88: \"SET.NAME\",\n 89: \"CALLER\",\n 90: \"DEREF\",\n 91: \"WINDOWS\",\n 92: \"SERIES\",\n 93: \"DOCUMENTS\",\n 94: \"ACTIVE.CELL\",\n 95: \"SELECTION\",\n 96: \"RESULT\",\n 97: \"ATAN2\",\n 98: \"ASIN\",\n 99: \"ACOS\",\n 100: \"CHOOSE\",\n 101: \"HLOOKUP\",\n 102: \"VLOOKUP\",\n 103: \"LINKS\",\n 104: \"INPUT\",\n 105: \"ISREF\",\n 106: \"GET.FORMULA\",\n 107: \"GET.NAME\",\n 108: \"SET.VALUE\",\n 109: \"LOG\",\n 110: \"EXEC\",\n 111: \"CHAR\",\n 112: \"LOWER\",\n 113: \"UPPER\",\n 114: \"PROPER\",\n 115: \"LEFT\",\n 116: \"RIGHT\",\n 117: \"EXACT\",\n 118: \"TRIM\",\n 119: \"REPLACE\",\n 120: \"SUBSTITUTE\",\n 121: \"CODE\",\n 122: \"NAMES\",\n 123: \"DIRECTORY\",\n 124: \"FIND\",\n 125: \"CELL\",\n 126: \"ISERR\",\n 127: \"ISTEXT\",\n 128: \"ISNUMBER\",\n 129: \"ISBLANK\",\n 130: \"T\",\n 131: \"N\",\n 132: \"FOPEN\",\n 133: \"FCLOSE\",\n 134: \"FSIZE\",\n 135: \"FREADLN\",\n 136: \"FREAD\",\n 137: \"FWRITELN\",\n 138: \"FWRITE\",\n 139: \"FPOS\",\n 140: \"DATEVALUE\",\n 141: \"TIMEVALUE\",\n 142: \"SLN\",\n 143: \"SYD\",\n 144: \"DDB\",\n 145: \"GET.DEF\",\n 146: \"REFTEXT\",\n 147: \"TEXTREF\",\n 148: \"INDIRECT\",\n 149: \"REGISTER\",\n 150: \"CALL\",\n 151: \"ADD.BAR\",\n 152: \"ADD.MENU\",\n 153: \"ADD.COMMAND\",\n 154: \"ENABLE.COMMAND\",\n 155: \"CHECK.COMMAND\",\n 156: \"RENAME.COMMAND\",\n 157: \"SHOW.BAR\",\n 158: \"DELETE.MENU\",\n 159: \"DELETE.COMMAND\",\n 160: \"GET.CHART.ITEM\",\n 161: \"DIALOG.BOX\",\n 162: \"CLEAN\",\n 163: \"MDETERM\",\n 164: \"MINVERSE\",\n 165: \"MMULT\",\n 166: \"FILES\",\n 167: \"IPMT\",\n 168: \"PPMT\",\n 169: \"COUNTA\",\n 170: \"CANCEL.KEY\",\n 171: \"FOR\",\n 172: \"WHILE\",\n 173: \"BREAK\",\n 174: \"NEXT\",\n 175: \"INITIATE\",\n 176: \"REQUEST\",\n 177: \"POKE\",\n 178: \"EXECUTE\",\n 179: \"TERMINATE\",\n 180: \"RESTART\",\n 181: \"HELP\",\n 182: \"GET.BAR\",\n 183: \"PRODUCT\",\n 184: \"FACT\",\n 185: \"GET.CELL\",\n 186: \"GET.WORKSPACE\",\n 187: \"GET.WINDOW\",\n 188: \"GET.DOCUMENT\",\n 189: \"DPRODUCT\",\n 190: \"ISNONTEXT\",\n 191: \"GET.NOTE\",\n 192: \"NOTE\",\n 193: \"STDEVP\",\n 194: \"VARP\",\n 195: \"DSTDEVP\",\n 196: \"DVARP\",\n 197: \"TRUNC\",\n 198: \"ISLOGICAL\",\n 199: \"DCOUNTA\",\n 200: \"DELETE.BAR\",\n 201: \"UNREGISTER\",\n 204: \"USDOLLAR\",\n 205: \"FINDB\",\n 206: \"SEARCHB\",\n 207: \"REPLACEB\",\n 208: \"LEFTB\",\n 209: \"RIGHTB\",\n 210: \"MIDB\",\n 211: \"LENB\",\n 212: \"ROUNDUP\",\n 213: \"ROUNDDOWN\",\n 214: \"ASC\",\n 215: \"DBCS\",\n 216: \"RANK\",\n 219: \"ADDRESS\",\n 220: \"DAYS360\",\n 221: \"TODAY\",\n 222: \"VDB\",\n 223: \"ELSE\",\n 224: \"ELSE.IF\",\n 225: \"END.IF\",\n 226: \"FOR.CELL\",\n 227: \"MEDIAN\",\n 228: \"SUMPRODUCT\",\n 229: \"SINH\",\n 230: \"COSH\",\n 231: \"TANH\",\n 232: \"ASINH\",\n 233: \"ACOSH\",\n 234: \"ATANH\",\n 235: \"DGET\",\n 236: \"CREATE.OBJECT\",\n 237: \"VOLATILE\",\n 238: \"LAST.ERROR\",\n 239: \"CUSTOM.UNDO\",\n 240: \"CUSTOM.REPEAT\",\n 241: \"FORMULA.CONVERT\",\n 242: \"GET.LINK.INFO\",\n 243: \"TEXT.BOX\",\n 244: \"INFO\",\n 245: \"GROUP\",\n 246: \"GET.OBJECT\",\n 247: \"DB\",\n 248: \"PAUSE\",\n 251: \"RESUME\",\n 252: \"FREQUENCY\",\n 253: \"ADD.TOOLBAR\",\n 254: \"DELETE.TOOLBAR\",\n 255: \"User\",\n 256: \"RESET.TOOLBAR\",\n 257: \"EVALUATE\",\n 258: \"GET.TOOLBAR\",\n 259: \"GET.TOOL\",\n 260: \"SPELLING.CHECK\",\n 261: \"ERROR.TYPE\",\n 262: \"APP.TITLE\",\n 263: \"WINDOW.TITLE\",\n 264: \"SAVE.TOOLBAR\",\n 265: \"ENABLE.TOOL\",\n 266: \"PRESS.TOOL\",\n 267: \"REGISTER.ID\",\n 268: \"GET.WORKBOOK\",\n 269: \"AVEDEV\",\n 270: \"BETADIST\",\n 271: \"GAMMALN\",\n 272: \"BETAINV\",\n 273: \"BINOMDIST\",\n 274: \"CHIDIST\",\n 275: \"CHIINV\",\n 276: \"COMBIN\",\n 277: \"CONFIDENCE\",\n 278: \"CRITBINOM\",\n 279: \"EVEN\",\n 280: \"EXPONDIST\",\n 281: \"FDIST\",\n 282: \"FINV\",\n 283: \"FISHER\",\n 284: \"FISHERINV\",\n 285: \"FLOOR\",\n 286: \"GAMMADIST\",\n 287: \"GAMMAINV\",\n 288: \"CEILING\",\n 289: \"HYPGEOMDIST\",\n 290: \"LOGNORMDIST\",\n 291: \"LOGINV\",\n 292: \"NEGBINOMDIST\",\n 293: \"NORMDIST\",\n 294: \"NORMSDIST\",\n 295: \"NORMINV\",\n 296: \"NORMSINV\",\n 297: \"STANDARDIZE\",\n 298: \"ODD\",\n 299: \"PERMUT\",\n 300: \"POISSON\",\n 301: \"TDIST\",\n 302: \"WEIBULL\",\n 303: \"SUMXMY2\",\n 304: \"SUMX2MY2\",\n 305: \"SUMX2PY2\",\n 306: \"CHITEST\",\n 307: \"CORREL\",\n 308: \"COVAR\",\n 309: \"FORECAST\",\n 310: \"FTEST\",\n 311: \"INTERCEPT\",\n 312: \"PEARSON\",\n 313: \"RSQ\",\n 314: \"STEYX\",\n 315: \"SLOPE\",\n 316: \"TTEST\",\n 317: \"PROB\",\n 318: \"DEVSQ\",\n 319: \"GEOMEAN\",\n 320: \"HARMEAN\",\n 321: \"SUMSQ\",\n 322: \"KURT\",\n 323: \"SKEW\",\n 324: \"ZTEST\",\n 325: \"LARGE\",\n 326: \"SMALL\",\n 327: \"QUARTILE\",\n 328: \"PERCENTILE\",\n 329: \"PERCENTRANK\",\n 330: \"MODE\",\n 331: \"TRIMMEAN\",\n 332: \"TINV\",\n 334: \"MOVIE.COMMAND\",\n 335: \"GET.MOVIE\",\n 336: \"CONCATENATE\",\n 337: \"POWER\",\n 338: \"PIVOT.ADD.DATA\",\n 339: \"GET.PIVOT.TABLE\",\n 340: \"GET.PIVOT.FIELD\",\n 341: \"GET.PIVOT.ITEM\",\n 342: \"RADIANS\",\n 343: \"DEGREES\",\n 344: \"SUBTOTAL\",\n 345: \"SUMIF\",\n 346: \"COUNTIF\",\n 347: \"COUNTBLANK\",\n 348: \"SCENARIO.GET\",\n 349: \"OPTIONS.LISTS.GET\",\n 350: \"ISPMT\",\n 351: \"DATEDIF\",\n 352: \"DATESTRING\",\n 353: \"NUMBERSTRING\",\n 354: \"ROMAN\",\n 355: \"OPEN.DIALOG\",\n 356: \"SAVE.DIALOG\",\n 357: \"VIEW.GET\",\n 358: \"GETPIVOTDATA\",\n 359: \"HYPERLINK\",\n 360: \"PHONETIC\",\n 361: \"AVERAGEA\",\n 362: \"MAXA\",\n 363: \"MINA\",\n 364: \"STDEVPA\",\n 365: \"VARPA\",\n 366: \"STDEVA\",\n 367: \"VARA\",\n 368: \"BAHTTEXT\",\n 369: \"THAIDAYOFWEEK\",\n 370: \"THAIDIGIT\",\n 371: \"THAIMONTHOFYEAR\",\n 372: \"THAINUMSOUND\",\n 373: \"THAINUMSTRING\",\n 374: \"THAISTRINGLENGTH\",\n 375: \"ISTHAIDIGIT\",\n 376: \"ROUNDBAHTDOWN\",\n 377: \"ROUNDBAHTUP\",\n 378: \"THAIYEAR\",\n 379: \"RTD\",\n 380: \"CUBEVALUE\",\n 381: \"CUBEMEMBER\",\n 382: \"CUBEMEMBERPROPERTY\",\n 383: \"CUBERANKEDMEMBER\",\n 384: \"HEX2BIN\",\n 385: \"HEX2DEC\",\n 386: \"HEX2OCT\",\n 387: \"DEC2BIN\",\n 388: \"DEC2HEX\",\n 389: \"DEC2OCT\",\n 390: \"OCT2BIN\",\n 391: \"OCT2HEX\",\n 392: \"OCT2DEC\",\n 393: \"BIN2DEC\",\n 394: \"BIN2OCT\",\n 395: \"BIN2HEX\",\n 396: \"IMSUB\",\n 397: \"IMDIV\",\n 398: \"IMPOWER\",\n 399: \"IMABS\",\n 400: \"IMSQRT\",\n 401: \"IMLN\",\n 402: \"IMLOG2\",\n 403: \"IMLOG10\",\n 404: \"IMSIN\",\n 405: \"IMCOS\",\n 406: \"IMEXP\",\n 407: \"IMARGUMENT\",\n 408: \"IMCONJUGATE\",\n 409: \"IMAGINARY\",\n 410: \"IMREAL\",\n 411: \"COMPLEX\",\n 412: \"IMSUM\",\n 413: \"IMPRODUCT\",\n 414: \"SERIESSUM\",\n 415: \"FACTDOUBLE\",\n 416: \"SQRTPI\",\n 417: \"QUOTIENT\",\n 418: \"DELTA\",\n 419: \"GESTEP\",\n 420: \"ISEVEN\",\n 421: \"ISODD\",\n 422: \"MROUND\",\n 423: \"ERF\",\n 424: \"ERFC\",\n 425: \"BESSELJ\",\n 426: \"BESSELK\",\n 427: \"BESSELY\",\n 428: \"BESSELI\",\n 429: \"XIRR\",\n 430: \"XNPV\",\n 431: \"PRICEMAT\",\n 432: \"YIELDMAT\",\n 433: \"INTRATE\",\n 434: \"RECEIVED\",\n 435: \"DISC\",\n 436: \"PRICEDISC\",\n 437: \"YIELDDISC\",\n 438: \"TBILLEQ\",\n 439: \"TBILLPRICE\",\n 440: \"TBILLYIELD\",\n 441: \"PRICE\",\n 442: \"YIELD\",\n 443: \"DOLLARDE\",\n 444: \"DOLLARFR\",\n 445: \"NOMINAL\",\n 446: \"EFFECT\",\n 447: \"CUMPRINC\",\n 448: \"CUMIPMT\",\n 449: \"EDATE\",\n 450: \"EOMONTH\",\n 451: \"YEARFRAC\",\n 452: \"COUPDAYBS\",\n 453: \"COUPDAYS\",\n 454: \"COUPDAYSNC\",\n 455: \"COUPNCD\",\n 456: \"COUPNUM\",\n 457: \"COUPPCD\",\n 458: \"DURATION\",\n 459: \"MDURATION\",\n 460: \"ODDLPRICE\",\n 461: \"ODDLYIELD\",\n 462: \"ODDFPRICE\",\n 463: \"ODDFYIELD\",\n 464: \"RANDBETWEEN\",\n 465: \"WEEKNUM\",\n 466: \"AMORDEGRC\",\n 467: \"AMORLINC\",\n 468: \"CONVERT\",\n 724: \"SHEETJS\",\n 469: \"ACCRINT\",\n 470: \"ACCRINTM\",\n 471: \"WORKDAY\",\n 472: \"NETWORKDAYS\",\n 473: \"GCD\",\n 474: \"MULTINOMIAL\",\n 475: \"LCM\",\n 476: \"FVSCHEDULE\",\n 477: \"CUBEKPIMEMBER\",\n 478: \"CUBESET\",\n 479: \"CUBESETCOUNT\",\n 480: \"IFERROR\",\n 481: \"COUNTIFS\",\n 482: \"SUMIFS\",\n 483: \"AVERAGEIF\",\n 484: \"AVERAGEIFS\"\n};\nvar FtabArgc = {\n 2: 1,\n 3: 1,\n 10: 0,\n 15: 1,\n 16: 1,\n 17: 1,\n 18: 1,\n 19: 0,\n 20: 1,\n 21: 1,\n 22: 1,\n 23: 1,\n 24: 1,\n 25: 1,\n 26: 1,\n 27: 2,\n 30: 2,\n 31: 3,\n 32: 1,\n 33: 1,\n 34: 0,\n 35: 0,\n 38: 1,\n 39: 2,\n 40: 3,\n 41: 3,\n 42: 3,\n 43: 3,\n 44: 3,\n 45: 3,\n 47: 3,\n 48: 2,\n 53: 1,\n 61: 3,\n 63: 0,\n 65: 3,\n 66: 3,\n 67: 1,\n 68: 1,\n 69: 1,\n 70: 1,\n 71: 1,\n 72: 1,\n 73: 1,\n 74: 0,\n 75: 1,\n 76: 1,\n 77: 1,\n 79: 2,\n 80: 2,\n 83: 1,\n 85: 0,\n 86: 1,\n 89: 0,\n 90: 1,\n 94: 0,\n 95: 0,\n 97: 2,\n 98: 1,\n 99: 1,\n 101: 3,\n 102: 3,\n 105: 1,\n 106: 1,\n 108: 2,\n 111: 1,\n 112: 1,\n 113: 1,\n 114: 1,\n 117: 2,\n 118: 1,\n 119: 4,\n 121: 1,\n 126: 1,\n 127: 1,\n 128: 1,\n 129: 1,\n 130: 1,\n 131: 1,\n 133: 1,\n 134: 1,\n 135: 1,\n 136: 2,\n 137: 2,\n 138: 2,\n 140: 1,\n 141: 1,\n 142: 3,\n 143: 4,\n 144: 4,\n 161: 1,\n 162: 1,\n 163: 1,\n 164: 1,\n 165: 2,\n 172: 1,\n 175: 2,\n 176: 2,\n 177: 3,\n 178: 2,\n 179: 1,\n 184: 1,\n 186: 1,\n 189: 3,\n 190: 1,\n 195: 3,\n 196: 3,\n 197: 1,\n 198: 1,\n 199: 3,\n 201: 1,\n 207: 4,\n 210: 3,\n 211: 1,\n 212: 2,\n 213: 2,\n 214: 1,\n 215: 1,\n 225: 0,\n 229: 1,\n 230: 1,\n 231: 1,\n 232: 1,\n 233: 1,\n 234: 1,\n 235: 3,\n 244: 1,\n 247: 4,\n 252: 2,\n 257: 1,\n 261: 1,\n 271: 1,\n 273: 4,\n 274: 2,\n 275: 2,\n 276: 2,\n 277: 3,\n 278: 3,\n 279: 1,\n 280: 3,\n 281: 3,\n 282: 3,\n 283: 1,\n 284: 1,\n 285: 2,\n 286: 4,\n 287: 3,\n 288: 2,\n 289: 4,\n 290: 3,\n 291: 3,\n 292: 3,\n 293: 4,\n 294: 1,\n 295: 3,\n 296: 1,\n 297: 3,\n 298: 1,\n 299: 2,\n 300: 3,\n 301: 3,\n 302: 4,\n 303: 2,\n 304: 2,\n 305: 2,\n 306: 2,\n 307: 2,\n 308: 2,\n 309: 3,\n 310: 2,\n 311: 2,\n 312: 2,\n 313: 2,\n 314: 2,\n 315: 2,\n 316: 4,\n 325: 2,\n 326: 2,\n 327: 2,\n 328: 2,\n 331: 2,\n 332: 2,\n 337: 2,\n 342: 1,\n 343: 1,\n 346: 2,\n 347: 1,\n 350: 4,\n 351: 3,\n 352: 1,\n 353: 2,\n 360: 1,\n 368: 1,\n 369: 1,\n 370: 1,\n 371: 1,\n 372: 1,\n 373: 1,\n 374: 1,\n 375: 1,\n 376: 1,\n 377: 1,\n 378: 1,\n 382: 3,\n 385: 1,\n 392: 1,\n 393: 1,\n 396: 2,\n 397: 2,\n 398: 2,\n 399: 1,\n 400: 1,\n 401: 1,\n 402: 1,\n 403: 1,\n 404: 1,\n 405: 1,\n 406: 1,\n 407: 1,\n 408: 1,\n 409: 1,\n 410: 1,\n 414: 4,\n 415: 1,\n 416: 1,\n 417: 2,\n 420: 1,\n 421: 1,\n 422: 2,\n 424: 1,\n 425: 2,\n 426: 2,\n 427: 2,\n 428: 2,\n 430: 3,\n 438: 3,\n 439: 3,\n 440: 3,\n 443: 2,\n 444: 2,\n 445: 2,\n 446: 2,\n 447: 6,\n 448: 6,\n 449: 2,\n 450: 2,\n 464: 2,\n 468: 3,\n 476: 2,\n 479: 1,\n 480: 2,\n 65535: 0\n};\n/* Part 3 TODO: actually parse formulae */\nfunction ods_to_csf_formula(f/*:string*/)/*:string*/ {\n\tif(f.slice(0,3) == \"of:\") f = f.slice(3);\n\t/* 5.2 Basic Expressions */\n\tif(f.charCodeAt(0) == 61) {\n\t\tf = f.slice(1);\n\t\tif(f.charCodeAt(0) == 61) f = f.slice(1);\n\t}\n\tf = f.replace(/COM\\.MICROSOFT\\./g, \"\");\n\t/* Part 3 Section 5.8 References */\n\tf = f.replace(/\\[((?:\\.[A-Z]+[0-9]+)(?::\\.[A-Z]+[0-9]+)?)\\]/g, function($$, $1) { return $1.replace(/\\./g,\"\"); });\n\t/* TODO: something other than this */\n\tf = f.replace(/\\[.(#[A-Z]*[?!])\\]/g, \"$1\");\n\treturn f.replace(/[;~]/g,\",\").replace(/\\|/g,\";\");\n}\n\nfunction csf_to_ods_formula(f/*:string*/)/*:string*/ {\n\tvar o = \"of:=\" + f.replace(crefregex, \"$1[.$2$3$4$5]\").replace(/\\]:\\[/g,\":\");\n\t/* TODO: something other than this */\n\treturn o.replace(/;/g, \"|\").replace(/,/g,\";\");\n}\n\nfunction ods_to_csf_3D(r/*:string*/)/*:[string, string]*/ {\n\tvar a = r.split(\":\");\n\tvar s = a[0].split(\".\")[0];\n\treturn [s, a[0].split(\".\")[1] + (a.length > 1 ? (\":\" + (a[1].split(\".\")[1] || a[1].split(\".\")[0])) : \"\")];\n}\n\nfunction csf_to_ods_3D(r/*:string*/)/*:string*/ {\n\treturn r.replace(/\\./,\"!\");\n}\n\nvar strs = {}; // shared strings\nvar _ssfopts = {}; // spreadsheet formatting options\n\n\n/*global Map */\nvar browser_has_Map = typeof Map !== 'undefined';\n\nfunction get_sst_id(sst/*:SST*/, str/*:string*/, rev)/*:number*/ {\n\tvar i = 0, len = sst.length;\n\tif(rev) {\n\t\tif(browser_has_Map ? rev.has(str) : Object.prototype.hasOwnProperty.call(rev, str)) {\n\t\t\tvar revarr = browser_has_Map ? rev.get(str) : rev[str];\n\t\t\tfor(; i < revarr.length; ++i) {\n\t\t\t\tif(sst[revarr[i]].t === str) { sst.Count ++; return revarr[i]; }\n\t\t\t}\n\t\t}\n\t} else for(; i < len; ++i) {\n\t\tif(sst[i].t === str) { sst.Count ++; return i; }\n\t}\n\tsst[len] = ({t:str}/*:any*/); sst.Count ++; sst.Unique ++;\n\tif(rev) {\n\t\tif(browser_has_Map) {\n\t\t\tif(!rev.has(str)) rev.set(str, []);\n\t\t\trev.get(str).push(len);\n\t\t} else {\n\t\t\tif(!Object.prototype.hasOwnProperty.call(rev, str)) rev[str] = [];\n\t\t\trev[str].push(len);\n\t\t}\n\t}\n\treturn len;\n}\n\nfunction col_obj_w(C/*:number*/, col) {\n\tvar p = ({min:C+1,max:C+1}/*:any*/);\n\t/* wch (chars), wpx (pixels) */\n\tvar wch = -1;\n\tif(col.MDW) MDW = col.MDW;\n\tif(col.width != null) p.customWidth = 1;\n\telse if(col.wpx != null) wch = px2char(col.wpx);\n\telse if(col.wch != null) wch = col.wch;\n\tif(wch > -1) { p.width = char2width(wch); p.customWidth = 1; }\n\telse if(col.width != null) p.width = col.width;\n\tif(col.hidden) p.hidden = true;\n\tif(col.level != null) { p.outlineLevel = p.level = col.level; }\n\treturn p;\n}\n\nfunction default_margins(margins/*:Margins*/, mode/*:?string*/) {\n\tif(!margins) return;\n\tvar defs = [0.7, 0.7, 0.75, 0.75, 0.3, 0.3];\n\tif(mode == 'xlml') defs = [1, 1, 1, 1, 0.5, 0.5];\n\tif(margins.left == null) margins.left = defs[0];\n\tif(margins.right == null) margins.right = defs[1];\n\tif(margins.top == null) margins.top = defs[2];\n\tif(margins.bottom == null) margins.bottom = defs[3];\n\tif(margins.header == null) margins.header = defs[4];\n\tif(margins.footer == null) margins.footer = defs[5];\n}\n\nfunction get_cell_style(styles/*:Array<any>*/, cell/*:Cell*/, opts) {\n\tvar z = opts.revssf[cell.z != null ? cell.z : \"General\"];\n\tvar i = 0x3c, len = styles.length;\n\tif(z == null && opts.ssf) {\n\t\tfor(; i < 0x188; ++i) if(opts.ssf[i] == null) {\n\t\t\tSSF_load(cell.z, i);\n\t\t\t// $FlowIgnore\n\t\t\topts.ssf[i] = cell.z;\n\t\t\topts.revssf[cell.z] = z = i;\n\t\t\tbreak;\n\t\t}\n\t}\n\tfor(i = 0; i != len; ++i) if(styles[i].numFmtId === z) return i;\n\tstyles[len] = {\n\t\tnumFmtId:z,\n\t\tfontId:0,\n\t\tfillId:0,\n\t\tborderId:0,\n\t\txfId:0,\n\t\tapplyNumberFormat:1\n\t};\n\treturn len;\n}\n\nfunction safe_format(p/*:Cell*/, fmtid/*:number*/, fillid/*:?number*/, opts, themes, styles) {\n\ttry {\n\t\tif(opts.cellNF) p.z = table_fmt[fmtid];\n\t} catch(e) { if(opts.WTF) throw e; }\n\tif(p.t === 'z' && !opts.cellStyles) return;\n\tif(p.t === 'd' && typeof p.v === 'string') p.v = parseDate(p.v);\n\tif((!opts || opts.cellText !== false) && p.t !== 'z') try {\n\t\tif(table_fmt[fmtid] == null) SSF_load(SSFImplicit[fmtid] || \"General\", fmtid);\n\t\tif(p.t === 'e') p.w = p.w || BErr[p.v];\n\t\telse if(fmtid === 0) {\n\t\t\tif(p.t === 'n') {\n\t\t\t\tif((p.v|0) === p.v) p.w = p.v.toString(10);\n\t\t\t\telse p.w = SSF_general_num(p.v);\n\t\t\t}\n\t\t\telse if(p.t === 'd') {\n\t\t\t\tvar dd = datenum(p.v);\n\t\t\t\tif((dd|0) === dd) p.w = dd.toString(10);\n\t\t\t\telse p.w = SSF_general_num(dd);\n\t\t\t}\n\t\t\telse if(p.v === undefined) return \"\";\n\t\t\telse p.w = SSF_general(p.v,_ssfopts);\n\t\t}\n\t\telse if(p.t === 'd') p.w = SSF_format(fmtid,datenum(p.v),_ssfopts);\n\t\telse p.w = SSF_format(fmtid,p.v,_ssfopts);\n\t} catch(e) { if(opts.WTF) throw e; }\n\tif(!opts.cellStyles) return;\n\tif(fillid != null) try {\n\t\tp.s = styles.Fills[fillid];\n\t\tif (p.s.fgColor && p.s.fgColor.theme && !p.s.fgColor.rgb) {\n\t\t\tp.s.fgColor.rgb = rgb_tint(themes.themeElements.clrScheme[p.s.fgColor.theme].rgb, p.s.fgColor.tint || 0);\n\t\t\tif(opts.WTF) p.s.fgColor.raw_rgb = themes.themeElements.clrScheme[p.s.fgColor.theme].rgb;\n\t\t}\n\t\tif (p.s.bgColor && p.s.bgColor.theme) {\n\t\t\tp.s.bgColor.rgb = rgb_tint(themes.themeElements.clrScheme[p.s.bgColor.theme].rgb, p.s.bgColor.tint || 0);\n\t\t\tif(opts.WTF) p.s.bgColor.raw_rgb = themes.themeElements.clrScheme[p.s.bgColor.theme].rgb;\n\t\t}\n\t} catch(e) { if(opts.WTF && styles.Fills) throw e; }\n}\n\nfunction check_ws(ws/*:Worksheet*/, sname/*:string*/, i/*:number*/) {\n\tif(ws && ws['!ref']) {\n\t\tvar range = safe_decode_range(ws['!ref']);\n\t\tif(range.e.c < range.s.c || range.e.r < range.s.r) throw new Error(\"Bad range (\" + i + \"): \" + ws['!ref']);\n\t}\n}\nfunction parse_ws_xml_dim(ws/*:Worksheet*/, s/*:string*/) {\n\tvar d = safe_decode_range(s);\n\tif(d.s.r<=d.e.r && d.s.c<=d.e.c && d.s.r>=0 && d.s.c>=0) ws[\"!ref\"] = encode_range(d);\n}\nvar mergecregex = /<(?:\\w:)?mergeCell ref=\"[A-Z0-9:]+\"\\s*[\\/]?>/g;\nvar sheetdataregex = /<(?:\\w+:)?sheetData[^>]*>([\\s\\S]*)<\\/(?:\\w+:)?sheetData>/;\nvar hlinkregex = /<(?:\\w:)?hyperlink [^>]*>/mg;\nvar dimregex = /\"(\\w*:\\w*)\"/;\nvar colregex = /<(?:\\w:)?col\\b[^>]*[\\/]?>/g;\nvar afregex = /<(?:\\w:)?autoFilter[^>]*([\\/]|>([\\s\\S]*)<\\/(?:\\w:)?autoFilter)>/g;\nvar marginregex= /<(?:\\w:)?pageMargins[^>]*\\/>/g;\nvar sheetprregex = /<(?:\\w:)?sheetPr\\b(?:[^>a-z][^>]*)?\\/>/;\nvar sheetprregex2= /<(?:\\w:)?sheetPr[^>]*(?:[\\/]|>([\\s\\S]*)<\\/(?:\\w:)?sheetPr)>/;\nvar svsregex = /<(?:\\w:)?sheetViews[^>]*(?:[\\/]|>([\\s\\S]*)<\\/(?:\\w:)?sheetViews)>/;\n\n/* 18.3 Worksheets */\nfunction parse_ws_xml(data/*:?string*/, opts, idx/*:number*/, rels, wb/*:WBWBProps*/, themes, styles)/*:Worksheet*/ {\n\tif(!data) return data;\n\tif(!rels) rels = {'!id':{}};\n\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\n\t/* 18.3.1.99 worksheet CT_Worksheet */\n\tvar s = opts.dense ? ([]/*:any*/) : ({}/*:any*/);\n\tvar refguess/*:Range*/ = ({s: {r:2000000, c:2000000}, e: {r:0, c:0} }/*:any*/);\n\n\tvar data1 = \"\", data2 = \"\";\n\tvar mtch/*:?any*/ = data.match(sheetdataregex);\n\tif(mtch) {\n\t\tdata1 = data.slice(0, mtch.index);\n\t\tdata2 = data.slice(mtch.index + mtch[0].length);\n\t} else data1 = data2 = data;\n\n\t/* 18.3.1.82 sheetPr CT_SheetPr */\n\tvar sheetPr = data1.match(sheetprregex);\n\tif(sheetPr) parse_ws_xml_sheetpr(sheetPr[0], s, wb, idx);\n\telse if((sheetPr = data1.match(sheetprregex2))) parse_ws_xml_sheetpr2(sheetPr[0], sheetPr[1]||\"\", s, wb, idx, styles, themes);\n\n\t/* 18.3.1.35 dimension CT_SheetDimension */\n\tvar ridx = (data1.match(/<(?:\\w*:)?dimension/)||{index:-1}).index;\n\tif(ridx > 0) {\n\t\tvar ref = data1.slice(ridx,ridx+50).match(dimregex);\n\t\tif(ref) parse_ws_xml_dim(s, ref[1]);\n\t}\n\n\t/* 18.3.1.88 sheetViews CT_SheetViews */\n\tvar svs = data1.match(svsregex);\n\tif(svs && svs[1]) parse_ws_xml_sheetviews(svs[1], wb);\n\n\t/* 18.3.1.17 cols CT_Cols */\n\tvar columns/*:Array<ColInfo>*/ = [];\n\tif(opts.cellStyles) {\n\t\t/* 18.3.1.13 col CT_Col */\n\t\tvar cols = data1.match(colregex);\n\t\tif(cols) parse_ws_xml_cols(columns, cols);\n\t}\n\n\t/* 18.3.1.80 sheetData CT_SheetData ? */\n\tif(mtch) parse_ws_xml_data(mtch[1], s, opts, refguess, themes, styles);\n\n\t/* 18.3.1.2 autoFilter CT_AutoFilter */\n\tvar afilter = data2.match(afregex);\n\tif(afilter) s['!autofilter'] = parse_ws_xml_autofilter(afilter[0]);\n\n\t/* 18.3.1.55 mergeCells CT_MergeCells */\n\tvar merges/*:Array<Range>*/ = [];\n\tvar _merge = data2.match(mergecregex);\n\tif(_merge) for(ridx = 0; ridx != _merge.length; ++ridx)\n\t\tmerges[ridx] = safe_decode_range(_merge[ridx].slice(_merge[ridx].indexOf(\"\\\"\")+1));\n\n\t/* 18.3.1.48 hyperlinks CT_Hyperlinks */\n\tvar hlink = data2.match(hlinkregex);\n\tif(hlink) parse_ws_xml_hlinks(s, hlink, rels);\n\n\t/* 18.3.1.62 pageMargins CT_PageMargins */\n\tvar margins = data2.match(marginregex);\n\tif(margins) s['!margins'] = parse_ws_xml_margins(parsexmltag(margins[0]));\n\n\tif(!s[\"!ref\"] && refguess.e.c >= refguess.s.c && refguess.e.r >= refguess.s.r) s[\"!ref\"] = encode_range(refguess);\n\tif(opts.sheetRows > 0 && s[\"!ref\"]) {\n\t\tvar tmpref = safe_decode_range(s[\"!ref\"]);\n\t\tif(opts.sheetRows <= +tmpref.e.r) {\n\t\t\ttmpref.e.r = opts.sheetRows - 1;\n\t\t\tif(tmpref.e.r > refguess.e.r) tmpref.e.r = refguess.e.r;\n\t\t\tif(tmpref.e.r < tmpref.s.r) tmpref.s.r = tmpref.e.r;\n\t\t\tif(tmpref.e.c > refguess.e.c) tmpref.e.c = refguess.e.c;\n\t\t\tif(tmpref.e.c < tmpref.s.c) tmpref.s.c = tmpref.e.c;\n\t\t\ts[\"!fullref\"] = s[\"!ref\"];\n\t\t\ts[\"!ref\"] = encode_range(tmpref);\n\t\t}\n\t}\n\tif(columns.length > 0) s[\"!cols\"] = columns;\n\tif(merges.length > 0) s[\"!merges\"] = merges;\n\treturn s;\n}\n\nfunction write_ws_xml_merges(merges/*:Array<Range>*/)/*:string*/ {\n\tif(merges.length === 0) return \"\";\n\tvar o = '<mergeCells count=\"' + merges.length + '\">';\n\tfor(var i = 0; i != merges.length; ++i) o += '<mergeCell ref=\"' + encode_range(merges[i]) + '\"/>';\n\treturn o + '</mergeCells>';\n}\n\n/* 18.3.1.82-3 sheetPr CT_ChartsheetPr / CT_SheetPr */\nfunction parse_ws_xml_sheetpr(sheetPr/*:string*/, s, wb/*:WBWBProps*/, idx/*:number*/) {\n\tvar data = parsexmltag(sheetPr);\n\tif(!wb.Sheets[idx]) wb.Sheets[idx] = {};\n\tif(data.codeName) wb.Sheets[idx].CodeName = unescapexml(utf8read(data.codeName));\n}\nfunction parse_ws_xml_sheetpr2(sheetPr/*:string*/, body/*:string*/, s, wb/*:WBWBProps*/, idx/*:number*/) {\n\tparse_ws_xml_sheetpr(sheetPr.slice(0, sheetPr.indexOf(\">\")), s, wb, idx);\n}\nfunction write_ws_xml_sheetpr(ws, wb, idx, opts, o) {\n\tvar needed = false;\n\tvar props = {}, payload = null;\n\tif(opts.bookType !== 'xlsx' && wb.vbaraw) {\n\t\tvar cname = wb.SheetNames[idx];\n\t\ttry { if(wb.Workbook) cname = wb.Workbook.Sheets[idx].CodeName || cname; } catch(e) {}\n\t\tneeded = true;\n\t\tprops.codeName = utf8write(escapexml(cname));\n\t}\n\n\tif(ws && ws[\"!outline\"]) {\n\t\tvar outlineprops = {summaryBelow:1, summaryRight:1};\n\t\tif(ws[\"!outline\"].above) outlineprops.summaryBelow = 0;\n\t\tif(ws[\"!outline\"].left) outlineprops.summaryRight = 0;\n\t\tpayload = (payload||\"\") + writextag('outlinePr', null, outlineprops);\n\t}\n\n\tif(!needed && !payload) return;\n\to[o.length] = (writextag('sheetPr', payload, props));\n}\n\n/* 18.3.1.85 sheetProtection CT_SheetProtection */\nvar sheetprot_deffalse = [\"objects\", \"scenarios\", \"selectLockedCells\", \"selectUnlockedCells\"];\nvar sheetprot_deftrue = [\n\t\"formatColumns\", \"formatRows\", \"formatCells\",\n\t\"insertColumns\", \"insertRows\", \"insertHyperlinks\",\n\t\"deleteColumns\", \"deleteRows\",\n\t\"sort\", \"autoFilter\", \"pivotTables\"\n];\nfunction write_ws_xml_protection(sp)/*:string*/ {\n\t// algorithmName, hashValue, saltValue, spinCount\n\tvar o = ({sheet:1}/*:any*/);\n\tsheetprot_deffalse.forEach(function(n) { if(sp[n] != null && sp[n]) o[n] = \"1\"; });\n\tsheetprot_deftrue.forEach(function(n) { if(sp[n] != null && !sp[n]) o[n] = \"0\"; });\n\t/* TODO: algorithm */\n\tif(sp.password) o.password = crypto_CreatePasswordVerifier_Method1(sp.password).toString(16).toUpperCase();\n\treturn writextag('sheetProtection', null, o);\n}\n\nfunction parse_ws_xml_hlinks(s, data/*:Array<string>*/, rels) {\n\tvar dense = Array.isArray(s);\n\tfor(var i = 0; i != data.length; ++i) {\n\t\tvar val = parsexmltag(utf8read(data[i]), true);\n\t\tif(!val.ref) return;\n\t\tvar rel = ((rels || {})['!id']||[])[val.id];\n\t\tif(rel) {\n\t\t\tval.Target = rel.Target;\n\t\t\tif(val.location) val.Target += \"#\"+unescapexml(val.location);\n\t\t} else {\n\t\t\tval.Target = \"#\" + unescapexml(val.location);\n\t\t\trel = {Target: val.Target, TargetMode: 'Internal'};\n\t\t}\n\t\tval.Rel = rel;\n\t\tif(val.tooltip) { val.Tooltip = val.tooltip; delete val.tooltip; }\n\t\tvar rng = safe_decode_range(val.ref);\n\t\tfor(var R=rng.s.r;R<=rng.e.r;++R) for(var C=rng.s.c;C<=rng.e.c;++C) {\n\t\t\tvar addr = encode_cell({c:C,r:R});\n\t\t\tif(dense) {\n\t\t\t\tif(!s[R]) s[R] = [];\n\t\t\t\tif(!s[R][C]) s[R][C] = {t:\"z\",v:undefined};\n\t\t\t\ts[R][C].l = val;\n\t\t\t} else {\n\t\t\t\tif(!s[addr]) s[addr] = {t:\"z\",v:undefined};\n\t\t\t\ts[addr].l = val;\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction parse_ws_xml_margins(margin) {\n\tvar o = {};\n\t[\"left\", \"right\", \"top\", \"bottom\", \"header\", \"footer\"].forEach(function(k) {\n\t\tif(margin[k]) o[k] = parseFloat(margin[k]);\n\t});\n\treturn o;\n}\nfunction write_ws_xml_margins(margin)/*:string*/ {\n\tdefault_margins(margin);\n\treturn writextag('pageMargins', null, margin);\n}\n\nfunction parse_ws_xml_cols(columns, cols) {\n\tvar seencol = false;\n\tfor(var coli = 0; coli != cols.length; ++coli) {\n\t\tvar coll = parsexmltag(cols[coli], true);\n\t\tif(coll.hidden) coll.hidden = parsexmlbool(coll.hidden);\n\t\tvar colm=parseInt(coll.min, 10)-1, colM=parseInt(coll.max,10)-1;\n\t\tif(coll.outlineLevel) coll.level = (+coll.outlineLevel || 0);\n\t\tdelete coll.min; delete coll.max; coll.width = +coll.width;\n\t\tif(!seencol && coll.width) { seencol = true; find_mdw_colw(coll.width); }\n\t\tprocess_col(coll);\n\t\twhile(colm <= colM) columns[colm++] = dup(coll);\n\t}\n}\nfunction write_ws_xml_cols(ws, cols)/*:string*/ {\n\tvar o = [\"<cols>\"], col;\n\tfor(var i = 0; i != cols.length; ++i) {\n\t\tif(!(col = cols[i])) continue;\n\t\to[o.length] = (writextag('col', null, col_obj_w(i, col)));\n\t}\n\to[o.length] = \"</cols>\";\n\treturn o.join(\"\");\n}\n\nfunction parse_ws_xml_autofilter(data/*:string*/) {\n\tvar o = { ref: (data.match(/ref=\"([^\"]*)\"/)||[])[1]};\n\treturn o;\n}\nfunction write_ws_xml_autofilter(data, ws, wb, idx)/*:string*/ {\n\tvar ref = typeof data.ref == \"string\" ? data.ref : encode_range(data.ref);\n\tif(!wb.Workbook) wb.Workbook = ({Sheets:[]}/*:any*/);\n\tif(!wb.Workbook.Names) wb.Workbook.Names = [];\n\tvar names/*: Array<any> */ = wb.Workbook.Names;\n\tvar range = decode_range(ref);\n\tif(range.s.r == range.e.r) { range.e.r = decode_range(ws[\"!ref\"]).e.r; ref = encode_range(range); }\n\tfor(var i = 0; i < names.length; ++i) {\n\t\tvar name = names[i];\n\t\tif(name.Name != '_xlnm._FilterDatabase') continue;\n\t\tif(name.Sheet != idx) continue;\n\t\tname.Ref = \"'\" + wb.SheetNames[idx] + \"'!\" + ref; break;\n\t}\n\tif(i == names.length) names.push({ Name: '_xlnm._FilterDatabase', Sheet: idx, Ref: \"'\" + wb.SheetNames[idx] + \"'!\" + ref });\n\treturn writextag(\"autoFilter\", null, {ref:ref});\n}\n\n/* 18.3.1.88 sheetViews CT_SheetViews */\n/* 18.3.1.87 sheetView CT_SheetView */\nvar sviewregex = /<(?:\\w:)?sheetView(?:[^>a-z][^>]*)?\\/?>/;\nfunction parse_ws_xml_sheetviews(data, wb/*:WBWBProps*/) {\n\tif(!wb.Views) wb.Views = [{}];\n\t(data.match(sviewregex)||[]).forEach(function(r/*:string*/, i/*:number*/) {\n\t\tvar tag = parsexmltag(r);\n\t\t// $FlowIgnore\n\t\tif(!wb.Views[i]) wb.Views[i] = {};\n\t\t// $FlowIgnore\n\t\tif(+tag.zoomScale) wb.Views[i].zoom = +tag.zoomScale;\n\t\t// $FlowIgnore\n\t\tif(parsexmlbool(tag.rightToLeft)) wb.Views[i].RTL = true;\n\t});\n}\nfunction write_ws_xml_sheetviews(ws, opts, idx, wb)/*:string*/ {\n\tvar sview = ({workbookViewId:\"0\"}/*:any*/);\n\t// $FlowIgnore\n\tif((((wb||{}).Workbook||{}).Views||[])[0]) sview.rightToLeft = wb.Workbook.Views[0].RTL ? \"1\" : \"0\";\n\treturn writextag(\"sheetViews\", writextag(\"sheetView\", null, sview), {});\n}\n\nfunction write_ws_xml_cell(cell/*:Cell*/, ref, ws, opts/*::, idx, wb*/)/*:string*/ {\n\tif(cell.c) ws['!comments'].push([ref, cell.c]);\n\tif(cell.v === undefined && typeof cell.f !== \"string\" || cell.t === 'z' && !cell.f) return \"\";\n\tvar vv = \"\";\n\tvar oldt = cell.t, oldv = cell.v;\n\tif(cell.t !== \"z\") switch(cell.t) {\n\t\tcase 'b': vv = cell.v ? \"1\" : \"0\"; break;\n\t\tcase 'n': vv = ''+cell.v; break;\n\t\tcase 'e': vv = BErr[cell.v]; break;\n\t\tcase 'd':\n\t\t\tif(opts && opts.cellDates) vv = parseDate(cell.v, -1).toISOString();\n\t\t\telse {\n\t\t\t\tcell = dup(cell);\n\t\t\t\tcell.t = 'n';\n\t\t\t\tvv = ''+(cell.v = datenum(parseDate(cell.v)));\n\t\t\t}\n\t\t\tif(typeof cell.z === 'undefined') cell.z = table_fmt[14];\n\t\t\tbreak;\n\t\tdefault: vv = cell.v; break;\n\t}\n\tvar v = writetag('v', escapexml(vv)), o = ({r:ref}/*:any*/);\n\t/* TODO: cell style */\n\tvar os = get_cell_style(opts.cellXfs, cell, opts);\n\tif(os !== 0) o.s = os;\n\tswitch(cell.t) {\n\t\tcase 'n': break;\n\t\tcase 'd': o.t = \"d\"; break;\n\t\tcase 'b': o.t = \"b\"; break;\n\t\tcase 'e': o.t = \"e\"; break;\n\t\tcase 'z': break;\n\t\tdefault: if(cell.v == null) { delete cell.t; break; }\n\t\t\tif(cell.v.length > 32767) throw new Error(\"Text length must not exceed 32767 characters\");\n\t\t\tif(opts && opts.bookSST) {\n\t\t\t\tv = writetag('v', ''+get_sst_id(opts.Strings, cell.v, opts.revStrings));\n\t\t\t\to.t = \"s\"; break;\n\t\t\t}\n\t\t\to.t = \"str\"; break;\n\t}\n\tif(cell.t != oldt) { cell.t = oldt; cell.v = oldv; }\n\tif(typeof cell.f == \"string\" && cell.f) {\n\t\tvar ff = cell.F && cell.F.slice(0, ref.length) == ref ? {t:\"array\", ref:cell.F} : null;\n\t\tv = writextag('f', escapexml(cell.f), ff) + (cell.v != null ? v : \"\");\n\t}\n\tif(cell.l) ws['!links'].push([ref, cell.l]);\n\tif(cell.D) o.cm = 1;\n\treturn writextag('c', v, o);\n}\n\nvar parse_ws_xml_data = /*#__PURE__*/(function() {\n\tvar cellregex = /<(?:\\w+:)?c[ \\/>]/, rowregex = /<\\/(?:\\w+:)?row>/;\n\tvar rregex = /r=[\"']([^\"']*)[\"']/, isregex = /<(?:\\w+:)?is>([\\S\\s]*?)<\\/(?:\\w+:)?is>/;\n\tvar refregex = /ref=[\"']([^\"']*)[\"']/;\n\tvar match_v = matchtag(\"v\"), match_f = matchtag(\"f\");\n\nreturn function parse_ws_xml_data(sdata/*:string*/, s, opts, guess/*:Range*/, themes, styles) {\n\tvar ri = 0, x = \"\", cells/*:Array<string>*/ = [], cref/*:?Array<string>*/ = [], idx=0, i=0, cc=0, d=\"\", p/*:any*/;\n\tvar tag, tagr = 0, tagc = 0;\n\tvar sstr, ftag;\n\tvar fmtid = 0, fillid = 0;\n\tvar do_format = Array.isArray(styles.CellXf), cf;\n\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\tvar sharedf = [];\n\tvar dense = Array.isArray(s);\n\tvar rows/*:Array<RowInfo>*/ = [], rowobj = {}, rowrite = false;\n\tvar sheetStubs = !!opts.sheetStubs;\n\tfor(var marr = sdata.split(rowregex), mt = 0, marrlen = marr.length; mt != marrlen; ++mt) {\n\t\tx = marr[mt].trim();\n\t\tvar xlen = x.length;\n\t\tif(xlen === 0) continue;\n\n\t\t/* 18.3.1.73 row CT_Row */\n\t\tvar rstarti = 0;\n\t\touta: for(ri = 0; ri < xlen; ++ri) switch(/*x.charCodeAt(ri)*/x[ri]) {\n\t\t\tcase \">\" /*62*/:\n\t\t\t\tif(/*x.charCodeAt(ri-1) != 47*/x[ri-1] != \"/\") { ++ri; break outa; }\n\t\t\t\tif(opts && opts.cellStyles) {\n\t\t\t\t\t// TODO: avoid duplication\n\t\t\t\t\ttag = parsexmltag(x.slice(rstarti,ri), true);\n\t\t\t\t\ttagr = tag.r != null ? parseInt(tag.r, 10) : tagr+1; tagc = -1;\n\t\t\t\t\tif(opts.sheetRows && opts.sheetRows < tagr) continue;\n\t\t\t\t\trowobj = {}; rowrite = false;\n\t\t\t\t\tif(tag.ht) { rowrite = true; rowobj.hpt = parseFloat(tag.ht); rowobj.hpx = pt2px(rowobj.hpt); }\n\t\t\t\t\tif(tag.hidden == \"1\") { rowrite = true; rowobj.hidden = true; }\n\t\t\t\t\tif(tag.outlineLevel != null) { rowrite = true; rowobj.level = +tag.outlineLevel; }\n\t\t\t\t\tif(rowrite) rows[tagr-1] = rowobj;\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase \"<\" /*60*/: rstarti = ri; break;\n\t\t}\n\t\tif(rstarti >= ri) break;\n\t\ttag = parsexmltag(x.slice(rstarti,ri), true);\n\t\ttagr = tag.r != null ? parseInt(tag.r, 10) : tagr+1; tagc = -1;\n\t\tif(opts.sheetRows && opts.sheetRows < tagr) continue;\n\t\tif(guess.s.r > tagr - 1) guess.s.r = tagr - 1;\n\t\tif(guess.e.r < tagr - 1) guess.e.r = tagr - 1;\n\n\t\tif(opts && opts.cellStyles) {\n\t\t\trowobj = {}; rowrite = false;\n\t\t\tif(tag.ht) { rowrite = true; rowobj.hpt = parseFloat(tag.ht); rowobj.hpx = pt2px(rowobj.hpt); }\n\t\t\tif(tag.hidden == \"1\") { rowrite = true; rowobj.hidden = true; }\n\t\t\tif(tag.outlineLevel != null) { rowrite = true; rowobj.level = +tag.outlineLevel; }\n\t\t\tif(rowrite) rows[tagr-1] = rowobj;\n\t\t}\n\n\t\t/* 18.3.1.4 c CT_Cell */\n\t\tcells = x.slice(ri).split(cellregex);\n\t\tfor(var rslice = 0; rslice != cells.length; ++rslice) if(cells[rslice].trim().charAt(0) != \"<\") break;\n\t\tcells = cells.slice(rslice);\n\t\tfor(ri = 0; ri != cells.length; ++ri) {\n\t\t\tx = cells[ri].trim();\n\t\t\tif(x.length === 0) continue;\n\t\t\tcref = x.match(rregex); idx = ri; i=0; cc=0;\n\t\t\tx = \"<c \" + (x.slice(0,1)==\"<\"?\">\":\"\") + x;\n\t\t\tif(cref != null && cref.length === 2) {\n\t\t\t\tidx = 0; d=cref[1];\n\t\t\t\tfor(i=0; i != d.length; ++i) {\n\t\t\t\t\tif((cc=d.charCodeAt(i)-64) < 1 || cc > 26) break;\n\t\t\t\t\tidx = 26*idx + cc;\n\t\t\t\t}\n\t\t\t\t--idx;\n\t\t\t\ttagc = idx;\n\t\t\t} else ++tagc;\n\t\t\tfor(i = 0; i != x.length; ++i) if(x.charCodeAt(i) === 62) break; ++i;\n\t\t\ttag = parsexmltag(x.slice(0,i), true);\n\t\t\tif(!tag.r) tag.r = encode_cell({r:tagr-1, c:tagc});\n\t\t\td = x.slice(i);\n\t\t\tp = ({t:\"\"}/*:any*/);\n\n\t\t\tif((cref=d.match(match_v))!= null && /*::cref != null && */cref[1] !== '') p.v=unescapexml(cref[1]);\n\t\t\tif(opts.cellFormula) {\n\t\t\t\tif((cref=d.match(match_f))!= null && /*::cref != null && */cref[1] !== '') {\n\t\t\t\t\t/* TODO: match against XLSXFutureFunctions */\n\t\t\t\t\tp.f=unescapexml(utf8read(cref[1])).replace(/\\r\\n/g, \"\\n\");\n\t\t\t\t\tif(!opts.xlfn) p.f = _xlfn(p.f);\n\t\t\t\t\tif(/*::cref != null && cref[0] != null && */cref[0].indexOf('t=\"array\"') > -1) {\n\t\t\t\t\t\tp.F = (d.match(refregex)||[])[1];\n\t\t\t\t\t\tif(p.F.indexOf(\":\") > -1) arrayf.push([safe_decode_range(p.F), p.F]);\n\t\t\t\t\t} else if(/*::cref != null && cref[0] != null && */cref[0].indexOf('t=\"shared\"') > -1) {\n\t\t\t\t\t\t// TODO: parse formula\n\t\t\t\t\t\tftag = parsexmltag(cref[0]);\n\t\t\t\t\t\tvar ___f = unescapexml(utf8read(cref[1]));\n\t\t\t\t\t\tif(!opts.xlfn) ___f = _xlfn(___f);\n\t\t\t\t\t\tsharedf[parseInt(ftag.si, 10)] = [ftag, ___f, tag.r];\n\t\t\t\t\t}\n\t\t\t\t} else if((cref=d.match(/<f[^>]*\\/>/))) {\n\t\t\t\t\tftag = parsexmltag(cref[0]);\n\t\t\t\t\tif(sharedf[ftag.si]) p.f = shift_formula_xlsx(sharedf[ftag.si][1], sharedf[ftag.si][2]/*[0].ref*/, tag.r);\n\t\t\t\t}\n\t\t\t\t/* TODO: factor out contains logic */\n\t\t\t\tvar _tag = decode_cell(tag.r);\n\t\t\t\tfor(i = 0; i < arrayf.length; ++i)\n\t\t\t\t\tif(_tag.r >= arrayf[i][0].s.r && _tag.r <= arrayf[i][0].e.r)\n\t\t\t\t\t\tif(_tag.c >= arrayf[i][0].s.c && _tag.c <= arrayf[i][0].e.c)\n\t\t\t\t\t\t\tp.F = arrayf[i][1];\n\t\t\t}\n\n\t\t\tif(tag.t == null && p.v === undefined) {\n\t\t\t\tif(p.f || p.F) {\n\t\t\t\t\tp.v = 0; p.t = \"n\";\n\t\t\t\t} else if(!sheetStubs) continue;\n\t\t\t\telse p.t = \"z\";\n\t\t\t}\n\t\t\telse p.t = tag.t || \"n\";\n\t\t\tif(guess.s.c > tagc) guess.s.c = tagc;\n\t\t\tif(guess.e.c < tagc) guess.e.c = tagc;\n\t\t\t/* 18.18.11 t ST_CellType */\n\t\t\tswitch(p.t) {\n\t\t\t\tcase 'n':\n\t\t\t\t\tif(p.v == \"\" || p.v == null) {\n\t\t\t\t\t\tif(!sheetStubs) continue;\n\t\t\t\t\t\tp.t = 'z';\n\t\t\t\t\t} else p.v = parseFloat(p.v);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 's':\n\t\t\t\t\tif(typeof p.v == 'undefined') {\n\t\t\t\t\t\tif(!sheetStubs) continue;\n\t\t\t\t\t\tp.t = 'z';\n\t\t\t\t\t} else {\n\t\t\t\t\t\tsstr = strs[parseInt(p.v, 10)];\n\t\t\t\t\t\tp.v = sstr.t;\n\t\t\t\t\t\tp.r = sstr.r;\n\t\t\t\t\t\tif(opts.cellHTML) p.h = sstr.h;\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'str':\n\t\t\t\t\tp.t = \"s\";\n\t\t\t\t\tp.v = (p.v!=null) ? utf8read(p.v) : '';\n\t\t\t\t\tif(opts.cellHTML) p.h = escapehtml(p.v);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'inlineStr':\n\t\t\t\t\tcref = d.match(isregex);\n\t\t\t\t\tp.t = 's';\n\t\t\t\t\tif(cref != null && (sstr = parse_si(cref[1]))) {\n\t\t\t\t\t\tp.v = sstr.t;\n\t\t\t\t\t\tif(opts.cellHTML) p.h = sstr.h;\n\t\t\t\t\t} else p.v = \"\";\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'b': p.v = parsexmlbool(p.v); break;\n\t\t\t\tcase 'd':\n\t\t\t\t\tif(opts.cellDates) p.v = parseDate(p.v, 1);\n\t\t\t\t\telse { p.v = datenum(parseDate(p.v, 1)); p.t = 'n'; }\n\t\t\t\t\tbreak;\n\t\t\t\t/* error string in .w, number in .v */\n\t\t\t\tcase 'e':\n\t\t\t\t\tif(!opts || opts.cellText !== false) p.w = p.v;\n\t\t\t\t\tp.v = RBErr[p.v]; break;\n\t\t\t}\n\t\t\t/* formatting */\n\t\t\tfmtid = fillid = 0;\n\t\t\tcf = null;\n\t\t\tif(do_format && tag.s !== undefined) {\n\t\t\t\tcf = styles.CellXf[tag.s];\n\t\t\t\tif(cf != null) {\n\t\t\t\t\tif(cf.numFmtId != null) fmtid = cf.numFmtId;\n\t\t\t\t\tif(opts.cellStyles) {\n\t\t\t\t\t\tif(cf.fillId != null) fillid = cf.fillId;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tsafe_format(p, fmtid, fillid, opts, themes, styles);\n\t\t\tif(opts.cellDates && do_format && p.t == 'n' && fmt_is_date(table_fmt[fmtid])) { p.t = 'd'; p.v = numdate(p.v); }\n\t\t\tif(tag.cm && opts.xlmeta) {\n\t\t\t\tvar cm = (opts.xlmeta.Cell||[])[+tag.cm-1];\n\t\t\t\tif(cm && cm.type == 'XLDAPR') p.D = true;\n\t\t\t}\n\t\t\tif(dense) {\n\t\t\t\tvar _r = decode_cell(tag.r);\n\t\t\t\tif(!s[_r.r]) s[_r.r] = [];\n\t\t\t\ts[_r.r][_r.c] = p;\n\t\t\t} else s[tag.r] = p;\n\t\t}\n\t}\n\tif(rows.length > 0) s['!rows'] = rows;\n}; })();\n\nfunction write_ws_xml_data(ws/*:Worksheet*/, opts, idx/*:number*/, wb/*:Workbook*//*::, rels*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [], r/*:Array<string>*/ = [], range = safe_decode_range(ws['!ref']), cell=\"\", ref, rr = \"\", cols/*:Array<string>*/ = [], R=0, C=0, rows = ws['!rows'];\n\tvar dense = Array.isArray(ws);\n\tvar params = ({r:rr}/*:any*/), row/*:RowInfo*/, height = -1;\n\tfor(C = range.s.c; C <= range.e.c; ++C) cols[C] = encode_col(C);\n\tfor(R = range.s.r; R <= range.e.r; ++R) {\n\t\tr = [];\n\t\trr = encode_row(R);\n\t\tfor(C = range.s.c; C <= range.e.c; ++C) {\n\t\t\tref = cols[C] + rr;\n\t\t\tvar _cell = dense ? (ws[R]||[])[C]: ws[ref];\n\t\t\tif(_cell === undefined) continue;\n\t\t\tif((cell = write_ws_xml_cell(_cell, ref, ws, opts, idx, wb)) != null) r.push(cell);\n\t\t}\n\t\tif(r.length > 0 || (rows && rows[R])) {\n\t\t\tparams = ({r:rr}/*:any*/);\n\t\t\tif(rows && rows[R]) {\n\t\t\t\trow = rows[R];\n\t\t\t\tif(row.hidden) params.hidden = 1;\n\t\t\t\theight = -1;\n\t\t\t\tif(row.hpx) height = px2pt(row.hpx);\n\t\t\t\telse if(row.hpt) height = row.hpt;\n\t\t\t\tif(height > -1) { params.ht = height; params.customHeight = 1; }\n\t\t\t\tif(row.level) { params.outlineLevel = row.level; }\n\t\t\t}\n\t\t\to[o.length] = (writextag('row', r.join(\"\"), params));\n\t\t}\n\t}\n\tif(rows) for(; R < rows.length; ++R) {\n\t\tif(rows && rows[R]) {\n\t\t\tparams = ({r:R+1}/*:any*/);\n\t\t\trow = rows[R];\n\t\t\tif(row.hidden) params.hidden = 1;\n\t\t\theight = -1;\n\t\t\tif (row.hpx) height = px2pt(row.hpx);\n\t\t\telse if (row.hpt) height = row.hpt;\n\t\t\tif (height > -1) { params.ht = height; params.customHeight = 1; }\n\t\t\tif (row.level) { params.outlineLevel = row.level; }\n\t\t\to[o.length] = (writextag('row', \"\", params));\n\t\t}\n\t}\n\treturn o.join(\"\");\n}\n\nfunction write_ws_xml(idx/*:number*/, opts, wb/*:Workbook*/, rels)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('worksheet', null, {\n\t\t'xmlns': XMLNS_main[0],\n\t\t'xmlns:r': XMLNS.r\n\t})];\n\tvar s = wb.SheetNames[idx], sidx = 0, rdata = \"\";\n\tvar ws = wb.Sheets[s];\n\tif(ws == null) ws = {};\n\tvar ref = ws['!ref'] || 'A1';\n\tvar range = safe_decode_range(ref);\n\tif(range.e.c > 0x3FFF || range.e.r > 0xFFFFF) {\n\t\tif(opts.WTF) throw new Error(\"Range \" + ref + \" exceeds format limit A1:XFD1048576\");\n\t\trange.e.c = Math.min(range.e.c, 0x3FFF);\n\t\trange.e.r = Math.min(range.e.c, 0xFFFFF);\n\t\tref = encode_range(range);\n\t}\n\tif(!rels) rels = {};\n\tws['!comments'] = [];\n\tvar _drawing = [];\n\n\twrite_ws_xml_sheetpr(ws, wb, idx, opts, o);\n\n\to[o.length] = (writextag('dimension', null, {'ref': ref}));\n\n\to[o.length] = write_ws_xml_sheetviews(ws, opts, idx, wb);\n\n\t/* TODO: store in WB, process styles */\n\tif(opts.sheetFormat) o[o.length] = (writextag('sheetFormatPr', null, {\n\t\tdefaultRowHeight:opts.sheetFormat.defaultRowHeight||'16',\n\t\tbaseColWidth:opts.sheetFormat.baseColWidth||'10',\n\t\toutlineLevelRow:opts.sheetFormat.outlineLevelRow||'7'\n\t}));\n\n\tif(ws['!cols'] != null && ws['!cols'].length > 0) o[o.length] = (write_ws_xml_cols(ws, ws['!cols']));\n\n\to[sidx = o.length] = '<sheetData/>';\n\tws['!links'] = [];\n\tif(ws['!ref'] != null) {\n\t\trdata = write_ws_xml_data(ws, opts, idx, wb, rels);\n\t\tif(rdata.length > 0) o[o.length] = (rdata);\n\t}\n\tif(o.length>sidx+1) { o[o.length] = ('</sheetData>'); o[sidx]=o[sidx].replace(\"/>\",\">\"); }\n\n\t/* sheetCalcPr */\n\n\tif(ws['!protect']) o[o.length] = write_ws_xml_protection(ws['!protect']);\n\n\t/* protectedRanges */\n\t/* scenarios */\n\n\tif(ws['!autofilter'] != null) o[o.length] = write_ws_xml_autofilter(ws['!autofilter'], ws, wb, idx);\n\n\t/* sortState */\n\t/* dataConsolidate */\n\t/* customSheetViews */\n\n\tif(ws['!merges'] != null && ws['!merges'].length > 0) o[o.length] = (write_ws_xml_merges(ws['!merges']));\n\n\t/* phoneticPr */\n\t/* conditionalFormatting */\n\t/* dataValidations */\n\n\tvar relc = -1, rel, rId = -1;\n\tif(/*::(*/ws['!links']/*::||[])*/.length > 0) {\n\t\to[o.length] = \"<hyperlinks>\";\n\t\t/*::(*/ws['!links']/*::||[])*/.forEach(function(l) {\n\t\t\tif(!l[1].Target) return;\n\t\t\trel = ({\"ref\":l[0]}/*:any*/);\n\t\t\tif(l[1].Target.charAt(0) != \"#\") {\n\t\t\t\trId = add_rels(rels, -1, escapexml(l[1].Target).replace(/#.*$/, \"\"), RELS.HLINK);\n\t\t\t\trel[\"r:id\"] = \"rId\"+rId;\n\t\t\t}\n\t\t\tif((relc = l[1].Target.indexOf(\"#\")) > -1) rel.location = escapexml(l[1].Target.slice(relc+1));\n\t\t\tif(l[1].Tooltip) rel.tooltip = escapexml(l[1].Tooltip);\n\t\t\to[o.length] = writextag(\"hyperlink\",null,rel);\n\t\t});\n\t\to[o.length] = \"</hyperlinks>\";\n\t}\n\tdelete ws['!links'];\n\n\t/* printOptions */\n\n\tif(ws['!margins'] != null) o[o.length] = write_ws_xml_margins(ws['!margins']);\n\n\t/* pageSetup */\n\t/* headerFooter */\n\t/* rowBreaks */\n\t/* colBreaks */\n\t/* customProperties */\n\t/* cellWatches */\n\n\tif(!opts || opts.ignoreEC || (opts.ignoreEC == (void 0))) o[o.length] = writetag(\"ignoredErrors\", writextag(\"ignoredError\", null, {numberStoredAsText:1, sqref:ref}));\n\n\t/* smartTags */\n\n\tif(_drawing.length > 0) {\n\t\trId = add_rels(rels, -1, \"../drawings/drawing\" + (idx+1) + \".xml\", RELS.DRAW);\n\t\to[o.length] = writextag(\"drawing\", null, {\"r:id\":\"rId\" + rId});\n\t\tws['!drawing'] = _drawing;\n\t}\n\n\tif(ws['!comments'].length > 0) {\n\t\trId = add_rels(rels, -1, \"../drawings/vmlDrawing\" + (idx+1) + \".vml\", RELS.VML);\n\t\to[o.length] = writextag(\"legacyDrawing\", null, {\"r:id\":\"rId\" + rId});\n\t\tws['!legacy'] = rId;\n\t}\n\n\t/* legacyDrawingHF */\n\t/* picture */\n\t/* oleObjects */\n\t/* controls */\n\t/* webPublishItems */\n\t/* tableParts */\n\t/* extLst */\n\n\tif(o.length>1) { o[o.length] = ('</worksheet>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n\n/* [MS-XLSB] 2.4.726 BrtRowHdr */\nfunction parse_BrtRowHdr(data, length) {\n\tvar z = ({}/*:any*/);\n\tvar tgt = data.l + length;\n\tz.r = data.read_shift(4);\n\tdata.l += 4; // TODO: ixfe\n\tvar miyRw = data.read_shift(2);\n\tdata.l += 1; // TODO: top/bot padding\n\tvar flags = data.read_shift(1);\n\tdata.l = tgt;\n\tif(flags & 0x07) z.level = flags & 0x07;\n\tif(flags & 0x10) z.hidden = true;\n\tif(flags & 0x20) z.hpt = miyRw / 20;\n\treturn z;\n}\nfunction write_BrtRowHdr(R/*:number*/, range, ws) {\n\tvar o = new_buf(17+8*16);\n\tvar row = (ws['!rows']||[])[R]||{};\n\to.write_shift(4, R);\n\n\to.write_shift(4, 0); /* TODO: ixfe */\n\n\tvar miyRw = 0x0140;\n\tif(row.hpx) miyRw = px2pt(row.hpx) * 20;\n\telse if(row.hpt) miyRw = row.hpt * 20;\n\to.write_shift(2, miyRw);\n\n\to.write_shift(1, 0); /* top/bot padding */\n\n\tvar flags = 0x0;\n\tif(row.level) flags |= row.level;\n\tif(row.hidden) flags |= 0x10;\n\tif(row.hpx || row.hpt) flags |= 0x20;\n\to.write_shift(1, flags);\n\n\to.write_shift(1, 0); /* phonetic guide */\n\n\t/* [MS-XLSB] 2.5.8 BrtColSpan explains the mechanism */\n\tvar ncolspan = 0, lcs = o.l;\n\to.l += 4;\n\n\tvar caddr = {r:R, c:0};\n\tfor(var i = 0; i < 16; ++i) {\n\t\tif((range.s.c > ((i+1) << 10)) || (range.e.c < (i << 10))) continue;\n\t\tvar first = -1, last = -1;\n\t\tfor(var j = (i<<10); j < ((i+1)<<10); ++j) {\n\t\t\tcaddr.c = j;\n\t\t\tvar cell = Array.isArray(ws) ? (ws[caddr.r]||[])[caddr.c] : ws[encode_cell(caddr)];\n\t\t\tif(cell) { if(first < 0) first = j; last = j; }\n\t\t}\n\t\tif(first < 0) continue;\n\t\t++ncolspan;\n\t\to.write_shift(4, first);\n\t\to.write_shift(4, last);\n\t}\n\n\tvar l = o.l;\n\to.l = lcs;\n\to.write_shift(4, ncolspan);\n\to.l = l;\n\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\nfunction write_row_header(ba, ws, range, R) {\n\tvar o = write_BrtRowHdr(R, range, ws);\n\tif((o.length > 17) || (ws['!rows']||[])[R]) write_record(ba, 0x0000 /* BrtRowHdr */, o);\n}\n\n/* [MS-XLSB] 2.4.820 BrtWsDim */\nvar parse_BrtWsDim = parse_UncheckedRfX;\nvar write_BrtWsDim = write_UncheckedRfX;\n\n/* [MS-XLSB] 2.4.821 BrtWsFmtInfo */\nfunction parse_BrtWsFmtInfo(/*::data, length*/) {\n}\n//function write_BrtWsFmtInfo(ws, o) { }\n\n/* [MS-XLSB] 2.4.823 BrtWsProp */\nfunction parse_BrtWsProp(data, length) {\n\tvar z = {};\n\tvar f = data[data.l]; ++data.l;\n\tz.above = !(f & 0x40);\n\tz.left = !(f & 0x80);\n\t/* TODO: pull flags */\n\tdata.l += 18;\n\tz.name = parse_XLSBCodeName(data, length - 19);\n\treturn z;\n}\nfunction write_BrtWsProp(str, outl, o) {\n\tif(o == null) o = new_buf(84+4*str.length);\n\tvar f = 0xC0;\n\tif(outl) {\n\t\tif(outl.above) f &= ~0x40;\n\t\tif(outl.left) f &= ~0x80;\n\t}\n\to.write_shift(1, f);\n\tfor(var i = 1; i < 3; ++i) o.write_shift(1,0);\n\twrite_BrtColor({auto:1}, o);\n\to.write_shift(-4,-1);\n\to.write_shift(-4,-1);\n\twrite_XLSBCodeName(str, o);\n\treturn o.slice(0, o.l);\n}\n\n/* [MS-XLSB] 2.4.306 BrtCellBlank */\nfunction parse_BrtCellBlank(data) {\n\tvar cell = parse_XLSBCell(data);\n\treturn [cell];\n}\nfunction write_BrtCellBlank(cell, ncell, o) {\n\tif(o == null) o = new_buf(8);\n\treturn write_XLSBCell(ncell, o);\n}\nfunction parse_BrtShortBlank(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\treturn [cell];\n}\nfunction write_BrtShortBlank(cell, ncell, o) {\n\tif(o == null) o = new_buf(4);\n\treturn write_XLSBShortCell(ncell, o);\n}\n\n/* [MS-XLSB] 2.4.307 BrtCellBool */\nfunction parse_BrtCellBool(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar fBool = data.read_shift(1);\n\treturn [cell, fBool, 'b'];\n}\nfunction write_BrtCellBool(cell, ncell, o) {\n\tif(o == null) o = new_buf(9);\n\twrite_XLSBCell(ncell, o);\n\to.write_shift(1, cell.v ? 1 : 0);\n\treturn o;\n}\nfunction parse_BrtShortBool(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar fBool = data.read_shift(1);\n\treturn [cell, fBool, 'b'];\n}\nfunction write_BrtShortBool(cell, ncell, o) {\n\tif(o == null) o = new_buf(5);\n\twrite_XLSBShortCell(ncell, o);\n\to.write_shift(1, cell.v ? 1 : 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.308 BrtCellError */\nfunction parse_BrtCellError(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar bError = data.read_shift(1);\n\treturn [cell, bError, 'e'];\n}\nfunction write_BrtCellError(cell, ncell, o) {\n\tif(o == null) o = new_buf(9);\n\twrite_XLSBCell(ncell, o);\n\to.write_shift(1, cell.v);\n\treturn o;\n}\nfunction parse_BrtShortError(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar bError = data.read_shift(1);\n\treturn [cell, bError, 'e'];\n}\nfunction write_BrtShortError(cell, ncell, o) {\n\tif(o == null) o = new_buf(8);\n\twrite_XLSBShortCell(ncell, o);\n\to.write_shift(1, cell.v);\n\to.write_shift(2, 0);\n\to.write_shift(1, 0);\n\treturn o;\n}\n\n\n/* [MS-XLSB] 2.4.311 BrtCellIsst */\nfunction parse_BrtCellIsst(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar isst = data.read_shift(4);\n\treturn [cell, isst, 's'];\n}\nfunction write_BrtCellIsst(cell, ncell, o) {\n\tif(o == null) o = new_buf(12);\n\twrite_XLSBCell(ncell, o);\n\to.write_shift(4, ncell.v);\n\treturn o;\n}\nfunction parse_BrtShortIsst(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar isst = data.read_shift(4);\n\treturn [cell, isst, 's'];\n}\nfunction write_BrtShortIsst(cell, ncell, o) {\n\tif(o == null) o = new_buf(8);\n\twrite_XLSBShortCell(ncell, o);\n\to.write_shift(4, ncell.v);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.313 BrtCellReal */\nfunction parse_BrtCellReal(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_Xnum(data);\n\treturn [cell, value, 'n'];\n}\nfunction write_BrtCellReal(cell, ncell, o) {\n\tif(o == null) o = new_buf(16);\n\twrite_XLSBCell(ncell, o);\n\twrite_Xnum(cell.v, o);\n\treturn o;\n}\nfunction parse_BrtShortReal(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar value = parse_Xnum(data);\n\treturn [cell, value, 'n'];\n}\nfunction write_BrtShortReal(cell, ncell, o) {\n\tif(o == null) o = new_buf(12);\n\twrite_XLSBShortCell(ncell, o);\n\twrite_Xnum(cell.v, o);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.314 BrtCellRk */\nfunction parse_BrtCellRk(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_RkNumber(data);\n\treturn [cell, value, 'n'];\n}\nfunction write_BrtCellRk(cell, ncell, o) {\n\tif(o == null) o = new_buf(12);\n\twrite_XLSBCell(ncell, o);\n\twrite_RkNumber(cell.v, o);\n\treturn o;\n}\nfunction parse_BrtShortRk(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar value = parse_RkNumber(data);\n\treturn [cell, value, 'n'];\n}\nfunction write_BrtShortRk(cell, ncell, o) {\n\tif(o == null) o = new_buf(8);\n\twrite_XLSBShortCell(ncell, o);\n\twrite_RkNumber(cell.v, o);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.323 BrtCellRString */\nfunction parse_BrtCellRString(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_RichStr(data);\n\treturn [cell, value, 'is'];\n}\n\n/* [MS-XLSB] 2.4.317 BrtCellSt */\nfunction parse_BrtCellSt(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_XLWideString(data);\n\treturn [cell, value, 'str'];\n}\nfunction write_BrtCellSt(cell, ncell, o) {\n\tif(o == null) o = new_buf(12 + 4 * cell.v.length);\n\twrite_XLSBCell(ncell, o);\n\twrite_XLWideString(cell.v, o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\nfunction parse_BrtShortSt(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar value = parse_XLWideString(data);\n\treturn [cell, value, 'str'];\n}\nfunction write_BrtShortSt(cell, ncell, o) {\n\tif(o == null) o = new_buf(8 + 4 * cell.v.length);\n\twrite_XLSBShortCell(ncell, o);\n\twrite_XLWideString(cell.v, o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.653 BrtFmlaBool */\nfunction parse_BrtFmlaBool(data, length, opts) {\n\tvar end = data.l + length;\n\tvar cell = parse_XLSBCell(data);\n\tcell.r = opts['!row'];\n\tvar value = data.read_shift(1);\n\tvar o = [cell, value, 'b'];\n\tif(opts.cellFormula) {\n\t\tdata.l += 2;\n\t\tvar formula = parse_XLSBCellParsedFormula(data, end - data.l, opts);\n\t\to[3] = stringify_formula(formula, null/*range*/, cell, opts.supbooks, opts);/* TODO */\n\t}\n\telse data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.654 BrtFmlaError */\nfunction parse_BrtFmlaError(data, length, opts) {\n\tvar end = data.l + length;\n\tvar cell = parse_XLSBCell(data);\n\tcell.r = opts['!row'];\n\tvar value = data.read_shift(1);\n\tvar o = [cell, value, 'e'];\n\tif(opts.cellFormula) {\n\t\tdata.l += 2;\n\t\tvar formula = parse_XLSBCellParsedFormula(data, end - data.l, opts);\n\t\to[3] = stringify_formula(formula, null/*range*/, cell, opts.supbooks, opts);/* TODO */\n\t}\n\telse data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.655 BrtFmlaNum */\nfunction parse_BrtFmlaNum(data, length, opts) {\n\tvar end = data.l + length;\n\tvar cell = parse_XLSBCell(data);\n\tcell.r = opts['!row'];\n\tvar value = parse_Xnum(data);\n\tvar o = [cell, value, 'n'];\n\tif(opts.cellFormula) {\n\t\tdata.l += 2;\n\t\tvar formula = parse_XLSBCellParsedFormula(data, end - data.l, opts);\n\t\to[3] = stringify_formula(formula, null/*range*/, cell, opts.supbooks, opts);/* TODO */\n\t}\n\telse data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.656 BrtFmlaString */\nfunction parse_BrtFmlaString(data, length, opts) {\n\tvar end = data.l + length;\n\tvar cell = parse_XLSBCell(data);\n\tcell.r = opts['!row'];\n\tvar value = parse_XLWideString(data);\n\tvar o = [cell, value, 'str'];\n\tif(opts.cellFormula) {\n\t\tdata.l += 2;\n\t\tvar formula = parse_XLSBCellParsedFormula(data, end - data.l, opts);\n\t\to[3] = stringify_formula(formula, null/*range*/, cell, opts.supbooks, opts);/* TODO */\n\t}\n\telse data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.682 BrtMergeCell */\nvar parse_BrtMergeCell = parse_UncheckedRfX;\nvar write_BrtMergeCell = write_UncheckedRfX;\n/* [MS-XLSB] 2.4.107 BrtBeginMergeCells */\nfunction write_BrtBeginMergeCells(cnt, o) {\n\tif(o == null) o = new_buf(4);\n\to.write_shift(4, cnt);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.662 BrtHLink */\nfunction parse_BrtHLink(data, length/*::, opts*/) {\n\tvar end = data.l + length;\n\tvar rfx = parse_UncheckedRfX(data, 16);\n\tvar relId = parse_XLNullableWideString(data);\n\tvar loc = parse_XLWideString(data);\n\tvar tooltip = parse_XLWideString(data);\n\tvar display = parse_XLWideString(data);\n\tdata.l = end;\n\tvar o = ({rfx:rfx, relId:relId, loc:loc, display:display}/*:any*/);\n\tif(tooltip) o.Tooltip = tooltip;\n\treturn o;\n}\nfunction write_BrtHLink(l, rId) {\n\tvar o = new_buf(50+4*(l[1].Target.length + (l[1].Tooltip || \"\").length));\n\twrite_UncheckedRfX({s:decode_cell(l[0]), e:decode_cell(l[0])}, o);\n\twrite_RelID(\"rId\" + rId, o);\n\tvar locidx = l[1].Target.indexOf(\"#\");\n\tvar loc = locidx == -1 ? \"\" : l[1].Target.slice(locidx+1);\n\twrite_XLWideString(loc || \"\", o);\n\twrite_XLWideString(l[1].Tooltip || \"\", o);\n\twrite_XLWideString(\"\", o);\n\treturn o.slice(0, o.l);\n}\n\n/* [MS-XLSB] 2.4.692 BrtPane */\nfunction parse_BrtPane(/*data, length, opts*/) {\n}\n\n/* [MS-XLSB] 2.4.6 BrtArrFmla */\nfunction parse_BrtArrFmla(data, length, opts) {\n\tvar end = data.l + length;\n\tvar rfx = parse_RfX(data, 16);\n\tvar fAlwaysCalc = data.read_shift(1);\n\tvar o = [rfx]; o[2] = fAlwaysCalc;\n\tif(opts.cellFormula) {\n\t\tvar formula = parse_XLSBArrayParsedFormula(data, end - data.l, opts);\n\t\to[1] = formula;\n\t} else data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.750 BrtShrFmla */\nfunction parse_BrtShrFmla(data, length, opts) {\n\tvar end = data.l + length;\n\tvar rfx = parse_UncheckedRfX(data, 16);\n\tvar o = [rfx];\n\tif(opts.cellFormula) {\n\t\tvar formula = parse_XLSBSharedParsedFormula(data, end - data.l, opts);\n\t\to[1] = formula;\n\t\tdata.l = end;\n\t} else data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.323 BrtColInfo */\n/* TODO: once XLS ColInfo is set, combine the functions */\nfunction write_BrtColInfo(C/*:number*/, col, o) {\n\tif(o == null) o = new_buf(18);\n\tvar p = col_obj_w(C, col);\n\to.write_shift(-4, C);\n\to.write_shift(-4, C);\n\to.write_shift(4, (p.width || 10) * 256);\n\to.write_shift(4, 0/*ixfe*/); // style\n\tvar flags = 0;\n\tif(col.hidden) flags |= 0x01;\n\tif(typeof p.width == 'number') flags |= 0x02;\n\tif(col.level) flags |= (col.level << 8);\n\to.write_shift(2, flags); // bit flag\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.678 BrtMargins */\nvar BrtMarginKeys = [\"left\",\"right\",\"top\",\"bottom\",\"header\",\"footer\"];\nfunction parse_BrtMargins(data/*::, length, opts*/)/*:Margins*/ {\n\tvar margins = ({}/*:any*/);\n\tBrtMarginKeys.forEach(function(k) { margins[k] = parse_Xnum(data, 8); });\n\treturn margins;\n}\nfunction write_BrtMargins(margins/*:Margins*/, o) {\n\tif(o == null) o = new_buf(6*8);\n\tdefault_margins(margins);\n\tBrtMarginKeys.forEach(function(k) { write_Xnum((margins/*:any*/)[k], o); });\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.299 BrtBeginWsView */\nfunction parse_BrtBeginWsView(data/*::, length, opts*/) {\n\tvar f = data.read_shift(2);\n\tdata.l += 28;\n\treturn { RTL: f & 0x20 };\n}\nfunction write_BrtBeginWsView(ws, Workbook, o) {\n\tif(o == null) o = new_buf(30);\n\tvar f = 0x39c;\n\tif((((Workbook||{}).Views||[])[0]||{}).RTL) f |= 0x20;\n\to.write_shift(2, f); // bit flag\n\to.write_shift(4, 0);\n\to.write_shift(4, 0); // view first row\n\to.write_shift(4, 0); // view first col\n\to.write_shift(1, 0); // gridline color ICV\n\to.write_shift(1, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, 100); // zoom scale\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(4, 0); // workbook view id\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.309 BrtCellIgnoreEC */\nfunction write_BrtCellIgnoreEC(ref) {\n\tvar o = new_buf(24);\n\to.write_shift(4, 4);\n\to.write_shift(4, 1);\n\twrite_UncheckedRfX(ref, o);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.748 BrtSheetProtection */\nfunction write_BrtSheetProtection(sp, o) {\n\tif(o == null) o = new_buf(16*4+2);\n\to.write_shift(2, sp.password ? crypto_CreatePasswordVerifier_Method1(sp.password) : 0);\n\to.write_shift(4, 1); // this record should not be written if no protection\n\t[\n\t\t[\"objects\", false], // fObjects\n\t\t[\"scenarios\", false], // fScenarios\n\t\t[\"formatCells\", true], // fFormatCells\n\t\t[\"formatColumns\", true], // fFormatColumns\n\t\t[\"formatRows\", true], // fFormatRows\n\t\t[\"insertColumns\", true], // fInsertColumns\n\t\t[\"insertRows\", true], // fInsertRows\n\t\t[\"insertHyperlinks\", true], // fInsertHyperlinks\n\t\t[\"deleteColumns\", true], // fDeleteColumns\n\t\t[\"deleteRows\", true], // fDeleteRows\n\t\t[\"selectLockedCells\", false], // fSelLockedCells\n\t\t[\"sort\", true], // fSort\n\t\t[\"autoFilter\", true], // fAutoFilter\n\t\t[\"pivotTables\", true], // fPivotTables\n\t\t[\"selectUnlockedCells\", false] // fSelUnlockedCells\n\t].forEach(function(n) {\n\t\t/*:: if(o == null) throw \"unreachable\"; */\n\t\tif(n[1]) o.write_shift(4, sp[n[0]] != null && !sp[n[0]] ? 1 : 0);\n\t\telse o.write_shift(4, sp[n[0]] != null && sp[n[0]] ? 0 : 1);\n\t});\n\treturn o;\n}\n\nfunction parse_BrtDVal(/*data, length, opts*/) {\n}\nfunction parse_BrtDVal14(/*data, length, opts*/) {\n}\n/* [MS-XLSB] 2.1.7.61 Worksheet */\nfunction parse_ws_bin(data, _opts, idx, rels, wb/*:WBWBProps*/, themes, styles)/*:Worksheet*/ {\n\tif(!data) return data;\n\tvar opts = _opts || {};\n\tif(!rels) rels = {'!id':{}};\n\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\tvar s/*:Worksheet*/ = (opts.dense ? [] : {});\n\n\tvar ref;\n\tvar refguess = {s: {r:2000000, c:2000000}, e: {r:0, c:0} };\n\n\tvar state/*:Array<string>*/ = [];\n\tvar pass = false, end = false;\n\tvar row, p, cf, R, C, addr, sstr, rr, cell/*:Cell*/;\n\tvar merges/*:Array<Range>*/ = [];\n\topts.biff = 12;\n\topts['!row'] = 0;\n\n\tvar ai = 0, af = false;\n\n\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\tvar sharedf = {};\n\tvar supbooks = opts.supbooks || /*::(*/wb/*:: :any)*/.supbooks || ([[]]/*:any*/);\n\tsupbooks.sharedf = sharedf;\n\tsupbooks.arrayf = arrayf;\n\tsupbooks.SheetNames = wb.SheetNames || wb.Sheets.map(function(x) { return x.name; });\n\tif(!opts.supbooks) {\n\t\topts.supbooks = supbooks;\n\t\tif(wb.Names) for(var i = 0; i < wb.Names.length; ++i) supbooks[0][i+1] = wb.Names[i];\n\t}\n\n\tvar colinfo/*:Array<ColInfo>*/ = [], rowinfo/*:Array<RowInfo>*/ = [];\n\tvar seencol = false;\n\n\tXLSBRecordEnum[0x0010] = { n:\"BrtShortReal\", f:parse_BrtShortReal };\n\n\tvar cm, vm;\n\n\trecordhopper(data, function ws_parse(val, RR, RT) {\n\t\tif(end) return;\n\t\tswitch(RT) {\n\t\t\tcase 0x0094: /* 'BrtWsDim' */\n\t\t\t\tref = val; break;\n\t\t\tcase 0x0000: /* 'BrtRowHdr' */\n\t\t\t\trow = val;\n\t\t\t\tif(opts.sheetRows && opts.sheetRows <= row.r) end=true;\n\t\t\t\trr = encode_row(R = row.r);\n\t\t\t\topts['!row'] = row.r;\n\t\t\t\tif(val.hidden || val.hpt || val.level != null) {\n\t\t\t\t\tif(val.hpt) val.hpx = pt2px(val.hpt);\n\t\t\t\t\trowinfo[val.r] = val;\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0002: /* 'BrtCellRk' */\n\t\t\tcase 0x0003: /* 'BrtCellError' */\n\t\t\tcase 0x0004: /* 'BrtCellBool' */\n\t\t\tcase 0x0005: /* 'BrtCellReal' */\n\t\t\tcase 0x0006: /* 'BrtCellSt' */\n\t\t\tcase 0x0007: /* 'BrtCellIsst' */\n\t\t\tcase 0x0008: /* 'BrtFmlaString' */\n\t\t\tcase 0x0009: /* 'BrtFmlaNum' */\n\t\t\tcase 0x000A: /* 'BrtFmlaBool' */\n\t\t\tcase 0x000B: /* 'BrtFmlaError' */\n\t\t\tcase 0x000D: /* 'BrtShortRk' */\n\t\t\tcase 0x000E: /* 'BrtShortError' */\n\t\t\tcase 0x000F: /* 'BrtShortBool' */\n\t\t\tcase 0x0010: /* 'BrtShortReal' */\n\t\t\tcase 0x0011: /* 'BrtShortSt' */\n\t\t\tcase 0x0012: /* 'BrtShortIsst' */\n\t\t\tcase 0x003E: /* 'BrtCellRString' */\n\t\t\t\tp = ({t:val[2]}/*:any*/);\n\t\t\t\tswitch(val[2]) {\n\t\t\t\t\tcase 'n': p.v = val[1]; break;\n\t\t\t\t\tcase 's': sstr = strs[val[1]]; p.v = sstr.t; p.r = sstr.r; break;\n\t\t\t\t\tcase 'b': p.v = val[1] ? true : false; break;\n\t\t\t\t\tcase 'e': p.v = val[1]; if(opts.cellText !== false) p.w = BErr[p.v]; break;\n\t\t\t\t\tcase 'str': p.t = 's'; p.v = val[1]; break;\n\t\t\t\t\tcase 'is': p.t = 's'; p.v = val[1].t; break;\n\t\t\t\t}\n\t\t\t\tif((cf = styles.CellXf[val[0].iStyleRef])) safe_format(p,cf.numFmtId,null,opts, themes, styles);\n\t\t\t\tC = val[0].c == -1 ? C + 1 : val[0].c;\n\t\t\t\tif(opts.dense) { if(!s[R]) s[R] = []; s[R][C] = p; }\n\t\t\t\telse s[encode_col(C) + rr] = p;\n\t\t\t\tif(opts.cellFormula) {\n\t\t\t\t\taf = false;\n\t\t\t\t\tfor(ai = 0; ai < arrayf.length; ++ai) {\n\t\t\t\t\t\tvar aii = arrayf[ai];\n\t\t\t\t\t\tif(row.r >= aii[0].s.r && row.r <= aii[0].e.r)\n\t\t\t\t\t\t\tif(C >= aii[0].s.c && C <= aii[0].e.c) {\n\t\t\t\t\t\t\t\tp.F = encode_range(aii[0]); af = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif(!af && val.length > 3) p.f = val[3];\n\t\t\t\t}\n\n\t\t\t\tif(refguess.s.r > row.r) refguess.s.r = row.r;\n\t\t\t\tif(refguess.s.c > C) refguess.s.c = C;\n\t\t\t\tif(refguess.e.r < row.r) refguess.e.r = row.r;\n\t\t\t\tif(refguess.e.c < C) refguess.e.c = C;\n\t\t\t\tif(opts.cellDates && cf && p.t == 'n' && fmt_is_date(table_fmt[cf.numFmtId])) {\n\t\t\t\t\tvar _d = SSF_parse_date_code(p.v); if(_d) { p.t = 'd'; p.v = new Date(_d.y, _d.m-1,_d.d,_d.H,_d.M,_d.S,_d.u); }\n\t\t\t\t}\n\t\t\t\tif(cm) {\n\t\t\t\t\tif(cm.type == 'XLDAPR') p.D = true;\n\t\t\t\t\tcm = void 0;\n\t\t\t\t}\n\t\t\t\tif(vm) vm = void 0;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0001: /* 'BrtCellBlank' */\n\t\t\tcase 0x000C: /* 'BrtShortBlank' */\n\t\t\t\tif(!opts.sheetStubs || pass) break;\n\t\t\t\tp = ({t:'z',v:void 0}/*:any*/);\n\t\t\t\tC = val[0].c == -1 ? C + 1 : val[0].c;\n\t\t\t\tif(opts.dense) { if(!s[R]) s[R] = []; s[R][C] = p; }\n\t\t\t\telse s[encode_col(C) + rr] = p;\n\t\t\t\tif(refguess.s.r > row.r) refguess.s.r = row.r;\n\t\t\t\tif(refguess.s.c > C) refguess.s.c = C;\n\t\t\t\tif(refguess.e.r < row.r) refguess.e.r = row.r;\n\t\t\t\tif(refguess.e.c < C) refguess.e.c = C;\n\t\t\t\tif(cm) {\n\t\t\t\t\tif(cm.type == 'XLDAPR') p.D = true;\n\t\t\t\t\tcm = void 0;\n\t\t\t\t}\n\t\t\t\tif(vm) vm = void 0;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x00B0: /* 'BrtMergeCell' */\n\t\t\t\tmerges.push(val); break;\n\n\t\t\tcase 0x0031: { /* 'BrtCellMeta' */\n\t\t\t\tcm = ((opts.xlmeta||{}).Cell||[])[val-1];\n\t\t\t} break;\n\n\t\t\tcase 0x01EE: /* 'BrtHLink' */\n\t\t\t\tvar rel = rels['!id'][val.relId];\n\t\t\t\tif(rel) {\n\t\t\t\t\tval.Target = rel.Target;\n\t\t\t\t\tif(val.loc) val.Target += \"#\"+val.loc;\n\t\t\t\t\tval.Rel = rel;\n\t\t\t\t} else if(val.relId == '') {\n\t\t\t\t\tval.Target = \"#\" + val.loc;\n\t\t\t\t}\n\t\t\t\tfor(R=val.rfx.s.r;R<=val.rfx.e.r;++R) for(C=val.rfx.s.c;C<=val.rfx.e.c;++C) {\n\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\tif(!s[R]) s[R] = [];\n\t\t\t\t\t\tif(!s[R][C]) s[R][C] = {t:'z',v:undefined};\n\t\t\t\t\t\ts[R][C].l = val;\n\t\t\t\t\t} else {\n\t\t\t\t\t\taddr = encode_cell({c:C,r:R});\n\t\t\t\t\t\tif(!s[addr]) s[addr] = {t:'z',v:undefined};\n\t\t\t\t\t\ts[addr].l = val;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 0x01AA: /* 'BrtArrFmla' */\n\t\t\t\tif(!opts.cellFormula) break;\n\t\t\t\tarrayf.push(val);\n\t\t\t\tcell = ((opts.dense ? s[R][C] : s[encode_col(C) + rr])/*:any*/);\n\t\t\t\tcell.f = stringify_formula(val[1], refguess, {r:row.r, c:C}, supbooks, opts);\n\t\t\t\tcell.F = encode_range(val[0]);\n\t\t\t\tbreak;\n\t\t\tcase 0x01AB: /* 'BrtShrFmla' */\n\t\t\t\tif(!opts.cellFormula) break;\n\t\t\t\tsharedf[encode_cell(val[0].s)] = val[1];\n\t\t\t\tcell = (opts.dense ? s[R][C] : s[encode_col(C) + rr]);\n\t\t\t\tcell.f = stringify_formula(val[1], refguess, {r:row.r, c:C}, supbooks, opts);\n\t\t\t\tbreak;\n\n\t\t\t/* identical to 'ColInfo' in XLS */\n\t\t\tcase 0x003C: /* 'BrtColInfo' */\n\t\t\t\tif(!opts.cellStyles) break;\n\t\t\t\twhile(val.e >= val.s) {\n\t\t\t\t\tcolinfo[val.e--] = { width: val.w/256, hidden: !!(val.flags & 0x01), level: val.level };\n\t\t\t\t\tif(!seencol) { seencol = true; find_mdw_colw(val.w/256); }\n\t\t\t\t\tprocess_col(colinfo[val.e+1]);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 0x00A1: /* 'BrtBeginAFilter' */\n\t\t\t\ts['!autofilter'] = { ref:encode_range(val) };\n\t\t\t\tbreak;\n\n\t\t\tcase 0x01DC: /* 'BrtMargins' */\n\t\t\t\ts['!margins'] = val;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0093: /* 'BrtWsProp' */\n\t\t\t\tif(!wb.Sheets[idx]) wb.Sheets[idx] = {};\n\t\t\t\tif(val.name) wb.Sheets[idx].CodeName = val.name;\n\t\t\t\tif(val.above || val.left) s['!outline'] = { above: val.above, left: val.left };\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0089: /* 'BrtBeginWsView' */\n\t\t\t\tif(!wb.Views) wb.Views = [{}];\n\t\t\t\tif(!wb.Views[0]) wb.Views[0] = {};\n\t\t\t\tif(val.RTL) wb.Views[0].RTL = true;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x01E5: /* 'BrtWsFmtInfo' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0040: /* 'BrtDVal' */\n\t\t\tcase 0x041D: /* 'BrtDVal14' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0097: /* 'BrtPane' */\n\t\t\t\tbreak;\n\t\t\tcase 0x0098: /* 'BrtSel' */\n\t\t\tcase 0x00AF: /* 'BrtAFilterDateGroupItem' */\n\t\t\tcase 0x0284: /* 'BrtActiveX' */\n\t\t\tcase 0x0271: /* 'BrtBigName' */\n\t\t\tcase 0x0232: /* 'BrtBkHim' */\n\t\t\tcase 0x018C: /* 'BrtBrk' */\n\t\t\tcase 0x0458: /* 'BrtCFIcon' */\n\t\t\tcase 0x047A: /* 'BrtCFRuleExt' */\n\t\t\tcase 0x01D7: /* 'BrtCFVO' */\n\t\t\tcase 0x041A: /* 'BrtCFVO14' */\n\t\t\tcase 0x0289: /* 'BrtCellIgnoreEC' */\n\t\t\tcase 0x0451: /* 'BrtCellIgnoreEC14' */\n\t\t\tcase 0x024D: /* 'BrtCellSmartTagProperty' */\n\t\t\tcase 0x025F: /* 'BrtCellWatch' */\n\t\t\tcase 0x0234: /* 'BrtColor' */\n\t\t\tcase 0x041F: /* 'BrtColor14' */\n\t\t\tcase 0x00A8: /* 'BrtColorFilter' */\n\t\t\tcase 0x00AE: /* 'BrtCustomFilter' */\n\t\t\tcase 0x049C: /* 'BrtCustomFilter14' */\n\t\t\tcase 0x01F3: /* 'BrtDRef' */\n\t\t\tcase 0x01FB: /* 'BrtDXF' */\n\t\t\tcase 0x0226: /* 'BrtDrawing' */\n\t\t\tcase 0x00AB: /* 'BrtDynamicFilter' */\n\t\t\tcase 0x00A7: /* 'BrtFilter' */\n\t\t\tcase 0x0499: /* 'BrtFilter14' */\n\t\t\tcase 0x00A9: /* 'BrtIconFilter' */\n\t\t\tcase 0x049D: /* 'BrtIconFilter14' */\n\t\t\tcase 0x0227: /* 'BrtLegacyDrawing' */\n\t\t\tcase 0x0228: /* 'BrtLegacyDrawingHF' */\n\t\t\tcase 0x0295: /* 'BrtListPart' */\n\t\t\tcase 0x027F: /* 'BrtOleObject' */\n\t\t\tcase 0x01DE: /* 'BrtPageSetup' */\n\t\t\tcase 0x0219: /* 'BrtPhoneticInfo' */\n\t\t\tcase 0x01DD: /* 'BrtPrintOptions' */\n\t\t\tcase 0x0218: /* 'BrtRangeProtection' */\n\t\t\tcase 0x044F: /* 'BrtRangeProtection14' */\n\t\t\tcase 0x02A8: /* 'BrtRangeProtectionIso' */\n\t\t\tcase 0x0450: /* 'BrtRangeProtectionIso14' */\n\t\t\tcase 0x0400: /* 'BrtRwDescent' */\n\t\t\tcase 0x0297: /* 'BrtSheetCalcProp' */\n\t\t\tcase 0x0217: /* 'BrtSheetProtection' */\n\t\t\tcase 0x02A6: /* 'BrtSheetProtectionIso' */\n\t\t\tcase 0x01F8: /* 'BrtSlc' */\n\t\t\tcase 0x0413: /* 'BrtSparkline' */\n\t\t\tcase 0x01AC: /* 'BrtTable' */\n\t\t\tcase 0x00AA: /* 'BrtTop10Filter' */\n\t\t\tcase 0x0C00: /* 'BrtUid' */\n\t\t\tcase 0x0032: /* 'BrtValueMeta' */\n\t\t\tcase 0x0816: /* 'BrtWebExtension' */\n\t\t\tcase 0x0415: /* 'BrtWsFmtInfoEx14' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tpass = false; break;\n\t\t\tcase 0x0025: /* 'BrtACBegin' */\n\t\t\t\tstate.push(RT); pass = true; break;\n\t\t\tcase 0x0026: /* 'BrtACEnd' */\n\t\t\t\tstate.pop(); pass = false; break;\n\n\t\t\tdefault:\n\t\t\t\tif(RR.T){/* empty */}\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t}, opts);\n\n\tdelete opts.supbooks;\n\tdelete opts['!row'];\n\n\tif(!s[\"!ref\"] && (refguess.s.r < 2000000 || ref && (ref.e.r > 0 || ref.e.c > 0 || ref.s.r > 0 || ref.s.c > 0))) s[\"!ref\"] = encode_range(ref || refguess);\n\tif(opts.sheetRows && s[\"!ref\"]) {\n\t\tvar tmpref = safe_decode_range(s[\"!ref\"]);\n\t\tif(opts.sheetRows <= +tmpref.e.r) {\n\t\t\ttmpref.e.r = opts.sheetRows - 1;\n\t\t\tif(tmpref.e.r > refguess.e.r) tmpref.e.r = refguess.e.r;\n\t\t\tif(tmpref.e.r < tmpref.s.r) tmpref.s.r = tmpref.e.r;\n\t\t\tif(tmpref.e.c > refguess.e.c) tmpref.e.c = refguess.e.c;\n\t\t\tif(tmpref.e.c < tmpref.s.c) tmpref.s.c = tmpref.e.c;\n\t\t\ts[\"!fullref\"] = s[\"!ref\"];\n\t\t\ts[\"!ref\"] = encode_range(tmpref);\n\t\t}\n\t}\n\tif(merges.length > 0) s[\"!merges\"] = merges;\n\tif(colinfo.length > 0) s[\"!cols\"] = colinfo;\n\tif(rowinfo.length > 0) s[\"!rows\"] = rowinfo;\n\treturn s;\n}\n\n/* TODO: something useful -- this is a stub */\nfunction write_ws_bin_cell(ba/*:BufArray*/, cell/*:Cell*/, R/*:number*/, C/*:number*/, opts, ws/*:Worksheet*/, last_seen/*:boolean*/)/*:boolean*/ {\n\tif(cell.v === undefined) return false;\n\tvar vv = \"\";\n\tswitch(cell.t) {\n\t\tcase 'b': vv = cell.v ? \"1\" : \"0\"; break;\n\t\tcase 'd': // no BrtCellDate :(\n\t\t\tcell = dup(cell);\n\t\t\tcell.z = cell.z || table_fmt[14];\n\t\t\tcell.v = datenum(parseDate(cell.v)); cell.t = 'n';\n\t\t\tbreak;\n\t\t/* falls through */\n\t\tcase 'n': case 'e': vv = ''+cell.v; break;\n\t\tdefault: vv = cell.v; break;\n\t}\n\tvar o/*:any*/ = ({r:R, c:C}/*:any*/);\n\t/* TODO: cell style */\n\to.s = get_cell_style(opts.cellXfs, cell, opts);\n\tif(cell.l) ws['!links'].push([encode_cell(o), cell.l]);\n\tif(cell.c) ws['!comments'].push([encode_cell(o), cell.c]);\n\tswitch(cell.t) {\n\t\tcase 's': case 'str':\n\t\t\tif(opts.bookSST) {\n\t\t\t\tvv = get_sst_id(opts.Strings, (cell.v/*:any*/), opts.revStrings);\n\t\t\t\to.t = \"s\"; o.v = vv;\n\t\t\t\tif(last_seen) write_record(ba, 0x0012 /* BrtShortIsst */, write_BrtShortIsst(cell, o));\n\t\t\t\telse write_record(ba, 0x0007 /* BrtCellIsst */, write_BrtCellIsst(cell, o));\n\t\t\t} else {\n\t\t\t\to.t = \"str\";\n\t\t\t\tif(last_seen) write_record(ba, 0x0011 /* BrtShortSt */, write_BrtShortSt(cell, o));\n\t\t\t\telse write_record(ba, 0x0006 /* BrtCellSt */, write_BrtCellSt(cell, o));\n\t\t\t}\n\t\t\treturn true;\n\t\tcase 'n':\n\t\t\t/* TODO: determine threshold for Real vs RK */\n\t\t\tif(cell.v == (cell.v | 0) && cell.v > -1000 && cell.v < 1000) {\n\t\t\t\tif(last_seen) write_record(ba, 0x000D /* BrtShortRk */, write_BrtShortRk(cell, o));\n\t\t\t\telse write_record(ba, 0x0002 /* BrtCellRk */, write_BrtCellRk(cell, o));\n\t\t\t} else {\n\t\t\t\tif(last_seen) write_record(ba, 0x0010 /* BrtShortReal */, write_BrtShortReal(cell, o));\n\t\t\t\telse write_record(ba, 0x0005 /* BrtCellReal */, write_BrtCellReal(cell, o));\n\t\t\t} return true;\n\t\tcase 'b':\n\t\t\to.t = \"b\";\n\t\t\tif(last_seen) write_record(ba, 0x000F /* BrtShortBool */, write_BrtShortBool(cell, o));\n\t\t\telse write_record(ba, 0x0004 /* BrtCellBool */, write_BrtCellBool(cell, o));\n\t\t\treturn true;\n\t\tcase 'e':\n\t\t\to.t = \"e\";\n\t\t\tif(last_seen) write_record(ba, 0x000E /* BrtShortError */, write_BrtShortError(cell, o));\n\t\t\telse write_record(ba, 0x0003 /* BrtCellError */, write_BrtCellError(cell, o));\n\t\t\treturn true;\n\t}\n\tif(last_seen) write_record(ba, 0x000C /* BrtShortBlank */, write_BrtShortBlank(cell, o));\n\telse write_record(ba, 0x0001 /* BrtCellBlank */, write_BrtCellBlank(cell, o));\n\treturn true;\n}\n\nfunction write_CELLTABLE(ba, ws/*:Worksheet*/, idx/*:number*/, opts/*::, wb:Workbook*/) {\n\tvar range = safe_decode_range(ws['!ref'] || \"A1\"), ref, rr = \"\", cols/*:Array<string>*/ = [];\n\twrite_record(ba, 0x0091 /* BrtBeginSheetData */);\n\tvar dense = Array.isArray(ws);\n\tvar cap = range.e.r;\n\tif(ws['!rows']) cap = Math.max(range.e.r, ws['!rows'].length - 1);\n\tfor(var R = range.s.r; R <= cap; ++R) {\n\t\trr = encode_row(R);\n\t\t/* [ACCELLTABLE] */\n\t\t/* BrtRowHdr */\n\t\twrite_row_header(ba, ws, range, R);\n\t\tvar last_seen = false;\n\t\tif(R <= range.e.r) for(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\t/* *16384CELL */\n\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\tref = cols[C] + rr;\n\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\tif(!cell) { last_seen = false; continue; }\n\t\t\t/* write cell */\n\t\t\tlast_seen = write_ws_bin_cell(ba, cell, R, C, opts, ws, last_seen);\n\t\t}\n\t}\n\twrite_record(ba, 0x0092 /* BrtEndSheetData */);\n}\n\nfunction write_MERGECELLS(ba, ws/*:Worksheet*/) {\n\tif(!ws || !ws['!merges']) return;\n\twrite_record(ba, 0x00B1 /* BrtBeginMergeCells */, write_BrtBeginMergeCells(ws['!merges'].length));\n\tws['!merges'].forEach(function(m) { write_record(ba, 0x00B0 /* BrtMergeCell */, write_BrtMergeCell(m)); });\n\twrite_record(ba, 0x00B2 /* BrtEndMergeCells */);\n}\n\nfunction write_COLINFOS(ba, ws/*:Worksheet*//*::, idx:number, opts, wb:Workbook*/) {\n\tif(!ws || !ws['!cols']) return;\n\twrite_record(ba, 0x0186 /* BrtBeginColInfos */);\n\tws['!cols'].forEach(function(m, i) { if(m) write_record(ba, 0x003C /* 'BrtColInfo' */, write_BrtColInfo(i, m)); });\n\twrite_record(ba, 0x0187 /* BrtEndColInfos */);\n}\n\nfunction write_IGNOREECS(ba, ws/*:Worksheet*/) {\n\tif(!ws || !ws['!ref']) return;\n\twrite_record(ba, 0x0288 /* BrtBeginCellIgnoreECs */);\n\twrite_record(ba, 0x0289 /* BrtCellIgnoreEC */, write_BrtCellIgnoreEC(safe_decode_range(ws['!ref'])));\n\twrite_record(ba, 0x028A /* BrtEndCellIgnoreECs */);\n}\n\nfunction write_HLINKS(ba, ws/*:Worksheet*/, rels) {\n\t/* *BrtHLink */\n\tws['!links'].forEach(function(l) {\n\t\tif(!l[1].Target) return;\n\t\tvar rId = add_rels(rels, -1, l[1].Target.replace(/#.*$/, \"\"), RELS.HLINK);\n\t\twrite_record(ba, 0x01EE /* BrtHLink */, write_BrtHLink(l, rId));\n\t});\n\tdelete ws['!links'];\n}\nfunction write_LEGACYDRAWING(ba, ws/*:Worksheet*/, idx/*:number*/, rels) {\n\t/* [BrtLegacyDrawing] */\n\tif(ws['!comments'].length > 0) {\n\t\tvar rId = add_rels(rels, -1, \"../drawings/vmlDrawing\" + (idx+1) + \".vml\", RELS.VML);\n\t\twrite_record(ba, 0x0227 /* BrtLegacyDrawing */, write_RelID(\"rId\" + rId));\n\t\tws['!legacy'] = rId;\n\t}\n}\n\nfunction write_AUTOFILTER(ba, ws, wb, idx) {\n\tif(!ws['!autofilter']) return;\n\tvar data = ws['!autofilter'];\n\tvar ref = typeof data.ref === \"string\" ? data.ref : encode_range(data.ref);\n\n\t/* Update FilterDatabase defined name for the worksheet */\n\tif(!wb.Workbook) wb.Workbook = ({Sheets:[]}/*:any*/);\n\tif(!wb.Workbook.Names) wb.Workbook.Names = [];\n\tvar names/*: Array<any> */ = wb.Workbook.Names;\n\tvar range = decode_range(ref);\n\tif(range.s.r == range.e.r) { range.e.r = decode_range(ws[\"!ref\"]).e.r; ref = encode_range(range); }\n\tfor(var i = 0; i < names.length; ++i) {\n\t\tvar name = names[i];\n\t\tif(name.Name != '_xlnm._FilterDatabase') continue;\n\t\tif(name.Sheet != idx) continue;\n\t\tname.Ref = \"'\" + wb.SheetNames[idx] + \"'!\" + ref; break;\n\t}\n\tif(i == names.length) names.push({ Name: '_xlnm._FilterDatabase', Sheet: idx, Ref: \"'\" + wb.SheetNames[idx] + \"'!\" + ref });\n\n\twrite_record(ba, 0x00A1 /* BrtBeginAFilter */, write_UncheckedRfX(safe_decode_range(ref)));\n\t/* *FILTERCOLUMN */\n\t/* [SORTSTATE] */\n\t/* BrtEndAFilter */\n\twrite_record(ba, 0x00A2 /* BrtEndAFilter */);\n}\n\nfunction write_WSVIEWS2(ba, ws, Workbook) {\n\twrite_record(ba, 0x0085 /* BrtBeginWsViews */);\n\t{ /* 1*WSVIEW2 */\n\t\t/* [ACUID] */\n\t\twrite_record(ba, 0x0089 /* BrtBeginWsView */, write_BrtBeginWsView(ws, Workbook));\n\t\t/* [BrtPane] */\n\t\t/* *4BrtSel */\n\t\t/* *4SXSELECT */\n\t\t/* *FRT */\n\t\twrite_record(ba, 0x008A /* BrtEndWsView */);\n\t}\n\t/* *FRT */\n\twrite_record(ba, 0x0086 /* BrtEndWsViews */);\n}\n\nfunction write_WSFMTINFO(/*::ba, ws*/) {\n\t/* [ACWSFMTINFO] */\n\t// write_record(ba, 0x01E5 /* BrtWsFmtInfo */, write_BrtWsFmtInfo(ws));\n}\n\nfunction write_SHEETPROTECT(ba, ws) {\n\tif(!ws['!protect']) return;\n\t/* [BrtSheetProtectionIso] */\n\twrite_record(ba, 0x0217 /* BrtSheetProtection */, write_BrtSheetProtection(ws['!protect']));\n}\n\nfunction write_ws_bin(idx/*:number*/, opts, wb/*:Workbook*/, rels) {\n\tvar ba = buf_array();\n\tvar s = wb.SheetNames[idx], ws = wb.Sheets[s] || {};\n\tvar c/*:string*/ = s; try { if(wb && wb.Workbook) c = wb.Workbook.Sheets[idx].CodeName || c; } catch(e) {}\n\tvar r = safe_decode_range(ws['!ref'] || \"A1\");\n\tif(r.e.c > 0x3FFF || r.e.r > 0xFFFFF) {\n\t\tif(opts.WTF) throw new Error(\"Range \" + (ws['!ref'] || \"A1\") + \" exceeds format limit A1:XFD1048576\");\n\t\tr.e.c = Math.min(r.e.c, 0x3FFF);\n\t\tr.e.r = Math.min(r.e.c, 0xFFFFF);\n\t}\n\tws['!links'] = [];\n\t/* passed back to write_zip and removed there */\n\tws['!comments'] = [];\n\twrite_record(ba, 0x0081 /* BrtBeginSheet */);\n\tif(wb.vbaraw || ws['!outline']) write_record(ba, 0x0093 /* BrtWsProp */, write_BrtWsProp(c, ws['!outline']));\n\twrite_record(ba, 0x0094 /* BrtWsDim */, write_BrtWsDim(r));\n\twrite_WSVIEWS2(ba, ws, wb.Workbook);\n\twrite_WSFMTINFO(ba, ws);\n\twrite_COLINFOS(ba, ws, idx, opts, wb);\n\twrite_CELLTABLE(ba, ws, idx, opts, wb);\n\t/* [BrtSheetCalcProp] */\n\twrite_SHEETPROTECT(ba, ws);\n\t/* *([BrtRangeProtectionIso] BrtRangeProtection) */\n\t/* [SCENMAN] */\n\twrite_AUTOFILTER(ba, ws, wb, idx);\n\t/* [SORTSTATE] */\n\t/* [DCON] */\n\t/* [USERSHVIEWS] */\n\twrite_MERGECELLS(ba, ws);\n\t/* [BrtPhoneticInfo] */\n\t/* *CONDITIONALFORMATTING */\n\t/* [DVALS] */\n\twrite_HLINKS(ba, ws, rels);\n\t/* [BrtPrintOptions] */\n\tif(ws['!margins']) write_record(ba, 0x01DC /* BrtMargins */, write_BrtMargins(ws['!margins']));\n\t/* [BrtPageSetup] */\n\t/* [HEADERFOOTER] */\n\t/* [RWBRK] */\n\t/* [COLBRK] */\n\t/* *BrtBigName */\n\t/* [CELLWATCHES] */\n\tif(!opts || opts.ignoreEC || (opts.ignoreEC == (void 0))) write_IGNOREECS(ba, ws);\n\t/* [SMARTTAGS] */\n\t/* [BrtDrawing] */\n\twrite_LEGACYDRAWING(ba, ws, idx, rels);\n\t/* [BrtLegacyDrawingHF] */\n\t/* [BrtBkHim] */\n\t/* [OLEOBJECTS] */\n\t/* [ACTIVEXCONTROLS] */\n\t/* [WEBPUBITEMS] */\n\t/* [LISTPARTS] */\n\t/* FRTWORKSHEET */\n\twrite_record(ba, 0x0082 /* BrtEndSheet */);\n\treturn ba.end();\n}\nfunction parse_Cache(data/*:string*/)/*:[Array<number|string>, string, ?string]*/ {\n\tvar col/*:Array<number|string>*/ = [];\n\tvar num = data.match(/^<c:numCache>/);\n\tvar f;\n\n\t/* 21.2.2.150 pt CT_NumVal */\n\t(data.match(/<c:pt idx=\"(\\d*)\">(.*?)<\\/c:pt>/mg)||[]).forEach(function(pt) {\n\t\tvar q = pt.match(/<c:pt idx=\"(\\d*?)\"><c:v>(.*)<\\/c:v><\\/c:pt>/);\n\t\tif(!q) return;\n\t\tcol[+q[1]] = num ? +q[2] : q[2];\n\t});\n\n\t/* 21.2.2.71 formatCode CT_Xstring */\n\tvar nf = unescapexml((data.match(/<c:formatCode>([\\s\\S]*?)<\\/c:formatCode>/) || [\"\",\"General\"])[1]);\n\n\t(data.match(/<c:f>(.*?)<\\/c:f>/mg)||[]).forEach(function(F) { f = F.replace(/<.*?>/g,\"\"); });\n\n\treturn [col, nf, f];\n}\n\n/* 21.2 DrawingML - Charts */\nfunction parse_chart(data/*:?string*/, name/*:string*/, opts, rels, wb, csheet) {\n\tvar cs/*:Worksheet*/ = ((csheet || {\"!type\":\"chart\"})/*:any*/);\n\tif(!data) return csheet;\n\t/* 21.2.2.27 chart CT_Chart */\n\n\tvar C = 0, R = 0, col = \"A\";\n\tvar refguess = {s: {r:2000000, c:2000000}, e: {r:0, c:0} };\n\n\t/* 21.2.2.120 numCache CT_NumData */\n\t(data.match(/<c:numCache>[\\s\\S]*?<\\/c:numCache>/gm)||[]).forEach(function(nc) {\n\t\tvar cache = parse_Cache(nc);\n\t\trefguess.s.r = refguess.s.c = 0;\n\t\trefguess.e.c = C;\n\t\tcol = encode_col(C);\n\t\tcache[0].forEach(function(n,i) {\n\t\t\tcs[col + encode_row(i)] = {t:'n', v:n, z:cache[1] };\n\t\t\tR = i;\n\t\t});\n\t\tif(refguess.e.r < R) refguess.e.r = R;\n\t\t++C;\n\t});\n\tif(C > 0) cs[\"!ref\"] = encode_range(refguess);\n\treturn cs;\n}\n/* 18.3 Worksheets also covers Chartsheets */\nfunction parse_cs_xml(data/*:?string*/, opts, idx/*:number*/, rels, wb/*::, themes, styles*/)/*:Worksheet*/ {\n\tif(!data) return data;\n\t/* 18.3.1.12 chartsheet CT_ChartSheet */\n\tif(!rels) rels = {'!id':{}};\n\tvar s = ({'!type':\"chart\", '!drawel':null, '!rel':\"\"}/*:any*/);\n\tvar m;\n\n\t/* 18.3.1.83 sheetPr CT_ChartsheetPr */\n\tvar sheetPr = data.match(sheetprregex);\n\tif(sheetPr) parse_ws_xml_sheetpr(sheetPr[0], s, wb, idx);\n\n\t/* 18.3.1.36 drawing CT_Drawing */\n\tif((m = data.match(/drawing r:id=\"(.*?)\"/))) s['!rel'] = m[1];\n\n\tif(rels['!id'][s['!rel']]) s['!drawel'] = rels['!id'][s['!rel']];\n\treturn s;\n}\nfunction write_cs_xml(idx/*:number*/, opts, wb/*:Workbook*/, rels)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('chartsheet', null, {\n\t\t'xmlns': XMLNS_main[0],\n\t\t'xmlns:r': XMLNS.r\n\t})];\n\to[o.length] = writextag(\"drawing\", null, {\"r:id\": \"rId1\"});\n\tadd_rels(rels, -1, \"../drawings/drawing\" + (idx+1) + \".xml\", RELS.DRAW);\n\tif(o.length>2) { o[o.length] = ('</chartsheet>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n\n/* [MS-XLSB] 2.4.331 BrtCsProp */\nfunction parse_BrtCsProp(data, length/*:number*/) {\n\tdata.l += 10;\n\tvar name = parse_XLWideString(data, length - 10);\n\treturn { name: name };\n}\n\n/* [MS-XLSB] 2.1.7.7 Chart Sheet */\nfunction parse_cs_bin(data, opts, idx/*:number*/, rels, wb/*::, themes, styles*/)/*:Worksheet*/ {\n\tif(!data) return data;\n\tif(!rels) rels = {'!id':{}};\n\tvar s = {'!type':\"chart\", '!drawel':null, '!rel':\"\"};\n\tvar state/*:Array<string>*/ = [];\n\tvar pass = false;\n\trecordhopper(data, function cs_parse(val, R, RT) {\n\t\tswitch(RT) {\n\n\t\t\tcase 0x0226: /* 'BrtDrawing' */\n\t\t\t\ts['!rel'] = val; break;\n\n\t\t\tcase 0x028B: /* 'BrtCsProp' */\n\t\t\t\tif(!wb.Sheets[idx]) wb.Sheets[idx] = {};\n\t\t\t\tif(val.name) wb.Sheets[idx].CodeName = val.name;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0232: /* 'BrtBkHim' */\n\t\t\tcase 0x028C: /* 'BrtCsPageSetup' */\n\t\t\tcase 0x029D: /* 'BrtCsProtection' */\n\t\t\tcase 0x02A7: /* 'BrtCsProtectionIso' */\n\t\t\tcase 0x0227: /* 'BrtLegacyDrawing' */\n\t\t\tcase 0x0228: /* 'BrtLegacyDrawingHF' */\n\t\t\tcase 0x01DC: /* 'BrtMargins' */\n\t\t\tcase 0x0C00: /* 'BrtUid' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tpass = false; break;\n\t\t\tcase 0x0025: /* 'BrtACBegin' */\n\t\t\t\tstate.push(RT); break;\n\t\t\tcase 0x0026: /* 'BrtACEnd' */\n\t\t\t\tstate.pop(); break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T > 0) state.push(RT);\n\t\t\t\telse if(R.T < 0) state.pop();\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t}, opts);\n\n\tif(rels['!id'][s['!rel']]) s['!drawel'] = rels['!id'][s['!rel']];\n\treturn s;\n}\nfunction write_cs_bin(/*::idx:number, opts, wb:Workbook, rels*/) {\n\tvar ba = buf_array();\n\twrite_record(ba, 0x0081 /* BrtBeginSheet */);\n\t/* [BrtCsProp] */\n\t/* CSVIEWS */\n\t/* [[BrtCsProtectionIso] BrtCsProtection] */\n\t/* [USERCSVIEWS] */\n\t/* [BrtMargins] */\n\t/* [BrtCsPageSetup] */\n\t/* [HEADERFOOTER] */\n\t/* BrtDrawing */\n\t/* [BrtLegacyDrawing] */\n\t/* [BrtLegacyDrawingHF] */\n\t/* [BrtBkHim] */\n\t/* [WEBPUBITEMS] */\n\t/* FRTCHARTSHEET */\n\twrite_record(ba, 0x0082 /* BrtEndSheet */);\n\treturn ba.end();\n}\n/* 18.2.28 (CT_WorkbookProtection) Defaults */\nvar WBPropsDef = [\n\t['allowRefreshQuery', false, \"bool\"],\n\t['autoCompressPictures', true, \"bool\"],\n\t['backupFile', false, \"bool\"],\n\t['checkCompatibility', false, \"bool\"],\n\t['CodeName', ''],\n\t['date1904', false, \"bool\"],\n\t['defaultThemeVersion', 0, \"int\"],\n\t['filterPrivacy', false, \"bool\"],\n\t['hidePivotFieldList', false, \"bool\"],\n\t['promptedSolutions', false, \"bool\"],\n\t['publishItems', false, \"bool\"],\n\t['refreshAllConnections', false, \"bool\"],\n\t['saveExternalLinkValues', true, \"bool\"],\n\t['showBorderUnselectedTables', true, \"bool\"],\n\t['showInkAnnotation', true, \"bool\"],\n\t['showObjects', 'all'],\n\t['showPivotChartFilter', false, \"bool\"],\n\t['updateLinks', 'userSet']\n];\n\n/* 18.2.30 (CT_BookView) Defaults */\nvar WBViewDef = [\n\t['activeTab', 0, \"int\"],\n\t['autoFilterDateGrouping', true, \"bool\"],\n\t['firstSheet', 0, \"int\"],\n\t['minimized', false, \"bool\"],\n\t['showHorizontalScroll', true, \"bool\"],\n\t['showSheetTabs', true, \"bool\"],\n\t['showVerticalScroll', true, \"bool\"],\n\t['tabRatio', 600, \"int\"],\n\t['visibility', 'visible']\n\t//window{Height,Width}, {x,y}Window\n];\n\n/* 18.2.19 (CT_Sheet) Defaults */\nvar SheetDef = [\n\t//['state', 'visible']\n];\n\n/* 18.2.2 (CT_CalcPr) Defaults */\nvar CalcPrDef = [\n\t['calcCompleted', 'true'],\n\t['calcMode', 'auto'],\n\t['calcOnSave', 'true'],\n\t['concurrentCalc', 'true'],\n\t['fullCalcOnLoad', 'false'],\n\t['fullPrecision', 'true'],\n\t['iterate', 'false'],\n\t['iterateCount', '100'],\n\t['iterateDelta', '0.001'],\n\t['refMode', 'A1']\n];\n\n/* 18.2.3 (CT_CustomWorkbookView) Defaults */\n/*var CustomWBViewDef = [\n\t['autoUpdate', 'false'],\n\t['changesSavedWin', 'false'],\n\t['includeHiddenRowCol', 'true'],\n\t['includePrintSettings', 'true'],\n\t['maximized', 'false'],\n\t['minimized', 'false'],\n\t['onlySync', 'false'],\n\t['personalView', 'false'],\n\t['showComments', 'commIndicator'],\n\t['showFormulaBar', 'true'],\n\t['showHorizontalScroll', 'true'],\n\t['showObjects', 'all'],\n\t['showSheetTabs', 'true'],\n\t['showStatusbar', 'true'],\n\t['showVerticalScroll', 'true'],\n\t['tabRatio', '600'],\n\t['xWindow', '0'],\n\t['yWindow', '0']\n];*/\n\nfunction push_defaults_array(target, defaults) {\n\tfor(var j = 0; j != target.length; ++j) { var w = target[j];\n\t\tfor(var i=0; i != defaults.length; ++i) { var z = defaults[i];\n\t\t\tif(w[z[0]] == null) w[z[0]] = z[1];\n\t\t\telse switch(z[2]) {\n\t\t\tcase \"bool\": if(typeof w[z[0]] == \"string\") w[z[0]] = parsexmlbool(w[z[0]]); break;\n\t\t\tcase \"int\": if(typeof w[z[0]] == \"string\") w[z[0]] = parseInt(w[z[0]], 10); break;\n\t\t\t}\n\t\t}\n\t}\n}\nfunction push_defaults(target, defaults) {\n\tfor(var i = 0; i != defaults.length; ++i) { var z = defaults[i];\n\t\tif(target[z[0]] == null) target[z[0]] = z[1];\n\t\telse switch(z[2]) {\n\t\t\tcase \"bool\": if(typeof target[z[0]] == \"string\") target[z[0]] = parsexmlbool(target[z[0]]); break;\n\t\t\tcase \"int\": if(typeof target[z[0]] == \"string\") target[z[0]] = parseInt(target[z[0]], 10); break;\n\t\t}\n\t}\n}\n\nfunction parse_wb_defaults(wb) {\n\tpush_defaults(wb.WBProps, WBPropsDef);\n\tpush_defaults(wb.CalcPr, CalcPrDef);\n\n\tpush_defaults_array(wb.WBView, WBViewDef);\n\tpush_defaults_array(wb.Sheets, SheetDef);\n\n\t_ssfopts.date1904 = parsexmlbool(wb.WBProps.date1904);\n}\n\nfunction safe1904(wb/*:Workbook*/)/*:string*/ {\n\t/* TODO: store date1904 somewhere else */\n\tif(!wb.Workbook) return \"false\";\n\tif(!wb.Workbook.WBProps) return \"false\";\n\treturn parsexmlbool(wb.Workbook.WBProps.date1904) ? \"true\" : \"false\";\n}\n\nvar badchars = /*#__PURE__*/\"][*?\\/\\\\\".split(\"\");\nfunction check_ws_name(n/*:string*/, safe/*:?boolean*/)/*:boolean*/ {\n\tif(n.length > 31) { if(safe) return false; throw new Error(\"Sheet names cannot exceed 31 chars\"); }\n\tvar _good = true;\n\tbadchars.forEach(function(c) {\n\t\tif(n.indexOf(c) == -1) return;\n\t\tif(!safe) throw new Error(\"Sheet name cannot contain : \\\\ / ? * [ ]\");\n\t\t_good = false;\n\t});\n\treturn _good;\n}\nfunction check_wb_names(N, S, codes) {\n\tN.forEach(function(n,i) {\n\t\tcheck_ws_name(n);\n\t\tfor(var j = 0; j < i; ++j) if(n == N[j]) throw new Error(\"Duplicate Sheet Name: \" + n);\n\t\tif(codes) {\n\t\t\tvar cn = (S && S[i] && S[i].CodeName) || n;\n\t\t\tif(cn.charCodeAt(0) == 95 && cn.length > 22) throw new Error(\"Bad Code Name: Worksheet\" + cn);\n\t\t}\n\t});\n}\nfunction check_wb(wb) {\n\tif(!wb || !wb.SheetNames || !wb.Sheets) throw new Error(\"Invalid Workbook\");\n\tif(!wb.SheetNames.length) throw new Error(\"Workbook is empty\");\n\tvar Sheets = (wb.Workbook && wb.Workbook.Sheets) || [];\n\tcheck_wb_names(wb.SheetNames, Sheets, !!wb.vbaraw);\n\tfor(var i = 0; i < wb.SheetNames.length; ++i) check_ws(wb.Sheets[wb.SheetNames[i]], wb.SheetNames[i], i);\n\t/* TODO: validate workbook */\n}\n/* 18.2 Workbook */\nvar wbnsregex = /<\\w+:workbook/;\nfunction parse_wb_xml(data, opts)/*:WorkbookFile*/ {\n\tif(!data) throw new Error(\"Could not find file\");\n\tvar wb = /*::(*/{ AppVersion:{}, WBProps:{}, WBView:[], Sheets:[], CalcPr:{}, Names:[], xmlns: \"\" }/*::)*/;\n\tvar pass = false, xmlns = \"xmlns\";\n\tvar dname = {}, dnstart = 0;\n\tdata.replace(tagregex, function xml_wb(x, idx) {\n\t\tvar y/*:any*/ = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<?xml': break;\n\n\t\t\t/* 18.2.27 workbook CT_Workbook 1 */\n\t\t\tcase '<workbook':\n\t\t\t\tif(x.match(wbnsregex)) xmlns = \"xmlns\" + x.match(/<(\\w+):/)[1];\n\t\t\t\twb.xmlns = y[xmlns];\n\t\t\t\tbreak;\n\t\t\tcase '</workbook>': break;\n\n\t\t\t/* 18.2.13 fileVersion CT_FileVersion ? */\n\t\t\tcase '<fileVersion': delete y[0]; wb.AppVersion = y; break;\n\t\t\tcase '<fileVersion/>': case '</fileVersion>': break;\n\n\t\t\t/* 18.2.12 fileSharing CT_FileSharing ? */\n\t\t\tcase '<fileSharing':\n\t\t\t\tbreak;\n\t\t\tcase '<fileSharing/>': break;\n\n\t\t\t/* 18.2.28 workbookPr CT_WorkbookPr ? */\n\t\t\tcase '<workbookPr':\n\t\t\tcase '<workbookPr/>':\n\t\t\t\tWBPropsDef.forEach(function(w) {\n\t\t\t\t\tif(y[w[0]] == null) return;\n\t\t\t\t\tswitch(w[2]) {\n\t\t\t\t\t\tcase \"bool\": wb.WBProps[w[0]] = parsexmlbool(y[w[0]]); break;\n\t\t\t\t\t\tcase \"int\": wb.WBProps[w[0]] = parseInt(y[w[0]], 10); break;\n\t\t\t\t\t\tdefault: wb.WBProps[w[0]] = y[w[0]];\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tif(y.codeName) wb.WBProps.CodeName = utf8read(y.codeName);\n\t\t\t\tbreak;\n\t\t\tcase '</workbookPr>': break;\n\n\t\t\t/* 18.2.29 workbookProtection CT_WorkbookProtection ? */\n\t\t\tcase '<workbookProtection':\n\t\t\t\tbreak;\n\t\t\tcase '<workbookProtection/>': break;\n\n\t\t\t/* 18.2.1 bookViews CT_BookViews ? */\n\t\t\tcase '<bookViews': case '<bookViews>': case '</bookViews>': break;\n\t\t\t/* 18.2.30 workbookView CT_BookView + */\n\t\t\tcase '<workbookView': case '<workbookView/>': delete y[0]; wb.WBView.push(y); break;\n\t\t\tcase '</workbookView>': break;\n\n\t\t\t/* 18.2.20 sheets CT_Sheets 1 */\n\t\t\tcase '<sheets': case '<sheets>': case '</sheets>': break; // aggregate sheet\n\t\t\t/* 18.2.19 sheet CT_Sheet + */\n\t\t\tcase '<sheet':\n\t\t\t\tswitch(y.state) {\n\t\t\t\t\tcase \"hidden\": y.Hidden = 1; break;\n\t\t\t\t\tcase \"veryHidden\": y.Hidden = 2; break;\n\t\t\t\t\tdefault: y.Hidden = 0;\n\t\t\t\t}\n\t\t\t\tdelete y.state;\n\t\t\t\ty.name = unescapexml(utf8read(y.name));\n\t\t\t\tdelete y[0]; wb.Sheets.push(y); break;\n\t\t\tcase '</sheet>': break;\n\n\t\t\t/* 18.2.15 functionGroups CT_FunctionGroups ? */\n\t\t\tcase '<functionGroups': case '<functionGroups/>': break;\n\t\t\t/* 18.2.14 functionGroup CT_FunctionGroup + */\n\t\t\tcase '<functionGroup': break;\n\n\t\t\t/* 18.2.9 externalReferences CT_ExternalReferences ? */\n\t\t\tcase '<externalReferences': case '</externalReferences>': case '<externalReferences>': break;\n\t\t\t/* 18.2.8 externalReference CT_ExternalReference + */\n\t\t\tcase '<externalReference': break;\n\n\t\t\t/* 18.2.6 definedNames CT_DefinedNames ? */\n\t\t\tcase '<definedNames/>': break;\n\t\t\tcase '<definedNames>': case '<definedNames': pass=true; break;\n\t\t\tcase '</definedNames>': pass=false; break;\n\t\t\t/* 18.2.5 definedName CT_DefinedName + */\n\t\t\tcase '<definedName': {\n\t\t\t\tdname = {};\n\t\t\t\tdname.Name = utf8read(y.name);\n\t\t\t\tif(y.comment) dname.Comment = y.comment;\n\t\t\t\tif(y.localSheetId) dname.Sheet = +y.localSheetId;\n\t\t\t\tif(parsexmlbool(y.hidden||\"0\")) dname.Hidden = true;\n\t\t\t\tdnstart = idx + x.length;\n\t\t\t}\tbreak;\n\t\t\tcase '</definedName>': {\n\t\t\t\tdname.Ref = unescapexml(utf8read(data.slice(dnstart, idx)));\n\t\t\t\twb.Names.push(dname);\n\t\t\t} break;\n\t\t\tcase '<definedName/>': break;\n\n\t\t\t/* 18.2.2 calcPr CT_CalcPr ? */\n\t\t\tcase '<calcPr': delete y[0]; wb.CalcPr = y; break;\n\t\t\tcase '<calcPr/>': delete y[0]; wb.CalcPr = y; break;\n\t\t\tcase '</calcPr>': break;\n\n\t\t\t/* 18.2.16 oleSize CT_OleSize ? (ref required) */\n\t\t\tcase '<oleSize': break;\n\n\t\t\t/* 18.2.4 customWorkbookViews CT_CustomWorkbookViews ? */\n\t\t\tcase '<customWorkbookViews>': case '</customWorkbookViews>': case '<customWorkbookViews': break;\n\t\t\t/* 18.2.3 customWorkbookView CT_CustomWorkbookView + */\n\t\t\tcase '<customWorkbookView': case '</customWorkbookView>': break;\n\n\t\t\t/* 18.2.18 pivotCaches CT_PivotCaches ? */\n\t\t\tcase '<pivotCaches>': case '</pivotCaches>': case '<pivotCaches': break;\n\t\t\t/* 18.2.17 pivotCache CT_PivotCache ? */\n\t\t\tcase '<pivotCache': break;\n\n\t\t\t/* 18.2.21 smartTagPr CT_SmartTagPr ? */\n\t\t\tcase '<smartTagPr': case '<smartTagPr/>': break;\n\n\t\t\t/* 18.2.23 smartTagTypes CT_SmartTagTypes ? */\n\t\t\tcase '<smartTagTypes': case '<smartTagTypes>': case '</smartTagTypes>': break;\n\t\t\t/* 18.2.22 smartTagType CT_SmartTagType ? */\n\t\t\tcase '<smartTagType': break;\n\n\t\t\t/* 18.2.24 webPublishing CT_WebPublishing ? */\n\t\t\tcase '<webPublishing': case '<webPublishing/>': break;\n\n\t\t\t/* 18.2.11 fileRecoveryPr CT_FileRecoveryPr ? */\n\t\t\tcase '<fileRecoveryPr': case '<fileRecoveryPr/>': break;\n\n\t\t\t/* 18.2.26 webPublishObjects CT_WebPublishObjects ? */\n\t\t\tcase '<webPublishObjects>': case '<webPublishObjects': case '</webPublishObjects>': break;\n\t\t\t/* 18.2.25 webPublishObject CT_WebPublishObject ? */\n\t\t\tcase '<webPublishObject': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': case '<extLst/>': break;\n\t\t\t/* 18.2.7 ext CT_Extension + */\n\t\t\tcase '<ext': pass=true; break; //TODO: check with versions of excel\n\t\t\tcase '</ext>': pass=false; break;\n\n\t\t\t/* Others */\n\t\t\tcase '<ArchID': break;\n\t\t\tcase '<AlternateContent':\n\t\t\tcase '<AlternateContent>': pass=true; break;\n\t\t\tcase '</AlternateContent>': pass=false; break;\n\n\t\t\t/* TODO */\n\t\t\tcase '<revisionPtr': break;\n\n\t\t\tdefault: if(!pass && opts.WTF) throw new Error('unrecognized ' + y[0] + ' in workbook');\n\t\t}\n\t\treturn x;\n\t});\n\tif(XMLNS_main.indexOf(wb.xmlns) === -1) throw new Error(\"Unknown Namespace: \" + wb.xmlns);\n\n\tparse_wb_defaults(wb);\n\n\treturn wb;\n}\n\nfunction write_wb_xml(wb/*:Workbook*//*::, opts:?WriteOpts*/)/*:string*/ {\n\tvar o = [XML_HEADER];\n\to[o.length] = writextag('workbook', null, {\n\t\t'xmlns': XMLNS_main[0],\n\t\t//'xmlns:mx': XMLNS.mx,\n\t\t//'xmlns:s': XMLNS_main[0],\n\t\t'xmlns:r': XMLNS.r\n\t});\n\n\tvar write_names = (wb.Workbook && (wb.Workbook.Names||[]).length > 0);\n\n\t/* fileVersion */\n\t/* fileSharing */\n\n\tvar workbookPr/*:any*/ = ({codeName:\"ThisWorkbook\"}/*:any*/);\n\tif(wb.Workbook && wb.Workbook.WBProps) {\n\t\tWBPropsDef.forEach(function(x) {\n\t\t\t/*:: if(!wb.Workbook || !wb.Workbook.WBProps) throw \"unreachable\"; */\n\t\t\tif((wb.Workbook.WBProps[x[0]]/*:any*/) == null) return;\n\t\t\tif((wb.Workbook.WBProps[x[0]]/*:any*/) == x[1]) return;\n\t\t\tworkbookPr[x[0]] = (wb.Workbook.WBProps[x[0]]/*:any*/);\n\t\t});\n\t\t/*:: if(!wb.Workbook || !wb.Workbook.WBProps) throw \"unreachable\"; */\n\t\tif(wb.Workbook.WBProps.CodeName) { workbookPr.codeName = wb.Workbook.WBProps.CodeName; delete workbookPr.CodeName; }\n\t}\n\to[o.length] = (writextag('workbookPr', null, workbookPr));\n\n\t/* workbookProtection */\n\n\tvar sheets = wb.Workbook && wb.Workbook.Sheets || [];\n\tvar i = 0;\n\n\t/* bookViews only written if first worksheet is hidden */\n\tif(sheets && sheets[0] && !!sheets[0].Hidden) {\n\t\to[o.length] = \"<bookViews>\";\n\t\tfor(i = 0; i != wb.SheetNames.length; ++i) {\n\t\t\tif(!sheets[i]) break;\n\t\t\tif(!sheets[i].Hidden) break;\n\t\t}\n\t\tif(i == wb.SheetNames.length) i = 0;\n\t\to[o.length] = '<workbookView firstSheet=\"' + i + '\" activeTab=\"' + i + '\"/>';\n\t\to[o.length] = \"</bookViews>\";\n\t}\n\n\to[o.length] = \"<sheets>\";\n\tfor(i = 0; i != wb.SheetNames.length; ++i) {\n\t\tvar sht = ({name:escapexml(wb.SheetNames[i].slice(0,31))}/*:any*/);\n\t\tsht.sheetId = \"\"+(i+1);\n\t\tsht[\"r:id\"] = \"rId\"+(i+1);\n\t\tif(sheets[i]) switch(sheets[i].Hidden) {\n\t\t\tcase 1: sht.state = \"hidden\"; break;\n\t\t\tcase 2: sht.state = \"veryHidden\"; break;\n\t\t}\n\t\to[o.length] = (writextag('sheet',null,sht));\n\t}\n\to[o.length] = \"</sheets>\";\n\n\t/* functionGroups */\n\t/* externalReferences */\n\n\tif(write_names) {\n\t\to[o.length] = \"<definedNames>\";\n\t\tif(wb.Workbook && wb.Workbook.Names) wb.Workbook.Names.forEach(function(n) {\n\t\t\tvar d/*:any*/ = {name:n.Name};\n\t\t\tif(n.Comment) d.comment = n.Comment;\n\t\t\tif(n.Sheet != null) d.localSheetId = \"\"+n.Sheet;\n\t\t\tif(n.Hidden) d.hidden = \"1\";\n\t\t\tif(!n.Ref) return;\n\t\t\to[o.length] = writextag('definedName', escapexml(n.Ref), d);\n\t\t});\n\t\to[o.length] = \"</definedNames>\";\n\t}\n\n\t/* calcPr */\n\t/* oleSize */\n\t/* customWorkbookViews */\n\t/* pivotCaches */\n\t/* smartTagPr */\n\t/* smartTagTypes */\n\t/* webPublishing */\n\t/* fileRecoveryPr */\n\t/* webPublishObjects */\n\t/* extLst */\n\n\tif(o.length>2){ o[o.length] = '</workbook>'; o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.304 BrtBundleSh */\nfunction parse_BrtBundleSh(data, length/*:number*/) {\n\tvar z = {};\n\tz.Hidden = data.read_shift(4); //hsState ST_SheetState\n\tz.iTabID = data.read_shift(4);\n\tz.strRelID = parse_RelID(data,length-8);\n\tz.name = parse_XLWideString(data);\n\treturn z;\n}\nfunction write_BrtBundleSh(data, o) {\n\tif(!o) o = new_buf(127);\n\to.write_shift(4, data.Hidden);\n\to.write_shift(4, data.iTabID);\n\twrite_RelID(data.strRelID, o);\n\twrite_XLWideString(data.name.slice(0,31), o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.815 BrtWbProp */\nfunction parse_BrtWbProp(data, length)/*:WBProps*/ {\n\tvar o/*:WBProps*/ = ({}/*:any*/);\n\tvar flags = data.read_shift(4);\n\to.defaultThemeVersion = data.read_shift(4);\n\tvar strName = (length > 8) ? parse_XLWideString(data) : \"\";\n\tif(strName.length > 0) o.CodeName = strName;\n\to.autoCompressPictures = !!(flags & 0x10000);\n\to.backupFile = !!(flags & 0x40);\n\to.checkCompatibility = !!(flags & 0x1000);\n\to.date1904 = !!(flags & 0x01);\n\to.filterPrivacy = !!(flags & 0x08);\n\to.hidePivotFieldList = !!(flags & 0x400);\n\to.promptedSolutions = !!(flags & 0x10);\n\to.publishItems = !!(flags & 0x800);\n\to.refreshAllConnections = !!(flags & 0x40000);\n\to.saveExternalLinkValues = !!(flags & 0x80);\n\to.showBorderUnselectedTables = !!(flags & 0x04);\n\to.showInkAnnotation = !!(flags & 0x20);\n\to.showObjects = [\"all\", \"placeholders\", \"none\"][(flags >> 13) & 0x03];\n\to.showPivotChartFilter = !!(flags & 0x8000);\n\to.updateLinks = [\"userSet\", \"never\", \"always\"][(flags >> 8) & 0x03];\n\treturn o;\n}\nfunction write_BrtWbProp(data/*:?WBProps*/, o) {\n\tif(!o) o = new_buf(72);\n\tvar flags = 0;\n\tif(data) {\n\t\t/* TODO: mirror parse_BrtWbProp fields */\n\t\tif(data.filterPrivacy) flags |= 0x08;\n\t}\n\to.write_shift(4, flags);\n\to.write_shift(4, 0);\n\twrite_XLSBCodeName(data && data.CodeName || \"ThisWorkbook\", o);\n\treturn o.slice(0, o.l);\n}\n\nfunction parse_BrtFRTArchID$(data, length) {\n\tvar o = {};\n\tdata.read_shift(4);\n\to.ArchID = data.read_shift(4);\n\tdata.l += length - 8;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.687 BrtName */\nfunction parse_BrtName(data, length, opts) {\n\tvar end = data.l + length;\n\tdata.l += 4; //var flags = data.read_shift(4);\n\tdata.l += 1; //var chKey = data.read_shift(1);\n\tvar itab = data.read_shift(4);\n\tvar name = parse_XLNameWideString(data);\n\tvar formula = parse_XLSBNameParsedFormula(data, 0, opts);\n\tvar comment = parse_XLNullableWideString(data);\n\t//if(0 /* fProc */) {\n\t\t// unusedstring1: XLNullableWideString\n\t\t// description: XLNullableWideString\n\t\t// helpTopic: XLNullableWideString\n\t\t// unusedstring2: XLNullableWideString\n\t//}\n\tdata.l = end;\n\tvar out = ({Name:name, Ptg:formula}/*:any*/);\n\tif(itab < 0xFFFFFFF) out.Sheet = itab;\n\tif(comment) out.Comment = comment;\n\treturn out;\n}\n\n/* [MS-XLSB] 2.1.7.61 Workbook */\nfunction parse_wb_bin(data, opts)/*:WorkbookFile*/ {\n\tvar wb = { AppVersion:{}, WBProps:{}, WBView:[], Sheets:[], CalcPr:{}, xmlns: \"\" };\n\tvar state/*:Array<string>*/ = [];\n\tvar pass = false;\n\n\tif(!opts) opts = {};\n\topts.biff = 12;\n\n\tvar Names = [];\n\tvar supbooks = ([[]]/*:any*/);\n\tsupbooks.SheetNames = [];\n\tsupbooks.XTI = [];\n\n\tXLSBRecordEnum[0x0010] = { n:\"BrtFRTArchID$\", f:parse_BrtFRTArchID$ };\n\n\trecordhopper(data, function hopper_wb(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x009C: /* 'BrtBundleSh' */\n\t\t\t\tsupbooks.SheetNames.push(val.name);\n\t\t\t\twb.Sheets.push(val); break;\n\n\t\t\tcase 0x0099: /* 'BrtWbProp' */\n\t\t\t\twb.WBProps = val; break;\n\n\t\t\tcase 0x0027: /* 'BrtName' */\n\t\t\t\tif(val.Sheet != null) opts.SID = val.Sheet;\n\t\t\t\tval.Ref = stringify_formula(val.Ptg, null, null, supbooks, opts);\n\t\t\t\tdelete opts.SID;\n\t\t\t\tdelete val.Ptg;\n\t\t\t\tNames.push(val);\n\t\t\t\tbreak;\n\t\t\tcase 0x040C: /* 'BrtNameExt' */ break;\n\n\t\t\tcase 0x0165: /* 'BrtSupSelf' */\n\t\t\tcase 0x0166: /* 'BrtSupSame' */\n\t\t\tcase 0x0163: /* 'BrtSupBookSrc' */\n\t\t\tcase 0x029B: /* 'BrtSupAddin' */\n\t\t\t\tif(!supbooks[0].length) supbooks[0] = [RT, val];\n\t\t\t\telse supbooks.push([RT, val]);\n\t\t\t\tsupbooks[supbooks.length - 1].XTI = [];\n\t\t\t\tbreak;\n\t\t\tcase 0x016A: /* 'BrtExternSheet' */\n\t\t\t\tif(supbooks.length === 0) { supbooks[0] = []; supbooks[0].XTI = []; }\n\t\t\t\tsupbooks[supbooks.length - 1].XTI = supbooks[supbooks.length - 1].XTI.concat(val);\n\t\t\t\tsupbooks.XTI = supbooks.XTI.concat(val);\n\t\t\t\tbreak;\n\t\t\tcase 0x0169: /* 'BrtPlaceholderName' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0817: /* 'BrtAbsPath15' */\n\t\t\tcase 0x009E: /* 'BrtBookView' */\n\t\t\tcase 0x008F: /* 'BrtBeginBundleShs' */\n\t\t\tcase 0x0298: /* 'BrtBeginFnGroup' */\n\t\t\tcase 0x0161: /* 'BrtBeginExternals' */\n\t\t\t\tbreak;\n\n\t\t\t/* case 'BrtModelTimeGroupingCalcCol' */\n\t\t\tcase 0x0C00: /* 'BrtUid' */\n\t\t\tcase 0x0C01: /* 'BrtRevisionPtr' */\n\t\t\tcase 0x0216: /* 'BrtBookProtection' */\n\t\t\tcase 0x02A5: /* 'BrtBookProtectionIso' */\n\t\t\tcase 0x009D: /* 'BrtCalcProp' */\n\t\t\tcase 0x0262: /* 'BrtCrashRecErr' */\n\t\t\tcase 0x0802: /* 'BrtDecoupledPivotCacheID' */\n\t\t\tcase 0x009B: /* 'BrtFileRecover' */\n\t\t\tcase 0x0224: /* 'BrtFileSharing' */\n\t\t\tcase 0x02A4: /* 'BrtFileSharingIso' */\n\t\t\tcase 0x0080: /* 'BrtFileVersion' */\n\t\t\tcase 0x0299: /* 'BrtFnGroup' */\n\t\t\tcase 0x0850: /* 'BrtModelRelationship' */\n\t\t\tcase 0x084D: /* 'BrtModelTable' */\n\t\t\tcase 0x0225: /* 'BrtOleSize' */\n\t\t\tcase 0x0805: /* 'BrtPivotTableRef' */\n\t\t\tcase 0x0254: /* 'BrtSmartTagType' */\n\t\t\tcase 0x081C: /* 'BrtTableSlicerCacheID' */\n\t\t\tcase 0x081B: /* 'BrtTableSlicerCacheIDs' */\n\t\t\tcase 0x0822: /* 'BrtTimelineCachePivotCacheID' */\n\t\t\tcase 0x018D: /* 'BrtUserBookView' */\n\t\t\tcase 0x009A: /* 'BrtWbFactoid' */\n\t\t\tcase 0x045D: /* 'BrtWbProp14' */\n\t\t\tcase 0x0229: /* 'BrtWebOpt' */\n\t\t\tcase 0x082B: /* 'BrtWorkBookPr15' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tstate.push(RT); pass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tstate.pop(); pass = false; break;\n\t\t\tcase 0x0025: /* 'BrtACBegin' */\n\t\t\t\tstate.push(RT); pass = true; break;\n\t\t\tcase 0x0026: /* 'BrtACEnd' */\n\t\t\t\tstate.pop(); pass = false; break;\n\n\t\t\tcase 0x0010: /* 'BrtFRTArchID$' */ break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){/* empty */}\n\t\t\t\telse if(!pass || (opts.WTF && state[state.length-1] != 0x0025 /* BrtACBegin */ && state[state.length-1] != 0x0023 /* BrtFRTBegin */)) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t}, opts);\n\n\tparse_wb_defaults(wb);\n\n\t// $FlowIgnore\n\twb.Names = Names;\n\n\t(wb/*:any*/).supbooks = supbooks;\n\treturn wb;\n}\n\nfunction write_BUNDLESHS(ba, wb/*::, opts*/) {\n\twrite_record(ba, 0x008F /* BrtBeginBundleShs */);\n\tfor(var idx = 0; idx != wb.SheetNames.length; ++idx) {\n\t\tvar viz = wb.Workbook && wb.Workbook.Sheets && wb.Workbook.Sheets[idx] && wb.Workbook.Sheets[idx].Hidden || 0;\n\t\tvar d = { Hidden: viz, iTabID: idx+1, strRelID: 'rId' + (idx+1), name: wb.SheetNames[idx] };\n\t\twrite_record(ba, 0x009C /* BrtBundleSh */, write_BrtBundleSh(d));\n\t}\n\twrite_record(ba, 0x0090 /* BrtEndBundleShs */);\n}\n\n/* [MS-XLSB] 2.4.649 BrtFileVersion */\nfunction write_BrtFileVersion(data, o) {\n\tif(!o) o = new_buf(127);\n\tfor(var i = 0; i != 4; ++i) o.write_shift(4, 0);\n\twrite_XLWideString(\"SheetJS\", o);\n\twrite_XLWideString(XLSX.version, o);\n\twrite_XLWideString(XLSX.version, o);\n\twrite_XLWideString(\"7262\", o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.301 BrtBookView */\nfunction write_BrtBookView(idx, o) {\n\tif(!o) o = new_buf(29);\n\to.write_shift(-4, 0);\n\to.write_shift(-4, 460);\n\to.write_shift(4, 28800);\n\to.write_shift(4, 17600);\n\to.write_shift(4, 500);\n\to.write_shift(4, idx);\n\to.write_shift(4, idx);\n\tvar flags = 0x78;\n\to.write_shift(1, flags);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\nfunction write_BOOKVIEWS(ba, wb/*::, opts*/) {\n\t/* required if hidden tab appears before visible tab */\n\tif(!wb.Workbook || !wb.Workbook.Sheets) return;\n\tvar sheets = wb.Workbook.Sheets;\n\tvar i = 0, vistab = -1, hidden = -1;\n\tfor(; i < sheets.length; ++i) {\n\t\tif(!sheets[i] || !sheets[i].Hidden && vistab == -1) vistab = i;\n\t\telse if(sheets[i].Hidden == 1 && hidden == -1) hidden = i;\n\t}\n\tif(hidden > vistab) return;\n\twrite_record(ba, 0x0087 /* BrtBeginBookViews */);\n\twrite_record(ba, 0x009E /* BrtBookView */, write_BrtBookView(vistab));\n\t/* 1*(BrtBookView *FRT) */\n\twrite_record(ba, 0x0088 /* BrtEndBookViews */);\n}\n\n/* [MS-XLSB] 2.4.305 BrtCalcProp */\n/*function write_BrtCalcProp(data, o) {\n\tif(!o) o = new_buf(26);\n\to.write_shift(4,0); // force recalc\n\to.write_shift(4,1);\n\to.write_shift(4,0);\n\twrite_Xnum(0, o);\n\to.write_shift(-4, 1023);\n\to.write_shift(1, 0x33);\n\to.write_shift(1, 0x00);\n\treturn o;\n}*/\n\n/* [MS-XLSB] 2.4.646 BrtFileRecover */\n/*function write_BrtFileRecover(data, o) {\n\tif(!o) o = new_buf(1);\n\to.write_shift(1,0);\n\treturn o;\n}*/\n\n/* [MS-XLSB] 2.1.7.61 Workbook */\nfunction write_wb_bin(wb, opts) {\n\tvar ba = buf_array();\n\twrite_record(ba, 0x0083 /* BrtBeginBook */);\n\twrite_record(ba, 0x0080 /* BrtFileVersion */, write_BrtFileVersion());\n\t/* [[BrtFileSharingIso] BrtFileSharing] */\n\twrite_record(ba, 0x0099 /* BrtWbProp */, write_BrtWbProp(wb.Workbook && wb.Workbook.WBProps || null));\n\t/* [ACABSPATH] */\n\t/* [[BrtBookProtectionIso] BrtBookProtection] */\n\twrite_BOOKVIEWS(ba, wb, opts);\n\twrite_BUNDLESHS(ba, wb, opts);\n\t/* [FNGROUP] */\n\t/* [EXTERNALS] */\n\t/* *BrtName */\n\t/* write_record(ba, 0x009D BrtCalcProp, write_BrtCalcProp()); */\n\t/* [BrtOleSize] */\n\t/* *(BrtUserBookView *FRT) */\n\t/* [PIVOTCACHEIDS] */\n\t/* [BrtWbFactoid] */\n\t/* [SMARTTAGTYPES] */\n\t/* [BrtWebOpt] */\n\t/* write_record(ba, 0x009B BrtFileRecover, write_BrtFileRecover()); */\n\t/* [WEBPUBITEMS] */\n\t/* [CRERRS] */\n\t/* FRTWORKBOOK */\n\twrite_record(ba, 0x0084 /* BrtEndBook */);\n\n\treturn ba.end();\n}\nfunction parse_wb(data, name/*:string*/, opts)/*:WorkbookFile*/ {\n\tif(name.slice(-4)===\".bin\") return parse_wb_bin((data/*:any*/), opts);\n\treturn parse_wb_xml((data/*:any*/), opts);\n}\n\nfunction parse_ws(data, name/*:string*/, idx/*:number*/, opts, rels, wb, themes, styles)/*:Worksheet*/ {\n\tif(name.slice(-4)===\".bin\") return parse_ws_bin((data/*:any*/), opts, idx, rels, wb, themes, styles);\n\treturn parse_ws_xml((data/*:any*/), opts, idx, rels, wb, themes, styles);\n}\n\nfunction parse_cs(data, name/*:string*/, idx/*:number*/, opts, rels, wb, themes, styles)/*:Worksheet*/ {\n\tif(name.slice(-4)===\".bin\") return parse_cs_bin((data/*:any*/), opts, idx, rels, wb, themes, styles);\n\treturn parse_cs_xml((data/*:any*/), opts, idx, rels, wb, themes, styles);\n}\n\nfunction parse_ms(data, name/*:string*/, idx/*:number*/, opts, rels, wb, themes, styles)/*:Worksheet*/ {\n\tif(name.slice(-4)===\".bin\") return parse_ms_bin((data/*:any*/), opts, idx, rels, wb, themes, styles);\n\treturn parse_ms_xml((data/*:any*/), opts, idx, rels, wb, themes, styles);\n}\n\nfunction parse_ds(data, name/*:string*/, idx/*:number*/, opts, rels, wb, themes, styles)/*:Worksheet*/ {\n\tif(name.slice(-4)===\".bin\") return parse_ds_bin((data/*:any*/), opts, idx, rels, wb, themes, styles);\n\treturn parse_ds_xml((data/*:any*/), opts, idx, rels, wb, themes, styles);\n}\n\nfunction parse_sty(data, name/*:string*/, themes, opts) {\n\tif(name.slice(-4)===\".bin\") return parse_sty_bin((data/*:any*/), themes, opts);\n\treturn parse_sty_xml((data/*:any*/), themes, opts);\n}\n\nfunction parse_theme(data/*:string*/, name/*:string*/, opts) {\n\treturn parse_theme_xml(data, opts);\n}\n\nfunction parse_sst(data, name/*:string*/, opts)/*:SST*/ {\n\tif(name.slice(-4)===\".bin\") return parse_sst_bin((data/*:any*/), opts);\n\treturn parse_sst_xml((data/*:any*/), opts);\n}\n\nfunction parse_cmnt(data, name/*:string*/, opts)/*:Array<RawComment>*/ {\n\tif(name.slice(-4)===\".bin\") return parse_comments_bin((data/*:any*/), opts);\n\treturn parse_comments_xml((data/*:any*/), opts);\n}\n\nfunction parse_cc(data, name/*:string*/, opts) {\n\tif(name.slice(-4)===\".bin\") return parse_cc_bin((data/*:any*/), name, opts);\n\treturn parse_cc_xml((data/*:any*/), name, opts);\n}\n\nfunction parse_xlink(data, rel, name/*:string*/, opts) {\n\tif(name.slice(-4)===\".bin\") return parse_xlink_bin((data/*:any*/), rel, name, opts);\n\treturn parse_xlink_xml((data/*:any*/), rel, name, opts);\n}\n\nfunction parse_xlmeta(data, name/*:string*/, opts) {\n\tif(name.slice(-4)===\".bin\") return parse_xlmeta_bin((data/*:any*/), name, opts);\n\treturn parse_xlmeta_xml((data/*:any*/), name, opts);\n}\n\nfunction write_wb(wb, name/*:string*/, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_wb_bin : write_wb_xml)(wb, opts);\n}\n\nfunction write_ws(data/*:number*/, name/*:string*/, opts, wb/*:Workbook*/, rels) {\n\treturn (name.slice(-4)===\".bin\" ? write_ws_bin : write_ws_xml)(data, opts, wb, rels);\n}\n\n// eslint-disable-next-line no-unused-vars\nfunction write_cs(data/*:number*/, name/*:string*/, opts, wb/*:Workbook*/, rels) {\n\treturn (name.slice(-4)===\".bin\" ? write_cs_bin : write_cs_xml)(data, opts, wb, rels);\n}\n\nfunction write_sty(data, name/*:string*/, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_sty_bin : write_sty_xml)(data, opts);\n}\n\nfunction write_sst(data/*:SST*/, name/*:string*/, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_sst_bin : write_sst_xml)(data, opts);\n}\n\nfunction write_cmnt(data/*:Array<any>*/, name/*:string*/, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_comments_bin : write_comments_xml)(data, opts);\n}\n/*\nfunction write_cc(data, name:string, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_cc_bin : write_cc_xml)(data, opts);\n}\n*/\n\nfunction write_xlmeta(name/*:string*/) {\n\treturn (name.slice(-4)===\".bin\" ? write_xlmeta_bin : write_xlmeta_xml)();\n}\nvar attregexg2=/([\\w:]+)=((?:\")([^\"]*)(?:\")|(?:')([^']*)(?:'))/g;\nvar attregex2=/([\\w:]+)=((?:\")(?:[^\"]*)(?:\")|(?:')(?:[^']*)(?:'))/;\nfunction xlml_parsexmltag(tag/*:string*/, skip_root/*:?boolean*/) {\n\tvar words = tag.split(/\\s+/);\n\tvar z/*:any*/ = ([]/*:any*/); if(!skip_root) z[0] = words[0];\n\tif(words.length === 1) return z;\n\tvar m = tag.match(attregexg2), y, j, w, i;\n\tif(m) for(i = 0; i != m.length; ++i) {\n\t\ty = m[i].match(attregex2);\n/*:: if(!y || !y[2]) continue; */\n\t\tif((j=y[1].indexOf(\":\")) === -1) z[y[1]] = y[2].slice(1,y[2].length-1);\n\t\telse {\n\t\t\tif(y[1].slice(0,6) === \"xmlns:\") w = \"xmlns\"+y[1].slice(6);\n\t\t\telse w = y[1].slice(j+1);\n\t\t\tz[w] = y[2].slice(1,y[2].length-1);\n\t\t}\n\t}\n\treturn z;\n}\nfunction xlml_parsexmltagobj(tag/*:string*/) {\n\tvar words = tag.split(/\\s+/);\n\tvar z = {};\n\tif(words.length === 1) return z;\n\tvar m = tag.match(attregexg2), y, j, w, i;\n\tif(m) for(i = 0; i != m.length; ++i) {\n\t\ty = m[i].match(attregex2);\n/*:: if(!y || !y[2]) continue; */\n\t\tif((j=y[1].indexOf(\":\")) === -1) z[y[1]] = y[2].slice(1,y[2].length-1);\n\t\telse {\n\t\t\tif(y[1].slice(0,6) === \"xmlns:\") w = \"xmlns\"+y[1].slice(6);\n\t\t\telse w = y[1].slice(j+1);\n\t\t\tz[w] = y[2].slice(1,y[2].length-1);\n\t\t}\n\t}\n\treturn z;\n}\n\n// ----\n\n/* map from xlml named formats to SSF TODO: localize */\nvar XLMLFormatMap/*: {[string]:string}*/;\n\nfunction xlml_format(format, value)/*:string*/ {\n\tvar fmt = XLMLFormatMap[format] || unescapexml(format);\n\tif(fmt === \"General\") return SSF_general(value);\n\treturn SSF_format(fmt, value);\n}\n\nfunction xlml_set_custprop(Custprops, key, cp, val/*:string*/) {\n\tvar oval/*:any*/ = val;\n\tswitch((cp[0].match(/dt:dt=\"([\\w.]+)\"/)||[\"\",\"\"])[1]) {\n\t\tcase \"boolean\": oval = parsexmlbool(val); break;\n\t\tcase \"i2\": case \"int\": oval = parseInt(val, 10); break;\n\t\tcase \"r4\": case \"float\": oval = parseFloat(val); break;\n\t\tcase \"date\": case \"dateTime.tz\": oval = parseDate(val); break;\n\t\tcase \"i8\": case \"string\": case \"fixed\": case \"uuid\": case \"bin.base64\": break;\n\t\tdefault: throw new Error(\"bad custprop:\" + cp[0]);\n\t}\n\tCustprops[unescapexml(key)] = oval;\n}\n\nfunction safe_format_xlml(cell/*:Cell*/, nf, o) {\n\tif(cell.t === 'z') return;\n\tif(!o || o.cellText !== false) try {\n\t\tif(cell.t === 'e') { cell.w = cell.w || BErr[cell.v]; }\n\t\telse if(nf === \"General\") {\n\t\t\tif(cell.t === 'n') {\n\t\t\t\tif((cell.v|0) === cell.v) cell.w = cell.v.toString(10);\n\t\t\t\telse cell.w = SSF_general_num(cell.v);\n\t\t\t}\n\t\t\telse cell.w = SSF_general(cell.v);\n\t\t}\n\t\telse cell.w = xlml_format(nf||\"General\", cell.v);\n\t} catch(e) { if(o.WTF) throw e; }\n\ttry {\n\t\tvar z = XLMLFormatMap[nf]||nf||\"General\";\n\t\tif(o.cellNF) cell.z = z;\n\t\tif(o.cellDates && cell.t == 'n' && fmt_is_date(z)) {\n\t\t\tvar _d = SSF_parse_date_code(cell.v); if(_d) { cell.t = 'd'; cell.v = new Date(_d.y, _d.m-1,_d.d,_d.H,_d.M,_d.S,_d.u); }\n\t\t}\n\t} catch(e) { if(o.WTF) throw e; }\n}\n\nfunction process_style_xlml(styles, stag, opts) {\n\tif(opts.cellStyles) {\n\t\tif(stag.Interior) {\n\t\t\tvar I = stag.Interior;\n\t\t\tif(I.Pattern) I.patternType = XLMLPatternTypeMap[I.Pattern] || I.Pattern;\n\t\t}\n\t}\n\tstyles[stag.ID] = stag;\n}\n\n/* TODO: there must exist some form of OSP-blessed spec */\nfunction parse_xlml_data(xml, ss, data, cell/*:any*/, base, styles, csty, row, arrayf, o) {\n\tvar nf = \"General\", sid = cell.StyleID, S = {}; o = o || {};\n\tvar interiors = [];\n\tvar i = 0;\n\tif(sid === undefined && row) sid = row.StyleID;\n\tif(sid === undefined && csty) sid = csty.StyleID;\n\twhile(styles[sid] !== undefined) {\n\t\tif(styles[sid].nf) nf = styles[sid].nf;\n\t\tif(styles[sid].Interior) interiors.push(styles[sid].Interior);\n\t\tif(!styles[sid].Parent) break;\n\t\tsid = styles[sid].Parent;\n\t}\n\tswitch(data.Type) {\n\t\tcase 'Boolean':\n\t\t\tcell.t = 'b';\n\t\t\tcell.v = parsexmlbool(xml);\n\t\t\tbreak;\n\t\tcase 'String':\n\t\t\tcell.t = 's'; cell.r = xlml_fixstr(unescapexml(xml));\n\t\t\tcell.v = (xml.indexOf(\"<\") > -1 ? unescapexml(ss||xml).replace(/<.*?>/g, \"\") : cell.r); // todo: BR etc\n\t\t\tbreak;\n\t\tcase 'DateTime':\n\t\t\tif(xml.slice(-1) != \"Z\") xml += \"Z\";\n\t\t\tcell.v = (parseDate(xml) - new Date(Date.UTC(1899, 11, 30))) / (24 * 60 * 60 * 1000);\n\t\t\tif(cell.v !== cell.v) cell.v = unescapexml(xml);\n\t\t\telse if(cell.v<60) cell.v = cell.v -1;\n\t\t\tif(!nf || nf == \"General\") nf = \"yyyy-mm-dd\";\n\t\t\t/* falls through */\n\t\tcase 'Number':\n\t\t\tif(cell.v === undefined) cell.v=+xml;\n\t\t\tif(!cell.t) cell.t = 'n';\n\t\t\tbreak;\n\t\tcase 'Error': cell.t = 'e'; cell.v = RBErr[xml]; if(o.cellText !== false) cell.w = xml; break;\n\t\tdefault:\n\t\t\tif(xml == \"\" && ss == \"\") { cell.t = 'z'; }\n\t\t\telse { cell.t = 's'; cell.v = xlml_fixstr(ss||xml); }\n\t\t\tbreak;\n\t}\n\tsafe_format_xlml(cell, nf, o);\n\tif(o.cellFormula !== false) {\n\t\tif(cell.Formula) {\n\t\t\tvar fstr = unescapexml(cell.Formula);\n\t\t\t/* strictly speaking, the leading = is required but some writers omit */\n\t\t\tif(fstr.charCodeAt(0) == 61 /* = */) fstr = fstr.slice(1);\n\t\t\tcell.f = rc_to_a1(fstr, base);\n\t\t\tdelete cell.Formula;\n\t\t\tif(cell.ArrayRange == \"RC\") cell.F = rc_to_a1(\"RC:RC\", base);\n\t\t\telse if(cell.ArrayRange) {\n\t\t\t\tcell.F = rc_to_a1(cell.ArrayRange, base);\n\t\t\t\tarrayf.push([safe_decode_range(cell.F), cell.F]);\n\t\t\t}\n\t\t} else {\n\t\t\tfor(i = 0; i < arrayf.length; ++i)\n\t\t\t\tif(base.r >= arrayf[i][0].s.r && base.r <= arrayf[i][0].e.r)\n\t\t\t\t\tif(base.c >= arrayf[i][0].s.c && base.c <= arrayf[i][0].e.c)\n\t\t\t\t\t\tcell.F = arrayf[i][1];\n\t\t}\n\t}\n\tif(o.cellStyles) {\n\t\tinteriors.forEach(function(x) {\n\t\t\tif(!S.patternType && x.patternType) S.patternType = x.patternType;\n\t\t});\n\t\tcell.s = S;\n\t}\n\tif(cell.StyleID !== undefined) cell.ixfe = cell.StyleID;\n}\n\nfunction xlml_clean_comment(comment/*:any*/) {\n\tcomment.t = comment.v || \"\";\n\tcomment.t = comment.t.replace(/\\r\\n/g,\"\\n\").replace(/\\r/g,\"\\n\");\n\tcomment.v = comment.w = comment.ixfe = undefined;\n}\n\n/* TODO: Everything */\nfunction parse_xlml_xml(d, _opts)/*:Workbook*/ {\n\tvar opts = _opts || {};\n\tmake_ssf();\n\tvar str = debom(xlml_normalize(d));\n\tif(opts.type == 'binary' || opts.type == 'array' || opts.type == 'base64') {\n\t\tif(typeof $cptable !== 'undefined') str = $cptable.utils.decode(65001, char_codes(str));\n\t\telse str = utf8read(str);\n\t}\n\tvar opening = str.slice(0, 1024).toLowerCase(), ishtml = false;\n\topening = opening.replace(/\".*?\"/g, \"\");\n\tif((opening.indexOf(\">\") & 1023) > Math.min((opening.indexOf(\",\") & 1023), (opening.indexOf(\";\")&1023))) { var _o = dup(opts); _o.type = \"string\"; return PRN.to_workbook(str, _o); }\n\tif(opening.indexOf(\"<?xml\") == -1) [\"html\", \"table\", \"head\", \"meta\", \"script\", \"style\", \"div\"].forEach(function(tag) { if(opening.indexOf(\"<\" + tag) >= 0) ishtml = true; });\n\tif(ishtml) return html_to_workbook(str, opts);\n\n\tXLMLFormatMap = ({\n\t\t\"General Number\": \"General\",\n\t\t\"General Date\": table_fmt[22],\n\t\t\"Long Date\": \"dddd, mmmm dd, yyyy\",\n\t\t\"Medium Date\": table_fmt[15],\n\t\t\"Short Date\": table_fmt[14],\n\t\t\"Long Time\": table_fmt[19],\n\t\t\"Medium Time\": table_fmt[18],\n\t\t\"Short Time\": table_fmt[20],\n\t\t\"Currency\": '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\t\t\"Fixed\": table_fmt[2],\n\t\t\"Standard\": table_fmt[4],\n\t\t\"Percent\": table_fmt[10],\n\t\t\"Scientific\": table_fmt[11],\n\t\t\"Yes/No\": '\"Yes\";\"Yes\";\"No\";@',\n\t\t\"True/False\": '\"True\";\"True\";\"False\";@',\n\t\t\"On/Off\": '\"Yes\";\"Yes\";\"No\";@'\n\t}/*:any*/);\n\n\n\tvar Rn;\n\tvar state = [], tmp;\n\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\tvar sheets = {}, sheetnames/*:Array<string>*/ = [], cursheet/*:Worksheet*/ = (opts.dense ? [] : {}), sheetname = \"\";\n\tvar cell = ({}/*:any*/), row = {};// eslint-disable-line no-unused-vars\n\tvar dtag = xlml_parsexmltag('<Data ss:Type=\"String\">'), didx = 0;\n\tvar c = 0, r = 0;\n\tvar refguess/*:Range*/ = {s: {r:2000000, c:2000000}, e: {r:0, c:0} };\n\tvar styles = {}, stag = {};\n\tvar ss = \"\", fidx = 0;\n\tvar merges/*:Array<Range>*/ = [];\n\tvar Props = {}, Custprops = {}, pidx = 0, cp = [];\n\tvar comments/*:Array<Comment>*/ = [], comment/*:Comment*/ = ({}/*:any*/);\n\tvar cstys = [], csty, seencol = false;\n\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\tvar rowinfo/*:Array<RowInfo>*/ = [], rowobj = {}, cc = 0, rr = 0;\n\tvar Workbook/*:WBWBProps*/ = ({ Sheets:[], WBProps:{date1904:false} }/*:any*/), wsprops = {};\n\txlmlregex.lastIndex = 0;\n\tstr = str.replace(/<!--([\\s\\S]*?)-->/mg,\"\");\n\tvar raw_Rn3 = \"\";\n\twhile((Rn = xlmlregex.exec(str))) switch((Rn[3] = (raw_Rn3 = Rn[3]).toLowerCase())) {\n\t\tcase 'data' /*case 'Data'*/:\n\t\t\tif(raw_Rn3 == \"data\") {\n\t\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], true]);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif(state[state.length-1][1]) break;\n\t\t\tif(Rn[1]==='/') parse_xlml_data(str.slice(didx, Rn.index), ss, dtag, state[state.length-1][0]==/*\"Comment\"*/\"comment\"?comment:cell, {c:c,r:r}, styles, cstys[c], row, arrayf, opts);\n\t\t\telse { ss = \"\"; dtag = xlml_parsexmltag(Rn[0]); didx = Rn.index + Rn[0].length; }\n\t\t\tbreak;\n\t\tcase 'cell' /*case 'Cell'*/:\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif(comments.length > 0) cell.c = comments;\n\t\t\t\tif((!opts.sheetRows || opts.sheetRows > r) && cell.v !== undefined) {\n\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\tif(!cursheet[r]) cursheet[r] = [];\n\t\t\t\t\t\tcursheet[r][c] = cell;\n\t\t\t\t\t} else cursheet[encode_col(c) + encode_row(r)] = cell;\n\t\t\t\t}\n\t\t\t\tif(cell.HRef) {\n\t\t\t\t\tcell.l = ({Target:unescapexml(cell.HRef)}/*:any*/);\n\t\t\t\t\tif(cell.HRefScreenTip) cell.l.Tooltip = cell.HRefScreenTip;\n\t\t\t\t\tdelete cell.HRef; delete cell.HRefScreenTip;\n\t\t\t\t}\n\t\t\t\tif(cell.MergeAcross || cell.MergeDown) {\n\t\t\t\t\tcc = c + (parseInt(cell.MergeAcross,10)|0);\n\t\t\t\t\trr = r + (parseInt(cell.MergeDown,10)|0);\n\t\t\t\t\tmerges.push({s:{c:c,r:r},e:{c:cc,r:rr}});\n\t\t\t\t}\n\t\t\t\tif(!opts.sheetStubs) { if(cell.MergeAcross) c = cc + 1; else ++c; }\n\t\t\t\telse if(cell.MergeAcross || cell.MergeDown) {\n\t\t\t\t\t/*:: if(!cc) cc = 0; if(!rr) rr = 0; */\n\t\t\t\t\tfor(var cma = c; cma <= cc; ++cma) {\n\t\t\t\t\t\tfor(var cmd = r; cmd <= rr; ++cmd) {\n\t\t\t\t\t\t\tif(cma > c || cmd > r) {\n\t\t\t\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\t\t\t\tif(!cursheet[cmd]) cursheet[cmd] = [];\n\t\t\t\t\t\t\t\t\tcursheet[cmd][cma] = {t:'z'};\n\t\t\t\t\t\t\t\t} else cursheet[encode_col(cma) + encode_row(cmd)] = {t:'z'};\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tc = cc + 1;\n\t\t\t\t}\n\t\t\t\telse ++c;\n\t\t\t} else {\n\t\t\t\tcell = xlml_parsexmltagobj(Rn[0]);\n\t\t\t\tif(cell.Index) c = +cell.Index - 1;\n\t\t\t\tif(c < refguess.s.c) refguess.s.c = c;\n\t\t\t\tif(c > refguess.e.c) refguess.e.c = c;\n\t\t\t\tif(Rn[0].slice(-2) === \"/>\") ++c;\n\t\t\t\tcomments = [];\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 'row' /*case 'Row'*/:\n\t\t\tif(Rn[1]==='/' || Rn[0].slice(-2) === \"/>\") {\n\t\t\t\tif(r < refguess.s.r) refguess.s.r = r;\n\t\t\t\tif(r > refguess.e.r) refguess.e.r = r;\n\t\t\t\tif(Rn[0].slice(-2) === \"/>\") {\n\t\t\t\t\trow = xlml_parsexmltag(Rn[0]);\n\t\t\t\t\tif(row.Index) r = +row.Index - 1;\n\t\t\t\t}\n\t\t\t\tc = 0; ++r;\n\t\t\t} else {\n\t\t\t\trow = xlml_parsexmltag(Rn[0]);\n\t\t\t\tif(row.Index) r = +row.Index - 1;\n\t\t\t\trowobj = {};\n\t\t\t\tif(row.AutoFitHeight == \"0\" || row.Height) {\n\t\t\t\t\trowobj.hpx = parseInt(row.Height, 10); rowobj.hpt = px2pt(rowobj.hpx);\n\t\t\t\t\trowinfo[r] = rowobj;\n\t\t\t\t}\n\t\t\t\tif(row.Hidden == \"1\") { rowobj.hidden = true; rowinfo[r] = rowobj; }\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 'worksheet' /*case 'Worksheet'*/: /* TODO: read range from FullRows/FullColumns */\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));\n\t\t\t\tsheetnames.push(sheetname);\n\t\t\t\tif(refguess.s.r <= refguess.e.r && refguess.s.c <= refguess.e.c) {\n\t\t\t\t\tcursheet[\"!ref\"] = encode_range(refguess);\n\t\t\t\t\tif(opts.sheetRows && opts.sheetRows <= refguess.e.r) {\n\t\t\t\t\t\tcursheet[\"!fullref\"] = cursheet[\"!ref\"];\n\t\t\t\t\t\trefguess.e.r = opts.sheetRows - 1;\n\t\t\t\t\t\tcursheet[\"!ref\"] = encode_range(refguess);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif(merges.length) cursheet[\"!merges\"] = merges;\n\t\t\t\tif(cstys.length > 0) cursheet[\"!cols\"] = cstys;\n\t\t\t\tif(rowinfo.length > 0) cursheet[\"!rows\"] = rowinfo;\n\t\t\t\tsheets[sheetname] = cursheet;\n\t\t\t} else {\n\t\t\t\trefguess = {s: {r:2000000, c:2000000}, e: {r:0, c:0} };\n\t\t\t\tr = c = 0;\n\t\t\t\tstate.push([Rn[3], false]);\n\t\t\t\ttmp = xlml_parsexmltag(Rn[0]);\n\t\t\t\tsheetname = unescapexml(tmp.Name);\n\t\t\t\tcursheet = (opts.dense ? [] : {});\n\t\t\t\tmerges = [];\n\t\t\t\tarrayf = [];\n\t\t\t\trowinfo = [];\n\t\t\t\twsprops = {name:sheetname, Hidden:0};\n\t\t\t\tWorkbook.Sheets.push(wsprops);\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 'table' /*case 'Table'*/:\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\telse if(Rn[0].slice(-2) == \"/>\") break;\n\t\t\telse {\n\t\t\t\tstate.push([Rn[3], false]);\n\t\t\t\tcstys = []; seencol = false;\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'style' /*case 'Style'*/:\n\t\t\tif(Rn[1]==='/') process_style_xlml(styles, stag, opts);\n\t\t\telse stag = xlml_parsexmltag(Rn[0]);\n\t\t\tbreak;\n\n\t\tcase 'numberformat' /*case 'NumberFormat'*/:\n\t\t\tstag.nf = unescapexml(xlml_parsexmltag(Rn[0]).Format || \"General\");\n\t\t\tif(XLMLFormatMap[stag.nf]) stag.nf = XLMLFormatMap[stag.nf];\n\t\t\tfor(var ssfidx = 0; ssfidx != 0x188; ++ssfidx) if(table_fmt[ssfidx] == stag.nf) break;\n\t\t\tif(ssfidx == 0x188) for(ssfidx = 0x39; ssfidx != 0x188; ++ssfidx) if(table_fmt[ssfidx] == null) { SSF_load(stag.nf, ssfidx); break; }\n\t\t\tbreak;\n\n\t\tcase 'column' /*case 'Column'*/:\n\t\t\tif(state[state.length-1][0] !== /*'Table'*/'table') break;\n\t\t\tcsty = xlml_parsexmltag(Rn[0]);\n\t\t\tif(csty.Hidden) { csty.hidden = true; delete csty.Hidden; }\n\t\t\tif(csty.Width) csty.wpx = parseInt(csty.Width, 10);\n\t\t\tif(!seencol && csty.wpx > 10) {\n\t\t\t\tseencol = true; MDW = DEF_MDW; //find_mdw_wpx(csty.wpx);\n\t\t\t\tfor(var _col = 0; _col < cstys.length; ++_col) if(cstys[_col]) process_col(cstys[_col]);\n\t\t\t}\n\t\t\tif(seencol) process_col(csty);\n\t\t\tcstys[(csty.Index-1||cstys.length)] = csty;\n\t\t\tfor(var i = 0; i < +csty.Span; ++i) cstys[cstys.length] = dup(csty);\n\t\t\tbreak;\n\n\t\tcase 'namedrange' /*case 'NamedRange'*/:\n\t\t\tif(Rn[1]==='/') break;\n\t\t\tif(!Workbook.Names) Workbook.Names = [];\n\t\t\tvar _NamedRange = parsexmltag(Rn[0]);\n\t\t\tvar _DefinedName/*:DefinedName*/ = ({\n\t\t\t\tName: _NamedRange.Name,\n\t\t\t\tRef: rc_to_a1(_NamedRange.RefersTo.slice(1), {r:0, c:0})\n\t\t\t}/*:any*/);\n\t\t\tif(Workbook.Sheets.length>0) _DefinedName.Sheet=Workbook.Sheets.length-1;\n\t\t\t/*:: if(Workbook.Names) */Workbook.Names.push(_DefinedName);\n\t\t\tbreak;\n\n\t\tcase 'namedcell' /*case 'NamedCell'*/: break;\n\t\tcase 'b' /*case 'B'*/: break;\n\t\tcase 'i' /*case 'I'*/: break;\n\t\tcase 'u' /*case 'U'*/: break;\n\t\tcase 's' /*case 'S'*/: break;\n\t\tcase 'em' /*case 'EM'*/: break;\n\t\tcase 'h2' /*case 'H2'*/: break;\n\t\tcase 'h3' /*case 'H3'*/: break;\n\t\tcase 'sub' /*case 'Sub'*/: break;\n\t\tcase 'sup' /*case 'Sup'*/: break;\n\t\tcase 'span' /*case 'Span'*/: break;\n\t\tcase 'alignment' /*case 'Alignment'*/:\n\t\t\tbreak;\n\t\tcase 'borders' /*case 'Borders'*/: break;\n\t\tcase 'border' /*case 'Border'*/: break;\n\t\tcase 'font' /*case 'Font'*/:\n\t\t\tif(Rn[0].slice(-2) === \"/>\") break;\n\t\t\telse if(Rn[1]===\"/\") ss += str.slice(fidx, Rn.index);\n\t\t\telse fidx = Rn.index + Rn[0].length;\n\t\t\tbreak;\n\t\tcase 'interior' /*case 'Interior'*/:\n\t\t\tif(!opts.cellStyles) break;\n\t\t\tstag.Interior = xlml_parsexmltag(Rn[0]);\n\t\t\tbreak;\n\t\tcase 'protection' /*case 'Protection'*/: break;\n\n\t\tcase 'author' /*case 'Author'*/:\n\t\tcase 'title' /*case 'Title'*/:\n\t\tcase 'description' /*case 'Description'*/:\n\t\tcase 'created' /*case 'Created'*/:\n\t\tcase 'keywords' /*case 'Keywords'*/:\n\t\tcase 'subject' /*case 'Subject'*/:\n\t\tcase 'category' /*case 'Category'*/:\n\t\tcase 'company' /*case 'Company'*/:\n\t\tcase 'lastauthor' /*case 'LastAuthor'*/:\n\t\tcase 'lastsaved' /*case 'LastSaved'*/:\n\t\tcase 'lastprinted' /*case 'LastPrinted'*/:\n\t\tcase 'version' /*case 'Version'*/:\n\t\tcase 'revision' /*case 'Revision'*/:\n\t\tcase 'totaltime' /*case 'TotalTime'*/:\n\t\tcase 'hyperlinkbase' /*case 'HyperlinkBase'*/:\n\t\tcase 'manager' /*case 'Manager'*/:\n\t\tcase 'contentstatus' /*case 'ContentStatus'*/:\n\t\tcase 'identifier' /*case 'Identifier'*/:\n\t\tcase 'language' /*case 'Language'*/:\n\t\tcase 'appname' /*case 'AppName'*/:\n\t\t\tif(Rn[0].slice(-2) === \"/>\") break;\n\t\t\telse if(Rn[1]===\"/\") xlml_set_prop(Props, raw_Rn3, str.slice(pidx, Rn.index));\n\t\t\telse pidx = Rn.index + Rn[0].length;\n\t\t\tbreak;\n\t\tcase 'paragraphs' /*case 'Paragraphs'*/: break;\n\n\t\tcase 'styles' /*case 'Styles'*/:\n\t\tcase 'workbook' /*case 'Workbook'*/:\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\telse state.push([Rn[3], false]);\n\t\t\tbreak;\n\n\t\tcase 'comment' /*case 'Comment'*/:\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));\n\t\t\t\txlml_clean_comment(comment);\n\t\t\t\tcomments.push(comment);\n\t\t\t} else {\n\t\t\t\tstate.push([Rn[3], false]);\n\t\t\t\ttmp = xlml_parsexmltag(Rn[0]);\n\t\t\t\tcomment = ({a:tmp.Author}/*:any*/);\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'autofilter' /*case 'AutoFilter'*/:\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') {\n\t\t\t\tvar AutoFilter = xlml_parsexmltag(Rn[0]);\n\t\t\t\tcursheet['!autofilter'] = { ref:rc_to_a1(AutoFilter.Range).replace(/\\$/g,\"\") };\n\t\t\t\tstate.push([Rn[3], true]);\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'name' /*case 'Name'*/: break;\n\n\t\tcase 'datavalidation' /*case 'DataValidation'*/:\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));\n\t\t\t} else {\n\t\t\t\tif(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], true]);\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'pixelsperinch' /*case 'PixelsPerInch'*/:\n\t\t\tbreak;\n\t\tcase 'componentoptions' /*case 'ComponentOptions'*/:\n\t\tcase 'documentproperties' /*case 'DocumentProperties'*/:\n\t\tcase 'customdocumentproperties' /*case 'CustomDocumentProperties'*/:\n\t\tcase 'officedocumentsettings' /*case 'OfficeDocumentSettings'*/:\n\t\tcase 'pivottable' /*case 'PivotTable'*/:\n\t\tcase 'pivotcache' /*case 'PivotCache'*/:\n\t\tcase 'names' /*case 'Names'*/:\n\t\tcase 'mapinfo' /*case 'MapInfo'*/:\n\t\tcase 'pagebreaks' /*case 'PageBreaks'*/:\n\t\tcase 'querytable' /*case 'QueryTable'*/:\n\t\tcase 'sorting' /*case 'Sorting'*/:\n\t\tcase 'schema' /*case 'Schema'*/: //case 'data' /*case 'data'*/:\n\t\tcase 'conditionalformatting' /*case 'ConditionalFormatting'*/:\n\t\tcase 'smarttagtype' /*case 'SmartTagType'*/:\n\t\tcase 'smarttags' /*case 'SmartTags'*/:\n\t\tcase 'excelworkbook' /*case 'ExcelWorkbook'*/:\n\t\tcase 'workbookoptions' /*case 'WorkbookOptions'*/:\n\t\tcase 'worksheetoptions' /*case 'WorksheetOptions'*/:\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], true]);\n\t\t\tbreak;\n\n\t\tcase 'null' /*case 'Null'*/: break;\n\n\t\tdefault:\n\t\t\t/* FODS file root is <office:document> */\n\t\t\tif(state.length == 0 && Rn[3] == \"document\") return parse_fods(str, opts);\n\t\t\t/* UOS file root is <uof:UOF> */\n\t\t\tif(state.length == 0 && Rn[3] == \"uof\"/*\"UOF\"*/) return parse_fods(str, opts);\n\n\t\t\tvar seen = true;\n\t\t\tswitch(state[state.length-1][0]) {\n\t\t\t\t/* OfficeDocumentSettings */\n\t\t\t\tcase 'officedocumentsettings' /*case 'OfficeDocumentSettings'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'allowpng' /*case 'AllowPNG'*/: break;\n\t\t\t\t\tcase 'removepersonalinformation' /*case 'RemovePersonalInformation'*/: break;\n\t\t\t\t\tcase 'downloadcomponents' /*case 'DownloadComponents'*/: break;\n\t\t\t\t\tcase 'locationofcomponents' /*case 'LocationOfComponents'*/: break;\n\t\t\t\t\tcase 'colors' /*case 'Colors'*/: break;\n\t\t\t\t\tcase 'color' /*case 'Color'*/: break;\n\t\t\t\t\tcase 'index' /*case 'Index'*/: break;\n\t\t\t\t\tcase 'rgb' /*case 'RGB'*/: break;\n\t\t\t\t\tcase 'targetscreensize' /*case 'TargetScreenSize'*/: break;\n\t\t\t\t\tcase 'readonlyrecommended' /*case 'ReadOnlyRecommended'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* ComponentOptions */\n\t\t\t\tcase 'componentoptions' /*case 'ComponentOptions'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'toolbar' /*case 'Toolbar'*/: break;\n\t\t\t\t\tcase 'hideofficelogo' /*case 'HideOfficeLogo'*/: break;\n\t\t\t\t\tcase 'spreadsheetautofit' /*case 'SpreadsheetAutoFit'*/: break;\n\t\t\t\t\tcase 'label' /*case 'Label'*/: break;\n\t\t\t\t\tcase 'caption' /*case 'Caption'*/: break;\n\t\t\t\t\tcase 'maxheight' /*case 'MaxHeight'*/: break;\n\t\t\t\t\tcase 'maxwidth' /*case 'MaxWidth'*/: break;\n\t\t\t\t\tcase 'nextsheetnumber' /*case 'NextSheetNumber'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* ExcelWorkbook */\n\t\t\t\tcase 'excelworkbook' /*case 'ExcelWorkbook'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'date1904' /*case 'Date1904'*/:\n\t\t\t\t\t\t/*:: if(!Workbook.WBProps) Workbook.WBProps = {}; */\n\t\t\t\t\t\tWorkbook.WBProps.date1904 = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'windowheight' /*case 'WindowHeight'*/: break;\n\t\t\t\t\tcase 'windowwidth' /*case 'WindowWidth'*/: break;\n\t\t\t\t\tcase 'windowtopx' /*case 'WindowTopX'*/: break;\n\t\t\t\t\tcase 'windowtopy' /*case 'WindowTopY'*/: break;\n\t\t\t\t\tcase 'tabratio' /*case 'TabRatio'*/: break;\n\t\t\t\t\tcase 'protectstructure' /*case 'ProtectStructure'*/: break;\n\t\t\t\t\tcase 'protectwindow' /*case 'ProtectWindow'*/: break;\n\t\t\t\t\tcase 'protectwindows' /*case 'ProtectWindows'*/: break;\n\t\t\t\t\tcase 'activesheet' /*case 'ActiveSheet'*/: break;\n\t\t\t\t\tcase 'displayinknotes' /*case 'DisplayInkNotes'*/: break;\n\t\t\t\t\tcase 'firstvisiblesheet' /*case 'FirstVisibleSheet'*/: break;\n\t\t\t\t\tcase 'supbook' /*case 'SupBook'*/: break;\n\t\t\t\t\tcase 'sheetname' /*case 'SheetName'*/: break;\n\t\t\t\t\tcase 'sheetindex' /*case 'SheetIndex'*/: break;\n\t\t\t\t\tcase 'sheetindexfirst' /*case 'SheetIndexFirst'*/: break;\n\t\t\t\t\tcase 'sheetindexlast' /*case 'SheetIndexLast'*/: break;\n\t\t\t\t\tcase 'dll' /*case 'Dll'*/: break;\n\t\t\t\t\tcase 'acceptlabelsinformulas' /*case 'AcceptLabelsInFormulas'*/: break;\n\t\t\t\t\tcase 'donotsavelinkvalues' /*case 'DoNotSaveLinkValues'*/: break;\n\t\t\t\t\tcase 'iteration' /*case 'Iteration'*/: break;\n\t\t\t\t\tcase 'maxiterations' /*case 'MaxIterations'*/: break;\n\t\t\t\t\tcase 'maxchange' /*case 'MaxChange'*/: break;\n\t\t\t\t\tcase 'path' /*case 'Path'*/: break;\n\t\t\t\t\tcase 'xct' /*case 'Xct'*/: break;\n\t\t\t\t\tcase 'count' /*case 'Count'*/: break;\n\t\t\t\t\tcase 'selectedsheets' /*case 'SelectedSheets'*/: break;\n\t\t\t\t\tcase 'calculation' /*case 'Calculation'*/: break;\n\t\t\t\t\tcase 'uncalced' /*case 'Uncalced'*/: break;\n\t\t\t\t\tcase 'startupprompt' /*case 'StartupPrompt'*/: break;\n\t\t\t\t\tcase 'crn' /*case 'Crn'*/: break;\n\t\t\t\t\tcase 'externname' /*case 'ExternName'*/: break;\n\t\t\t\t\tcase 'formula' /*case 'Formula'*/: break;\n\t\t\t\t\tcase 'colfirst' /*case 'ColFirst'*/: break;\n\t\t\t\t\tcase 'collast' /*case 'ColLast'*/: break;\n\t\t\t\t\tcase 'wantadvise' /*case 'WantAdvise'*/: break;\n\t\t\t\t\tcase 'boolean' /*case 'Boolean'*/: break;\n\t\t\t\t\tcase 'error' /*case 'Error'*/: break;\n\t\t\t\t\tcase 'text' /*case 'Text'*/: break;\n\t\t\t\t\tcase 'ole' /*case 'OLE'*/: break;\n\t\t\t\t\tcase 'noautorecover' /*case 'NoAutoRecover'*/: break;\n\t\t\t\t\tcase 'publishobjects' /*case 'PublishObjects'*/: break;\n\t\t\t\t\tcase 'donotcalculatebeforesave' /*case 'DoNotCalculateBeforeSave'*/: break;\n\t\t\t\t\tcase 'number' /*case 'Number'*/: break;\n\t\t\t\t\tcase 'refmoder1c1' /*case 'RefModeR1C1'*/: break;\n\t\t\t\t\tcase 'embedsavesmarttags' /*case 'EmbedSaveSmartTags'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* WorkbookOptions */\n\t\t\t\tcase 'workbookoptions' /*case 'WorkbookOptions'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'owcversion' /*case 'OWCVersion'*/: break;\n\t\t\t\t\tcase 'height' /*case 'Height'*/: break;\n\t\t\t\t\tcase 'width' /*case 'Width'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* WorksheetOptions */\n\t\t\t\tcase 'worksheetoptions' /*case 'WorksheetOptions'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'visible' /*case 'Visible'*/:\n\t\t\t\t\t\tif(Rn[0].slice(-2) === \"/>\"){/* empty */}\n\t\t\t\t\t\telse if(Rn[1]===\"/\") switch(str.slice(pidx, Rn.index)) {\n\t\t\t\t\t\t\tcase \"SheetHidden\": wsprops.Hidden = 1; break;\n\t\t\t\t\t\t\tcase \"SheetVeryHidden\": wsprops.Hidden = 2; break;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse pidx = Rn.index + Rn[0].length;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'header' /*case 'Header'*/:\n\t\t\t\t\t\tif(!cursheet['!margins']) default_margins(cursheet['!margins']={}, 'xlml');\n\t\t\t\t\t\tif(!isNaN(+parsexmltag(Rn[0]).Margin)) cursheet['!margins'].header = +parsexmltag(Rn[0]).Margin;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'footer' /*case 'Footer'*/:\n\t\t\t\t\t\tif(!cursheet['!margins']) default_margins(cursheet['!margins']={}, 'xlml');\n\t\t\t\t\t\tif(!isNaN(+parsexmltag(Rn[0]).Margin)) cursheet['!margins'].footer = +parsexmltag(Rn[0]).Margin;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'pagemargins' /*case 'PageMargins'*/:\n\t\t\t\t\t\tvar pagemargins = parsexmltag(Rn[0]);\n\t\t\t\t\t\tif(!cursheet['!margins']) default_margins(cursheet['!margins']={},'xlml');\n\t\t\t\t\t\tif(!isNaN(+pagemargins.Top)) cursheet['!margins'].top = +pagemargins.Top;\n\t\t\t\t\t\tif(!isNaN(+pagemargins.Left)) cursheet['!margins'].left = +pagemargins.Left;\n\t\t\t\t\t\tif(!isNaN(+pagemargins.Right)) cursheet['!margins'].right = +pagemargins.Right;\n\t\t\t\t\t\tif(!isNaN(+pagemargins.Bottom)) cursheet['!margins'].bottom = +pagemargins.Bottom;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'displayrighttoleft' /*case 'DisplayRightToLeft'*/:\n\t\t\t\t\t\tif(!Workbook.Views) Workbook.Views = [];\n\t\t\t\t\t\tif(!Workbook.Views[0]) Workbook.Views[0] = {};\n\t\t\t\t\t\tWorkbook.Views[0].RTL = true;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'freezepanes' /*case 'FreezePanes'*/: break;\n\t\t\t\t\tcase 'frozennosplit' /*case 'FrozenNoSplit'*/: break;\n\n\t\t\t\t\tcase 'splithorizontal' /*case 'SplitHorizontal'*/:\n\t\t\t\t\tcase 'splitvertical' /*case 'SplitVertical'*/:\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'donotdisplaygridlines' /*case 'DoNotDisplayGridlines'*/:\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'activerow' /*case 'ActiveRow'*/: break;\n\t\t\t\t\tcase 'activecol' /*case 'ActiveCol'*/: break;\n\t\t\t\t\tcase 'toprowbottompane' /*case 'TopRowBottomPane'*/: break;\n\t\t\t\t\tcase 'leftcolumnrightpane' /*case 'LeftColumnRightPane'*/: break;\n\n\t\t\t\t\tcase 'unsynced' /*case 'Unsynced'*/: break;\n\t\t\t\t\tcase 'print' /*case 'Print'*/: break;\n\t\t\t\t\tcase 'printerrors' /*case 'PrintErrors'*/: break;\n\t\t\t\t\tcase 'panes' /*case 'Panes'*/: break;\n\t\t\t\t\tcase 'scale' /*case 'Scale'*/: break;\n\t\t\t\t\tcase 'pane' /*case 'Pane'*/: break;\n\t\t\t\t\tcase 'number' /*case 'Number'*/: break;\n\t\t\t\t\tcase 'layout' /*case 'Layout'*/: break;\n\t\t\t\t\tcase 'pagesetup' /*case 'PageSetup'*/: break;\n\t\t\t\t\tcase 'selected' /*case 'Selected'*/: break;\n\t\t\t\t\tcase 'protectobjects' /*case 'ProtectObjects'*/: break;\n\t\t\t\t\tcase 'enableselection' /*case 'EnableSelection'*/: break;\n\t\t\t\t\tcase 'protectscenarios' /*case 'ProtectScenarios'*/: break;\n\t\t\t\t\tcase 'validprinterinfo' /*case 'ValidPrinterInfo'*/: break;\n\t\t\t\t\tcase 'horizontalresolution' /*case 'HorizontalResolution'*/: break;\n\t\t\t\t\tcase 'verticalresolution' /*case 'VerticalResolution'*/: break;\n\t\t\t\t\tcase 'numberofcopies' /*case 'NumberofCopies'*/: break;\n\t\t\t\t\tcase 'activepane' /*case 'ActivePane'*/: break;\n\t\t\t\t\tcase 'toprowvisible' /*case 'TopRowVisible'*/: break;\n\t\t\t\t\tcase 'leftcolumnvisible' /*case 'LeftColumnVisible'*/: break;\n\t\t\t\t\tcase 'fittopage' /*case 'FitToPage'*/: break;\n\t\t\t\t\tcase 'rangeselection' /*case 'RangeSelection'*/: break;\n\t\t\t\t\tcase 'papersizeindex' /*case 'PaperSizeIndex'*/: break;\n\t\t\t\t\tcase 'pagelayoutzoom' /*case 'PageLayoutZoom'*/: break;\n\t\t\t\t\tcase 'pagebreakzoom' /*case 'PageBreakZoom'*/: break;\n\t\t\t\t\tcase 'filteron' /*case 'FilterOn'*/: break;\n\t\t\t\t\tcase 'fitwidth' /*case 'FitWidth'*/: break;\n\t\t\t\t\tcase 'fitheight' /*case 'FitHeight'*/: break;\n\t\t\t\t\tcase 'commentslayout' /*case 'CommentsLayout'*/: break;\n\t\t\t\t\tcase 'zoom' /*case 'Zoom'*/: break;\n\t\t\t\t\tcase 'lefttoright' /*case 'LeftToRight'*/: break;\n\t\t\t\t\tcase 'gridlines' /*case 'Gridlines'*/: break;\n\t\t\t\t\tcase 'allowsort' /*case 'AllowSort'*/: break;\n\t\t\t\t\tcase 'allowfilter' /*case 'AllowFilter'*/: break;\n\t\t\t\t\tcase 'allowinsertrows' /*case 'AllowInsertRows'*/: break;\n\t\t\t\t\tcase 'allowdeleterows' /*case 'AllowDeleteRows'*/: break;\n\t\t\t\t\tcase 'allowinsertcols' /*case 'AllowInsertCols'*/: break;\n\t\t\t\t\tcase 'allowdeletecols' /*case 'AllowDeleteCols'*/: break;\n\t\t\t\t\tcase 'allowinserthyperlinks' /*case 'AllowInsertHyperlinks'*/: break;\n\t\t\t\t\tcase 'allowformatcells' /*case 'AllowFormatCells'*/: break;\n\t\t\t\t\tcase 'allowsizecols' /*case 'AllowSizeCols'*/: break;\n\t\t\t\t\tcase 'allowsizerows' /*case 'AllowSizeRows'*/: break;\n\t\t\t\t\tcase 'nosummaryrowsbelowdetail' /*case 'NoSummaryRowsBelowDetail'*/:\n\t\t\t\t\t\tif(!cursheet[\"!outline\"]) cursheet[\"!outline\"] = {};\n\t\t\t\t\t\tcursheet[\"!outline\"].above = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'tabcolorindex' /*case 'TabColorIndex'*/: break;\n\t\t\t\t\tcase 'donotdisplayheadings' /*case 'DoNotDisplayHeadings'*/: break;\n\t\t\t\t\tcase 'showpagelayoutzoom' /*case 'ShowPageLayoutZoom'*/: break;\n\t\t\t\t\tcase 'nosummarycolumnsrightdetail' /*case 'NoSummaryColumnsRightDetail'*/:\n\t\t\t\t\t\tif(!cursheet[\"!outline\"]) cursheet[\"!outline\"] = {};\n\t\t\t\t\t\tcursheet[\"!outline\"].left = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'blackandwhite' /*case 'BlackAndWhite'*/: break;\n\t\t\t\t\tcase 'donotdisplayzeros' /*case 'DoNotDisplayZeros'*/: break;\n\t\t\t\t\tcase 'displaypagebreak' /*case 'DisplayPageBreak'*/: break;\n\t\t\t\t\tcase 'rowcolheadings' /*case 'RowColHeadings'*/: break;\n\t\t\t\t\tcase 'donotdisplayoutline' /*case 'DoNotDisplayOutline'*/: break;\n\t\t\t\t\tcase 'noorientation' /*case 'NoOrientation'*/: break;\n\t\t\t\t\tcase 'allowusepivottables' /*case 'AllowUsePivotTables'*/: break;\n\t\t\t\t\tcase 'zeroheight' /*case 'ZeroHeight'*/: break;\n\t\t\t\t\tcase 'viewablerange' /*case 'ViewableRange'*/: break;\n\t\t\t\t\tcase 'selection' /*case 'Selection'*/: break;\n\t\t\t\t\tcase 'protectcontents' /*case 'ProtectContents'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* PivotTable */\n\t\t\t\tcase 'pivottable' /*case 'PivotTable'*/: case 'pivotcache' /*case 'PivotCache'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'immediateitemsondrop' /*case 'ImmediateItemsOnDrop'*/: break;\n\t\t\t\t\tcase 'showpagemultipleitemlabel' /*case 'ShowPageMultipleItemLabel'*/: break;\n\t\t\t\t\tcase 'compactrowindent' /*case 'CompactRowIndent'*/: break;\n\t\t\t\t\tcase 'location' /*case 'Location'*/: break;\n\t\t\t\t\tcase 'pivotfield' /*case 'PivotField'*/: break;\n\t\t\t\t\tcase 'orientation' /*case 'Orientation'*/: break;\n\t\t\t\t\tcase 'layoutform' /*case 'LayoutForm'*/: break;\n\t\t\t\t\tcase 'layoutsubtotallocation' /*case 'LayoutSubtotalLocation'*/: break;\n\t\t\t\t\tcase 'layoutcompactrow' /*case 'LayoutCompactRow'*/: break;\n\t\t\t\t\tcase 'position' /*case 'Position'*/: break;\n\t\t\t\t\tcase 'pivotitem' /*case 'PivotItem'*/: break;\n\t\t\t\t\tcase 'datatype' /*case 'DataType'*/: break;\n\t\t\t\t\tcase 'datafield' /*case 'DataField'*/: break;\n\t\t\t\t\tcase 'sourcename' /*case 'SourceName'*/: break;\n\t\t\t\t\tcase 'parentfield' /*case 'ParentField'*/: break;\n\t\t\t\t\tcase 'ptlineitems' /*case 'PTLineItems'*/: break;\n\t\t\t\t\tcase 'ptlineitem' /*case 'PTLineItem'*/: break;\n\t\t\t\t\tcase 'countofsameitems' /*case 'CountOfSameItems'*/: break;\n\t\t\t\t\tcase 'item' /*case 'Item'*/: break;\n\t\t\t\t\tcase 'itemtype' /*case 'ItemType'*/: break;\n\t\t\t\t\tcase 'ptsource' /*case 'PTSource'*/: break;\n\t\t\t\t\tcase 'cacheindex' /*case 'CacheIndex'*/: break;\n\t\t\t\t\tcase 'consolidationreference' /*case 'ConsolidationReference'*/: break;\n\t\t\t\t\tcase 'filename' /*case 'FileName'*/: break;\n\t\t\t\t\tcase 'reference' /*case 'Reference'*/: break;\n\t\t\t\t\tcase 'nocolumngrand' /*case 'NoColumnGrand'*/: break;\n\t\t\t\t\tcase 'norowgrand' /*case 'NoRowGrand'*/: break;\n\t\t\t\t\tcase 'blanklineafteritems' /*case 'BlankLineAfterItems'*/: break;\n\t\t\t\t\tcase 'hidden' /*case 'Hidden'*/: break;\n\t\t\t\t\tcase 'subtotal' /*case 'Subtotal'*/: break;\n\t\t\t\t\tcase 'basefield' /*case 'BaseField'*/: break;\n\t\t\t\t\tcase 'mapchilditems' /*case 'MapChildItems'*/: break;\n\t\t\t\t\tcase 'function' /*case 'Function'*/: break;\n\t\t\t\t\tcase 'refreshonfileopen' /*case 'RefreshOnFileOpen'*/: break;\n\t\t\t\t\tcase 'printsettitles' /*case 'PrintSetTitles'*/: break;\n\t\t\t\t\tcase 'mergelabels' /*case 'MergeLabels'*/: break;\n\t\t\t\t\tcase 'defaultversion' /*case 'DefaultVersion'*/: break;\n\t\t\t\t\tcase 'refreshname' /*case 'RefreshName'*/: break;\n\t\t\t\t\tcase 'refreshdate' /*case 'RefreshDate'*/: break;\n\t\t\t\t\tcase 'refreshdatecopy' /*case 'RefreshDateCopy'*/: break;\n\t\t\t\t\tcase 'versionlastrefresh' /*case 'VersionLastRefresh'*/: break;\n\t\t\t\t\tcase 'versionlastupdate' /*case 'VersionLastUpdate'*/: break;\n\t\t\t\t\tcase 'versionupdateablemin' /*case 'VersionUpdateableMin'*/: break;\n\t\t\t\t\tcase 'versionrefreshablemin' /*case 'VersionRefreshableMin'*/: break;\n\t\t\t\t\tcase 'calculation' /*case 'Calculation'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* PageBreaks */\n\t\t\t\tcase 'pagebreaks' /*case 'PageBreaks'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'colbreaks' /*case 'ColBreaks'*/: break;\n\t\t\t\t\tcase 'colbreak' /*case 'ColBreak'*/: break;\n\t\t\t\t\tcase 'rowbreaks' /*case 'RowBreaks'*/: break;\n\t\t\t\t\tcase 'rowbreak' /*case 'RowBreak'*/: break;\n\t\t\t\t\tcase 'colstart' /*case 'ColStart'*/: break;\n\t\t\t\t\tcase 'colend' /*case 'ColEnd'*/: break;\n\t\t\t\t\tcase 'rowend' /*case 'RowEnd'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* AutoFilter */\n\t\t\t\tcase 'autofilter' /*case 'AutoFilter'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'autofiltercolumn' /*case 'AutoFilterColumn'*/: break;\n\t\t\t\t\tcase 'autofiltercondition' /*case 'AutoFilterCondition'*/: break;\n\t\t\t\t\tcase 'autofilterand' /*case 'AutoFilterAnd'*/: break;\n\t\t\t\t\tcase 'autofilteror' /*case 'AutoFilterOr'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* QueryTable */\n\t\t\t\tcase 'querytable' /*case 'QueryTable'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'id' /*case 'Id'*/: break;\n\t\t\t\t\tcase 'autoformatfont' /*case 'AutoFormatFont'*/: break;\n\t\t\t\t\tcase 'autoformatpattern' /*case 'AutoFormatPattern'*/: break;\n\t\t\t\t\tcase 'querysource' /*case 'QuerySource'*/: break;\n\t\t\t\t\tcase 'querytype' /*case 'QueryType'*/: break;\n\t\t\t\t\tcase 'enableredirections' /*case 'EnableRedirections'*/: break;\n\t\t\t\t\tcase 'refreshedinxl9' /*case 'RefreshedInXl9'*/: break;\n\t\t\t\t\tcase 'urlstring' /*case 'URLString'*/: break;\n\t\t\t\t\tcase 'htmltables' /*case 'HTMLTables'*/: break;\n\t\t\t\t\tcase 'connection' /*case 'Connection'*/: break;\n\t\t\t\t\tcase 'commandtext' /*case 'CommandText'*/: break;\n\t\t\t\t\tcase 'refreshinfo' /*case 'RefreshInfo'*/: break;\n\t\t\t\t\tcase 'notitles' /*case 'NoTitles'*/: break;\n\t\t\t\t\tcase 'nextid' /*case 'NextId'*/: break;\n\t\t\t\t\tcase 'columninfo' /*case 'ColumnInfo'*/: break;\n\t\t\t\t\tcase 'overwritecells' /*case 'OverwriteCells'*/: break;\n\t\t\t\t\tcase 'donotpromptforfile' /*case 'DoNotPromptForFile'*/: break;\n\t\t\t\t\tcase 'textwizardsettings' /*case 'TextWizardSettings'*/: break;\n\t\t\t\t\tcase 'source' /*case 'Source'*/: break;\n\t\t\t\t\tcase 'number' /*case 'Number'*/: break;\n\t\t\t\t\tcase 'decimal' /*case 'Decimal'*/: break;\n\t\t\t\t\tcase 'thousandseparator' /*case 'ThousandSeparator'*/: break;\n\t\t\t\t\tcase 'trailingminusnumbers' /*case 'TrailingMinusNumbers'*/: break;\n\t\t\t\t\tcase 'formatsettings' /*case 'FormatSettings'*/: break;\n\t\t\t\t\tcase 'fieldtype' /*case 'FieldType'*/: break;\n\t\t\t\t\tcase 'delimiters' /*case 'Delimiters'*/: break;\n\t\t\t\t\tcase 'tab' /*case 'Tab'*/: break;\n\t\t\t\t\tcase 'comma' /*case 'Comma'*/: break;\n\t\t\t\t\tcase 'autoformatname' /*case 'AutoFormatName'*/: break;\n\t\t\t\t\tcase 'versionlastedit' /*case 'VersionLastEdit'*/: break;\n\t\t\t\t\tcase 'versionlastrefresh' /*case 'VersionLastRefresh'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\tcase 'datavalidation' /*case 'DataValidation'*/:\n\t\t\t\tswitch(Rn[3]) {\n\t\t\t\t\tcase 'range' /*case 'Range'*/: break;\n\n\t\t\t\t\tcase 'type' /*case 'Type'*/: break;\n\t\t\t\t\tcase 'min' /*case 'Min'*/: break;\n\t\t\t\t\tcase 'max' /*case 'Max'*/: break;\n\t\t\t\t\tcase 'sort' /*case 'Sort'*/: break;\n\t\t\t\t\tcase 'descending' /*case 'Descending'*/: break;\n\t\t\t\t\tcase 'order' /*case 'Order'*/: break;\n\t\t\t\t\tcase 'casesensitive' /*case 'CaseSensitive'*/: break;\n\t\t\t\t\tcase 'value' /*case 'Value'*/: break;\n\t\t\t\t\tcase 'errorstyle' /*case 'ErrorStyle'*/: break;\n\t\t\t\t\tcase 'errormessage' /*case 'ErrorMessage'*/: break;\n\t\t\t\t\tcase 'errortitle' /*case 'ErrorTitle'*/: break;\n\t\t\t\t\tcase 'inputmessage' /*case 'InputMessage'*/: break;\n\t\t\t\t\tcase 'inputtitle' /*case 'InputTitle'*/: break;\n\t\t\t\t\tcase 'combohide' /*case 'ComboHide'*/: break;\n\t\t\t\t\tcase 'inputhide' /*case 'InputHide'*/: break;\n\t\t\t\t\tcase 'condition' /*case 'Condition'*/: break;\n\t\t\t\t\tcase 'qualifier' /*case 'Qualifier'*/: break;\n\t\t\t\t\tcase 'useblank' /*case 'UseBlank'*/: break;\n\t\t\t\t\tcase 'value1' /*case 'Value1'*/: break;\n\t\t\t\t\tcase 'value2' /*case 'Value2'*/: break;\n\t\t\t\t\tcase 'format' /*case 'Format'*/: break;\n\n\t\t\t\t\tcase 'cellrangelist' /*case 'CellRangeList'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\tcase 'sorting' /*case 'Sorting'*/:\n\t\t\t\tcase 'conditionalformatting' /*case 'ConditionalFormatting'*/:\n\t\t\t\tswitch(Rn[3]) {\n\t\t\t\t\tcase 'range' /*case 'Range'*/: break;\n\t\t\t\t\tcase 'type' /*case 'Type'*/: break;\n\t\t\t\t\tcase 'min' /*case 'Min'*/: break;\n\t\t\t\t\tcase 'max' /*case 'Max'*/: break;\n\t\t\t\t\tcase 'sort' /*case 'Sort'*/: break;\n\t\t\t\t\tcase 'descending' /*case 'Descending'*/: break;\n\t\t\t\t\tcase 'order' /*case 'Order'*/: break;\n\t\t\t\t\tcase 'casesensitive' /*case 'CaseSensitive'*/: break;\n\t\t\t\t\tcase 'value' /*case 'Value'*/: break;\n\t\t\t\t\tcase 'errorstyle' /*case 'ErrorStyle'*/: break;\n\t\t\t\t\tcase 'errormessage' /*case 'ErrorMessage'*/: break;\n\t\t\t\t\tcase 'errortitle' /*case 'ErrorTitle'*/: break;\n\t\t\t\t\tcase 'cellrangelist' /*case 'CellRangeList'*/: break;\n\t\t\t\t\tcase 'inputmessage' /*case 'InputMessage'*/: break;\n\t\t\t\t\tcase 'inputtitle' /*case 'InputTitle'*/: break;\n\t\t\t\t\tcase 'combohide' /*case 'ComboHide'*/: break;\n\t\t\t\t\tcase 'inputhide' /*case 'InputHide'*/: break;\n\t\t\t\t\tcase 'condition' /*case 'Condition'*/: break;\n\t\t\t\t\tcase 'qualifier' /*case 'Qualifier'*/: break;\n\t\t\t\t\tcase 'useblank' /*case 'UseBlank'*/: break;\n\t\t\t\t\tcase 'value1' /*case 'Value1'*/: break;\n\t\t\t\t\tcase 'value2' /*case 'Value2'*/: break;\n\t\t\t\t\tcase 'format' /*case 'Format'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* MapInfo (schema) */\n\t\t\t\tcase 'mapinfo' /*case 'MapInfo'*/: case 'schema' /*case 'Schema'*/: case 'data' /*case 'data'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'map' /*case 'Map'*/: break;\n\t\t\t\t\tcase 'entry' /*case 'Entry'*/: break;\n\t\t\t\t\tcase 'range' /*case 'Range'*/: break;\n\t\t\t\t\tcase 'xpath' /*case 'XPath'*/: break;\n\t\t\t\t\tcase 'field' /*case 'Field'*/: break;\n\t\t\t\t\tcase 'xsdtype' /*case 'XSDType'*/: break;\n\t\t\t\t\tcase 'filteron' /*case 'FilterOn'*/: break;\n\t\t\t\t\tcase 'aggregate' /*case 'Aggregate'*/: break;\n\t\t\t\t\tcase 'elementtype' /*case 'ElementType'*/: break;\n\t\t\t\t\tcase 'attributetype' /*case 'AttributeType'*/: break;\n\t\t\t\t/* These are from xsd (XML Schema Definition) */\n\t\t\t\t\tcase 'schema' /*case 'schema'*/:\n\t\t\t\t\tcase 'element' /*case 'element'*/:\n\t\t\t\t\tcase 'complextype' /*case 'complexType'*/:\n\t\t\t\t\tcase 'datatype' /*case 'datatype'*/:\n\t\t\t\t\tcase 'all' /*case 'all'*/:\n\t\t\t\t\tcase 'attribute' /*case 'attribute'*/:\n\t\t\t\t\tcase 'extends' /*case 'extends'*/: break;\n\n\t\t\t\t\tcase 'row' /*case 'row'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* SmartTags (can be anything) */\n\t\t\t\tcase 'smarttags' /*case 'SmartTags'*/: break;\n\n\t\t\t\tdefault: seen = false; break;\n\t\t\t}\n\t\t\tif(seen) break;\n\t\t\t/* CustomDocumentProperties */\n\t\t\tif(Rn[3].match(/!\\[CDATA/)) break;\n\t\t\tif(!state[state.length-1][1]) throw 'Unrecognized tag: ' + Rn[3] + \"|\" + state.join(\"|\");\n\t\t\tif(state[state.length-1][0]===/*'CustomDocumentProperties'*/'customdocumentproperties') {\n\t\t\t\tif(Rn[0].slice(-2) === \"/>\") break;\n\t\t\t\telse if(Rn[1]===\"/\") xlml_set_custprop(Custprops, raw_Rn3, cp, str.slice(pidx, Rn.index));\n\t\t\t\telse { cp = Rn; pidx = Rn.index + Rn[0].length; }\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif(opts.WTF) throw 'Unrecognized tag: ' + Rn[3] + \"|\" + state.join(\"|\");\n\t}\n\tvar out = ({}/*:any*/);\n\tif(!opts.bookSheets && !opts.bookProps) out.Sheets = sheets;\n\tout.SheetNames = sheetnames;\n\tout.Workbook = Workbook;\n\tout.SSF = dup(table_fmt);\n\tout.Props = Props;\n\tout.Custprops = Custprops;\n\treturn out;\n}\n\nfunction parse_xlml(data/*:RawBytes|string*/, opts)/*:Workbook*/ {\n\tfix_read_opts(opts=opts||{});\n\tswitch(opts.type||\"base64\") {\n\t\tcase \"base64\": return parse_xlml_xml(Base64_decode(data), opts);\n\t\tcase \"binary\": case \"buffer\": case \"file\": return parse_xlml_xml(data, opts);\n\t\tcase \"array\": return parse_xlml_xml(a2s(data), opts);\n\t}\n\t/*:: throw new Error(\"unsupported type \" + opts.type); */\n}\n\n/* TODO */\nfunction write_props_xlml(wb/*:Workbook*/, opts)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\t/* DocumentProperties */\n\tif(wb.Props) o.push(xlml_write_docprops(wb.Props, opts));\n\t/* CustomDocumentProperties */\n\tif(wb.Custprops) o.push(xlml_write_custprops(wb.Props, wb.Custprops, opts));\n\treturn o.join(\"\");\n}\n/* TODO */\nfunction write_wb_xlml(/*::wb, opts*/)/*:string*/ {\n\t/* OfficeDocumentSettings */\n\t/* ExcelWorkbook */\n\treturn \"\";\n}\n/* TODO */\nfunction write_sty_xlml(wb, opts)/*:string*/ {\n\t/* Styles */\n\tvar styles/*:Array<string>*/ = ['<Style ss:ID=\"Default\" ss:Name=\"Normal\"><NumberFormat/></Style>'];\n\topts.cellXfs.forEach(function(xf, id) {\n\t\tvar payload/*:Array<string>*/ = [];\n\t\tpayload.push(writextag('NumberFormat', null, {\"ss:Format\": escapexml(table_fmt[xf.numFmtId])}));\n\n\t\tvar o = /*::(*/{\"ss:ID\": \"s\" + (21+id)}/*:: :any)*/;\n\t\tstyles.push(writextag('Style', payload.join(\"\"), o));\n\t});\n\treturn writextag(\"Styles\", styles.join(\"\"));\n}\nfunction write_name_xlml(n) { return writextag(\"NamedRange\", null, {\"ss:Name\": n.Name, \"ss:RefersTo\":\"=\" + a1_to_rc(n.Ref, {r:0,c:0})}); }\nfunction write_names_xlml(wb/*::, opts*/)/*:string*/ {\n\tif(!((wb||{}).Workbook||{}).Names) return \"\";\n\t/*:: if(!wb || !wb.Workbook || !wb.Workbook.Names) throw new Error(\"unreachable\"); */\n\tvar names/*:Array<any>*/ = wb.Workbook.Names;\n\tvar out/*:Array<string>*/ = [];\n\tfor(var i = 0; i < names.length; ++i) {\n\t\tvar n = names[i];\n\t\tif(n.Sheet != null) continue;\n\t\tif(n.Name.match(/^_xlfn\\./)) continue;\n\t\tout.push(write_name_xlml(n));\n\t}\n\treturn writextag(\"Names\", out.join(\"\"));\n}\nfunction write_ws_xlml_names(ws/*:Worksheet*/, opts, idx/*:number*/, wb/*:Workbook*/)/*:string*/ {\n\tif(!ws) return \"\";\n\tif(!((wb||{}).Workbook||{}).Names) return \"\";\n\t/*:: if(!wb || !wb.Workbook || !wb.Workbook.Names) throw new Error(\"unreachable\"); */\n\tvar names/*:Array<any>*/ = wb.Workbook.Names;\n\tvar out/*:Array<string>*/ = [];\n\tfor(var i = 0; i < names.length; ++i) {\n\t\tvar n = names[i];\n\t\tif(n.Sheet != idx) continue;\n\t\t/*switch(n.Name) {\n\t\t\tcase \"_\": continue;\n\t\t}*/\n\t\tif(n.Name.match(/^_xlfn\\./)) continue;\n\t\tout.push(write_name_xlml(n));\n\t}\n\treturn out.join(\"\");\n}\n/* WorksheetOptions */\nfunction write_ws_xlml_wsopts(ws/*:Worksheet*/, opts, idx/*:number*/, wb/*:Workbook*/)/*:string*/ {\n\tif(!ws) return \"\";\n\tvar o/*:Array<string>*/ = [];\n\t/* NOTE: spec technically allows any order, but stick with implied order */\n\n\t/* FitToPage */\n\t/* DoNotDisplayColHeaders */\n\t/* DoNotDisplayRowHeaders */\n\t/* ViewableRange */\n\t/* Selection */\n\t/* GridlineColor */\n\t/* Name */\n\t/* ExcelWorksheetType */\n\t/* IntlMacro */\n\t/* Unsynced */\n\t/* Selected */\n\t/* CodeName */\n\n\tif(ws['!margins']) {\n\t\to.push(\"<PageSetup>\");\n\t\tif(ws['!margins'].header) o.push(writextag(\"Header\", null, {'x:Margin':ws['!margins'].header}));\n\t\tif(ws['!margins'].footer) o.push(writextag(\"Footer\", null, {'x:Margin':ws['!margins'].footer}));\n\t\to.push(writextag(\"PageMargins\", null, {\n\t\t\t'x:Bottom': ws['!margins'].bottom || \"0.75\",\n\t\t\t'x:Left': ws['!margins'].left || \"0.7\",\n\t\t\t'x:Right': ws['!margins'].right || \"0.7\",\n\t\t\t'x:Top': ws['!margins'].top || \"0.75\"\n\t\t}));\n\t\to.push(\"</PageSetup>\");\n\t}\n\n\t/* PageSetup */\n\t/* DisplayPageBreak */\n\t/* TransitionExpressionEvaluation */\n\t/* TransitionFormulaEntry */\n\t/* Print */\n\t/* Zoom */\n\t/* PageLayoutZoom */\n\t/* PageBreakZoom */\n\t/* ShowPageBreakZoom */\n\t/* DefaultRowHeight */\n\t/* DefaultColumnWidth */\n\t/* StandardWidth */\n\n\tif(wb && wb.Workbook && wb.Workbook.Sheets && wb.Workbook.Sheets[idx]) {\n\t\t/* Visible */\n\t\tif(wb.Workbook.Sheets[idx].Hidden) o.push(writextag(\"Visible\", (wb.Workbook.Sheets[idx].Hidden == 1 ? \"SheetHidden\" : \"SheetVeryHidden\"), {}));\n\t\telse {\n\t\t\t/* Selected */\n\t\t\tfor(var i = 0; i < idx; ++i) if(wb.Workbook.Sheets[i] && !wb.Workbook.Sheets[i].Hidden) break;\n\t\t\tif(i == idx) o.push(\"<Selected/>\");\n\t\t}\n\t}\n\n\t/* LeftColumnVisible */\n\n\tif(((((wb||{}).Workbook||{}).Views||[])[0]||{}).RTL) o.push(\"<DisplayRightToLeft/>\");\n\n\t/* GridlineColorIndex */\n\t/* DisplayFormulas */\n\t/* DoNotDisplayGridlines */\n\t/* DoNotDisplayHeadings */\n\t/* DoNotDisplayOutline */\n\t/* ApplyAutomaticOutlineStyles */\n\t/* NoSummaryRowsBelowDetail */\n\t/* NoSummaryColumnsRightDetail */\n\t/* DoNotDisplayZeros */\n\t/* ActiveRow */\n\t/* ActiveColumn */\n\t/* FilterOn */\n\t/* RangeSelection */\n\t/* TopRowVisible */\n\t/* TopRowBottomPane */\n\t/* LeftColumnRightPane */\n\t/* ActivePane */\n\t/* SplitHorizontal */\n\t/* SplitVertical */\n\t/* FreezePanes */\n\t/* FrozenNoSplit */\n\t/* TabColorIndex */\n\t/* Panes */\n\n\t/* NOTE: Password not supported in XLML Format */\n\tif(ws['!protect']) {\n\t\to.push(writetag(\"ProtectContents\", \"True\"));\n\t\tif(ws['!protect'].objects) o.push(writetag(\"ProtectObjects\", \"True\"));\n\t\tif(ws['!protect'].scenarios) o.push(writetag(\"ProtectScenarios\", \"True\"));\n\t\tif(ws['!protect'].selectLockedCells != null && !ws['!protect'].selectLockedCells) o.push(writetag(\"EnableSelection\", \"NoSelection\"));\n\t\telse if(ws['!protect'].selectUnlockedCells != null && !ws['!protect'].selectUnlockedCells) o.push(writetag(\"EnableSelection\", \"UnlockedCells\"));\n\t[\n\t\t[ \"formatCells\", \"AllowFormatCells\" ],\n\t\t[ \"formatColumns\", \"AllowSizeCols\" ],\n\t\t[ \"formatRows\", \"AllowSizeRows\" ],\n\t\t[ \"insertColumns\", \"AllowInsertCols\" ],\n\t\t[ \"insertRows\", \"AllowInsertRows\" ],\n\t\t[ \"insertHyperlinks\", \"AllowInsertHyperlinks\" ],\n\t\t[ \"deleteColumns\", \"AllowDeleteCols\" ],\n\t\t[ \"deleteRows\", \"AllowDeleteRows\" ],\n\t\t[ \"sort\", \"AllowSort\" ],\n\t\t[ \"autoFilter\", \"AllowFilter\" ],\n\t\t[ \"pivotTables\", \"AllowUsePivotTables\" ]\n\t].forEach(function(x) { if(ws['!protect'][x[0]]) o.push(\"<\"+x[1]+\"/>\"); });\n\t}\n\n\tif(o.length == 0) return \"\";\n\treturn writextag(\"WorksheetOptions\", o.join(\"\"), {xmlns:XLMLNS.x});\n}\nfunction write_ws_xlml_comment(comments/*:Array<any>*/)/*:string*/ {\n\treturn comments.map(function(c) {\n\t\t// TODO: formatted text\n\t\tvar t = xlml_unfixstr(c.t||\"\");\n\t\tvar d =writextag(\"ss:Data\", t, {\"xmlns\":\"http://www.w3.org/TR/REC-html40\"});\n\t\treturn writextag(\"Comment\", d, {\"ss:Author\":c.a});\n\t}).join(\"\");\n}\nfunction write_ws_xlml_cell(cell, ref/*:string*/, ws, opts, idx/*:number*/, wb, addr)/*:string*/{\n\tif(!cell || (cell.v == undefined && cell.f == undefined)) return \"\";\n\n\tvar attr = {};\n\tif(cell.f) attr[\"ss:Formula\"] = \"=\" + escapexml(a1_to_rc(cell.f, addr));\n\tif(cell.F && cell.F.slice(0, ref.length) == ref) {\n\t\tvar end = decode_cell(cell.F.slice(ref.length + 1));\n\t\tattr[\"ss:ArrayRange\"] = \"RC:R\" + (end.r == addr.r ? \"\" : \"[\" + (end.r - addr.r) + \"]\") + \"C\" + (end.c == addr.c ? \"\" : \"[\" + (end.c - addr.c) + \"]\");\n\t}\n\n\tif(cell.l && cell.l.Target) {\n\t\tattr[\"ss:HRef\"] = escapexml(cell.l.Target);\n\t\tif(cell.l.Tooltip) attr[\"x:HRefScreenTip\"] = escapexml(cell.l.Tooltip);\n\t}\n\n\tif(ws['!merges']) {\n\t\tvar marr = ws['!merges'];\n\t\tfor(var mi = 0; mi != marr.length; ++mi) {\n\t\t\tif(marr[mi].s.c != addr.c || marr[mi].s.r != addr.r) continue;\n\t\t\tif(marr[mi].e.c > marr[mi].s.c) attr['ss:MergeAcross'] = marr[mi].e.c - marr[mi].s.c;\n\t\t\tif(marr[mi].e.r > marr[mi].s.r) attr['ss:MergeDown'] = marr[mi].e.r - marr[mi].s.r;\n\t\t}\n\t}\n\n\tvar t = \"\", p = \"\";\n\tswitch(cell.t) {\n\t\tcase 'z': if(!opts.sheetStubs) return \"\"; break;\n\t\tcase 'n': t = 'Number'; p = String(cell.v); break;\n\t\tcase 'b': t = 'Boolean'; p = (cell.v ? \"1\" : \"0\"); break;\n\t\tcase 'e': t = 'Error'; p = BErr[cell.v]; break;\n\t\tcase 'd': t = 'DateTime'; p = new Date(cell.v).toISOString(); if(cell.z == null) cell.z = cell.z || table_fmt[14]; break;\n\t\tcase 's': t = 'String'; p = escapexlml(cell.v||\"\"); break;\n\t}\n\t/* TODO: cell style */\n\tvar os = get_cell_style(opts.cellXfs, cell, opts);\n\tattr[\"ss:StyleID\"] = \"s\" + (21+os);\n\tattr[\"ss:Index\"] = addr.c + 1;\n\tvar _v = (cell.v != null ? p : \"\");\n\tvar m = cell.t == 'z' ? \"\" : ('<Data ss:Type=\"' + t + '\">' + _v + '</Data>');\n\n\tif((cell.c||[]).length > 0) m += write_ws_xlml_comment(cell.c);\n\n\treturn writextag(\"Cell\", m, attr);\n}\nfunction write_ws_xlml_row(R/*:number*/, row)/*:string*/ {\n\tvar o = '<Row ss:Index=\"' + (R+1) + '\"';\n\tif(row) {\n\t\tif(row.hpt && !row.hpx) row.hpx = pt2px(row.hpt);\n\t\tif(row.hpx) o += ' ss:AutoFitHeight=\"0\" ss:Height=\"' + row.hpx + '\"';\n\t\tif(row.hidden) o += ' ss:Hidden=\"1\"';\n\t}\n\treturn o + '>';\n}\n/* TODO */\nfunction write_ws_xlml_table(ws/*:Worksheet*/, opts, idx/*:number*/, wb/*:Workbook*/)/*:string*/ {\n\tif(!ws['!ref']) return \"\";\n\tvar range/*:Range*/ = safe_decode_range(ws['!ref']);\n\tvar marr/*:Array<Range>*/ = ws['!merges'] || [], mi = 0;\n\tvar o/*:Array<string>*/ = [];\n\tif(ws['!cols']) ws['!cols'].forEach(function(n, i) {\n\t\tprocess_col(n);\n\t\tvar w = !!n.width;\n\t\tvar p = col_obj_w(i, n);\n\t\tvar k/*:any*/ = {\"ss:Index\":i+1};\n\t\tif(w) k['ss:Width'] = width2px(p.width);\n\t\tif(n.hidden) k['ss:Hidden']=\"1\";\n\t\to.push(writextag(\"Column\",null,k));\n\t});\n\tvar dense = Array.isArray(ws);\n\tfor(var R = range.s.r; R <= range.e.r; ++R) {\n\t\tvar row = [write_ws_xlml_row(R, (ws['!rows']||[])[R])];\n\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\tvar skip = false;\n\t\t\tfor(mi = 0; mi != marr.length; ++mi) {\n\t\t\t\tif(marr[mi].s.c > C) continue;\n\t\t\t\tif(marr[mi].s.r > R) continue;\n\t\t\t\tif(marr[mi].e.c < C) continue;\n\t\t\t\tif(marr[mi].e.r < R) continue;\n\t\t\t\tif(marr[mi].s.c != C || marr[mi].s.r != R) skip = true;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif(skip) continue;\n\t\t\tvar addr = {r:R,c:C};\n\t\t\tvar ref = encode_cell(addr), cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\trow.push(write_ws_xlml_cell(cell, ref, ws, opts, idx, wb, addr));\n\t\t}\n\t\trow.push(\"</Row>\");\n\t\tif(row.length > 2) o.push(row.join(\"\"));\n\t}\n\treturn o.join(\"\");\n}\nfunction write_ws_xlml(idx/*:number*/, opts, wb/*:Workbook*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\tvar s = wb.SheetNames[idx];\n\tvar ws = wb.Sheets[s];\n\n\tvar t/*:string*/ = ws ? write_ws_xlml_names(ws, opts, idx, wb) : \"\";\n\tif(t.length > 0) o.push(\"<Names>\" + t + \"</Names>\");\n\n\t/* Table */\n\tt = ws ? write_ws_xlml_table(ws, opts, idx, wb) : \"\";\n\tif(t.length > 0) o.push(\"<Table>\" + t + \"</Table>\");\n\n\t/* WorksheetOptions */\n\to.push(write_ws_xlml_wsopts(ws, opts, idx, wb));\n\n\treturn o.join(\"\");\n}\nfunction write_xlml(wb, opts)/*:string*/ {\n\tif(!opts) opts = {};\n\tif(!wb.SSF) wb.SSF = dup(table_fmt);\n\tif(wb.SSF) {\n\t\tmake_ssf(); SSF_load_table(wb.SSF);\n\t\t// $FlowIgnore\n\t\topts.revssf = evert_num(wb.SSF); opts.revssf[wb.SSF[65535]] = 0;\n\t\topts.ssf = wb.SSF;\n\t\topts.cellXfs = [];\n\t\tget_cell_style(opts.cellXfs, {}, {revssf:{\"General\":0}});\n\t}\n\tvar d/*:Array<string>*/ = [];\n\td.push(write_props_xlml(wb, opts));\n\td.push(write_wb_xlml(wb, opts));\n\td.push(\"\");\n\td.push(\"\");\n\tfor(var i = 0; i < wb.SheetNames.length; ++i)\n\t\td.push(writextag(\"Worksheet\", write_ws_xlml(i, opts, wb), {\"ss:Name\":escapexml(wb.SheetNames[i])}));\n\td[2] = write_sty_xlml(wb, opts);\n\td[3] = write_names_xlml(wb, opts);\n\treturn XML_HEADER + writextag(\"Workbook\", d.join(\"\"), {\n\t\t'xmlns': XLMLNS.ss,\n\t\t'xmlns:o': XLMLNS.o,\n\t\t'xmlns:x': XLMLNS.x,\n\t\t'xmlns:ss': XLMLNS.ss,\n\t\t'xmlns:dt': XLMLNS.dt,\n\t\t'xmlns:html': XLMLNS.html\n\t});\n}\n/* [MS-OLEDS] 2.3.8 CompObjStream */\nfunction parse_compobj(obj/*:CFBEntry*/) {\n\tvar v = {};\n\tvar o = obj.content;\n\t/*:: if(o == null) return; */\n\n\t/* [MS-OLEDS] 2.3.7 CompObjHeader -- All fields MUST be ignored */\n\to.l = 28;\n\n\tv.AnsiUserType = o.read_shift(0, \"lpstr-ansi\");\n\tv.AnsiClipboardFormat = parse_ClipboardFormatOrAnsiString(o);\n\n\tif(o.length - o.l <= 4) return v;\n\n\tvar m/*:number*/ = o.read_shift(4);\n\tif(m == 0 || m > 40) return v;\n\to.l-=4; v.Reserved1 = o.read_shift(0, \"lpstr-ansi\");\n\n\tif(o.length - o.l <= 4) return v;\n\tm = o.read_shift(4);\n\tif(m !== 0x71b239f4) return v;\n\tv.UnicodeClipboardFormat = parse_ClipboardFormatOrUnicodeString(o);\n\n\tm = o.read_shift(4);\n\tif(m == 0 || m > 40) return v;\n\to.l-=4; v.Reserved2 = o.read_shift(0, \"lpwstr\");\n}\n\n/*\n\tContinue logic for:\n\t- 2.4.58 Continue 0x003c\n\t- 2.4.59 ContinueBigName 0x043c\n\t- 2.4.60 ContinueFrt 0x0812\n\t- 2.4.61 ContinueFrt11 0x0875\n\t- 2.4.62 ContinueFrt12 0x087f\n*/\nvar CONTINUE_RT = [ 0x003c, 0x043c, 0x0812, 0x0875, 0x087f ];\nfunction slurp(RecordType, R, blob, length/*:number*/, opts)/*:any*/ {\n\tvar l = length;\n\tvar bufs = [];\n\tvar d = blob.slice(blob.l,blob.l+l);\n\tif(opts && opts.enc && opts.enc.insitu && d.length > 0) switch(RecordType) {\n\tcase 0x0009: case 0x0209: case 0x0409: case 0x0809/* BOF */: case 0x002f /* FilePass */: case 0x0195 /* FileLock */: case 0x00e1 /* InterfaceHdr */: case 0x0196 /* RRDInfo */: case 0x0138 /* RRDHead */: case 0x0194 /* UsrExcl */: case 0x000a /* EOF */:\n\t\tbreak;\n\tcase 0x0085 /* BoundSheet8 */:\n\t\tbreak;\n\tdefault:\n\t\topts.enc.insitu(d);\n\t}\n\tbufs.push(d);\n\tblob.l += l;\n\tvar nextrt = __readUInt16LE(blob,blob.l), next = XLSRecordEnum[nextrt];\n\tvar start = 0;\n\twhile(next != null && CONTINUE_RT.indexOf(nextrt) > -1) {\n\t\tl = __readUInt16LE(blob,blob.l+2);\n\t\tstart = blob.l + 4;\n\t\tif(nextrt == 0x0812 /* ContinueFrt */) start += 4;\n\t\telse if(nextrt == 0x0875 || nextrt == 0x087f) {\n\t\t\tstart += 12;\n\t\t}\n\t\td = blob.slice(start,blob.l+4+l);\n\t\tbufs.push(d);\n\t\tblob.l += 4+l;\n\t\tnext = (XLSRecordEnum[nextrt = __readUInt16LE(blob, blob.l)]);\n\t}\n\tvar b = (bconcat(bufs)/*:any*/);\n\tprep_blob(b, 0);\n\tvar ll = 0; b.lens = [];\n\tfor(var j = 0; j < bufs.length; ++j) { b.lens.push(ll); ll += bufs[j].length; }\n\tif(b.length < length) throw \"XLS Record 0x\" + RecordType.toString(16) + \" Truncated: \" + b.length + \" < \" + length;\n\treturn R.f(b, b.length, opts);\n}\n\nfunction safe_format_xf(p/*:any*/, opts/*:ParseOpts*/, date1904/*:?boolean*/) {\n\tif(p.t === 'z') return;\n\tif(!p.XF) return;\n\tvar fmtid = 0;\n\ttry {\n\t\tfmtid = p.z || p.XF.numFmtId || 0;\n\t\tif(opts.cellNF) p.z = table_fmt[fmtid];\n\t} catch(e) { if(opts.WTF) throw e; }\n\tif(!opts || opts.cellText !== false) try {\n\t\tif(p.t === 'e') { p.w = p.w || BErr[p.v]; }\n\t\telse if(fmtid === 0 || fmtid == \"General\") {\n\t\t\tif(p.t === 'n') {\n\t\t\t\tif((p.v|0) === p.v) p.w = p.v.toString(10);\n\t\t\t\telse p.w = SSF_general_num(p.v);\n\t\t\t}\n\t\t\telse p.w = SSF_general(p.v);\n\t\t}\n\t\telse p.w = SSF_format(fmtid,p.v, {date1904:!!date1904, dateNF: opts && opts.dateNF});\n\t} catch(e) { if(opts.WTF) throw e; }\n\tif(opts.cellDates && fmtid && p.t == 'n' && fmt_is_date(table_fmt[fmtid] || String(fmtid))) {\n\t\tvar _d = SSF_parse_date_code(p.v); if(_d) { p.t = 'd'; p.v = new Date(_d.y, _d.m-1,_d.d,_d.H,_d.M,_d.S,_d.u); }\n\t}\n}\n\nfunction make_cell(val, ixfe, t)/*:Cell*/ {\n\treturn ({v:val, ixfe:ixfe, t:t}/*:any*/);\n}\n\n// 2.3.2\nfunction parse_workbook(blob, options/*:ParseOpts*/)/*:Workbook*/ {\n\tvar wb = ({opts:{}}/*:any*/);\n\tvar Sheets = {};\n\tif(DENSE != null && options.dense == null) options.dense = DENSE;\n\tvar out/*:Worksheet*/ = ((options.dense ? [] : {})/*:any*/);\n\tvar Directory = {};\n\tvar range/*:Range*/ = ({}/*:any*/);\n\tvar last_formula = null;\n\tvar sst/*:SST*/ = ([]/*:any*/);\n\tvar cur_sheet = \"\";\n\tvar Preamble = {};\n\tvar lastcell, last_cell = \"\", cc/*:Cell*/, cmnt, rngC, rngR;\n\tvar sharedf = {};\n\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\tvar temp_val/*:Cell*/;\n\tvar country;\n\tvar XFs = []; /* XF records */\n\tvar palette/*:Array<[number, number, number]>*/ = [];\n\tvar Workbook/*:WBWBProps*/ = ({ Sheets:[], WBProps:{date1904:false}, Views:[{}] }/*:any*/), wsprops = {};\n\tvar get_rgb = function getrgb(icv/*:number*/)/*:[number, number, number]*/ {\n\t\tif(icv < 8) return XLSIcv[icv];\n\t\tif(icv < 64) return palette[icv-8] || XLSIcv[icv];\n\t\treturn XLSIcv[icv];\n\t};\n\tvar process_cell_style = function pcs(cell, line/*:any*/, options) {\n\t\tvar xfd = line.XF.data;\n\t\tif(!xfd || !xfd.patternType || !options || !options.cellStyles) return;\n\t\tline.s = ({}/*:any*/);\n\t\tline.s.patternType = xfd.patternType;\n\t\tvar t;\n\t\tif((t = rgb2Hex(get_rgb(xfd.icvFore)))) { line.s.fgColor = {rgb:t}; }\n\t\tif((t = rgb2Hex(get_rgb(xfd.icvBack)))) { line.s.bgColor = {rgb:t}; }\n\t};\n\tvar addcell = function addcell(cell/*:any*/, line/*:any*/, options/*:any*/) {\n\t\tif(file_depth > 1) return;\n\t\tif(options.sheetRows && cell.r >= options.sheetRows) return;\n\t\tif(options.cellStyles && line.XF && line.XF.data) process_cell_style(cell, line, options);\n\t\tdelete line.ixfe; delete line.XF;\n\t\tlastcell = cell;\n\t\tlast_cell = encode_cell(cell);\n\t\tif(!range || !range.s || !range.e) range = {s:{r:0,c:0},e:{r:0,c:0}};\n\t\tif(cell.r < range.s.r) range.s.r = cell.r;\n\t\tif(cell.c < range.s.c) range.s.c = cell.c;\n\t\tif(cell.r + 1 > range.e.r) range.e.r = cell.r + 1;\n\t\tif(cell.c + 1 > range.e.c) range.e.c = cell.c + 1;\n\t\tif(options.cellFormula && line.f) {\n\t\t\tfor(var afi = 0; afi < arrayf.length; ++afi) {\n\t\t\t\tif(arrayf[afi][0].s.c > cell.c || arrayf[afi][0].s.r > cell.r) continue;\n\t\t\t\tif(arrayf[afi][0].e.c < cell.c || arrayf[afi][0].e.r < cell.r) continue;\n\t\t\t\tline.F = encode_range(arrayf[afi][0]);\n\t\t\t\tif(arrayf[afi][0].s.c != cell.c || arrayf[afi][0].s.r != cell.r) delete line.f;\n\t\t\t\tif(line.f) line.f = \"\" + stringify_formula(arrayf[afi][1], range, cell, supbooks, opts);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\t{\n\t\t\tif(options.dense) {\n\t\t\t\tif(!out[cell.r]) out[cell.r] = [];\n\t\t\t\tout[cell.r][cell.c] = line;\n\t\t\t} else out[last_cell] = line;\n\t\t}\n\t};\n\tvar opts = ({\n\t\tenc: false, // encrypted\n\t\tsbcch: 0, // cch in the preceding SupBook\n\t\tsnames: [], // sheetnames\n\t\tsharedf: sharedf, // shared formulae by address\n\t\tarrayf: arrayf, // array formulae array\n\t\trrtabid: [], // RRTabId\n\t\tlastuser: \"\", // Last User from WriteAccess\n\t\tbiff: 8, // BIFF version\n\t\tcodepage: 0, // CP from CodePage record\n\t\twinlocked: 0, // fLockWn from WinProtect\n\t\tcellStyles: !!options && !!options.cellStyles,\n\t\tWTF: !!options && !!options.wtf\n\t}/*:any*/);\n\tif(options.password) opts.password = options.password;\n\tvar themes;\n\tvar merges/*:Array<Range>*/ = [];\n\tvar objects = [];\n\tvar colinfo/*:Array<ColInfo>*/ = [], rowinfo/*:Array<RowInfo>*/ = [];\n\tvar seencol = false;\n\tvar supbooks = ([]/*:any*/); // 1-indexed, will hold extern names\n\tsupbooks.SheetNames = opts.snames;\n\tsupbooks.sharedf = opts.sharedf;\n\tsupbooks.arrayf = opts.arrayf;\n\tsupbooks.names = [];\n\tsupbooks.XTI = [];\n\tvar last_RT = 0;\n\tvar file_depth = 0; /* TODO: make a real stack */\n\tvar BIFF2Fmt = 0, BIFF2FmtTable/*:Array<string>*/ = [];\n\tvar FilterDatabases = []; /* TODO: sort out supbooks and process elsewhere */\n\tvar last_lbl/*:?DefinedName*/;\n\n\t/* explicit override for some broken writers */\n\topts.codepage = 1200;\n\tset_cp(1200);\n\tvar seen_codepage = false;\n\twhile(blob.l < blob.length - 1) {\n\t\tvar s = blob.l;\n\t\tvar RecordType = blob.read_shift(2);\n\t\tif(RecordType === 0 && last_RT === 0x000a /* EOF */) break;\n\t\tvar length = (blob.l === blob.length ? 0 : blob.read_shift(2));\n\t\tvar R = XLSRecordEnum[RecordType];\n\t\t//console.log(RecordType.toString(16), RecordType, R, blob.l, length, blob.length);\n\t\t//if(!R) console.log(blob.slice(blob.l, blob.l + length));\n\t\tif(R && R.f) {\n\t\t\tif(options.bookSheets) {\n\t\t\t\tif(last_RT === 0x0085 /* BoundSheet8 */ && RecordType !== 0x0085 /* R.n !== 'BoundSheet8' */) break;\n\t\t\t}\n\t\t\tlast_RT = RecordType;\n\t\t\tif(R.r === 2 || R.r == 12) {\n\t\t\t\tvar rt = blob.read_shift(2); length -= 2;\n\t\t\t\tif(!opts.enc && rt !== RecordType && (((rt&0xFF)<<8)|(rt>>8)) !== RecordType) throw new Error(\"rt mismatch: \" + rt + \"!=\" + RecordType);\n\t\t\t\tif(R.r == 12){\n\t\t\t\t\tblob.l += 10; length -= 10;\n\t\t\t\t} // skip FRT\n\t\t\t}\n\t\t\t//console.error(R,blob.l,length,blob.length);\n\t\t\tvar val/*:any*/ = ({}/*:any*/);\n\t\t\tif(RecordType === 0x000a /* EOF */) val = /*::(*/R.f(blob, length, opts)/*:: :any)*/;\n\t\t\telse val = /*::(*/slurp(RecordType, R, blob, length, opts)/*:: :any)*/;\n\t\t\t/*:: val = (val:any); */\n\t\t\tif(file_depth == 0 && [0x0009, 0x0209, 0x0409, 0x0809].indexOf(last_RT) === -1 /* 'BOF' */) continue;\n\t\t\tswitch(RecordType) {\n\t\t\t\tcase 0x0022 /* Date1904 */:\n\t\t\t\t\t/*:: if(!Workbook.WBProps) Workbook.WBProps = {}; */\n\t\t\t\t\twb.opts.Date1904 = Workbook.WBProps.date1904 = val; break;\n\t\t\t\tcase 0x0086 /* WriteProtect */: wb.opts.WriteProtect = true; break;\n\t\t\t\tcase 0x002f /* FilePass */:\n\t\t\t\t\tif(!opts.enc) blob.l = 0;\n\t\t\t\t\topts.enc = val;\n\t\t\t\t\tif(!options.password) throw new Error(\"File is password-protected\");\n\t\t\t\t\tif(val.valid == null) throw new Error(\"Encryption scheme unsupported\");\n\t\t\t\t\tif(!val.valid) throw new Error(\"Password is incorrect\");\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x005c /* WriteAccess */: opts.lastuser = val; break;\n\t\t\t\tcase 0x0042 /* CodePage */:\n\t\t\t\t\tvar cpval = Number(val);\n\t\t\t\t\t/* overrides based on test cases */\n\t\t\t\t\tswitch(cpval) {\n\t\t\t\t\t\tcase 0x5212: cpval = 1200; break;\n\t\t\t\t\t\tcase 0x8000: cpval = 10000; break;\n\t\t\t\t\t\tcase 0x8001: cpval = 1252; break;\n\t\t\t\t\t}\n\t\t\t\t\tset_cp(opts.codepage = cpval);\n\t\t\t\t\tseen_codepage = true;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x013d /* RRTabId */: opts.rrtabid = val; break;\n\t\t\t\tcase 0x0019 /* WinProtect */: opts.winlocked = val; break;\n\t\t\t\tcase 0x01b7 /* RefreshAll */: wb.opts[\"RefreshAll\"] = val; break;\n\t\t\t\tcase 0x000c /* CalcCount */: wb.opts[\"CalcCount\"] = val; break;\n\t\t\t\tcase 0x0010 /* CalcDelta */: wb.opts[\"CalcDelta\"] = val; break;\n\t\t\t\tcase 0x0011 /* CalcIter */: wb.opts[\"CalcIter\"] = val; break;\n\t\t\t\tcase 0x000d /* CalcMode */: wb.opts[\"CalcMode\"] = val; break;\n\t\t\t\tcase 0x000e /* CalcPrecision */: wb.opts[\"CalcPrecision\"] = val; break;\n\t\t\t\tcase 0x005f /* CalcSaveRecalc */: wb.opts[\"CalcSaveRecalc\"] = val; break;\n\t\t\t\tcase 0x000f /* CalcRefMode */: opts.CalcRefMode = val; break; // TODO: implement R1C1\n\t\t\t\tcase 0x08a3 /* ForceFullCalculation */: wb.opts.FullCalc = val; break;\n\t\t\t\tcase 0x0081 /* WsBool */:\n\t\t\t\t\tif(val.fDialog) out[\"!type\"] = \"dialog\";\n\t\t\t\t\tif(!val.fBelow) (out[\"!outline\"] || (out[\"!outline\"] = {})).above = true;\n\t\t\t\t\tif(!val.fRight) (out[\"!outline\"] || (out[\"!outline\"] = {})).left = true;\n\t\t\t\t\tbreak; // TODO\n\t\t\t\tcase 0x00e0 /* XF */:\n\t\t\t\t\tXFs.push(val); break;\n\t\t\t\tcase 0x01ae /* SupBook */:\n\t\t\t\t\tsupbooks.push([val]);\n\t\t\t\t\tsupbooks[supbooks.length-1].XTI = [];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0023: case 0x0223 /* ExternName */:\n\t\t\t\t\tsupbooks[supbooks.length-1].push(val);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0018: case 0x0218 /* Lbl */:\n\t\t\t\t\tlast_lbl = ({\n\t\t\t\t\t\tName: val.Name,\n\t\t\t\t\t\tRef: stringify_formula(val.rgce,range,null,supbooks,opts)\n\t\t\t\t\t}/*:DefinedName*/);\n\t\t\t\t\tif(val.itab > 0) last_lbl.Sheet = val.itab - 1;\n\t\t\t\t\tsupbooks.names.push(last_lbl);\n\t\t\t\t\tif(!supbooks[0]) { supbooks[0] = []; supbooks[0].XTI = []; }\n\t\t\t\t\tsupbooks[supbooks.length-1].push(val);\n\t\t\t\t\tif(val.Name == \"_xlnm._FilterDatabase\" && val.itab > 0)\n\t\t\t\t\t\tif(val.rgce && val.rgce[0] && val.rgce[0][0] && val.rgce[0][0][0] == 'PtgArea3d')\n\t\t\t\t\t\t\tFilterDatabases[val.itab - 1] = { ref: encode_range(val.rgce[0][0][1][2]) };\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0016 /* ExternCount */: opts.ExternCount = val; break;\n\t\t\t\tcase 0x0017 /* ExternSheet */:\n\t\t\t\t\tif(supbooks.length == 0) { supbooks[0] = []; supbooks[0].XTI = []; }\n\t\t\t\t\tsupbooks[supbooks.length - 1].XTI = supbooks[supbooks.length - 1].XTI.concat(val); supbooks.XTI = supbooks.XTI.concat(val); break;\n\t\t\t\tcase 0x0894 /* NameCmt */:\n\t\t\t\t\t/* TODO: search for correct name */\n\t\t\t\t\tif(opts.biff < 8) break;\n\t\t\t\t\tif(last_lbl != null) last_lbl.Comment = val[1];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0012 /* Protect */: out[\"!protect\"] = val; break; /* for sheet or book */\n\t\t\t\tcase 0x0013 /* Password */: if(val !== 0 && opts.WTF) console.error(\"Password verifier: \" + val); break;\n\t\t\t\tcase 0x0085 /* BoundSheet8 */: {\n\t\t\t\t\tDirectory[val.pos] = val;\n\t\t\t\t\topts.snames.push(val.name);\n\t\t\t\t} break;\n\t\t\t\tcase 0x000a /* EOF */: {\n\t\t\t\t\tif(--file_depth) break;\n\t\t\t\t\tif(range.e) {\n\t\t\t\t\t\tif(range.e.r > 0 && range.e.c > 0) {\n\t\t\t\t\t\t\trange.e.r--; range.e.c--;\n\t\t\t\t\t\t\tout[\"!ref\"] = encode_range(range);\n\t\t\t\t\t\t\tif(options.sheetRows && options.sheetRows <= range.e.r) {\n\t\t\t\t\t\t\t\tvar tmpri = range.e.r;\n\t\t\t\t\t\t\t\trange.e.r = options.sheetRows - 1;\n\t\t\t\t\t\t\t\tout[\"!fullref\"] = out[\"!ref\"];\n\t\t\t\t\t\t\t\tout[\"!ref\"] = encode_range(range);\n\t\t\t\t\t\t\t\trange.e.r = tmpri;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\trange.e.r++; range.e.c++;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif(merges.length > 0) out[\"!merges\"] = merges;\n\t\t\t\t\t\tif(objects.length > 0) out[\"!objects\"] = objects;\n\t\t\t\t\t\tif(colinfo.length > 0) out[\"!cols\"] = colinfo;\n\t\t\t\t\t\tif(rowinfo.length > 0) out[\"!rows\"] = rowinfo;\n\t\t\t\t\t\tWorkbook.Sheets.push(wsprops);\n\t\t\t\t\t}\n\t\t\t\t\tif(cur_sheet === \"\") Preamble = out; else Sheets[cur_sheet] = out;\n\t\t\t\t\tout = ((options.dense ? [] : {})/*:any*/);\n\t\t\t\t} break;\n\t\t\t\tcase 0x0009: case 0x0209: case 0x0409: case 0x0809 /* BOF */: {\n\t\t\t\t\tif(opts.biff === 8) opts.biff = {\n\t\t\t\t\t\t/*::[*/0x0009/*::]*/:2,\n\t\t\t\t\t\t/*::[*/0x0209/*::]*/:3,\n\t\t\t\t\t\t/*::[*/0x0409/*::]*/:4\n\t\t\t\t\t}[RecordType] || {\n\t\t\t\t\t\t/*::[*/0x0200/*::]*/:2,\n\t\t\t\t\t\t/*::[*/0x0300/*::]*/:3,\n\t\t\t\t\t\t/*::[*/0x0400/*::]*/:4,\n\t\t\t\t\t\t/*::[*/0x0500/*::]*/:5,\n\t\t\t\t\t\t/*::[*/0x0600/*::]*/:8,\n\t\t\t\t\t\t/*::[*/0x0002/*::]*/:2,\n\t\t\t\t\t\t/*::[*/0x0007/*::]*/:2\n\t\t\t\t\t}[val.BIFFVer] || 8;\n\t\t\t\t\topts.biffguess = val.BIFFVer == 0;\n\t\t\t\t\tif(val.BIFFVer == 0 && val.dt == 0x1000) { opts.biff = 5; seen_codepage = true; set_cp(opts.codepage = 28591); }\n\t\t\t\t\tif(opts.biff == 8 && val.BIFFVer == 0 && val.dt == 16) opts.biff = 2;\n\t\t\t\t\tif(file_depth++) break;\n\t\t\t\t\tout = ((options.dense ? [] : {})/*:any*/);\n\n\t\t\t\t\tif(opts.biff < 8 && !seen_codepage) { seen_codepage = true; set_cp(opts.codepage = options.codepage || 1252); }\n\n\t\t\t\t\tif(opts.biff < 5 || val.BIFFVer == 0 && val.dt == 0x1000) {\n\t\t\t\t\t\tif(cur_sheet === \"\") cur_sheet = \"Sheet1\";\n\t\t\t\t\t\trange = {s:{r:0,c:0},e:{r:0,c:0}};\n\t\t\t\t\t\t/* fake BoundSheet8 */\n\t\t\t\t\t\tvar fakebs8 = {pos: blob.l - length, name:cur_sheet};\n\t\t\t\t\t\tDirectory[fakebs8.pos] = fakebs8;\n\t\t\t\t\t\topts.snames.push(cur_sheet);\n\t\t\t\t\t}\n\t\t\t\t\telse cur_sheet = (Directory[s] || {name:\"\"}).name;\n\t\t\t\t\tif(val.dt == 0x20) out[\"!type\"] = \"chart\";\n\t\t\t\t\tif(val.dt == 0x40) out[\"!type\"] = \"macro\";\n\t\t\t\t\tmerges = [];\n\t\t\t\t\tobjects = [];\n\t\t\t\t\topts.arrayf = arrayf = [];\n\t\t\t\t\tcolinfo = []; rowinfo = [];\n\t\t\t\t\tseencol = false;\n\t\t\t\t\twsprops = {Hidden:(Directory[s]||{hs:0}).hs, name:cur_sheet };\n\t\t\t\t} break;\n\t\t\t\tcase 0x0203 /* Number */: case 0x0003 /* BIFF2NUM */: case 0x0002 /* BIFF2INT */: {\n\t\t\t\t\tif(out[\"!type\"] == \"chart\") if(options.dense ? (out[val.r]||[])[val.c]: out[encode_cell({c:val.c, r:val.r})]) ++val.c;\n\t\t\t\t\ttemp_val = ({ixfe: val.ixfe, XF: XFs[val.ixfe]||{}, v:val.val, t:'n'}/*:any*/);\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 0x0005: case 0x0205 /* BoolErr */: {\n\t\t\t\t\ttemp_val = ({ixfe: val.ixfe, XF: XFs[val.ixfe], v:val.val, t:val.t}/*:any*/);\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 0x027e /* RK */: {\n\t\t\t\t\ttemp_val = ({ixfe: val.ixfe, XF: XFs[val.ixfe], v:val.rknum, t:'n'}/*:any*/);\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 0x00bd /* MulRk */: {\n\t\t\t\t\tfor(var j = val.c; j <= val.C; ++j) {\n\t\t\t\t\t\tvar ixfe = val.rkrec[j-val.c][0];\n\t\t\t\t\t\ttemp_val= ({ixfe:ixfe, XF:XFs[ixfe], v:val.rkrec[j-val.c][1], t:'n'}/*:any*/);\n\t\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\t\taddcell({c:j, r:val.r}, temp_val, options);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x0006: case 0x0206: case 0x0406 /* Formula */: {\n\t\t\t\t\tif(val.val == 'String') { last_formula = val; break; }\n\t\t\t\t\ttemp_val = make_cell(val.val, val.cell.ixfe, val.tt);\n\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\tif(options.cellFormula) {\n\t\t\t\t\t\tvar _f = val.formula;\n\t\t\t\t\t\tif(_f && _f[0] && _f[0][0] && _f[0][0][0] == 'PtgExp') {\n\t\t\t\t\t\t\tvar _fr = _f[0][0][1][0], _fc = _f[0][0][1][1];\n\t\t\t\t\t\t\tvar _fe = encode_cell({r:_fr, c:_fc});\n\t\t\t\t\t\t\tif(sharedf[_fe]) temp_val.f = \"\"+stringify_formula(val.formula,range,val.cell,supbooks, opts);\n\t\t\t\t\t\t\telse temp_val.F = ((options.dense ? (out[_fr]||[])[_fc]: out[_fe]) || {}).F;\n\t\t\t\t\t\t} else temp_val.f = \"\"+stringify_formula(val.formula,range,val.cell,supbooks, opts);\n\t\t\t\t\t}\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell(val.cell, temp_val, options);\n\t\t\t\t\tlast_formula = val;\n\t\t\t\t} break;\n\t\t\t\tcase 0x0007: case 0x0207 /* String */: {\n\t\t\t\t\tif(last_formula) { /* technically always true */\n\t\t\t\t\t\tlast_formula.val = val;\n\t\t\t\t\t\ttemp_val = make_cell(val, last_formula.cell.ixfe, 's');\n\t\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\t\tif(options.cellFormula) {\n\t\t\t\t\t\t\ttemp_val.f = \"\"+stringify_formula(last_formula.formula, range, last_formula.cell, supbooks, opts);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\t\taddcell(last_formula.cell, temp_val, options);\n\t\t\t\t\t\tlast_formula = null;\n\t\t\t\t\t} else throw new Error(\"String record expects Formula\");\n\t\t\t\t} break;\n\t\t\t\tcase 0x0021: case 0x0221 /* Array */: {\n\t\t\t\t\tarrayf.push(val);\n\t\t\t\t\tvar _arraystart = encode_cell(val[0].s);\n\t\t\t\t\tcc = options.dense ? (out[val[0].s.r]||[])[val[0].s.c] : out[_arraystart];\n\t\t\t\t\tif(options.cellFormula && cc) {\n\t\t\t\t\t\tif(!last_formula) break; /* technically unreachable */\n\t\t\t\t\t\tif(!_arraystart || !cc) break;\n\t\t\t\t\t\tcc.f = \"\"+stringify_formula(val[1], range, val[0], supbooks, opts);\n\t\t\t\t\t\tcc.F = encode_range(val[0]);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x04bc /* ShrFmla */: {\n\t\t\t\t\tif(!options.cellFormula) break;\n\t\t\t\t\tif(last_cell) {\n\t\t\t\t\t\t/* TODO: capture range */\n\t\t\t\t\t\tif(!last_formula) break; /* technically unreachable */\n\t\t\t\t\t\tsharedf[encode_cell(last_formula.cell)]= val[0];\n\t\t\t\t\t\tcc = options.dense ? (out[last_formula.cell.r]||[])[last_formula.cell.c] : out[encode_cell(last_formula.cell)];\n\t\t\t\t\t\t(cc||{}).f = \"\"+stringify_formula(val[0], range, lastcell, supbooks, opts);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x00fd /* LabelSst */:\n\t\t\t\t\ttemp_val=make_cell(sst[val.isst].t, val.ixfe, 's');\n\t\t\t\t\tif(sst[val.isst].h) temp_val.h = sst[val.isst].h;\n\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0201 /* Blank */: if(options.sheetStubs) {\n\t\t\t\t\ttemp_val = ({ixfe: val.ixfe, XF: XFs[val.ixfe], t:'z'}/*:any*/);\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 0x00be /* MulBlank */: if(options.sheetStubs) {\n\t\t\t\t\tfor(var _j = val.c; _j <= val.C; ++_j) {\n\t\t\t\t\t\tvar _ixfe = val.ixfe[_j-val.c];\n\t\t\t\t\t\ttemp_val= ({ixfe:_ixfe, XF:XFs[_ixfe], t:'z'}/*:any*/);\n\t\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\t\taddcell({c:_j, r:val.r}, temp_val, options);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x00d6 /* RString */:\n\t\t\t\tcase 0x0204 /* Label */: case 0x0004 /* BIFF2STR */:\n\t\t\t\t\ttemp_val=make_cell(val.val, val.ixfe, 's');\n\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 0x0000: case 0x0200 /* Dimensions */: {\n\t\t\t\t\tif(file_depth === 1) range = val; /* TODO: stack */\n\t\t\t\t} break;\n\t\t\t\tcase 0x00fc /* SST */: {\n\t\t\t\t\tsst = val;\n\t\t\t\t} break;\n\t\t\t\tcase 0x041e /* Format */: { /* val = [id, fmt] */\n\t\t\t\t\tif(opts.biff == 4) {\n\t\t\t\t\t\tBIFF2FmtTable[BIFF2Fmt++] = val[1];\n\t\t\t\t\t\tfor(var b4idx = 0; b4idx < BIFF2Fmt + 163; ++b4idx) if(table_fmt[b4idx] == val[1]) break;\n\t\t\t\t\t\tif(b4idx >= 163) SSF_load(val[1], BIFF2Fmt + 163);\n\t\t\t\t\t}\n\t\t\t\t\telse SSF_load(val[1], val[0]);\n\t\t\t\t} break;\n\t\t\t\tcase 0x001e /* BIFF2FORMAT */: {\n\t\t\t\t\tBIFF2FmtTable[BIFF2Fmt++] = val;\n\t\t\t\t\tfor(var b2idx = 0; b2idx < BIFF2Fmt + 163; ++b2idx) if(table_fmt[b2idx] == val) break;\n\t\t\t\t\tif(b2idx >= 163) SSF_load(val, BIFF2Fmt + 163);\n\t\t\t\t} break;\n\n\t\t\t\tcase 0x00e5 /* MergeCells */: merges = merges.concat(val); break;\n\n\t\t\t\tcase 0x005d /* Obj */: objects[val.cmo[0]] = opts.lastobj = val; break;\n\t\t\t\tcase 0x01b6 /* TxO */: opts.lastobj.TxO = val; break;\n\t\t\t\tcase 0x007f /* ImData */: opts.lastobj.ImData = val; break;\n\n\t\t\t\tcase 0x01b8 /* HLink */: {\n\t\t\t\t\tfor(rngR = val[0].s.r; rngR <= val[0].e.r; ++rngR)\n\t\t\t\t\t\tfor(rngC = val[0].s.c; rngC <= val[0].e.c; ++rngC) {\n\t\t\t\t\t\t\tcc = options.dense ? (out[rngR]||[])[rngC] : out[encode_cell({c:rngC,r:rngR})];\n\t\t\t\t\t\t\tif(cc) cc.l = val[1];\n\t\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x0800 /* HLinkTooltip */: {\n\t\t\t\t\tfor(rngR = val[0].s.r; rngR <= val[0].e.r; ++rngR)\n\t\t\t\t\t\tfor(rngC = val[0].s.c; rngC <= val[0].e.c; ++rngC) {\n\t\t\t\t\t\t\tcc = options.dense ? (out[rngR]||[])[rngC] : out[encode_cell({c:rngC,r:rngR})];\n\t\t\t\t\t\t\tif(cc && cc.l) cc.l.Tooltip = val[1];\n\t\t\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x001c /* Note */: {\n\t\t\t\t\tif(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */\n\t\t\t\t\tcc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];\n\t\t\t\t\tvar noteobj = objects[val[2]];\n\t\t\t\t\tif(!cc) {\n\t\t\t\t\t\tif(options.dense) {\n\t\t\t\t\t\t\tif(!out[val[0].r]) out[val[0].r] = [];\n\t\t\t\t\t\t\tcc = out[val[0].r][val[0].c] = ({t:\"z\"}/*:any*/);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tcc = out[encode_cell(val[0])] = ({t:\"z\"}/*:any*/);\n\t\t\t\t\t\t}\n\t\t\t\t\t\trange.e.r = Math.max(range.e.r, val[0].r);\n\t\t\t\t\t\trange.s.r = Math.min(range.s.r, val[0].r);\n\t\t\t\t\t\trange.e.c = Math.max(range.e.c, val[0].c);\n\t\t\t\t\t\trange.s.c = Math.min(range.s.c, val[0].c);\n\t\t\t\t\t}\n\t\t\t\t\tif(!cc.c) cc.c = [];\n\t\t\t\t\tcmnt = {a:val[1],t:noteobj.TxO.t};\n\t\t\t\t\tcc.c.push(cmnt);\n\t\t\t\t} break;\n\t\t\t\tcase 0x087d /* XFExt */: update_xfext(XFs[val.ixfe], val.ext); break;\n\t\t\t\tcase 0x007d /* ColInfo */: {\n\t\t\t\t\tif(!opts.cellStyles) break;\n\t\t\t\t\twhile(val.e >= val.s) {\n\t\t\t\t\t\tcolinfo[val.e--] = { width: val.w/256, level: (val.level || 0), hidden: !!(val.flags & 1) };\n\t\t\t\t\t\tif(!seencol) { seencol = true; find_mdw_colw(val.w/256); }\n\t\t\t\t\t\tprocess_col(colinfo[val.e+1]);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x0208 /* Row */: {\n\t\t\t\t\tvar rowobj = {};\n\t\t\t\t\tif(val.level != null) { rowinfo[val.r] = rowobj; rowobj.level = val.level; }\n\t\t\t\t\tif(val.hidden) { rowinfo[val.r] = rowobj; rowobj.hidden = true; }\n\t\t\t\t\tif(val.hpt) {\n\t\t\t\t\t\trowinfo[val.r] = rowobj;\n\t\t\t\t\t\trowobj.hpt = val.hpt; rowobj.hpx = pt2px(val.hpt);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x0026 /* LeftMargin */:\n\t\t\t\tcase 0x0027 /* RightMargin */:\n\t\t\t\tcase 0x0028 /* TopMargin */:\n\t\t\t\tcase 0x0029 /* BottomMargin */:\n\t\t\t\t\tif(!out['!margins']) default_margins(out['!margins'] = {});\n\t\t\t\t\tout['!margins'][({0x26: \"left\", 0x27:\"right\", 0x28:\"top\", 0x29:\"bottom\"})[RecordType]] = val;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x00a1 /* Setup */: // TODO\n\t\t\t\t\tif(!out['!margins']) default_margins(out['!margins'] = {});\n\t\t\t\t\tout['!margins'].header = val.header;\n\t\t\t\t\tout['!margins'].footer = val.footer;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x023e /* Window2 */: // TODO\n\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\tif(val.RTL) Workbook.Views[0].RTL = true;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0092 /* Palette */: palette = val; break;\n\t\t\t\tcase 0x0896 /* Theme */: themes = val; break;\n\t\t\t\tcase 0x008c /* Country */: country = val; break;\n\t\t\t\tcase 0x01ba /* CodeName */: {\n\t\t\t\t\t/*:: if(!Workbook.WBProps) Workbook.WBProps = {}; */\n\t\t\t\t\tif(!cur_sheet) Workbook.WBProps.CodeName = val || \"ThisWorkbook\";\n\t\t\t\t\telse wsprops.CodeName = val || wsprops.name;\n\t\t\t\t} break;\n\t\t\t}\n\t\t} else {\n\t\t\tif(!R) console.error(\"Missing Info for XLS Record 0x\" + RecordType.toString(16));\n\t\t\tblob.l += length;\n\t\t}\n\t}\n\twb.SheetNames=keys(Directory).sort(function(a,b) { return Number(a) - Number(b); }).map(function(x){return Directory[x].name;});\n\tif(!options.bookSheets) wb.Sheets=Sheets;\n\tif(!wb.SheetNames.length && Preamble[\"!ref\"]) {\n\t\twb.SheetNames.push(\"Sheet1\");\n\t\t/*jshint -W069 */\n\t\tif(wb.Sheets) wb.Sheets[\"Sheet1\"] = Preamble;\n\t\t/*jshint +W069 */\n\t} else wb.Preamble=Preamble;\n\tif(wb.Sheets) FilterDatabases.forEach(function(r,i) { wb.Sheets[wb.SheetNames[i]]['!autofilter'] = r; });\n\twb.Strings = sst;\n\twb.SSF = dup(table_fmt);\n\tif(opts.enc) wb.Encryption = opts.enc;\n\tif(themes) wb.Themes = themes;\n\twb.Metadata = {};\n\tif(country !== undefined) wb.Metadata.Country = country;\n\tif(supbooks.names.length > 0) Workbook.Names = supbooks.names;\n\twb.Workbook = Workbook;\n\treturn wb;\n}\n\n/* TODO: split props*/\nvar PSCLSID = {\n\tSI: \"e0859ff2f94f6810ab9108002b27b3d9\",\n\tDSI: \"02d5cdd59c2e1b10939708002b2cf9ae\",\n\tUDI: \"05d5cdd59c2e1b10939708002b2cf9ae\"\n};\nfunction parse_xls_props(cfb/*:CFBContainer*/, props, o) {\n\t/* [MS-OSHARED] 2.3.3.2.2 Document Summary Information Property Set */\n\tvar DSI = CFB.find(cfb, '/!DocumentSummaryInformation');\n\tif(DSI && DSI.size > 0) try {\n\t\tvar DocSummary = parse_PropertySetStream(DSI, DocSummaryPIDDSI, PSCLSID.DSI);\n\t\tfor(var d in DocSummary) props[d] = DocSummary[d];\n\t} catch(e) {if(o.WTF) throw e;/* empty */}\n\n\t/* [MS-OSHARED] 2.3.3.2.1 Summary Information Property Set*/\n\tvar SI = CFB.find(cfb, '/!SummaryInformation');\n\tif(SI && SI.size > 0) try {\n\t\tvar Summary = parse_PropertySetStream(SI, SummaryPIDSI, PSCLSID.SI);\n\t\tfor(var s in Summary) if(props[s] == null) props[s] = Summary[s];\n\t} catch(e) {if(o.WTF) throw e;/* empty */}\n\n\tif(props.HeadingPairs && props.TitlesOfParts) {\n\t\tload_props_pairs(props.HeadingPairs, props.TitlesOfParts, props, o);\n\t\tdelete props.HeadingPairs; delete props.TitlesOfParts;\n\t}\n}\nfunction write_xls_props(wb/*:Workbook*/, cfb/*:CFBContainer*/) {\n\tvar DSEntries = [], SEntries = [], CEntries = [];\n\tvar i = 0, Keys;\n\tvar DocSummaryRE/*:{[key:string]:string}*/ = evert_key(DocSummaryPIDDSI, \"n\");\n\tvar SummaryRE/*:{[key:string]:string}*/ = evert_key(SummaryPIDSI, \"n\");\n\tif(wb.Props) {\n\t\tKeys = keys(wb.Props);\n\t\t// $FlowIgnore\n\t\tfor(i = 0; i < Keys.length; ++i) (Object.prototype.hasOwnProperty.call(DocSummaryRE, Keys[i]) ? DSEntries : Object.prototype.hasOwnProperty.call(SummaryRE, Keys[i]) ? SEntries : CEntries).push([Keys[i], wb.Props[Keys[i]]]);\n\t}\n\tif(wb.Custprops) {\n\t\tKeys = keys(wb.Custprops);\n\t\t// $FlowIgnore\n\t\tfor(i = 0; i < Keys.length; ++i) if(!Object.prototype.hasOwnProperty.call((wb.Props||{}), Keys[i])) (Object.prototype.hasOwnProperty.call(DocSummaryRE, Keys[i]) ? DSEntries : Object.prototype.hasOwnProperty.call(SummaryRE, Keys[i]) ? SEntries : CEntries).push([Keys[i], wb.Custprops[Keys[i]]]);\n\t}\n\tvar CEntries2 = [];\n\tfor(i = 0; i < CEntries.length; ++i) {\n\t\tif(XLSPSSkip.indexOf(CEntries[i][0]) > -1 || PseudoPropsPairs.indexOf(CEntries[i][0]) > -1) continue;\n\t\tif(CEntries[i][1] == null) continue;\n\t\tCEntries2.push(CEntries[i]);\n\t}\n\tif(SEntries.length) CFB.utils.cfb_add(cfb, \"/\\u0005SummaryInformation\", write_PropertySetStream(SEntries, PSCLSID.SI, SummaryRE, SummaryPIDSI));\n\tif(DSEntries.length || CEntries2.length) CFB.utils.cfb_add(cfb, \"/\\u0005DocumentSummaryInformation\", write_PropertySetStream(DSEntries, PSCLSID.DSI, DocSummaryRE, DocSummaryPIDDSI, CEntries2.length ? CEntries2 : null, PSCLSID.UDI));\n}\n\nfunction parse_xlscfb(cfb/*:any*/, options/*:?ParseOpts*/)/*:Workbook*/ {\nif(!options) options = {};\nfix_read_opts(options);\nreset_cp();\nif(options.codepage) set_ansi(options.codepage);\nvar CompObj/*:?CFBEntry*/, WB/*:?any*/;\nif(cfb.FullPaths) {\n\tif(CFB.find(cfb, '/encryption')) throw new Error(\"File is password-protected\");\n\tCompObj = CFB.find(cfb, '!CompObj');\n\tWB = CFB.find(cfb, '/Workbook') || CFB.find(cfb, '/Book');\n} else {\n\tswitch(options.type) {\n\t\tcase 'base64': cfb = s2a(Base64_decode(cfb)); break;\n\t\tcase 'binary': cfb = s2a(cfb); break;\n\t\tcase 'buffer': break;\n\t\tcase 'array': if(!Array.isArray(cfb)) cfb = Array.prototype.slice.call(cfb); break;\n\t}\n\tprep_blob(cfb, 0);\n\tWB = ({content: cfb}/*:any*/);\n}\nvar /*::CompObjP, */WorkbookP/*:: :Workbook = XLSX.utils.book_new(); */;\n\nvar _data/*:?any*/;\nif(CompObj) /*::CompObjP = */parse_compobj(CompObj);\nif(options.bookProps && !options.bookSheets) WorkbookP = ({}/*:any*/);\nelse/*:: if(cfb instanceof CFBContainer) */ {\n\tvar T = has_buf ? 'buffer' : 'array';\n\tif(WB && WB.content) WorkbookP = parse_workbook(WB.content, options);\n\t/* Quattro Pro 7-8 */\n\telse if((_data=CFB.find(cfb, 'PerfectOffice_MAIN')) && _data.content) WorkbookP = WK_.to_workbook(_data.content, (options.type = T, options));\n\t/* Quattro Pro 9 */\n\telse if((_data=CFB.find(cfb, 'NativeContent_MAIN')) && _data.content) WorkbookP = WK_.to_workbook(_data.content, (options.type = T, options));\n\t/* Works 4 for Mac */\n\telse if((_data=CFB.find(cfb, 'MN0')) && _data.content) throw new Error(\"Unsupported Works 4 for Mac file\");\n\telse throw new Error(\"Cannot find Workbook stream\");\n\tif(options.bookVBA && cfb.FullPaths && CFB.find(cfb, '/_VBA_PROJECT_CUR/VBA/dir')) WorkbookP.vbaraw = make_vba_xls(cfb);\n}\n\nvar props = {};\nif(cfb.FullPaths) parse_xls_props(/*::((*/cfb/*:: :any):CFBContainer)*/, props, options);\n\nWorkbookP.Props = WorkbookP.Custprops = props; /* TODO: split up properties */\nif(options.bookFiles) WorkbookP.cfb = cfb;\n/*WorkbookP.CompObjP = CompObjP; // TODO: storage? */\nreturn WorkbookP;\n}\n\n\nfunction write_xlscfb(wb/*:Workbook*/, opts/*:WriteOpts*/)/*:CFBContainer*/ {\n\tvar o = opts || {};\n\tvar cfb = CFB.utils.cfb_new({root:\"R\"});\n\tvar wbpath = \"/Workbook\";\n\tswitch(o.bookType || \"xls\") {\n\t\tcase \"xls\": o.bookType = \"biff8\";\n\t\t/* falls through */\n\t\tcase \"xla\": if(!o.bookType) o.bookType = \"xla\";\n\t\t/* falls through */\n\t\tcase \"biff8\": wbpath = \"/Workbook\"; o.biff = 8; break;\n\t\tcase \"biff5\": wbpath = \"/Book\"; o.biff = 5; break;\n\t\tdefault: throw new Error(\"invalid type \" + o.bookType + \" for XLS CFB\");\n\t}\n\tCFB.utils.cfb_add(cfb, wbpath, write_biff_buf(wb, o));\n\tif(o.biff == 8 && (wb.Props || wb.Custprops)) write_xls_props(wb, cfb);\n\t// TODO: SI, DSI, CO\n\tif(o.biff == 8 && wb.vbaraw) fill_vba_xls(cfb, CFB.read(wb.vbaraw, {type: typeof wb.vbaraw == \"string\" ? \"binary\" : \"buffer\"}));\n\treturn cfb;\n}\n/* [MS-XLSB] 2.3 Record Enumeration */\nvar XLSBRecordEnum = {\n\t/*::[*/0x0000/*::]*/: { /* n:\"BrtRowHdr\", */ f:parse_BrtRowHdr },\n\t/*::[*/0x0001/*::]*/: { /* n:\"BrtCellBlank\", */ f:parse_BrtCellBlank },\n\t/*::[*/0x0002/*::]*/: { /* n:\"BrtCellRk\", */ f:parse_BrtCellRk },\n\t/*::[*/0x0003/*::]*/: { /* n:\"BrtCellError\", */ f:parse_BrtCellError },\n\t/*::[*/0x0004/*::]*/: { /* n:\"BrtCellBool\", */ f:parse_BrtCellBool },\n\t/*::[*/0x0005/*::]*/: { /* n:\"BrtCellReal\", */ f:parse_BrtCellReal },\n\t/*::[*/0x0006/*::]*/: { /* n:\"BrtCellSt\", */ f:parse_BrtCellSt },\n\t/*::[*/0x0007/*::]*/: { /* n:\"BrtCellIsst\", */ f:parse_BrtCellIsst },\n\t/*::[*/0x0008/*::]*/: { /* n:\"BrtFmlaString\", */ f:parse_BrtFmlaString },\n\t/*::[*/0x0009/*::]*/: { /* n:\"BrtFmlaNum\", */ f:parse_BrtFmlaNum },\n\t/*::[*/0x000A/*::]*/: { /* n:\"BrtFmlaBool\", */ f:parse_BrtFmlaBool },\n\t/*::[*/0x000B/*::]*/: { /* n:\"BrtFmlaError\", */ f:parse_BrtFmlaError },\n\t/*::[*/0x000C/*::]*/: { /* n:\"BrtShortBlank\", */ f:parse_BrtShortBlank },\n\t/*::[*/0x000D/*::]*/: { /* n:\"BrtShortRk\", */ f:parse_BrtShortRk },\n\t/*::[*/0x000E/*::]*/: { /* n:\"BrtShortError\", */ f:parse_BrtShortError },\n\t/*::[*/0x000F/*::]*/: { /* n:\"BrtShortBool\", */ f:parse_BrtShortBool },\n\t/*::[*/0x0010/*::]*/: { /* n:\"BrtShortReal\", */ f:parse_BrtShortReal },\n\t/*::[*/0x0011/*::]*/: { /* n:\"BrtShortSt\", */ f:parse_BrtShortSt },\n\t/*::[*/0x0012/*::]*/: { /* n:\"BrtShortIsst\", */ f:parse_BrtShortIsst },\n\t/*::[*/0x0013/*::]*/: { /* n:\"BrtSSTItem\", */ f:parse_RichStr },\n\t/*::[*/0x0014/*::]*/: { /* n:\"BrtPCDIMissing\" */ },\n\t/*::[*/0x0015/*::]*/: { /* n:\"BrtPCDINumber\" */ },\n\t/*::[*/0x0016/*::]*/: { /* n:\"BrtPCDIBoolean\" */ },\n\t/*::[*/0x0017/*::]*/: { /* n:\"BrtPCDIError\" */ },\n\t/*::[*/0x0018/*::]*/: { /* n:\"BrtPCDIString\" */ },\n\t/*::[*/0x0019/*::]*/: { /* n:\"BrtPCDIDatetime\" */ },\n\t/*::[*/0x001A/*::]*/: { /* n:\"BrtPCDIIndex\" */ },\n\t/*::[*/0x001B/*::]*/: { /* n:\"BrtPCDIAMissing\" */ },\n\t/*::[*/0x001C/*::]*/: { /* n:\"BrtPCDIANumber\" */ },\n\t/*::[*/0x001D/*::]*/: { /* n:\"BrtPCDIABoolean\" */ },\n\t/*::[*/0x001E/*::]*/: { /* n:\"BrtPCDIAError\" */ },\n\t/*::[*/0x001F/*::]*/: { /* n:\"BrtPCDIAString\" */ },\n\t/*::[*/0x0020/*::]*/: { /* n:\"BrtPCDIADatetime\" */ },\n\t/*::[*/0x0021/*::]*/: { /* n:\"BrtPCRRecord\" */ },\n\t/*::[*/0x0022/*::]*/: { /* n:\"BrtPCRRecordDt\" */ },\n\t/*::[*/0x0023/*::]*/: { /* n:\"BrtFRTBegin\", */ T:1 },\n\t/*::[*/0x0024/*::]*/: { /* n:\"BrtFRTEnd\", */ T:-1 },\n\t/*::[*/0x0025/*::]*/: { /* n:\"BrtACBegin\", */ T:1 },\n\t/*::[*/0x0026/*::]*/: { /* n:\"BrtACEnd\", */ T:-1 },\n\t/*::[*/0x0027/*::]*/: { /* n:\"BrtName\", */ f:parse_BrtName },\n\t/*::[*/0x0028/*::]*/: { /* n:\"BrtIndexRowBlock\" */ },\n\t/*::[*/0x002A/*::]*/: { /* n:\"BrtIndexBlock\" */ },\n\t/*::[*/0x002B/*::]*/: { /* n:\"BrtFont\", */ f:parse_BrtFont },\n\t/*::[*/0x002C/*::]*/: { /* n:\"BrtFmt\", */ f:parse_BrtFmt },\n\t/*::[*/0x002D/*::]*/: { /* n:\"BrtFill\", */ f:parse_BrtFill },\n\t/*::[*/0x002E/*::]*/: { /* n:\"BrtBorder\", */ f:parse_BrtBorder },\n\t/*::[*/0x002F/*::]*/: { /* n:\"BrtXF\", */ f:parse_BrtXF },\n\t/*::[*/0x0030/*::]*/: { /* n:\"BrtStyle\" */ },\n\t/*::[*/0x0031/*::]*/: { /* n:\"BrtCellMeta\", */ f:parse_Int32LE },\n\t/*::[*/0x0032/*::]*/: { /* n:\"BrtValueMeta\" */ },\n\t/*::[*/0x0033/*::]*/: { /* n:\"BrtMdb\" */ f:parse_BrtMdb },\n\t/*::[*/0x0034/*::]*/: { /* n:\"BrtBeginFmd\", */ T:1 },\n\t/*::[*/0x0035/*::]*/: { /* n:\"BrtEndFmd\", */ T:-1 },\n\t/*::[*/0x0036/*::]*/: { /* n:\"BrtBeginMdx\", */ T:1 },\n\t/*::[*/0x0037/*::]*/: { /* n:\"BrtEndMdx\", */ T:-1 },\n\t/*::[*/0x0038/*::]*/: { /* n:\"BrtBeginMdxTuple\", */ T:1 },\n\t/*::[*/0x0039/*::]*/: { /* n:\"BrtEndMdxTuple\", */ T:-1 },\n\t/*::[*/0x003A/*::]*/: { /* n:\"BrtMdxMbrIstr\" */ },\n\t/*::[*/0x003B/*::]*/: { /* n:\"BrtStr\" */ },\n\t/*::[*/0x003C/*::]*/: { /* n:\"BrtColInfo\", */ f:parse_ColInfo },\n\t/*::[*/0x003E/*::]*/: { /* n:\"BrtCellRString\", */ f:parse_BrtCellRString },\n\t/*::[*/0x003F/*::]*/: { /* n:\"BrtCalcChainItem$\", */ f:parse_BrtCalcChainItem$ },\n\t/*::[*/0x0040/*::]*/: { /* n:\"BrtDVal\", */ f:parse_BrtDVal },\n\t/*::[*/0x0041/*::]*/: { /* n:\"BrtSxvcellNum\" */ },\n\t/*::[*/0x0042/*::]*/: { /* n:\"BrtSxvcellStr\" */ },\n\t/*::[*/0x0043/*::]*/: { /* n:\"BrtSxvcellBool\" */ },\n\t/*::[*/0x0044/*::]*/: { /* n:\"BrtSxvcellErr\" */ },\n\t/*::[*/0x0045/*::]*/: { /* n:\"BrtSxvcellDate\" */ },\n\t/*::[*/0x0046/*::]*/: { /* n:\"BrtSxvcellNil\" */ },\n\t/*::[*/0x0080/*::]*/: { /* n:\"BrtFileVersion\" */ },\n\t/*::[*/0x0081/*::]*/: { /* n:\"BrtBeginSheet\", */ T:1 },\n\t/*::[*/0x0082/*::]*/: { /* n:\"BrtEndSheet\", */ T:-1 },\n\t/*::[*/0x0083/*::]*/: { /* n:\"BrtBeginBook\", */ T:1, f:parsenoop, p:0 },\n\t/*::[*/0x0084/*::]*/: { /* n:\"BrtEndBook\", */ T:-1 },\n\t/*::[*/0x0085/*::]*/: { /* n:\"BrtBeginWsViews\", */ T:1 },\n\t/*::[*/0x0086/*::]*/: { /* n:\"BrtEndWsViews\", */ T:-1 },\n\t/*::[*/0x0087/*::]*/: { /* n:\"BrtBeginBookViews\", */ T:1 },\n\t/*::[*/0x0088/*::]*/: { /* n:\"BrtEndBookViews\", */ T:-1 },\n\t/*::[*/0x0089/*::]*/: { /* n:\"BrtBeginWsView\", */ T:1, f:parse_BrtBeginWsView },\n\t/*::[*/0x008A/*::]*/: { /* n:\"BrtEndWsView\", */ T:-1 },\n\t/*::[*/0x008B/*::]*/: { /* n:\"BrtBeginCsViews\", */ T:1 },\n\t/*::[*/0x008C/*::]*/: { /* n:\"BrtEndCsViews\", */ T:-1 },\n\t/*::[*/0x008D/*::]*/: { /* n:\"BrtBeginCsView\", */ T:1 },\n\t/*::[*/0x008E/*::]*/: { /* n:\"BrtEndCsView\", */ T:-1 },\n\t/*::[*/0x008F/*::]*/: { /* n:\"BrtBeginBundleShs\", */ T:1 },\n\t/*::[*/0x0090/*::]*/: { /* n:\"BrtEndBundleShs\", */ T:-1 },\n\t/*::[*/0x0091/*::]*/: { /* n:\"BrtBeginSheetData\", */ T:1 },\n\t/*::[*/0x0092/*::]*/: { /* n:\"BrtEndSheetData\", */ T:-1 },\n\t/*::[*/0x0093/*::]*/: { /* n:\"BrtWsProp\", */ f:parse_BrtWsProp },\n\t/*::[*/0x0094/*::]*/: { /* n:\"BrtWsDim\", */ f:parse_BrtWsDim, p:16 },\n\t/*::[*/0x0097/*::]*/: { /* n:\"BrtPane\", */ f:parse_BrtPane },\n\t/*::[*/0x0098/*::]*/: { /* n:\"BrtSel\" */ },\n\t/*::[*/0x0099/*::]*/: { /* n:\"BrtWbProp\", */ f:parse_BrtWbProp },\n\t/*::[*/0x009A/*::]*/: { /* n:\"BrtWbFactoid\" */ },\n\t/*::[*/0x009B/*::]*/: { /* n:\"BrtFileRecover\" */ },\n\t/*::[*/0x009C/*::]*/: { /* n:\"BrtBundleSh\", */ f:parse_BrtBundleSh },\n\t/*::[*/0x009D/*::]*/: { /* n:\"BrtCalcProp\" */ },\n\t/*::[*/0x009E/*::]*/: { /* n:\"BrtBookView\" */ },\n\t/*::[*/0x009F/*::]*/: { /* n:\"BrtBeginSst\", */ T:1, f:parse_BrtBeginSst },\n\t/*::[*/0x00A0/*::]*/: { /* n:\"BrtEndSst\", */ T:-1 },\n\t/*::[*/0x00A1/*::]*/: { /* n:\"BrtBeginAFilter\", */ T:1, f:parse_UncheckedRfX },\n\t/*::[*/0x00A2/*::]*/: { /* n:\"BrtEndAFilter\", */ T:-1 },\n\t/*::[*/0x00A3/*::]*/: { /* n:\"BrtBeginFilterColumn\", */ T:1 },\n\t/*::[*/0x00A4/*::]*/: { /* n:\"BrtEndFilterColumn\", */ T:-1 },\n\t/*::[*/0x00A5/*::]*/: { /* n:\"BrtBeginFilters\", */ T:1 },\n\t/*::[*/0x00A6/*::]*/: { /* n:\"BrtEndFilters\", */ T:-1 },\n\t/*::[*/0x00A7/*::]*/: { /* n:\"BrtFilter\" */ },\n\t/*::[*/0x00A8/*::]*/: { /* n:\"BrtColorFilter\" */ },\n\t/*::[*/0x00A9/*::]*/: { /* n:\"BrtIconFilter\" */ },\n\t/*::[*/0x00AA/*::]*/: { /* n:\"BrtTop10Filter\" */ },\n\t/*::[*/0x00AB/*::]*/: { /* n:\"BrtDynamicFilter\" */ },\n\t/*::[*/0x00AC/*::]*/: { /* n:\"BrtBeginCustomFilters\", */ T:1 },\n\t/*::[*/0x00AD/*::]*/: { /* n:\"BrtEndCustomFilters\", */ T:-1 },\n\t/*::[*/0x00AE/*::]*/: { /* n:\"BrtCustomFilter\" */ },\n\t/*::[*/0x00AF/*::]*/: { /* n:\"BrtAFilterDateGroupItem\" */ },\n\t/*::[*/0x00B0/*::]*/: { /* n:\"BrtMergeCell\", */ f:parse_BrtMergeCell },\n\t/*::[*/0x00B1/*::]*/: { /* n:\"BrtBeginMergeCells\", */ T:1 },\n\t/*::[*/0x00B2/*::]*/: { /* n:\"BrtEndMergeCells\", */ T:-1 },\n\t/*::[*/0x00B3/*::]*/: { /* n:\"BrtBeginPivotCacheDef\", */ T:1 },\n\t/*::[*/0x00B4/*::]*/: { /* n:\"BrtEndPivotCacheDef\", */ T:-1 },\n\t/*::[*/0x00B5/*::]*/: { /* n:\"BrtBeginPCDFields\", */ T:1 },\n\t/*::[*/0x00B6/*::]*/: { /* n:\"BrtEndPCDFields\", */ T:-1 },\n\t/*::[*/0x00B7/*::]*/: { /* n:\"BrtBeginPCDField\", */ T:1 },\n\t/*::[*/0x00B8/*::]*/: { /* n:\"BrtEndPCDField\", */ T:-1 },\n\t/*::[*/0x00B9/*::]*/: { /* n:\"BrtBeginPCDSource\", */ T:1 },\n\t/*::[*/0x00BA/*::]*/: { /* n:\"BrtEndPCDSource\", */ T:-1 },\n\t/*::[*/0x00BB/*::]*/: { /* n:\"BrtBeginPCDSRange\", */ T:1 },\n\t/*::[*/0x00BC/*::]*/: { /* n:\"BrtEndPCDSRange\", */ T:-1 },\n\t/*::[*/0x00BD/*::]*/: { /* n:\"BrtBeginPCDFAtbl\", */ T:1 },\n\t/*::[*/0x00BE/*::]*/: { /* n:\"BrtEndPCDFAtbl\", */ T:-1 },\n\t/*::[*/0x00BF/*::]*/: { /* n:\"BrtBeginPCDIRun\", */ T:1 },\n\t/*::[*/0x00C0/*::]*/: { /* n:\"BrtEndPCDIRun\", */ T:-1 },\n\t/*::[*/0x00C1/*::]*/: { /* n:\"BrtBeginPivotCacheRecords\", */ T:1 },\n\t/*::[*/0x00C2/*::]*/: { /* n:\"BrtEndPivotCacheRecords\", */ T:-1 },\n\t/*::[*/0x00C3/*::]*/: { /* n:\"BrtBeginPCDHierarchies\", */ T:1 },\n\t/*::[*/0x00C4/*::]*/: { /* n:\"BrtEndPCDHierarchies\", */ T:-1 },\n\t/*::[*/0x00C5/*::]*/: { /* n:\"BrtBeginPCDHierarchy\", */ T:1 },\n\t/*::[*/0x00C6/*::]*/: { /* n:\"BrtEndPCDHierarchy\", */ T:-1 },\n\t/*::[*/0x00C7/*::]*/: { /* n:\"BrtBeginPCDHFieldsUsage\", */ T:1 },\n\t/*::[*/0x00C8/*::]*/: { /* n:\"BrtEndPCDHFieldsUsage\", */ T:-1 },\n\t/*::[*/0x00C9/*::]*/: { /* n:\"BrtBeginExtConnection\", */ T:1 },\n\t/*::[*/0x00CA/*::]*/: { /* n:\"BrtEndExtConnection\", */ T:-1 },\n\t/*::[*/0x00CB/*::]*/: { /* n:\"BrtBeginECDbProps\", */ T:1 },\n\t/*::[*/0x00CC/*::]*/: { /* n:\"BrtEndECDbProps\", */ T:-1 },\n\t/*::[*/0x00CD/*::]*/: { /* n:\"BrtBeginECOlapProps\", */ T:1 },\n\t/*::[*/0x00CE/*::]*/: { /* n:\"BrtEndECOlapProps\", */ T:-1 },\n\t/*::[*/0x00CF/*::]*/: { /* n:\"BrtBeginPCDSConsol\", */ T:1 },\n\t/*::[*/0x00D0/*::]*/: { /* n:\"BrtEndPCDSConsol\", */ T:-1 },\n\t/*::[*/0x00D1/*::]*/: { /* n:\"BrtBeginPCDSCPages\", */ T:1 },\n\t/*::[*/0x00D2/*::]*/: { /* n:\"BrtEndPCDSCPages\", */ T:-1 },\n\t/*::[*/0x00D3/*::]*/: { /* n:\"BrtBeginPCDSCPage\", */ T:1 },\n\t/*::[*/0x00D4/*::]*/: { /* n:\"BrtEndPCDSCPage\", */ T:-1 },\n\t/*::[*/0x00D5/*::]*/: { /* n:\"BrtBeginPCDSCPItem\", */ T:1 },\n\t/*::[*/0x00D6/*::]*/: { /* n:\"BrtEndPCDSCPItem\", */ T:-1 },\n\t/*::[*/0x00D7/*::]*/: { /* n:\"BrtBeginPCDSCSets\", */ T:1 },\n\t/*::[*/0x00D8/*::]*/: { /* n:\"BrtEndPCDSCSets\", */ T:-1 },\n\t/*::[*/0x00D9/*::]*/: { /* n:\"BrtBeginPCDSCSet\", */ T:1 },\n\t/*::[*/0x00DA/*::]*/: { /* n:\"BrtEndPCDSCSet\", */ T:-1 },\n\t/*::[*/0x00DB/*::]*/: { /* n:\"BrtBeginPCDFGroup\", */ T:1 },\n\t/*::[*/0x00DC/*::]*/: { /* n:\"BrtEndPCDFGroup\", */ T:-1 },\n\t/*::[*/0x00DD/*::]*/: { /* n:\"BrtBeginPCDFGItems\", */ T:1 },\n\t/*::[*/0x00DE/*::]*/: { /* n:\"BrtEndPCDFGItems\", */ T:-1 },\n\t/*::[*/0x00DF/*::]*/: { /* n:\"BrtBeginPCDFGRange\", */ T:1 },\n\t/*::[*/0x00E0/*::]*/: { /* n:\"BrtEndPCDFGRange\", */ T:-1 },\n\t/*::[*/0x00E1/*::]*/: { /* n:\"BrtBeginPCDFGDiscrete\", */ T:1 },\n\t/*::[*/0x00E2/*::]*/: { /* n:\"BrtEndPCDFGDiscrete\", */ T:-1 },\n\t/*::[*/0x00E3/*::]*/: { /* n:\"BrtBeginPCDSDTupleCache\", */ T:1 },\n\t/*::[*/0x00E4/*::]*/: { /* n:\"BrtEndPCDSDTupleCache\", */ T:-1 },\n\t/*::[*/0x00E5/*::]*/: { /* n:\"BrtBeginPCDSDTCEntries\", */ T:1 },\n\t/*::[*/0x00E6/*::]*/: { /* n:\"BrtEndPCDSDTCEntries\", */ T:-1 },\n\t/*::[*/0x00E7/*::]*/: { /* n:\"BrtBeginPCDSDTCEMembers\", */ T:1 },\n\t/*::[*/0x00E8/*::]*/: { /* n:\"BrtEndPCDSDTCEMembers\", */ T:-1 },\n\t/*::[*/0x00E9/*::]*/: { /* n:\"BrtBeginPCDSDTCEMember\", */ T:1 },\n\t/*::[*/0x00EA/*::]*/: { /* n:\"BrtEndPCDSDTCEMember\", */ T:-1 },\n\t/*::[*/0x00EB/*::]*/: { /* n:\"BrtBeginPCDSDTCQueries\", */ T:1 },\n\t/*::[*/0x00EC/*::]*/: { /* n:\"BrtEndPCDSDTCQueries\", */ T:-1 },\n\t/*::[*/0x00ED/*::]*/: { /* n:\"BrtBeginPCDSDTCQuery\", */ T:1 },\n\t/*::[*/0x00EE/*::]*/: { /* n:\"BrtEndPCDSDTCQuery\", */ T:-1 },\n\t/*::[*/0x00EF/*::]*/: { /* n:\"BrtBeginPCDSDTCSets\", */ T:1 },\n\t/*::[*/0x00F0/*::]*/: { /* n:\"BrtEndPCDSDTCSets\", */ T:-1 },\n\t/*::[*/0x00F1/*::]*/: { /* n:\"BrtBeginPCDSDTCSet\", */ T:1 },\n\t/*::[*/0x00F2/*::]*/: { /* n:\"BrtEndPCDSDTCSet\", */ T:-1 },\n\t/*::[*/0x00F3/*::]*/: { /* n:\"BrtBeginPCDCalcItems\", */ T:1 },\n\t/*::[*/0x00F4/*::]*/: { /* n:\"BrtEndPCDCalcItems\", */ T:-1 },\n\t/*::[*/0x00F5/*::]*/: { /* n:\"BrtBeginPCDCalcItem\", */ T:1 },\n\t/*::[*/0x00F6/*::]*/: { /* n:\"BrtEndPCDCalcItem\", */ T:-1 },\n\t/*::[*/0x00F7/*::]*/: { /* n:\"BrtBeginPRule\", */ T:1 },\n\t/*::[*/0x00F8/*::]*/: { /* n:\"BrtEndPRule\", */ T:-1 },\n\t/*::[*/0x00F9/*::]*/: { /* n:\"BrtBeginPRFilters\", */ T:1 },\n\t/*::[*/0x00FA/*::]*/: { /* n:\"BrtEndPRFilters\", */ T:-1 },\n\t/*::[*/0x00FB/*::]*/: { /* n:\"BrtBeginPRFilter\", */ T:1 },\n\t/*::[*/0x00FC/*::]*/: { /* n:\"BrtEndPRFilter\", */ T:-1 },\n\t/*::[*/0x00FD/*::]*/: { /* n:\"BrtBeginPNames\", */ T:1 },\n\t/*::[*/0x00FE/*::]*/: { /* n:\"BrtEndPNames\", */ T:-1 },\n\t/*::[*/0x00FF/*::]*/: { /* n:\"BrtBeginPName\", */ T:1 },\n\t/*::[*/0x0100/*::]*/: { /* n:\"BrtEndPName\", */ T:-1 },\n\t/*::[*/0x0101/*::]*/: { /* n:\"BrtBeginPNPairs\", */ T:1 },\n\t/*::[*/0x0102/*::]*/: { /* n:\"BrtEndPNPairs\", */ T:-1 },\n\t/*::[*/0x0103/*::]*/: { /* n:\"BrtBeginPNPair\", */ T:1 },\n\t/*::[*/0x0104/*::]*/: { /* n:\"BrtEndPNPair\", */ T:-1 },\n\t/*::[*/0x0105/*::]*/: { /* n:\"BrtBeginECWebProps\", */ T:1 },\n\t/*::[*/0x0106/*::]*/: { /* n:\"BrtEndECWebProps\", */ T:-1 },\n\t/*::[*/0x0107/*::]*/: { /* n:\"BrtBeginEcWpTables\", */ T:1 },\n\t/*::[*/0x0108/*::]*/: { /* n:\"BrtEndECWPTables\", */ T:-1 },\n\t/*::[*/0x0109/*::]*/: { /* n:\"BrtBeginECParams\", */ T:1 },\n\t/*::[*/0x010A/*::]*/: { /* n:\"BrtEndECParams\", */ T:-1 },\n\t/*::[*/0x010B/*::]*/: { /* n:\"BrtBeginECParam\", */ T:1 },\n\t/*::[*/0x010C/*::]*/: { /* n:\"BrtEndECParam\", */ T:-1 },\n\t/*::[*/0x010D/*::]*/: { /* n:\"BrtBeginPCDKPIs\", */ T:1 },\n\t/*::[*/0x010E/*::]*/: { /* n:\"BrtEndPCDKPIs\", */ T:-1 },\n\t/*::[*/0x010F/*::]*/: { /* n:\"BrtBeginPCDKPI\", */ T:1 },\n\t/*::[*/0x0110/*::]*/: { /* n:\"BrtEndPCDKPI\", */ T:-1 },\n\t/*::[*/0x0111/*::]*/: { /* n:\"BrtBeginDims\", */ T:1 },\n\t/*::[*/0x0112/*::]*/: { /* n:\"BrtEndDims\", */ T:-1 },\n\t/*::[*/0x0113/*::]*/: { /* n:\"BrtBeginDim\", */ T:1 },\n\t/*::[*/0x0114/*::]*/: { /* n:\"BrtEndDim\", */ T:-1 },\n\t/*::[*/0x0115/*::]*/: { /* n:\"BrtIndexPartEnd\" */ },\n\t/*::[*/0x0116/*::]*/: { /* n:\"BrtBeginStyleSheet\", */ T:1 },\n\t/*::[*/0x0117/*::]*/: { /* n:\"BrtEndStyleSheet\", */ T:-1 },\n\t/*::[*/0x0118/*::]*/: { /* n:\"BrtBeginSXView\", */ T:1 },\n\t/*::[*/0x0119/*::]*/: { /* n:\"BrtEndSXVI\", */ T:-1 },\n\t/*::[*/0x011A/*::]*/: { /* n:\"BrtBeginSXVI\", */ T:1 },\n\t/*::[*/0x011B/*::]*/: { /* n:\"BrtBeginSXVIs\", */ T:1 },\n\t/*::[*/0x011C/*::]*/: { /* n:\"BrtEndSXVIs\", */ T:-1 },\n\t/*::[*/0x011D/*::]*/: { /* n:\"BrtBeginSXVD\", */ T:1 },\n\t/*::[*/0x011E/*::]*/: { /* n:\"BrtEndSXVD\", */ T:-1 },\n\t/*::[*/0x011F/*::]*/: { /* n:\"BrtBeginSXVDs\", */ T:1 },\n\t/*::[*/0x0120/*::]*/: { /* n:\"BrtEndSXVDs\", */ T:-1 },\n\t/*::[*/0x0121/*::]*/: { /* n:\"BrtBeginSXPI\", */ T:1 },\n\t/*::[*/0x0122/*::]*/: { /* n:\"BrtEndSXPI\", */ T:-1 },\n\t/*::[*/0x0123/*::]*/: { /* n:\"BrtBeginSXPIs\", */ T:1 },\n\t/*::[*/0x0124/*::]*/: { /* n:\"BrtEndSXPIs\", */ T:-1 },\n\t/*::[*/0x0125/*::]*/: { /* n:\"BrtBeginSXDI\", */ T:1 },\n\t/*::[*/0x0126/*::]*/: { /* n:\"BrtEndSXDI\", */ T:-1 },\n\t/*::[*/0x0127/*::]*/: { /* n:\"BrtBeginSXDIs\", */ T:1 },\n\t/*::[*/0x0128/*::]*/: { /* n:\"BrtEndSXDIs\", */ T:-1 },\n\t/*::[*/0x0129/*::]*/: { /* n:\"BrtBeginSXLI\", */ T:1 },\n\t/*::[*/0x012A/*::]*/: { /* n:\"BrtEndSXLI\", */ T:-1 },\n\t/*::[*/0x012B/*::]*/: { /* n:\"BrtBeginSXLIRws\", */ T:1 },\n\t/*::[*/0x012C/*::]*/: { /* n:\"BrtEndSXLIRws\", */ T:-1 },\n\t/*::[*/0x012D/*::]*/: { /* n:\"BrtBeginSXLICols\", */ T:1 },\n\t/*::[*/0x012E/*::]*/: { /* n:\"BrtEndSXLICols\", */ T:-1 },\n\t/*::[*/0x012F/*::]*/: { /* n:\"BrtBeginSXFormat\", */ T:1 },\n\t/*::[*/0x0130/*::]*/: { /* n:\"BrtEndSXFormat\", */ T:-1 },\n\t/*::[*/0x0131/*::]*/: { /* n:\"BrtBeginSXFormats\", */ T:1 },\n\t/*::[*/0x0132/*::]*/: { /* n:\"BrtEndSxFormats\", */ T:-1 },\n\t/*::[*/0x0133/*::]*/: { /* n:\"BrtBeginSxSelect\", */ T:1 },\n\t/*::[*/0x0134/*::]*/: { /* n:\"BrtEndSxSelect\", */ T:-1 },\n\t/*::[*/0x0135/*::]*/: { /* n:\"BrtBeginISXVDRws\", */ T:1 },\n\t/*::[*/0x0136/*::]*/: { /* n:\"BrtEndISXVDRws\", */ T:-1 },\n\t/*::[*/0x0137/*::]*/: { /* n:\"BrtBeginISXVDCols\", */ T:1 },\n\t/*::[*/0x0138/*::]*/: { /* n:\"BrtEndISXVDCols\", */ T:-1 },\n\t/*::[*/0x0139/*::]*/: { /* n:\"BrtEndSXLocation\", */ T:-1 },\n\t/*::[*/0x013A/*::]*/: { /* n:\"BrtBeginSXLocation\", */ T:1 },\n\t/*::[*/0x013B/*::]*/: { /* n:\"BrtEndSXView\", */ T:-1 },\n\t/*::[*/0x013C/*::]*/: { /* n:\"BrtBeginSXTHs\", */ T:1 },\n\t/*::[*/0x013D/*::]*/: { /* n:\"BrtEndSXTHs\", */ T:-1 },\n\t/*::[*/0x013E/*::]*/: { /* n:\"BrtBeginSXTH\", */ T:1 },\n\t/*::[*/0x013F/*::]*/: { /* n:\"BrtEndSXTH\", */ T:-1 },\n\t/*::[*/0x0140/*::]*/: { /* n:\"BrtBeginISXTHRws\", */ T:1 },\n\t/*::[*/0x0141/*::]*/: { /* n:\"BrtEndISXTHRws\", */ T:-1 },\n\t/*::[*/0x0142/*::]*/: { /* n:\"BrtBeginISXTHCols\", */ T:1 },\n\t/*::[*/0x0143/*::]*/: { /* n:\"BrtEndISXTHCols\", */ T:-1 },\n\t/*::[*/0x0144/*::]*/: { /* n:\"BrtBeginSXTDMPS\", */ T:1 },\n\t/*::[*/0x0145/*::]*/: { /* n:\"BrtEndSXTDMPs\", */ T:-1 },\n\t/*::[*/0x0146/*::]*/: { /* n:\"BrtBeginSXTDMP\", */ T:1 },\n\t/*::[*/0x0147/*::]*/: { /* n:\"BrtEndSXTDMP\", */ T:-1 },\n\t/*::[*/0x0148/*::]*/: { /* n:\"BrtBeginSXTHItems\", */ T:1 },\n\t/*::[*/0x0149/*::]*/: { /* n:\"BrtEndSXTHItems\", */ T:-1 },\n\t/*::[*/0x014A/*::]*/: { /* n:\"BrtBeginSXTHItem\", */ T:1 },\n\t/*::[*/0x014B/*::]*/: { /* n:\"BrtEndSXTHItem\", */ T:-1 },\n\t/*::[*/0x014C/*::]*/: { /* n:\"BrtBeginMetadata\", */ T:1 },\n\t/*::[*/0x014D/*::]*/: { /* n:\"BrtEndMetadata\", */ T:-1 },\n\t/*::[*/0x014E/*::]*/: { /* n:\"BrtBeginEsmdtinfo\", */ T:1 },\n\t/*::[*/0x014F/*::]*/: { /* n:\"BrtMdtinfo\", */ f:parse_BrtMdtinfo },\n\t/*::[*/0x0150/*::]*/: { /* n:\"BrtEndEsmdtinfo\", */ T:-1 },\n\t/*::[*/0x0151/*::]*/: { /* n:\"BrtBeginEsmdb\", */ f:parse_BrtBeginEsmdb, T:1 },\n\t/*::[*/0x0152/*::]*/: { /* n:\"BrtEndEsmdb\", */ T:-1 },\n\t/*::[*/0x0153/*::]*/: { /* n:\"BrtBeginEsfmd\", */ T:1 },\n\t/*::[*/0x0154/*::]*/: { /* n:\"BrtEndEsfmd\", */ T:-1 },\n\t/*::[*/0x0155/*::]*/: { /* n:\"BrtBeginSingleCells\", */ T:1 },\n\t/*::[*/0x0156/*::]*/: { /* n:\"BrtEndSingleCells\", */ T:-1 },\n\t/*::[*/0x0157/*::]*/: { /* n:\"BrtBeginList\", */ T:1 },\n\t/*::[*/0x0158/*::]*/: { /* n:\"BrtEndList\", */ T:-1 },\n\t/*::[*/0x0159/*::]*/: { /* n:\"BrtBeginListCols\", */ T:1 },\n\t/*::[*/0x015A/*::]*/: { /* n:\"BrtEndListCols\", */ T:-1 },\n\t/*::[*/0x015B/*::]*/: { /* n:\"BrtBeginListCol\", */ T:1 },\n\t/*::[*/0x015C/*::]*/: { /* n:\"BrtEndListCol\", */ T:-1 },\n\t/*::[*/0x015D/*::]*/: { /* n:\"BrtBeginListXmlCPr\", */ T:1 },\n\t/*::[*/0x015E/*::]*/: { /* n:\"BrtEndListXmlCPr\", */ T:-1 },\n\t/*::[*/0x015F/*::]*/: { /* n:\"BrtListCCFmla\" */ },\n\t/*::[*/0x0160/*::]*/: { /* n:\"BrtListTrFmla\" */ },\n\t/*::[*/0x0161/*::]*/: { /* n:\"BrtBeginExternals\", */ T:1 },\n\t/*::[*/0x0162/*::]*/: { /* n:\"BrtEndExternals\", */ T:-1 },\n\t/*::[*/0x0163/*::]*/: { /* n:\"BrtSupBookSrc\", */ f:parse_RelID},\n\t/*::[*/0x0165/*::]*/: { /* n:\"BrtSupSelf\" */ },\n\t/*::[*/0x0166/*::]*/: { /* n:\"BrtSupSame\" */ },\n\t/*::[*/0x0167/*::]*/: { /* n:\"BrtSupTabs\" */ },\n\t/*::[*/0x0168/*::]*/: { /* n:\"BrtBeginSupBook\", */ T:1 },\n\t/*::[*/0x0169/*::]*/: { /* n:\"BrtPlaceholderName\" */ },\n\t/*::[*/0x016A/*::]*/: { /* n:\"BrtExternSheet\", */ f:parse_ExternSheet },\n\t/*::[*/0x016B/*::]*/: { /* n:\"BrtExternTableStart\" */ },\n\t/*::[*/0x016C/*::]*/: { /* n:\"BrtExternTableEnd\" */ },\n\t/*::[*/0x016E/*::]*/: { /* n:\"BrtExternRowHdr\" */ },\n\t/*::[*/0x016F/*::]*/: { /* n:\"BrtExternCellBlank\" */ },\n\t/*::[*/0x0170/*::]*/: { /* n:\"BrtExternCellReal\" */ },\n\t/*::[*/0x0171/*::]*/: { /* n:\"BrtExternCellBool\" */ },\n\t/*::[*/0x0172/*::]*/: { /* n:\"BrtExternCellError\" */ },\n\t/*::[*/0x0173/*::]*/: { /* n:\"BrtExternCellString\" */ },\n\t/*::[*/0x0174/*::]*/: { /* n:\"BrtBeginEsmdx\", */ T:1 },\n\t/*::[*/0x0175/*::]*/: { /* n:\"BrtEndEsmdx\", */ T:-1 },\n\t/*::[*/0x0176/*::]*/: { /* n:\"BrtBeginMdxSet\", */ T:1 },\n\t/*::[*/0x0177/*::]*/: { /* n:\"BrtEndMdxSet\", */ T:-1 },\n\t/*::[*/0x0178/*::]*/: { /* n:\"BrtBeginMdxMbrProp\", */ T:1 },\n\t/*::[*/0x0179/*::]*/: { /* n:\"BrtEndMdxMbrProp\", */ T:-1 },\n\t/*::[*/0x017A/*::]*/: { /* n:\"BrtBeginMdxKPI\", */ T:1 },\n\t/*::[*/0x017B/*::]*/: { /* n:\"BrtEndMdxKPI\", */ T:-1 },\n\t/*::[*/0x017C/*::]*/: { /* n:\"BrtBeginEsstr\", */ T:1 },\n\t/*::[*/0x017D/*::]*/: { /* n:\"BrtEndEsstr\", */ T:-1 },\n\t/*::[*/0x017E/*::]*/: { /* n:\"BrtBeginPRFItem\", */ T:1 },\n\t/*::[*/0x017F/*::]*/: { /* n:\"BrtEndPRFItem\", */ T:-1 },\n\t/*::[*/0x0180/*::]*/: { /* n:\"BrtBeginPivotCacheIDs\", */ T:1 },\n\t/*::[*/0x0181/*::]*/: { /* n:\"BrtEndPivotCacheIDs\", */ T:-1 },\n\t/*::[*/0x0182/*::]*/: { /* n:\"BrtBeginPivotCacheID\", */ T:1 },\n\t/*::[*/0x0183/*::]*/: { /* n:\"BrtEndPivotCacheID\", */ T:-1 },\n\t/*::[*/0x0184/*::]*/: { /* n:\"BrtBeginISXVIs\", */ T:1 },\n\t/*::[*/0x0185/*::]*/: { /* n:\"BrtEndISXVIs\", */ T:-1 },\n\t/*::[*/0x0186/*::]*/: { /* n:\"BrtBeginColInfos\", */ T:1 },\n\t/*::[*/0x0187/*::]*/: { /* n:\"BrtEndColInfos\", */ T:-1 },\n\t/*::[*/0x0188/*::]*/: { /* n:\"BrtBeginRwBrk\", */ T:1 },\n\t/*::[*/0x0189/*::]*/: { /* n:\"BrtEndRwBrk\", */ T:-1 },\n\t/*::[*/0x018A/*::]*/: { /* n:\"BrtBeginColBrk\", */ T:1 },\n\t/*::[*/0x018B/*::]*/: { /* n:\"BrtEndColBrk\", */ T:-1 },\n\t/*::[*/0x018C/*::]*/: { /* n:\"BrtBrk\" */ },\n\t/*::[*/0x018D/*::]*/: { /* n:\"BrtUserBookView\" */ },\n\t/*::[*/0x018E/*::]*/: { /* n:\"BrtInfo\" */ },\n\t/*::[*/0x018F/*::]*/: { /* n:\"BrtCUsr\" */ },\n\t/*::[*/0x0190/*::]*/: { /* n:\"BrtUsr\" */ },\n\t/*::[*/0x0191/*::]*/: { /* n:\"BrtBeginUsers\", */ T:1 },\n\t/*::[*/0x0193/*::]*/: { /* n:\"BrtEOF\" */ },\n\t/*::[*/0x0194/*::]*/: { /* n:\"BrtUCR\" */ },\n\t/*::[*/0x0195/*::]*/: { /* n:\"BrtRRInsDel\" */ },\n\t/*::[*/0x0196/*::]*/: { /* n:\"BrtRREndInsDel\" */ },\n\t/*::[*/0x0197/*::]*/: { /* n:\"BrtRRMove\" */ },\n\t/*::[*/0x0198/*::]*/: { /* n:\"BrtRREndMove\" */ },\n\t/*::[*/0x0199/*::]*/: { /* n:\"BrtRRChgCell\" */ },\n\t/*::[*/0x019A/*::]*/: { /* n:\"BrtRREndChgCell\" */ },\n\t/*::[*/0x019B/*::]*/: { /* n:\"BrtRRHeader\" */ },\n\t/*::[*/0x019C/*::]*/: { /* n:\"BrtRRUserView\" */ },\n\t/*::[*/0x019D/*::]*/: { /* n:\"BrtRRRenSheet\" */ },\n\t/*::[*/0x019E/*::]*/: { /* n:\"BrtRRInsertSh\" */ },\n\t/*::[*/0x019F/*::]*/: { /* n:\"BrtRRDefName\" */ },\n\t/*::[*/0x01A0/*::]*/: { /* n:\"BrtRRNote\" */ },\n\t/*::[*/0x01A1/*::]*/: { /* n:\"BrtRRConflict\" */ },\n\t/*::[*/0x01A2/*::]*/: { /* n:\"BrtRRTQSIF\" */ },\n\t/*::[*/0x01A3/*::]*/: { /* n:\"BrtRRFormat\" */ },\n\t/*::[*/0x01A4/*::]*/: { /* n:\"BrtRREndFormat\" */ },\n\t/*::[*/0x01A5/*::]*/: { /* n:\"BrtRRAutoFmt\" */ },\n\t/*::[*/0x01A6/*::]*/: { /* n:\"BrtBeginUserShViews\", */ T:1 },\n\t/*::[*/0x01A7/*::]*/: { /* n:\"BrtBeginUserShView\", */ T:1 },\n\t/*::[*/0x01A8/*::]*/: { /* n:\"BrtEndUserShView\", */ T:-1 },\n\t/*::[*/0x01A9/*::]*/: { /* n:\"BrtEndUserShViews\", */ T:-1 },\n\t/*::[*/0x01AA/*::]*/: { /* n:\"BrtArrFmla\", */ f:parse_BrtArrFmla },\n\t/*::[*/0x01AB/*::]*/: { /* n:\"BrtShrFmla\", */ f:parse_BrtShrFmla },\n\t/*::[*/0x01AC/*::]*/: { /* n:\"BrtTable\" */ },\n\t/*::[*/0x01AD/*::]*/: { /* n:\"BrtBeginExtConnections\", */ T:1 },\n\t/*::[*/0x01AE/*::]*/: { /* n:\"BrtEndExtConnections\", */ T:-1 },\n\t/*::[*/0x01AF/*::]*/: { /* n:\"BrtBeginPCDCalcMems\", */ T:1 },\n\t/*::[*/0x01B0/*::]*/: { /* n:\"BrtEndPCDCalcMems\", */ T:-1 },\n\t/*::[*/0x01B1/*::]*/: { /* n:\"BrtBeginPCDCalcMem\", */ T:1 },\n\t/*::[*/0x01B2/*::]*/: { /* n:\"BrtEndPCDCalcMem\", */ T:-1 },\n\t/*::[*/0x01B3/*::]*/: { /* n:\"BrtBeginPCDHGLevels\", */ T:1 },\n\t/*::[*/0x01B4/*::]*/: { /* n:\"BrtEndPCDHGLevels\", */ T:-1 },\n\t/*::[*/0x01B5/*::]*/: { /* n:\"BrtBeginPCDHGLevel\", */ T:1 },\n\t/*::[*/0x01B6/*::]*/: { /* n:\"BrtEndPCDHGLevel\", */ T:-1 },\n\t/*::[*/0x01B7/*::]*/: { /* n:\"BrtBeginPCDHGLGroups\", */ T:1 },\n\t/*::[*/0x01B8/*::]*/: { /* n:\"BrtEndPCDHGLGroups\", */ T:-1 },\n\t/*::[*/0x01B9/*::]*/: { /* n:\"BrtBeginPCDHGLGroup\", */ T:1 },\n\t/*::[*/0x01BA/*::]*/: { /* n:\"BrtEndPCDHGLGroup\", */ T:-1 },\n\t/*::[*/0x01BB/*::]*/: { /* n:\"BrtBeginPCDHGLGMembers\", */ T:1 },\n\t/*::[*/0x01BC/*::]*/: { /* n:\"BrtEndPCDHGLGMembers\", */ T:-1 },\n\t/*::[*/0x01BD/*::]*/: { /* n:\"BrtBeginPCDHGLGMember\", */ T:1 },\n\t/*::[*/0x01BE/*::]*/: { /* n:\"BrtEndPCDHGLGMember\", */ T:-1 },\n\t/*::[*/0x01BF/*::]*/: { /* n:\"BrtBeginQSI\", */ T:1 },\n\t/*::[*/0x01C0/*::]*/: { /* n:\"BrtEndQSI\", */ T:-1 },\n\t/*::[*/0x01C1/*::]*/: { /* n:\"BrtBeginQSIR\", */ T:1 },\n\t/*::[*/0x01C2/*::]*/: { /* n:\"BrtEndQSIR\", */ T:-1 },\n\t/*::[*/0x01C3/*::]*/: { /* n:\"BrtBeginDeletedNames\", */ T:1 },\n\t/*::[*/0x01C4/*::]*/: { /* n:\"BrtEndDeletedNames\", */ T:-1 },\n\t/*::[*/0x01C5/*::]*/: { /* n:\"BrtBeginDeletedName\", */ T:1 },\n\t/*::[*/0x01C6/*::]*/: { /* n:\"BrtEndDeletedName\", */ T:-1 },\n\t/*::[*/0x01C7/*::]*/: { /* n:\"BrtBeginQSIFs\", */ T:1 },\n\t/*::[*/0x01C8/*::]*/: { /* n:\"BrtEndQSIFs\", */ T:-1 },\n\t/*::[*/0x01C9/*::]*/: { /* n:\"BrtBeginQSIF\", */ T:1 },\n\t/*::[*/0x01CA/*::]*/: { /* n:\"BrtEndQSIF\", */ T:-1 },\n\t/*::[*/0x01CB/*::]*/: { /* n:\"BrtBeginAutoSortScope\", */ T:1 },\n\t/*::[*/0x01CC/*::]*/: { /* n:\"BrtEndAutoSortScope\", */ T:-1 },\n\t/*::[*/0x01CD/*::]*/: { /* n:\"BrtBeginConditionalFormatting\", */ T:1 },\n\t/*::[*/0x01CE/*::]*/: { /* n:\"BrtEndConditionalFormatting\", */ T:-1 },\n\t/*::[*/0x01CF/*::]*/: { /* n:\"BrtBeginCFRule\", */ T:1 },\n\t/*::[*/0x01D0/*::]*/: { /* n:\"BrtEndCFRule\", */ T:-1 },\n\t/*::[*/0x01D1/*::]*/: { /* n:\"BrtBeginIconSet\", */ T:1 },\n\t/*::[*/0x01D2/*::]*/: { /* n:\"BrtEndIconSet\", */ T:-1 },\n\t/*::[*/0x01D3/*::]*/: { /* n:\"BrtBeginDatabar\", */ T:1 },\n\t/*::[*/0x01D4/*::]*/: { /* n:\"BrtEndDatabar\", */ T:-1 },\n\t/*::[*/0x01D5/*::]*/: { /* n:\"BrtBeginColorScale\", */ T:1 },\n\t/*::[*/0x01D6/*::]*/: { /* n:\"BrtEndColorScale\", */ T:-1 },\n\t/*::[*/0x01D7/*::]*/: { /* n:\"BrtCFVO\" */ },\n\t/*::[*/0x01D8/*::]*/: { /* n:\"BrtExternValueMeta\" */ },\n\t/*::[*/0x01D9/*::]*/: { /* n:\"BrtBeginColorPalette\", */ T:1 },\n\t/*::[*/0x01DA/*::]*/: { /* n:\"BrtEndColorPalette\", */ T:-1 },\n\t/*::[*/0x01DB/*::]*/: { /* n:\"BrtIndexedColor\" */ },\n\t/*::[*/0x01DC/*::]*/: { /* n:\"BrtMargins\", */ f:parse_BrtMargins },\n\t/*::[*/0x01DD/*::]*/: { /* n:\"BrtPrintOptions\" */ },\n\t/*::[*/0x01DE/*::]*/: { /* n:\"BrtPageSetup\" */ },\n\t/*::[*/0x01DF/*::]*/: { /* n:\"BrtBeginHeaderFooter\", */ T:1 },\n\t/*::[*/0x01E0/*::]*/: { /* n:\"BrtEndHeaderFooter\", */ T:-1 },\n\t/*::[*/0x01E1/*::]*/: { /* n:\"BrtBeginSXCrtFormat\", */ T:1 },\n\t/*::[*/0x01E2/*::]*/: { /* n:\"BrtEndSXCrtFormat\", */ T:-1 },\n\t/*::[*/0x01E3/*::]*/: { /* n:\"BrtBeginSXCrtFormats\", */ T:1 },\n\t/*::[*/0x01E4/*::]*/: { /* n:\"BrtEndSXCrtFormats\", */ T:-1 },\n\t/*::[*/0x01E5/*::]*/: { /* n:\"BrtWsFmtInfo\", */ f:parse_BrtWsFmtInfo },\n\t/*::[*/0x01E6/*::]*/: { /* n:\"BrtBeginMgs\", */ T:1 },\n\t/*::[*/0x01E7/*::]*/: { /* n:\"BrtEndMGs\", */ T:-1 },\n\t/*::[*/0x01E8/*::]*/: { /* n:\"BrtBeginMGMaps\", */ T:1 },\n\t/*::[*/0x01E9/*::]*/: { /* n:\"BrtEndMGMaps\", */ T:-1 },\n\t/*::[*/0x01EA/*::]*/: { /* n:\"BrtBeginMG\", */ T:1 },\n\t/*::[*/0x01EB/*::]*/: { /* n:\"BrtEndMG\", */ T:-1 },\n\t/*::[*/0x01EC/*::]*/: { /* n:\"BrtBeginMap\", */ T:1 },\n\t/*::[*/0x01ED/*::]*/: { /* n:\"BrtEndMap\", */ T:-1 },\n\t/*::[*/0x01EE/*::]*/: { /* n:\"BrtHLink\", */ f:parse_BrtHLink },\n\t/*::[*/0x01EF/*::]*/: { /* n:\"BrtBeginDCon\", */ T:1 },\n\t/*::[*/0x01F0/*::]*/: { /* n:\"BrtEndDCon\", */ T:-1 },\n\t/*::[*/0x01F1/*::]*/: { /* n:\"BrtBeginDRefs\", */ T:1 },\n\t/*::[*/0x01F2/*::]*/: { /* n:\"BrtEndDRefs\", */ T:-1 },\n\t/*::[*/0x01F3/*::]*/: { /* n:\"BrtDRef\" */ },\n\t/*::[*/0x01F4/*::]*/: { /* n:\"BrtBeginScenMan\", */ T:1 },\n\t/*::[*/0x01F5/*::]*/: { /* n:\"BrtEndScenMan\", */ T:-1 },\n\t/*::[*/0x01F6/*::]*/: { /* n:\"BrtBeginSct\", */ T:1 },\n\t/*::[*/0x01F7/*::]*/: { /* n:\"BrtEndSct\", */ T:-1 },\n\t/*::[*/0x01F8/*::]*/: { /* n:\"BrtSlc\" */ },\n\t/*::[*/0x01F9/*::]*/: { /* n:\"BrtBeginDXFs\", */ T:1 },\n\t/*::[*/0x01FA/*::]*/: { /* n:\"BrtEndDXFs\", */ T:-1 },\n\t/*::[*/0x01FB/*::]*/: { /* n:\"BrtDXF\" */ },\n\t/*::[*/0x01FC/*::]*/: { /* n:\"BrtBeginTableStyles\", */ T:1 },\n\t/*::[*/0x01FD/*::]*/: { /* n:\"BrtEndTableStyles\", */ T:-1 },\n\t/*::[*/0x01FE/*::]*/: { /* n:\"BrtBeginTableStyle\", */ T:1 },\n\t/*::[*/0x01FF/*::]*/: { /* n:\"BrtEndTableStyle\", */ T:-1 },\n\t/*::[*/0x0200/*::]*/: { /* n:\"BrtTableStyleElement\" */ },\n\t/*::[*/0x0201/*::]*/: { /* n:\"BrtTableStyleClient\" */ },\n\t/*::[*/0x0202/*::]*/: { /* n:\"BrtBeginVolDeps\", */ T:1 },\n\t/*::[*/0x0203/*::]*/: { /* n:\"BrtEndVolDeps\", */ T:-1 },\n\t/*::[*/0x0204/*::]*/: { /* n:\"BrtBeginVolType\", */ T:1 },\n\t/*::[*/0x0205/*::]*/: { /* n:\"BrtEndVolType\", */ T:-1 },\n\t/*::[*/0x0206/*::]*/: { /* n:\"BrtBeginVolMain\", */ T:1 },\n\t/*::[*/0x0207/*::]*/: { /* n:\"BrtEndVolMain\", */ T:-1 },\n\t/*::[*/0x0208/*::]*/: { /* n:\"BrtBeginVolTopic\", */ T:1 },\n\t/*::[*/0x0209/*::]*/: { /* n:\"BrtEndVolTopic\", */ T:-1 },\n\t/*::[*/0x020A/*::]*/: { /* n:\"BrtVolSubtopic\" */ },\n\t/*::[*/0x020B/*::]*/: { /* n:\"BrtVolRef\" */ },\n\t/*::[*/0x020C/*::]*/: { /* n:\"BrtVolNum\" */ },\n\t/*::[*/0x020D/*::]*/: { /* n:\"BrtVolErr\" */ },\n\t/*::[*/0x020E/*::]*/: { /* n:\"BrtVolStr\" */ },\n\t/*::[*/0x020F/*::]*/: { /* n:\"BrtVolBool\" */ },\n\t/*::[*/0x0210/*::]*/: { /* n:\"BrtBeginCalcChain$\", */ T:1 },\n\t/*::[*/0x0211/*::]*/: { /* n:\"BrtEndCalcChain$\", */ T:-1 },\n\t/*::[*/0x0212/*::]*/: { /* n:\"BrtBeginSortState\", */ T:1 },\n\t/*::[*/0x0213/*::]*/: { /* n:\"BrtEndSortState\", */ T:-1 },\n\t/*::[*/0x0214/*::]*/: { /* n:\"BrtBeginSortCond\", */ T:1 },\n\t/*::[*/0x0215/*::]*/: { /* n:\"BrtEndSortCond\", */ T:-1 },\n\t/*::[*/0x0216/*::]*/: { /* n:\"BrtBookProtection\" */ },\n\t/*::[*/0x0217/*::]*/: { /* n:\"BrtSheetProtection\" */ },\n\t/*::[*/0x0218/*::]*/: { /* n:\"BrtRangeProtection\" */ },\n\t/*::[*/0x0219/*::]*/: { /* n:\"BrtPhoneticInfo\" */ },\n\t/*::[*/0x021A/*::]*/: { /* n:\"BrtBeginECTxtWiz\", */ T:1 },\n\t/*::[*/0x021B/*::]*/: { /* n:\"BrtEndECTxtWiz\", */ T:-1 },\n\t/*::[*/0x021C/*::]*/: { /* n:\"BrtBeginECTWFldInfoLst\", */ T:1 },\n\t/*::[*/0x021D/*::]*/: { /* n:\"BrtEndECTWFldInfoLst\", */ T:-1 },\n\t/*::[*/0x021E/*::]*/: { /* n:\"BrtBeginECTwFldInfo\", */ T:1 },\n\t/*::[*/0x0224/*::]*/: { /* n:\"BrtFileSharing\" */ },\n\t/*::[*/0x0225/*::]*/: { /* n:\"BrtOleSize\" */ },\n\t/*::[*/0x0226/*::]*/: { /* n:\"BrtDrawing\", */ f:parse_RelID },\n\t/*::[*/0x0227/*::]*/: { /* n:\"BrtLegacyDrawing\" */ },\n\t/*::[*/0x0228/*::]*/: { /* n:\"BrtLegacyDrawingHF\" */ },\n\t/*::[*/0x0229/*::]*/: { /* n:\"BrtWebOpt\" */ },\n\t/*::[*/0x022A/*::]*/: { /* n:\"BrtBeginWebPubItems\", */ T:1 },\n\t/*::[*/0x022B/*::]*/: { /* n:\"BrtEndWebPubItems\", */ T:-1 },\n\t/*::[*/0x022C/*::]*/: { /* n:\"BrtBeginWebPubItem\", */ T:1 },\n\t/*::[*/0x022D/*::]*/: { /* n:\"BrtEndWebPubItem\", */ T:-1 },\n\t/*::[*/0x022E/*::]*/: { /* n:\"BrtBeginSXCondFmt\", */ T:1 },\n\t/*::[*/0x022F/*::]*/: { /* n:\"BrtEndSXCondFmt\", */ T:-1 },\n\t/*::[*/0x0230/*::]*/: { /* n:\"BrtBeginSXCondFmts\", */ T:1 },\n\t/*::[*/0x0231/*::]*/: { /* n:\"BrtEndSXCondFmts\", */ T:-1 },\n\t/*::[*/0x0232/*::]*/: { /* n:\"BrtBkHim\" */ },\n\t/*::[*/0x0234/*::]*/: { /* n:\"BrtColor\" */ },\n\t/*::[*/0x0235/*::]*/: { /* n:\"BrtBeginIndexedColors\", */ T:1 },\n\t/*::[*/0x0236/*::]*/: { /* n:\"BrtEndIndexedColors\", */ T:-1 },\n\t/*::[*/0x0239/*::]*/: { /* n:\"BrtBeginMRUColors\", */ T:1 },\n\t/*::[*/0x023A/*::]*/: { /* n:\"BrtEndMRUColors\", */ T:-1 },\n\t/*::[*/0x023C/*::]*/: { /* n:\"BrtMRUColor\" */ },\n\t/*::[*/0x023D/*::]*/: { /* n:\"BrtBeginDVals\", */ T:1 },\n\t/*::[*/0x023E/*::]*/: { /* n:\"BrtEndDVals\", */ T:-1 },\n\t/*::[*/0x0241/*::]*/: { /* n:\"BrtSupNameStart\" */ },\n\t/*::[*/0x0242/*::]*/: { /* n:\"BrtSupNameValueStart\" */ },\n\t/*::[*/0x0243/*::]*/: { /* n:\"BrtSupNameValueEnd\" */ },\n\t/*::[*/0x0244/*::]*/: { /* n:\"BrtSupNameNum\" */ },\n\t/*::[*/0x0245/*::]*/: { /* n:\"BrtSupNameErr\" */ },\n\t/*::[*/0x0246/*::]*/: { /* n:\"BrtSupNameSt\" */ },\n\t/*::[*/0x0247/*::]*/: { /* n:\"BrtSupNameNil\" */ },\n\t/*::[*/0x0248/*::]*/: { /* n:\"BrtSupNameBool\" */ },\n\t/*::[*/0x0249/*::]*/: { /* n:\"BrtSupNameFmla\" */ },\n\t/*::[*/0x024A/*::]*/: { /* n:\"BrtSupNameBits\" */ },\n\t/*::[*/0x024B/*::]*/: { /* n:\"BrtSupNameEnd\" */ },\n\t/*::[*/0x024C/*::]*/: { /* n:\"BrtEndSupBook\", */ T:-1 },\n\t/*::[*/0x024D/*::]*/: { /* n:\"BrtCellSmartTagProperty\" */ },\n\t/*::[*/0x024E/*::]*/: { /* n:\"BrtBeginCellSmartTag\", */ T:1 },\n\t/*::[*/0x024F/*::]*/: { /* n:\"BrtEndCellSmartTag\", */ T:-1 },\n\t/*::[*/0x0250/*::]*/: { /* n:\"BrtBeginCellSmartTags\", */ T:1 },\n\t/*::[*/0x0251/*::]*/: { /* n:\"BrtEndCellSmartTags\", */ T:-1 },\n\t/*::[*/0x0252/*::]*/: { /* n:\"BrtBeginSmartTags\", */ T:1 },\n\t/*::[*/0x0253/*::]*/: { /* n:\"BrtEndSmartTags\", */ T:-1 },\n\t/*::[*/0x0254/*::]*/: { /* n:\"BrtSmartTagType\" */ },\n\t/*::[*/0x0255/*::]*/: { /* n:\"BrtBeginSmartTagTypes\", */ T:1 },\n\t/*::[*/0x0256/*::]*/: { /* n:\"BrtEndSmartTagTypes\", */ T:-1 },\n\t/*::[*/0x0257/*::]*/: { /* n:\"BrtBeginSXFilters\", */ T:1 },\n\t/*::[*/0x0258/*::]*/: { /* n:\"BrtEndSXFilters\", */ T:-1 },\n\t/*::[*/0x0259/*::]*/: { /* n:\"BrtBeginSXFILTER\", */ T:1 },\n\t/*::[*/0x025A/*::]*/: { /* n:\"BrtEndSXFilter\", */ T:-1 },\n\t/*::[*/0x025B/*::]*/: { /* n:\"BrtBeginFills\", */ T:1 },\n\t/*::[*/0x025C/*::]*/: { /* n:\"BrtEndFills\", */ T:-1 },\n\t/*::[*/0x025D/*::]*/: { /* n:\"BrtBeginCellWatches\", */ T:1 },\n\t/*::[*/0x025E/*::]*/: { /* n:\"BrtEndCellWatches\", */ T:-1 },\n\t/*::[*/0x025F/*::]*/: { /* n:\"BrtCellWatch\" */ },\n\t/*::[*/0x0260/*::]*/: { /* n:\"BrtBeginCRErrs\", */ T:1 },\n\t/*::[*/0x0261/*::]*/: { /* n:\"BrtEndCRErrs\", */ T:-1 },\n\t/*::[*/0x0262/*::]*/: { /* n:\"BrtCrashRecErr\" */ },\n\t/*::[*/0x0263/*::]*/: { /* n:\"BrtBeginFonts\", */ T:1 },\n\t/*::[*/0x0264/*::]*/: { /* n:\"BrtEndFonts\", */ T:-1 },\n\t/*::[*/0x0265/*::]*/: { /* n:\"BrtBeginBorders\", */ T:1 },\n\t/*::[*/0x0266/*::]*/: { /* n:\"BrtEndBorders\", */ T:-1 },\n\t/*::[*/0x0267/*::]*/: { /* n:\"BrtBeginFmts\", */ T:1 },\n\t/*::[*/0x0268/*::]*/: { /* n:\"BrtEndFmts\", */ T:-1 },\n\t/*::[*/0x0269/*::]*/: { /* n:\"BrtBeginCellXFs\", */ T:1 },\n\t/*::[*/0x026A/*::]*/: { /* n:\"BrtEndCellXFs\", */ T:-1 },\n\t/*::[*/0x026B/*::]*/: { /* n:\"BrtBeginStyles\", */ T:1 },\n\t/*::[*/0x026C/*::]*/: { /* n:\"BrtEndStyles\", */ T:-1 },\n\t/*::[*/0x0271/*::]*/: { /* n:\"BrtBigName\" */ },\n\t/*::[*/0x0272/*::]*/: { /* n:\"BrtBeginCellStyleXFs\", */ T:1 },\n\t/*::[*/0x0273/*::]*/: { /* n:\"BrtEndCellStyleXFs\", */ T:-1 },\n\t/*::[*/0x0274/*::]*/: { /* n:\"BrtBeginComments\", */ T:1 },\n\t/*::[*/0x0275/*::]*/: { /* n:\"BrtEndComments\", */ T:-1 },\n\t/*::[*/0x0276/*::]*/: { /* n:\"BrtBeginCommentAuthors\", */ T:1 },\n\t/*::[*/0x0277/*::]*/: { /* n:\"BrtEndCommentAuthors\", */ T:-1 },\n\t/*::[*/0x0278/*::]*/: { /* n:\"BrtCommentAuthor\", */ f:parse_BrtCommentAuthor },\n\t/*::[*/0x0279/*::]*/: { /* n:\"BrtBeginCommentList\", */ T:1 },\n\t/*::[*/0x027A/*::]*/: { /* n:\"BrtEndCommentList\", */ T:-1 },\n\t/*::[*/0x027B/*::]*/: { /* n:\"BrtBeginComment\", */ T:1, f:parse_BrtBeginComment},\n\t/*::[*/0x027C/*::]*/: { /* n:\"BrtEndComment\", */ T:-1 },\n\t/*::[*/0x027D/*::]*/: { /* n:\"BrtCommentText\", */ f:parse_BrtCommentText },\n\t/*::[*/0x027E/*::]*/: { /* n:\"BrtBeginOleObjects\", */ T:1 },\n\t/*::[*/0x027F/*::]*/: { /* n:\"BrtOleObject\" */ },\n\t/*::[*/0x0280/*::]*/: { /* n:\"BrtEndOleObjects\", */ T:-1 },\n\t/*::[*/0x0281/*::]*/: { /* n:\"BrtBeginSxrules\", */ T:1 },\n\t/*::[*/0x0282/*::]*/: { /* n:\"BrtEndSxRules\", */ T:-1 },\n\t/*::[*/0x0283/*::]*/: { /* n:\"BrtBeginActiveXControls\", */ T:1 },\n\t/*::[*/0x0284/*::]*/: { /* n:\"BrtActiveX\" */ },\n\t/*::[*/0x0285/*::]*/: { /* n:\"BrtEndActiveXControls\", */ T:-1 },\n\t/*::[*/0x0286/*::]*/: { /* n:\"BrtBeginPCDSDTCEMembersSortBy\", */ T:1 },\n\t/*::[*/0x0288/*::]*/: { /* n:\"BrtBeginCellIgnoreECs\", */ T:1 },\n\t/*::[*/0x0289/*::]*/: { /* n:\"BrtCellIgnoreEC\" */ },\n\t/*::[*/0x028A/*::]*/: { /* n:\"BrtEndCellIgnoreECs\", */ T:-1 },\n\t/*::[*/0x028B/*::]*/: { /* n:\"BrtCsProp\", */ f:parse_BrtCsProp },\n\t/*::[*/0x028C/*::]*/: { /* n:\"BrtCsPageSetup\" */ },\n\t/*::[*/0x028D/*::]*/: { /* n:\"BrtBeginUserCsViews\", */ T:1 },\n\t/*::[*/0x028E/*::]*/: { /* n:\"BrtEndUserCsViews\", */ T:-1 },\n\t/*::[*/0x028F/*::]*/: { /* n:\"BrtBeginUserCsView\", */ T:1 },\n\t/*::[*/0x0290/*::]*/: { /* n:\"BrtEndUserCsView\", */ T:-1 },\n\t/*::[*/0x0291/*::]*/: { /* n:\"BrtBeginPcdSFCIEntries\", */ T:1 },\n\t/*::[*/0x0292/*::]*/: { /* n:\"BrtEndPCDSFCIEntries\", */ T:-1 },\n\t/*::[*/0x0293/*::]*/: { /* n:\"BrtPCDSFCIEntry\" */ },\n\t/*::[*/0x0294/*::]*/: { /* n:\"BrtBeginListParts\", */ T:1 },\n\t/*::[*/0x0295/*::]*/: { /* n:\"BrtListPart\" */ },\n\t/*::[*/0x0296/*::]*/: { /* n:\"BrtEndListParts\", */ T:-1 },\n\t/*::[*/0x0297/*::]*/: { /* n:\"BrtSheetCalcProp\" */ },\n\t/*::[*/0x0298/*::]*/: { /* n:\"BrtBeginFnGroup\", */ T:1 },\n\t/*::[*/0x0299/*::]*/: { /* n:\"BrtFnGroup\" */ },\n\t/*::[*/0x029A/*::]*/: { /* n:\"BrtEndFnGroup\", */ T:-1 },\n\t/*::[*/0x029B/*::]*/: { /* n:\"BrtSupAddin\" */ },\n\t/*::[*/0x029C/*::]*/: { /* n:\"BrtSXTDMPOrder\" */ },\n\t/*::[*/0x029D/*::]*/: { /* n:\"BrtCsProtection\" */ },\n\t/*::[*/0x029F/*::]*/: { /* n:\"BrtBeginWsSortMap\", */ T:1 },\n\t/*::[*/0x02A0/*::]*/: { /* n:\"BrtEndWsSortMap\", */ T:-1 },\n\t/*::[*/0x02A1/*::]*/: { /* n:\"BrtBeginRRSort\", */ T:1 },\n\t/*::[*/0x02A2/*::]*/: { /* n:\"BrtEndRRSort\", */ T:-1 },\n\t/*::[*/0x02A3/*::]*/: { /* n:\"BrtRRSortItem\" */ },\n\t/*::[*/0x02A4/*::]*/: { /* n:\"BrtFileSharingIso\" */ },\n\t/*::[*/0x02A5/*::]*/: { /* n:\"BrtBookProtectionIso\" */ },\n\t/*::[*/0x02A6/*::]*/: { /* n:\"BrtSheetProtectionIso\" */ },\n\t/*::[*/0x02A7/*::]*/: { /* n:\"BrtCsProtectionIso\" */ },\n\t/*::[*/0x02A8/*::]*/: { /* n:\"BrtRangeProtectionIso\" */ },\n\t/*::[*/0x02A9/*::]*/: { /* n:\"BrtDValList\" */ },\n\t/*::[*/0x0400/*::]*/: { /* n:\"BrtRwDescent\" */ },\n\t/*::[*/0x0401/*::]*/: { /* n:\"BrtKnownFonts\" */ },\n\t/*::[*/0x0402/*::]*/: { /* n:\"BrtBeginSXTupleSet\", */ T:1 },\n\t/*::[*/0x0403/*::]*/: { /* n:\"BrtEndSXTupleSet\", */ T:-1 },\n\t/*::[*/0x0404/*::]*/: { /* n:\"BrtBeginSXTupleSetHeader\", */ T:1 },\n\t/*::[*/0x0405/*::]*/: { /* n:\"BrtEndSXTupleSetHeader\", */ T:-1 },\n\t/*::[*/0x0406/*::]*/: { /* n:\"BrtSXTupleSetHeaderItem\" */ },\n\t/*::[*/0x0407/*::]*/: { /* n:\"BrtBeginSXTupleSetData\", */ T:1 },\n\t/*::[*/0x0408/*::]*/: { /* n:\"BrtEndSXTupleSetData\", */ T:-1 },\n\t/*::[*/0x0409/*::]*/: { /* n:\"BrtBeginSXTupleSetRow\", */ T:1 },\n\t/*::[*/0x040A/*::]*/: { /* n:\"BrtEndSXTupleSetRow\", */ T:-1 },\n\t/*::[*/0x040B/*::]*/: { /* n:\"BrtSXTupleSetRowItem\" */ },\n\t/*::[*/0x040C/*::]*/: { /* n:\"BrtNameExt\" */ },\n\t/*::[*/0x040D/*::]*/: { /* n:\"BrtPCDH14\" */ },\n\t/*::[*/0x040E/*::]*/: { /* n:\"BrtBeginPCDCalcMem14\", */ T:1 },\n\t/*::[*/0x040F/*::]*/: { /* n:\"BrtEndPCDCalcMem14\", */ T:-1 },\n\t/*::[*/0x0410/*::]*/: { /* n:\"BrtSXTH14\" */ },\n\t/*::[*/0x0411/*::]*/: { /* n:\"BrtBeginSparklineGroup\", */ T:1 },\n\t/*::[*/0x0412/*::]*/: { /* n:\"BrtEndSparklineGroup\", */ T:-1 },\n\t/*::[*/0x0413/*::]*/: { /* n:\"BrtSparkline\" */ },\n\t/*::[*/0x0414/*::]*/: { /* n:\"BrtSXDI14\" */ },\n\t/*::[*/0x0415/*::]*/: { /* n:\"BrtWsFmtInfoEx14\" */ },\n\t/*::[*/0x0416/*::]*/: { /* n:\"BrtBeginConditionalFormatting14\", */ T:1 },\n\t/*::[*/0x0417/*::]*/: { /* n:\"BrtEndConditionalFormatting14\", */ T:-1 },\n\t/*::[*/0x0418/*::]*/: { /* n:\"BrtBeginCFRule14\", */ T:1 },\n\t/*::[*/0x0419/*::]*/: { /* n:\"BrtEndCFRule14\", */ T:-1 },\n\t/*::[*/0x041A/*::]*/: { /* n:\"BrtCFVO14\" */ },\n\t/*::[*/0x041B/*::]*/: { /* n:\"BrtBeginDatabar14\", */ T:1 },\n\t/*::[*/0x041C/*::]*/: { /* n:\"BrtBeginIconSet14\", */ T:1 },\n\t/*::[*/0x041D/*::]*/: { /* n:\"BrtDVal14\", */ f: parse_BrtDVal14 },\n\t/*::[*/0x041E/*::]*/: { /* n:\"BrtBeginDVals14\", */ T:1 },\n\t/*::[*/0x041F/*::]*/: { /* n:\"BrtColor14\" */ },\n\t/*::[*/0x0420/*::]*/: { /* n:\"BrtBeginSparklines\", */ T:1 },\n\t/*::[*/0x0421/*::]*/: { /* n:\"BrtEndSparklines\", */ T:-1 },\n\t/*::[*/0x0422/*::]*/: { /* n:\"BrtBeginSparklineGroups\", */ T:1 },\n\t/*::[*/0x0423/*::]*/: { /* n:\"BrtEndSparklineGroups\", */ T:-1 },\n\t/*::[*/0x0425/*::]*/: { /* n:\"BrtSXVD14\" */ },\n\t/*::[*/0x0426/*::]*/: { /* n:\"BrtBeginSXView14\", */ T:1 },\n\t/*::[*/0x0427/*::]*/: { /* n:\"BrtEndSXView14\", */ T:-1 },\n\t/*::[*/0x0428/*::]*/: { /* n:\"BrtBeginSXView16\", */ T:1 },\n\t/*::[*/0x0429/*::]*/: { /* n:\"BrtEndSXView16\", */ T:-1 },\n\t/*::[*/0x042A/*::]*/: { /* n:\"BrtBeginPCD14\", */ T:1 },\n\t/*::[*/0x042B/*::]*/: { /* n:\"BrtEndPCD14\", */ T:-1 },\n\t/*::[*/0x042C/*::]*/: { /* n:\"BrtBeginExtConn14\", */ T:1 },\n\t/*::[*/0x042D/*::]*/: { /* n:\"BrtEndExtConn14\", */ T:-1 },\n\t/*::[*/0x042E/*::]*/: { /* n:\"BrtBeginSlicerCacheIDs\", */ T:1 },\n\t/*::[*/0x042F/*::]*/: { /* n:\"BrtEndSlicerCacheIDs\", */ T:-1 },\n\t/*::[*/0x0430/*::]*/: { /* n:\"BrtBeginSlicerCacheID\", */ T:1 },\n\t/*::[*/0x0431/*::]*/: { /* n:\"BrtEndSlicerCacheID\", */ T:-1 },\n\t/*::[*/0x0433/*::]*/: { /* n:\"BrtBeginSlicerCache\", */ T:1 },\n\t/*::[*/0x0434/*::]*/: { /* n:\"BrtEndSlicerCache\", */ T:-1 },\n\t/*::[*/0x0435/*::]*/: { /* n:\"BrtBeginSlicerCacheDef\", */ T:1 },\n\t/*::[*/0x0436/*::]*/: { /* n:\"BrtEndSlicerCacheDef\", */ T:-1 },\n\t/*::[*/0x0437/*::]*/: { /* n:\"BrtBeginSlicersEx\", */ T:1 },\n\t/*::[*/0x0438/*::]*/: { /* n:\"BrtEndSlicersEx\", */ T:-1 },\n\t/*::[*/0x0439/*::]*/: { /* n:\"BrtBeginSlicerEx\", */ T:1 },\n\t/*::[*/0x043A/*::]*/: { /* n:\"BrtEndSlicerEx\", */ T:-1 },\n\t/*::[*/0x043B/*::]*/: { /* n:\"BrtBeginSlicer\", */ T:1 },\n\t/*::[*/0x043C/*::]*/: { /* n:\"BrtEndSlicer\", */ T:-1 },\n\t/*::[*/0x043D/*::]*/: { /* n:\"BrtSlicerCachePivotTables\" */ },\n\t/*::[*/0x043E/*::]*/: { /* n:\"BrtBeginSlicerCacheOlapImpl\", */ T:1 },\n\t/*::[*/0x043F/*::]*/: { /* n:\"BrtEndSlicerCacheOlapImpl\", */ T:-1 },\n\t/*::[*/0x0440/*::]*/: { /* n:\"BrtBeginSlicerCacheLevelsData\", */ T:1 },\n\t/*::[*/0x0441/*::]*/: { /* n:\"BrtEndSlicerCacheLevelsData\", */ T:-1 },\n\t/*::[*/0x0442/*::]*/: { /* n:\"BrtBeginSlicerCacheLevelData\", */ T:1 },\n\t/*::[*/0x0443/*::]*/: { /* n:\"BrtEndSlicerCacheLevelData\", */ T:-1 },\n\t/*::[*/0x0444/*::]*/: { /* n:\"BrtBeginSlicerCacheSiRanges\", */ T:1 },\n\t/*::[*/0x0445/*::]*/: { /* n:\"BrtEndSlicerCacheSiRanges\", */ T:-1 },\n\t/*::[*/0x0446/*::]*/: { /* n:\"BrtBeginSlicerCacheSiRange\", */ T:1 },\n\t/*::[*/0x0447/*::]*/: { /* n:\"BrtEndSlicerCacheSiRange\", */ T:-1 },\n\t/*::[*/0x0448/*::]*/: { /* n:\"BrtSlicerCacheOlapItem\" */ },\n\t/*::[*/0x0449/*::]*/: { /* n:\"BrtBeginSlicerCacheSelections\", */ T:1 },\n\t/*::[*/0x044A/*::]*/: { /* n:\"BrtSlicerCacheSelection\" */ },\n\t/*::[*/0x044B/*::]*/: { /* n:\"BrtEndSlicerCacheSelections\", */ T:-1 },\n\t/*::[*/0x044C/*::]*/: { /* n:\"BrtBeginSlicerCacheNative\", */ T:1 },\n\t/*::[*/0x044D/*::]*/: { /* n:\"BrtEndSlicerCacheNative\", */ T:-1 },\n\t/*::[*/0x044E/*::]*/: { /* n:\"BrtSlicerCacheNativeItem\" */ },\n\t/*::[*/0x044F/*::]*/: { /* n:\"BrtRangeProtection14\" */ },\n\t/*::[*/0x0450/*::]*/: { /* n:\"BrtRangeProtectionIso14\" */ },\n\t/*::[*/0x0451/*::]*/: { /* n:\"BrtCellIgnoreEC14\" */ },\n\t/*::[*/0x0457/*::]*/: { /* n:\"BrtList14\" */ },\n\t/*::[*/0x0458/*::]*/: { /* n:\"BrtCFIcon\" */ },\n\t/*::[*/0x0459/*::]*/: { /* n:\"BrtBeginSlicerCachesPivotCacheIDs\", */ T:1 },\n\t/*::[*/0x045A/*::]*/: { /* n:\"BrtEndSlicerCachesPivotCacheIDs\", */ T:-1 },\n\t/*::[*/0x045B/*::]*/: { /* n:\"BrtBeginSlicers\", */ T:1 },\n\t/*::[*/0x045C/*::]*/: { /* n:\"BrtEndSlicers\", */ T:-1 },\n\t/*::[*/0x045D/*::]*/: { /* n:\"BrtWbProp14\" */ },\n\t/*::[*/0x045E/*::]*/: { /* n:\"BrtBeginSXEdit\", */ T:1 },\n\t/*::[*/0x045F/*::]*/: { /* n:\"BrtEndSXEdit\", */ T:-1 },\n\t/*::[*/0x0460/*::]*/: { /* n:\"BrtBeginSXEdits\", */ T:1 },\n\t/*::[*/0x0461/*::]*/: { /* n:\"BrtEndSXEdits\", */ T:-1 },\n\t/*::[*/0x0462/*::]*/: { /* n:\"BrtBeginSXChange\", */ T:1 },\n\t/*::[*/0x0463/*::]*/: { /* n:\"BrtEndSXChange\", */ T:-1 },\n\t/*::[*/0x0464/*::]*/: { /* n:\"BrtBeginSXChanges\", */ T:1 },\n\t/*::[*/0x0465/*::]*/: { /* n:\"BrtEndSXChanges\", */ T:-1 },\n\t/*::[*/0x0466/*::]*/: { /* n:\"BrtSXTupleItems\" */ },\n\t/*::[*/0x0468/*::]*/: { /* n:\"BrtBeginSlicerStyle\", */ T:1 },\n\t/*::[*/0x0469/*::]*/: { /* n:\"BrtEndSlicerStyle\", */ T:-1 },\n\t/*::[*/0x046A/*::]*/: { /* n:\"BrtSlicerStyleElement\" */ },\n\t/*::[*/0x046B/*::]*/: { /* n:\"BrtBeginStyleSheetExt14\", */ T:1 },\n\t/*::[*/0x046C/*::]*/: { /* n:\"BrtEndStyleSheetExt14\", */ T:-1 },\n\t/*::[*/0x046D/*::]*/: { /* n:\"BrtBeginSlicerCachesPivotCacheID\", */ T:1 },\n\t/*::[*/0x046E/*::]*/: { /* n:\"BrtEndSlicerCachesPivotCacheID\", */ T:-1 },\n\t/*::[*/0x046F/*::]*/: { /* n:\"BrtBeginConditionalFormattings\", */ T:1 },\n\t/*::[*/0x0470/*::]*/: { /* n:\"BrtEndConditionalFormattings\", */ T:-1 },\n\t/*::[*/0x0471/*::]*/: { /* n:\"BrtBeginPCDCalcMemExt\", */ T:1 },\n\t/*::[*/0x0472/*::]*/: { /* n:\"BrtEndPCDCalcMemExt\", */ T:-1 },\n\t/*::[*/0x0473/*::]*/: { /* n:\"BrtBeginPCDCalcMemsExt\", */ T:1 },\n\t/*::[*/0x0474/*::]*/: { /* n:\"BrtEndPCDCalcMemsExt\", */ T:-1 },\n\t/*::[*/0x0475/*::]*/: { /* n:\"BrtPCDField14\" */ },\n\t/*::[*/0x0476/*::]*/: { /* n:\"BrtBeginSlicerStyles\", */ T:1 },\n\t/*::[*/0x0477/*::]*/: { /* n:\"BrtEndSlicerStyles\", */ T:-1 },\n\t/*::[*/0x0478/*::]*/: { /* n:\"BrtBeginSlicerStyleElements\", */ T:1 },\n\t/*::[*/0x0479/*::]*/: { /* n:\"BrtEndSlicerStyleElements\", */ T:-1 },\n\t/*::[*/0x047A/*::]*/: { /* n:\"BrtCFRuleExt\" */ },\n\t/*::[*/0x047B/*::]*/: { /* n:\"BrtBeginSXCondFmt14\", */ T:1 },\n\t/*::[*/0x047C/*::]*/: { /* n:\"BrtEndSXCondFmt14\", */ T:-1 },\n\t/*::[*/0x047D/*::]*/: { /* n:\"BrtBeginSXCondFmts14\", */ T:1 },\n\t/*::[*/0x047E/*::]*/: { /* n:\"BrtEndSXCondFmts14\", */ T:-1 },\n\t/*::[*/0x0480/*::]*/: { /* n:\"BrtBeginSortCond14\", */ T:1 },\n\t/*::[*/0x0481/*::]*/: { /* n:\"BrtEndSortCond14\", */ T:-1 },\n\t/*::[*/0x0482/*::]*/: { /* n:\"BrtEndDVals14\", */ T:-1 },\n\t/*::[*/0x0483/*::]*/: { /* n:\"BrtEndIconSet14\", */ T:-1 },\n\t/*::[*/0x0484/*::]*/: { /* n:\"BrtEndDatabar14\", */ T:-1 },\n\t/*::[*/0x0485/*::]*/: { /* n:\"BrtBeginColorScale14\", */ T:1 },\n\t/*::[*/0x0486/*::]*/: { /* n:\"BrtEndColorScale14\", */ T:-1 },\n\t/*::[*/0x0487/*::]*/: { /* n:\"BrtBeginSxrules14\", */ T:1 },\n\t/*::[*/0x0488/*::]*/: { /* n:\"BrtEndSxrules14\", */ T:-1 },\n\t/*::[*/0x0489/*::]*/: { /* n:\"BrtBeginPRule14\", */ T:1 },\n\t/*::[*/0x048A/*::]*/: { /* n:\"BrtEndPRule14\", */ T:-1 },\n\t/*::[*/0x048B/*::]*/: { /* n:\"BrtBeginPRFilters14\", */ T:1 },\n\t/*::[*/0x048C/*::]*/: { /* n:\"BrtEndPRFilters14\", */ T:-1 },\n\t/*::[*/0x048D/*::]*/: { /* n:\"BrtBeginPRFilter14\", */ T:1 },\n\t/*::[*/0x048E/*::]*/: { /* n:\"BrtEndPRFilter14\", */ T:-1 },\n\t/*::[*/0x048F/*::]*/: { /* n:\"BrtBeginPRFItem14\", */ T:1 },\n\t/*::[*/0x0490/*::]*/: { /* n:\"BrtEndPRFItem14\", */ T:-1 },\n\t/*::[*/0x0491/*::]*/: { /* n:\"BrtBeginCellIgnoreECs14\", */ T:1 },\n\t/*::[*/0x0492/*::]*/: { /* n:\"BrtEndCellIgnoreECs14\", */ T:-1 },\n\t/*::[*/0x0493/*::]*/: { /* n:\"BrtDxf14\" */ },\n\t/*::[*/0x0494/*::]*/: { /* n:\"BrtBeginDxF14s\", */ T:1 },\n\t/*::[*/0x0495/*::]*/: { /* n:\"BrtEndDxf14s\", */ T:-1 },\n\t/*::[*/0x0499/*::]*/: { /* n:\"BrtFilter14\" */ },\n\t/*::[*/0x049A/*::]*/: { /* n:\"BrtBeginCustomFilters14\", */ T:1 },\n\t/*::[*/0x049C/*::]*/: { /* n:\"BrtCustomFilter14\" */ },\n\t/*::[*/0x049D/*::]*/: { /* n:\"BrtIconFilter14\" */ },\n\t/*::[*/0x049E/*::]*/: { /* n:\"BrtPivotCacheConnectionName\" */ },\n\t/*::[*/0x0800/*::]*/: { /* n:\"BrtBeginDecoupledPivotCacheIDs\", */ T:1 },\n\t/*::[*/0x0801/*::]*/: { /* n:\"BrtEndDecoupledPivotCacheIDs\", */ T:-1 },\n\t/*::[*/0x0802/*::]*/: { /* n:\"BrtDecoupledPivotCacheID\" */ },\n\t/*::[*/0x0803/*::]*/: { /* n:\"BrtBeginPivotTableRefs\", */ T:1 },\n\t/*::[*/0x0804/*::]*/: { /* n:\"BrtEndPivotTableRefs\", */ T:-1 },\n\t/*::[*/0x0805/*::]*/: { /* n:\"BrtPivotTableRef\" */ },\n\t/*::[*/0x0806/*::]*/: { /* n:\"BrtSlicerCacheBookPivotTables\" */ },\n\t/*::[*/0x0807/*::]*/: { /* n:\"BrtBeginSxvcells\", */ T:1 },\n\t/*::[*/0x0808/*::]*/: { /* n:\"BrtEndSxvcells\", */ T:-1 },\n\t/*::[*/0x0809/*::]*/: { /* n:\"BrtBeginSxRow\", */ T:1 },\n\t/*::[*/0x080A/*::]*/: { /* n:\"BrtEndSxRow\", */ T:-1 },\n\t/*::[*/0x080C/*::]*/: { /* n:\"BrtPcdCalcMem15\" */ },\n\t/*::[*/0x0813/*::]*/: { /* n:\"BrtQsi15\" */ },\n\t/*::[*/0x0814/*::]*/: { /* n:\"BrtBeginWebExtensions\", */ T:1 },\n\t/*::[*/0x0815/*::]*/: { /* n:\"BrtEndWebExtensions\", */ T:-1 },\n\t/*::[*/0x0816/*::]*/: { /* n:\"BrtWebExtension\" */ },\n\t/*::[*/0x0817/*::]*/: { /* n:\"BrtAbsPath15\" */ },\n\t/*::[*/0x0818/*::]*/: { /* n:\"BrtBeginPivotTableUISettings\", */ T:1 },\n\t/*::[*/0x0819/*::]*/: { /* n:\"BrtEndPivotTableUISettings\", */ T:-1 },\n\t/*::[*/0x081B/*::]*/: { /* n:\"BrtTableSlicerCacheIDs\" */ },\n\t/*::[*/0x081C/*::]*/: { /* n:\"BrtTableSlicerCacheID\" */ },\n\t/*::[*/0x081D/*::]*/: { /* n:\"BrtBeginTableSlicerCache\", */ T:1 },\n\t/*::[*/0x081E/*::]*/: { /* n:\"BrtEndTableSlicerCache\", */ T:-1 },\n\t/*::[*/0x081F/*::]*/: { /* n:\"BrtSxFilter15\" */ },\n\t/*::[*/0x0820/*::]*/: { /* n:\"BrtBeginTimelineCachePivotCacheIDs\", */ T:1 },\n\t/*::[*/0x0821/*::]*/: { /* n:\"BrtEndTimelineCachePivotCacheIDs\", */ T:-1 },\n\t/*::[*/0x0822/*::]*/: { /* n:\"BrtTimelineCachePivotCacheID\" */ },\n\t/*::[*/0x0823/*::]*/: { /* n:\"BrtBeginTimelineCacheIDs\", */ T:1 },\n\t/*::[*/0x0824/*::]*/: { /* n:\"BrtEndTimelineCacheIDs\", */ T:-1 },\n\t/*::[*/0x0825/*::]*/: { /* n:\"BrtBeginTimelineCacheID\", */ T:1 },\n\t/*::[*/0x0826/*::]*/: { /* n:\"BrtEndTimelineCacheID\", */ T:-1 },\n\t/*::[*/0x0827/*::]*/: { /* n:\"BrtBeginTimelinesEx\", */ T:1 },\n\t/*::[*/0x0828/*::]*/: { /* n:\"BrtEndTimelinesEx\", */ T:-1 },\n\t/*::[*/0x0829/*::]*/: { /* n:\"BrtBeginTimelineEx\", */ T:1 },\n\t/*::[*/0x082A/*::]*/: { /* n:\"BrtEndTimelineEx\", */ T:-1 },\n\t/*::[*/0x082B/*::]*/: { /* n:\"BrtWorkBookPr15\" */ },\n\t/*::[*/0x082C/*::]*/: { /* n:\"BrtPCDH15\" */ },\n\t/*::[*/0x082D/*::]*/: { /* n:\"BrtBeginTimelineStyle\", */ T:1 },\n\t/*::[*/0x082E/*::]*/: { /* n:\"BrtEndTimelineStyle\", */ T:-1 },\n\t/*::[*/0x082F/*::]*/: { /* n:\"BrtTimelineStyleElement\" */ },\n\t/*::[*/0x0830/*::]*/: { /* n:\"BrtBeginTimelineStylesheetExt15\", */ T:1 },\n\t/*::[*/0x0831/*::]*/: { /* n:\"BrtEndTimelineStylesheetExt15\", */ T:-1 },\n\t/*::[*/0x0832/*::]*/: { /* n:\"BrtBeginTimelineStyles\", */ T:1 },\n\t/*::[*/0x0833/*::]*/: { /* n:\"BrtEndTimelineStyles\", */ T:-1 },\n\t/*::[*/0x0834/*::]*/: { /* n:\"BrtBeginTimelineStyleElements\", */ T:1 },\n\t/*::[*/0x0835/*::]*/: { /* n:\"BrtEndTimelineStyleElements\", */ T:-1 },\n\t/*::[*/0x0836/*::]*/: { /* n:\"BrtDxf15\" */ },\n\t/*::[*/0x0837/*::]*/: { /* n:\"BrtBeginDxfs15\", */ T:1 },\n\t/*::[*/0x0838/*::]*/: { /* n:\"BrtEndDxfs15\", */ T:-1 },\n\t/*::[*/0x0839/*::]*/: { /* n:\"BrtSlicerCacheHideItemsWithNoData\" */ },\n\t/*::[*/0x083A/*::]*/: { /* n:\"BrtBeginItemUniqueNames\", */ T:1 },\n\t/*::[*/0x083B/*::]*/: { /* n:\"BrtEndItemUniqueNames\", */ T:-1 },\n\t/*::[*/0x083C/*::]*/: { /* n:\"BrtItemUniqueName\" */ },\n\t/*::[*/0x083D/*::]*/: { /* n:\"BrtBeginExtConn15\", */ T:1 },\n\t/*::[*/0x083E/*::]*/: { /* n:\"BrtEndExtConn15\", */ T:-1 },\n\t/*::[*/0x083F/*::]*/: { /* n:\"BrtBeginOledbPr15\", */ T:1 },\n\t/*::[*/0x0840/*::]*/: { /* n:\"BrtEndOledbPr15\", */ T:-1 },\n\t/*::[*/0x0841/*::]*/: { /* n:\"BrtBeginDataFeedPr15\", */ T:1 },\n\t/*::[*/0x0842/*::]*/: { /* n:\"BrtEndDataFeedPr15\", */ T:-1 },\n\t/*::[*/0x0843/*::]*/: { /* n:\"BrtTextPr15\" */ },\n\t/*::[*/0x0844/*::]*/: { /* n:\"BrtRangePr15\" */ },\n\t/*::[*/0x0845/*::]*/: { /* n:\"BrtDbCommand15\" */ },\n\t/*::[*/0x0846/*::]*/: { /* n:\"BrtBeginDbTables15\", */ T:1 },\n\t/*::[*/0x0847/*::]*/: { /* n:\"BrtEndDbTables15\", */ T:-1 },\n\t/*::[*/0x0848/*::]*/: { /* n:\"BrtDbTable15\" */ },\n\t/*::[*/0x0849/*::]*/: { /* n:\"BrtBeginDataModel\", */ T:1 },\n\t/*::[*/0x084A/*::]*/: { /* n:\"BrtEndDataModel\", */ T:-1 },\n\t/*::[*/0x084B/*::]*/: { /* n:\"BrtBeginModelTables\", */ T:1 },\n\t/*::[*/0x084C/*::]*/: { /* n:\"BrtEndModelTables\", */ T:-1 },\n\t/*::[*/0x084D/*::]*/: { /* n:\"BrtModelTable\" */ },\n\t/*::[*/0x084E/*::]*/: { /* n:\"BrtBeginModelRelationships\", */ T:1 },\n\t/*::[*/0x084F/*::]*/: { /* n:\"BrtEndModelRelationships\", */ T:-1 },\n\t/*::[*/0x0850/*::]*/: { /* n:\"BrtModelRelationship\" */ },\n\t/*::[*/0x0851/*::]*/: { /* n:\"BrtBeginECTxtWiz15\", */ T:1 },\n\t/*::[*/0x0852/*::]*/: { /* n:\"BrtEndECTxtWiz15\", */ T:-1 },\n\t/*::[*/0x0853/*::]*/: { /* n:\"BrtBeginECTWFldInfoLst15\", */ T:1 },\n\t/*::[*/0x0854/*::]*/: { /* n:\"BrtEndECTWFldInfoLst15\", */ T:-1 },\n\t/*::[*/0x0855/*::]*/: { /* n:\"BrtBeginECTWFldInfo15\", */ T:1 },\n\t/*::[*/0x0856/*::]*/: { /* n:\"BrtFieldListActiveItem\" */ },\n\t/*::[*/0x0857/*::]*/: { /* n:\"BrtPivotCacheIdVersion\" */ },\n\t/*::[*/0x0858/*::]*/: { /* n:\"BrtSXDI15\" */ },\n\t/*::[*/0x0859/*::]*/: { /* n:\"BrtBeginModelTimeGroupings\", */ T:1 },\n\t/*::[*/0x085A/*::]*/: { /* n:\"BrtEndModelTimeGroupings\", */ T:-1 },\n\t/*::[*/0x085B/*::]*/: { /* n:\"BrtBeginModelTimeGrouping\", */ T:1 },\n\t/*::[*/0x085C/*::]*/: { /* n:\"BrtEndModelTimeGrouping\", */ T:-1 },\n\t/*::[*/0x085D/*::]*/: { /* n:\"BrtModelTimeGroupingCalcCol\" */ },\n\t/*::[*/0x0C00/*::]*/: { /* n:\"BrtUid\" */ },\n\t/*::[*/0x0C01/*::]*/: { /* n:\"BrtRevisionPtr\" */ },\n\t/*::[*/0x1000/*::]*/: { /* n:\"BrtBeginDynamicArrayPr\", */ T:1 },\n\t/*::[*/0x1001/*::]*/: { /* n:\"BrtEndDynamicArrayPr\", */ T:-1 },\n\t/*::[*/0x138A/*::]*/: { /* n:\"BrtBeginRichValueBlock\", */ T:1 },\n\t/*::[*/0x138B/*::]*/: { /* n:\"BrtEndRichValueBlock\", */ T:-1 },\n\t/*::[*/0x13D9/*::]*/: { /* n:\"BrtBeginRichFilters\", */ T:1 },\n\t/*::[*/0x13DA/*::]*/: { /* n:\"BrtEndRichFilters\", */ T:-1 },\n\t/*::[*/0x13DB/*::]*/: { /* n:\"BrtRichFilter\" */ },\n\t/*::[*/0x13DC/*::]*/: { /* n:\"BrtBeginRichFilterColumn\", */ T:1 },\n\t/*::[*/0x13DD/*::]*/: { /* n:\"BrtEndRichFilterColumn\", */ T:-1 },\n\t/*::[*/0x13DE/*::]*/: { /* n:\"BrtBeginCustomRichFilters\", */ T:1 },\n\t/*::[*/0x13DF/*::]*/: { /* n:\"BrtEndCustomRichFilters\", */ T:-1 },\n\t/*::[*/0x13E0/*::]*/: { /* n:\"BrtCustomRichFilter\" */ },\n\t/*::[*/0x13E1/*::]*/: { /* n:\"BrtTop10RichFilter\" */ },\n\t/*::[*/0x13E2/*::]*/: { /* n:\"BrtDynamicRichFilter\" */ },\n\t/*::[*/0x13E4/*::]*/: { /* n:\"BrtBeginRichSortCondition\", */ T:1 },\n\t/*::[*/0x13E5/*::]*/: { /* n:\"BrtEndRichSortCondition\", */ T:-1 },\n\t/*::[*/0x13E6/*::]*/: { /* n:\"BrtRichFilterDateGroupItem\" */ },\n\t/*::[*/0x13E7/*::]*/: { /* n:\"BrtBeginCalcFeatures\", */ T:1 },\n\t/*::[*/0x13E8/*::]*/: { /* n:\"BrtEndCalcFeatures\", */ T:-1 },\n\t/*::[*/0x13E9/*::]*/: { /* n:\"BrtCalcFeature\" */ },\n\t/*::[*/0x13EB/*::]*/: { /* n:\"BrtExternalLinksPr\" */ },\n\t/*::[*/0xFFFF/*::]*/: { n:\"\" }\n};\n\n/* [MS-XLS] 2.3 Record Enumeration (and other sources) */\nvar XLSRecordEnum = {\n\t/* [MS-XLS] 2.3 Record Enumeration 2021-08-17 */\n\t/*::[*/0x0006/*::]*/: { /* n:\"Formula\", */ f:parse_Formula },\n\t/*::[*/0x000a/*::]*/: { /* n:\"EOF\", */ f:parsenoop2 },\n\t/*::[*/0x000c/*::]*/: { /* n:\"CalcCount\", */ f:parseuint16 }, //\n\t/*::[*/0x000d/*::]*/: { /* n:\"CalcMode\", */ f:parseuint16 }, //\n\t/*::[*/0x000e/*::]*/: { /* n:\"CalcPrecision\", */ f:parsebool }, //\n\t/*::[*/0x000f/*::]*/: { /* n:\"CalcRefMode\", */ f:parsebool }, //\n\t/*::[*/0x0010/*::]*/: { /* n:\"CalcDelta\", */ f:parse_Xnum }, //\n\t/*::[*/0x0011/*::]*/: { /* n:\"CalcIter\", */ f:parsebool }, //\n\t/*::[*/0x0012/*::]*/: { /* n:\"Protect\", */ f:parsebool },\n\t/*::[*/0x0013/*::]*/: { /* n:\"Password\", */ f:parseuint16 },\n\t/*::[*/0x0014/*::]*/: { /* n:\"Header\", */ f:parse_XLHeaderFooter },\n\t/*::[*/0x0015/*::]*/: { /* n:\"Footer\", */ f:parse_XLHeaderFooter },\n\t/*::[*/0x0017/*::]*/: { /* n:\"ExternSheet\", */ f:parse_ExternSheet },\n\t/*::[*/0x0018/*::]*/: { /* n:\"Lbl\", */ f:parse_Lbl },\n\t/*::[*/0x0019/*::]*/: { /* n:\"WinProtect\", */ f:parsebool },\n\t/*::[*/0x001a/*::]*/: { /* n:\"VerticalPageBreaks\", */ },\n\t/*::[*/0x001b/*::]*/: { /* n:\"HorizontalPageBreaks\", */ },\n\t/*::[*/0x001c/*::]*/: { /* n:\"Note\", */ f:parse_Note },\n\t/*::[*/0x001d/*::]*/: { /* n:\"Selection\", */ },\n\t/*::[*/0x0022/*::]*/: { /* n:\"Date1904\", */ f:parsebool },\n\t/*::[*/0x0023/*::]*/: { /* n:\"ExternName\", */ f:parse_ExternName },\n\t/*::[*/0x0026/*::]*/: { /* n:\"LeftMargin\", */ f:parse_Xnum }, // *\n\t/*::[*/0x0027/*::]*/: { /* n:\"RightMargin\", */ f:parse_Xnum }, // *\n\t/*::[*/0x0028/*::]*/: { /* n:\"TopMargin\", */ f:parse_Xnum }, // *\n\t/*::[*/0x0029/*::]*/: { /* n:\"BottomMargin\", */ f:parse_Xnum }, // *\n\t/*::[*/0x002a/*::]*/: { /* n:\"PrintRowCol\", */ f:parsebool },\n\t/*::[*/0x002b/*::]*/: { /* n:\"PrintGrid\", */ f:parsebool },\n\t/*::[*/0x002f/*::]*/: { /* n:\"FilePass\", */ f:parse_FilePass },\n\t/*::[*/0x0031/*::]*/: { /* n:\"Font\", */ f:parse_Font },\n\t/*::[*/0x0033/*::]*/: { /* n:\"PrintSize\", */ f:parseuint16 },\n\t/*::[*/0x003c/*::]*/: { /* n:\"Continue\", */ },\n\t/*::[*/0x003d/*::]*/: { /* n:\"Window1\", */ f:parse_Window1 },\n\t/*::[*/0x0040/*::]*/: { /* n:\"Backup\", */ f:parsebool },\n\t/*::[*/0x0041/*::]*/: { /* n:\"Pane\", */ f:parse_Pane },\n\t/*::[*/0x0042/*::]*/: { /* n:\"CodePage\", */ f:parseuint16 },\n\t/*::[*/0x004d/*::]*/: { /* n:\"Pls\", */ },\n\t/*::[*/0x0050/*::]*/: { /* n:\"DCon\", */ },\n\t/*::[*/0x0051/*::]*/: { /* n:\"DConRef\", */ },\n\t/*::[*/0x0052/*::]*/: { /* n:\"DConName\", */ },\n\t/*::[*/0x0055/*::]*/: { /* n:\"DefColWidth\", */ f:parseuint16 },\n\t/*::[*/0x0059/*::]*/: { /* n:\"XCT\", */ },\n\t/*::[*/0x005a/*::]*/: { /* n:\"CRN\", */ },\n\t/*::[*/0x005b/*::]*/: { /* n:\"FileSharing\", */ },\n\t/*::[*/0x005c/*::]*/: { /* n:\"WriteAccess\", */ f:parse_WriteAccess },\n\t/*::[*/0x005d/*::]*/: { /* n:\"Obj\", */ f:parse_Obj },\n\t/*::[*/0x005e/*::]*/: { /* n:\"Uncalced\", */ },\n\t/*::[*/0x005f/*::]*/: { /* n:\"CalcSaveRecalc\", */ f:parsebool }, //\n\t/*::[*/0x0060/*::]*/: { /* n:\"Template\", */ },\n\t/*::[*/0x0061/*::]*/: { /* n:\"Intl\", */ },\n\t/*::[*/0x0063/*::]*/: { /* n:\"ObjProtect\", */ f:parsebool },\n\t/*::[*/0x007d/*::]*/: { /* n:\"ColInfo\", */ f:parse_ColInfo },\n\t/*::[*/0x0080/*::]*/: { /* n:\"Guts\", */ f:parse_Guts },\n\t/*::[*/0x0081/*::]*/: { /* n:\"WsBool\", */ f:parse_WsBool },\n\t/*::[*/0x0082/*::]*/: { /* n:\"GridSet\", */ f:parseuint16 },\n\t/*::[*/0x0083/*::]*/: { /* n:\"HCenter\", */ f:parsebool },\n\t/*::[*/0x0084/*::]*/: { /* n:\"VCenter\", */ f:parsebool },\n\t/*::[*/0x0085/*::]*/: { /* n:\"BoundSheet8\", */ f:parse_BoundSheet8 },\n\t/*::[*/0x0086/*::]*/: { /* n:\"WriteProtect\", */ },\n\t/*::[*/0x008c/*::]*/: { /* n:\"Country\", */ f:parse_Country },\n\t/*::[*/0x008d/*::]*/: { /* n:\"HideObj\", */ f:parseuint16 },\n\t/*::[*/0x0090/*::]*/: { /* n:\"Sort\", */ },\n\t/*::[*/0x0092/*::]*/: { /* n:\"Palette\", */ f:parse_Palette },\n\t/*::[*/0x0097/*::]*/: { /* n:\"Sync\", */ },\n\t/*::[*/0x0098/*::]*/: { /* n:\"LPr\", */ },\n\t/*::[*/0x0099/*::]*/: { /* n:\"DxGCol\", */ },\n\t/*::[*/0x009a/*::]*/: { /* n:\"FnGroupName\", */ },\n\t/*::[*/0x009b/*::]*/: { /* n:\"FilterMode\", */ },\n\t/*::[*/0x009c/*::]*/: { /* n:\"BuiltInFnGroupCount\", */ f:parseuint16 },\n\t/*::[*/0x009d/*::]*/: { /* n:\"AutoFilterInfo\", */ },\n\t/*::[*/0x009e/*::]*/: { /* n:\"AutoFilter\", */ },\n\t/*::[*/0x00a0/*::]*/: { /* n:\"Scl\", */ f:parse_Scl },\n\t/*::[*/0x00a1/*::]*/: { /* n:\"Setup\", */ f:parse_Setup },\n\t/*::[*/0x00ae/*::]*/: { /* n:\"ScenMan\", */ },\n\t/*::[*/0x00af/*::]*/: { /* n:\"SCENARIO\", */ },\n\t/*::[*/0x00b0/*::]*/: { /* n:\"SxView\", */ },\n\t/*::[*/0x00b1/*::]*/: { /* n:\"Sxvd\", */ },\n\t/*::[*/0x00b2/*::]*/: { /* n:\"SXVI\", */ },\n\t/*::[*/0x00b4/*::]*/: { /* n:\"SxIvd\", */ },\n\t/*::[*/0x00b5/*::]*/: { /* n:\"SXLI\", */ },\n\t/*::[*/0x00b6/*::]*/: { /* n:\"SXPI\", */ },\n\t/*::[*/0x00b8/*::]*/: { /* n:\"DocRoute\", */ },\n\t/*::[*/0x00b9/*::]*/: { /* n:\"RecipName\", */ },\n\t/*::[*/0x00bd/*::]*/: { /* n:\"MulRk\", */ f:parse_MulRk },\n\t/*::[*/0x00be/*::]*/: { /* n:\"MulBlank\", */ f:parse_MulBlank },\n\t/*::[*/0x00c1/*::]*/: { /* n:\"Mms\", */ f:parsenoop2 },\n\t/*::[*/0x00c5/*::]*/: { /* n:\"SXDI\", */ },\n\t/*::[*/0x00c6/*::]*/: { /* n:\"SXDB\", */ },\n\t/*::[*/0x00c7/*::]*/: { /* n:\"SXFDB\", */ },\n\t/*::[*/0x00c8/*::]*/: { /* n:\"SXDBB\", */ },\n\t/*::[*/0x00c9/*::]*/: { /* n:\"SXNum\", */ },\n\t/*::[*/0x00ca/*::]*/: { /* n:\"SxBool\", */ f:parsebool },\n\t/*::[*/0x00cb/*::]*/: { /* n:\"SxErr\", */ },\n\t/*::[*/0x00cc/*::]*/: { /* n:\"SXInt\", */ },\n\t/*::[*/0x00cd/*::]*/: { /* n:\"SXString\", */ },\n\t/*::[*/0x00ce/*::]*/: { /* n:\"SXDtr\", */ },\n\t/*::[*/0x00cf/*::]*/: { /* n:\"SxNil\", */ },\n\t/*::[*/0x00d0/*::]*/: { /* n:\"SXTbl\", */ },\n\t/*::[*/0x00d1/*::]*/: { /* n:\"SXTBRGIITM\", */ },\n\t/*::[*/0x00d2/*::]*/: { /* n:\"SxTbpg\", */ },\n\t/*::[*/0x00d3/*::]*/: { /* n:\"ObProj\", */ },\n\t/*::[*/0x00d5/*::]*/: { /* n:\"SXStreamID\", */ },\n\t/*::[*/0x00d7/*::]*/: { /* n:\"DBCell\", */ },\n\t/*::[*/0x00d8/*::]*/: { /* n:\"SXRng\", */ },\n\t/*::[*/0x00d9/*::]*/: { /* n:\"SxIsxoper\", */ },\n\t/*::[*/0x00da/*::]*/: { /* n:\"BookBool\", */ f:parseuint16 },\n\t/*::[*/0x00dc/*::]*/: { /* n:\"DbOrParamQry\", */ },\n\t/*::[*/0x00dd/*::]*/: { /* n:\"ScenarioProtect\", */ f:parsebool },\n\t/*::[*/0x00de/*::]*/: { /* n:\"OleObjectSize\", */ },\n\t/*::[*/0x00e0/*::]*/: { /* n:\"XF\", */ f:parse_XF },\n\t/*::[*/0x00e1/*::]*/: { /* n:\"InterfaceHdr\", */ f:parse_InterfaceHdr },\n\t/*::[*/0x00e2/*::]*/: { /* n:\"InterfaceEnd\", */ f:parsenoop2 },\n\t/*::[*/0x00e3/*::]*/: { /* n:\"SXVS\", */ },\n\t/*::[*/0x00e5/*::]*/: { /* n:\"MergeCells\", */ f:parse_MergeCells },\n\t/*::[*/0x00e9/*::]*/: { /* n:\"BkHim\", */ },\n\t/*::[*/0x00eb/*::]*/: { /* n:\"MsoDrawingGroup\", */ },\n\t/*::[*/0x00ec/*::]*/: { /* n:\"MsoDrawing\", */ },\n\t/*::[*/0x00ed/*::]*/: { /* n:\"MsoDrawingSelection\", */ },\n\t/*::[*/0x00ef/*::]*/: { /* n:\"PhoneticInfo\", */ },\n\t/*::[*/0x00f0/*::]*/: { /* n:\"SxRule\", */ },\n\t/*::[*/0x00f1/*::]*/: { /* n:\"SXEx\", */ },\n\t/*::[*/0x00f2/*::]*/: { /* n:\"SxFilt\", */ },\n\t/*::[*/0x00f4/*::]*/: { /* n:\"SxDXF\", */ },\n\t/*::[*/0x00f5/*::]*/: { /* n:\"SxItm\", */ },\n\t/*::[*/0x00f6/*::]*/: { /* n:\"SxName\", */ },\n\t/*::[*/0x00f7/*::]*/: { /* n:\"SxSelect\", */ },\n\t/*::[*/0x00f8/*::]*/: { /* n:\"SXPair\", */ },\n\t/*::[*/0x00f9/*::]*/: { /* n:\"SxFmla\", */ },\n\t/*::[*/0x00fb/*::]*/: { /* n:\"SxFormat\", */ },\n\t/*::[*/0x00fc/*::]*/: { /* n:\"SST\", */ f:parse_SST },\n\t/*::[*/0x00fd/*::]*/: { /* n:\"LabelSst\", */ f:parse_LabelSst },\n\t/*::[*/0x00ff/*::]*/: { /* n:\"ExtSST\", */ f:parse_ExtSST },\n\t/*::[*/0x0100/*::]*/: { /* n:\"SXVDEx\", */ },\n\t/*::[*/0x0103/*::]*/: { /* n:\"SXFormula\", */ },\n\t/*::[*/0x0122/*::]*/: { /* n:\"SXDBEx\", */ },\n\t/*::[*/0x0137/*::]*/: { /* n:\"RRDInsDel\", */ },\n\t/*::[*/0x0138/*::]*/: { /* n:\"RRDHead\", */ },\n\t/*::[*/0x013b/*::]*/: { /* n:\"RRDChgCell\", */ },\n\t/*::[*/0x013d/*::]*/: { /* n:\"RRTabId\", */ f:parseuint16a },\n\t/*::[*/0x013e/*::]*/: { /* n:\"RRDRenSheet\", */ },\n\t/*::[*/0x013f/*::]*/: { /* n:\"RRSort\", */ },\n\t/*::[*/0x0140/*::]*/: { /* n:\"RRDMove\", */ },\n\t/*::[*/0x014a/*::]*/: { /* n:\"RRFormat\", */ },\n\t/*::[*/0x014b/*::]*/: { /* n:\"RRAutoFmt\", */ },\n\t/*::[*/0x014d/*::]*/: { /* n:\"RRInsertSh\", */ },\n\t/*::[*/0x014e/*::]*/: { /* n:\"RRDMoveBegin\", */ },\n\t/*::[*/0x014f/*::]*/: { /* n:\"RRDMoveEnd\", */ },\n\t/*::[*/0x0150/*::]*/: { /* n:\"RRDInsDelBegin\", */ },\n\t/*::[*/0x0151/*::]*/: { /* n:\"RRDInsDelEnd\", */ },\n\t/*::[*/0x0152/*::]*/: { /* n:\"RRDConflict\", */ },\n\t/*::[*/0x0153/*::]*/: { /* n:\"RRDDefName\", */ },\n\t/*::[*/0x0154/*::]*/: { /* n:\"RRDRstEtxp\", */ },\n\t/*::[*/0x015f/*::]*/: { /* n:\"LRng\", */ },\n\t/*::[*/0x0160/*::]*/: { /* n:\"UsesELFs\", */ f:parsebool },\n\t/*::[*/0x0161/*::]*/: { /* n:\"DSF\", */ f:parsenoop2 },\n\t/*::[*/0x0191/*::]*/: { /* n:\"CUsr\", */ },\n\t/*::[*/0x0192/*::]*/: { /* n:\"CbUsr\", */ },\n\t/*::[*/0x0193/*::]*/: { /* n:\"UsrInfo\", */ },\n\t/*::[*/0x0194/*::]*/: { /* n:\"UsrExcl\", */ },\n\t/*::[*/0x0195/*::]*/: { /* n:\"FileLock\", */ },\n\t/*::[*/0x0196/*::]*/: { /* n:\"RRDInfo\", */ },\n\t/*::[*/0x0197/*::]*/: { /* n:\"BCUsrs\", */ },\n\t/*::[*/0x0198/*::]*/: { /* n:\"UsrChk\", */ },\n\t/*::[*/0x01a9/*::]*/: { /* n:\"UserBView\", */ },\n\t/*::[*/0x01aa/*::]*/: { /* n:\"UserSViewBegin\", */ },\n\t/*::[*/0x01ab/*::]*/: { /* n:\"UserSViewEnd\", */ },\n\t/*::[*/0x01ac/*::]*/: { /* n:\"RRDUserView\", */ },\n\t/*::[*/0x01ad/*::]*/: { /* n:\"Qsi\", */ },\n\t/*::[*/0x01ae/*::]*/: { /* n:\"SupBook\", */ f:parse_SupBook },\n\t/*::[*/0x01af/*::]*/: { /* n:\"Prot4Rev\", */ f:parsebool },\n\t/*::[*/0x01b0/*::]*/: { /* n:\"CondFmt\", */ },\n\t/*::[*/0x01b1/*::]*/: { /* n:\"CF\", */ },\n\t/*::[*/0x01b2/*::]*/: { /* n:\"DVal\", */ },\n\t/*::[*/0x01b5/*::]*/: { /* n:\"DConBin\", */ },\n\t/*::[*/0x01b6/*::]*/: { /* n:\"TxO\", */ f:parse_TxO },\n\t/*::[*/0x01b7/*::]*/: { /* n:\"RefreshAll\", */ f:parsebool }, //\n\t/*::[*/0x01b8/*::]*/: { /* n:\"HLink\", */ f:parse_HLink },\n\t/*::[*/0x01b9/*::]*/: { /* n:\"Lel\", */ },\n\t/*::[*/0x01ba/*::]*/: { /* n:\"CodeName\", */ f:parse_XLUnicodeString },\n\t/*::[*/0x01bb/*::]*/: { /* n:\"SXFDBType\", */ },\n\t/*::[*/0x01bc/*::]*/: { /* n:\"Prot4RevPass\", */ f:parseuint16 },\n\t/*::[*/0x01bd/*::]*/: { /* n:\"ObNoMacros\", */ },\n\t/*::[*/0x01be/*::]*/: { /* n:\"Dv\", */ },\n\t/*::[*/0x01c0/*::]*/: { /* n:\"Excel9File\", */ f:parsenoop2 },\n\t/*::[*/0x01c1/*::]*/: { /* n:\"RecalcId\", */ f:parse_RecalcId, r:2},\n\t/*::[*/0x01c2/*::]*/: { /* n:\"EntExU2\", */ f:parsenoop2 },\n\t/*::[*/0x0200/*::]*/: { /* n:\"Dimensions\", */ f:parse_Dimensions },\n\t/*::[*/0x0201/*::]*/: { /* n:\"Blank\", */ f:parse_Blank },\n\t/*::[*/0x0203/*::]*/: { /* n:\"Number\", */ f:parse_Number },\n\t/*::[*/0x0204/*::]*/: { /* n:\"Label\", */ f:parse_Label },\n\t/*::[*/0x0205/*::]*/: { /* n:\"BoolErr\", */ f:parse_BoolErr },\n\t/*::[*/0x0207/*::]*/: { /* n:\"String\", */ f:parse_String },\n\t/*::[*/0x0208/*::]*/: { /* n:\"Row\", */ f:parse_Row },\n\t/*::[*/0x020b/*::]*/: { /* n:\"Index\", */ },\n\t/*::[*/0x0221/*::]*/: { /* n:\"Array\", */ f:parse_Array },\n\t/*::[*/0x0225/*::]*/: { /* n:\"DefaultRowHeight\", */ f:parse_DefaultRowHeight },\n\t/*::[*/0x0236/*::]*/: { /* n:\"Table\", */ },\n\t/*::[*/0x023e/*::]*/: { /* n:\"Window2\", */ f:parse_Window2 },\n\t/*::[*/0x027e/*::]*/: { /* n:\"RK\", */ f:parse_RK },\n\t/*::[*/0x0293/*::]*/: { /* n:\"Style\", */ },\n\t/*::[*/0x0418/*::]*/: { /* n:\"BigName\", */ },\n\t/*::[*/0x041e/*::]*/: { /* n:\"Format\", */ f:parse_Format },\n\t/*::[*/0x043c/*::]*/: { /* n:\"ContinueBigName\", */ },\n\t/*::[*/0x04bc/*::]*/: { /* n:\"ShrFmla\", */ f:parse_ShrFmla },\n\t/*::[*/0x0800/*::]*/: { /* n:\"HLinkTooltip\", */ f:parse_HLinkTooltip },\n\t/*::[*/0x0801/*::]*/: { /* n:\"WebPub\", */ },\n\t/*::[*/0x0802/*::]*/: { /* n:\"QsiSXTag\", */ },\n\t/*::[*/0x0803/*::]*/: { /* n:\"DBQueryExt\", */ },\n\t/*::[*/0x0804/*::]*/: { /* n:\"ExtString\", */ },\n\t/*::[*/0x0805/*::]*/: { /* n:\"TxtQry\", */ },\n\t/*::[*/0x0806/*::]*/: { /* n:\"Qsir\", */ },\n\t/*::[*/0x0807/*::]*/: { /* n:\"Qsif\", */ },\n\t/*::[*/0x0808/*::]*/: { /* n:\"RRDTQSIF\", */ },\n\t/*::[*/0x0809/*::]*/: { /* n:\"BOF\", */ f:parse_BOF },\n\t/*::[*/0x080a/*::]*/: { /* n:\"OleDbConn\", */ },\n\t/*::[*/0x080b/*::]*/: { /* n:\"WOpt\", */ },\n\t/*::[*/0x080c/*::]*/: { /* n:\"SXViewEx\", */ },\n\t/*::[*/0x080d/*::]*/: { /* n:\"SXTH\", */ },\n\t/*::[*/0x080e/*::]*/: { /* n:\"SXPIEx\", */ },\n\t/*::[*/0x080f/*::]*/: { /* n:\"SXVDTEx\", */ },\n\t/*::[*/0x0810/*::]*/: { /* n:\"SXViewEx9\", */ },\n\t/*::[*/0x0812/*::]*/: { /* n:\"ContinueFrt\", */ },\n\t/*::[*/0x0813/*::]*/: { /* n:\"RealTimeData\", */ },\n\t/*::[*/0x0850/*::]*/: { /* n:\"ChartFrtInfo\", */ },\n\t/*::[*/0x0851/*::]*/: { /* n:\"FrtWrapper\", */ },\n\t/*::[*/0x0852/*::]*/: { /* n:\"StartBlock\", */ },\n\t/*::[*/0x0853/*::]*/: { /* n:\"EndBlock\", */ },\n\t/*::[*/0x0854/*::]*/: { /* n:\"StartObject\", */ },\n\t/*::[*/0x0855/*::]*/: { /* n:\"EndObject\", */ },\n\t/*::[*/0x0856/*::]*/: { /* n:\"CatLab\", */ },\n\t/*::[*/0x0857/*::]*/: { /* n:\"YMult\", */ },\n\t/*::[*/0x0858/*::]*/: { /* n:\"SXViewLink\", */ },\n\t/*::[*/0x0859/*::]*/: { /* n:\"PivotChartBits\", */ },\n\t/*::[*/0x085a/*::]*/: { /* n:\"FrtFontList\", */ },\n\t/*::[*/0x0862/*::]*/: { /* n:\"SheetExt\", */ },\n\t/*::[*/0x0863/*::]*/: { /* n:\"BookExt\", */ r:12},\n\t/*::[*/0x0864/*::]*/: { /* n:\"SXAddl\", */ },\n\t/*::[*/0x0865/*::]*/: { /* n:\"CrErr\", */ },\n\t/*::[*/0x0866/*::]*/: { /* n:\"HFPicture\", */ },\n\t/*::[*/0x0867/*::]*/: { /* n:\"FeatHdr\", */ f:parsenoop2 },\n\t/*::[*/0x0868/*::]*/: { /* n:\"Feat\", */ },\n\t/*::[*/0x086a/*::]*/: { /* n:\"DataLabExt\", */ },\n\t/*::[*/0x086b/*::]*/: { /* n:\"DataLabExtContents\", */ },\n\t/*::[*/0x086c/*::]*/: { /* n:\"CellWatch\", */ },\n\t/*::[*/0x0871/*::]*/: { /* n:\"FeatHdr11\", */ },\n\t/*::[*/0x0872/*::]*/: { /* n:\"Feature11\", */ },\n\t/*::[*/0x0874/*::]*/: { /* n:\"DropDownObjIds\", */ },\n\t/*::[*/0x0875/*::]*/: { /* n:\"ContinueFrt11\", */ },\n\t/*::[*/0x0876/*::]*/: { /* n:\"DConn\", */ },\n\t/*::[*/0x0877/*::]*/: { /* n:\"List12\", */ },\n\t/*::[*/0x0878/*::]*/: { /* n:\"Feature12\", */ },\n\t/*::[*/0x0879/*::]*/: { /* n:\"CondFmt12\", */ },\n\t/*::[*/0x087a/*::]*/: { /* n:\"CF12\", */ },\n\t/*::[*/0x087b/*::]*/: { /* n:\"CFEx\", */ },\n\t/*::[*/0x087c/*::]*/: { /* n:\"XFCRC\", */ f:parse_XFCRC, r:12 },\n\t/*::[*/0x087d/*::]*/: { /* n:\"XFExt\", */ f:parse_XFExt, r:12 },\n\t/*::[*/0x087e/*::]*/: { /* n:\"AutoFilter12\", */ },\n\t/*::[*/0x087f/*::]*/: { /* n:\"ContinueFrt12\", */ },\n\t/*::[*/0x0884/*::]*/: { /* n:\"MDTInfo\", */ },\n\t/*::[*/0x0885/*::]*/: { /* n:\"MDXStr\", */ },\n\t/*::[*/0x0886/*::]*/: { /* n:\"MDXTuple\", */ },\n\t/*::[*/0x0887/*::]*/: { /* n:\"MDXSet\", */ },\n\t/*::[*/0x0888/*::]*/: { /* n:\"MDXProp\", */ },\n\t/*::[*/0x0889/*::]*/: { /* n:\"MDXKPI\", */ },\n\t/*::[*/0x088a/*::]*/: { /* n:\"MDB\", */ },\n\t/*::[*/0x088b/*::]*/: { /* n:\"PLV\", */ },\n\t/*::[*/0x088c/*::]*/: { /* n:\"Compat12\", */ f:parsebool, r:12 },\n\t/*::[*/0x088d/*::]*/: { /* n:\"DXF\", */ },\n\t/*::[*/0x088e/*::]*/: { /* n:\"TableStyles\", */ r:12 },\n\t/*::[*/0x088f/*::]*/: { /* n:\"TableStyle\", */ },\n\t/*::[*/0x0890/*::]*/: { /* n:\"TableStyleElement\", */ },\n\t/*::[*/0x0892/*::]*/: { /* n:\"StyleExt\", */ },\n\t/*::[*/0x0893/*::]*/: { /* n:\"NamePublish\", */ },\n\t/*::[*/0x0894/*::]*/: { /* n:\"NameCmt\", */ f:parse_NameCmt, r:12 },\n\t/*::[*/0x0895/*::]*/: { /* n:\"SortData\", */ },\n\t/*::[*/0x0896/*::]*/: { /* n:\"Theme\", */ f:parse_Theme, r:12 },\n\t/*::[*/0x0897/*::]*/: { /* n:\"GUIDTypeLib\", */ },\n\t/*::[*/0x0898/*::]*/: { /* n:\"FnGrp12\", */ },\n\t/*::[*/0x0899/*::]*/: { /* n:\"NameFnGrp12\", */ },\n\t/*::[*/0x089a/*::]*/: { /* n:\"MTRSettings\", */ f:parse_MTRSettings, r:12 },\n\t/*::[*/0x089b/*::]*/: { /* n:\"CompressPictures\", */ f:parsenoop2 },\n\t/*::[*/0x089c/*::]*/: { /* n:\"HeaderFooter\", */ },\n\t/*::[*/0x089d/*::]*/: { /* n:\"CrtLayout12\", */ },\n\t/*::[*/0x089e/*::]*/: { /* n:\"CrtMlFrt\", */ },\n\t/*::[*/0x089f/*::]*/: { /* n:\"CrtMlFrtContinue\", */ },\n\t/*::[*/0x08a3/*::]*/: { /* n:\"ForceFullCalculation\", */ f:parse_ForceFullCalculation },\n\t/*::[*/0x08a4/*::]*/: { /* n:\"ShapePropsStream\", */ },\n\t/*::[*/0x08a5/*::]*/: { /* n:\"TextPropsStream\", */ },\n\t/*::[*/0x08a6/*::]*/: { /* n:\"RichTextStream\", */ },\n\t/*::[*/0x08a7/*::]*/: { /* n:\"CrtLayout12A\", */ },\n\t/*::[*/0x1001/*::]*/: { /* n:\"Units\", */ },\n\t/*::[*/0x1002/*::]*/: { /* n:\"Chart\", */ },\n\t/*::[*/0x1003/*::]*/: { /* n:\"Series\", */ },\n\t/*::[*/0x1006/*::]*/: { /* n:\"DataFormat\", */ },\n\t/*::[*/0x1007/*::]*/: { /* n:\"LineFormat\", */ },\n\t/*::[*/0x1009/*::]*/: { /* n:\"MarkerFormat\", */ },\n\t/*::[*/0x100a/*::]*/: { /* n:\"AreaFormat\", */ },\n\t/*::[*/0x100b/*::]*/: { /* n:\"PieFormat\", */ },\n\t/*::[*/0x100c/*::]*/: { /* n:\"AttachedLabel\", */ },\n\t/*::[*/0x100d/*::]*/: { /* n:\"SeriesText\", */ },\n\t/*::[*/0x1014/*::]*/: { /* n:\"ChartFormat\", */ },\n\t/*::[*/0x1015/*::]*/: { /* n:\"Legend\", */ },\n\t/*::[*/0x1016/*::]*/: { /* n:\"SeriesList\", */ },\n\t/*::[*/0x1017/*::]*/: { /* n:\"Bar\", */ },\n\t/*::[*/0x1018/*::]*/: { /* n:\"Line\", */ },\n\t/*::[*/0x1019/*::]*/: { /* n:\"Pie\", */ },\n\t/*::[*/0x101a/*::]*/: { /* n:\"Area\", */ },\n\t/*::[*/0x101b/*::]*/: { /* n:\"Scatter\", */ },\n\t/*::[*/0x101c/*::]*/: { /* n:\"CrtLine\", */ },\n\t/*::[*/0x101d/*::]*/: { /* n:\"Axis\", */ },\n\t/*::[*/0x101e/*::]*/: { /* n:\"Tick\", */ },\n\t/*::[*/0x101f/*::]*/: { /* n:\"ValueRange\", */ },\n\t/*::[*/0x1020/*::]*/: { /* n:\"CatSerRange\", */ },\n\t/*::[*/0x1021/*::]*/: { /* n:\"AxisLine\", */ },\n\t/*::[*/0x1022/*::]*/: { /* n:\"CrtLink\", */ },\n\t/*::[*/0x1024/*::]*/: { /* n:\"DefaultText\", */ },\n\t/*::[*/0x1025/*::]*/: { /* n:\"Text\", */ },\n\t/*::[*/0x1026/*::]*/: { /* n:\"FontX\", */ f:parseuint16 },\n\t/*::[*/0x1027/*::]*/: { /* n:\"ObjectLink\", */ },\n\t/*::[*/0x1032/*::]*/: { /* n:\"Frame\", */ },\n\t/*::[*/0x1033/*::]*/: { /* n:\"Begin\", */ },\n\t/*::[*/0x1034/*::]*/: { /* n:\"End\", */ },\n\t/*::[*/0x1035/*::]*/: { /* n:\"PlotArea\", */ },\n\t/*::[*/0x103a/*::]*/: { /* n:\"Chart3d\", */ },\n\t/*::[*/0x103c/*::]*/: { /* n:\"PicF\", */ },\n\t/*::[*/0x103d/*::]*/: { /* n:\"DropBar\", */ },\n\t/*::[*/0x103e/*::]*/: { /* n:\"Radar\", */ },\n\t/*::[*/0x103f/*::]*/: { /* n:\"Surf\", */ },\n\t/*::[*/0x1040/*::]*/: { /* n:\"RadarArea\", */ },\n\t/*::[*/0x1041/*::]*/: { /* n:\"AxisParent\", */ },\n\t/*::[*/0x1043/*::]*/: { /* n:\"LegendException\", */ },\n\t/*::[*/0x1044/*::]*/: { /* n:\"ShtProps\", */ f:parse_ShtProps },\n\t/*::[*/0x1045/*::]*/: { /* n:\"SerToCrt\", */ },\n\t/*::[*/0x1046/*::]*/: { /* n:\"AxesUsed\", */ },\n\t/*::[*/0x1048/*::]*/: { /* n:\"SBaseRef\", */ },\n\t/*::[*/0x104a/*::]*/: { /* n:\"SerParent\", */ },\n\t/*::[*/0x104b/*::]*/: { /* n:\"SerAuxTrend\", */ },\n\t/*::[*/0x104e/*::]*/: { /* n:\"IFmtRecord\", */ },\n\t/*::[*/0x104f/*::]*/: { /* n:\"Pos\", */ },\n\t/*::[*/0x1050/*::]*/: { /* n:\"AlRuns\", */ },\n\t/*::[*/0x1051/*::]*/: { /* n:\"BRAI\", */ },\n\t/*::[*/0x105b/*::]*/: { /* n:\"SerAuxErrBar\", */ },\n\t/*::[*/0x105c/*::]*/: { /* n:\"ClrtClient\", */ f:parse_ClrtClient },\n\t/*::[*/0x105d/*::]*/: { /* n:\"SerFmt\", */ },\n\t/*::[*/0x105f/*::]*/: { /* n:\"Chart3DBarShape\", */ },\n\t/*::[*/0x1060/*::]*/: { /* n:\"Fbi\", */ },\n\t/*::[*/0x1061/*::]*/: { /* n:\"BopPop\", */ },\n\t/*::[*/0x1062/*::]*/: { /* n:\"AxcExt\", */ },\n\t/*::[*/0x1063/*::]*/: { /* n:\"Dat\", */ },\n\t/*::[*/0x1064/*::]*/: { /* n:\"PlotGrowth\", */ },\n\t/*::[*/0x1065/*::]*/: { /* n:\"SIIndex\", */ },\n\t/*::[*/0x1066/*::]*/: { /* n:\"GelFrame\", */ },\n\t/*::[*/0x1067/*::]*/: { /* n:\"BopPopCustom\", */ },\n\t/*::[*/0x1068/*::]*/: { /* n:\"Fbi2\", */ },\n\n\t/*::[*/0x0000/*::]*/: { /* n:\"Dimensions\", */ f:parse_Dimensions },\n\t/*::[*/0x0001/*::]*/: { /* n:\"BIFF2BLANK\", */ },\n\t/*::[*/0x0002/*::]*/: { /* n:\"BIFF2INT\", */ f:parse_BIFF2INT },\n\t/*::[*/0x0003/*::]*/: { /* n:\"BIFF2NUM\", */ f:parse_BIFF2NUM },\n\t/*::[*/0x0004/*::]*/: { /* n:\"BIFF2STR\", */ f:parse_BIFF2STR },\n\t/*::[*/0x0005/*::]*/: { /* n:\"BoolErr\", */ f:parse_BoolErr },\n\t/*::[*/0x0007/*::]*/: { /* n:\"String\", */ f:parse_BIFF2STRING },\n\t/*::[*/0x0008/*::]*/: { /* n:\"BIFF2ROW\", */ },\n\t/*::[*/0x0009/*::]*/: { /* n:\"BOF\", */ f:parse_BOF },\n\t/*::[*/0x000b/*::]*/: { /* n:\"Index\", */ },\n\t/*::[*/0x0016/*::]*/: { /* n:\"ExternCount\", */ f:parseuint16 },\n\t/*::[*/0x001e/*::]*/: { /* n:\"BIFF2FORMAT\", */ f:parse_BIFF2Format },\n\t/*::[*/0x001f/*::]*/: { /* n:\"BIFF2FMTCNT\", */ }, /* 16-bit cnt of BIFF2FORMAT records */\n\t/*::[*/0x0020/*::]*/: { /* n:\"BIFF2COLINFO\", */ },\n\t/*::[*/0x0021/*::]*/: { /* n:\"Array\", */ f:parse_Array },\n\t/*::[*/0x0024/*::]*/: { /* n:\"COLWIDTH\", */ },\n\t/*::[*/0x0025/*::]*/: { /* n:\"DefaultRowHeight\", */ f:parse_DefaultRowHeight },\n\t// 0x2c ??\n\t// 0x2d ??\n\t// 0x2e ??\n\t// 0x30 FONTCOUNT: number of fonts\n\t/*::[*/0x0032/*::]*/: { /* n:\"BIFF2FONTXTRA\", */ f:parse_BIFF2FONTXTRA },\n\t// 0x35: INFOOPTS\n\t// 0x36: TABLE (BIFF2 only)\n\t// 0x37: TABLE2 (BIFF2 only)\n\t// 0x38: WNDESK\n\t// 0x39 ??\n\t// 0x3a: BEGINPREF\n\t// 0x3b: ENDPREF\n\t/*::[*/0x003e/*::]*/: { /* n:\"BIFF2WINDOW2\", */ },\n\t// 0x3f ??\n\t// 0x46: SHOWSCROLL\n\t// 0x47: SHOWFORMULA\n\t// 0x48: STATUSBAR\n\t// 0x49: SHORTMENUS\n\t// 0x4A:\n\t// 0x4B:\n\t// 0x4C:\n\t// 0x4E:\n\t// 0x4F:\n\t// 0x58: TOOLBAR (BIFF3)\n\n\t/* - - - */\n\t/*::[*/0x0034/*::]*/: { /* n:\"DDEObjName\", */ },\n\t/*::[*/0x0043/*::]*/: { /* n:\"BIFF2XF\", */ },\n\t/*::[*/0x0044/*::]*/: { /* n:\"BIFF2XFINDEX\", */ f:parseuint16 },\n\t/*::[*/0x0045/*::]*/: { /* n:\"BIFF2FONTCLR\", */ },\n\t/*::[*/0x0056/*::]*/: { /* n:\"BIFF4FMTCNT\", */ }, /* 16-bit cnt, similar to BIFF2 */\n\t/*::[*/0x007e/*::]*/: { /* n:\"RK\", */ }, /* Not necessarily same as 0x027e */\n\t/*::[*/0x007f/*::]*/: { /* n:\"ImData\", */ f:parse_ImData },\n\t/*::[*/0x0087/*::]*/: { /* n:\"Addin\", */ },\n\t/*::[*/0x0088/*::]*/: { /* n:\"Edg\", */ },\n\t/*::[*/0x0089/*::]*/: { /* n:\"Pub\", */ },\n\t// 0x8A\n\t// 0x8B LH: alternate menu key flag (BIFF3/4)\n\t// 0x8E\n\t// 0x8F\n\t/*::[*/0x0091/*::]*/: { /* n:\"Sub\", */ },\n\t// 0x93 STYLE\n\t/*::[*/0x0094/*::]*/: { /* n:\"LHRecord\", */ },\n\t/*::[*/0x0095/*::]*/: { /* n:\"LHNGraph\", */ },\n\t/*::[*/0x0096/*::]*/: { /* n:\"Sound\", */ },\n\t// 0xA2 FNPROTO: function prototypes (BIFF4)\n\t// 0xA3\n\t// 0xA8\n\t/*::[*/0x00a9/*::]*/: { /* n:\"CoordList\", */ },\n\t/*::[*/0x00ab/*::]*/: { /* n:\"GCW\", */ },\n\t/*::[*/0x00bc/*::]*/: { /* n:\"ShrFmla\", */ }, /* Not necessarily same as 0x04bc */\n\t/*::[*/0x00bf/*::]*/: { /* n:\"ToolbarHdr\", */ },\n\t/*::[*/0x00c0/*::]*/: { /* n:\"ToolbarEnd\", */ },\n\t/*::[*/0x00c2/*::]*/: { /* n:\"AddMenu\", */ },\n\t/*::[*/0x00c3/*::]*/: { /* n:\"DelMenu\", */ },\n\t/*::[*/0x00d6/*::]*/: { /* n:\"RString\", */ f:parse_RString },\n\t/*::[*/0x00df/*::]*/: { /* n:\"UDDesc\", */ },\n\t/*::[*/0x00ea/*::]*/: { /* n:\"TabIdConf\", */ },\n\t/*::[*/0x0162/*::]*/: { /* n:\"XL5Modify\", */ },\n\t/*::[*/0x01a5/*::]*/: { /* n:\"FileSharing2\", */ },\n\t/*::[*/0x0206/*::]*/: { /* n:\"Formula\", */ f:parse_Formula },\n\t/*::[*/0x0209/*::]*/: { /* n:\"BOF\", */ f:parse_BOF },\n\t/*::[*/0x0218/*::]*/: { /* n:\"Lbl\", */ f:parse_Lbl },\n\t/*::[*/0x0223/*::]*/: { /* n:\"ExternName\", */ f:parse_ExternName },\n\t/*::[*/0x0231/*::]*/: { /* n:\"Font\", */ },\n\t/*::[*/0x0243/*::]*/: { /* n:\"BIFF3XF\", */ },\n\t/*::[*/0x0406/*::]*/: { /* n:\"Formula\", */ f:parse_Formula },\n\t/*::[*/0x0409/*::]*/: { /* n:\"BOF\", */ f:parse_BOF },\n\t/*::[*/0x0443/*::]*/: { /* n:\"BIFF4XF\", */ },\n\t/*::[*/0x086d/*::]*/: { /* n:\"FeatInfo\", */ },\n\t/*::[*/0x0873/*::]*/: { /* n:\"FeatInfo11\", */ },\n\t/*::[*/0x0881/*::]*/: { /* n:\"SXAddl12\", */ },\n\t/*::[*/0x08c0/*::]*/: { /* n:\"AutoWebPub\", */ },\n\t/*::[*/0x08c1/*::]*/: { /* n:\"ListObj\", */ },\n\t/*::[*/0x08c2/*::]*/: { /* n:\"ListField\", */ },\n\t/*::[*/0x08c3/*::]*/: { /* n:\"ListDV\", */ },\n\t/*::[*/0x08c4/*::]*/: { /* n:\"ListCondFmt\", */ },\n\t/*::[*/0x08c5/*::]*/: { /* n:\"ListCF\", */ },\n\t/*::[*/0x08c6/*::]*/: { /* n:\"FMQry\", */ },\n\t/*::[*/0x08c7/*::]*/: { /* n:\"FMSQry\", */ },\n\t/*::[*/0x08c8/*::]*/: { /* n:\"PLV\", */ },\n\t/*::[*/0x08c9/*::]*/: { /* n:\"LnExt\", */ },\n\t/*::[*/0x08ca/*::]*/: { /* n:\"MkrExt\", */ },\n\t/*::[*/0x08cb/*::]*/: { /* n:\"CrtCoopt\", */ },\n\t/*::[*/0x08d6/*::]*/: { /* n:\"FRTArchId$\", */ r:12 },\n\n\t/*::[*/0x7262/*::]*/: {}\n};\n\nfunction write_biff_rec(ba/*:BufArray*/, type/*:number*/, payload, length/*:?number*/)/*:void*/ {\n\tvar t/*:number*/ = type;\n\tif(isNaN(t)) return;\n\tvar len = length || (payload||[]).length || 0;\n\tvar o = ba.next(4);\n\to.write_shift(2, t);\n\to.write_shift(2, len);\n\tif(/*:: len != null &&*/len > 0 && is_buf(payload)) ba.push(payload);\n}\n\nfunction write_biff_continue(ba/*:BufArray*/, type/*:number*/, payload, length/*:?number*/)/*:void*/ {\n\tvar len = length || (payload||[]).length || 0;\n\tif(len <= 8224) return write_biff_rec(ba, type, payload, len);\n\tvar t = type;\n\tif(isNaN(t)) return;\n\tvar parts = payload.parts || [], sidx = 0;\n\tvar i = 0, w = 0;\n\twhile(w + (parts[sidx] || 8224) <= 8224) { w+= (parts[sidx] || 8224); sidx++; }\n\tvar o = ba.next(4);\n\to.write_shift(2, t);\n\to.write_shift(2, w);\n\tba.push(payload.slice(i, i + w));\n\ti += w;\n\twhile(i < len) {\n\t\to = ba.next(4);\n\t\to.write_shift(2, 0x3c); // TODO: figure out correct continue type\n\t\tw = 0;\n\t\twhile(w + (parts[sidx] || 8224) <= 8224) { w+= (parts[sidx] || 8224); sidx++; }\n\t\to.write_shift(2, w);\n\t\tba.push(payload.slice(i, i+w)); i+= w;\n\t}\n}\n\nfunction write_BIFF2Cell(out, r/*:number*/, c/*:number*/) {\n\tif(!out) out = new_buf(7);\n\tout.write_shift(2, r);\n\tout.write_shift(2, c);\n\tout.write_shift(2, 0);\n\tout.write_shift(1, 0);\n\treturn out;\n}\n\nfunction write_BIFF2BERR(r/*:number*/, c/*:number*/, val, t/*:?string*/) {\n\tvar out = new_buf(9);\n\twrite_BIFF2Cell(out, r, c);\n\twrite_Bes(val, t || 'b', out);\n\treturn out;\n}\n\n/* TODO: codepage, large strings */\nfunction write_BIFF2LABEL(r/*:number*/, c/*:number*/, val) {\n\tvar out = new_buf(8 + 2*val.length);\n\twrite_BIFF2Cell(out, r, c);\n\tout.write_shift(1, val.length);\n\tout.write_shift(val.length, val, 'sbcs');\n\treturn out.l < out.length ? out.slice(0, out.l) : out;\n}\n\nfunction write_ws_biff2_cell(ba/*:BufArray*/, cell/*:Cell*/, R/*:number*/, C/*:number*//*::, opts*/) {\n\tif(cell.v != null) switch(cell.t) {\n\t\tcase 'd': case 'n':\n\t\t\tvar v = cell.t == 'd' ? datenum(parseDate(cell.v)) : cell.v;\n\t\t\tif((v == (v|0)) && (v >= 0) && (v < 65536))\n\t\t\t\twrite_biff_rec(ba, 0x0002, write_BIFF2INT(R, C, v));\n\t\t\telse\n\t\t\t\twrite_biff_rec(ba, 0x0003, write_BIFF2NUM(R,C, v));\n\t\t\treturn;\n\t\tcase 'b': case 'e': write_biff_rec(ba, 0x0005, write_BIFF2BERR(R, C, cell.v, cell.t)); return;\n\t\t/* TODO: codepage, sst */\n\t\tcase 's': case 'str':\n\t\t\twrite_biff_rec(ba, 0x0004, write_BIFF2LABEL(R, C, (cell.v||\"\").slice(0,255)));\n\t\t\treturn;\n\t}\n\twrite_biff_rec(ba, 0x0001, write_BIFF2Cell(null, R, C));\n}\n\nfunction write_ws_biff2(ba/*:BufArray*/, ws/*:Worksheet*/, idx/*:number*/, opts/*::, wb:Workbook*/) {\n\tvar dense = Array.isArray(ws);\n\tvar range = safe_decode_range(ws['!ref'] || \"A1\"), ref/*:string*/, rr = \"\", cols/*:Array<string>*/ = [];\n\tif(range.e.c > 0xFF || range.e.r > 0x3FFF) {\n\t\tif(opts.WTF) throw new Error(\"Range \" + (ws['!ref'] || \"A1\") + \" exceeds format limit A1:IV16384\");\n\t\trange.e.c = Math.min(range.e.c, 0xFF);\n\t\trange.e.r = Math.min(range.e.c, 0x3FFF);\n\t\tref = encode_range(range);\n\t}\n\tfor(var R = range.s.r; R <= range.e.r; ++R) {\n\t\trr = encode_row(R);\n\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\tref = cols[C] + rr;\n\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\tif(!cell) continue;\n\t\t\t/* write cell */\n\t\t\twrite_ws_biff2_cell(ba, cell, R, C, opts);\n\t\t}\n\t}\n}\n\n/* Based on test files */\nfunction write_biff2_buf(wb/*:Workbook*/, opts/*:WriteOpts*/) {\n\tvar o = opts || {};\n\tif(DENSE != null && o.dense == null) o.dense = DENSE;\n\tvar ba = buf_array();\n\tvar idx = 0;\n\tfor(var i=0;i<wb.SheetNames.length;++i) if(wb.SheetNames[i] == o.sheet) idx=i;\n\tif(idx == 0 && !!o.sheet && wb.SheetNames[0] != o.sheet) throw new Error(\"Sheet not found: \" + o.sheet);\n\twrite_biff_rec(ba, (o.biff == 4 ? 0x0409 : (o.biff == 3 ? 0x0209 : 0x0009)), write_BOF(wb, 0x10, o));\n\t/* ... */\n\twrite_ws_biff2(ba, wb.Sheets[wb.SheetNames[idx]], idx, o, wb);\n\t/* ... */\n\twrite_biff_rec(ba, 0x000A);\n\treturn ba.end();\n}\n\nfunction write_FONTS_biff8(ba, data, opts) {\n\twrite_biff_rec(ba, 0x0031 /* Font */, write_Font({\n\t\tsz:12,\n\t\tcolor: {theme:1},\n\t\tname: \"Arial\",\n\t\tfamily: 2,\n\t\tscheme: \"minor\"\n\t}, opts));\n}\n\n\nfunction write_FMTS_biff8(ba, NF/*:?SSFTable*/, opts) {\n\tif(!NF) return;\n\t[[5,8],[23,26],[41,44],[/*63*/50,/*66],[164,*/392]].forEach(function(r) {\n\t\t/*:: if(!NF) return; */\n\t\tfor(var i = r[0]; i <= r[1]; ++i) if(NF[i] != null) write_biff_rec(ba, 0x041E /* Format */, write_Format(i, NF[i], opts));\n\t});\n}\n\nfunction write_FEAT(ba, ws) {\n\t/* [MS-XLS] 2.4.112 */\n\tvar o = new_buf(19);\n\to.write_shift(4, 0x867); o.write_shift(4, 0); o.write_shift(4, 0);\n\to.write_shift(2, 3); o.write_shift(1, 1); o.write_shift(4, 0);\n\twrite_biff_rec(ba, 0x0867 /* FeatHdr */, o);\n\t/* [MS-XLS] 2.4.111 */\n\to = new_buf(39);\n\to.write_shift(4, 0x868); o.write_shift(4, 0); o.write_shift(4, 0);\n\to.write_shift(2, 3); o.write_shift(1, 0); o.write_shift(4, 0);\n\to.write_shift(2, 1); o.write_shift(4, 4); o.write_shift(2, 0);\n\twrite_Ref8U(safe_decode_range(ws['!ref']||\"A1\"), o);\n\to.write_shift(4, 4);\n\twrite_biff_rec(ba, 0x0868 /* Feat */, o);\n}\n\nfunction write_CELLXFS_biff8(ba, opts) {\n\tfor(var i = 0; i < 16; ++i) write_biff_rec(ba, 0x00e0 /* XF */, write_XF({numFmtId:0, style:true}, 0, opts));\n\topts.cellXfs.forEach(function(c) {\n\t\twrite_biff_rec(ba, 0x00e0 /* XF */, write_XF(c, 0, opts));\n\t});\n}\n\nfunction write_ws_biff8_hlinks(ba/*:BufArray*/, ws) {\n\tfor(var R=0; R<ws['!links'].length; ++R) {\n\t\tvar HL = ws['!links'][R];\n\t\twrite_biff_rec(ba, 0x01b8 /* HLink */, write_HLink(HL));\n\t\tif(HL[1].Tooltip) write_biff_rec(ba, 0x0800 /* HLinkTooltip */, write_HLinkTooltip(HL));\n\t}\n\tdelete ws['!links'];\n}\n\nfunction write_ws_cols_biff8(ba, cols) {\n\tif(!cols) return;\n\tvar cnt = 0;\n\tcols.forEach(function(col, idx) {\n\t\tif(++cnt <= 256 && col) {\n\t\t\twrite_biff_rec(ba, 0x007d /* ColInfo */, write_ColInfo(col_obj_w(idx, col), idx));\n\t\t}\n\t});\n}\n\nfunction write_ws_biff8_cell(ba/*:BufArray*/, cell/*:Cell*/, R/*:number*/, C/*:number*/, opts) {\n\tvar os = 16 + get_cell_style(opts.cellXfs, cell, opts);\n\tif(cell.v == null && !cell.bf) {\n\t\twrite_biff_rec(ba, 0x0201 /* Blank */, write_XLSCell(R, C, os));\n\t\treturn;\n\t}\n\tif(cell.bf) write_biff_rec(ba, 0x0006 /* Formula */, write_Formula(cell, R, C, opts, os));\n\telse switch(cell.t) {\n\t\tcase 'd': case 'n':\n\t\t\tvar v = cell.t == 'd' ? datenum(parseDate(cell.v)) : cell.v;\n\t\t\t/* TODO: emit RK as appropriate */\n\t\t\twrite_biff_rec(ba, 0x0203 /* Number */, write_Number(R, C, v, os, opts));\n\t\t\tbreak;\n\t\tcase 'b': case 'e':\n\t\t\twrite_biff_rec(ba, 0x0205 /* BoolErr */, write_BoolErr(R, C, cell.v, os, opts, cell.t));\n\t\t\tbreak;\n\t\t/* TODO: codepage, sst */\n\t\tcase 's': case 'str':\n\t\t\tif(opts.bookSST) {\n\t\t\t\tvar isst = get_sst_id(opts.Strings, cell.v, opts.revStrings);\n\t\t\t\twrite_biff_rec(ba, 0x00fd /* LabelSst */, write_LabelSst(R, C, isst, os, opts));\n\t\t\t} else write_biff_rec(ba, 0x0204 /* Label */, write_Label(R, C, (cell.v||\"\").slice(0,255), os, opts));\n\t\t\tbreak;\n\t\tdefault:\n\t\t\twrite_biff_rec(ba, 0x0201 /* Blank */, write_XLSCell(R, C, os));\n\t}\n}\n\n/* [MS-XLS] 2.1.7.20.5 */\nfunction write_ws_biff8(idx/*:number*/, opts, wb/*:Workbook*/) {\n\tvar ba = buf_array();\n\tvar s = wb.SheetNames[idx], ws = wb.Sheets[s] || {};\n\tvar _WB/*:WBWBProps*/ = ((wb||{}).Workbook||{}/*:any*/);\n\tvar _sheet/*:WBWSProp*/ = ((_WB.Sheets||[])[idx]||{}/*:any*/);\n\tvar dense = Array.isArray(ws);\n\tvar b8 = opts.biff == 8;\n\tvar ref/*:string*/, rr = \"\", cols/*:Array<string>*/ = [];\n\tvar range = safe_decode_range(ws['!ref'] || \"A1\");\n\tvar MAX_ROWS = b8 ? 65536 : 16384;\n\tif(range.e.c > 0xFF || range.e.r >= MAX_ROWS) {\n\t\tif(opts.WTF) throw new Error(\"Range \" + (ws['!ref'] || \"A1\") + \" exceeds format limit A1:IV16384\");\n\t\trange.e.c = Math.min(range.e.c, 0xFF);\n\t\trange.e.r = Math.min(range.e.c, MAX_ROWS-1);\n\t}\n\n\twrite_biff_rec(ba, 0x0809, write_BOF(wb, 0x10, opts));\n\t/* [Uncalced] Index */\n\twrite_biff_rec(ba, 0x000d /* CalcMode */, writeuint16(1));\n\twrite_biff_rec(ba, 0x000c /* CalcCount */, writeuint16(100));\n\twrite_biff_rec(ba, 0x000f /* CalcRefMode */, writebool(true));\n\twrite_biff_rec(ba, 0x0011 /* CalcIter */, writebool(false));\n\twrite_biff_rec(ba, 0x0010 /* CalcDelta */, write_Xnum(0.001));\n\twrite_biff_rec(ba, 0x005f /* CalcSaveRecalc */, writebool(true));\n\twrite_biff_rec(ba, 0x002a /* PrintRowCol */, writebool(false));\n\twrite_biff_rec(ba, 0x002b /* PrintGrid */, writebool(false));\n\twrite_biff_rec(ba, 0x0082 /* GridSet */, writeuint16(1));\n\twrite_biff_rec(ba, 0x0080 /* Guts */, write_Guts([0,0]));\n\t/* DefaultRowHeight WsBool [Sync] [LPr] [HorizontalPageBreaks] [VerticalPageBreaks] */\n\t/* Header (string) */\n\t/* Footer (string) */\n\twrite_biff_rec(ba, 0x0083 /* HCenter */, writebool(false));\n\twrite_biff_rec(ba, 0x0084 /* VCenter */, writebool(false));\n\t/* ... */\n\tif(b8) write_ws_cols_biff8(ba, ws[\"!cols\"]);\n\t/* ... */\n\twrite_biff_rec(ba, 0x200, write_Dimensions(range, opts));\n\t/* ... */\n\n\tif(b8) ws['!links'] = [];\n\tfor(var R = range.s.r; R <= range.e.r; ++R) {\n\t\trr = encode_row(R);\n\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\tref = cols[C] + rr;\n\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\tif(!cell) continue;\n\t\t\t/* write cell */\n\t\t\twrite_ws_biff8_cell(ba, cell, R, C, opts);\n\t\t\tif(b8 && cell.l) ws['!links'].push([ref, cell.l]);\n\t\t}\n\t}\n\tvar cname/*:string*/ = _sheet.CodeName || _sheet.name || s;\n\t/* ... */\n\tif(b8) write_biff_rec(ba, 0x023e /* Window2 */, write_Window2((_WB.Views||[])[0]));\n\t/* ... */\n\tif(b8 && (ws['!merges']||[]).length) write_biff_rec(ba, 0x00e5 /* MergeCells */, write_MergeCells(ws['!merges']));\n\t/* [LRng] *QUERYTABLE [PHONETICINFO] CONDFMTS */\n\tif(b8) write_ws_biff8_hlinks(ba, ws);\n\t/* [DVAL] */\n\twrite_biff_rec(ba, 0x01ba /* CodeName */, write_XLUnicodeString(cname, opts));\n\t/* *WebPub *CellWatch [SheetExt] */\n\tif(b8) write_FEAT(ba, ws);\n\t/* *FEAT11 *RECORD12 */\n\twrite_biff_rec(ba, 0x000a /* EOF */);\n\treturn ba.end();\n}\n\n/* [MS-XLS] 2.1.7.20.3 */\nfunction write_biff8_global(wb/*:Workbook*/, bufs, opts/*:WriteOpts*/) {\n\tvar A = buf_array();\n\tvar _WB/*:WBWBProps*/ = ((wb||{}).Workbook||{}/*:any*/);\n\tvar _sheets/*:Array<WBWSProp>*/ = (_WB.Sheets||[]);\n\tvar _wb/*:WBProps*/ = /*::((*/_WB.WBProps||{/*::CodeName:\"ThisWorkbook\"*/}/*:: ):any)*/;\n\tvar b8 = opts.biff == 8, b5 = opts.biff == 5;\n\twrite_biff_rec(A, 0x0809, write_BOF(wb, 0x05, opts));\n\tif(opts.bookType == \"xla\") write_biff_rec(A, 0x0087 /* Addin */);\n\twrite_biff_rec(A, 0x00e1 /* InterfaceHdr */, b8 ? writeuint16(0x04b0) : null);\n\twrite_biff_rec(A, 0x00c1 /* Mms */, writezeroes(2));\n\tif(b5) write_biff_rec(A, 0x00bf /* ToolbarHdr */);\n\tif(b5) write_biff_rec(A, 0x00c0 /* ToolbarEnd */);\n\twrite_biff_rec(A, 0x00e2 /* InterfaceEnd */);\n\twrite_biff_rec(A, 0x005c /* WriteAccess */, write_WriteAccess(\"SheetJS\", opts));\n\t/* [FileSharing] */\n\twrite_biff_rec(A, 0x0042 /* CodePage */, writeuint16(b8 ? 0x04b0 : 0x04E4));\n\t/* *2047 Lel */\n\tif(b8) write_biff_rec(A, 0x0161 /* DSF */, writeuint16(0));\n\tif(b8) write_biff_rec(A, 0x01c0 /* Excel9File */);\n\twrite_biff_rec(A, 0x013d /* RRTabId */, write_RRTabId(wb.SheetNames.length));\n\tif(b8 && wb.vbaraw) write_biff_rec(A, 0x00d3 /* ObProj */);\n\t/* [ObNoMacros] */\n\tif(b8 && wb.vbaraw) {\n\t\tvar cname/*:string*/ = _wb.CodeName || \"ThisWorkbook\";\n\t\twrite_biff_rec(A, 0x01ba /* CodeName */, write_XLUnicodeString(cname, opts));\n\t}\n\twrite_biff_rec(A, 0x009c /* BuiltInFnGroupCount */, writeuint16(0x11));\n\t/* *FnGroupName *FnGrp12 */\n\t/* *Lbl */\n\t/* [OleObjectSize] */\n\twrite_biff_rec(A, 0x0019 /* WinProtect */, writebool(false));\n\twrite_biff_rec(A, 0x0012 /* Protect */, writebool(false));\n\twrite_biff_rec(A, 0x0013 /* Password */, writeuint16(0));\n\tif(b8) write_biff_rec(A, 0x01af /* Prot4Rev */, writebool(false));\n\tif(b8) write_biff_rec(A, 0x01bc /* Prot4RevPass */, writeuint16(0));\n\twrite_biff_rec(A, 0x003d /* Window1 */, write_Window1(opts));\n\twrite_biff_rec(A, 0x0040 /* Backup */, writebool(false));\n\twrite_biff_rec(A, 0x008d /* HideObj */, writeuint16(0));\n\twrite_biff_rec(A, 0x0022 /* Date1904 */, writebool(safe1904(wb)==\"true\"));\n\twrite_biff_rec(A, 0x000e /* CalcPrecision */, writebool(true));\n\tif(b8) write_biff_rec(A, 0x01b7 /* RefreshAll */, writebool(false));\n\twrite_biff_rec(A, 0x00DA /* BookBool */, writeuint16(0));\n\t/* ... */\n\twrite_FONTS_biff8(A, wb, opts);\n\twrite_FMTS_biff8(A, wb.SSF, opts);\n\twrite_CELLXFS_biff8(A, opts);\n\t/* ... */\n\tif(b8) write_biff_rec(A, 0x0160 /* UsesELFs */, writebool(false));\n\tvar a = A.end();\n\n\tvar C = buf_array();\n\t/* METADATA [MTRSettings] [ForceFullCalculation] */\n\tif(b8) write_biff_rec(C, 0x008C, write_Country());\n\t/* *SUPBOOK *LBL *RTD [RecalcId] *HFPicture *MSODRAWINGGROUP */\n\n\t/* BIFF8: [SST *Continue] ExtSST */\n\tif(b8 && opts.Strings) write_biff_continue(C, 0x00FC, write_SST(opts.Strings, opts));\n\n\t/* *WebPub [WOpt] [CrErr] [BookExt] *FeatHdr *DConn [THEME] [CompressPictures] [Compat12] [GUIDTypeLib] */\n\twrite_biff_rec(C, 0x000A /* EOF */);\n\tvar c = C.end();\n\n\tvar B = buf_array();\n\tvar blen = 0, j = 0;\n\tfor(j = 0; j < wb.SheetNames.length; ++j) blen += (b8 ? 12 : 11) + (b8 ? 2 : 1) * wb.SheetNames[j].length;\n\tvar start = a.length + blen + c.length;\n\tfor(j = 0; j < wb.SheetNames.length; ++j) {\n\t\tvar _sheet/*:WBWSProp*/ = _sheets[j] || ({}/*:any*/);\n\t\twrite_biff_rec(B, 0x0085 /* BoundSheet8 */, write_BoundSheet8({pos:start, hs:_sheet.Hidden||0, dt:0, name:wb.SheetNames[j]}, opts));\n\t\tstart += bufs[j].length;\n\t}\n\t/* 1*BoundSheet8 */\n\tvar b = B.end();\n\tif(blen != b.length) throw new Error(\"BS8 \" + blen + \" != \" + b.length);\n\n\tvar out = [];\n\tif(a.length) out.push(a);\n\tif(b.length) out.push(b);\n\tif(c.length) out.push(c);\n\treturn bconcat(out);\n}\n\n/* [MS-XLS] 2.1.7.20 Workbook Stream */\nfunction write_biff8_buf(wb/*:Workbook*/, opts/*:WriteOpts*/) {\n\tvar o = opts || {};\n\tvar bufs = [];\n\n\tif(wb && !wb.SSF) {\n\t\twb.SSF = dup(table_fmt);\n\t}\n\tif(wb && wb.SSF) {\n\t\tmake_ssf(); SSF_load_table(wb.SSF);\n\t\t// $FlowIgnore\n\t\to.revssf = evert_num(wb.SSF); o.revssf[wb.SSF[65535]] = 0;\n\t\to.ssf = wb.SSF;\n\t}\n\n\to.Strings = /*::((*/[]/*:: :any):SST)*/; o.Strings.Count = 0; o.Strings.Unique = 0;\n\tfix_write_opts(o);\n\n\to.cellXfs = [];\n\tget_cell_style(o.cellXfs, {}, {revssf:{\"General\":0}});\n\n\tif(!wb.Props) wb.Props = {};\n\n\tfor(var i = 0; i < wb.SheetNames.length; ++i) bufs[bufs.length] = write_ws_biff8(i, o, wb);\n\tbufs.unshift(write_biff8_global(wb, bufs, o));\n\treturn bconcat(bufs);\n}\n\nfunction write_biff_buf(wb/*:Workbook*/, opts/*:WriteOpts*/) {\n\tfor(var i = 0; i <= wb.SheetNames.length; ++i) {\n\t\tvar ws = wb.Sheets[wb.SheetNames[i]];\n\t\tif(!ws || !ws[\"!ref\"]) continue;\n\t\tvar range = decode_range(ws[\"!ref\"]);\n\t\tif(range.e.c > 255) { // note: 255 is IV\n\t\tif(typeof console != \"undefined\" && console.error) console.error(\"Worksheet '\" + wb.SheetNames[i] + \"' extends beyond column IV (255). Data may be lost.\");\n\t\t}\n\t}\n\n\tvar o = opts || {};\n\tswitch(o.biff || 2) {\n\t\tcase 8: case 5: return write_biff8_buf(wb, opts);\n\t\tcase 4: case 3: case 2: return write_biff2_buf(wb, opts);\n\t}\n\tthrow new Error(\"invalid type \" + o.bookType + \" for BIFF\");\n}\n/* note: browser DOM element cannot see mso- style attrs, must parse */\nfunction html_to_sheet(str/*:string*/, _opts)/*:Workbook*/ {\n\tvar opts = _opts || {};\n\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\tvar ws/*:Worksheet*/ = opts.dense ? ([]/*:any*/) : ({}/*:any*/);\n\tstr = str.replace(/<!--.*?-->/g, \"\");\n\tvar mtch/*:any*/ = str.match(/<table/i);\n\tif(!mtch) throw new Error(\"Invalid HTML: could not find <table>\");\n\tvar mtch2/*:any*/ = str.match(/<\\/table/i);\n\tvar i/*:number*/ = mtch.index, j/*:number*/ = mtch2 && mtch2.index || str.length;\n\tvar rows = split_regex(str.slice(i, j), /(:?<tr[^>]*>)/i, \"<tr>\");\n\tvar R = -1, C = 0, RS = 0, CS = 0;\n\tvar range/*:Range*/ = {s:{r:10000000, c:10000000},e:{r:0,c:0}};\n\tvar merges/*:Array<Range>*/ = [];\n\tfor(i = 0; i < rows.length; ++i) {\n\t\tvar row = rows[i].trim();\n\t\tvar hd = row.slice(0,3).toLowerCase();\n\t\tif(hd == \"<tr\") { ++R; if(opts.sheetRows && opts.sheetRows <= R) { --R; break; } C = 0; continue; }\n\t\tif(hd != \"<td\" && hd != \"<th\") continue;\n\t\tvar cells = row.split(/<\\/t[dh]>/i);\n\t\tfor(j = 0; j < cells.length; ++j) {\n\t\t\tvar cell = cells[j].trim();\n\t\t\tif(!cell.match(/<t[dh]/i)) continue;\n\t\t\tvar m = cell, cc = 0;\n\t\t\t/* TODO: parse styles etc */\n\t\t\twhile(m.charAt(0) == \"<\" && (cc = m.indexOf(\">\")) > -1) m = m.slice(cc+1);\n\t\t\tfor(var midx = 0; midx < merges.length; ++midx) {\n\t\t\t\tvar _merge/*:Range*/ = merges[midx];\n\t\t\t\tif(_merge.s.c == C && _merge.s.r < R && R <= _merge.e.r) { C = _merge.e.c + 1; midx = -1; }\n\t\t\t}\n\t\t\tvar tag = parsexmltag(cell.slice(0, cell.indexOf(\">\")));\n\t\t\tCS = tag.colspan ? +tag.colspan : 1;\n\t\t\tif((RS = +tag.rowspan)>1 || CS>1) merges.push({s:{r:R,c:C},e:{r:R + (RS||1) - 1, c:C + CS - 1}});\n\t\t\tvar _t/*:string*/ = tag.t || tag[\"data-t\"] || \"\";\n\t\t\t/* TODO: generate stub cells */\n\t\t\tif(!m.length) { C += CS; continue; }\n\t\t\tm = htmldecode(m);\n\t\t\tif(range.s.r > R) range.s.r = R; if(range.e.r < R) range.e.r = R;\n\t\t\tif(range.s.c > C) range.s.c = C; if(range.e.c < C) range.e.c = C;\n\t\t\tif(!m.length) { C += CS; continue; }\n\t\t\tvar o/*:Cell*/ = {t:'s', v:m};\n\t\t\tif(opts.raw || !m.trim().length || _t == 's'){}\n\t\t\telse if(m === 'TRUE') o = {t:'b', v:true};\n\t\t\telse if(m === 'FALSE') o = {t:'b', v:false};\n\t\t\telse if(!isNaN(fuzzynum(m))) o = {t:'n', v:fuzzynum(m)};\n\t\t\telse if(!isNaN(fuzzydate(m).getDate())) {\n\t\t\t\to = ({t:'d', v:parseDate(m)}/*:any*/);\n\t\t\t\tif(!opts.cellDates) o = ({t:'n', v:datenum(o.v)}/*:any*/);\n\t\t\t\to.z = opts.dateNF || table_fmt[14];\n\t\t\t}\n\t\t\tif(opts.dense) { if(!ws[R]) ws[R] = []; ws[R][C] = o; }\n\t\t\telse ws[encode_cell({r:R, c:C})] = o;\n\t\t\tC += CS;\n\t\t}\n\t}\n\tws['!ref'] = encode_range(range);\n\tif(merges.length) ws[\"!merges\"] = merges;\n\treturn ws;\n}\nfunction make_html_row(ws/*:Worksheet*/, r/*:Range*/, R/*:number*/, o/*:Sheet2HTMLOpts*/)/*:string*/ {\n\tvar M/*:Array<Range>*/ = (ws['!merges'] ||[]);\n\tvar oo/*:Array<string>*/ = [];\n\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\tvar RS = 0, CS = 0;\n\t\tfor(var j = 0; j < M.length; ++j) {\n\t\t\tif(M[j].s.r > R || M[j].s.c > C) continue;\n\t\t\tif(M[j].e.r < R || M[j].e.c < C) continue;\n\t\t\tif(M[j].s.r < R || M[j].s.c < C) { RS = -1; break; }\n\t\t\tRS = M[j].e.r - M[j].s.r + 1; CS = M[j].e.c - M[j].s.c + 1; break;\n\t\t}\n\t\tif(RS < 0) continue;\n\t\tvar coord = encode_cell({r:R,c:C});\n\t\tvar cell = o.dense ? (ws[R]||[])[C] : ws[coord];\n\t\t/* TODO: html entities */\n\t\tvar w = (cell && cell.v != null) && (cell.h || escapehtml(cell.w || (format_cell(cell), cell.w) || \"\")) || \"\";\n\t\tvar sp = ({}/*:any*/);\n\t\tif(RS > 1) sp.rowspan = RS;\n\t\tif(CS > 1) sp.colspan = CS;\n\t\tif(o.editable) w = '<span contenteditable=\"true\">' + w + '</span>';\n\t\telse if(cell) {\n\t\t\tsp[\"data-t\"] = cell && cell.t || 'z';\n\t\t\tif(cell.v != null) sp[\"data-v\"] = cell.v;\n\t\t\tif(cell.z != null) sp[\"data-z\"] = cell.z;\n\t\t\tif(cell.l && (cell.l.Target || \"#\").charAt(0) != \"#\") w = '<a href=\"' + cell.l.Target +'\">' + w + '</a>';\n\t\t}\n\t\tsp.id = (o.id || \"sjs\") + \"-\" + coord;\n\t\too.push(writextag('td', w, sp));\n\t}\n\tvar preamble = \"<tr>\";\n\treturn preamble + oo.join(\"\") + \"</tr>\";\n}\n\nvar HTML_BEGIN = '<html><head><meta charset=\"utf-8\"/><title>SheetJS Table Export</title></head><body>';\nvar HTML_END = '</body></html>';\n\nfunction html_to_workbook(str/*:string*/, opts)/*:Workbook*/ {\n\tvar mtch = str.match(/<table[\\s\\S]*?>[\\s\\S]*?<\\/table>/gi);\n\tif(!mtch || mtch.length == 0) throw new Error(\"Invalid HTML: could not find <table>\");\n\tif(mtch.length == 1) return sheet_to_workbook(html_to_sheet(mtch[0], opts), opts);\n\tvar wb = book_new();\n\tmtch.forEach(function(s, idx) { book_append_sheet(wb, html_to_sheet(s, opts), \"Sheet\" + (idx+1)); });\n\treturn wb;\n}\n\nfunction make_html_preamble(ws/*:Worksheet*/, R/*:Range*/, o/*:Sheet2HTMLOpts*/)/*:string*/ {\n\tvar out/*:Array<string>*/ = [];\n\treturn out.join(\"\") + '<table' + (o && o.id ? ' id=\"' + o.id + '\"' : \"\") + '>';\n}\n\nfunction sheet_to_html(ws/*:Worksheet*/, opts/*:?Sheet2HTMLOpts*//*, wb:?Workbook*/)/*:string*/ {\n\tvar o = opts || {};\n\tvar header = o.header != null ? o.header : HTML_BEGIN;\n\tvar footer = o.footer != null ? o.footer : HTML_END;\n\tvar out/*:Array<string>*/ = [header];\n\tvar r = decode_range(ws['!ref']);\n\to.dense = Array.isArray(ws);\n\tout.push(make_html_preamble(ws, r, o));\n\tfor(var R = r.s.r; R <= r.e.r; ++R) out.push(make_html_row(ws, r, R, o));\n\tout.push(\"</table>\" + footer);\n\treturn out.join(\"\");\n}\n\nfunction sheet_add_dom(ws/*:Worksheet*/, table/*:HTMLElement*/, _opts/*:?any*/)/*:Worksheet*/ {\n\tvar opts = _opts || {};\n\tif(DENSE != null) opts.dense = DENSE;\n\tvar or_R = 0, or_C = 0;\n\tif(opts.origin != null) {\n\t\tif(typeof opts.origin == 'number') or_R = opts.origin;\n\t\telse {\n\t\t\tvar _origin/*:CellAddress*/ = typeof opts.origin == \"string\" ? decode_cell(opts.origin) : opts.origin;\n\t\t\tor_R = _origin.r; or_C = _origin.c;\n\t\t}\n\t}\n\n\tvar rows/*:HTMLCollection<HTMLTableRowElement>*/ = table.getElementsByTagName('tr');\n\tvar sheetRows = Math.min(opts.sheetRows||10000000, rows.length);\n\tvar range/*:Range*/ = {s:{r:0,c:0},e:{r:or_R,c:or_C}};\n\tif(ws[\"!ref\"]) {\n\t\tvar _range/*:Range*/ = decode_range(ws[\"!ref\"]);\n\t\trange.s.r = Math.min(range.s.r, _range.s.r);\n\t\trange.s.c = Math.min(range.s.c, _range.s.c);\n\t\trange.e.r = Math.max(range.e.r, _range.e.r);\n\t\trange.e.c = Math.max(range.e.c, _range.e.c);\n\t\tif(or_R == -1) range.e.r = or_R = _range.e.r + 1;\n\t}\n\tvar merges/*:Array<Range>*/ = [], midx = 0;\n\tvar rowinfo/*:Array<RowInfo>*/ = ws[\"!rows\"] || (ws[\"!rows\"] = []);\n\tvar _R = 0, R = 0, _C = 0, C = 0, RS = 0, CS = 0;\n\tif(!ws[\"!cols\"]) ws['!cols'] = [];\n\tfor(; _R < rows.length && R < sheetRows; ++_R) {\n\t\tvar row/*:HTMLTableRowElement*/ = rows[_R];\n\t\tif (is_dom_element_hidden(row)) {\n\t\t\tif (opts.display) continue;\n\t\t\trowinfo[R] = {hidden: true};\n\t\t}\n\t\tvar elts/*:HTMLCollection<HTMLTableCellElement>*/ = (row.children/*:any*/);\n\t\tfor(_C = C = 0; _C < elts.length; ++_C) {\n\t\t\tvar elt/*:HTMLTableCellElement*/ = elts[_C];\n\t\t\tif (opts.display && is_dom_element_hidden(elt)) continue;\n\t\t\tvar v/*:?string*/ = elt.hasAttribute('data-v') ? elt.getAttribute('data-v') : elt.hasAttribute('v') ? elt.getAttribute('v') : htmldecode(elt.innerHTML);\n\t\t\tvar z/*:?string*/ = elt.getAttribute('data-z') || elt.getAttribute('z');\n\t\t\tfor(midx = 0; midx < merges.length; ++midx) {\n\t\t\t\tvar m/*:Range*/ = merges[midx];\n\t\t\t\tif(m.s.c == C + or_C && m.s.r < R + or_R && R + or_R <= m.e.r) { C = m.e.c+1 - or_C; midx = -1; }\n\t\t\t}\n\t\t\t/* TODO: figure out how to extract nonstandard mso- style */\n\t\t\tCS = +elt.getAttribute(\"colspan\") || 1;\n\t\t\tif( ((RS = (+elt.getAttribute(\"rowspan\") || 1)))>1 || CS>1) merges.push({s:{r:R + or_R,c:C + or_C},e:{r:R + or_R + (RS||1) - 1, c:C + or_C + (CS||1) - 1}});\n\t\t\tvar o/*:Cell*/ = {t:'s', v:v};\n\t\t\tvar _t/*:string*/ = elt.getAttribute(\"data-t\") || elt.getAttribute(\"t\") || \"\";\n\t\t\tif(v != null) {\n\t\t\t\tif(v.length == 0) o.t = _t || 'z';\n\t\t\t\telse if(opts.raw || v.trim().length == 0 || _t == \"s\"){}\n\t\t\t\telse if(v === 'TRUE') o = {t:'b', v:true};\n\t\t\t\telse if(v === 'FALSE') o = {t:'b', v:false};\n\t\t\t\telse if(!isNaN(fuzzynum(v))) o = {t:'n', v:fuzzynum(v)};\n\t\t\t\telse if(!isNaN(fuzzydate(v).getDate())) {\n\t\t\t\t\to = ({t:'d', v:parseDate(v)}/*:any*/);\n\t\t\t\t\tif(!opts.cellDates) o = ({t:'n', v:datenum(o.v)}/*:any*/);\n\t\t\t\t\to.z = opts.dateNF || table_fmt[14];\n\t\t\t\t}\n\t\t\t}\n\t\t\tif(o.z === undefined && z != null) o.z = z;\n\t\t\t/* The first link is used. Links are assumed to be fully specified.\n\t\t\t * TODO: The right way to process relative links is to make a new <a> */\n\t\t\tvar l = \"\", Aelts = elt.getElementsByTagName(\"A\");\n\t\t\tif(Aelts && Aelts.length) for(var Aelti = 0; Aelti < Aelts.length; ++Aelti)\tif(Aelts[Aelti].hasAttribute(\"href\")) {\n\t\t\t\tl = Aelts[Aelti].getAttribute(\"href\"); if(l.charAt(0) != \"#\") break;\n\t\t\t}\n\t\t\tif(l && l.charAt(0) != \"#\") o.l = ({ Target: l });\n\t\t\tif(opts.dense) { if(!ws[R + or_R]) ws[R + or_R] = []; ws[R + or_R][C + or_C] = o; }\n\t\t\telse ws[encode_cell({c:C + or_C, r:R + or_R})] = o;\n\t\t\tif(range.e.c < C + or_C) range.e.c = C + or_C;\n\t\t\tC += CS;\n\t\t}\n\t\t++R;\n\t}\n\tif(merges.length) ws['!merges'] = (ws[\"!merges\"] || []).concat(merges);\n\trange.e.r = Math.max(range.e.r, R - 1 + or_R);\n\tws['!ref'] = encode_range(range);\n\tif(R >= sheetRows) ws['!fullref'] = encode_range((range.e.r = rows.length-_R+R-1 + or_R,range)); // We can count the real number of rows to parse but we don't to improve the performance\n\treturn ws;\n}\n\nfunction parse_dom_table(table/*:HTMLElement*/, _opts/*:?any*/)/*:Worksheet*/ {\n\tvar opts = _opts || {};\n\tvar ws/*:Worksheet*/ = opts.dense ? ([]/*:any*/) : ({}/*:any*/);\n\treturn sheet_add_dom(ws, table, _opts);\n}\n\nfunction table_to_book(table/*:HTMLElement*/, opts/*:?any*/)/*:Workbook*/ {\n\treturn sheet_to_workbook(parse_dom_table(table, opts), opts);\n}\n\nfunction is_dom_element_hidden(element/*:HTMLElement*/)/*:boolean*/ {\n\tvar display/*:string*/ = '';\n\tvar get_computed_style/*:?function*/ = get_get_computed_style_function(element);\n\tif(get_computed_style) display = get_computed_style(element).getPropertyValue('display');\n\tif(!display) display = element.style && element.style.display;\n\treturn display === 'none';\n}\n\n/* global getComputedStyle */\nfunction get_get_computed_style_function(element/*:HTMLElement*/)/*:?function*/ {\n\t// The proper getComputedStyle implementation is the one defined in the element window\n\tif(element.ownerDocument.defaultView && typeof element.ownerDocument.defaultView.getComputedStyle === 'function') return element.ownerDocument.defaultView.getComputedStyle;\n\t// If it is not available, try to get one from the global namespace\n\tif(typeof getComputedStyle === 'function') return getComputedStyle;\n\treturn null;\n}\n/* OpenDocument */\nfunction parse_text_p(text/*:string*//*::, tag*/)/*:Array<any>*/ {\n\t/* 6.1.2 White Space Characters */\n\tvar fixed = text\n\t\t.replace(/[\\t\\r\\n]/g, \" \").trim().replace(/ +/g, \" \")\n\t\t.replace(/<text:s\\/>/g,\" \")\n\t\t.replace(/<text:s text:c=\"(\\d+)\"\\/>/g, function($$,$1) { return Array(parseInt($1,10)+1).join(\" \"); })\n\t\t.replace(/<text:tab[^>]*\\/>/g,\"\\t\")\n\t\t.replace(/<text:line-break\\/>/g,\"\\n\");\n\tvar v = unescapexml(fixed.replace(/<[^>]*>/g,\"\"));\n\n\treturn [v];\n}\n\nvar number_formats_ods = {\n\t/* ods name: [short ssf fmt, long ssf fmt] */\n\tday: [\"d\", \"dd\"],\n\tmonth: [\"m\", \"mm\"],\n\tyear: [\"y\", \"yy\"],\n\thours: [\"h\", \"hh\"],\n\tminutes: [\"m\", \"mm\"],\n\tseconds: [\"s\", \"ss\"],\n\t\"am-pm\": [\"A/P\", \"AM/PM\"],\n\t\"day-of-week\": [\"ddd\", \"dddd\"],\n\tera: [\"e\", \"ee\"],\n\t/* there is no native representation of LO \"Q\" format */\n\tquarter: [\"\\\\Qm\", \"m\\\\\\\"th quarter\\\"\"]\n};\n\n\nfunction parse_content_xml(d/*:string*/, _opts)/*:Workbook*/ {\n\t\tvar opts = _opts || {};\n\t\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\t\tvar str = xlml_normalize(d);\n\t\tvar state/*:Array<any>*/ = [], tmp;\n\t\tvar tag/*:: = {}*/;\n\t\tvar NFtag = {name:\"\"}, NF = \"\", pidx = 0;\n\t\tvar sheetag/*:: = {name:\"\", '名称':\"\"}*/;\n\t\tvar rowtag/*:: = {'行号':\"\"}*/;\n\t\tvar Sheets = {}, SheetNames/*:Array<string>*/ = [];\n\t\tvar ws = opts.dense ? ([]/*:any*/) : ({}/*:any*/);\n\t\tvar Rn, q/*:: :any = ({t:\"\", v:null, z:null, w:\"\",c:[],}:any)*/;\n\t\tvar ctag = ({value:\"\"}/*:any*/);\n\t\tvar textp = \"\", textpidx = 0, textptag/*:: = {}*/;\n\t\tvar textR = [];\n\t\tvar R = -1, C = -1, range = {s: {r:1000000,c:10000000}, e: {r:0, c:0}};\n\t\tvar row_ol = 0;\n\t\tvar number_format_map = {};\n\t\tvar merges/*:Array<Range>*/ = [], mrange = {}, mR = 0, mC = 0;\n\t\tvar rowinfo/*:Array<RowInfo>*/ = [], rowpeat = 1, colpeat = 1;\n\t\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\t\tvar WB = {Names:[]};\n\t\tvar atag = ({}/*:any*/);\n\t\tvar _Ref/*:[string, string]*/ = [\"\", \"\"];\n\t\tvar comments/*:Array<Comment>*/ = [], comment/*:Comment*/ = ({}/*:any*/);\n\t\tvar creator = \"\", creatoridx = 0;\n\t\tvar isstub = false, intable = false;\n\t\tvar i = 0;\n\t\txlmlregex.lastIndex = 0;\n\t\tstr = str.replace(/<!--([\\s\\S]*?)-->/mg,\"\").replace(/<!DOCTYPE[^\\[]*\\[[^\\]]*\\]>/gm,\"\");\n\t\twhile((Rn = xlmlregex.exec(str))) switch((Rn[3]=Rn[3].replace(/_.*$/,\"\"))) {\n\n\t\t\tcase 'table': case '工作表': // 9.1.2 <table:table>\n\t\t\t\tif(Rn[1]==='/') {\n\t\t\t\t\tif(range.e.c >= range.s.c && range.e.r >= range.s.r) ws['!ref'] = encode_range(range);\n\t\t\t\t\telse ws['!ref'] = \"A1:A1\";\n\t\t\t\t\tif(opts.sheetRows > 0 && opts.sheetRows <= range.e.r) {\n\t\t\t\t\t\tws['!fullref'] = ws['!ref'];\n\t\t\t\t\t\trange.e.r = opts.sheetRows - 1;\n\t\t\t\t\t\tws['!ref'] = encode_range(range);\n\t\t\t\t\t}\n\t\t\t\t\tif(merges.length) ws['!merges'] = merges;\n\t\t\t\t\tif(rowinfo.length) ws[\"!rows\"] = rowinfo;\n\t\t\t\t\tsheetag.name = sheetag['名称'] || sheetag.name;\n\t\t\t\t\tif(typeof JSON !== 'undefined') JSON.stringify(sheetag);\n\t\t\t\t\tSheetNames.push(sheetag.name);\n\t\t\t\t\tSheets[sheetag.name] = ws;\n\t\t\t\t\tintable = false;\n\t\t\t\t}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') {\n\t\t\t\t\tsheetag = parsexmltag(Rn[0], false);\n\t\t\t\t\tR = C = -1;\n\t\t\t\t\trange.s.r = range.s.c = 10000000; range.e.r = range.e.c = 0;\n\t\t\t\t\tws = opts.dense ? ([]/*:any*/) : ({}/*:any*/); merges = [];\n\t\t\t\t\trowinfo = [];\n\t\t\t\t\tintable = true;\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 'table-row-group': // 9.1.9 <table:table-row-group>\n\t\t\t\tif(Rn[1] === \"/\") --row_ol; else ++row_ol;\n\t\t\t\tbreak;\n\t\t\tcase 'table-row': case '行': // 9.1.3 <table:table-row>\n\t\t\t\tif(Rn[1] === '/') { R+=rowpeat; rowpeat = 1; break; }\n\t\t\t\trowtag = parsexmltag(Rn[0], false);\n\t\t\t\tif(rowtag['行号']) R = rowtag['行号'] - 1; else if(R == -1) R = 0;\n\t\t\t\trowpeat = +rowtag['number-rows-repeated'] || 1;\n\t\t\t\t/* TODO: remove magic */\n\t\t\t\tif(rowpeat < 10) for(i = 0; i < rowpeat; ++i) if(row_ol > 0) rowinfo[R + i] = {level: row_ol};\n\t\t\t\tC = -1; break;\n\t\t\tcase 'covered-table-cell': // 9.1.5 <table:covered-table-cell>\n\t\t\t\tif(Rn[1] !== '/') ++C;\n\t\t\t\tif(opts.sheetStubs) {\n\t\t\t\t\tif(opts.dense) { if(!ws[R]) ws[R] = []; ws[R][C] = {t:'z'}; }\n\t\t\t\t\telse ws[encode_cell({r:R,c:C})] = {t:'z'};\n\t\t\t\t}\n\t\t\t\ttextp = \"\"; textR = [];\n\t\t\t\tbreak; /* stub */\n\t\t\tcase 'table-cell': case '数据':\n\t\t\t\tif(Rn[0].charAt(Rn[0].length-2) === '/') {\n\t\t\t\t\t++C;\n\t\t\t\t\tctag = parsexmltag(Rn[0], false);\n\t\t\t\t\tcolpeat = parseInt(ctag['number-columns-repeated']||\"1\", 10);\n\t\t\t\t\tq = ({t:'z', v:null/*:: , z:null, w:\"\",c:[]*/}/*:any*/);\n\t\t\t\t\tif(ctag.formula && opts.cellFormula != false) q.f = ods_to_csf_formula(unescapexml(ctag.formula));\n\t\t\t\t\tif((ctag['数据类型'] || ctag['value-type']) == \"string\") {\n\t\t\t\t\t\tq.t = \"s\"; q.v = unescapexml(ctag['string-value'] || \"\");\n\t\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\t\tif(!ws[R]) ws[R] = [];\n\t\t\t\t\t\t\tws[R][C] = q;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tws[encode_cell({r:R,c:C})] = q;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tC+= colpeat-1;\n\t\t\t\t} else if(Rn[1]!=='/') {\n\t\t\t\t\t++C;\n\t\t\t\t\ttextp = \"\"; textpidx = 0; textR = [];\n\t\t\t\t\tcolpeat = 1;\n\t\t\t\t\tvar rptR = rowpeat ? R + rowpeat - 1 : R;\n\t\t\t\t\tif(C > range.e.c) range.e.c = C;\n\t\t\t\t\tif(C < range.s.c) range.s.c = C;\n\t\t\t\t\tif(R < range.s.r) range.s.r = R;\n\t\t\t\t\tif(rptR > range.e.r) range.e.r = rptR;\n\t\t\t\t\tctag = parsexmltag(Rn[0], false);\n\t\t\t\t\tcomments = []; comment = ({}/*:any*/);\n\t\t\t\t\tq = ({t:ctag['数据类型'] || ctag['value-type'], v:null/*:: , z:null, w:\"\",c:[]*/}/*:any*/);\n\t\t\t\t\tif(opts.cellFormula) {\n\t\t\t\t\t\tif(ctag.formula) ctag.formula = unescapexml(ctag.formula);\n\t\t\t\t\t\tif(ctag['number-matrix-columns-spanned'] && ctag['number-matrix-rows-spanned']) {\n\t\t\t\t\t\t\tmR = parseInt(ctag['number-matrix-rows-spanned'],10) || 0;\n\t\t\t\t\t\t\tmC = parseInt(ctag['number-matrix-columns-spanned'],10) || 0;\n\t\t\t\t\t\t\tmrange = {s: {r:R,c:C}, e:{r:R + mR-1,c:C + mC-1}};\n\t\t\t\t\t\t\tq.F = encode_range(mrange);\n\t\t\t\t\t\t\tarrayf.push([mrange, q.F]);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif(ctag.formula) q.f = ods_to_csf_formula(ctag.formula);\n\t\t\t\t\t\telse for(i = 0; i < arrayf.length; ++i)\n\t\t\t\t\t\t\tif(R >= arrayf[i][0].s.r && R <= arrayf[i][0].e.r)\n\t\t\t\t\t\t\t\tif(C >= arrayf[i][0].s.c && C <= arrayf[i][0].e.c)\n\t\t\t\t\t\t\t\t\tq.F = arrayf[i][1];\n\t\t\t\t\t}\n\t\t\t\t\tif(ctag['number-columns-spanned'] || ctag['number-rows-spanned']) {\n\t\t\t\t\t\tmR = parseInt(ctag['number-rows-spanned'],10) || 0;\n\t\t\t\t\t\tmC = parseInt(ctag['number-columns-spanned'],10) || 0;\n\t\t\t\t\t\tmrange = {s: {r:R,c:C}, e:{r:R + mR-1,c:C + mC-1}};\n\t\t\t\t\t\tmerges.push(mrange);\n\t\t\t\t\t}\n\n\t\t\t\t\t/* 19.675.2 table:number-columns-repeated */\n\t\t\t\t\tif(ctag['number-columns-repeated']) colpeat = parseInt(ctag['number-columns-repeated'], 10);\n\n\t\t\t\t\t/* 19.385 office:value-type */\n\t\t\t\t\tswitch(q.t) {\n\t\t\t\t\t\tcase 'boolean': q.t = 'b'; q.v = parsexmlbool(ctag['boolean-value']); break;\n\t\t\t\t\t\tcase 'float': q.t = 'n'; q.v = parseFloat(ctag.value); break;\n\t\t\t\t\t\tcase 'percentage': q.t = 'n'; q.v = parseFloat(ctag.value); break;\n\t\t\t\t\t\tcase 'currency': q.t = 'n'; q.v = parseFloat(ctag.value); break;\n\t\t\t\t\t\tcase 'date': q.t = 'd'; q.v = parseDate(ctag['date-value']);\n\t\t\t\t\t\t\tif(!opts.cellDates) { q.t = 'n'; q.v = datenum(q.v); }\n\t\t\t\t\t\t\tq.z = 'm/d/yy'; break;\n\t\t\t\t\t\tcase 'time': q.t = 'n'; q.v = parse_isodur(ctag['time-value'])/86400;\n\t\t\t\t\t\t\tif(opts.cellDates) { q.t = 'd'; q.v = numdate(q.v); }\n\t\t\t\t\t\t\tq.z = 'HH:MM:SS'; break;\n\t\t\t\t\t\tcase 'number': q.t = 'n'; q.v = parseFloat(ctag['数据数值']); break;\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tif(q.t === 'string' || q.t === 'text' || !q.t) {\n\t\t\t\t\t\t\t\tq.t = 's';\n\t\t\t\t\t\t\t\tif(ctag['string-value'] != null) { textp = unescapexml(ctag['string-value']); textR = []; }\n\t\t\t\t\t\t\t} else throw new Error('Unsupported value type ' + q.t);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tisstub = false;\n\t\t\t\t\tif(q.t === 's') {\n\t\t\t\t\t\tq.v = textp || '';\n\t\t\t\t\t\tif(textR.length) q.R = textR;\n\t\t\t\t\t\tisstub = textpidx == 0;\n\t\t\t\t\t}\n\t\t\t\t\tif(atag.Target) q.l = atag;\n\t\t\t\t\tif(comments.length > 0) { q.c = comments; comments = []; }\n\t\t\t\t\tif(textp && opts.cellText !== false) q.w = textp;\n\t\t\t\t\tif(isstub) { q.t = \"z\"; delete q.v; }\n\t\t\t\t\tif(!isstub || opts.sheetStubs) {\n\t\t\t\t\t\tif(!(opts.sheetRows && opts.sheetRows <= R)) {\n\t\t\t\t\t\t\tfor(var rpt = 0; rpt < rowpeat; ++rpt) {\n\t\t\t\t\t\t\t\tcolpeat = parseInt(ctag['number-columns-repeated']||\"1\", 10);\n\t\t\t\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\t\t\t\tif(!ws[R + rpt]) ws[R + rpt] = [];\n\t\t\t\t\t\t\t\t\tws[R + rpt][C] = rpt == 0 ? q : dup(q);\n\t\t\t\t\t\t\t\t\twhile(--colpeat > 0) ws[R + rpt][C + colpeat] = dup(q);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tws[encode_cell({r:R + rpt,c:C})] = q;\n\t\t\t\t\t\t\t\t\twhile(--colpeat > 0) ws[encode_cell({r:R + rpt,c:C + colpeat})] = dup(q);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tif(range.e.c <= C) range.e.c = C;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcolpeat = parseInt(ctag['number-columns-repeated']||\"1\", 10);\n\t\t\t\t\tC += colpeat-1; colpeat = 0;\n\t\t\t\t\tq = {/*:: t:\"\", v:null, z:null, w:\"\",c:[]*/};\n\t\t\t\t\ttextp = \"\"; textR = [];\n\t\t\t\t}\n\t\t\t\tatag = ({}/*:any*/);\n\t\t\t\tbreak; // 9.1.4 <table:table-cell>\n\n\t\t\t/* pure state */\n\t\t\tcase 'document': // TODO: <office:document> is the root for FODS\n\t\t\tcase 'document-content': case '电子表格文档': // 3.1.3.2 <office:document-content>\n\t\t\tcase 'spreadsheet': case '主体': // 3.7 <office:spreadsheet>\n\t\t\tcase 'scripts': // 3.12 <office:scripts>\n\t\t\tcase 'styles': // TODO <office:styles>\n\t\t\tcase 'font-face-decls': // 3.14 <office:font-face-decls>\n\t\t\tcase 'master-styles': // 3.15.4 <office:master-styles> -- relevant for FODS\n\t\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], true]);\n\t\t\t\tbreak;\n\n\t\t\tcase 'annotation': // 14.1 <office:annotation>\n\t\t\t\tif(Rn[1]==='/'){\n\t\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;\n\t\t\t\t\tcomment.t = textp;\n\t\t\t\t\tif(textR.length) /*::(*/comment/*:: :any)*/.R = textR;\n\t\t\t\t\tcomment.a = creator;\n\t\t\t\t\tcomments.push(comment);\n\t\t\t\t}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') {state.push([Rn[3], false]);}\n\t\t\t\tcreator = \"\"; creatoridx = 0;\n\t\t\t\ttextp = \"\"; textpidx = 0; textR = [];\n\t\t\t\tbreak;\n\n\t\t\tcase 'creator': // 4.3.2.7 <dc:creator>\n\t\t\t\tif(Rn[1]==='/') { creator = str.slice(creatoridx,Rn.index); }\n\t\t\t\telse creatoridx = Rn.index + Rn[0].length;\n\t\t\t\tbreak;\n\n\t\t\t/* ignore state */\n\t\t\tcase 'meta': case '元数据': // TODO: <office:meta> <uof:元数据> FODS/UOF\n\t\t\tcase 'settings': // TODO: <office:settings>\n\t\t\tcase 'config-item-set': // TODO: <office:config-item-set>\n\t\t\tcase 'config-item-map-indexed': // TODO: <office:config-item-map-indexed>\n\t\t\tcase 'config-item-map-entry': // TODO: <office:config-item-map-entry>\n\t\t\tcase 'config-item-map-named': // TODO: <office:config-item-map-entry>\n\t\t\tcase 'shapes': // 9.2.8 <table:shapes>\n\t\t\tcase 'frame': // 10.4.2 <draw:frame>\n\t\t\tcase 'text-box': // 10.4.3 <draw:text-box>\n\t\t\tcase 'image': // 10.4.4 <draw:image>\n\t\t\tcase 'data-pilot-tables': // 9.6.2 <table:data-pilot-tables>\n\t\t\tcase 'list-style': // 16.30 <text:list-style>\n\t\t\tcase 'form': // 13.13 <form:form>\n\t\t\tcase 'dde-links': // 9.8 <table:dde-links>\n\t\t\tcase 'event-listeners': // TODO\n\t\t\tcase 'chart': // TODO\n\t\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], false]);\n\t\t\t\ttextp = \"\"; textpidx = 0; textR = [];\n\t\t\t\tbreak;\n\n\t\t\tcase 'scientific-number': // TODO: <number:scientific-number>\n\t\t\t\tbreak;\n\t\t\tcase 'currency-symbol': // TODO: <number:currency-symbol>\n\t\t\t\tbreak;\n\t\t\tcase 'currency-style': // TODO: <number:currency-style>\n\t\t\t\tbreak;\n\t\t\tcase 'number-style': // 16.27.2 <number:number-style>\n\t\t\tcase 'percentage-style': // 16.27.9 <number:percentage-style>\n\t\t\tcase 'date-style': // 16.27.10 <number:date-style>\n\t\t\tcase 'time-style': // 16.27.18 <number:time-style>\n\t\t\t\tif(Rn[1]==='/'){\n\t\t\t\t\tnumber_format_map[NFtag.name] = NF;\n\t\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;\n\t\t\t\t} else if(Rn[0].charAt(Rn[0].length-2) !== '/') {\n\t\t\t\t\tNF = \"\";\n\t\t\t\t\tNFtag = parsexmltag(Rn[0], false);\n\t\t\t\t\tstate.push([Rn[3], true]);\n\t\t\t\t} break;\n\n\t\t\tcase 'script': break; // 3.13 <office:script>\n\t\t\tcase 'libraries': break; // TODO: <ooo:libraries>\n\t\t\tcase 'automatic-styles': break; // 3.15.3 <office:automatic-styles>\n\n\t\t\tcase 'default-style': // TODO: <style:default-style>\n\t\t\tcase 'page-layout': break; // TODO: <style:page-layout>\n\t\t\tcase 'style': // 16.2 <style:style>\n\t\t\t\tbreak;\n\t\t\tcase 'map': break; // 16.3 <style:map>\n\t\t\tcase 'font-face': break; // 16.21 <style:font-face>\n\n\t\t\tcase 'paragraph-properties': break; // 17.6 <style:paragraph-properties>\n\t\t\tcase 'table-properties': break; // 17.15 <style:table-properties>\n\t\t\tcase 'table-column-properties': break; // 17.16 <style:table-column-properties>\n\t\t\tcase 'table-row-properties': break; // 17.17 <style:table-row-properties>\n\t\t\tcase 'table-cell-properties': break; // 17.18 <style:table-cell-properties>\n\n\t\t\tcase 'number': // 16.27.3 <number:number>\n\t\t\t\tswitch(state[state.length-1][0]) {\n\t\t\t\t\tcase 'time-style':\n\t\t\t\t\tcase 'date-style':\n\t\t\t\t\t\ttag = parsexmltag(Rn[0], false);\n\t\t\t\t\t\tNF += number_formats_ods[Rn[3]][tag.style==='long'?1:0]; break;\n\t\t\t\t} break;\n\n\t\t\tcase 'fraction': break; // TODO 16.27.6 <number:fraction>\n\n\t\t\tcase 'day': // 16.27.11 <number:day>\n\t\t\tcase 'month': // 16.27.12 <number:month>\n\t\t\tcase 'year': // 16.27.13 <number:year>\n\t\t\tcase 'era': // 16.27.14 <number:era>\n\t\t\tcase 'day-of-week': // 16.27.15 <number:day-of-week>\n\t\t\tcase 'week-of-year': // 16.27.16 <number:week-of-year>\n\t\t\tcase 'quarter': // 16.27.17 <number:quarter>\n\t\t\tcase 'hours': // 16.27.19 <number:hours>\n\t\t\tcase 'minutes': // 16.27.20 <number:minutes>\n\t\t\tcase 'seconds': // 16.27.21 <number:seconds>\n\t\t\tcase 'am-pm': // 16.27.22 <number:am-pm>\n\t\t\t\tswitch(state[state.length-1][0]) {\n\t\t\t\t\tcase 'time-style':\n\t\t\t\t\tcase 'date-style':\n\t\t\t\t\t\ttag = parsexmltag(Rn[0], false);\n\t\t\t\t\t\tNF += number_formats_ods[Rn[3]][tag.style==='long'?1:0]; break;\n\t\t\t\t} break;\n\n\t\t\tcase 'boolean-style': break; // 16.27.23 <number:boolean-style>\n\t\t\tcase 'boolean': break; // 16.27.24 <number:boolean>\n\t\t\tcase 'text-style': break; // 16.27.25 <number:text-style>\n\t\t\tcase 'text': // 16.27.26 <number:text>\n\t\t\t\tif(Rn[0].slice(-2) === \"/>\") break;\n\t\t\t\telse if(Rn[1]===\"/\") switch(state[state.length-1][0]) {\n\t\t\t\t\tcase 'number-style':\n\t\t\t\t\tcase 'date-style':\n\t\t\t\t\tcase 'time-style':\n\t\t\t\t\t\tNF += str.slice(pidx, Rn.index);\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\telse pidx = Rn.index + Rn[0].length;\n\t\t\t\tbreak;\n\n\t\t\tcase 'named-range': // 9.4.12 <table:named-range>\n\t\t\t\ttag = parsexmltag(Rn[0], false);\n\t\t\t\t_Ref = ods_to_csf_3D(tag['cell-range-address']);\n\t\t\t\tvar nrange = ({Name:tag.name, Ref:_Ref[0] + '!' + _Ref[1]}/*:any*/);\n\t\t\t\tif(intable) nrange.Sheet = SheetNames.length;\n\t\t\t\tWB.Names.push(nrange);\n\t\t\t\tbreak;\n\n\t\t\tcase 'text-content': break; // 16.27.27 <number:text-content>\n\t\t\tcase 'text-properties': break; // 16.27.27 <style:text-properties>\n\t\t\tcase 'embedded-text': break; // 16.27.4 <number:embedded-text>\n\n\t\t\tcase 'body': case '电子表格': break; // 3.3 16.9.6 19.726.3\n\n\t\t\tcase 'forms': break; // 12.25.2 13.2\n\t\t\tcase 'table-column': break; // 9.1.6 <table:table-column>\n\t\t\tcase 'table-header-rows': break; // 9.1.7 <table:table-header-rows>\n\t\t\tcase 'table-rows': break; // 9.1.12 <table:table-rows>\n\t\t\t/* TODO: outline levels */\n\t\t\tcase 'table-column-group': break; // 9.1.10 <table:table-column-group>\n\t\t\tcase 'table-header-columns': break; // 9.1.11 <table:table-header-columns>\n\t\t\tcase 'table-columns': break; // 9.1.12 <table:table-columns>\n\n\t\t\tcase 'null-date': break; // 9.4.2 <table:null-date> TODO: date1904\n\n\t\t\tcase 'graphic-properties': break; // 17.21 <style:graphic-properties>\n\t\t\tcase 'calculation-settings': break; // 9.4.1 <table:calculation-settings>\n\t\t\tcase 'named-expressions': break; // 9.4.11 <table:named-expressions>\n\t\t\tcase 'label-range': break; // 9.4.9 <table:label-range>\n\t\t\tcase 'label-ranges': break; // 9.4.10 <table:label-ranges>\n\t\t\tcase 'named-expression': break; // 9.4.13 <table:named-expression>\n\t\t\tcase 'sort': break; // 9.4.19 <table:sort>\n\t\t\tcase 'sort-by': break; // 9.4.20 <table:sort-by>\n\t\t\tcase 'sort-groups': break; // 9.4.22 <table:sort-groups>\n\n\t\t\tcase 'tab': break; // 6.1.4 <text:tab>\n\t\t\tcase 'line-break': break; // 6.1.5 <text:line-break>\n\t\t\tcase 'span': break; // 6.1.7 <text:span>\n\t\t\tcase 'p': case '文本串': // 5.1.3 <text:p>\n\t\t\t\tif(['master-styles'].indexOf(state[state.length-1][0]) > -1) break;\n\t\t\t\tif(Rn[1]==='/' && (!ctag || !ctag['string-value'])) {\n\t\t\t\t\tvar ptp = parse_text_p(str.slice(textpidx,Rn.index), textptag);\n\t\t\t\t\ttextp = (textp.length > 0 ? textp + \"\\n\" : \"\") + ptp[0];\n\t\t\t\t} else { textptag = parsexmltag(Rn[0], false); textpidx = Rn.index + Rn[0].length; }\n\t\t\t\tbreak; // <text:p>\n\t\t\tcase 's': break; // <text:s>\n\n\t\t\tcase 'database-range': // 9.4.15 <table:database-range>\n\t\t\t\tif(Rn[1]==='/') break;\n\t\t\t\ttry {\n\t\t\t\t\t_Ref = ods_to_csf_3D(parsexmltag(Rn[0])['target-range-address']);\n\t\t\t\t\tSheets[_Ref[0]]['!autofilter'] = { ref:_Ref[1] };\n\t\t\t\t} catch(e) {/* empty */}\n\t\t\t\tbreak;\n\n\t\t\tcase 'date': break; // <*:date>\n\n\t\t\tcase 'object': break; // 10.4.6.2 <draw:object>\n\t\t\tcase 'title': case '标题': break; // <*:title> OR <uof:标题>\n\t\t\tcase 'desc': break; // <*:desc>\n\t\t\tcase 'binary-data': break; // 10.4.5 TODO: b64 blob\n\n\t\t\t/* 9.2 Advanced Tables */\n\t\t\tcase 'table-source': break; // 9.2.6\n\t\t\tcase 'scenario': break; // 9.2.6\n\n\t\t\tcase 'iteration': break; // 9.4.3 <table:iteration>\n\t\t\tcase 'content-validations': break; // 9.4.4 <table:\n\t\t\tcase 'content-validation': break; // 9.4.5 <table:\n\t\t\tcase 'help-message': break; // 9.4.6 <table:\n\t\t\tcase 'error-message': break; // 9.4.7 <table:\n\t\t\tcase 'database-ranges': break; // 9.4.14 <table:database-ranges>\n\t\t\tcase 'filter': break; // 9.5.2 <table:filter>\n\t\t\tcase 'filter-and': break; // 9.5.3 <table:filter-and>\n\t\t\tcase 'filter-or': break; // 9.5.4 <table:filter-or>\n\t\t\tcase 'filter-condition': break; // 9.5.5 <table:filter-condition>\n\n\t\t\tcase 'list-level-style-bullet': break; // 16.31 <text:\n\t\t\tcase 'list-level-style-number': break; // 16.32 <text:\n\t\t\tcase 'list-level-properties': break; // 17.19 <style:\n\n\t\t\t/* 7.3 Document Fields */\n\t\t\tcase 'sender-firstname': // 7.3.6.2\n\t\t\tcase 'sender-lastname': // 7.3.6.3\n\t\t\tcase 'sender-initials': // 7.3.6.4\n\t\t\tcase 'sender-title': // 7.3.6.5\n\t\t\tcase 'sender-position': // 7.3.6.6\n\t\t\tcase 'sender-email': // 7.3.6.7\n\t\t\tcase 'sender-phone-private': // 7.3.6.8\n\t\t\tcase 'sender-fax': // 7.3.6.9\n\t\t\tcase 'sender-company': // 7.3.6.10\n\t\t\tcase 'sender-phone-work': // 7.3.6.11\n\t\t\tcase 'sender-street': // 7.3.6.12\n\t\t\tcase 'sender-city': // 7.3.6.13\n\t\t\tcase 'sender-postal-code': // 7.3.6.14\n\t\t\tcase 'sender-country': // 7.3.6.15\n\t\t\tcase 'sender-state-or-province': // 7.3.6.16\n\t\t\tcase 'author-name': // 7.3.7.1\n\t\t\tcase 'author-initials': // 7.3.7.2\n\t\t\tcase 'chapter': // 7.3.8\n\t\t\tcase 'file-name': // 7.3.9\n\t\t\tcase 'template-name': // 7.3.9\n\t\t\tcase 'sheet-name': // 7.3.9\n\t\t\t\tbreak;\n\n\t\t\tcase 'event-listener':\n\t\t\t\tbreak;\n\t\t\t/* TODO: FODS Properties */\n\t\t\tcase 'initial-creator':\n\t\t\tcase 'creation-date':\n\t\t\tcase 'print-date':\n\t\t\tcase 'generator':\n\t\t\tcase 'document-statistic':\n\t\t\tcase 'user-defined':\n\t\t\tcase 'editing-duration':\n\t\t\tcase 'editing-cycles':\n\t\t\t\tbreak;\n\n\t\t\t/* TODO: FODS Config */\n\t\t\tcase 'config-item':\n\t\t\t\tbreak;\n\n\t\t\t/* TODO: style tokens */\n\t\t\tcase 'page-number': break; // TODO <text:page-number>\n\t\t\tcase 'page-count': break; // TODO <text:page-count>\n\t\t\tcase 'time': break; // TODO <text:time>\n\n\t\t\t/* 9.3 Advanced Table Cells */\n\t\t\tcase 'cell-range-source': break; // 9.3.1 <table:\n\t\t\tcase 'detective': break; // 9.3.2 <table:\n\t\t\tcase 'operation': break; // 9.3.3 <table:\n\t\t\tcase 'highlighted-range': break; // 9.3.4 <table:\n\n\t\t\t/* 9.6 Data Pilot Tables <table: */\n\t\t\tcase 'data-pilot-table': // 9.6.3\n\t\t\tcase 'source-cell-range': // 9.6.5\n\t\t\tcase 'source-service': // 9.6.6\n\t\t\tcase 'data-pilot-field': // 9.6.7\n\t\t\tcase 'data-pilot-level': // 9.6.8\n\t\t\tcase 'data-pilot-subtotals': // 9.6.9\n\t\t\tcase 'data-pilot-subtotal': // 9.6.10\n\t\t\tcase 'data-pilot-members': // 9.6.11\n\t\t\tcase 'data-pilot-member': // 9.6.12\n\t\t\tcase 'data-pilot-display-info': // 9.6.13\n\t\t\tcase 'data-pilot-sort-info': // 9.6.14\n\t\t\tcase 'data-pilot-layout-info': // 9.6.15\n\t\t\tcase 'data-pilot-field-reference': // 9.6.16\n\t\t\tcase 'data-pilot-groups': // 9.6.17\n\t\t\tcase 'data-pilot-group': // 9.6.18\n\t\t\tcase 'data-pilot-group-member': // 9.6.19\n\t\t\t\tbreak;\n\n\t\t\t/* 10.3 Drawing Shapes */\n\t\t\tcase 'rect': // 10.3.2\n\t\t\t\tbreak;\n\n\t\t\t/* 14.6 DDE Connections */\n\t\t\tcase 'dde-connection-decls': // 14.6.2 <text:\n\t\t\tcase 'dde-connection-decl': // 14.6.3 <text:\n\t\t\tcase 'dde-link': // 14.6.4 <table:\n\t\t\tcase 'dde-source': // 14.6.5 <office:\n\t\t\t\tbreak;\n\n\t\t\tcase 'properties': break; // 13.7 <form:properties>\n\t\t\tcase 'property': break; // 13.8 <form:property>\n\n\t\t\tcase 'a': // 6.1.8 hyperlink\n\t\t\t\tif(Rn[1]!== '/') {\n\t\t\t\t\tatag = parsexmltag(Rn[0], false);\n\t\t\t\t\tif(!atag.href) break;\n\t\t\t\t\tatag.Target = unescapexml(atag.href); delete atag.href;\n\t\t\t\t\tif(atag.Target.charAt(0) == \"#\" && atag.Target.indexOf(\".\") > -1) {\n\t\t\t\t\t\t_Ref = ods_to_csf_3D(atag.Target.slice(1));\n\t\t\t\t\t\tatag.Target = \"#\" + _Ref[0] + \"!\" + _Ref[1];\n\t\t\t\t\t} else if(atag.Target.match(/^\\.\\.[\\\\\\/]/)) atag.Target = atag.Target.slice(3);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\t/* non-standard */\n\t\t\tcase 'table-protection': break;\n\t\t\tcase 'data-pilot-grand-total': break; // <table:\n\t\t\tcase 'office-document-common-attrs': break; // bare\n\t\t\tdefault: switch(Rn[2]) {\n\t\t\t\tcase 'dc:': // TODO: properties\n\t\t\t\tcase 'calcext:': // ignore undocumented extensions\n\t\t\t\tcase 'loext:': // ignore undocumented extensions\n\t\t\t\tcase 'ooo:': // ignore undocumented extensions\n\t\t\t\tcase 'chartooo:': // ignore undocumented extensions\n\t\t\t\tcase 'draw:': // TODO: drawing\n\t\t\t\tcase 'style:': // TODO: styles\n\t\t\t\tcase 'chart:': // TODO: charts\n\t\t\t\tcase 'form:': // TODO: forms\n\t\t\t\tcase 'uof:': // TODO: uof\n\t\t\t\tcase '表:': // TODO: uof\n\t\t\t\tcase '字:': // TODO: uof\n\t\t\t\t\tbreak;\n\t\t\t\tdefault: if(opts.WTF) throw new Error(Rn);\n\t\t\t}\n\t\t}\n\t\tvar out/*:Workbook*/ = ({\n\t\t\tSheets: Sheets,\n\t\t\tSheetNames: SheetNames,\n\t\t\tWorkbook: WB\n\t\t}/*:any*/);\n\t\tif(opts.bookSheets) delete /*::(*/out/*:: :any)*/.Sheets;\n\t\treturn out;\n}\n\nfunction parse_ods(zip/*:ZIPFile*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\topts = opts || ({}/*:any*/);\n\tif(safegetzipfile(zip, 'META-INF/manifest.xml')) parse_manifest(getzipdata(zip, 'META-INF/manifest.xml'), opts);\n\tvar content = getzipstr(zip, 'content.xml');\n\tif(!content) throw new Error(\"Missing content.xml in ODS / UOF file\");\n\tvar wb = parse_content_xml(utf8read(content), opts);\n\tif(safegetzipfile(zip, 'meta.xml')) wb.Props = parse_core_props(getzipdata(zip, 'meta.xml'));\n\treturn wb;\n}\nfunction parse_fods(data/*:string*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\treturn parse_content_xml(data, opts);\n}\n\n/* OpenDocument */\nvar write_styles_ods/*:{(wb:any, opts:any):string}*/ = /* @__PURE__ */(function() {\n\tvar master_styles = [\n\t\t'<office:master-styles>',\n\t\t\t'<style:master-page style:name=\"mp1\" style:page-layout-name=\"mp1\">',\n\t\t\t\t'<style:header/>',\n\t\t\t\t'<style:header-left style:display=\"false\"/>',\n\t\t\t\t'<style:footer/>',\n\t\t\t\t'<style:footer-left style:display=\"false\"/>',\n\t\t\t'</style:master-page>',\n\t\t'</office:master-styles>'\n\t].join(\"\");\n\n\tvar payload = '<office:document-styles ' + wxt_helper({\n\t\t'xmlns:office': \"urn:oasis:names:tc:opendocument:xmlns:office:1.0\",\n\t\t'xmlns:table': \"urn:oasis:names:tc:opendocument:xmlns:table:1.0\",\n\t\t'xmlns:style': \"urn:oasis:names:tc:opendocument:xmlns:style:1.0\",\n\t\t'xmlns:text': \"urn:oasis:names:tc:opendocument:xmlns:text:1.0\",\n\t\t'xmlns:draw': \"urn:oasis:names:tc:opendocument:xmlns:drawing:1.0\",\n\t\t'xmlns:fo': \"urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0\",\n\t\t'xmlns:xlink': \"http://www.w3.org/1999/xlink\",\n\t\t'xmlns:dc': \"http://purl.org/dc/elements/1.1/\",\n\t\t'xmlns:number': \"urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0\",\n\t\t'xmlns:svg': \"urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0\",\n\t\t'xmlns:of': \"urn:oasis:names:tc:opendocument:xmlns:of:1.2\",\n\t\t'office:version': \"1.2\"\n\t}) + '>' + master_styles + '</office:document-styles>';\n\n\treturn function wso(/*::wb, opts*/) {\n\t\treturn XML_HEADER + payload;\n\t};\n})();\nvar write_content_ods/*:{(wb:any, opts:any):string}*/ = /* @__PURE__ */(function() {\n\t/* 6.1.2 White Space Characters */\n\tvar write_text_p = function(text/*:string*/)/*:string*/ {\n\t\treturn escapexml(text)\n\t\t\t.replace(/ +/g, function($$){return '<text:s text:c=\"'+$$.length+'\"/>';})\n\t\t\t.replace(/\\t/g, \"<text:tab/>\")\n\t\t\t.replace(/\\n/g, \"</text:p><text:p>\")\n\t\t\t.replace(/^ /, \"<text:s/>\").replace(/ $/, \"<text:s/>\");\n\t};\n\n\tvar null_cell_xml = ' <table:table-cell />\\n';\n\tvar covered_cell_xml = ' <table:covered-table-cell/>\\n';\n\tvar write_ws = function(ws, wb/*:Workbook*/, i/*:number*//*::, opts*/)/*:string*/ {\n\t\t/* Section 9 Tables */\n\t\tvar o/*:Array<string>*/ = [];\n\t\to.push(' <table:table table:name=\"' + escapexml(wb.SheetNames[i]) + '\" table:style-name=\"ta1\">\\n');\n\t\tvar R=0,C=0, range = decode_range(ws['!ref']||\"A1\");\n\t\tvar marr/*:Array<Range>*/ = ws['!merges'] || [], mi = 0;\n\t\tvar dense = Array.isArray(ws);\n\t\tif(ws[\"!cols\"]) {\n\t\t\tfor(C = 0; C <= range.e.c; ++C) o.push(' <table:table-column' + (ws[\"!cols\"][C] ? ' table:style-name=\"co' + ws[\"!cols\"][C].ods + '\"' : '') + '></table:table-column>\\n');\n\t\t}\n\t\tvar H = \"\", ROWS = ws[\"!rows\"]||[];\n\t\tfor(R = 0; R < range.s.r; ++R) {\n\t\t\tH = ROWS[R] ? ' table:style-name=\"ro' + ROWS[R].ods + '\"' : \"\";\n\t\t\to.push(' <table:table-row' + H + '></table:table-row>\\n');\n\t\t}\n\t\tfor(; R <= range.e.r; ++R) {\n\t\t\tH = ROWS[R] ? ' table:style-name=\"ro' + ROWS[R].ods + '\"' : \"\";\n\t\t\to.push(' <table:table-row' + H + '>\\n');\n\t\t\tfor(C=0; C < range.s.c; ++C) o.push(null_cell_xml);\n\t\t\tfor(; C <= range.e.c; ++C) {\n\t\t\t\tvar skip = false, ct = {}, textp = \"\";\n\t\t\t\tfor(mi = 0; mi != marr.length; ++mi) {\n\t\t\t\t\tif(marr[mi].s.c > C) continue;\n\t\t\t\t\tif(marr[mi].s.r > R) continue;\n\t\t\t\t\tif(marr[mi].e.c < C) continue;\n\t\t\t\t\tif(marr[mi].e.r < R) continue;\n\t\t\t\t\tif(marr[mi].s.c != C || marr[mi].s.r != R) skip = true;\n\t\t\t\t\tct['table:number-columns-spanned'] = (marr[mi].e.c - marr[mi].s.c + 1);\n\t\t\t\t\tct['table:number-rows-spanned'] = (marr[mi].e.r - marr[mi].s.r + 1);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tif(skip) { o.push(covered_cell_xml); continue; }\n\t\t\t\tvar ref = encode_cell({r:R, c:C}), cell = dense ? (ws[R]||[])[C]: ws[ref];\n\t\t\t\tif(cell && cell.f) {\n\t\t\t\t\tct['table:formula'] = escapexml(csf_to_ods_formula(cell.f));\n\t\t\t\t\tif(cell.F) {\n\t\t\t\t\t\tif(cell.F.slice(0, ref.length) == ref) {\n\t\t\t\t\t\t\tvar _Fref = decode_range(cell.F);\n\t\t\t\t\t\t\tct['table:number-matrix-columns-spanned'] = (_Fref.e.c - _Fref.s.c + 1);\n\t\t\t\t\t\t\tct['table:number-matrix-rows-spanned'] = (_Fref.e.r - _Fref.s.r + 1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif(!cell) { o.push(null_cell_xml); continue; }\n\t\t\t\tswitch(cell.t) {\n\t\t\t\t\tcase 'b':\n\t\t\t\t\t\ttextp = (cell.v ? 'TRUE' : 'FALSE');\n\t\t\t\t\t\tct['office:value-type'] = \"boolean\";\n\t\t\t\t\t\tct['office:boolean-value'] = (cell.v ? 'true' : 'false');\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'n':\n\t\t\t\t\t\ttextp = (cell.w||String(cell.v||0));\n\t\t\t\t\t\tct['office:value-type'] = \"float\";\n\t\t\t\t\t\tct['office:value'] = (cell.v||0);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 's': case 'str':\n\t\t\t\t\t\ttextp = cell.v == null ? \"\" : cell.v;\n\t\t\t\t\t\tct['office:value-type'] = \"string\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'd':\n\t\t\t\t\t\ttextp = (cell.w||(parseDate(cell.v).toISOString()));\n\t\t\t\t\t\tct['office:value-type'] = \"date\";\n\t\t\t\t\t\tct['office:date-value'] = (parseDate(cell.v).toISOString());\n\t\t\t\t\t\tct['table:style-name'] = \"ce1\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t//case 'e':\n\t\t\t\t\tdefault: o.push(null_cell_xml); continue;\n\t\t\t\t}\n\t\t\t\tvar text_p = write_text_p(textp);\n\t\t\t\tif(cell.l && cell.l.Target) {\n\t\t\t\t\tvar _tgt = cell.l.Target;\n\t\t\t\t\t_tgt = _tgt.charAt(0) == \"#\" ? \"#\" + csf_to_ods_3D(_tgt.slice(1)) : _tgt;\n\t\t\t\t\t// TODO: choose correct parent path format based on link delimiters\n\t\t\t\t\tif(_tgt.charAt(0) != \"#\" && !_tgt.match(/^\\w+:/)) _tgt = '../' + _tgt;\n\t\t\t\t\ttext_p = writextag('text:a', text_p, {'xlink:href': _tgt.replace(/&/g, \"&amp;\")});\n\t\t\t\t}\n\t\t\t\to.push(' ' + writextag('table:table-cell', writextag('text:p', text_p, {}), ct) + '\\n');\n\t\t\t}\n\t\t\to.push(' </table:table-row>\\n');\n\t\t}\n\t\to.push(' </table:table>\\n');\n\t\treturn o.join(\"\");\n\t};\n\n\tvar write_automatic_styles_ods = function(o/*:Array<string>*/, wb) {\n\t\to.push(' <office:automatic-styles>\\n');\n\n\t\to.push(' <number:date-style style:name=\"N37\" number:automatic-order=\"true\">\\n');\n\t\to.push(' <number:month number:style=\"long\"/>\\n');\n\t\to.push(' <number:text>/</number:text>\\n');\n\t\to.push(' <number:day number:style=\"long\"/>\\n');\n\t\to.push(' <number:text>/</number:text>\\n');\n\t\to.push(' <number:year/>\\n');\n\t\to.push(' </number:date-style>\\n');\n\n\t\t/* column styles */\n\t\tvar cidx = 0;\n\t\twb.SheetNames.map(function(n) { return wb.Sheets[n]; }).forEach(function(ws) {\n\t\t\tif(!ws) return;\n\t\t\tif(ws[\"!cols\"]) {\n\t\t\t\tfor(var C = 0; C < ws[\"!cols\"].length; ++C) if(ws[\"!cols\"][C]) {\n\t\t\t\t\tvar colobj = ws[\"!cols\"][C];\n\t\t\t\t\tif(colobj.width == null && colobj.wpx == null && colobj.wch == null) continue;\n\t\t\t\t\tprocess_col(colobj);\n\t\t\t\t\tcolobj.ods = cidx;\n\t\t\t\t\tvar w = ws[\"!cols\"][C].wpx + \"px\";\n\t\t\t\t\to.push(' <style:style style:name=\"co' + cidx + '\" style:family=\"table-column\">\\n');\n\t\t\t\t\to.push(' <style:table-column-properties fo:break-before=\"auto\" style:column-width=\"' + w + '\"/>\\n');\n\t\t\t\t\to.push(' </style:style>\\n');\n\t\t\t\t\t++cidx;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\t/* row styles */\n\t\tvar ridx = 0;\n\t\twb.SheetNames.map(function(n) { return wb.Sheets[n]; }).forEach(function(ws) {\n\t\t\tif(!ws) return;\n\t\t\tif(ws[\"!rows\"]) {\n\t\t\t\tfor(var R = 0; R < ws[\"!rows\"].length; ++R) if(ws[\"!rows\"][R]) {\n\t\t\t\t\tws[\"!rows\"][R].ods = ridx;\n\t\t\t\t\tvar h = ws[\"!rows\"][R].hpx + \"px\";\n\t\t\t\t\to.push(' <style:style style:name=\"ro' + ridx + '\" style:family=\"table-row\">\\n');\n\t\t\t\t\to.push(' <style:table-row-properties fo:break-before=\"auto\" style:row-height=\"' + h + '\"/>\\n');\n\t\t\t\t\to.push(' </style:style>\\n');\n\t\t\t\t\t++ridx;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\t/* table */\n\t\to.push(' <style:style style:name=\"ta1\" style:family=\"table\" style:master-page-name=\"mp1\">\\n');\n\t\to.push(' <style:table-properties table:display=\"true\" style:writing-mode=\"lr-tb\"/>\\n');\n\t\to.push(' </style:style>\\n');\n\n\t\t/* table cells, text */\n\t\to.push(' <style:style style:name=\"ce1\" style:family=\"table-cell\" style:parent-style-name=\"Default\" style:data-style-name=\"N37\"/>\\n');\n\n\t\t/* page-layout */\n\n\t\to.push(' </office:automatic-styles>\\n');\n\t};\n\n\treturn function wcx(wb, opts) {\n\t\tvar o = [XML_HEADER];\n\t\t/* 3.1.3.2 */\n\t\tvar attr = wxt_helper({\n\t\t\t'xmlns:office': \"urn:oasis:names:tc:opendocument:xmlns:office:1.0\",\n\t\t\t'xmlns:table': \"urn:oasis:names:tc:opendocument:xmlns:table:1.0\",\n\t\t\t'xmlns:style': \"urn:oasis:names:tc:opendocument:xmlns:style:1.0\",\n\t\t\t'xmlns:text': \"urn:oasis:names:tc:opendocument:xmlns:text:1.0\",\n\t\t\t'xmlns:draw': \"urn:oasis:names:tc:opendocument:xmlns:drawing:1.0\",\n\t\t\t'xmlns:fo': \"urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0\",\n\t\t\t'xmlns:xlink': \"http://www.w3.org/1999/xlink\",\n\t\t\t'xmlns:dc': \"http://purl.org/dc/elements/1.1/\",\n\t\t\t'xmlns:meta': \"urn:oasis:names:tc:opendocument:xmlns:meta:1.0\",\n\t\t\t'xmlns:number': \"urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0\",\n\t\t\t'xmlns:presentation': \"urn:oasis:names:tc:opendocument:xmlns:presentation:1.0\",\n\t\t\t'xmlns:svg': \"urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0\",\n\t\t\t'xmlns:chart': \"urn:oasis:names:tc:opendocument:xmlns:chart:1.0\",\n\t\t\t'xmlns:dr3d': \"urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0\",\n\t\t\t'xmlns:math': \"http://www.w3.org/1998/Math/MathML\",\n\t\t\t'xmlns:form': \"urn:oasis:names:tc:opendocument:xmlns:form:1.0\",\n\t\t\t'xmlns:script': \"urn:oasis:names:tc:opendocument:xmlns:script:1.0\",\n\t\t\t'xmlns:ooo': \"http://openoffice.org/2004/office\",\n\t\t\t'xmlns:ooow': \"http://openoffice.org/2004/writer\",\n\t\t\t'xmlns:oooc': \"http://openoffice.org/2004/calc\",\n\t\t\t'xmlns:dom': \"http://www.w3.org/2001/xml-events\",\n\t\t\t'xmlns:xforms': \"http://www.w3.org/2002/xforms\",\n\t\t\t'xmlns:xsd': \"http://www.w3.org/2001/XMLSchema\",\n\t\t\t'xmlns:xsi': \"http://www.w3.org/2001/XMLSchema-instance\",\n\t\t\t'xmlns:sheet': \"urn:oasis:names:tc:opendocument:sh33tjs:1.0\",\n\t\t\t'xmlns:rpt': \"http://openoffice.org/2005/report\",\n\t\t\t'xmlns:of': \"urn:oasis:names:tc:opendocument:xmlns:of:1.2\",\n\t\t\t'xmlns:xhtml': \"http://www.w3.org/1999/xhtml\",\n\t\t\t'xmlns:grddl': \"http://www.w3.org/2003/g/data-view#\",\n\t\t\t'xmlns:tableooo': \"http://openoffice.org/2009/table\",\n\t\t\t'xmlns:drawooo': \"http://openoffice.org/2010/draw\",\n\t\t\t'xmlns:calcext': \"urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0\",\n\t\t\t'xmlns:loext': \"urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0\",\n\t\t\t'xmlns:field': \"urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0\",\n\t\t\t'xmlns:formx': \"urn:openoffice:names:experimental:ooxml-odf-interop:xmlns:form:1.0\",\n\t\t\t'xmlns:css3t': \"http://www.w3.org/TR/css3-text/\",\n\t\t\t'office:version': \"1.2\"\n\t\t});\n\n\t\tvar fods = wxt_helper({\n\t\t\t'xmlns:config': \"urn:oasis:names:tc:opendocument:xmlns:config:1.0\",\n\t\t\t'office:mimetype': \"application/vnd.oasis.opendocument.spreadsheet\"\n\t\t});\n\n\t\tif(opts.bookType == \"fods\") {\n\t\t\to.push('<office:document' + attr + fods + '>\\n');\n\t\t\to.push(write_meta_ods().replace(/office:document-meta/g, \"office:meta\"));\n\t\t\t// TODO: settings (equiv of settings.xml for ODS)\n\t\t} else o.push('<office:document-content' + attr + '>\\n');\n\t\t// o.push(' <office:scripts/>\\n');\n\t\twrite_automatic_styles_ods(o, wb);\n\t\to.push(' <office:body>\\n');\n\t\to.push(' <office:spreadsheet>\\n');\n\t\tfor(var i = 0; i != wb.SheetNames.length; ++i) o.push(write_ws(wb.Sheets[wb.SheetNames[i]], wb, i, opts));\n\t\to.push(' </office:spreadsheet>\\n');\n\t\to.push(' </office:body>\\n');\n\t\tif(opts.bookType == \"fods\") o.push('</office:document>');\n\t\telse o.push('</office:document-content>');\n\t\treturn o.join(\"\");\n\t};\n})();\n\nfunction write_ods(wb/*:any*/, opts/*:any*/) {\n\tif(opts.bookType == \"fods\") return write_content_ods(wb, opts);\n\n\tvar zip = zip_new();\n\tvar f = \"\";\n\n\tvar manifest/*:Array<Array<string> >*/ = [];\n\tvar rdf/*:Array<[string, string]>*/ = [];\n\n\t/* Part 3 Section 3.3 MIME Media Type */\n\tf = \"mimetype\";\n\tzip_add_file(zip, f, \"application/vnd.oasis.opendocument.spreadsheet\");\n\n\t/* Part 1 Section 2.2 Documents */\n\tf = \"content.xml\";\n\tzip_add_file(zip, f, write_content_ods(wb, opts));\n\tmanifest.push([f, \"text/xml\"]);\n\trdf.push([f, \"ContentFile\"]);\n\n\t/* TODO: these are hard-coded styles to satiate excel */\n\tf = \"styles.xml\";\n\tzip_add_file(zip, f, write_styles_ods(wb, opts));\n\tmanifest.push([f, \"text/xml\"]);\n\trdf.push([f, \"StylesFile\"]);\n\n\t/* TODO: this is hard-coded to satiate excel */\n\tf = \"meta.xml\";\n\tzip_add_file(zip, f, XML_HEADER + write_meta_ods(/*::wb, opts*/));\n\tmanifest.push([f, \"text/xml\"]);\n\trdf.push([f, \"MetadataFile\"]);\n\n\t/* Part 3 Section 6 Metadata Manifest File */\n\tf = \"manifest.rdf\";\n\tzip_add_file(zip, f, write_rdf(rdf/*, opts*/));\n\tmanifest.push([f, \"application/rdf+xml\"]);\n\n\t/* Part 3 Section 4 Manifest File */\n\tf = \"META-INF/manifest.xml\";\n\tzip_add_file(zip, f, write_manifest(manifest/*, opts*/));\n\n\treturn zip;\n}\n\n/*! sheetjs (C) 2013-present SheetJS -- http://sheetjs.com */\nfunction u8_to_dataview(array) {\n return new DataView(array.buffer, array.byteOffset, array.byteLength);\n}\nfunction u8str(u8) {\n return typeof TextDecoder != \"undefined\" ? new TextDecoder().decode(u8) : utf8read(a2s(u8));\n}\nfunction stru8(str) {\n return typeof TextEncoder != \"undefined\" ? new TextEncoder().encode(str) : s2a(utf8write(str));\n}\nfunction u8contains(body, search) {\n outer:\n for (var L = 0; L <= body.length - search.length; ++L) {\n for (var j = 0; j < search.length; ++j)\n if (body[L + j] != search[j])\n continue outer;\n return true;\n }\n return false;\n}\nfunction u8concat(u8a) {\n var len = u8a.reduce(function(acc, x) {\n return acc + x.length;\n }, 0);\n var out = new Uint8Array(len);\n var off = 0;\n u8a.forEach(function(u8) {\n out.set(u8, off);\n off += u8.length;\n });\n return out;\n}\nfunction popcnt(x) {\n x -= x >> 1 & 1431655765;\n x = (x & 858993459) + (x >> 2 & 858993459);\n return (x + (x >> 4) & 252645135) * 16843009 >>> 24;\n}\nfunction readDecimal128LE(buf, offset) {\n var exp = (buf[offset + 15] & 127) << 7 | buf[offset + 14] >> 1;\n var mantissa = buf[offset + 14] & 1;\n for (var j = offset + 13; j >= offset; --j)\n mantissa = mantissa * 256 + buf[j];\n return (buf[offset + 15] & 128 ? -mantissa : mantissa) * Math.pow(10, exp - 6176);\n}\nfunction writeDecimal128LE(buf, offset, value) {\n var exp = Math.floor(value == 0 ? 0 : Math.LOG10E * Math.log(Math.abs(value))) + 6176 - 20;\n var mantissa = value / Math.pow(10, exp - 6176);\n buf[offset + 15] |= exp >> 7;\n buf[offset + 14] |= (exp & 127) << 1;\n for (var i = 0; mantissa >= 1; ++i, mantissa /= 256)\n buf[offset + i] = mantissa & 255;\n buf[offset + 15] |= value >= 0 ? 0 : 128;\n}\nfunction parse_varint49(buf, ptr) {\n var l = ptr ? ptr[0] : 0;\n var usz = buf[l] & 127;\n varint:\n if (buf[l++] >= 128) {\n usz |= (buf[l] & 127) << 7;\n if (buf[l++] < 128)\n break varint;\n usz |= (buf[l] & 127) << 14;\n if (buf[l++] < 128)\n break varint;\n usz |= (buf[l] & 127) << 21;\n if (buf[l++] < 128)\n break varint;\n usz += (buf[l] & 127) * Math.pow(2, 28);\n ++l;\n if (buf[l++] < 128)\n break varint;\n usz += (buf[l] & 127) * Math.pow(2, 35);\n ++l;\n if (buf[l++] < 128)\n break varint;\n usz += (buf[l] & 127) * Math.pow(2, 42);\n ++l;\n if (buf[l++] < 128)\n break varint;\n }\n if (ptr)\n ptr[0] = l;\n return usz;\n}\nfunction write_varint49(v) {\n var usz = new Uint8Array(7);\n usz[0] = v & 127;\n var L = 1;\n sz:\n if (v > 127) {\n usz[L - 1] |= 128;\n usz[L] = v >> 7 & 127;\n ++L;\n if (v <= 16383)\n break sz;\n usz[L - 1] |= 128;\n usz[L] = v >> 14 & 127;\n ++L;\n if (v <= 2097151)\n break sz;\n usz[L - 1] |= 128;\n usz[L] = v >> 21 & 127;\n ++L;\n if (v <= 268435455)\n break sz;\n usz[L - 1] |= 128;\n usz[L] = v / 256 >>> 21 & 127;\n ++L;\n if (v <= 34359738367)\n break sz;\n usz[L - 1] |= 128;\n usz[L] = v / 65536 >>> 21 & 127;\n ++L;\n if (v <= 4398046511103)\n break sz;\n usz[L - 1] |= 128;\n usz[L] = v / 16777216 >>> 21 & 127;\n ++L;\n }\n return usz.slice(0, L);\n}\nfunction varint_to_i32(buf) {\n var l = 0, i32 = buf[l] & 127;\n varint:\n if (buf[l++] >= 128) {\n i32 |= (buf[l] & 127) << 7;\n if (buf[l++] < 128)\n break varint;\n i32 |= (buf[l] & 127) << 14;\n if (buf[l++] < 128)\n break varint;\n i32 |= (buf[l] & 127) << 21;\n if (buf[l++] < 128)\n break varint;\n i32 |= (buf[l] & 127) << 28;\n }\n return i32;\n}\nfunction parse_shallow(buf) {\n var out = [], ptr = [0];\n while (ptr[0] < buf.length) {\n var off = ptr[0];\n var num = parse_varint49(buf, ptr);\n var type = num & 7;\n num = Math.floor(num / 8);\n var len = 0;\n var res;\n if (num == 0)\n break;\n switch (type) {\n case 0:\n {\n var l = ptr[0];\n while (buf[ptr[0]++] >= 128)\n ;\n res = buf.slice(l, ptr[0]);\n }\n break;\n case 5:\n len = 4;\n res = buf.slice(ptr[0], ptr[0] + len);\n ptr[0] += len;\n break;\n case 1:\n len = 8;\n res = buf.slice(ptr[0], ptr[0] + len);\n ptr[0] += len;\n break;\n case 2:\n len = parse_varint49(buf, ptr);\n res = buf.slice(ptr[0], ptr[0] + len);\n ptr[0] += len;\n break;\n case 3:\n case 4:\n default:\n throw new Error(\"PB Type \".concat(type, \" for Field \").concat(num, \" at offset \").concat(off));\n }\n var v = { data: res, type: type };\n if (out[num] == null)\n out[num] = [v];\n else\n out[num].push(v);\n }\n return out;\n}\nfunction write_shallow(proto) {\n var out = [];\n proto.forEach(function(field, idx) {\n field.forEach(function(item) {\n if (!item.data)\n return;\n out.push(write_varint49(idx * 8 + item.type));\n if (item.type == 2)\n out.push(write_varint49(item.data.length));\n out.push(item.data);\n });\n });\n return u8concat(out);\n}\nfunction mappa(data, cb) {\n return (data == null ? void 0 : data.map(function(d) {\n return cb(d.data);\n })) || [];\n}\nfunction parse_iwa_file(buf) {\n var _a;\n var out = [], ptr = [0];\n while (ptr[0] < buf.length) {\n var len = parse_varint49(buf, ptr);\n var ai = parse_shallow(buf.slice(ptr[0], ptr[0] + len));\n ptr[0] += len;\n var res = {\n id: varint_to_i32(ai[1][0].data),\n messages: []\n };\n ai[2].forEach(function(b) {\n var mi = parse_shallow(b.data);\n var fl = varint_to_i32(mi[3][0].data);\n res.messages.push({\n meta: mi,\n data: buf.slice(ptr[0], ptr[0] + fl)\n });\n ptr[0] += fl;\n });\n if ((_a = ai[3]) == null ? void 0 : _a[0])\n res.merge = varint_to_i32(ai[3][0].data) >>> 0 > 0;\n out.push(res);\n }\n return out;\n}\nfunction write_iwa_file(ias) {\n var bufs = [];\n ias.forEach(function(ia) {\n var ai = [];\n ai[1] = [{ data: write_varint49(ia.id), type: 0 }];\n ai[2] = [];\n if (ia.merge != null)\n ai[3] = [{ data: write_varint49(+!!ia.merge), type: 0 }];\n var midata = [];\n ia.messages.forEach(function(mi) {\n midata.push(mi.data);\n mi.meta[3] = [{ type: 0, data: write_varint49(mi.data.length) }];\n ai[2].push({ data: write_shallow(mi.meta), type: 2 });\n });\n var aipayload = write_shallow(ai);\n bufs.push(write_varint49(aipayload.length));\n bufs.push(aipayload);\n midata.forEach(function(mid) {\n return bufs.push(mid);\n });\n });\n return u8concat(bufs);\n}\nfunction parse_snappy_chunk(type, buf) {\n if (type != 0)\n throw new Error(\"Unexpected Snappy chunk type \".concat(type));\n var ptr = [0];\n var usz = parse_varint49(buf, ptr);\n var chunks = [];\n while (ptr[0] < buf.length) {\n var tag = buf[ptr[0]] & 3;\n if (tag == 0) {\n var len = buf[ptr[0]++] >> 2;\n if (len < 60)\n ++len;\n else {\n var c = len - 59;\n len = buf[ptr[0]];\n if (c > 1)\n len |= buf[ptr[0] + 1] << 8;\n if (c > 2)\n len |= buf[ptr[0] + 2] << 16;\n if (c > 3)\n len |= buf[ptr[0] + 3] << 24;\n len >>>= 0;\n len++;\n ptr[0] += c;\n }\n chunks.push(buf.slice(ptr[0], ptr[0] + len));\n ptr[0] += len;\n continue;\n } else {\n var offset = 0, length = 0;\n if (tag == 1) {\n length = (buf[ptr[0]] >> 2 & 7) + 4;\n offset = (buf[ptr[0]++] & 224) << 3;\n offset |= buf[ptr[0]++];\n } else {\n length = (buf[ptr[0]++] >> 2) + 1;\n if (tag == 2) {\n offset = buf[ptr[0]] | buf[ptr[0] + 1] << 8;\n ptr[0] += 2;\n } else {\n offset = (buf[ptr[0]] | buf[ptr[0] + 1] << 8 | buf[ptr[0] + 2] << 16 | buf[ptr[0] + 3] << 24) >>> 0;\n ptr[0] += 4;\n }\n }\n chunks = [u8concat(chunks)];\n if (offset == 0)\n throw new Error(\"Invalid offset 0\");\n if (offset > chunks[0].length)\n throw new Error(\"Invalid offset beyond length\");\n if (length >= offset) {\n chunks.push(chunks[0].slice(-offset));\n length -= offset;\n while (length >= chunks[chunks.length - 1].length) {\n chunks.push(chunks[chunks.length - 1]);\n length -= chunks[chunks.length - 1].length;\n }\n }\n chunks.push(chunks[0].slice(-offset, -offset + length));\n }\n }\n var o = u8concat(chunks);\n if (o.length != usz)\n throw new Error(\"Unexpected length: \".concat(o.length, \" != \").concat(usz));\n return o;\n}\nfunction decompress_iwa_file(buf) {\n var out = [];\n var l = 0;\n while (l < buf.length) {\n var t = buf[l++];\n var len = buf[l] | buf[l + 1] << 8 | buf[l + 2] << 16;\n l += 3;\n out.push(parse_snappy_chunk(t, buf.slice(l, l + len)));\n l += len;\n }\n if (l !== buf.length)\n throw new Error(\"data is not a valid framed stream!\");\n return u8concat(out);\n}\nfunction compress_iwa_file(buf) {\n var out = [];\n var l = 0;\n while (l < buf.length) {\n var c = Math.min(buf.length - l, 268435455);\n var frame = new Uint8Array(4);\n out.push(frame);\n var usz = write_varint49(c);\n var L = usz.length;\n out.push(usz);\n if (c <= 60) {\n L++;\n out.push(new Uint8Array([c - 1 << 2]));\n } else if (c <= 256) {\n L += 2;\n out.push(new Uint8Array([240, c - 1 & 255]));\n } else if (c <= 65536) {\n L += 3;\n out.push(new Uint8Array([244, c - 1 & 255, c - 1 >> 8 & 255]));\n } else if (c <= 16777216) {\n L += 4;\n out.push(new Uint8Array([248, c - 1 & 255, c - 1 >> 8 & 255, c - 1 >> 16 & 255]));\n } else if (c <= 4294967296) {\n L += 5;\n out.push(new Uint8Array([252, c - 1 & 255, c - 1 >> 8 & 255, c - 1 >> 16 & 255, c - 1 >>> 24 & 255]));\n }\n out.push(buf.slice(l, l + c));\n L += c;\n frame[0] = 0;\n frame[1] = L & 255;\n frame[2] = L >> 8 & 255;\n frame[3] = L >> 16 & 255;\n l += c;\n }\n return u8concat(out);\n}\nfunction parse_old_storage(buf, sst, rsst, v) {\n var dv = u8_to_dataview(buf);\n var flags = dv.getUint32(4, true);\n var data_offset = (v > 1 ? 12 : 8) + popcnt(flags & (v > 1 ? 3470 : 398)) * 4;\n var ridx = -1, sidx = -1, ieee = NaN, dt = new Date(2001, 0, 1);\n if (flags & 512) {\n ridx = dv.getUint32(data_offset, true);\n data_offset += 4;\n }\n data_offset += popcnt(flags & (v > 1 ? 12288 : 4096)) * 4;\n if (flags & 16) {\n sidx = dv.getUint32(data_offset, true);\n data_offset += 4;\n }\n if (flags & 32) {\n ieee = dv.getFloat64(data_offset, true);\n data_offset += 8;\n }\n if (flags & 64) {\n dt.setTime(dt.getTime() + dv.getFloat64(data_offset, true) * 1e3);\n data_offset += 8;\n }\n var ret;\n switch (buf[2]) {\n case 0:\n break;\n case 2:\n ret = { t: \"n\", v: ieee };\n break;\n case 3:\n ret = { t: \"s\", v: sst[sidx] };\n break;\n case 5:\n ret = { t: \"d\", v: dt };\n break;\n case 6:\n ret = { t: \"b\", v: ieee > 0 };\n break;\n case 7:\n ret = { t: \"n\", v: ieee / 86400 };\n break;\n case 8:\n ret = { t: \"e\", v: 0 };\n break;\n case 9:\n {\n if (ridx > -1)\n ret = { t: \"s\", v: rsst[ridx] };\n else if (sidx > -1)\n ret = { t: \"s\", v: sst[sidx] };\n else if (!isNaN(ieee))\n ret = { t: \"n\", v: ieee };\n else\n throw new Error(\"Unsupported cell type \".concat(buf.slice(0, 4)));\n }\n break;\n default:\n throw new Error(\"Unsupported cell type \".concat(buf.slice(0, 4)));\n }\n return ret;\n}\nfunction parse_new_storage(buf, sst, rsst) {\n var dv = u8_to_dataview(buf);\n var flags = dv.getUint32(8, true);\n var data_offset = 12;\n var ridx = -1, sidx = -1, d128 = NaN, ieee = NaN, dt = new Date(2001, 0, 1);\n if (flags & 1) {\n d128 = readDecimal128LE(buf, data_offset);\n data_offset += 16;\n }\n if (flags & 2) {\n ieee = dv.getFloat64(data_offset, true);\n data_offset += 8;\n }\n if (flags & 4) {\n dt.setTime(dt.getTime() + dv.getFloat64(data_offset, true) * 1e3);\n data_offset += 8;\n }\n if (flags & 8) {\n sidx = dv.getUint32(data_offset, true);\n data_offset += 4;\n }\n if (flags & 16) {\n ridx = dv.getUint32(data_offset, true);\n data_offset += 4;\n }\n var ret;\n switch (buf[1]) {\n case 0:\n break;\n case 2:\n ret = { t: \"n\", v: d128 };\n break;\n case 3:\n ret = { t: \"s\", v: sst[sidx] };\n break;\n case 5:\n ret = { t: \"d\", v: dt };\n break;\n case 6:\n ret = { t: \"b\", v: ieee > 0 };\n break;\n case 7:\n ret = { t: \"n\", v: ieee / 86400 };\n break;\n case 8:\n ret = { t: \"e\", v: 0 };\n break;\n case 9:\n {\n if (ridx > -1)\n ret = { t: \"s\", v: rsst[ridx] };\n else\n throw new Error(\"Unsupported cell type \".concat(buf[1], \" : \").concat(flags & 31, \" : \").concat(buf.slice(0, 4)));\n }\n break;\n case 10:\n ret = { t: \"n\", v: d128 };\n break;\n default:\n throw new Error(\"Unsupported cell type \".concat(buf[1], \" : \").concat(flags & 31, \" : \").concat(buf.slice(0, 4)));\n }\n return ret;\n}\nfunction write_new_storage(cell, sst) {\n var out = new Uint8Array(32), dv = u8_to_dataview(out), l = 12, flags = 0;\n out[0] = 5;\n switch (cell.t) {\n case \"n\":\n out[1] = 2;\n writeDecimal128LE(out, l, cell.v);\n flags |= 1;\n l += 16;\n break;\n case \"b\":\n out[1] = 6;\n dv.setFloat64(l, cell.v ? 1 : 0, true);\n flags |= 2;\n l += 8;\n break;\n case \"s\":\n if (sst.indexOf(cell.v) == -1)\n throw new Error(\"Value \".concat(cell.v, \" missing from SST!\"));\n out[1] = 3;\n dv.setUint32(l, sst.indexOf(cell.v), true);\n flags |= 8;\n l += 4;\n break;\n default:\n throw \"unsupported cell type \" + cell.t;\n }\n dv.setUint32(8, flags, true);\n return out.slice(0, l);\n}\nfunction write_old_storage(cell, sst) {\n var out = new Uint8Array(32), dv = u8_to_dataview(out), l = 12, flags = 0;\n out[0] = 3;\n switch (cell.t) {\n case \"n\":\n out[2] = 2;\n dv.setFloat64(l, cell.v, true);\n flags |= 32;\n l += 8;\n break;\n case \"b\":\n out[2] = 6;\n dv.setFloat64(l, cell.v ? 1 : 0, true);\n flags |= 32;\n l += 8;\n break;\n case \"s\":\n if (sst.indexOf(cell.v) == -1)\n throw new Error(\"Value \".concat(cell.v, \" missing from SST!\"));\n out[2] = 3;\n dv.setUint32(l, sst.indexOf(cell.v), true);\n flags |= 16;\n l += 4;\n break;\n default:\n throw \"unsupported cell type \" + cell.t;\n }\n dv.setUint32(4, flags, true);\n return out.slice(0, l);\n}\nfunction parse_cell_storage(buf, sst, rsst) {\n switch (buf[0]) {\n case 0:\n case 1:\n case 2:\n case 3:\n return parse_old_storage(buf, sst, rsst, buf[0]);\n case 5:\n return parse_new_storage(buf, sst, rsst);\n default:\n throw new Error(\"Unsupported payload version \".concat(buf[0]));\n }\n}\nfunction parse_TSP_Reference(buf) {\n var pb = parse_shallow(buf);\n return parse_varint49(pb[1][0].data);\n}\nfunction write_TSP_Reference(idx) {\n var out = [];\n out[1] = [{ type: 0, data: write_varint49(idx) }];\n return write_shallow(out);\n}\nfunction parse_TST_TableDataList(M, root) {\n var pb = parse_shallow(root.data);\n var type = varint_to_i32(pb[1][0].data);\n var entries = pb[3];\n var data = [];\n (entries || []).forEach(function(entry) {\n var le = parse_shallow(entry.data);\n var key = varint_to_i32(le[1][0].data) >>> 0;\n switch (type) {\n case 1:\n data[key] = u8str(le[3][0].data);\n break;\n case 8:\n {\n var rt = M[parse_TSP_Reference(le[9][0].data)][0];\n var rtp = parse_shallow(rt.data);\n var rtpref = M[parse_TSP_Reference(rtp[1][0].data)][0];\n var mtype = varint_to_i32(rtpref.meta[1][0].data);\n if (mtype != 2001)\n throw new Error(\"2000 unexpected reference to \".concat(mtype));\n var tswpsa = parse_shallow(rtpref.data);\n data[key] = tswpsa[3].map(function(x) {\n return u8str(x.data);\n }).join(\"\");\n }\n break;\n }\n });\n return data;\n}\nfunction parse_TST_TileRowInfo(u8, type) {\n var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n;\n var pb = parse_shallow(u8);\n var R = varint_to_i32(pb[1][0].data) >>> 0;\n var cnt = varint_to_i32(pb[2][0].data) >>> 0;\n var wide_offsets = ((_b = (_a = pb[8]) == null ? void 0 : _a[0]) == null ? void 0 : _b.data) && varint_to_i32(pb[8][0].data) > 0 || false;\n var used_storage_u8, used_storage;\n if (((_d = (_c = pb[7]) == null ? void 0 : _c[0]) == null ? void 0 : _d.data) && type != 0) {\n used_storage_u8 = (_f = (_e = pb[7]) == null ? void 0 : _e[0]) == null ? void 0 : _f.data;\n used_storage = (_h = (_g = pb[6]) == null ? void 0 : _g[0]) == null ? void 0 : _h.data;\n } else if (((_j = (_i = pb[4]) == null ? void 0 : _i[0]) == null ? void 0 : _j.data) && type != 1) {\n used_storage_u8 = (_l = (_k = pb[4]) == null ? void 0 : _k[0]) == null ? void 0 : _l.data;\n used_storage = (_n = (_m = pb[3]) == null ? void 0 : _m[0]) == null ? void 0 : _n.data;\n } else\n throw \"NUMBERS Tile missing \".concat(type, \" cell storage\");\n var width = wide_offsets ? 4 : 1;\n var used_storage_offsets = u8_to_dataview(used_storage_u8);\n var offsets = [];\n for (var C = 0; C < used_storage_u8.length / 2; ++C) {\n var off = used_storage_offsets.getUint16(C * 2, true);\n if (off < 65535)\n offsets.push([C, off]);\n }\n if (offsets.length != cnt)\n throw \"Expected \".concat(cnt, \" cells, found \").concat(offsets.length);\n var cells = [];\n for (C = 0; C < offsets.length - 1; ++C)\n cells[offsets[C][0]] = used_storage.subarray(offsets[C][1] * width, offsets[C + 1][1] * width);\n if (offsets.length >= 1)\n cells[offsets[offsets.length - 1][0]] = used_storage.subarray(offsets[offsets.length - 1][1] * width);\n return { R: R, cells: cells };\n}\nfunction parse_TST_Tile(M, root) {\n var _a;\n var pb = parse_shallow(root.data);\n var storage = ((_a = pb == null ? void 0 : pb[7]) == null ? void 0 : _a[0]) ? varint_to_i32(pb[7][0].data) >>> 0 > 0 ? 1 : 0 : -1;\n var ri = mappa(pb[5], function(u8) {\n return parse_TST_TileRowInfo(u8, storage);\n });\n return {\n nrows: varint_to_i32(pb[4][0].data) >>> 0,\n data: ri.reduce(function(acc, x) {\n if (!acc[x.R])\n acc[x.R] = [];\n x.cells.forEach(function(cell, C) {\n if (acc[x.R][C])\n throw new Error(\"Duplicate cell r=\".concat(x.R, \" c=\").concat(C));\n acc[x.R][C] = cell;\n });\n return acc;\n }, [])\n };\n}\nfunction parse_TST_TableModelArchive(M, root, ws) {\n var _a;\n var pb = parse_shallow(root.data);\n var range = { s: { r: 0, c: 0 }, e: { r: 0, c: 0 } };\n range.e.r = (varint_to_i32(pb[6][0].data) >>> 0) - 1;\n if (range.e.r < 0)\n throw new Error(\"Invalid row varint \".concat(pb[6][0].data));\n range.e.c = (varint_to_i32(pb[7][0].data) >>> 0) - 1;\n if (range.e.c < 0)\n throw new Error(\"Invalid col varint \".concat(pb[7][0].data));\n ws[\"!ref\"] = encode_range(range);\n var store = parse_shallow(pb[4][0].data);\n var sst = parse_TST_TableDataList(M, M[parse_TSP_Reference(store[4][0].data)][0]);\n var rsst = ((_a = store[17]) == null ? void 0 : _a[0]) ? parse_TST_TableDataList(M, M[parse_TSP_Reference(store[17][0].data)][0]) : [];\n var tile = parse_shallow(store[3][0].data);\n var _R = 0;\n tile[1].forEach(function(t) {\n var tl = parse_shallow(t.data);\n var ref = M[parse_TSP_Reference(tl[2][0].data)][0];\n var mtype = varint_to_i32(ref.meta[1][0].data);\n if (mtype != 6002)\n throw new Error(\"6001 unexpected reference to \".concat(mtype));\n var _tile = parse_TST_Tile(M, ref);\n _tile.data.forEach(function(row, R) {\n row.forEach(function(buf, C) {\n var addr = encode_cell({ r: _R + R, c: C });\n var res = parse_cell_storage(buf, sst, rsst);\n if (res)\n ws[addr] = res;\n });\n });\n _R += _tile.nrows;\n });\n}\nfunction parse_TST_TableInfoArchive(M, root) {\n var pb = parse_shallow(root.data);\n var out = { \"!ref\": \"A1\" };\n var tableref = M[parse_TSP_Reference(pb[2][0].data)];\n var mtype = varint_to_i32(tableref[0].meta[1][0].data);\n if (mtype != 6001)\n throw new Error(\"6000 unexpected reference to \".concat(mtype));\n parse_TST_TableModelArchive(M, tableref[0], out);\n return out;\n}\nfunction parse_TN_SheetArchive(M, root) {\n var _a;\n var pb = parse_shallow(root.data);\n var out = {\n name: ((_a = pb[1]) == null ? void 0 : _a[0]) ? u8str(pb[1][0].data) : \"\",\n sheets: []\n };\n var shapeoffs = mappa(pb[2], parse_TSP_Reference);\n shapeoffs.forEach(function(off) {\n M[off].forEach(function(m) {\n var mtype = varint_to_i32(m.meta[1][0].data);\n if (mtype == 6e3)\n out.sheets.push(parse_TST_TableInfoArchive(M, m));\n });\n });\n return out;\n}\nfunction parse_TN_DocumentArchive(M, root) {\n var out = book_new();\n var pb = parse_shallow(root.data);\n var sheetoffs = mappa(pb[1], parse_TSP_Reference);\n sheetoffs.forEach(function(off) {\n M[off].forEach(function(m) {\n var mtype = varint_to_i32(m.meta[1][0].data);\n if (mtype == 2) {\n var root2 = parse_TN_SheetArchive(M, m);\n root2.sheets.forEach(function(sheet, idx) {\n book_append_sheet(out, sheet, idx == 0 ? root2.name : root2.name + \"_\" + idx, true);\n });\n }\n });\n });\n if (out.SheetNames.length == 0)\n throw new Error(\"Empty NUMBERS file\");\n return out;\n}\nfunction parse_numbers_iwa(cfb) {\n var _a, _b, _c, _d;\n var M = {}, indices = [];\n cfb.FullPaths.forEach(function(p) {\n if (p.match(/\\.iwpv2/))\n throw new Error(\"Unsupported password protection\");\n });\n cfb.FileIndex.forEach(function(s) {\n if (!s.name.match(/\\.iwa$/))\n return;\n var o;\n try {\n o = decompress_iwa_file(s.content);\n } catch (e) {\n return console.log(\"?? \" + s.content.length + \" \" + (e.message || e));\n }\n var packets;\n try {\n packets = parse_iwa_file(o);\n } catch (e) {\n return console.log(\"## \" + (e.message || e));\n }\n packets.forEach(function(packet) {\n M[packet.id] = packet.messages;\n indices.push(packet.id);\n });\n });\n if (!indices.length)\n throw new Error(\"File has no messages\");\n var docroot = ((_d = (_c = (_b = (_a = M == null ? void 0 : M[1]) == null ? void 0 : _a[0]) == null ? void 0 : _b.meta) == null ? void 0 : _c[1]) == null ? void 0 : _d[0].data) && varint_to_i32(M[1][0].meta[1][0].data) == 1 && M[1][0];\n if (!docroot)\n indices.forEach(function(idx) {\n M[idx].forEach(function(iwam) {\n var mtype = varint_to_i32(iwam.meta[1][0].data) >>> 0;\n if (mtype == 1) {\n if (!docroot)\n docroot = iwam;\n else\n throw new Error(\"Document has multiple roots\");\n }\n });\n });\n if (!docroot)\n throw new Error(\"Cannot find Document root\");\n return parse_TN_DocumentArchive(M, docroot);\n}\nfunction write_tile_row(tri, data, SST) {\n var _a, _b, _c, _d;\n if (!((_a = tri[6]) == null ? void 0 : _a[0]) || !((_b = tri[7]) == null ? void 0 : _b[0]))\n throw \"Mutation only works on post-BNC storages!\";\n var wide_offsets = ((_d = (_c = tri[8]) == null ? void 0 : _c[0]) == null ? void 0 : _d.data) && varint_to_i32(tri[8][0].data) > 0 || false;\n if (wide_offsets)\n throw \"Math only works with normal offsets\";\n var cnt = 0;\n var dv = u8_to_dataview(tri[7][0].data), last_offset = 0, cell_storage = [];\n var _dv = u8_to_dataview(tri[4][0].data), _last_offset = 0, _cell_storage = [];\n for (var C = 0; C < data.length; ++C) {\n if (data[C] == null) {\n dv.setUint16(C * 2, 65535, true);\n _dv.setUint16(C * 2, 65535);\n continue;\n }\n dv.setUint16(C * 2, last_offset, true);\n _dv.setUint16(C * 2, _last_offset, true);\n var celload, _celload;\n switch (typeof data[C]) {\n case \"string\":\n celload = write_new_storage({ t: \"s\", v: data[C] }, SST);\n _celload = write_old_storage({ t: \"s\", v: data[C] }, SST);\n break;\n case \"number\":\n celload = write_new_storage({ t: \"n\", v: data[C] }, SST);\n _celload = write_old_storage({ t: \"n\", v: data[C] }, SST);\n break;\n case \"boolean\":\n celload = write_new_storage({ t: \"b\", v: data[C] }, SST);\n _celload = write_old_storage({ t: \"b\", v: data[C] }, SST);\n break;\n default:\n throw new Error(\"Unsupported value \" + data[C]);\n }\n cell_storage.push(celload);\n last_offset += celload.length;\n _cell_storage.push(_celload);\n _last_offset += _celload.length;\n ++cnt;\n }\n tri[2][0].data = write_varint49(cnt);\n for (; C < tri[7][0].data.length / 2; ++C) {\n dv.setUint16(C * 2, 65535, true);\n _dv.setUint16(C * 2, 65535, true);\n }\n tri[6][0].data = u8concat(cell_storage);\n tri[3][0].data = u8concat(_cell_storage);\n return cnt;\n}\nfunction write_numbers_iwa(wb, opts) {\n if (!opts || !opts.numbers)\n throw new Error(\"Must pass a `numbers` option -- check the README\");\n var ws = wb.Sheets[wb.SheetNames[0]];\n if (wb.SheetNames.length > 1)\n console.error(\"The Numbers writer currently writes only the first table\");\n var range = decode_range(ws[\"!ref\"]);\n range.s.r = range.s.c = 0;\n var trunc = false;\n if (range.e.c > 9) {\n trunc = true;\n range.e.c = 9;\n }\n if (range.e.r > 49) {\n trunc = true;\n range.e.r = 49;\n }\n if (trunc)\n console.error(\"The Numbers writer is currently limited to \".concat(encode_range(range)));\n var data = sheet_to_json(ws, { range: range, header: 1 });\n var SST = [\"~Sh33tJ5~\"];\n data.forEach(function(row) {\n return row.forEach(function(cell) {\n if (typeof cell == \"string\")\n SST.push(cell);\n });\n });\n var dependents = {};\n var indices = [];\n var cfb = CFB.read(opts.numbers, { type: \"base64\" });\n cfb.FileIndex.map(function(fi, idx) {\n return [fi, cfb.FullPaths[idx]];\n }).forEach(function(row) {\n var fi = row[0], fp = row[1];\n if (fi.type != 2)\n return;\n if (!fi.name.match(/\\.iwa/))\n return;\n var old_content = fi.content;\n var raw1 = decompress_iwa_file(old_content);\n var x2 = parse_iwa_file(raw1);\n x2.forEach(function(packet2) {\n indices.push(packet2.id);\n dependents[packet2.id] = { deps: [], location: fp, type: varint_to_i32(packet2.messages[0].meta[1][0].data) };\n });\n });\n indices.sort(function(x2, y2) {\n return x2 - y2;\n });\n var indices_varint = indices.filter(function(x2) {\n return x2 > 1;\n }).map(function(x2) {\n return [x2, write_varint49(x2)];\n });\n cfb.FileIndex.map(function(fi, idx) {\n return [fi, cfb.FullPaths[idx]];\n }).forEach(function(row) {\n var fi = row[0], fp = row[1];\n if (!fi.name.match(/\\.iwa/))\n return;\n var x2 = parse_iwa_file(decompress_iwa_file(fi.content));\n x2.forEach(function(ia) {\n ia.messages.forEach(function(m) {\n indices_varint.forEach(function(ivi) {\n if (ia.messages.some(function(mess) {\n return varint_to_i32(mess.meta[1][0].data) != 11006 && u8contains(mess.data, ivi[1]);\n })) {\n dependents[ivi[0]].deps.push(ia.id);\n }\n });\n });\n });\n });\n function get_unique_msgid() {\n for (var i = 927262; i < 2e6; ++i)\n if (!dependents[i])\n return i;\n throw new Error(\"Too many messages\");\n }\n var entry = CFB.find(cfb, dependents[1].location);\n var x = parse_iwa_file(decompress_iwa_file(entry.content));\n var docroot;\n for (var xi = 0; xi < x.length; ++xi) {\n var packet = x[xi];\n if (packet.id == 1)\n docroot = packet;\n }\n var sheetrootref = parse_TSP_Reference(parse_shallow(docroot.messages[0].data)[1][0].data);\n entry = CFB.find(cfb, dependents[sheetrootref].location);\n x = parse_iwa_file(decompress_iwa_file(entry.content));\n for (xi = 0; xi < x.length; ++xi) {\n packet = x[xi];\n if (packet.id == sheetrootref)\n docroot = packet;\n }\n sheetrootref = parse_TSP_Reference(parse_shallow(docroot.messages[0].data)[2][0].data);\n entry = CFB.find(cfb, dependents[sheetrootref].location);\n x = parse_iwa_file(decompress_iwa_file(entry.content));\n for (xi = 0; xi < x.length; ++xi) {\n packet = x[xi];\n if (packet.id == sheetrootref)\n docroot = packet;\n }\n sheetrootref = parse_TSP_Reference(parse_shallow(docroot.messages[0].data)[2][0].data);\n entry = CFB.find(cfb, dependents[sheetrootref].location);\n x = parse_iwa_file(decompress_iwa_file(entry.content));\n for (xi = 0; xi < x.length; ++xi) {\n packet = x[xi];\n if (packet.id == sheetrootref)\n docroot = packet;\n }\n var pb = parse_shallow(docroot.messages[0].data);\n {\n pb[6][0].data = write_varint49(range.e.r + 1);\n pb[7][0].data = write_varint49(range.e.c + 1);\n var cruidsref = parse_TSP_Reference(pb[46][0].data);\n var oldbucket = CFB.find(cfb, dependents[cruidsref].location);\n var _x = parse_iwa_file(decompress_iwa_file(oldbucket.content));\n {\n for (var j = 0; j < _x.length; ++j) {\n if (_x[j].id == cruidsref)\n break;\n }\n if (_x[j].id != cruidsref)\n throw \"Bad ColumnRowUIDMapArchive\";\n var cruids = parse_shallow(_x[j].messages[0].data);\n cruids[1] = [];\n cruids[2] = [], cruids[3] = [];\n for (var C = 0; C <= range.e.c; ++C) {\n var uuid = [];\n uuid[1] = uuid[2] = [{ type: 0, data: write_varint49(C + 420690) }];\n cruids[1].push({ type: 2, data: write_shallow(uuid) });\n cruids[2].push({ type: 0, data: write_varint49(C) });\n cruids[3].push({ type: 0, data: write_varint49(C) });\n }\n cruids[4] = [];\n cruids[5] = [], cruids[6] = [];\n for (var R = 0; R <= range.e.r; ++R) {\n uuid = [];\n uuid[1] = uuid[2] = [{ type: 0, data: write_varint49(R + 726270) }];\n cruids[4].push({ type: 2, data: write_shallow(uuid) });\n cruids[5].push({ type: 0, data: write_varint49(R) });\n cruids[6].push({ type: 0, data: write_varint49(R) });\n }\n _x[j].messages[0].data = write_shallow(cruids);\n }\n oldbucket.content = compress_iwa_file(write_iwa_file(_x));\n oldbucket.size = oldbucket.content.length;\n delete pb[46];\n var store = parse_shallow(pb[4][0].data);\n {\n store[7][0].data = write_varint49(range.e.r + 1);\n var row_headers = parse_shallow(store[1][0].data);\n var row_header_ref = parse_TSP_Reference(row_headers[2][0].data);\n oldbucket = CFB.find(cfb, dependents[row_header_ref].location);\n _x = parse_iwa_file(decompress_iwa_file(oldbucket.content));\n {\n if (_x[0].id != row_header_ref)\n throw \"Bad HeaderStorageBucket\";\n var base_bucket = parse_shallow(_x[0].messages[0].data);\n for (R = 0; R < data.length; ++R) {\n var _bucket = parse_shallow(base_bucket[2][0].data);\n _bucket[1][0].data = write_varint49(R);\n _bucket[4][0].data = write_varint49(data[R].length);\n base_bucket[2][R] = { type: base_bucket[2][0].type, data: write_shallow(_bucket) };\n }\n _x[0].messages[0].data = write_shallow(base_bucket);\n }\n oldbucket.content = compress_iwa_file(write_iwa_file(_x));\n oldbucket.size = oldbucket.content.length;\n var col_header_ref = parse_TSP_Reference(store[2][0].data);\n oldbucket = CFB.find(cfb, dependents[col_header_ref].location);\n _x = parse_iwa_file(decompress_iwa_file(oldbucket.content));\n {\n if (_x[0].id != col_header_ref)\n throw \"Bad HeaderStorageBucket\";\n base_bucket = parse_shallow(_x[0].messages[0].data);\n for (C = 0; C <= range.e.c; ++C) {\n _bucket = parse_shallow(base_bucket[2][0].data);\n _bucket[1][0].data = write_varint49(C);\n _bucket[4][0].data = write_varint49(range.e.r + 1);\n base_bucket[2][C] = { type: base_bucket[2][0].type, data: write_shallow(_bucket) };\n }\n _x[0].messages[0].data = write_shallow(base_bucket);\n }\n oldbucket.content = compress_iwa_file(write_iwa_file(_x));\n oldbucket.size = oldbucket.content.length;\n var sstref = parse_TSP_Reference(store[4][0].data);\n (function() {\n var sentry = CFB.find(cfb, dependents[sstref].location);\n var sx = parse_iwa_file(decompress_iwa_file(sentry.content));\n var sstroot;\n for (var sxi = 0; sxi < sx.length; ++sxi) {\n var packet2 = sx[sxi];\n if (packet2.id == sstref)\n sstroot = packet2;\n }\n var sstdata = parse_shallow(sstroot.messages[0].data);\n {\n sstdata[3] = [];\n var newsst = [];\n SST.forEach(function(str, i) {\n newsst[1] = [{ type: 0, data: write_varint49(i) }];\n newsst[2] = [{ type: 0, data: write_varint49(1) }];\n newsst[3] = [{ type: 2, data: stru8(str) }];\n sstdata[3].push({ type: 2, data: write_shallow(newsst) });\n });\n }\n sstroot.messages[0].data = write_shallow(sstdata);\n var sy = write_iwa_file(sx);\n var raw32 = compress_iwa_file(sy);\n sentry.content = raw32;\n sentry.size = sentry.content.length;\n })();\n var tile = parse_shallow(store[3][0].data);\n {\n var t = tile[1][0];\n delete tile[2];\n var tl = parse_shallow(t.data);\n {\n var tileref = parse_TSP_Reference(tl[2][0].data);\n (function() {\n var tentry = CFB.find(cfb, dependents[tileref].location);\n var tx = parse_iwa_file(decompress_iwa_file(tentry.content));\n var tileroot;\n for (var sxi = 0; sxi < tx.length; ++sxi) {\n var packet2 = tx[sxi];\n if (packet2.id == tileref)\n tileroot = packet2;\n }\n var tiledata = parse_shallow(tileroot.messages[0].data);\n {\n delete tiledata[6];\n delete tile[7];\n var rowload = new Uint8Array(tiledata[5][0].data);\n tiledata[5] = [];\n var cnt = 0;\n for (var R2 = 0; R2 <= range.e.r; ++R2) {\n var tilerow = parse_shallow(rowload);\n cnt += write_tile_row(tilerow, data[R2], SST);\n tilerow[1][0].data = write_varint49(R2);\n tiledata[5].push({ data: write_shallow(tilerow), type: 2 });\n }\n tiledata[1] = [{ type: 0, data: write_varint49(range.e.c + 1) }];\n tiledata[2] = [{ type: 0, data: write_varint49(range.e.r + 1) }];\n tiledata[3] = [{ type: 0, data: write_varint49(cnt) }];\n tiledata[4] = [{ type: 0, data: write_varint49(range.e.r + 1) }];\n }\n tileroot.messages[0].data = write_shallow(tiledata);\n var ty = write_iwa_file(tx);\n var raw32 = compress_iwa_file(ty);\n tentry.content = raw32;\n tentry.size = tentry.content.length;\n })();\n }\n t.data = write_shallow(tl);\n }\n store[3][0].data = write_shallow(tile);\n }\n pb[4][0].data = write_shallow(store);\n }\n docroot.messages[0].data = write_shallow(pb);\n var y = write_iwa_file(x);\n var raw3 = compress_iwa_file(y);\n entry.content = raw3;\n entry.size = entry.content.length;\n return cfb;\n}\nfunction fix_opts_func(defaults/*:Array<Array<any> >*/)/*:{(o:any):void}*/ {\n\treturn function fix_opts(opts) {\n\t\tfor(var i = 0; i != defaults.length; ++i) {\n\t\t\tvar d = defaults[i];\n\t\t\tif(opts[d[0]] === undefined) opts[d[0]] = d[1];\n\t\t\tif(d[2] === 'n') opts[d[0]] = Number(opts[d[0]]);\n\t\t}\n\t};\n}\n\nfunction fix_read_opts(opts) {\nfix_opts_func([\n\t['cellNF', false], /* emit cell number format string as .z */\n\t['cellHTML', true], /* emit html string as .h */\n\t['cellFormula', true], /* emit formulae as .f */\n\t['cellStyles', false], /* emits style/theme as .s */\n\t['cellText', true], /* emit formatted text as .w */\n\t['cellDates', false], /* emit date cells with type `d` */\n\n\t['sheetStubs', false], /* emit empty cells */\n\t['sheetRows', 0, 'n'], /* read n rows (0 = read all rows) */\n\n\t['bookDeps', false], /* parse calculation chains */\n\t['bookSheets', false], /* only try to get sheet names (no Sheets) */\n\t['bookProps', false], /* only try to get properties (no Sheets) */\n\t['bookFiles', false], /* include raw file structure (keys, files, cfb) */\n\t['bookVBA', false], /* include vba raw data (vbaraw) */\n\n\t['password',''], /* password */\n\t['WTF', false] /* WTF mode (throws errors) */\n])(opts);\n}\n\nfunction fix_write_opts(opts) {\nfix_opts_func([\n\t['cellDates', false], /* write date cells with type `d` */\n\n\t['bookSST', false], /* Generate Shared String Table */\n\n\t['bookType', 'xlsx'], /* Type of workbook (xlsx/m/b) */\n\n\t['compression', false], /* Use file compression */\n\n\t['WTF', false] /* WTF mode (throws errors) */\n])(opts);\n}\nfunction get_sheet_type(n/*:string*/)/*:string*/ {\n\tif(RELS.WS.indexOf(n) > -1) return \"sheet\";\n\tif(RELS.CS && n == RELS.CS) return \"chart\";\n\tif(RELS.DS && n == RELS.DS) return \"dialog\";\n\tif(RELS.MS && n == RELS.MS) return \"macro\";\n\treturn (n && n.length) ? n : \"sheet\";\n}\nfunction safe_parse_wbrels(wbrels, sheets) {\n\tif(!wbrels) return 0;\n\ttry {\n\t\twbrels = sheets.map(function pwbr(w) { if(!w.id) w.id = w.strRelID; return [w.name, wbrels['!id'][w.id].Target, get_sheet_type(wbrels['!id'][w.id].Type)]; });\n\t} catch(e) { return null; }\n\treturn !wbrels || wbrels.length === 0 ? null : wbrels;\n}\n\nfunction safe_parse_sheet(zip, path/*:string*/, relsPath/*:string*/, sheet, idx/*:number*/, sheetRels, sheets, stype/*:string*/, opts, wb, themes, styles) {\n\ttry {\n\t\tsheetRels[sheet]=parse_rels(getzipstr(zip, relsPath, true), path);\n\t\tvar data = getzipdata(zip, path);\n\t\tvar _ws;\n\t\tswitch(stype) {\n\t\t\tcase 'sheet': _ws = parse_ws(data, path, idx, opts, sheetRels[sheet], wb, themes, styles); break;\n\t\t\tcase 'chart': _ws = parse_cs(data, path, idx, opts, sheetRels[sheet], wb, themes, styles);\n\t\t\t\tif(!_ws || !_ws['!drawel']) break;\n\t\t\t\tvar dfile = resolve_path(_ws['!drawel'].Target, path);\n\t\t\t\tvar drelsp = get_rels_path(dfile);\n\t\t\t\tvar draw = parse_drawing(getzipstr(zip, dfile, true), parse_rels(getzipstr(zip, drelsp, true), dfile));\n\t\t\t\tvar chartp = resolve_path(draw, dfile);\n\t\t\t\tvar crelsp = get_rels_path(chartp);\n\t\t\t\t_ws = parse_chart(getzipstr(zip, chartp, true), chartp, opts, parse_rels(getzipstr(zip, crelsp, true), chartp), wb, _ws);\n\t\t\t\tbreak;\n\t\t\tcase 'macro': _ws = parse_ms(data, path, idx, opts, sheetRels[sheet], wb, themes, styles); break;\n\t\t\tcase 'dialog': _ws = parse_ds(data, path, idx, opts, sheetRels[sheet], wb, themes, styles); break;\n\t\t\tdefault: throw new Error(\"Unrecognized sheet type \" + stype);\n\t\t}\n\t\tsheets[sheet] = _ws;\n\n\t\t/* scan rels for comments and threaded comments */\n\t\tvar tcomments = [];\n\t\tif(sheetRels && sheetRels[sheet]) keys(sheetRels[sheet]).forEach(function(n) {\n\t\t\tvar dfile = \"\";\n\t\t\tif(sheetRels[sheet][n].Type == RELS.CMNT) {\n\t\t\t\tdfile = resolve_path(sheetRels[sheet][n].Target, path);\n\t\t\t\tvar comments = parse_cmnt(getzipdata(zip, dfile, true), dfile, opts);\n\t\t\t\tif(!comments || !comments.length) return;\n\t\t\t\tsheet_insert_comments(_ws, comments, false);\n\t\t\t}\n\t\t\tif(sheetRels[sheet][n].Type == RELS.TCMNT) {\n\t\t\t\tdfile = resolve_path(sheetRels[sheet][n].Target, path);\n\t\t\t\ttcomments = tcomments.concat(parse_tcmnt_xml(getzipdata(zip, dfile, true), opts));\n\t\t\t}\n\t\t});\n\t\tif(tcomments && tcomments.length) sheet_insert_comments(_ws, tcomments, true, opts.people || []);\n\t} catch(e) { if(opts.WTF) throw e; }\n}\n\nfunction strip_front_slash(x/*:string*/)/*:string*/ { return x.charAt(0) == '/' ? x.slice(1) : x; }\n\nfunction parse_zip(zip/*:ZIP*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tmake_ssf();\n\topts = opts || {};\n\tfix_read_opts(opts);\n\n\t/* OpenDocument Part 3 Section 2.2.1 OpenDocument Package */\n\tif(safegetzipfile(zip, 'META-INF/manifest.xml')) return parse_ods(zip, opts);\n\t/* UOC */\n\tif(safegetzipfile(zip, 'objectdata.xml')) return parse_ods(zip, opts);\n\t/* Numbers */\n\tif(safegetzipfile(zip, 'Index/Document.iwa')) {\n\t\tif(typeof Uint8Array == \"undefined\") throw new Error('NUMBERS file parsing requires Uint8Array support');\n\t\tif(typeof parse_numbers_iwa != \"undefined\") {\n\t\t\tif(zip.FileIndex) return parse_numbers_iwa(zip);\n\t\t\tvar _zip = CFB.utils.cfb_new();\n\t\t\tzipentries(zip).forEach(function(e) { zip_add_file(_zip, e, getzipbin(zip, e)); });\n\t\t\treturn parse_numbers_iwa(_zip);\n\t\t}\n\t\tthrow new Error('Unsupported NUMBERS file');\n\t}\n\tif(!safegetzipfile(zip, '[Content_Types].xml')) {\n\t\tif(safegetzipfile(zip, 'index.xml.gz')) throw new Error('Unsupported NUMBERS 08 file');\n\t\tif(safegetzipfile(zip, 'index.xml')) throw new Error('Unsupported NUMBERS 09 file');\n\t\tthrow new Error('Unsupported ZIP file');\n\t}\n\n\tvar entries = zipentries(zip);\n\tvar dir = parse_ct((getzipstr(zip, '[Content_Types].xml')/*:?any*/));\n\tvar xlsb = false;\n\tvar sheets, binname;\n\tif(dir.workbooks.length === 0) {\n\t\tbinname = \"xl/workbook.xml\";\n\t\tif(getzipdata(zip,binname, true)) dir.workbooks.push(binname);\n\t}\n\tif(dir.workbooks.length === 0) {\n\t\tbinname = \"xl/workbook.bin\";\n\t\tif(!getzipdata(zip,binname,true)) throw new Error(\"Could not find workbook\");\n\t\tdir.workbooks.push(binname);\n\t\txlsb = true;\n\t}\n\tif(dir.workbooks[0].slice(-3) == \"bin\") xlsb = true;\n\n\tvar themes = ({}/*:any*/);\n\tvar styles = ({}/*:any*/);\n\tif(!opts.bookSheets && !opts.bookProps) {\n\t\tstrs = [];\n\t\tif(dir.sst) try { strs=parse_sst(getzipdata(zip, strip_front_slash(dir.sst)), dir.sst, opts); } catch(e) { if(opts.WTF) throw e; }\n\n\t\tif(opts.cellStyles && dir.themes.length) themes = parse_theme(getzipstr(zip, dir.themes[0].replace(/^\\//,''), true)||\"\",dir.themes[0], opts);\n\n\t\tif(dir.style) styles = parse_sty(getzipdata(zip, strip_front_slash(dir.style)), dir.style, themes, opts);\n\t}\n\n\t/*var externbooks = */dir.links.map(function(link) {\n\t\ttry {\n\t\t\tvar rels = parse_rels(getzipstr(zip, get_rels_path(strip_front_slash(link))), link);\n\t\t\treturn parse_xlink(getzipdata(zip, strip_front_slash(link)), rels, link, opts);\n\t\t} catch(e) {}\n\t});\n\n\tvar wb = parse_wb(getzipdata(zip, strip_front_slash(dir.workbooks[0])), dir.workbooks[0], opts);\n\n\tvar props = {}, propdata = \"\";\n\n\tif(dir.coreprops.length) {\n\t\tpropdata = getzipdata(zip, strip_front_slash(dir.coreprops[0]), true);\n\t\tif(propdata) props = parse_core_props(propdata);\n\t\tif(dir.extprops.length !== 0) {\n\t\t\tpropdata = getzipdata(zip, strip_front_slash(dir.extprops[0]), true);\n\t\t\tif(propdata) parse_ext_props(propdata, props, opts);\n\t\t}\n\t}\n\n\tvar custprops = {};\n\tif(!opts.bookSheets || opts.bookProps) {\n\t\tif (dir.custprops.length !== 0) {\n\t\t\tpropdata = getzipstr(zip, strip_front_slash(dir.custprops[0]), true);\n\t\t\tif(propdata) custprops = parse_cust_props(propdata, opts);\n\t\t}\n\t}\n\n\tvar out = ({}/*:any*/);\n\tif(opts.bookSheets || opts.bookProps) {\n\t\tif(wb.Sheets) sheets = wb.Sheets.map(function pluck(x){ return x.name; });\n\t\telse if(props.Worksheets && props.SheetNames.length > 0) sheets=props.SheetNames;\n\t\tif(opts.bookProps) { out.Props = props; out.Custprops = custprops; }\n\t\tif(opts.bookSheets && typeof sheets !== 'undefined') out.SheetNames = sheets;\n\t\tif(opts.bookSheets ? out.SheetNames : opts.bookProps) return out;\n\t}\n\tsheets = {};\n\n\tvar deps = {};\n\tif(opts.bookDeps && dir.calcchain) deps=parse_cc(getzipdata(zip, strip_front_slash(dir.calcchain)),dir.calcchain,opts);\n\n\tvar i=0;\n\tvar sheetRels = ({}/*:any*/);\n\tvar path, relsPath;\n\n\t{\n\t\tvar wbsheets = wb.Sheets;\n\t\tprops.Worksheets = wbsheets.length;\n\t\tprops.SheetNames = [];\n\t\tfor(var j = 0; j != wbsheets.length; ++j) {\n\t\t\tprops.SheetNames[j] = wbsheets[j].name;\n\t\t}\n\t}\n\n\tvar wbext = xlsb ? \"bin\" : \"xml\";\n\tvar wbrelsi = dir.workbooks[0].lastIndexOf(\"/\");\n\tvar wbrelsfile = (dir.workbooks[0].slice(0, wbrelsi+1) + \"_rels/\" + dir.workbooks[0].slice(wbrelsi+1) + \".rels\").replace(/^\\//,\"\");\n\tif(!safegetzipfile(zip, wbrelsfile)) wbrelsfile = 'xl/_rels/workbook.' + wbext + '.rels';\n\tvar wbrels = parse_rels(getzipstr(zip, wbrelsfile, true), wbrelsfile.replace(/_rels.*/, \"s5s\"));\n\n\tif((dir.metadata || []).length >= 1) {\n\t\t/* TODO: MDX and other types of metadata */\n\t\topts.xlmeta = parse_xlmeta(getzipdata(zip, strip_front_slash(dir.metadata[0])),dir.metadata[0],opts);\n\t}\n\n\tif((dir.people || []).length >= 1) {\n\t\topts.people = parse_people_xml(getzipdata(zip, strip_front_slash(dir.people[0])),opts);\n\t}\n\n\tif(wbrels) wbrels = safe_parse_wbrels(wbrels, wb.Sheets);\n\n\t/* Numbers iOS hack */\n\tvar nmode = (getzipdata(zip,\"xl/worksheets/sheet.xml\",true))?1:0;\n\twsloop: for(i = 0; i != props.Worksheets; ++i) {\n\t\tvar stype = \"sheet\";\n\t\tif(wbrels && wbrels[i]) {\n\t\t\tpath = 'xl/' + (wbrels[i][1]).replace(/[\\/]?xl\\//, \"\");\n\t\t\tif(!safegetzipfile(zip, path)) path = wbrels[i][1];\n\t\t\tif(!safegetzipfile(zip, path)) path = wbrelsfile.replace(/_rels\\/.*$/,\"\") + wbrels[i][1];\n\t\t\tstype = wbrels[i][2];\n\t\t} else {\n\t\t\tpath = 'xl/worksheets/sheet'+(i+1-nmode)+\".\" + wbext;\n\t\t\tpath = path.replace(/sheet0\\./,\"sheet.\");\n\t\t}\n\t\trelsPath = path.replace(/^(.*)(\\/)([^\\/]*)$/, \"$1/_rels/$3.rels\");\n\t\tif(opts && opts.sheets != null) switch(typeof opts.sheets) {\n\t\t\tcase \"number\": if(i != opts.sheets) continue wsloop; break;\n\t\t\tcase \"string\": if(props.SheetNames[i].toLowerCase() != opts.sheets.toLowerCase()) continue wsloop; break;\n\t\t\tdefault: if(Array.isArray && Array.isArray(opts.sheets)) {\n\t\t\t\tvar snjseen = false;\n\t\t\t\tfor(var snj = 0; snj != opts.sheets.length; ++snj) {\n\t\t\t\t\tif(typeof opts.sheets[snj] == \"number\" && opts.sheets[snj] == i) snjseen=1;\n\t\t\t\t\tif(typeof opts.sheets[snj] == \"string\" && opts.sheets[snj].toLowerCase() == props.SheetNames[i].toLowerCase()) snjseen = 1;\n\t\t\t\t}\n\t\t\t\tif(!snjseen) continue wsloop;\n\t\t\t}\n\t\t}\n\t\tsafe_parse_sheet(zip, path, relsPath, props.SheetNames[i], i, sheetRels, sheets, stype, opts, wb, themes, styles);\n\t}\n\n\tout = ({\n\t\tDirectory: dir,\n\t\tWorkbook: wb,\n\t\tProps: props,\n\t\tCustprops: custprops,\n\t\tDeps: deps,\n\t\tSheets: sheets,\n\t\tSheetNames: props.SheetNames,\n\t\tStrings: strs,\n\t\tStyles: styles,\n\t\tThemes: themes,\n\t\tSSF: dup(table_fmt)\n\t}/*:any*/);\n\tif(opts && opts.bookFiles) {\n\t\tif(zip.files) {\n\t\t\tout.keys = entries;\n\t\t\tout.files = zip.files;\n\t\t} else {\n\t\t\tout.keys = [];\n\t\t\tout.files = {};\n\t\t\tzip.FullPaths.forEach(function(p, idx) {\n\t\t\t\tp = p.replace(/^Root Entry[\\/]/, \"\");\n\t\t\t\tout.keys.push(p);\n\t\t\t\tout.files[p] = zip.FileIndex[idx];\n\t\t\t});\n\t\t}\n\t}\n\tif(opts && opts.bookVBA) {\n\t\tif(dir.vba.length > 0) out.vbaraw = getzipdata(zip,strip_front_slash(dir.vba[0]),true);\n\t\telse if(dir.defaults && dir.defaults.bin === CT_VBA) out.vbaraw = getzipdata(zip, 'xl/vbaProject.bin',true);\n\t}\n\treturn out;\n}\n\n/* [MS-OFFCRYPTO] 2.1.1 */\nfunction parse_xlsxcfb(cfb, _opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tvar opts = _opts || {};\n\tvar f = 'Workbook', data = CFB.find(cfb, f);\n\ttry {\n\tf = '/!DataSpaces/Version';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\t/*var version = */parse_DataSpaceVersionInfo(data.content);\n\n\t/* 2.3.4.1 */\n\tf = '/!DataSpaces/DataSpaceMap';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\tvar dsm = parse_DataSpaceMap(data.content);\n\tif(dsm.length !== 1 || dsm[0].comps.length !== 1 || dsm[0].comps[0].t !== 0 || dsm[0].name !== \"StrongEncryptionDataSpace\" || dsm[0].comps[0].v !== \"EncryptedPackage\")\n\t\tthrow new Error(\"ECMA-376 Encrypted file bad \" + f);\n\n\t/* 2.3.4.2 */\n\tf = '/!DataSpaces/DataSpaceInfo/StrongEncryptionDataSpace';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\tvar seds = parse_DataSpaceDefinition(data.content);\n\tif(seds.length != 1 || seds[0] != \"StrongEncryptionTransform\")\n\t\tthrow new Error(\"ECMA-376 Encrypted file bad \" + f);\n\n\t/* 2.3.4.3 */\n\tf = '/!DataSpaces/TransformInfo/StrongEncryptionTransform/!Primary';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\t/*var hdr = */parse_Primary(data.content);\n\t} catch(e) {}\n\n\tf = '/EncryptionInfo';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\tvar einfo = parse_EncryptionInfo(data.content);\n\n\t/* 2.3.4.4 */\n\tf = '/EncryptedPackage';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\n/*global decrypt_agile */\n/*:: declare var decrypt_agile:any; */\n\tif(einfo[0] == 0x04 && typeof decrypt_agile !== 'undefined') return decrypt_agile(einfo[1], data.content, opts.password || \"\", opts);\n/*global decrypt_std76 */\n/*:: declare var decrypt_std76:any; */\n\tif(einfo[0] == 0x02 && typeof decrypt_std76 !== 'undefined') return decrypt_std76(einfo[1], data.content, opts.password || \"\", opts);\n\tthrow new Error(\"File is password-protected\");\n}\n\nfunction write_zip(wb/*:Workbook*/, opts/*:WriteOpts*/)/*:ZIP*/ {\n\tif(opts.bookType == \"ods\") return write_ods(wb, opts);\n\tif(opts.bookType == \"numbers\") return write_numbers_iwa(wb, opts);\n\tif(opts.bookType == \"xlsb\") return write_zip_xlsxb(wb, opts);\n\treturn write_zip_xlsx(wb, opts);\n}\n\n/* XLSX and XLSB writing are very similar. Originally they were unified in one\n export function. This is horrible for tree shaking in the common case (most\n applications need to export files in one format) so this function supports\n both formats while write_zip_xlsx only handles XLSX */\nfunction write_zip_xlsxb(wb/*:Workbook*/, opts/*:WriteOpts*/)/*:ZIP*/ {\n\t_shapeid = 1024;\n\tif(wb && !wb.SSF) {\n\t\twb.SSF = dup(table_fmt);\n\t}\n\tif(wb && wb.SSF) {\n\t\tmake_ssf(); SSF_load_table(wb.SSF);\n\t\t// $FlowIgnore\n\t\topts.revssf = evert_num(wb.SSF); opts.revssf[wb.SSF[65535]] = 0;\n\t\topts.ssf = wb.SSF;\n\t}\n\topts.rels = {}; opts.wbrels = {};\n\topts.Strings = /*::((*/[]/*:: :any):SST)*/; opts.Strings.Count = 0; opts.Strings.Unique = 0;\n\tif(browser_has_Map) opts.revStrings = new Map();\n\telse { opts.revStrings = {}; opts.revStrings.foo = []; delete opts.revStrings.foo; }\n\tvar wbext = opts.bookType == \"xlsb\" ? \"bin\" : \"xml\";\n\tvar vbafmt = VBAFMTS.indexOf(opts.bookType) > -1;\n\tvar ct = new_ct();\n\tfix_write_opts(opts = opts || {});\n\tvar zip = zip_new();\n\tvar f = \"\", rId = 0;\n\n\topts.cellXfs = [];\n\tget_cell_style(opts.cellXfs, {}, {revssf:{\"General\":0}});\n\n\tif(!wb.Props) wb.Props = {};\n\n\tf = \"docProps/core.xml\";\n\tzip_add_file(zip, f, write_core_props(wb.Props, opts));\n\tct.coreprops.push(f);\n\tadd_rels(opts.rels, 2, f, RELS.CORE_PROPS);\n\n\t/*::if(!wb.Props) throw \"unreachable\"; */\n\tf = \"docProps/app.xml\";\n\tif(wb.Props && wb.Props.SheetNames){/* empty */}\n\telse if(!wb.Workbook || !wb.Workbook.Sheets) wb.Props.SheetNames = wb.SheetNames;\n\telse {\n\t\tvar _sn = [];\n\t\tfor(var _i = 0; _i < wb.SheetNames.length; ++_i)\n\t\t\tif((wb.Workbook.Sheets[_i]||{}).Hidden != 2) _sn.push(wb.SheetNames[_i]);\n\t\twb.Props.SheetNames = _sn;\n\t}\n\twb.Props.Worksheets = wb.Props.SheetNames.length;\n\tzip_add_file(zip, f, write_ext_props(wb.Props, opts));\n\tct.extprops.push(f);\n\tadd_rels(opts.rels, 3, f, RELS.EXT_PROPS);\n\n\tif(wb.Custprops !== wb.Props && keys(wb.Custprops||{}).length > 0) {\n\t\tf = \"docProps/custom.xml\";\n\t\tzip_add_file(zip, f, write_cust_props(wb.Custprops, opts));\n\t\tct.custprops.push(f);\n\t\tadd_rels(opts.rels, 4, f, RELS.CUST_PROPS);\n\t}\n\n\tfor(rId=1;rId <= wb.SheetNames.length; ++rId) {\n\t\tvar wsrels = {'!id':{}};\n\t\tvar ws = wb.Sheets[wb.SheetNames[rId-1]];\n\t\tvar _type = (ws || {})[\"!type\"] || \"sheet\";\n\t\tswitch(_type) {\n\t\tcase \"chart\":\n\t\t\t/* falls through */\n\t\tdefault:\n\t\t\tf = \"xl/worksheets/sheet\" + rId + \".\" + wbext;\n\t\t\tzip_add_file(zip, f, write_ws(rId-1, f, opts, wb, wsrels));\n\t\t\tct.sheets.push(f);\n\t\t\tadd_rels(opts.wbrels, -1, \"worksheets/sheet\" + rId + \".\" + wbext, RELS.WS[0]);\n\t\t}\n\n\t\tif(ws) {\n\t\t\tvar comments = ws['!comments'];\n\t\t\tvar need_vml = false;\n\t\t\tvar cf = \"\";\n\t\t\tif(comments && comments.length > 0) {\n\t\t\t\tcf = \"xl/comments\" + rId + \".\" + wbext;\n\t\t\t\tzip_add_file(zip, cf, write_cmnt(comments, cf, opts));\n\t\t\t\tct.comments.push(cf);\n\t\t\t\tadd_rels(wsrels, -1, \"../comments\" + rId + \".\" + wbext, RELS.CMNT);\n\t\t\t\tneed_vml = true;\n\t\t\t}\n\t\t\tif(ws['!legacy']) {\n\t\t\t\tif(need_vml) zip_add_file(zip, \"xl/drawings/vmlDrawing\" + (rId) + \".vml\", write_comments_vml(rId, ws['!comments']));\n\t\t\t}\n\t\t\tdelete ws['!comments'];\n\t\t\tdelete ws['!legacy'];\n\t\t}\n\n\t\tif(wsrels['!id'].rId1) zip_add_file(zip, get_rels_path(f), write_rels(wsrels));\n\t}\n\n\tif(opts.Strings != null && opts.Strings.length > 0) {\n\t\tf = \"xl/sharedStrings.\" + wbext;\n\t\tzip_add_file(zip, f, write_sst(opts.Strings, f, opts));\n\t\tct.strs.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"sharedStrings.\" + wbext, RELS.SST);\n\t}\n\n\tf = \"xl/workbook.\" + wbext;\n\tzip_add_file(zip, f, write_wb(wb, f, opts));\n\tct.workbooks.push(f);\n\tadd_rels(opts.rels, 1, f, RELS.WB);\n\n\t/* TODO: something more intelligent with themes */\n\n\tf = \"xl/theme/theme1.xml\";\n\tzip_add_file(zip, f, write_theme(wb.Themes, opts));\n\tct.themes.push(f);\n\tadd_rels(opts.wbrels, -1, \"theme/theme1.xml\", RELS.THEME);\n\n\t/* TODO: something more intelligent with styles */\n\n\tf = \"xl/styles.\" + wbext;\n\tzip_add_file(zip, f, write_sty(wb, f, opts));\n\tct.styles.push(f);\n\tadd_rels(opts.wbrels, -1, \"styles.\" + wbext, RELS.STY);\n\n\tif(wb.vbaraw && vbafmt) {\n\t\tf = \"xl/vbaProject.bin\";\n\t\tzip_add_file(zip, f, wb.vbaraw);\n\t\tct.vba.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"vbaProject.bin\", RELS.VBA);\n\t}\n\n\tf = \"xl/metadata.\" + wbext;\n\tzip_add_file(zip, f, write_xlmeta(f));\n\tct.metadata.push(f);\n\tadd_rels(opts.wbrels, -1, \"metadata.\" + wbext, RELS.XLMETA);\n\n\tzip_add_file(zip, \"[Content_Types].xml\", write_ct(ct, opts));\n\tzip_add_file(zip, '_rels/.rels', write_rels(opts.rels));\n\tzip_add_file(zip, 'xl/_rels/workbook.' + wbext + '.rels', write_rels(opts.wbrels));\n\n\tdelete opts.revssf; delete opts.ssf;\n\treturn zip;\n}\n\nfunction write_zip_xlsx(wb/*:Workbook*/, opts/*:WriteOpts*/)/*:ZIP*/ {\n\t_shapeid = 1024;\n\tif(wb && !wb.SSF) {\n\t\twb.SSF = dup(table_fmt);\n\t}\n\tif(wb && wb.SSF) {\n\t\tmake_ssf(); SSF_load_table(wb.SSF);\n\t\t// $FlowIgnore\n\t\topts.revssf = evert_num(wb.SSF); opts.revssf[wb.SSF[65535]] = 0;\n\t\topts.ssf = wb.SSF;\n\t}\n\topts.rels = {}; opts.wbrels = {};\n\topts.Strings = /*::((*/[]/*:: :any):SST)*/; opts.Strings.Count = 0; opts.Strings.Unique = 0;\n\tif(browser_has_Map) opts.revStrings = new Map();\n\telse { opts.revStrings = {}; opts.revStrings.foo = []; delete opts.revStrings.foo; }\n\tvar wbext = \"xml\";\n\tvar vbafmt = VBAFMTS.indexOf(opts.bookType) > -1;\n\tvar ct = new_ct();\n\tfix_write_opts(opts = opts || {});\n\tvar zip = zip_new();\n\tvar f = \"\", rId = 0;\n\n\topts.cellXfs = [];\n\tget_cell_style(opts.cellXfs, {}, {revssf:{\"General\":0}});\n\n\tif(!wb.Props) wb.Props = {};\n\n\tf = \"docProps/core.xml\";\n\tzip_add_file(zip, f, write_core_props(wb.Props, opts));\n\tct.coreprops.push(f);\n\tadd_rels(opts.rels, 2, f, RELS.CORE_PROPS);\n\n\t/*::if(!wb.Props) throw \"unreachable\"; */\n\tf = \"docProps/app.xml\";\n\tif(wb.Props && wb.Props.SheetNames){/* empty */}\n\telse if(!wb.Workbook || !wb.Workbook.Sheets) wb.Props.SheetNames = wb.SheetNames;\n\telse {\n\t\tvar _sn = [];\n\t\tfor(var _i = 0; _i < wb.SheetNames.length; ++_i)\n\t\t\tif((wb.Workbook.Sheets[_i]||{}).Hidden != 2) _sn.push(wb.SheetNames[_i]);\n\t\twb.Props.SheetNames = _sn;\n\t}\n\twb.Props.Worksheets = wb.Props.SheetNames.length;\n\tzip_add_file(zip, f, write_ext_props(wb.Props, opts));\n\tct.extprops.push(f);\n\tadd_rels(opts.rels, 3, f, RELS.EXT_PROPS);\n\n\tif(wb.Custprops !== wb.Props && keys(wb.Custprops||{}).length > 0) {\n\t\tf = \"docProps/custom.xml\";\n\t\tzip_add_file(zip, f, write_cust_props(wb.Custprops, opts));\n\t\tct.custprops.push(f);\n\t\tadd_rels(opts.rels, 4, f, RELS.CUST_PROPS);\n\t}\n\n\tvar people = [\"SheetJ5\"];\n\topts.tcid = 0;\n\n\tfor(rId=1;rId <= wb.SheetNames.length; ++rId) {\n\t\tvar wsrels = {'!id':{}};\n\t\tvar ws = wb.Sheets[wb.SheetNames[rId-1]];\n\t\tvar _type = (ws || {})[\"!type\"] || \"sheet\";\n\t\tswitch(_type) {\n\t\tcase \"chart\":\n\t\t\t/* falls through */\n\t\tdefault:\n\t\t\tf = \"xl/worksheets/sheet\" + rId + \".\" + wbext;\n\t\t\tzip_add_file(zip, f, write_ws_xml(rId-1, opts, wb, wsrels));\n\t\t\tct.sheets.push(f);\n\t\t\tadd_rels(opts.wbrels, -1, \"worksheets/sheet\" + rId + \".\" + wbext, RELS.WS[0]);\n\t\t}\n\n\t\tif(ws) {\n\t\t\tvar comments = ws['!comments'];\n\t\t\tvar need_vml = false;\n\t\t\tvar cf = \"\";\n\t\t\tif(comments && comments.length > 0) {\n\t\t\t\tvar needtc = false;\n\t\t\t\tcomments.forEach(function(carr) {\n\t\t\t\t\tcarr[1].forEach(function(c) { if(c.T == true) needtc = true; });\n\t\t\t\t});\n\t\t\t\tif(needtc) {\n\t\t\t\t\tcf = \"xl/threadedComments/threadedComment\" + rId + \".\" + wbext;\n\t\t\t\t\tzip_add_file(zip, cf, write_tcmnt_xml(comments, people, opts));\n\t\t\t\t\tct.threadedcomments.push(cf);\n\t\t\t\t\tadd_rels(wsrels, -1, \"../threadedComments/threadedComment\" + rId + \".\" + wbext, RELS.TCMNT);\n\t\t\t\t}\n\n\t\t\t\tcf = \"xl/comments\" + rId + \".\" + wbext;\n\t\t\t\tzip_add_file(zip, cf, write_comments_xml(comments, opts));\n\t\t\t\tct.comments.push(cf);\n\t\t\t\tadd_rels(wsrels, -1, \"../comments\" + rId + \".\" + wbext, RELS.CMNT);\n\t\t\t\tneed_vml = true;\n\t\t\t}\n\t\t\tif(ws['!legacy']) {\n\t\t\t\tif(need_vml) zip_add_file(zip, \"xl/drawings/vmlDrawing\" + (rId) + \".vml\", write_comments_vml(rId, ws['!comments']));\n\t\t\t}\n\t\t\tdelete ws['!comments'];\n\t\t\tdelete ws['!legacy'];\n\t\t}\n\n\t\tif(wsrels['!id'].rId1) zip_add_file(zip, get_rels_path(f), write_rels(wsrels));\n\t}\n\n\tif(opts.Strings != null && opts.Strings.length > 0) {\n\t\tf = \"xl/sharedStrings.\" + wbext;\n\t\tzip_add_file(zip, f, write_sst_xml(opts.Strings, opts));\n\t\tct.strs.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"sharedStrings.\" + wbext, RELS.SST);\n\t}\n\n\tf = \"xl/workbook.\" + wbext;\n\tzip_add_file(zip, f, write_wb_xml(wb, opts));\n\tct.workbooks.push(f);\n\tadd_rels(opts.rels, 1, f, RELS.WB);\n\n\t/* TODO: something more intelligent with themes */\n\n\tf = \"xl/theme/theme1.xml\";\n\tzip_add_file(zip, f, write_theme(wb.Themes, opts));\n\tct.themes.push(f);\n\tadd_rels(opts.wbrels, -1, \"theme/theme1.xml\", RELS.THEME);\n\n\t/* TODO: something more intelligent with styles */\n\n\tf = \"xl/styles.\" + wbext;\n\tzip_add_file(zip, f, write_sty_xml(wb, opts));\n\tct.styles.push(f);\n\tadd_rels(opts.wbrels, -1, \"styles.\" + wbext, RELS.STY);\n\n\tif(wb.vbaraw && vbafmt) {\n\t\tf = \"xl/vbaProject.bin\";\n\t\tzip_add_file(zip, f, wb.vbaraw);\n\t\tct.vba.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"vbaProject.bin\", RELS.VBA);\n\t}\n\n\tf = \"xl/metadata.\" + wbext;\n\tzip_add_file(zip, f, write_xlmeta_xml());\n\tct.metadata.push(f);\n\tadd_rels(opts.wbrels, -1, \"metadata.\" + wbext, RELS.XLMETA);\n\n\tif(people.length > 1) {\n\t\tf = \"xl/persons/person.xml\";\n\t\tzip_add_file(zip, f, write_people_xml(people, opts));\n\t\tct.people.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"persons/person.xml\", RELS.PEOPLE);\n\t}\n\n\tzip_add_file(zip, \"[Content_Types].xml\", write_ct(ct, opts));\n\tzip_add_file(zip, '_rels/.rels', write_rels(opts.rels));\n\tzip_add_file(zip, 'xl/_rels/workbook.' + wbext + '.rels', write_rels(opts.wbrels));\n\n\tdelete opts.revssf; delete opts.ssf;\n\treturn zip;\n}\n\nfunction firstbyte(f/*:RawData*/,o/*:?TypeOpts*/)/*:Array<number>*/ {\n\tvar x = \"\";\n\tswitch((o||{}).type || \"base64\") {\n\t\tcase 'buffer': return [f[0], f[1], f[2], f[3], f[4], f[5], f[6], f[7]];\n\t\tcase 'base64': x = Base64_decode(f.slice(0,12)); break;\n\t\tcase 'binary': x = f; break;\n\t\tcase 'array': return [f[0], f[1], f[2], f[3], f[4], f[5], f[6], f[7]];\n\t\tdefault: throw new Error(\"Unrecognized type \" + (o && o.type || \"undefined\"));\n\t}\n\treturn [x.charCodeAt(0), x.charCodeAt(1), x.charCodeAt(2), x.charCodeAt(3), x.charCodeAt(4), x.charCodeAt(5), x.charCodeAt(6), x.charCodeAt(7)];\n}\n\nfunction read_cfb(cfb/*:CFBContainer*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tif(CFB.find(cfb, \"EncryptedPackage\")) return parse_xlsxcfb(cfb, opts);\n\treturn parse_xlscfb(cfb, opts);\n}\n\nfunction read_zip(data/*:RawData*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tvar zip, d = data;\n\tvar o = opts||{};\n\tif(!o.type) o.type = (has_buf && Buffer.isBuffer(data)) ? \"buffer\" : \"base64\";\n\tzip = zip_read(d, o);\n\treturn parse_zip(zip, o);\n}\n\nfunction read_plaintext(data/*:string*/, o/*:ParseOpts*/)/*:Workbook*/ {\n\tvar i = 0;\n\tmain: while(i < data.length) switch(data.charCodeAt(i)) {\n\t\tcase 0x0A: case 0x0D: case 0x20: ++i; break;\n\t\tcase 0x3C: return parse_xlml(data.slice(i),o);\n\t\tdefault: break main;\n\t}\n\treturn PRN.to_workbook(data, o);\n}\n\nfunction read_plaintext_raw(data/*:RawData*/, o/*:ParseOpts*/)/*:Workbook*/ {\n\tvar str = \"\", bytes = firstbyte(data, o);\n\tswitch(o.type) {\n\t\tcase 'base64': str = Base64_decode(data); break;\n\t\tcase 'binary': str = data; break;\n\t\tcase 'buffer': str = data.toString('binary'); break;\n\t\tcase 'array': str = cc2str(data); break;\n\t\tdefault: throw new Error(\"Unrecognized type \" + o.type);\n\t}\n\tif(bytes[0] == 0xEF && bytes[1] == 0xBB && bytes[2] == 0xBF) str = utf8read(str);\n\to.type = \"binary\";\n\treturn read_plaintext(str, o);\n}\n\nfunction read_utf16(data/*:RawData*/, o/*:ParseOpts*/)/*:Workbook*/ {\n\tvar d = data;\n\tif(o.type == 'base64') d = Base64_decode(d);\n\td = $cptable.utils.decode(1200, d.slice(2), 'str');\n\to.type = \"binary\";\n\treturn read_plaintext(d, o);\n}\n\nfunction bstrify(data/*:string*/)/*:string*/ {\n\treturn !data.match(/[^\\x00-\\x7F]/) ? data : utf8write(data);\n}\n\nfunction read_prn(data, d, o, str) {\n\tif(str) { o.type = \"string\"; return PRN.to_workbook(data, o); }\n\treturn PRN.to_workbook(d, o);\n}\n\nfunction readSync(data/*:RawData*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\treset_cp();\n\tvar o = opts||{};\n\tif(typeof ArrayBuffer !== 'undefined' && data instanceof ArrayBuffer) return readSync(new Uint8Array(data), (o = dup(o), o.type = \"array\", o));\n\tif(typeof Uint8Array !== 'undefined' && data instanceof Uint8Array && !o.type) o.type = typeof Deno !== \"undefined\" ? \"buffer\" : \"array\";\n\tvar d = data, n = [0,0,0,0], str = false;\n\tif(o.cellStyles) { o.cellNF = true; o.sheetStubs = true; }\n\t_ssfopts = {};\n\tif(o.dateNF) _ssfopts.dateNF = o.dateNF;\n\tif(!o.type) o.type = (has_buf && Buffer.isBuffer(data)) ? \"buffer\" : \"base64\";\n\tif(o.type == \"file\") { o.type = has_buf ? \"buffer\" : \"binary\"; d = read_binary(data); if(typeof Uint8Array !== 'undefined' && !has_buf) o.type = \"array\"; }\n\tif(o.type == \"string\") { str = true; o.type = \"binary\"; o.codepage = 65001; d = bstrify(data); }\n\tif(o.type == 'array' && typeof Uint8Array !== 'undefined' && data instanceof Uint8Array && typeof ArrayBuffer !== 'undefined') {\n\t\t// $FlowIgnore\n\t\tvar ab=new ArrayBuffer(3), vu=new Uint8Array(ab); vu.foo=\"bar\";\n\t\t// $FlowIgnore\n\t\tif(!vu.foo) {o=dup(o); o.type='array'; return readSync(ab2a(d), o);}\n\t}\n\tswitch((n = firstbyte(d, o))[0]) {\n\t\tcase 0xD0: if(n[1] === 0xCF && n[2] === 0x11 && n[3] === 0xE0 && n[4] === 0xA1 && n[5] === 0xB1 && n[6] === 0x1A && n[7] === 0xE1) return read_cfb(CFB.read(d, o), o); break;\n\t\tcase 0x09: if(n[1] <= 0x08) return parse_xlscfb(d, o); break;\n\t\tcase 0x3C: return parse_xlml(d, o);\n\t\tcase 0x49:\n\t\t\tif(n[1] === 0x49 && n[2] === 0x2a && n[3] === 0x00) throw new Error(\"TIFF Image File is not a spreadsheet\");\n\t\t\tif(n[1] === 0x44) return read_wb_ID(d, o);\n\t\t\tbreak;\n\t\tcase 0x54: if(n[1] === 0x41 && n[2] === 0x42 && n[3] === 0x4C) return DIF.to_workbook(d, o); break;\n\t\tcase 0x50: return (n[1] === 0x4B && n[2] < 0x09 && n[3] < 0x09) ? read_zip(d, o) : read_prn(data, d, o, str);\n\t\tcase 0xEF: return n[3] === 0x3C ? parse_xlml(d, o) : read_prn(data, d, o, str);\n\t\tcase 0xFF:\n\t\t\tif(n[1] === 0xFE) { return read_utf16(d, o); }\n\t\t\telse if(n[1] === 0x00 && n[2] === 0x02 && n[3] === 0x00) return WK_.to_workbook(d, o);\n\t\t\tbreak;\n\t\tcase 0x00:\n\t\t\tif(n[1] === 0x00) {\n\t\t\t\tif(n[2] >= 0x02 && n[3] === 0x00) return WK_.to_workbook(d, o);\n\t\t\t\tif(n[2] === 0x00 && (n[3] === 0x08 || n[3] === 0x09)) return WK_.to_workbook(d, o);\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 0x03: case 0x83: case 0x8B: case 0x8C: return DBF.to_workbook(d, o);\n\t\tcase 0x7B: if(n[1] === 0x5C && n[2] === 0x72 && n[3] === 0x74) return RTF.to_workbook(d, o); break;\n\t\tcase 0x0A: case 0x0D: case 0x20: return read_plaintext_raw(d, o);\n\t\tcase 0x89: if(n[1] === 0x50 && n[2] === 0x4E && n[3] === 0x47) throw new Error(\"PNG Image File is not a spreadsheet\"); break;\n\t}\n\tif(DBF_SUPPORTED_VERSIONS.indexOf(n[0]) > -1 && n[2] <= 12 && n[3] <= 31) return DBF.to_workbook(d, o);\n\treturn read_prn(data, d, o, str);\n}\n\nfunction readFileSync(filename/*:string*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tvar o = opts||{}; o.type = 'file';\n\treturn readSync(filename, o);\n}\nfunction write_cfb_ctr(cfb/*:CFBContainer*/, o/*:WriteOpts*/)/*:any*/ {\n\tswitch(o.type) {\n\t\tcase \"base64\": case \"binary\": break;\n\t\tcase \"buffer\": case \"array\": o.type = \"\"; break;\n\t\tcase \"file\": return write_dl(o.file, CFB.write(cfb, {type:has_buf ? 'buffer' : \"\"}));\n\t\tcase \"string\": throw new Error(\"'string' output type invalid for '\" + o.bookType + \"' files\");\n\t\tdefault: throw new Error(\"Unrecognized type \" + o.type);\n\t}\n\treturn CFB.write(cfb, o);\n}\n\n/*:: declare var encrypt_agile:any; */\nfunction write_zip_type(wb/*:Workbook*/, opts/*:?WriteOpts*/)/*:any*/ {\n\tvar o = dup(opts||{});\n\tvar z = write_zip(wb, o);\n\treturn write_zip_denouement(z, o);\n}\nfunction write_zip_typeXLSX(wb/*:Workbook*/, opts/*:?WriteOpts*/)/*:any*/ {\n\tvar o = dup(opts||{});\n\tvar z = write_zip_xlsx(wb, o);\n\treturn write_zip_denouement(z, o);\n}\nfunction write_zip_denouement(z/*:any*/, o/*:?WriteOpts*/)/*:any*/ {\n\tvar oopts = {};\n\tvar ftype = has_buf ? \"nodebuffer\" : (typeof Uint8Array !== \"undefined\" ? \"array\" : \"string\");\n\tif(o.compression) oopts.compression = 'DEFLATE';\n\tif(o.password) oopts.type = ftype;\n\telse switch(o.type) {\n\t\tcase \"base64\": oopts.type = \"base64\"; break;\n\t\tcase \"binary\": oopts.type = \"string\"; break;\n\t\tcase \"string\": throw new Error(\"'string' output type invalid for '\" + o.bookType + \"' files\");\n\t\tcase \"buffer\":\n\t\tcase \"file\": oopts.type = ftype; break;\n\t\tdefault: throw new Error(\"Unrecognized type \" + o.type);\n\t}\n\tvar out = z.FullPaths ? CFB.write(z, {fileType:\"zip\", type: /*::(*/{\"nodebuffer\": \"buffer\", \"string\": \"binary\"}/*:: :any)*/[oopts.type] || oopts.type, compression: !!o.compression}) : z.generate(oopts);\n\tif(typeof Deno !== \"undefined\") {\n\t\tif(typeof out == \"string\") {\n\t\t\tif(o.type == \"binary\" || o.type == \"base64\") return out;\n\t\t\tout = new Uint8Array(s2ab(out));\n\t\t}\n\t}\n/*jshint -W083 */\n\tif(o.password && typeof encrypt_agile !== 'undefined') return write_cfb_ctr(encrypt_agile(out, o.password), o); // eslint-disable-line no-undef\n/*jshint +W083 */\n\tif(o.type === \"file\") return write_dl(o.file, out);\n\treturn o.type == \"string\" ? utf8read(/*::(*/out/*:: :any)*/) : out;\n}\n\nfunction write_cfb_type(wb/*:Workbook*/, opts/*:?WriteOpts*/)/*:any*/ {\n\tvar o = opts||{};\n\tvar cfb/*:CFBContainer*/ = write_xlscfb(wb, o);\n\treturn write_cfb_ctr(cfb, o);\n}\n\nfunction write_string_type(out/*:string*/, opts/*:WriteOpts*/, bom/*:?string*/)/*:any*/ {\n\tif(!bom) bom = \"\";\n\tvar o = bom + out;\n\tswitch(opts.type) {\n\t\tcase \"base64\": return Base64_encode(utf8write(o));\n\t\tcase \"binary\": return utf8write(o);\n\t\tcase \"string\": return out;\n\t\tcase \"file\": return write_dl(opts.file, o, 'utf8');\n\t\tcase \"buffer\": {\n\t\t\tif(has_buf) return Buffer_from(o, 'utf8');\n\t\t\telse if(typeof TextEncoder !== \"undefined\") return new TextEncoder().encode(o);\n\t\t\telse return write_string_type(o, {type:'binary'}).split(\"\").map(function(c) { return c.charCodeAt(0); });\n\t\t}\n\t}\n\tthrow new Error(\"Unrecognized type \" + opts.type);\n}\n\nfunction write_stxt_type(out/*:string*/, opts/*:WriteOpts*/)/*:any*/ {\n\tswitch(opts.type) {\n\t\tcase \"base64\": return Base64_encode(out);\n\t\tcase \"binary\": return out;\n\t\tcase \"string\": return out; /* override in sheet_to_txt */\n\t\tcase \"file\": return write_dl(opts.file, out, 'binary');\n\t\tcase \"buffer\": {\n\t\t\tif(has_buf) return Buffer_from(out, 'binary');\n\t\t\telse return out.split(\"\").map(function(c) { return c.charCodeAt(0); });\n\t\t}\n\t}\n\tthrow new Error(\"Unrecognized type \" + opts.type);\n}\n\n/* TODO: test consistency */\nfunction write_binary_type(out, opts/*:WriteOpts*/)/*:any*/ {\n\tswitch(opts.type) {\n\t\tcase \"string\":\n\t\tcase \"base64\":\n\t\tcase \"binary\":\n\t\t\tvar bstr = \"\";\n\t\t\t// $FlowIgnore\n\t\t\tfor(var i = 0; i < out.length; ++i) bstr += String.fromCharCode(out[i]);\n\t\t\treturn opts.type == 'base64' ? Base64_encode(bstr) : opts.type == 'string' ? utf8read(bstr) : bstr;\n\t\tcase \"file\": return write_dl(opts.file, out);\n\t\tcase \"buffer\": return out;\n\t\tdefault: throw new Error(\"Unrecognized type \" + opts.type);\n\t}\n}\n\nfunction writeSyncXLSX(wb/*:Workbook*/, opts/*:?WriteOpts*/) {\n\treset_cp();\n\tcheck_wb(wb);\n\tvar o = dup(opts||{});\n\tif(o.cellStyles) { o.cellNF = true; o.sheetStubs = true; }\n\tif(o.type == \"array\") { o.type = \"binary\"; var out/*:string*/ = (writeSyncXLSX(wb, o)/*:any*/); o.type = \"array\"; return s2ab(out); }\n\treturn write_zip_typeXLSX(wb, o);\n}\n\nfunction writeSync(wb/*:Workbook*/, opts/*:?WriteOpts*/) {\n\treset_cp();\n\tcheck_wb(wb);\n\tvar o = dup(opts||{});\n\tif(o.cellStyles) { o.cellNF = true; o.sheetStubs = true; }\n\tif(o.type == \"array\") { o.type = \"binary\"; var out/*:string*/ = (writeSync(wb, o)/*:any*/); o.type = \"array\"; return s2ab(out); }\n\tvar idx = 0;\n\tif(o.sheet) {\n\t\tif(typeof o.sheet == \"number\") idx = o.sheet;\n\t\telse idx = wb.SheetNames.indexOf(o.sheet);\n\t\tif(!wb.SheetNames[idx]) throw new Error(\"Sheet not found: \" + o.sheet + \" : \" + (typeof o.sheet));\n\t}\n\tswitch(o.bookType || 'xlsb') {\n\t\tcase 'xml':\n\t\tcase 'xlml': return write_string_type(write_xlml(wb, o), o);\n\t\tcase 'slk':\n\t\tcase 'sylk': return write_string_type(SYLK.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'htm':\n\t\tcase 'html': return write_string_type(sheet_to_html(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'txt': return write_stxt_type(sheet_to_txt(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'csv': return write_string_type(sheet_to_csv(wb.Sheets[wb.SheetNames[idx]], o), o, \"\\ufeff\");\n\t\tcase 'dif': return write_string_type(DIF.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'dbf': return write_binary_type(DBF.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'prn': return write_string_type(PRN.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'rtf': return write_string_type(RTF.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'eth': return write_string_type(ETH.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'fods': return write_string_type(write_ods(wb, o), o);\n\t\tcase 'wk1': return write_binary_type(WK_.sheet_to_wk1(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'wk3': return write_binary_type(WK_.book_to_wk3(wb, o), o);\n\t\tcase 'biff2': if(!o.biff) o.biff = 2; /* falls through */\n\t\tcase 'biff3': if(!o.biff) o.biff = 3; /* falls through */\n\t\tcase 'biff4': if(!o.biff) o.biff = 4; return write_binary_type(write_biff_buf(wb, o), o);\n\t\tcase 'biff5': if(!o.biff) o.biff = 5; /* falls through */\n\t\tcase 'biff8':\n\t\tcase 'xla':\n\t\tcase 'xls': if(!o.biff) o.biff = 8; return write_cfb_type(wb, o);\n\t\tcase 'xlsx':\n\t\tcase 'xlsm':\n\t\tcase 'xlam':\n\t\tcase 'xlsb':\n\t\tcase 'numbers':\n\t\tcase 'ods': return write_zip_type(wb, o);\n\t\tdefault: throw new Error (\"Unrecognized bookType |\" + o.bookType + \"|\");\n\t}\n}\n\nfunction resolve_book_type(o/*:WriteFileOpts*/) {\n\tif(o.bookType) return;\n\tvar _BT = {\n\t\t\"xls\": \"biff8\",\n\t\t\"htm\": \"html\",\n\t\t\"slk\": \"sylk\",\n\t\t\"socialcalc\": \"eth\",\n\t\t\"Sh33tJS\": \"WTF\"\n\t};\n\tvar ext = o.file.slice(o.file.lastIndexOf(\".\")).toLowerCase();\n\tif(ext.match(/^\\.[a-z]+$/)) o.bookType = ext.slice(1);\n\to.bookType = _BT[o.bookType] || o.bookType;\n}\n\nfunction writeFileSync(wb/*:Workbook*/, filename/*:string*/, opts/*:?WriteFileOpts*/) {\n\tvar o = opts||{}; o.type = 'file';\n\to.file = filename;\n\tresolve_book_type(o);\n\treturn writeSync(wb, o);\n}\n\nfunction writeFileSyncXLSX(wb/*:Workbook*/, filename/*:string*/, opts/*:?WriteFileOpts*/) {\n\tvar o = opts||{}; o.type = 'file';\n\to.file = filename;\n\tresolve_book_type(o);\n\treturn writeSyncXLSX(wb, o);\n}\n\n\nfunction writeFileAsync(filename/*:string*/, wb/*:Workbook*/, opts/*:?WriteFileOpts*/, cb/*:?(e?:ErrnoError)=>void*/) {\n\tvar o = opts||{}; o.type = 'file';\n\to.file = filename;\n\tresolve_book_type(o);\n\to.type = 'buffer';\n\tvar _cb = cb; if(!(_cb instanceof Function)) _cb = (opts/*:any*/);\n\treturn _fs.writeFile(filename, writeSync(wb, o), _cb);\n}\n/*::\ntype MJRObject = {\n\trow: any;\n\tisempty: boolean;\n};\n*/\nfunction make_json_row(sheet/*:Worksheet*/, r/*:Range*/, R/*:number*/, cols/*:Array<string>*/, header/*:number*/, hdr/*:Array<any>*/, dense/*:boolean*/, o/*:Sheet2JSONOpts*/)/*:MJRObject*/ {\n\tvar rr = encode_row(R);\n\tvar defval = o.defval, raw = o.raw || !Object.prototype.hasOwnProperty.call(o, \"raw\");\n\tvar isempty = true;\n\tvar row/*:any*/ = (header === 1) ? [] : {};\n\tif(header !== 1) {\n\t\tif(Object.defineProperty) try { Object.defineProperty(row, '__rowNum__', {value:R, enumerable:false}); } catch(e) { row.__rowNum__ = R; }\n\t\telse row.__rowNum__ = R;\n\t}\n\tif(!dense || sheet[R]) for (var C = r.s.c; C <= r.e.c; ++C) {\n\t\tvar val = dense ? sheet[R][C] : sheet[cols[C] + rr];\n\t\tif(val === undefined || val.t === undefined) {\n\t\t\tif(defval === undefined) continue;\n\t\t\tif(hdr[C] != null) { row[hdr[C]] = defval; }\n\t\t\tcontinue;\n\t\t}\n\t\tvar v = val.v;\n\t\tswitch(val.t){\n\t\t\tcase 'z': if(v == null) break; continue;\n\t\t\tcase 'e': v = (v == 0 ? null : void 0); break;\n\t\t\tcase 's': case 'd': case 'b': case 'n': break;\n\t\t\tdefault: throw new Error('unrecognized type ' + val.t);\n\t\t}\n\t\tif(hdr[C] != null) {\n\t\t\tif(v == null) {\n\t\t\t\tif(val.t == \"e\" && v === null) row[hdr[C]] = null;\n\t\t\t\telse if(defval !== undefined) row[hdr[C]] = defval;\n\t\t\t\telse if(raw && v === null) row[hdr[C]] = null;\n\t\t\t\telse continue;\n\t\t\t} else {\n\t\t\t\trow[hdr[C]] = raw && (val.t !== \"n\" || (val.t === \"n\" && o.rawNumbers !== false)) ? v : format_cell(val,v,o);\n\t\t\t}\n\t\t\tif(v != null) isempty = false;\n\t\t}\n\t}\n\treturn { row: row, isempty: isempty };\n}\n\n\nfunction sheet_to_json(sheet/*:Worksheet*/, opts/*:?Sheet2JSONOpts*/) {\n\tif(sheet == null || sheet[\"!ref\"] == null) return [];\n\tvar val = {t:'n',v:0}, header = 0, offset = 1, hdr/*:Array<any>*/ = [], v=0, vv=\"\";\n\tvar r = {s:{r:0,c:0},e:{r:0,c:0}};\n\tvar o = opts || {};\n\tvar range = o.range != null ? o.range : sheet[\"!ref\"];\n\tif(o.header === 1) header = 1;\n\telse if(o.header === \"A\") header = 2;\n\telse if(Array.isArray(o.header)) header = 3;\n\telse if(o.header == null) header = 0;\n\tswitch(typeof range) {\n\t\tcase 'string': r = safe_decode_range(range); break;\n\t\tcase 'number': r = safe_decode_range(sheet[\"!ref\"]); r.s.r = range; break;\n\t\tdefault: r = range;\n\t}\n\tif(header > 0) offset = 0;\n\tvar rr = encode_row(r.s.r);\n\tvar cols/*:Array<string>*/ = [];\n\tvar out/*:Array<any>*/ = [];\n\tvar outi = 0, counter = 0;\n\tvar dense = Array.isArray(sheet);\n\tvar R = r.s.r, C = 0;\n\tvar header_cnt = {};\n\tif(dense && !sheet[R]) sheet[R] = [];\n\tvar colinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!cols\"] || [];\n\tvar rowinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!rows\"] || [];\n\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\tif(((colinfo[C]||{}).hidden)) continue;\n\t\tcols[C] = encode_col(C);\n\t\tval = dense ? sheet[R][C] : sheet[cols[C] + rr];\n\t\tswitch(header) {\n\t\t\tcase 1: hdr[C] = C - r.s.c; break;\n\t\t\tcase 2: hdr[C] = cols[C]; break;\n\t\t\tcase 3: hdr[C] = o.header[C - r.s.c]; break;\n\t\t\tdefault:\n\t\t\t\tif(val == null) val = {w: \"__EMPTY\", t: \"s\"};\n\t\t\t\tvv = v = format_cell(val, null, o);\n\t\t\t\tcounter = header_cnt[v] || 0;\n\t\t\t\tif(!counter) header_cnt[v] = 1;\n\t\t\t\telse {\n\t\t\t\t\tdo { vv = v + \"_\" + (counter++); } while(header_cnt[vv]); header_cnt[v] = counter;\n\t\t\t\t\theader_cnt[vv] = 1;\n\t\t\t\t}\n\t\t\t\thdr[C] = vv;\n\t\t}\n\t}\n\tfor (R = r.s.r + offset; R <= r.e.r; ++R) {\n\t\tif ((rowinfo[R]||{}).hidden) continue;\n\t\tvar row = make_json_row(sheet, r, R, cols, header, hdr, dense, o);\n\t\tif((row.isempty === false) || (header === 1 ? o.blankrows !== false : !!o.blankrows)) out[outi++] = row.row;\n\t}\n\tout.length = outi;\n\treturn out;\n}\n\nvar qreg = /\"/g;\nfunction make_csv_row(sheet/*:Worksheet*/, r/*:Range*/, R/*:number*/, cols/*:Array<string>*/, fs/*:number*/, rs/*:number*/, FS/*:string*/, o/*:Sheet2CSVOpts*/)/*:?string*/ {\n\tvar isempty = true;\n\tvar row/*:Array<string>*/ = [], txt = \"\", rr = encode_row(R);\n\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\tif (!cols[C]) continue;\n\t\tvar val = o.dense ? (sheet[R]||[])[C]: sheet[cols[C] + rr];\n\t\tif(val == null) txt = \"\";\n\t\telse if(val.v != null) {\n\t\t\tisempty = false;\n\t\t\ttxt = ''+(o.rawNumbers && val.t == \"n\" ? val.v : format_cell(val, null, o));\n\t\t\tfor(var i = 0, cc = 0; i !== txt.length; ++i) if((cc = txt.charCodeAt(i)) === fs || cc === rs || cc === 34 || o.forceQuotes) {txt = \"\\\"\" + txt.replace(qreg, '\"\"') + \"\\\"\"; break; }\n\t\t\tif(txt == \"ID\") txt = '\"ID\"';\n\t\t} else if(val.f != null && !val.F) {\n\t\t\tisempty = false;\n\t\t\ttxt = '=' + val.f; if(txt.indexOf(\",\") >= 0) txt = '\"' + txt.replace(qreg, '\"\"') + '\"';\n\t\t} else txt = \"\";\n\t\t/* NOTE: Excel CSV does not support array formulae */\n\t\trow.push(txt);\n\t}\n\tif(o.blankrows === false && isempty) return null;\n\treturn row.join(FS);\n}\n\nfunction sheet_to_csv(sheet/*:Worksheet*/, opts/*:?Sheet2CSVOpts*/)/*:string*/ {\n\tvar out/*:Array<string>*/ = [];\n\tvar o = opts == null ? {} : opts;\n\tif(sheet == null || sheet[\"!ref\"] == null) return \"\";\n\tvar r = safe_decode_range(sheet[\"!ref\"]);\n\tvar FS = o.FS !== undefined ? o.FS : \",\", fs = FS.charCodeAt(0);\n\tvar RS = o.RS !== undefined ? o.RS : \"\\n\", rs = RS.charCodeAt(0);\n\tvar endregex = new RegExp((FS==\"|\" ? \"\\\\|\" : FS)+\"+$\");\n\tvar row = \"\", cols/*:Array<string>*/ = [];\n\to.dense = Array.isArray(sheet);\n\tvar colinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!cols\"] || [];\n\tvar rowinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!rows\"] || [];\n\tfor(var C = r.s.c; C <= r.e.c; ++C) if (!((colinfo[C]||{}).hidden)) cols[C] = encode_col(C);\n\tvar w = 0;\n\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\tif ((rowinfo[R]||{}).hidden) continue;\n\t\trow = make_csv_row(sheet, r, R, cols, fs, rs, FS, o);\n\t\tif(row == null) { continue; }\n\t\tif(o.strip) row = row.replace(endregex,\"\");\n\t\tif(row || (o.blankrows !== false)) out.push((w++ ? RS : \"\") + row);\n\t}\n\tdelete o.dense;\n\treturn out.join(\"\");\n}\n\nfunction sheet_to_txt(sheet/*:Worksheet*/, opts/*:?Sheet2CSVOpts*/) {\n\tif(!opts) opts = {}; opts.FS = \"\\t\"; opts.RS = \"\\n\";\n\tvar s = sheet_to_csv(sheet, opts);\n\tif(typeof $cptable == 'undefined' || opts.type == 'string') return s;\n\tvar o = $cptable.utils.encode(1200, s, 'str');\n\treturn String.fromCharCode(255) + String.fromCharCode(254) + o;\n}\n\nfunction sheet_to_formulae(sheet/*:Worksheet*/)/*:Array<string>*/ {\n\tvar y = \"\", x, val=\"\";\n\tif(sheet == null || sheet[\"!ref\"] == null) return [];\n\tvar r = safe_decode_range(sheet['!ref']), rr = \"\", cols/*:Array<string>*/ = [], C;\n\tvar cmds/*:Array<string>*/ = [];\n\tvar dense = Array.isArray(sheet);\n\tfor(C = r.s.c; C <= r.e.c; ++C) cols[C] = encode_col(C);\n\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\trr = encode_row(R);\n\t\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\t\ty = cols[C] + rr;\n\t\t\tx = dense ? (sheet[R]||[])[C] : sheet[y];\n\t\t\tval = \"\";\n\t\t\tif(x === undefined) continue;\n\t\t\telse if(x.F != null) {\n\t\t\t\ty = x.F;\n\t\t\t\tif(!x.f) continue;\n\t\t\t\tval = x.f;\n\t\t\t\tif(y.indexOf(\":\") == -1) y = y + \":\" + y;\n\t\t\t}\n\t\t\tif(x.f != null) val = x.f;\n\t\t\telse if(x.t == 'z') continue;\n\t\t\telse if(x.t == 'n' && x.v != null) val = \"\" + x.v;\n\t\t\telse if(x.t == 'b') val = x.v ? \"TRUE\" : \"FALSE\";\n\t\t\telse if(x.w !== undefined) val = \"'\" + x.w;\n\t\t\telse if(x.v === undefined) continue;\n\t\t\telse if(x.t == 's') val = \"'\" + x.v;\n\t\t\telse val = \"\"+x.v;\n\t\t\tcmds[cmds.length] = y + \"=\" + val;\n\t\t}\n\t}\n\treturn cmds;\n}\n\nfunction sheet_add_json(_ws/*:?Worksheet*/, js/*:Array<any>*/, opts)/*:Worksheet*/ {\n\tvar o = opts || {};\n\tvar offset = +!o.skipHeader;\n\tvar ws/*:Worksheet*/ = _ws || ({}/*:any*/);\n\tvar _R = 0, _C = 0;\n\tif(ws && o.origin != null) {\n\t\tif(typeof o.origin == 'number') _R = o.origin;\n\t\telse {\n\t\t\tvar _origin/*:CellAddress*/ = typeof o.origin == \"string\" ? decode_cell(o.origin) : o.origin;\n\t\t\t_R = _origin.r; _C = _origin.c;\n\t\t}\n\t}\n\tvar cell/*:Cell*/;\n\tvar range/*:Range*/ = ({s: {c:0, r:0}, e: {c:_C, r:_R + js.length - 1 + offset}}/*:any*/);\n\tif(ws['!ref']) {\n\t\tvar _range = safe_decode_range(ws['!ref']);\n\t\trange.e.c = Math.max(range.e.c, _range.e.c);\n\t\trange.e.r = Math.max(range.e.r, _range.e.r);\n\t\tif(_R == -1) { _R = _range.e.r + 1; range.e.r = _R + js.length - 1 + offset; }\n\t} else {\n\t\tif(_R == -1) { _R = 0; range.e.r = js.length - 1 + offset; }\n\t}\n\tvar hdr/*:Array<string>*/ = o.header || [], C = 0;\n\n\tjs.forEach(function (JS, R/*:number*/) {\n\t\tkeys(JS).forEach(function(k) {\n\t\t\tif((C=hdr.indexOf(k)) == -1) hdr[C=hdr.length] = k;\n\t\t\tvar v = JS[k];\n\t\t\tvar t = 'z';\n\t\t\tvar z = \"\";\n\t\t\tvar ref = encode_cell({c:_C + C,r:_R + R + offset});\n\t\t\tcell = ws_get_cell_stub(ws, ref);\n\t\t\tif(v && typeof v === 'object' && !(v instanceof Date)){\n\t\t\t\tws[ref] = v;\n\t\t\t} else {\n\t\t\t\tif(typeof v == 'number') t = 'n';\n\t\t\t\telse if(typeof v == 'boolean') t = 'b';\n\t\t\t\telse if(typeof v == 'string') t = 's';\n\t\t\t\telse if(v instanceof Date) {\n\t\t\t\t\tt = 'd';\n\t\t\t\t\tif(!o.cellDates) { t = 'n'; v = datenum(v); }\n\t\t\t\t\tz = (o.dateNF || table_fmt[14]);\n\t\t\t\t}\n\t\t\t\telse if(v === null && o.nullError) { t = 'e'; v = 0; }\n\t\t\t\tif(!cell) ws[ref] = cell = ({t:t, v:v}/*:any*/);\n\t\t\t\telse {\n\t\t\t\t\tcell.t = t; cell.v = v;\n\t\t\t\t\tdelete cell.w; delete cell.R;\n\t\t\t\t\tif(z) cell.z = z;\n\t\t\t\t}\n\t\t\t\tif(z) cell.z = z;\n\t\t\t}\n\t\t});\n\t});\n\trange.e.c = Math.max(range.e.c, _C + hdr.length - 1);\n\tvar __R = encode_row(_R);\n\tif(offset) for(C = 0; C < hdr.length; ++C) ws[encode_col(C + _C) + __R] = {t:'s', v:hdr[C]};\n\tws['!ref'] = encode_range(range);\n\treturn ws;\n}\nfunction json_to_sheet(js/*:Array<any>*/, opts)/*:Worksheet*/ { return sheet_add_json(null, js, opts); }\n\n/* get cell, creating a stub if necessary */\nfunction ws_get_cell_stub(ws/*:Worksheet*/, R, C/*:?number*/)/*:Cell*/ {\n\t/* A1 cell address */\n\tif(typeof R == \"string\") {\n\t\t/* dense */\n\t\tif(Array.isArray(ws)) {\n\t\t\tvar RC = decode_cell(R);\n\t\t\tif(!ws[RC.r]) ws[RC.r] = [];\n\t\t\treturn ws[RC.r][RC.c] || (ws[RC.r][RC.c] = {t:'z'});\n\t\t}\n\t\treturn ws[R] || (ws[R] = {t:'z'});\n\t}\n\t/* cell address object */\n\tif(typeof R != \"number\") return ws_get_cell_stub(ws, encode_cell(R));\n\t/* R and C are 0-based indices */\n\treturn ws_get_cell_stub(ws, encode_cell({r:R,c:C||0}));\n}\n\n/* find sheet index for given name / validate index */\nfunction wb_sheet_idx(wb/*:Workbook*/, sh/*:number|string*/) {\n\tif(typeof sh == \"number\") {\n\t\tif(sh >= 0 && wb.SheetNames.length > sh) return sh;\n\t\tthrow new Error(\"Cannot find sheet # \" + sh);\n\t} else if(typeof sh == \"string\") {\n\t\tvar idx = wb.SheetNames.indexOf(sh);\n\t\tif(idx > -1) return idx;\n\t\tthrow new Error(\"Cannot find sheet name |\" + sh + \"|\");\n\t} else throw new Error(\"Cannot find sheet |\" + sh + \"|\");\n}\n\n/* simple blank workbook object */\nfunction book_new()/*:Workbook*/ {\n\treturn { SheetNames: [], Sheets: {} };\n}\n\n/* add a worksheet to the end of a given workbook */\nfunction book_append_sheet(wb/*:Workbook*/, ws/*:Worksheet*/, name/*:?string*/, roll/*:?boolean*/)/*:string*/ {\n\tvar i = 1;\n\tif(!name) for(; i <= 0xFFFF; ++i, name = undefined) if(wb.SheetNames.indexOf(name = \"Sheet\" + i) == -1) break;\n\tif(!name || wb.SheetNames.length >= 0xFFFF) throw new Error(\"Too many worksheets\");\n\tif(roll && wb.SheetNames.indexOf(name) >= 0) {\n\t\tvar m = name.match(/(^.*?)(\\d+)$/);\n\t\ti = m && +m[2] || 0;\n\t\tvar root = m && m[1] || name;\n\t\tfor(++i; i <= 0xFFFF; ++i) if(wb.SheetNames.indexOf(name = root + i) == -1) break;\n\t}\n\tcheck_ws_name(name);\n\tif(wb.SheetNames.indexOf(name) >= 0) throw new Error(\"Worksheet with name |\" + name + \"| already exists!\");\n\n\twb.SheetNames.push(name);\n\twb.Sheets[name] = ws;\n\treturn name;\n}\n\n/* set sheet visibility (visible/hidden/very hidden) */\nfunction book_set_sheet_visibility(wb/*:Workbook*/, sh/*:number|string*/, vis/*:number*/) {\n\tif(!wb.Workbook) wb.Workbook = {};\n\tif(!wb.Workbook.Sheets) wb.Workbook.Sheets = [];\n\n\tvar idx = wb_sheet_idx(wb, sh);\n\t// $FlowIgnore\n\tif(!wb.Workbook.Sheets[idx]) wb.Workbook.Sheets[idx] = {};\n\n\tswitch(vis) {\n\t\tcase 0: case 1: case 2: break;\n\t\tdefault: throw new Error(\"Bad sheet visibility setting \" + vis);\n\t}\n\t// $FlowIgnore\n\twb.Workbook.Sheets[idx].Hidden = vis;\n}\n\n/* set number format */\nfunction cell_set_number_format(cell/*:Cell*/, fmt/*:string|number*/) {\n\tcell.z = fmt;\n\treturn cell;\n}\n\n/* set cell hyperlink */\nfunction cell_set_hyperlink(cell/*:Cell*/, target/*:string*/, tooltip/*:?string*/) {\n\tif(!target) {\n\t\tdelete cell.l;\n\t} else {\n\t\tcell.l = ({ Target: target }/*:Hyperlink*/);\n\t\tif(tooltip) cell.l.Tooltip = tooltip;\n\t}\n\treturn cell;\n}\nfunction cell_set_internal_link(cell/*:Cell*/, range/*:string*/, tooltip/*:?string*/) { return cell_set_hyperlink(cell, \"#\" + range, tooltip); }\n\n/* add to cell comments */\nfunction cell_add_comment(cell/*:Cell*/, text/*:string*/, author/*:?string*/) {\n\tif(!cell.c) cell.c = [];\n\tcell.c.push({t:text, a:author||\"SheetJS\"});\n}\n\n/* set array formula and flush related cells */\nfunction sheet_set_array_formula(ws/*:Worksheet*/, range, formula/*:string*/, dynamic/*:boolean*/) {\n\tvar rng = typeof range != \"string\" ? range : safe_decode_range(range);\n\tvar rngstr = typeof range == \"string\" ? range : encode_range(range);\n\tfor(var R = rng.s.r; R <= rng.e.r; ++R) for(var C = rng.s.c; C <= rng.e.c; ++C) {\n\t\tvar cell = ws_get_cell_stub(ws, R, C);\n\t\tcell.t = 'n';\n\t\tcell.F = rngstr;\n\t\tdelete cell.v;\n\t\tif(R == rng.s.r && C == rng.s.c) {\n\t\t\tcell.f = formula;\n\t\t\tif(dynamic) cell.D = true;\n\t\t}\n\t}\n\treturn ws;\n}\n\nvar utils/*:any*/ = {\n\tencode_col: encode_col,\n\tencode_row: encode_row,\n\tencode_cell: encode_cell,\n\tencode_range: encode_range,\n\tdecode_col: decode_col,\n\tdecode_row: decode_row,\n\tsplit_cell: split_cell,\n\tdecode_cell: decode_cell,\n\tdecode_range: decode_range,\n\tformat_cell: format_cell,\n\tsheet_add_aoa: sheet_add_aoa,\n\tsheet_add_json: sheet_add_json,\n\tsheet_add_dom: sheet_add_dom,\n\taoa_to_sheet: aoa_to_sheet,\n\tjson_to_sheet: json_to_sheet,\n\ttable_to_sheet: parse_dom_table,\n\ttable_to_book: table_to_book,\n\tsheet_to_csv: sheet_to_csv,\n\tsheet_to_txt: sheet_to_txt,\n\tsheet_to_json: sheet_to_json,\n\tsheet_to_html: sheet_to_html,\n\tsheet_to_formulae: sheet_to_formulae,\n\tsheet_to_row_object_array: sheet_to_json,\n\tsheet_get_cell: ws_get_cell_stub,\n\tbook_new: book_new,\n\tbook_append_sheet: book_append_sheet,\n\tbook_set_sheet_visibility: book_set_sheet_visibility,\n\tcell_set_number_format: cell_set_number_format,\n\tcell_set_hyperlink: cell_set_hyperlink,\n\tcell_set_internal_link: cell_set_internal_link,\n\tcell_add_comment: cell_add_comment,\n\tsheet_set_array_formula: sheet_set_array_formula,\n\tconsts: {\n\t\tSHEET_VISIBLE: 0,\n\t\tSHEET_HIDDEN: 1,\n\t\tSHEET_VERY_HIDDEN: 2\n\t}\n};\n\nvar _Readable;\nfunction set_readable(R) { _Readable = R; }\n\nfunction write_csv_stream(sheet/*:Worksheet*/, opts/*:?Sheet2CSVOpts*/) {\n\tvar stream = _Readable();\n\tvar o = opts == null ? {} : opts;\n\tif(sheet == null || sheet[\"!ref\"] == null) { stream.push(null); return stream; }\n\tvar r = safe_decode_range(sheet[\"!ref\"]);\n\tvar FS = o.FS !== undefined ? o.FS : \",\", fs = FS.charCodeAt(0);\n\tvar RS = o.RS !== undefined ? o.RS : \"\\n\", rs = RS.charCodeAt(0);\n\tvar endregex = new RegExp((FS==\"|\" ? \"\\\\|\" : FS)+\"+$\");\n\tvar row/*:?string*/ = \"\", cols/*:Array<string>*/ = [];\n\to.dense = Array.isArray(sheet);\n\tvar colinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!cols\"] || [];\n\tvar rowinfo/*:Array<RowInfo>*/ = o.skipHidden && sheet[\"!rows\"] || [];\n\tfor(var C = r.s.c; C <= r.e.c; ++C) if (!((colinfo[C]||{}).hidden)) cols[C] = encode_col(C);\n\tvar R = r.s.r;\n\tvar BOM = false, w = 0;\n\tstream._read = function() {\n\t\tif(!BOM) { BOM = true; return stream.push(\"\\uFEFF\"); }\n\t\twhile(R <= r.e.r) {\n\t\t\t++R;\n\t\t\tif ((rowinfo[R-1]||{}).hidden) continue;\n\t\t\trow = make_csv_row(sheet, r, R-1, cols, fs, rs, FS, o);\n\t\t\tif(row != null) {\n\t\t\t\tif(o.strip) row = row.replace(endregex,\"\");\n\t\t\t\tif(row || (o.blankrows !== false)) return stream.push((w++ ? RS : \"\") + row);\n\t\t\t}\n\t\t}\n\t\treturn stream.push(null);\n\t};\n\treturn stream;\n}\n\nfunction write_html_stream(ws/*:Worksheet*/, opts/*:?Sheet2HTMLOpts*/) {\n\tvar stream = _Readable();\n\n\tvar o = opts || {};\n\tvar header = o.header != null ? o.header : HTML_BEGIN;\n\tvar footer = o.footer != null ? o.footer : HTML_END;\n\tstream.push(header);\n\tvar r = decode_range(ws['!ref']);\n\to.dense = Array.isArray(ws);\n\tstream.push(make_html_preamble(ws, r, o));\n\tvar R = r.s.r;\n\tvar end = false;\n\tstream._read = function() {\n\t\tif(R > r.e.r) {\n\t\t\tif(!end) { end = true; stream.push(\"</table>\" + footer); }\n\t\t\treturn stream.push(null);\n\t\t}\n\t\twhile(R <= r.e.r) {\n\t\t\tstream.push(make_html_row(ws, r, R, o));\n\t\t\t++R;\n\t\t\tbreak;\n\t\t}\n\t};\n\treturn stream;\n}\n\nfunction write_json_stream(sheet/*:Worksheet*/, opts/*:?Sheet2CSVOpts*/) {\n\tvar stream = _Readable({objectMode:true});\n\n\tif(sheet == null || sheet[\"!ref\"] == null) { stream.push(null); return stream; }\n\tvar val = {t:'n',v:0}, header = 0, offset = 1, hdr/*:Array<any>*/ = [], v=0, vv=\"\";\n\tvar r = {s:{r:0,c:0},e:{r:0,c:0}};\n\tvar o = opts || {};\n\tvar range = o.range != null ? o.range : sheet[\"!ref\"];\n\tif(o.header === 1) header = 1;\n\telse if(o.header === \"A\") header = 2;\n\telse if(Array.isArray(o.header)) header = 3;\n\tswitch(typeof range) {\n\t\tcase 'string': r = safe_decode_range(range); break;\n\t\tcase 'number': r = safe_decode_range(sheet[\"!ref\"]); r.s.r = range; break;\n\t\tdefault: r = range;\n\t}\n\tif(header > 0) offset = 0;\n\tvar rr = encode_row(r.s.r);\n\tvar cols/*:Array<string>*/ = [];\n\tvar counter = 0;\n\tvar dense = Array.isArray(sheet);\n\tvar R = r.s.r, C = 0;\n\tvar header_cnt = {};\n\tif(dense && !sheet[R]) sheet[R] = [];\n\tvar colinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!cols\"] || [];\n\tvar rowinfo/*:Array<RowInfo>*/ = o.skipHidden && sheet[\"!rows\"] || [];\n\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\tif(((colinfo[C]||{}).hidden)) continue;\n\t\tcols[C] = encode_col(C);\n\t\tval = dense ? sheet[R][C] : sheet[cols[C] + rr];\n\t\tswitch(header) {\n\t\t\tcase 1: hdr[C] = C - r.s.c; break;\n\t\t\tcase 2: hdr[C] = cols[C]; break;\n\t\t\tcase 3: hdr[C] = o.header[C - r.s.c]; break;\n\t\t\tdefault:\n\t\t\t\tif(val == null) val = {w: \"__EMPTY\", t: \"s\"};\n\t\t\t\tvv = v = format_cell(val, null, o);\n\t\t\t\tcounter = header_cnt[v] || 0;\n\t\t\t\tif(!counter) header_cnt[v] = 1;\n\t\t\t\telse {\n\t\t\t\t\tdo { vv = v + \"_\" + (counter++); } while(header_cnt[vv]); header_cnt[v] = counter;\n\t\t\t\t\theader_cnt[vv] = 1;\n\t\t\t\t}\n\t\t\t\thdr[C] = vv;\n\t\t}\n\t}\n\tR = r.s.r + offset;\n\tstream._read = function() {\n\t\twhile(R <= r.e.r) {\n\t\t\tif ((rowinfo[R-1]||{}).hidden) continue;\n\t\t\tvar row = make_json_row(sheet, r, R, cols, header, hdr, dense, o);\n\t\t\t++R;\n\t\t\tif((row.isempty === false) || (header === 1 ? o.blankrows !== false : !!o.blankrows)) {\n\t\t\t\tstream.push(row.row);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t\treturn stream.push(null);\n\t};\n\treturn stream;\n}\n\nvar __stream = {\n\tto_json: write_json_stream,\n\tto_html: write_html_stream,\n\tto_csv: write_csv_stream,\n set_readable: set_readable\n};\nexport const version = XLSX.version;\nexport {\n\tparse_xlscfb,\n\tparse_zip,\n\treadSync as read,\n\treadFileSync as readFile,\n\treadFileSync,\n\twriteSync as write,\n\twriteFileSync as writeFile,\n\twriteFileSync,\n\twriteFileAsync,\n\twriteSyncXLSX as writeXLSX,\n\twriteFileSyncXLSX as writeFileXLSX,\n\tutils,\n\t__stream as stream,\n\tSSF,\n\tCFB\n};\n","import * as XLSX from \"xlsx\";\nimport { saveAs } from \"file-saver\";\nimport XLSXStyle from \"xlsx-js-style\";\n\nfunction generateArray(table) {\n\tlet out = [];\n\tlet rows = table.querySelectorAll(\"tr\");\n\tlet ranges = [];\n\tfor (var R = 0; R < rows.length; ++R) {\n\t\tvar outRow = [];\n\t\tlet row = rows[R];\n\t\tlet columns = row.querySelectorAll(\"td\");\n\t\tfor (let C = 0; C < columns.length; ++C) {\n\t\t\tlet cell = columns[C];\n\t\t\tlet colspan = cell.getAttribute(\"colspan\");\n\t\t\tlet rowspan = cell.getAttribute(\"rowspan\");\n\t\t\tlet cellValue = cell.innerText;\n\t\t\tif (cellValue !== \"\" && cellValue == +cellValue) cellValue = +cellValue;\n\n\t\t\t//Skip ranges\n\t\t\tranges.forEach(function (range) {\n\t\t\t\tif (R >= range.s.r && R <= range.e.r && outRow.length >= range.s.c && outRow.length <= range.e.c) {\n\t\t\t\t\tfor (let i = 0; i <= range.e.c - range.s.c; ++i) outRow.push(null);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t//Handle Row Span\n\t\t\tif (rowspan || colspan) {\n\t\t\t\trowspan = rowspan || 1;\n\t\t\t\tcolspan = colspan || 1;\n\t\t\t\tranges.push({\n\t\t\t\t\ts: {\n\t\t\t\t\t\tr: R,\n\t\t\t\t\t\tc: outRow.length\n\t\t\t\t\t},\n\t\t\t\t\te: {\n\t\t\t\t\t\tr: R + rowspan - 1,\n\t\t\t\t\t\tc: outRow.length + colspan - 1\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\n\t\t\t//Handle Value\n\t\t\toutRow.push(cellValue !== \"\" ? cellValue : null);\n\n\t\t\t//Handle Colspan\n\t\t\tif (colspan) for (let k = 0; k < colspan - 1; ++k) outRow.push(null);\n\t\t}\n\t\tout.push(outRow);\n\t}\n\treturn [out, ranges];\n}\n\nfunction datenum(v, date1904) {\n\tif (date1904) v += 1462;\n\tlet epoch = Date.parse(v);\n\treturn (epoch - new Date(Date.UTC(1899, 11, 30))) / (24 * 60 * 60 * 1000);\n}\n\nfunction sheet_from_array_of_arrays(data, opts) {\n\tlet ws = {};\n\tlet range = {\n\t\ts: {\n\t\t\tc: 10000000,\n\t\t\tr: 10000000\n\t\t},\n\t\te: {\n\t\t\tc: 0,\n\t\t\tr: 0\n\t\t}\n\t};\n\tfor (let R = 0; R != data.length; ++R) {\n\t\tfor (let C = 0; C != data[R].length; ++C) {\n\t\t\tif (range.s.r > R) range.s.r = R;\n\t\t\tif (range.s.c > C) range.s.c = C;\n\t\t\tif (range.e.r < R) range.e.r = R;\n\t\t\tif (range.e.c < C) range.e.c = C;\n\t\t\tlet cell = {\n\t\t\t\tv: data[R][C]\n\t\t\t};\n\t\t\tif (cell.v == null) continue;\n\t\t\tlet cell_ref = XLSX.utils.encode_cell({\n\t\t\t\tc: C,\n\t\t\t\tr: R\n\t\t\t});\n\n\t\t\tif (typeof cell.v === \"number\") cell.t = \"n\";\n\t\t\telse if (typeof cell.v === \"boolean\") cell.t = \"b\";\n\t\t\telse if (cell.v instanceof Date) {\n\t\t\t\tcell.t = \"n\";\n\t\t\t\tcell.z = XLSX.SSF._table[14];\n\t\t\t\tcell.v = datenum(cell.v);\n\t\t\t} else cell.t = \"s\";\n\n\t\t\tws[cell_ref] = cell;\n\t\t}\n\t}\n\tif (range.s.c < 10000000) ws[\"!ref\"] = XLSX.utils.encode_range(range);\n\treturn ws;\n}\n\nfunction Workbook() {\n\tif (!(this instanceof Workbook)) return new Workbook();\n\tthis.SheetNames = [];\n\tthis.Sheets = {};\n}\n\nfunction s2ab(s) {\n\tlet buf = new ArrayBuffer(s.length);\n\tlet view = new Uint8Array(buf);\n\tfor (let i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xff;\n\treturn buf;\n}\n\nexport function export_table_to_excel(id) {\n\tlet theTable = document.getElementById(id);\n\tlet oo = generateArray(theTable);\n\tlet ranges = oo[1];\n\n\t/* original data */\n\tlet data = oo[0];\n\tlet ws_name = \"SheetJS\";\n\n\tlet wb = new Workbook(),\n\t\tws = sheet_from_array_of_arrays(data);\n\n\t/* add ranges to worksheet */\n\t// ws['!cols'] = ['apple', 'banan'];\n\tws[\"!merges\"] = ranges;\n\n\t/* add worksheet to workbook */\n\twb.SheetNames.push(ws_name);\n\twb.Sheets[ws_name] = ws;\n\n\tlet wbout = XLSX.write(wb, {\n\t\tbookType: \"xlsx\",\n\t\tbookSST: false,\n\t\ttype: \"binary\"\n\t});\n\n\tsaveAs(\n\t\tnew Blob([s2ab(wbout)], {\n\t\t\ttype: \"application/octet-stream\"\n\t\t}),\n\t\t\"test.xlsx\"\n\t);\n}\n\nexport function export_json_to_excel({\n\tmultiHeader = [],\n\theader,\n\tdata,\n\tfilename,\n\tmerges = [],\n\tautoWidth = true,\n\texcelWidth = true,\n\tbookType = \"xlsx\"\n} = {}) {\n\t/* original data */\n\t// console.log( multiHeader,header,data,filename)\n\tfilename = filename || \"excel-list\";\n\tdata = [...data];\n\tdata.unshift(header);\n\n\tfor (let i = multiHeader.length - 1; i > -1; i--) {\n\t\tdata.unshift(multiHeader[i]);\n\t}\n\n\tlet ws_name = \"SheetJS\";\n\tlet wb = new Workbook(),\n\t\tws = sheet_from_array_of_arrays(data);\n\n\tif (merges.length > 0) {\n\t\tif (!ws[\"!merges\"]) ws[\"!merges\"] = [];\n\t\tmerges.forEach(item => {\n\t\t\tws[\"!merges\"].push(XLSX.utils.decode_range(item));\n\t\t});\n\t}\n\n\tif (autoWidth) ws[\"!cols\"] = getColWidth(data);\n\tif (excelWidth) setColMaxW(data, ws);\n\n\t/* add worksheet to workbook */\n\twb.SheetNames.push(ws_name);\n\twb.Sheets[ws_name] = ws;\n\n\tlet wbout = XLSX.write(wb, {\n\t\tbookType: bookType,\n\t\tbookSST: false,\n\t\ttype: \"binary\"\n\t});\n\tsaveAs(\n\t\tnew Blob([s2ab(wbout)], {\n\t\t\ttype: \"application/octet-stream\"\n\t\t}),\n\t\t`${filename}.${bookType}`\n\t);\n}\n\n// export function readFile(file) {\n// return new Promise((resolve) => {\n// let reader = new FileReader();\n// reader.readAsBinaryString(file);\n// reader.onload = (ev) => {\n// let dataBinary = ev.target.result;\n// let workBook = XLSX.read(dataBinary, { type: \"binary\", cellDates: true });\n// let workSheet = workBook.Sheets[workBook.SheetNames[0]];\n// const data = XLSX.utils.sheet_to_json(workSheet, {defval:\"\"});\n// resolve(data);\n// };\n// });\n// }\n\nexport function readFile(file) {\n\treturn new Promise(resolve => {\n\t\tlet reader = new FileReader();\n\t\treader.readAsBinaryString(file);\n\t\treader.onload = ev => {\n\t\t\tresolve(ev.target.result);\n\t\t};\n\t});\n}\n\n// 读取excel,返回一维数组,第一行格式:{列名:值,列名:值}\nexport async function readExcel(file) {\n\tlet dataBinary = await readFile(file);\n\tlet workBook = XLSX.read(dataBinary, { type: \"binary\", cellDates: true });\n\tlet workSheet = workBook.Sheets[workBook.SheetNames[0]];\n\tconst data = XLSX.utils.sheet_to_json(workSheet, { defval: \"\" });\n\treturn data;\n}\n\n// 读取excel,返回二维数组,第一行表头,后面行是数据\nexport async function readExcelToArray(file) {\n\tlet dataBinary = await readFile(file);\n\tlet workBook = XLSX.read(dataBinary, { type: \"binary\", cellDates: true });\n\tlet workSheet = workBook.Sheets[workBook.SheetNames[0]];\n\tconst data = XLSX.utils.sheet_to_json(workSheet, { defval: \"\", header: 1 });\n\treturn data;\n}\n\nexport async function saveFile(content, fileName) {\n\tlet file = new Blob([content]);\n\tsaveAs(file, fileName);\n}\n\n// 判断列宽\nfunction getColWidth(list) {\n\t/*设置worksheet每列的最大宽度*/\n\tconst colWidth = list.map(row =>\n\t\trow.map(val => {\n\t\t\t/*先判断是否为null/undefined*/\n\t\t\tif (val == null) {\n\t\t\t\treturn {\n\t\t\t\t\twch: 10\n\t\t\t\t};\n\t\t\t} else if (val.toString().charCodeAt(0) > 255) {\n\t\t\t\t/*再判断是否为中文*/\n\t\t\t\treturn {\n\t\t\t\t\twch: val.toString().length * 2\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\treturn {\n\t\t\t\t\twch: val.toString().length\n\t\t\t\t};\n\t\t\t}\n\t\t})\n\t);\n\t/*以第一行为初始值*/\n\tlet result = colWidth[0];\n\tfor (let i = 1; i < colWidth.length; i++) {\n\t\tfor (let j = 0; j < colWidth[i].length; j++) {\n\t\t\tif (result[j][\"wch\"] < colWidth[i][j][\"wch\"]) {\n\t\t\t\tresult[j][\"wch\"] = colWidth[i][j][\"wch\"];\n\t\t\t}\n\t\t}\n\t}\n\treturn result;\n}\n\n// 设置最大列宽\nfunction setColMaxW(list, ws) {\n\t/*设置worksheet每列的最大宽度*/\n\tconst colWidth = list.map(row =>\n\t\trow.map(val => {\n\t\t\t/*先判断是否为null/undefined*/\n\t\t\t// console.log(val)\n\t\t\tif (val == null) {\n\t\t\t\treturn {\n\t\t\t\t\twch: 10\n\t\t\t\t};\n\t\t\t} else if (val.toString().charCodeAt(0) > 255) {\n\t\t\t\t/*再判断是否为中文*/\n\t\t\t\treturn {\n\t\t\t\t\twch: 20\n\t\t\t\t};\n\t\t\t} else if (val.toString().indexOf(\"<operation\") !== -1) {\n\t\t\t\t/* 判断是否为报文数据*/\n\t\t\t\treturn {\n\t\t\t\t\twch: 30\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\treturn {\n\t\t\t\t\twch: val.toString().length\n\t\t\t\t};\n\t\t\t}\n\t\t})\n\t);\n\t// console.log(colWidth)\n\t/*以第一行为初始值*/\n\tlet result = colWidth[0];\n\tfor (let i = 1; i < colWidth.length; i++) {\n\t\tfor (let j = 0; j < colWidth[i].length; j++) {\n\t\t\tif (result[j][\"wch\"] < colWidth[i][j][\"wch\"]) {\n\t\t\t\tresult[j][\"wch\"] = colWidth[i][j][\"wch\"];\n\t\t\t}\n\t\t}\n\t}\n\t// console.log(result)\n\tresult[0].wch = 20;\n\tresult[4] ? (result[4].wch = 10) : \"\";\n\tws[\"!cols\"] = result;\n}\n\n// 导出excel,且可带单元格注释及样式\nconst englishLetter = [\n\t\"A\",\n\t\"B\",\n\t\"C\",\n\t\"D\",\n\t\"E\",\n\t\"F\",\n\t\"G\",\n\t\"H\",\n\t\"I\",\n\t\"J\",\n\t\"K\",\n\t\"L\",\n\t\"M\",\n\t\"N\",\n\t\"O\",\n\t\"P\",\n\t\"Q\",\n\t\"R\",\n\t\"S\",\n\t\"T\",\n\t\"U\",\n\t\"V\",\n\t\"W\",\n\t\"X\",\n\t\"Y\",\n\t\"X\"\n];\nexport function export_excel_style({ header, data, filename, merges = [], autoWidth = true, excelWidth = true } = {}) {\n\t// 创建一个工作簿\n\tconst workBook = XLSX.utils.book_new();\n\tdata = [...data];\n\tdata.unshift(header.map(item => item.label));\n\t// 创建工作表 worksheet\n\tconst workSheet = sheet_from_array_of_arrays(data);\n\tif (merges.length > 0) {\n\t\tif (!workSheet[\"!merges\"]) workSheet[\"!merges\"] = [];\n\t\tmerges.forEach(item => {\n\t\t\tworkSheet[\"!merges\"].push(XLSX.utils.decode_range(item));\n\t\t});\n\t}\n\tif (autoWidth) workSheet[\"!cols\"] = getColWidth(data);\n\tif (excelWidth) setColMaxW(data, workSheet);\n\theader.forEach((head, index) => {\n\t\tlet cell = workSheet[`${englishLetter[index]}1`];\n\t\t// cell.s = { font:{ bold: true } };\n\t\tif (cell && head.note) {\n\t\t\tif (!cell.c) cell.c = [];\n\t\t\tcell.c.hidden = true;\n\t\t\tcell.c.push({ a: head.label, t: head.note });\n\t\t}\n\t});\n\t// 将工作表放入工作簿中\n\tXLSX.utils.book_append_sheet(workBook, workSheet, \"Sheet1\");\n\t// 生成数据保存\n\tXLSXStyle.writeFile(workBook, `${filename}.xlsx`, { bookType: \"xlsx\" });\n}\n\n// 验证文件格式\nexport function checkFileType(file, fileType) {\n\tlet index = file.name.lastIndexOf(\".\");\n\tlet ext = file.name.substr(index);\n\tlet extList = fileType instanceof Array ? fileType : [fileType];\n\tif (fileType === \"Excel\") {\n\t\textList = [\".xls\", \".xlsx\", \".csv\"];\n\t}\n\tif (!extList.includes(ext)) {\n\t\treturn `请上传${extList.join(\"或\") || \"指定格式\"}文件!`;\n\t}\n\treturn \"\";\n}\n\n// 解析文件并判断文件类型\nexport async function parseFile(file, config) {\n\tlet typeErrorMsg = checkFileType(file, config.fileType);\n\tif (typeErrorMsg) return { code: 0, message: typeErrorMsg };\n\tif (config.fileType === \"Excel\") {\n\t\tlet data = await readExcelToArray(file);\n\t\treturn { code: 200, data };\n\t}\n\tlet dataBinary = await readFile(file);\n\treturn { code: 200, data: dataBinary };\n}\n\n// 导出多Sheet Excel\nexport async function exportMultiSheetExcel(fileName, list) {\n\tconst wb = XLSX.utils.book_new();\n\n\t// 使用 Promise 包装异步操作\n\tconst generateSheetAsync = async section => {\n\t\treturn new Promise(resolve => {\n\t\t\tsetTimeout(() => {\n\t\t\t\tconst ws = XLSX.utils.json_to_sheet(section.data);\n\t\t\t\tXLSX.utils.book_append_sheet(wb, ws, section.sheetName.replace(/[\\\\/:*?\\[\\]]/g, \"-\"));\n\t\t\t\tresolve(true);\n\t\t\t}, 0);\n\t\t});\n\t};\n\n\t// 使用 for...of 循环和 await 处理异步操作\n\tfor (const section of list) {\n\t\tawait generateSheetAsync(section);\n\t}\n\n\tconst excelBuffer = XLSX.write(wb, { bookType: \"xlsx\", type: \"array\" });\n\tconst data = new Blob([excelBuffer], { type: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\" });\n\tsaveAs(data, fileName);\n}\n\nexport const exportToExcel = ({ header, tableData, fileName }: any) => {\n\t// 1. 获取表头(columns)并处理为 Excel 中的第一行\n\tconst tHeader = header.map(col => col.label); // 获取每一列的 label 作为表头\n\t// 2. 获取表格数据(data)\n\tconst data = tableData.map(row => {\n\t\treturn header.map(col => row[col.prop]); // 按照表头的顺序排列每行数据\n\t});\n\t// 3. 将表头和数据合并\n\tconst finalData = [tHeader, ...data]; // 把表头和数据组合成一个数组\n\t// 4. 创建工作表(sheet)\n\tconst ws = XLSX.utils.aoa_to_sheet(finalData); // 使用 aoa_to_sheet 转换为工作表\n\tconst wb = XLSX.utils.book_new(); // 创建工作簿\n\tXLSX.utils.book_append_sheet(wb, ws, \"Sheet1\"); // 添加工作表\n\n\t// 5. 导出 Excel 文件\n\tXLSX.writeFile(wb, `${fileName}.xlsx`); // 下载 Excel 文件\n};\n","<!--\n * @Author: WangXin\n * @Date: 2024-01-04 16:35:08\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-26 15:00:51\n * @FilePath: /yxuse/packages/components/YxTable/index.vue\n * @Description: \n * \n * Copyright (c) 2024 by YuXing, All Rights Reserved. \n-->\n\n<script setup lang=\"tsx\">\nimport {\n\tref,\n\tonMounted,\n\tonBeforeMount,\n\tnextTick,\n\tuseSlots,\n\tuseAttrs,\n\twithModifiers,\n\twatch,\n\tresolveComponent,\n\tdefineOptions\n} from \"vue\";\nimport type { FormInstance, FormItemRule } from \"element-plus\";\nimport type { TableColumn, YxTableProps, ColumnsConfig } from \"./type.ts\";\n// import type { ComponentInterFace } from \"../Common/DynamicComponent/index.d\";\n// import DynamicComponents from \"../Common/DynamicComponent/index.vue\";\nimport { exportToExcel } from \"@packages/utils/excel\";\nimport Sortable from \"sortablejs\";\nconst props = defineProps<YxTableProps>();\nconst slots = useSlots();\nconst attrs = useAttrs();\nconst tableRef = ref();\nconst tableFormRef = ref();\nconst columns = ref<TableColumn[]>([]);\n/**是否为编辑表单,且需要进行表格校验 */\nconst isFormTable = ref(false);\nconst formTableRules = ref<{ [key: string]: FormItemRule[] }>({});\nconst emit = defineEmits<{\n\t(e: \"operate-handle\", type: string, data: object, index: number): void;\n\t(e: \"sort-end\", oldIndex: number, newIndex: number): void;\n\t(e: \"update-page\", type: string, value: number): void;\n}>();\nonMounted(() => {\n\tnextTick(() => {\n\t\tstartSort();\n\t});\n});\nwatch(\n\t() => props.columns,\n\t() => {\n\t\tinitTable();\n\t}\n);\nonBeforeMount(async () => {\n\tawait initTable();\n});\nconst initTable = async () => {\n\tcolumns.value = typeof props.columns === \"function\" ? await props.columns() : props.columns;\n\tcolumns.value.forEach((col: TableColumn) => {\n\t\tif (!col.renderType) return;\n\t\tif ([\"select\", \"cascader\"].includes(col.renderType) && col?.config?.loadOptions) {\n\t\t\tloadOptions(col.config);\n\t\t}\n\t\tif (col.required || col.rules?.length) {\n\t\t\tisFormTable.value = true;\n\t\t}\n\t});\n\tif (isFormTable.value) {\n\t\tgetRules();\n\t}\n};\n/**远程加载下拉数据 */\nconst loadOptions = async (config: any) => {\n\tif (config?.options && config?.options.length === 0 && config?.loadOptions && typeof config?.loadOptions === \"function\") {\n\t\tconfig.options = await config?.loadOptions();\n\t}\n};\nconst startSort = () => {\n\tif (!props.sort) return;\n\tconst sortDom = tableRef.value?.$el?.querySelector(\".el-table__body tbody\");\n\tSortable.create(sortDom, {\n\t\tanimation: 200,\n\t\t// group: \"el-table__row table-row\",\n\t\tsort: true,\n\t\thandle: props.sortHandle ? `.${props.sortHandle}` : null,\n\t\tonEnd: ({ oldIndex, newIndex }: { oldIndex: number; newIndex: number }) => {\n\t\t\temit(\"sort-end\", oldIndex, newIndex);\n\t\t}\n\t});\n};\n/***渲染动态组件 */\nconst dynamicComponent = (column: TableColumn, { $index, row }: any) => {\n\tconst { renderType, event = {}, prop, label, config = {}, required, rules } = column;\n\tif (!prop || !renderType) return null;\n\tconst Component = resolveComponent(\"el-\" + renderType) as any;\n\tconst { options = [], ...restConfig } = config;\n\t// 渲染子组件(如 select 的 options)\n\tconst renderChildComponent = () => {\n\t\tif (!options || options.length === 0) return null;\n\t\tif (renderType === \"select\") {\n\t\t\treturn options.map((item: any) => <el-option label={item.label} value={item.value} key={item.value} />);\n\t\t}\n\t\tif (renderType === \"radio-group\") {\n\t\t\treturn options.map((item: any) => (\n\t\t\t\t<el-radio label={item.value} key={item.value}>\n\t\t\t\t\t{item.label}\n\t\t\t\t</el-radio>\n\t\t\t));\n\t\t}\n\t\treturn null;\n\t};\n\t// 单独处理 cascader\n\tif (renderType === \"cascader\") {\n\t\treturn <el-cascader v-model={row[prop]} placeholder={`请选择${label}`} options={options} {...event} {...restConfig} />;\n\t}\n\t// 通用组件渲染\n\tconst isSelect = [\"select\", \"cascader\"].includes(renderType);\n\t//是否为编辑表格必填项\n\tconst isFormCell = required || rules?.length;\n\tconst modelValue = row[prop];\n\tconst updateModelValue = (val: any) => {\n\t\t//处理配置是数值类型\n\t\trow[prop] = config?.type === \"number\" ? Number(val) : val;\n\t};\n\tconst component = (\n\t\t<Component\n\t\t\tmodelValue={modelValue}\n\t\t\tonUpdate:modelValue={updateModelValue}\n\t\t\tplaceholder={`请${isSelect ? \"选择\" : \"输入\"}${label}`}\n\t\t\t{...event}\n\t\t\t{...restConfig}\n\t\t>\n\t\t\t{renderChildComponent()}\n\t\t</Component>\n\t);\n\tif (!isFormCell) return component;\n\t//编辑表格\n\treturn renderForm(prop, $index, component);\n};\nconst renderForm = (prop: any, index: number, component: any) => {\n\treturn (\n\t\t<el-form-item prop={\"tableData.\" + index + \".\" + prop} rules={formTableRules.value[prop]}>\n\t\t\t{component}\n\t\t</el-form-item>\n\t);\n};\n/**初始化规则 */\nconst getRules = () => {\n\tconst rules: { [key: string]: FormItemRule[] } = {};\n\tif (!isFormTable.value) return;\n\tconst handleRule = (item: TableColumn) => {\n\t\tif (!item.prop) return;\n\t\tconst isSelect = item?.renderType && [\"select\", \"cascader\"].includes(item?.renderType);\n\t\tconst defaultRule = { required: true, message: `${item.label ?? \"该字段\"}不能为空`, trigger: isSelect ? \"change\" : \"blur\" };\n\t\tif (item.required) {\n\t\t\trules[item.prop] = [defaultRule];\n\t\t}\n\t\tif (item.rules && item.rules.length > 0) {\n\t\t\trules[item.prop] = [...(rules[item?.prop] || []), ...item.rules];\n\t\t}\n\t};\n\tcolumns.value\n\t\t.filter(cell => (cell?.renderType || cell?.render) && (cell?.required || cell?.rules))\n\t\t.forEach((form: any) => {\n\t\t\tform.children?.forEach(handleRule); // 处理子项\n\t\t\thandleRule(form); // 处理自身\n\t\t});\n\tformTableRules.value = rules;\n\tconsole.log(\"rules\", formTableRules.value);\n};\n/**编辑表格校验 */\nconst tableFormValidate = async (): Promise<boolean> => {\n\tif (!isFormTable.value) return Promise.resolve(true);\n\tif (!tableFormRef.value) return Promise.resolve(false);\n\treturn await tableFormRef.value.validate(() => Promise.resolve());\n};\nconst render = (props: YxTableProps) => {\n\tconst { rowKey, tableData, pageInfo } = props;\n\t//动态插槽\n\tconst columnSlots = (cell: TableColumn, scope: any) => cell.slotName && slots[cell.slotName]?.(scope);\n\t//处理列;\n\tconst renderColumn = (columns: TableColumn[]) => {\n\t\treturn columns\n\t\t\t.filter(cell => !cell.show || cell.show(cell))\n\t\t\t.map((cell: TableColumn) => {\n\t\t\t\tconst { children, ...cellConf } = cell;\n\t\t\t\treturn (\n\t\t\t\t\t<el-table-column {...cellConf}>\n\t\t\t\t\t\t{{\n\t\t\t\t\t\t\tdefault: (scope: any) => {\n\t\t\t\t\t\t\t\t//先处理操作栏\n\t\t\t\t\t\t\t\tif (cell?.renderType === \"operate\") return renderOperate(cell, scope);\n\t\t\t\t\t\t\t\t//处理动态渲染的组件,绑定动态row\n\t\t\t\t\t\t\t\tif (cell?.renderType && cell?.renderType !== \"operate\") {\n\t\t\t\t\t\t\t\t\treturn dynamicComponent(cell, scope);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t//处理自定义渲染函数,判断是否为表单组件\n\t\t\t\t\t\t\t\tif (cell?.render) {\n\t\t\t\t\t\t\t\t\tconst renderResult = cell.render(scope.row, scope.$index, cell);\n\t\t\t\t\t\t\t\t\t//是否为编辑表单\n\t\t\t\t\t\t\t\t\tconst needsValidation = cell.required || cell.rules;\n\t\t\t\t\t\t\t\t\t//是否为组件节点\n\t\t\t\t\t\t\t\t\tconst isFragment = [\"symbol\", \"object\"].includes(typeof renderResult?.type);\n\t\t\t\t\t\t\t\t\t// 如果为表单节点且需要校验,进行form-item包裹\n\t\t\t\t\t\t\t\t\tif (needsValidation && isFragment) {\n\t\t\t\t\t\t\t\t\t\treturn renderForm(cell.prop, scope.$index, renderResult);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\treturn renderResult;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t//处理多级表头\n\t\t\t\t\t\t\t\tif (children && children?.length > 0) return renderColumn(children);\n\t\t\t\t\t\t\t\t//处理自定义插槽\n\t\t\t\t\t\t\t\treturn cell?.slotName && columnSlots(cell, scope);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\theader: (scope: any) => {\n\t\t\t\t\t\t\t\t//添加必填标识\n\t\t\t\t\t\t\t\tif (cell?.required) {\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<span class=\"flex items-center gap-5\">\n\t\t\t\t\t\t\t\t\t\t\t<span class=\"text-red-500\">* </span>\n\t\t\t\t\t\t\t\t\t\t\t{scope?.column?.label ?? \"\"}\n\t\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t//处理自定义渲染函数\n\t\t\t\t\t\t\t\tif (cell?.headerRender) return cell?.headerRender(scope.row);\n\t\t\t\t\t\t\t\t//处理表头自定义插槽\n\t\t\t\t\t\t\t\tif (cell?.headerSlotName) return slots[cell?.headerSlotName]?.(scope);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}}\n\t\t\t\t\t</el-table-column>\n\t\t\t\t);\n\t\t\t});\n\t};\n\t//操作栏;\n\tconst renderOperate = (cell: TableColumn, scope: any) => {\n\t\treturn (\n\t\t\t<div class={`flex justify-center items-center cursor-pointer gap-10 ${cell.config?.className ?? \"\"}`}>\n\t\t\t\t{cell.operate\n\t\t\t\t\t?.filter(op => !op.show || op.show(scope.row))\n\t\t\t\t\t.map(op => {\n\t\t\t\t\t\tif (op?.render) return op.render(scope.row, scope.$index);\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\tonClick={withModifiers(() => {\n\t\t\t\t\t\t\t\t\top?.onClick && op?.onClick(scope.row);\n\t\t\t\t\t\t\t\t\temit(\"operate-handle\", op.key, scope.row, scope.$index);\n\t\t\t\t\t\t\t\t}, [\"stop\"])}\n\t\t\t\t\t\t\t\tclass={`table-handle whitespace-nowrap ${op?.className ?? \"\"}`}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{op.label}\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t);\n\t\t\t\t\t})}\n\t\t\t</div>\n\t\t);\n\t};\n\t//分页\n\tconst pagination = () => {\n\t\tif (!pageInfo) return null;\n\t\tconst handleSizeChange = (e: number) => {\n\t\t\temit(\"update-page\", \"pageSize\", e);\n\t\t};\n\t\tconst handleCurrentChange = (e: number) => {\n\t\t\temit(\"update-page\", \"pageIndex\", e);\n\t\t};\n\t\treturn (\n\t\t\t<div class=\"pagination-wrap\">\n\t\t\t\t<el-pagination\n\t\t\t\t\tv-model:currentPage={pageInfo.pageIndex}\n\t\t\t\t\tv-model:pageSize={pageInfo.pageSize}\n\t\t\t\t\tsmall={false}\n\t\t\t\t\tdisabled={false}\n\t\t\t\t\tpage-sizes={[10, 20, 50, 100]}\n\t\t\t\t\tlayout={pageInfo?.layout ? pageInfo?.layout : \"total,sizes,prev, pager, next\"}\n\t\t\t\t\tbackground={false}\n\t\t\t\t\ttotal={pageInfo.total}\n\t\t\t\t\tonSizeChange={handleSizeChange}\n\t\t\t\t\tonCurrentChange={handleCurrentChange}\n\t\t\t\t/>\n\t\t\t</div>\n\t\t);\n\t};\n\tif (!columns.value) return;\n\treturn (\n\t\t<>\n\t\t\t{isFormTable.value ? (\n\t\t\t\t<el-form model={props} ref={tableFormRef}>\n\t\t\t\t\t{renderTable()}\n\t\t\t\t</el-form>\n\t\t\t) : (\n\t\t\t\trenderTable()\n\t\t\t)}\n\t\t\t{pagination()}\n\t\t</>\n\t);\n\t/**渲染表格 */\n\tfunction renderTable() {\n\t\treturn (\n\t\t\t<el-table ref={tableRef} {...attrs} row-key={rowKey} data={tableData}>\n\t\t\t\t{renderColumn(columns.value)}\n\t\t\t</el-table>\n\t\t);\n\t}\n};\nconst exportDataToExcel = (fileName?: string) => {\n\tconst header = columns.value.filter(cell => cell.prop);\n\tconst tableData = props.tableData;\n\texportToExcel({ header, tableData, fileName: fileName || Date.now() });\n};\n/** 更新列 */\nconst updateColumns = async (newColumns: ColumnsConfig) => {\n\tif (!columns.value) return;\n\tcolumns.value = typeof newColumns === \"function\" ? await newColumns() : newColumns;\n};\ndefineExpose({\n\ttableRef,\n\texportDataToExcel,\n\tupdateColumns,\n\ttableFormValidate\n});\ndefineOptions({\n\tname: \"YxTable\",\n\tinheritAttrs: false\n});\n</script>\n\n<template>\n\t<component :is=\"render(props)\" />\n</template>\n\n<style scoped lang=\"scss\"></style>\n","import { createElementVNode as _createElementVNode, openBlock as _openBlock, createElementBlock as _createElementBlock } from \"vue\"\n\nconst _hoisted_1 = {\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 1024 1024\"\n}\n\nexport function render(_ctx, _cache) {\n return (_openBlock(), _createElementBlock(\"svg\", _hoisted_1, _cache[0] || (_cache[0] = [\n _createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896m23.744 191.488c-52.096 0-92.928 14.784-123.2 44.352-30.976 29.568-45.76 70.4-45.76 122.496h80.256c0-29.568 5.632-52.8 17.6-68.992 13.376-19.712 35.2-28.864 66.176-28.864 23.936 0 42.944 6.336 56.32 19.712 12.672 13.376 19.712 31.68 19.712 54.912 0 17.6-6.336 34.496-19.008 49.984l-8.448 9.856c-45.76 40.832-73.216 70.4-82.368 89.408-9.856 19.008-14.08 42.24-14.08 68.992v9.856h80.96v-9.856c0-16.896 3.52-31.68 10.56-45.76 6.336-12.672 15.488-24.64 28.16-35.2 33.792-29.568 54.208-48.576 60.544-55.616 16.896-22.528 26.048-51.392 26.048-86.592q0-64.416-42.24-101.376c-28.16-25.344-65.472-37.312-111.232-37.312m-12.672 406.208a54.27 54.27 0 0 0-38.72 14.784 49.4 49.4 0 0 0-15.488 38.016c0 15.488 4.928 28.16 15.488 38.016A54.85 54.85 0 0 0 523.072 768c15.488 0 28.16-4.928 38.72-14.784a51.52 51.52 0 0 0 16.192-38.72 51.97 51.97 0 0 0-15.488-38.016 55.94 55.94 0 0 0-39.424-14.784\"\n }, null, -1)\n ])))\n}\nexport default { render: render }","<!--\n * @Author: WangXin\n * @Date: 2023-06-08 10:10:13\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-25 19:19:51\n * @FilePath: /yxuse/packages/components/YxForm/index.vue\n * @Description: \n * \n * Copyright (c) 2023 by YuXing, All Rights Reserved. \n-->\n<script setup lang=\"tsx\">\nimport { ref, useAttrs, useSlots, resolveComponent, watch, onBeforeMount, onUnmounted } from \"vue\";\nimport type { FormInstance, FormItemRule } from \"element-plus\";\nimport type { YxFormProps, FormItem, FormStyle } from \"./type\";\nimport Question from \"./icon/question.svg?component\";\nconst formData = ref<{ [key: string]: any }>({});\nconst formRules = ref<{ [key: string]: FormItemRule[] }>({});\nconst formColumn = ref<FormItem[]>([]);\nconst isOptionsComponent = (type?: string): any => type && [\"select\", \"cascader\"].includes(type);\n//初始化表单data\nconst initForm = async () => {\n\tconst { formList, formParams } = props as YxFormProps;\n\t// 获取表单配置\n\tformColumn.value = typeof formList === \"function\" ? await formList() : formList;\n\tif (!Array.isArray(formColumn.value) || formColumn.value.length === 0) {\n\t\tconsole.warn(\"请配置表单项\");\n\t\treturn;\n\t}\n\t// 初始化表单数据\n\tconst initialData: Record<string, any> = {};\n\t// 填充默认值并加载选项(递归处理嵌套)\n\tconst fillFormData = (item: any) => {\n\t\tif (item.prop && !(item.prop in initialData)) {\n\t\t\tinitialData[item.prop] = \"\";\n\t\t}\n\t\tif (isOptionsComponent(item?.renderType)) {\n\t\t\tloadOptions(item); // 异步加载选项数据\n\t\t}\n\t\tif (Array.isArray(item.children)) {\n\t\t\titem.children.forEach(fillFormData);\n\t\t}\n\t\t//如果有配置关联的选项\n\t\thandleLinkOptions(item);\n\t};\n\tformColumn.value.forEach(item => fillFormData(item));\n\t// 编辑模式下回填数据\n\tif (formParams && Object.keys(formParams).length > 0) {\n\t\tif (hasLoadOptions()) {\n\t\t\tfor (const item of formColumn.value) {\n\t\t\t\tif (!item.prop) continue;\n\t\t\t\tconst isAsyncOption = item.config?.loadOptions && typeof item.config.loadOptions === \"function\";\n\t\t\t\t// 如果不是需要跳过赋值的字段,就赋值\n\t\t\t\tif (!(isAsyncOption && formParams[item.prop] !== undefined)) {\n\t\t\t\t\tformData.value[item.prop] = formParams[item.prop];\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\t//兼容老版本回写formParams数据\n\t\t\tformData.value = formParams;\n\t\t}\n\t} else {\n\t\tconsole.log(\"initialData\", initialData);\n\t\tformData.value = initialData;\n\t}\n};\n/**处理关联选项的逻辑 */\nconst handleLinkOptions = (item: any) => {\n\tif (!item.config?.linkOptions || item?._linkedHandled) return;\n\tconst linkOptions = item.config.linkOptions;\n\tconst originOnChange = item.event?.onChange;\n\tconst newOnChange = async (e: any) => {\n\t\tconsole.log(\"执行事件\", e);\n\t\t// 执行你自己的逻辑\n\t\tconst updateForm: FormItem = formColumn.value.find((form: any) => form?.prop === linkOptions) as any;\n\t\t//没有自定义事件,不做处理\n\t\tif (!updateForm || !updateForm?.config?.loadOptions) return;\n\t\tconst options = await updateForm.config.loadOptions(e);\n\t\t//更新options\n\t\tupdateForm.config.options = options;\n\t\t// 调用原始事件\n\t\tif (typeof originOnChange === \"function\") {\n\t\t\toriginOnChange(e);\n\t\t}\n\t};\n\t// 保证 event 是对象\n\titem.event = {\n\t\t...item.event,\n\t\tonChange: newOnChange\n\t};\n\t//添加处理标识\n\titem._linkedHandled = true;\n};\n/**表单配置中是否有loadOptions兼容老版本formParams回写数据 */\nconst hasLoadOptions = () => {\n\treturn formColumn.value.some(item => item.config?.loadOptions && typeof item.config.loadOptions === \"function\");\n};\n/**远程加载下拉数据 */\nconst loadOptions = async ({ config, prop }: FormItem) => {\n\t//不自动加载选项\n\tif (!config || config.notAutoLoadOptions) return;\n\tconst { loadOptions, options } = config;\n\tif (!options || typeof loadOptions !== \"function\") return;\n\tconst { formParams } = props as YxFormProps;\n\t//回写联级表单\n\tconst parentProp = formColumn.value.find((item: any) => item?.config?.linkOptions === prop)?.prop;\n\tconst parentValue = parentProp ? formParams?.[parentProp] : undefined;\n\ttry {\n\t\tconfig.options = await loadOptions(parentValue);\n\t\t// 回填下拉框数据\n\t\tif (prop && formParams?.[prop]) {\n\t\t\tformData.value[prop] = formParams[prop];\n\t\t}\n\t} catch (err) {\n\t\tconsole.error(`加载选项失败: ${prop}`, err);\n\t}\n};\n\nconst slots = useSlots();\nconst attrs = useAttrs();\nconst props = withDefaults(defineProps<YxFormProps>(), {\n\tformLayout: \"horizontal\",\n\tformStyle: () => ({\n\t\trow: 3,\n\t\tgap: \"15px\",\n\t\tlabelWidth: \"100px\",\n\t\talignItems: \"start\"\n\t})\n});\n//监听form配置更新后,则立即初始化form\nwatch(\n\t() => props.formList,\n\tformList => {\n\t\tif (formList.length > 0) {\n\t\t\tconsole.log(\"监听到了,formlist\", formList);\n\t\t\tinitForm();\n\t\t\tgetRules();\n\t\t}\n\t}\n);\n//监听默认参数变化后,重置form\nwatch(\n\t() => props.formParams,\n\tformParams => {\n\t\tif (formParams) {\n\t\t\tconsole.log(\"监听到了,formlist\");\n\t\t\tinitForm();\n\t\t}\n\t}\n);\n\n/**初始化规则 */\nconst getRules = () => {\n\tconst rules: { [key: string]: FormItemRule[] } = {};\n\tif (!formColumn.value?.length) return;\n\tconst handleRule = (item: FormItem) => {\n\t\tif (!item.prop) return;\n\t\tconst isSelect = item?.renderType && [\"select\", \"cascader\"].includes(item?.renderType);\n\t\tconst defaultRule = { required: true, message: `${item.label ?? \"该字段\"}不能为空`, trigger: isSelect ? \"change\" : \"blur\" };\n\t\tif (item.required) {\n\t\t\trules[item.prop] = [defaultRule];\n\t\t}\n\t\tif (item.rules && item.rules.length > 0) {\n\t\t\trules[item.prop] = [...(rules[item?.prop] || []), ...item.rules];\n\t\t}\n\t};\n\tformColumn.value.forEach((form: any) => {\n\t\tform.children?.forEach(handleRule); // 处理子项\n\t\thandleRule(form); // 处理自身\n\t});\n\tformRules.value = rules;\n\tconsole.log(\"rules\", rules);\n};\n\nonBeforeMount(async () => {\n\tif (props.formList) {\n\t\tawait initForm();\n\t\tgetRules();\n\t}\n});\nonUnmounted(() => {\n\t// formRef?.value && formRef?.value.resetFields();\n});\nconst formRef = ref<FormInstance>();\nconst getFormStyle = () => {\n\tconst { formStyle } = props;\n\tconst { row, gap, ...style } = formStyle as FormStyle;\n\treturn {\n\t\t\"grid-template-columns\": `repeat(${row}, 1fr)`,\n\t\t\"grid-gap\": gap,\n\t\t...style\n\t};\n};\n//分组样式\nconst getGroupStyle = (groupStyle: FormStyle) => {\n\tif (!groupStyle) return {};\n\tconst { row, gap, ...style } = groupStyle;\n\treturn {\n\t\t\"grid-template-columns\": `repeat(${row}, 1fr)`,\n\t\t\"grid-gap\": gap,\n\t\t...style\n\t};\n};\n\nconst render = (props: YxFormProps) => {\n\tconst { formStyle, formLayout } = props;\n\tif (!formColumn.value?.length) return;\n\tconst dynamicComponent = ({ renderType, event, prop, label, config }: FormItem) => {\n\t\tif (!prop) return;\n\n\t\tconst Component = resolveComponent(\"el-\" + renderType) as any;\n\t\tconst renderChildComponent = () => {\n\t\t\tif (renderType === \"select\" && config?.options)\n\t\t\t\treturn config?.options.map((item: any) => <el-option label={item.label} value={item.value} />);\n\t\t\tif (renderType === \"radio-group\" && config?.options)\n\t\t\t\treturn config?.options.map((item: any) => <el-radio label={item.label} value={item.value} />);\n\t\t\treturn null;\n\t\t};\n\t\tconst { options, ...conf } = config || {};\n\t\tif (renderType === \"cascader\")\n\t\t\treturn (\n\t\t\t\t<el-cascader\n\t\t\t\t\t{...event}\n\t\t\t\t\t{...conf}\n\t\t\t\t\toptions={options}\n\t\t\t\t\tv-model={formData.value[prop]}\n\t\t\t\t\tplaceholder={`请选择${label}`}\n\t\t\t\t></el-cascader>\n\t\t\t);\n\t\tlet isSelect = renderType && [\"select\", \"cascader\"].includes(renderType);\n\t\treturn (\n\t\t\t<Component {...event} placeholder={`请${isSelect ? \"选择\" : \"输入\"}${label}`} {...conf} v-model={formData.value[prop]}>\n\t\t\t\t{renderChildComponent}\n\t\t\t</Component>\n\t\t);\n\t};\n\t//动态插槽\n\tconst formItemSlots = (form: FormItem) => form.slotName && slots[form.slotName]?.(formData.value);\n\tconst renderFormItem = (formList: any[]) => {\n\t\tconst renderForm = (form: FormItem) => {\n\t\t\tconst { className, ...formProps } = form;\n\t\t\treturn (\n\t\t\t\t<el-form-item\n\t\t\t\t\tclass={`${formLayout === \"vertical\" ? \"flex flex-col \" : \"\"} ${formStyle?.formItemClassName ?? \"\"} ${className ?? \"\"} ${\n\t\t\t\t\t\t!form.label ? \"no-label-item\" : \"\"\n\t\t\t\t\t}`}\n\t\t\t\t\t{...formProps}\n\t\t\t\t\tprop={form.prop}\n\t\t\t\t\tlabelWidth={formStyle?.labelWidth}\n\t\t\t\t\tkey={form.prop}\n\t\t\t\t>\n\t\t\t\t\t{{\n\t\t\t\t\t\tdefault: () => {\n\t\t\t\t\t\t\tif (form?.render) return form?.render(formData.value);\n\t\t\t\t\t\t\tif (form.renderType) return dynamicComponent(form);\n\t\t\t\t\t\t\treturn form?.slotName && formItemSlots(form);\n\t\t\t\t\t\t},\n\t\t\t\t\t\tlabel: () =>\n\t\t\t\t\t\t\tform.label ? (\n\t\t\t\t\t\t\t\t<div class={`flex items-center gap-5 ${form.labelClassName ?? \"\"}`}>\n\t\t\t\t\t\t\t\t\t{form.label}\n\t\t\t\t\t\t\t\t\t{form.promptConf ? (\n\t\t\t\t\t\t\t\t\t\t<el-tooltip {...form.promptConf?.tooltipConf}>\n\t\t\t\t\t\t\t\t\t\t\t<el-icon size={form.promptConf?.size ?? 15} color={form.promptConf?.color}>\n\t\t\t\t\t\t\t\t\t\t\t\t<Question />\n\t\t\t\t\t\t\t\t\t\t\t</el-icon>\n\t\t\t\t\t\t\t\t\t\t</el-tooltip>\n\t\t\t\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t\t\t\t\"\"\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t) : null\n\t\t\t\t\t}}\n\t\t\t\t</el-form-item>\n\t\t\t);\n\t\t};\n\t\t//处理分组的情况\n\t\treturn formList\n\t\t\t.filter(form => !form.show || form.show(formData.value))\n\t\t\t.map((form: FormItem) => {\n\t\t\t\tif (form.children && form.children.length > 0) {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<div class={`flex flex-col ${form.groupWrapClassName ?? \"\"}`} style={{ ...form?.groupWrapStyle }}>\n\t\t\t\t\t\t\t<div class={form.groupTitleClassName ?? \"\"} style={{ ...form?.groupTitleStyle }}>\n\t\t\t\t\t\t\t\t{form.groupName}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t<div class={`grid ${form.groupClassName ?? \"\"}`} style={{ ...getGroupStyle(form?.groupStyle ?? {}) }}>\n\t\t\t\t\t\t\t\t{form.children.filter(form => !form.show || form.show(formData.value)).map(form => renderForm(form))}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\treturn renderForm(form);\n\t\t\t\t}\n\t\t\t});\n\t};\n\treturn (\n\t\t<>\n\t\t\t<el-form\n\t\t\t\tscroll-to-error\n\t\t\t\tmodel={formData.value}\n\t\t\t\trules={formRules.value}\n\t\t\t\tclass=\"grid\"\n\t\t\t\tref={formRef}\n\t\t\t\tvalidate-on-rule-change={false}\n\t\t\t\t{...attrs}\n\t\t\t\tstyle={{ ...getFormStyle() }}\n\t\t\t>\n\t\t\t\t{renderFormItem(formColumn.value)}\n\t\t\t</el-form>\n\t\t</>\n\t);\n};\n//表单验证\nconst formValidate = async (): Promise<boolean> => {\n\tif (!formRef.value) return Promise.resolve(false);\n\treturn await formRef.value.validate(() => Promise.resolve());\n};\ndefineExpose({\n\tformData,\n\tformValidate,\n\tformRef\n});\ndefineOptions({\n\tname: \"YxForm\"\n});\n</script>\n<template>\n\t<component :is=\"render(props)\" />\n</template>\n<style scoped lang=\"scss\">\n.no-label-item :deep() .el-form-item__label {\n\tpadding-right: 0;\n\theight: 0;\n\tline-height: 0;\n}\n</style>\n","/*\n * @Author: WangXin\n * @Date: 2023-12-06 17:21:49\n * @LastEditors: WangXin\n * @LastEditTime: 2023-12-08 10:35:59\n * @FilePath: \\yxUse\\packages\\utils\\common\\update.ts\n * @Description:\n *\n * Copyright (c) 2023 by YuXing, All Rights Reserved.\n */\nimport { Update } from \"@packages/components\";\nimport { createApp } from \"vue\";\nlet versionKey, versionJsonUrl, _timer, curVersion, updateApp, timeGap;\n//每5分钟请求一次\nexport const monitorUpdate = (systemName, gap = 300) => {\n\ttimeGap = gap;\n\ttimedExecution(systemName);\n};\nconst timedExecution = systemName => {\n\t_timer = setTimeout(() => {\n\t\tgetVersion(systemName);\n\t\t_timer && clearTimeout(_timer);\n\t\ttimedExecution(systemName);\n\t\t// localStorage.removeItem(versionKey + \"delayTime\");\n\t}, timeGap * 1000);\n};\nconst getVersion = async (systemName: string) => {\n\tversionKey = `${systemName}_version`;\n\tconst systemPre = window.location.pathname.split(\"/\")[1] || \"ttc\";\n\tconsole.log(versionKey, systemPre);\n\t// versionJsonUrl = `/${systemPre}/${systemName}/version.json`;\n\tversionJsonUrl = \"/version.json\";\n\tconst oldVersion = localStorage.getItem(versionKey) || \"\";\n\tconst data = await fetch(versionJsonUrl, { cache: \"no-cache\" });\n\tconst { version, message, isNotice } = await data.json();\n\t// 没有历史版本则给缓存注入版本\n\tif (!oldVersion) {\n\t\tlocalStorage.setItem(versionKey, version);\n\t}\n\t//如果新版本与用户当前版本不一致,则提醒用户有版本更新\n\n\tif (oldVersion !== version) {\n\t\tif (isNotice) {\n\t\t\t//通知用户\n\t\t\tconsole.log(\"监测到有新版本\", version);\n\t\t\tnoticeUser(message);\n\t\t}\n\t\tcurVersion = version;\n\t}\n};\n//立即更新\nexport const updateSysVersion = () => {\n\tlocalStorage.setItem(versionKey, curVersion);\n\twindow.location.reload(true);\n};\n//暂不更新,加入延迟时间1小时\nexport const delayUpdateSysVersion = () => {\n\t//隐藏弹窗\n\tupdateApp.unmount();\n\tdocument.body.removeChild(document.querySelector(\"#update\"));\n\tlocalStorage.setItem(versionKey, curVersion);\n};\nconst noticeUser = message => {\n\tif (!document.querySelector(\"#update\")) {\n\t\tconst div = document.createElement(\"div\");\n\t\tdiv.setAttribute(\"id\", \"update\");\n\t\tdiv.style.position = \"absolute\";\n\t\tdiv.style.width = \"100%\";\n\t\tdiv.style.height = \"100%\";\n\t\tdiv.style.top = \"0\";\n\t\tdiv.style.left = \"0\";\n\t\tdocument.body.appendChild(div);\n\t\tupdateApp = createApp(Update, message);\n\t\tupdateApp.mount(\"#update\");\n\t}\n};\n","<script setup lang=\"ts\">\nimport { ref, reactive, defineProps } from \"vue\";\nimport { updateSysVersion, delayUpdateSysVersion } from \"@packages/utils/common/update\";\n// const props =\ninterface UpdateProps {\n\ttitle: String;\n\tdescription: String;\n\tcontent: Object;\n\ttime: String;\n}\n\nconst props = defineProps<UpdateProps>();\nconsole.log(props);\n</script>\n<template>\n\t<div class=\"update-wrap flex items-center justify-center\">\n\t\t<div class=\"relative update-content\">\n\t\t\t<div class=\"flex items-center justify-center\">{{ props?.title }}</div>\n\t\t\t<div class=\"flex flex-col gap-5 mt-10\">\n\t\t\t\t<div class=\"update-title\">{{ props?.description }}</div>\n\t\t\t\t<div class=\"update-item px-20\" v-for=\"(item, key) in props?.content\">\n\t\t\t\t\t<span>{{ key }}:</span> <span>{{ item }}</span>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"text-end\">{{ props.time }} 软件专业部</div>\n\t\t\t\t<div class=\"flex justify-end items-center mt-10\">\n\t\t\t\t\t<el-button plain @click=\"delayUpdateSysVersion\">暂不更新</el-button>\n\t\t\t\t\t<el-button @click=\"updateSysVersion\">立即更新</el-button>\n\t\t\t\t</div>\n\t\t\t\t<span class=\"tips mt-10\"\n\t\t\t\t\t>提示: 选择立即更新后,会立即刷新页面更新系统,当前页面缓存数据会消失选择暂不更新后,请稍后自行刷新页面更新系统。</span\n\t\t\t\t>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</template>\n<style scoped lang=\"scss\">\n.update-wrap {\n\tposition: absolute;\n\twidth: 100%;\n\theight: 100%;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tbackground: var(--dialog-overlay-background);\n\tz-index: 9999;\n\tcolor: var(--dialog-header-text-color);\n\tfont-family: YX-TEXT;\n\t.update-content {\n\t\twidth: 30%;\n\t\theight: fit-content;\n\t\tbackground: var(--dialog-background);\n\t\tborder-radius: var(--border-radius-medium);\n\t\tpadding: 20px 20px 10px 20px;\n\t\tbox-sizing: border-box;\n\t\t.tips {\n\t\t\tfont-size: 12px;\n\t\t}\n\t}\n}\n</style>\n","<!--\n * @Author: WangXin\n * @Date: 2024-04-02 20:01:00\n * @LastEditors: WangXin\n * @LastEditTime: 2024-04-11 15:11:58\n * @FilePath: /yxuse/packages/components/YxIcon/index.vue\n * @Description: \n * \n * Copyright (c) 2024 by YuXing, All Rights Reserved. \n-->\n<template>\n\t<i class=\"yx-icon\" :style=\"[{ '--color': color, 'font-size': size + 'px' }]\">\n\t\t<slot />\n\t</i>\n</template>\n\n<script>\n// import { version, createApp } from \"vue\";\n// console.log(this.$options);\nexport default {\n\tprops: {\n\t\tcolor: {\n\t\t\ttype: String,\n\t\t\tdefault: \"inherit\"\n\t\t},\n\t\tsize: {\n\t\t\ttype: String,\n\t\t\tdefault: \"16\"\n\t\t}\n\t}\n};\n</script>\n\n<style scoped>\n.yx-icon {\n\t--color: inherit;\n\tposition: relative;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\twidth: 1em;\n\theight: 1em;\n\tline-height: 1em;\n\tcolor: var(--color);\n\tfill: currentColor;\n}\n</style>\n","<!--\r\n * @Author: WangXin\r\n * @Date: 2024-03-20 09:40:21\r\n * @LastEditors: WangXin\r\n * @LastEditTime: 2025-05-22 09:26:11\r\n * @FilePath: /yxuse/packages/components/YxUpload/index.vue\r\n * @Description: \r\n * \r\n * Copyright (c) 2024 by YuXing, All Rights Reserved. \r\n-->\r\n<script setup lang=\"tsx\">\r\nimport { ref, useAttrs, useSlots } from \"vue\";\r\nimport type { UploadProps, UploadRawFile, UploadUserFile, UploadInstance } from \"element-plus\";\r\nimport { genFileId } from \"element-plus\";\r\nimport type { YxUploadProps } from \"./type\";\r\nimport { assets } from \"@packages/api\";\r\nconst attrs = useAttrs();\r\nconst slots = useSlots();\r\nconst fileList = ref<UploadUserFile[]>([]);\r\nconst props = defineProps<YxUploadProps>();\r\nlet uploadFileList: UploadUserFile[] = [];\r\nconst fileObsUrl = ref(\"\");\r\nconst upload = ref<UploadInstance>();\r\nconst emit = defineEmits<{\r\n\t(e: \"update:fileObsUrl\", value: string): void;\r\n\t(e: \"getFile\", value: any): void;\r\n}>();\r\nconst uploadFile = async (file: any) => {\r\n\tif (props?.customUpload) {\r\n\t\treturn props?.customUpload(file);\r\n\t}\r\n\tconst fromData = new FormData();\r\n\tfromData.append(\"file\", file);\r\n\tconst { data } = await (props?.uploadResourceApi ? props?.uploadResourceApi(fromData) : assets.uploadResourceApi(fromData));\r\n\tfileObsUrl.value = data.fileUrl;\r\n\temit(\"update:fileObsUrl\", fileObsUrl.value);\r\n};\r\nconst onExceed: UploadProps[\"onExceed\"] = async files => {\r\n\tupload.value!.clearFiles();\r\n\tconst file = files[0] as UploadRawFile;\r\n\tfile.uid = genFileId();\r\n\tupload.value!.handleStart(file);\r\n};\r\nconst onChange = async (file: UploadUserFile, uploadFiles: UploadUserFile[]) => {\r\n\tuploadFileList = uploadFiles;\r\n\tif (attrs?.limit && attrs?.limit === 1) {\r\n\t\tawait uploadFile(uploadFileList[0]?.raw);\r\n\t} else {\r\n\t\tawait uploadFile(uploadFileList);\r\n\t}\r\n};\r\n/**多文件使用 getFileList*/\r\nconst getFileList = () => uploadFileList;\r\ndefineExpose({ upload, getFileList });\r\nconst render = (props: YxUploadProps) => {\r\n\tconst defaultTrigger = () => {\r\n\t\treturn <el-button>{props.triggerText ?? \"上传文件\"}</el-button>;\r\n\t};\r\n\treturn (\r\n\t\t<>\r\n\t\t\t<el-upload\r\n\t\t\t\tref={upload}\r\n\t\t\t\tclass=\"w-full h-full\"\r\n\t\t\t\thttp-request={uploadFile}\r\n\t\t\t\tfile-list={fileList.value}\r\n\t\t\t\t{...attrs}\r\n\t\t\t\ton-exceed={onExceed}\r\n\t\t\t\ton-change={onChange}\r\n\t\t\t\tauto-upload={false}\r\n\t\t\t>\r\n\t\t\t\t{{\r\n\t\t\t\t\ttrigger: () => {\r\n\t\t\t\t\t\treturn props?.triggerRender\r\n\t\t\t\t\t\t\t? props?.triggerRender(fileObsUrl.value)\r\n\t\t\t\t\t\t\t: slots[\"trigger\"]\r\n\t\t\t\t\t\t\t? slots[\"trigger\"]()\r\n\t\t\t\t\t\t\t: defaultTrigger();\r\n\t\t\t\t\t},\r\n\t\t\t\t\ttip: () => {\r\n\t\t\t\t\t\treturn <div class=\"el-upload__tip\">{props?.uploadTips}</div>;\r\n\t\t\t\t\t}\r\n\t\t\t\t}}\r\n\t\t\t</el-upload>\r\n\t\t</>\r\n\t);\r\n};\r\n</script>\r\n<template>\r\n\t<component :model-value=\"fileObsUrl\" :is=\"render(props)\" />\r\n</template>\r\n<style scoped lang=\"scss\"></style>\r\n","<!--\n * @Author: WangXin\n * @Date: 2025-05-08 14:48:05\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-12 10:02:39\n * @FilePath: /yxuse/packages/components/LogoTitle/index.vue\n * @Description: \n * \n * Copyright (c) ${2024} by YuXing, All Rights Reserved. \n-->\n<script lang=\"ts\">\nimport { auth } from \"@packages/api\";\nimport type { SystemConfig } from \"./type\";\nexport default {\n\tname: \"LogoTitle\",\n\tprops: {\n\t\tshowLogo: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true\n\t\t},\n\t\tshowTitle: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t},\n\t\tlogoCanJump: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true\n\t\t}\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tcustomConfig: {\n\t\t\t\ticonStyle: {\n\t\t\t\t\twidth: \"116px\",\n\t\t\t\t\theight: \"20px\"\n\t\t\t\t}\n\t\t\t} as SystemConfig\n\t\t};\n\t},\n\tasync created() {\n\t\ttry {\n\t\t\tconst data = await auth.getUserConfig();\n\t\t\tthis.customConfig = {\n\t\t\t\t...this.customConfig,\n\t\t\t\t...data\n\t\t\t};\n\t\t} catch (e) {\n\t\t\tconsole.error(\"获取用户配置失败\", e);\n\t\t}\n\t},\n\tmethods: {\n\t\tlogoJumpHandle() {\n\t\t\tif (this.customConfig?.logoCanJump === false) return;\n\t\t\tauth.jumpToHome();\n\t\t}\n\t}\n};\n</script>\n\n<template>\n\t<div\n\t\tclass=\"flex items-center gap-x-10 logo-wrap\"\n\t\t:class=\"{ 'cursor-pointer': customConfig?.logoCanJump !== false }\"\n\t\t@click=\"logoJumpHandle\"\n\t>\n\t\t<div\n\t\t\tv-if=\"showLogo && customConfig?.icon\"\n\t\t\t:style=\"customConfig.iconStyle\"\n\t\t\tclass=\"yx-icon theme-icon\"\n\t\t\tv-html=\"customConfig.icon\"\n\t\t/>\n\t\t<div\n\t\t\t:style=\"customConfig.titleStyle\"\n\t\t\tv-if=\"showTitle && customConfig?.title\"\n\t\t\tclass=\"text-xl text-[var(--text-color-title)] title\"\n\t\t>\n\t\t\t{{ customConfig?.title }}\n\t\t</div>\n\t</div>\n</template>\n\n<style scoped>\n.logo-wrap {\n\tline-height: 1;\n}\n.yx-icon :deep() svg {\n\tvertical-align: middle;\n}\n</style>\n","/*\n * @Author: WangXin\n * @Date: 2025-05-08 14:48:05\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-08 18:01:08\n * @FilePath: /yxuse/packages/components/LogoTitle/index.ts\n * @Description:\n *\n * Copyright (c) ${2024} by YuXing, All Rights Reserved.\n */\nexport { default as LogoTitle } from \"./index.vue\";\nimport { version, createApp } from \"vue\";\nimport type { LogoTitleProps } from \"./type\";\nimport LogoTitle from \"./index.vue\";\nexport class LogoTitleRender {\n\tconstructor(props: LogoTitleProps, domId: string = \"system-logo-title\") {\n\t\tthis.render(props, domId);\n\t}\n\tget vueVersion(): \"2\" | \"3\" {\n\t\treturn version[0] as `${\"2\" | \"3\"}`;\n\t}\n\trender(props: LogoTitleProps, domId: string) {\n\t\tif (this.vueVersion === \"3\") {\n\t\t\tcreateApp(LogoTitle, props).mount(`#${domId}`);\n\t\t} else {\n\t\t\tconst Vue = require(\"vue\");\n\t\t\treturn new Vue({ render: h => h(LogoTitle, { props }) }).$mount(`#${domId}`);\n\t\t}\n\t}\n}\n"],"names":["dialogOptions","reactive","width","show","title","loading","showFooter","autoClose","close","dialogMap","submit","async","err","__expose","cancel","beforeOpen","beforeSubmit","drawerOptions","drawerMap","XLSX","current_ansi","VALID_ANSI","set_ansi","cp","indexOf","set_cp","reset_cp","$cptable","_getchar","x","String","fromCharCode","_getansi","Base64_map","Base64_encode","input","o","c1","c2","c3","e1","e2","e3","e4","i","length","charCodeAt","isNaN","charAt","Base64_decode","replace","has_buf","Buffer","process","versions","node","Buffer_from","nbfs","from","e","buf","enc","bind","new_raw_buf","len","alloc","Uint8Array","Array","new_unsafe_buf","allocUnsafe","s2a","s","split","map","s2ab","ArrayBuffer","view","a2s","data","isArray","c","join","bconcat","bufs","concat","isBuffer","maxlen","set","apply","slice","call","chr0","chr1","_strrev","pad0","v","d","t","fill","pad_","rpad_","p2_32","Math","pow","pad0r","round","pad0r1","pad0r2","SSF_isgeneral","days","months","table_fmt","SSF_default_map","SSF_default_str","SSF_frac","D","mixed","sgn","B","P_2","P_1","P","Q_2","Q_1","Q","A","floor","q","SSF_parse_date_code","opts","b2","date","time","dow","dout","out","T","u","y","m","H","M","S","abs","date1904","Date","setDate","getDate","getFullYear","getMonth","getDay","SSF_fix_hijri","SSFbasedate","SSFdnthresh","getTime","SSFbase1904","datenum_local","epoch","getTimezoneOffset","SSF_strip_decimal","SSF_general_num","V","log","LOG10E","toPrecision","w","toFixed","toExponential","SSF_small_exp","substr","SSF_large_exp","SSF_normalize_exp","toUpperCase","SSF_general","toString","SSF_format","Error","SSF_write_date","type","fmt","val","ss0","ss","tt","outl","commaify","j","pct1","write_num_exp","idx","match","period","ee","fakee","$$","$1","$2","$3","frac1","dec1","closeparen","phone","hashq","str","cc","rnd","dd","dec","_frac","write_num_flt","ffmt","write_num","write_num_cm","sfmt","mul","write_num_pct","r","ri","ff","aval","sign","den","parseInt","rr","base","myn","myd","write_num_f1","carry","oa","min","max","lres","rres","flr","write_num_exp2","write_num_int","write_num_cm2","write_num_pct2","write_num_f2","lastIndexOf","SSF_abstime","fmt_is_date","cfregex2","chkcond","thresh","parseFloat","choose_fmt","f","in_str","SSF_split_fmt","l","lat","m1","m2","dateNF","table","flen","dt","lst","hr","toLowerCase","ssm","bt","jj","nstr","myv","ostr","vv","decpt","lasti","retval","eval_fmt","SSF_load","SSF_load_table","tbl","make_ssf","dateNFregex","CRC32","version","T0","n","Int32Array","signed_crc_table","TT","subarray","slice_by_16_tables","T1","T2","T3","T4","T5","T6","T7","T8","T9","Ta","Tb","Tc","Td","Te","Tf","bstr","seed","C","L","CFB","fs","exports","dirname","p","filename","write_dos_date","hms","getHours","getMinutes","getSeconds","write_shift","ymd","parse_extra_field","blob","prep_blob","flags","read_shift","sz","tgt","mtime","atime","ctime","mt","get_fs","parse","file","options","parse_zip","root","di","row","test","mboundary","boundary","FileIndex","FullPaths","init_cfb","start_di","fcnt","line","parse_mad","mver","nmfs","difat_sec_cnt","dir_start","minifat_start","difat_start","ssz","fat_addrs","mv","chk","HEADER_SIGNATURE","check_get_mver","header","shift","check_shifts","dir_cnt","sectors","nsectors","ceil","sectorify","sleuth_fat","sector_list","sl","chkd","buf_chain","modulus","k","seen","push","addr","__readInt32LE","nodes","__toBuffer","make_sector_list","name","ENDOFCHAIN","Paths","files","mini","minifat_store","pl","sector","namelen","__utf16le","color","R","clsid","state","start","size","ct","read_date","storage","get_sector_list","content","get_mfat_entry","read_directory","FI","FP","dad","build_full_paths","raw","entry","payload","MSSZ","new_buf","cnt","offset","__readUInt32LE","cfb","CLSID","nm","find","rebuild_cfb","seed_cfb","gc","_file","pop","now","fullPaths","Object","create","HEADER_CLSID","sort","Z","namecmp","elt","_write","_opts","fileType","fp","fi","ca","cstr","dispcnt","csl","qp","get_content_type","write_quoted_printable","write_base64_76","write_mad","write_zip","cdirs","method","compression","start_cd","crcs","sz_cd","namebuf","outbuf","_deflateRawSync","mini_size","fat_size","mfat_cnt","fat_base","fat_cnt","difat_cnt","HEADER_SIG","chainit","consts","DIFSECT","FATSECT","_nm","copy","_zlib","MAXREGSECT","FREESECT","HEADER_MINOR_VERSION","MAXREGSID","NOSTREAM","EntryTypes","deflateRawSync","_deflate","CLEN_ORDER","LEN_LN","DST_LN","use_typed_arrays","bitswap8","bit_swap_n","b","rev","read_bits_2","bl","h","read_bits_3","read_bits_5","read_bits_7","read_bits_n","write_bits_3","write_bits_1","write_bits_8","write_bits_16","realloc","a","zero_fill_array","build_tree","clens","cmap","MAX","ccode","bl_count","Uint16Array","ctree","cleni","fix_lmap","fix_dmap","dlens","_deflateRaw","DST_LN_RE","LEN_LN_RE","boff","write_stored","addrs","hash","mlen","len_eb","dst_eb","write_huff_fixed","off","dyn_lmap","dyn_dmap","dyn_cmap","dyn_len_1","dyn_len_2","dyn","_HLIT","_HDIST","_HCLEN","read_bits_4","next_code","hcodes","h1","h2","_inflate","usz","woff","OL","max_len_1","max_len_2","bits","code","dst","inflate","warn_or_throw","wrn","msg","csz","efsz","fcsz","EF","parse_local_file","meth","setMilliseconds","setFullYear","setMonth","setHours","setMinutes","setSeconds","parse_dos_date","_csz","_usz","ef","InflRaw","InflateRaw","_processChunk","_finishFlushFlag","bytesRead","_inflateRawSync","cfb_add","unsafe","ContentTypeMap","htm","xml","gif","jpg","png","mso","thmx","sh33tj5","ctype","ext","text","encoded","si","end","tmp","parse_mime","fdata","fname","cte","trim","oi","parse_quoted_printable","fpath","utils","cfb_gc","path","UCFullPaths","UCPaths","UCPath","read","readFileSync","read_file","write","writeFileSync","writeFile","cfb_new","cfb_del","splice","cfb_mov","old_name","new_name","ReadShift","CheckField","use_zlib","zlib","_inflateRaw","blobify","a2u","write_dl","Deno","TextEncoder","encode","utf8write","IE_SaveFile","Blob","navigator","msSaveBlob","saveAs","URL","document","createElement","createObjectURL","url","chrome","downloads","download","revokeObjectURL","setTimeout","href","body","appendChild","click","removeChild","$","File","Folder","open","encoding","message","keys","ks","o2","prototype","hasOwnProperty","evert_key","obj","key","K","evert","evert_num","basedate","datenum","dnthresh","refdate","refoffset","numdate","setTime","good_pd_date_1","good_pd_date","good_pd","parseDate","fixdate","cc2str","arr","debomit","TextDecoder","decode","dup","JSON","stringify","fuzzynum","Number","isFinite","NaN","wt","lower_months","fuzzydate","getYear","lower","zip_add_file","zip","res","widx","ridx","utf8decode","zip_new","XML_HEADER","rencoding","decregex","charegex","escapexml","escapexmltag","htmlcharegex","utf8reada","orig","utf8readb","ww","utf8readc","utf8corpus","utf8read","htmldecode","entities","RegExp","wtregex","writetag","g","wxt_helper","writextag","write_w3cdtf","toISOString","XMLNS","XMLNS_main","XLMLNS","___toBuffer","___utf16le","__readUInt16LE","___hexlify","__hexlify","___utf8","__readUInt8","__utf8","___lpstr","__lpstr","___cpstr","__cpstr","___lpwstr","__lpwstr","___lpp4","__lpp4","___8lpp4","__8lpp4","___double","Infinity","read_double_le","__double","is_buf","readUInt32LE","readDoubleLE","__readInt16LE","__readInt32BE","oI","oR","loc","oo","this","lens","__writeUInt32LE","__writeInt32LE","__writeUInt16LE","WriteShift","bs","av","LN2","write_double_le","hexstr","fld","pos","parsenoop","buf_array","blksz","newblk","curbuf","endbuf","next","_bufs","write_record","ba","XLSBRecordEnum","shift_cell_xls","cell","cRel","rRel","biff","shift_range_xls","range","encode_cell_xls","encode_cell","fix_row","encode_range_xls","encode_row","encode_col","decode_row","rowstr","decode_col","colstr","col","decode_cell","decode_range","encode_range","cs","ce","safe_decode_range","safe_format_cell","z","XF","numFmtId","format_cell","BErr","sheet_to_workbook","sheet","sheets","SheetNames","Sheets","sheet_add_aoa","_ws","dense","ws","_R","_C","origin","_origin","_range","__R","__C","nullError","sheetStubs","cellDates","cell_ref","aoa_to_sheet","write_UInt32LE","parse_XLWideString","cchCharacters","write_XLWideString","_null","parse_StrRun","ich","ifnt","parse_RichStr","rgsStrRun","dwSizeStrRun","parse_BrtCommentText","write_BrtCommentText","run","write_StrRun","parse_XLSBCell","iStyleRef","write_XLSBCell","parse_XLSBShortCell","write_XLSBShortCell","parse_XLSBCodeName","write_XLSBCodeName","parse_XLNullableWideString","write_XLNullableWideString","parse_XLNameWideString","parse_RelID","write_RelID","parse_RkNumber","fX100","fInt","RK","write_RkNumber","d100","parse_RfX","parse_UncheckedRfX","write_UncheckedRfX","parse_Xnum","write_Xnum","write_BrtColor","auto","index","theme","nTS","tint","rgb","VT_STRING","DocSummaryPIDDSI","SummaryPIDSI","rgbify","XLSIcv","ct2type","CT_LIST","workbooks","xlsx","xlsm","xlsb","xlam","xltx","strs","comments","charts","dialogs","macros","metadata","styles","write_ct","type2ct","evert_arr","xmlns","Extension","ContentType","f1","PartName","bookType","f2","forEach","f3","RELS","WB","HLINK","VML","XPATH","XMISS","CMNT","CORE_PROPS","EXT_PROPS","CUST_PROPS","SST","STY","THEME","WS","DRAW","XLMETA","TCMNT","PEOPLE","VBA","get_rels_path","write_rels","rels","rid","add_rels","rId","relobj","targetmode","Id","Type","Target","TargetMode","write_rdf_type","tag","write_meta_ods","cp_doit","write_core_props","Props","CreatedDate","WTF","ModifiedDate","PseudoPropsPairs","write_ext_props","W","Application","Worksheets","baseType","write_cust_props","pid","write_vt","fmtid","XLMLDocPropsMap","Title","Subject","Author","Keywords","Comments","LastAuthor","RevNumber","LastPrinted","Category","Manager","Company","AppVersion","ContentStatus","Identifier","Language","write_TypedPropertyValue","value","write_FILETIME","XLSPSSkip","guess_property_type","write_PropertySet","entries","RE","PIDSI","hdr","piao","prop","pr","pio","unshift","pinfo","write_PropertySetStream","entries2","clsid2","ps0","ps1","writebool","parseuint16","writeuint16","write_Bes","parse_ShortXLUnicodeString","cch","write_XLUnicodeRichExtendedString","xlstr","otext","write_XLUnicodeString","write_HyperlinkString","write_Hyperlink","hl","hashidx","F","Pretarget","write_XLSCell","ixfe","parse_XTI","parse_Ref8U","rwFirst","rwLast","write_Ref8U","write_BOF","wb","write_BoundSheet8","hs","write_Format","b5","write_XF","ixfeP","style","write_HLink","O","ref","write_HLinkTooltip","Tooltip","DBF","dbf_codepage_map","dbf_reverse_map","dbf_to_sheet","ft","memo","vfp","l7","nrow","fpos","rlen","current_cp","codepage","fields","field","hend","sheetRows","dbf_to_aoa","wch","_RLEN","to_workbook","to_sheet","from_sheet","aoa","sheet_to_json","headers","cols","hcnt","coltypes","colwidths","coldecimals","guess","_guess","hf","_f","hb","rout","_n","_s","SYLK","sylk_escapes","AA","BA","CA","DA","HA","JA","AE","BE","CE","HE","AI","BI","CI","HI","AO","BO","CO","DO","HO","AU","BU","CU","HU","Aa","Ba","Ca","Da","Ha","Ja","Ae","Be","Ce","He","Ai","Bi","Ci","Hi","Ao","Bo","Co","Do","Ho","Au","Bu","Cu","Hu","KC","Kc","DN","Dn","Hy","sylk_char_regex","sylk_char_fn","_","decode_sylk_char","newcc","sylk_to_aoa_str","records","rj","formats","next_cell_format","sht","rowinfo","colinfo","cw","Mval","rstr","record","RT","C_seen_K","C_seen_X","C_seen_S","C_seen_E","formula","rc_to_a1","shrbase","shift_formula_str","F_seen","hidden","process_col","hpt","hpx","pt2px","sylk_to_sheet","aoasht","sylk_to_aoa","write_ws_cell_sylk","a1_to_rc","preamble","RS","rec","wpx","width2px","px2char","rows","px2pt","coord","DIF","dif_to_aoa_str","dif_to_sheet","dif_to_aoa","push_field","topic","push_value","ETH","eth_to_sheet","eth_to_aoa","sep","meta","sheet_to_eth_data","PRN","set_text_arr","guess_seps","guess_sep_weights","guess_sep","instr","dsv_to_sheet_str","FS","sepcc","startcc","_re","finish_cell","Y","datestr","timestr","dateNF_fix","cellText","cellNF","outer","prn_to_sheet_str","lines","prn_to_aoa_str","prn_to_sheet","bytes","firstbyte","WK_","lotushopper","cb","Enum","WK1Enum","lotus_to_workbook_buf","next_n","sidx","snames","realnames","refguess","vers","qpro","tmpcell","WK3Enum","osheets","rnames","parse_cell","parse_LABEL","write_LABEL","write_INTEGER","write_NUMBER","wk1_parse_rc","rel","FuncTab","BinOpTab","parse_cell_3","write_LABEL_16","wsidx","parse_NUMBER_17","v1","v2","write_NUMBER_17","log2","parse_NUMBER_27","parse_SHEETNAMECS","write_XFORMAT_SHEETNAME","argc","argL","argR","args","wk1_fmla_to_csf","id","sheet_to_wk1","write_biff_rec","write_RANGE","max_R","book_to_wk3","wscnt","write_BOF_WK3","straywsregex","write_sst_xml","sst","bookSST","count","Count","uniqueCount","Unique","sitag","write_BrtSSTItem","write_sst_bin","write_BrtBeginSst","crypto_CreatePasswordVerifier_Method1","Password","PasswordArray","Verifier","PasswordDecoded","_JS2ANSI","RTF","rtf_to_sheet","rtf_to_sheet_str","rowtf","rtfre","last_index","exec","lastIndex","rgb2Hex","MDW","px","char2width","chr","coll","customWidth","PPI","pt","write_sty_xml","SSF","NF","formatCode","write_numFmts","cellXfs","write_cellXfs","write_BrtFmt","write_BrtFont","font","grbit","italic","strike","outline","shadow","condense","extend","write_FontFlags","bold","sss","vertAlign","underline","family","charset","rev_XLSBFillPTNames","XLSBFillPTNames","parse_BrtFill","write_BrtFill","fls","patternType","write_BrtXF","write_Blxf","parse_BrtBorder","write_BORDERS_bin","write_STYLES_bin","xfId","write_TABLESTYLES_bin","defTableStyle","defPivotStyle","write_BrtBeginTableStyles","write_sty_bin","write_FMTS_bin","write_FONTS_bin","write_FILLS_bin","write_CELLSTYLEXFS_bin","write_CELLXFS_bin","write_DXFS_bin","write_theme","Themes","themeXLSX","write_xlmeta_bin","write_BrtBeginEsfmd","write_BrtBeginEsmdb","mdb","write_BrtMdb","write_xlmeta_xml","_shapeid","write_comments_vml","csize","bbox","joinstyle","gradientshapeok","coordsize","fillopts","color2","angle","fillparm","fillxml","fillcolor","strokecolor","on","obscured","write_comments_xml","iauthor","ID","lastauthor","ts","write_tcmnt_xml","people","carr","rootid","tcopts","tcid","parentId","personId","parse_BrtCommentAuthor","write_comments_bin","comment","write_BrtCommentAuthor","write_BrtBeginComment","VBAFMTS","rcregex","rcbase","rcfunc","fstr","crefregex","$0","$4","$5","delta","parseread1","parse_ColRelU","parse_RgceArea","parse_RgceArea_BIFF2","parse_RgceLoc","parse_RgceLoc_BIFF2","parse_RgceElfLoc","fQuoted","parse_PtgAttrBaxcel","bitSemi","parse_PtgAttrSpaceType","parse_SerAr","parsebool","parse_XLUnicodeStringNoCch","parse_XLUnicodeString","parse_XLUnicodeString2","parse_PtgExtraMem","cce","parse_PtgExtraArray","parse_PtgElfLoc","parse_PtgElfNoop","parse_PtgElfLel","PtgListRT","PtgTypes","iftab","FtabArgc","Ftab","cparams","tab","parsetab","Cetab","nameindex","rl","parse_RgceLocRel_BIFF2","cl","parse_RgceLocRel","area","parse_RgceAreaRel","ixti","parse_PtgNameX_BIFF5","PtgDupes","Ptg18","coltype","rt","Ptg19","bitIf","bitGoto","stringify_array","PtgBinOp","PtgAdd","PtgConcat","PtgDiv","PtgEq","PtgGe","PtgGt","PtgLe","PtgLt","PtgMul","PtgNe","PtgPower","PtgSub","get_ixti_raw","supbooks","XTI","SID","Name","get_ixti","ixtiraw","sname","formula_quote_sheet_name","stringify_formula","stack","nameidx","last_sp","sp","fflen","func","lbl","names","xlfn","externbook","bookidx","itab","ixtidata","lp","rp","sharedf","parsedf","fnd","arrayf","_left","write_Formula","os","o1","write_FormulaValue","o3","bf","parse_XLSBParsedFormula","rgce","target","ptgs","parse_Rgce","rgcb","parse_RgbExtra","parse_XLSBArrayParsedFormula","parse_XLSBCellParsedFormula","parse_XLSBNameParsedFormula","parse_XLSBSharedParsedFormula","browser_has_Map","Map","get_sst_id","has","revarr","get","col_obj_w","level","outlineLevel","default_margins","margins","mode","defs","left","right","top","bottom","footer","get_cell_style","revssf","ssf","fontId","fillId","borderId","applyNumberFormat","check_ws","sheetprot_deffalse","sheetprot_deftrue","write_ws_xml_cell","oldt","oldv","Strings","revStrings","cm","write_ws_xml","rdata","_drawing","needed","props","vbaraw","cname","Workbook","CodeName","codeName","outlineprops","summaryBelow","summaryRight","above","write_ws_xml_sheetpr","sview","workbookViewId","Views","rightToLeft","RTL","write_ws_xml_sheetviews","sheetFormat","defaultRowHeight","baseColWidth","outlineLevelRow","write_ws_xml_cols","params","height","_cell","ht","customHeight","write_ws_xml_data","password","write_ws_xml_protection","Names","Sheet","Ref","write_ws_xml_autofilter","merges","write_ws_xml_merges","margin","relc","location","tooltip","ignoreEC","numberStoredAsText","sqref","write_row_header","miyRw","ncolspan","lcs","caddr","first","last","write_BrtRowHdr","parse_BrtWsDim","write_BrtWsDim","parse_BrtMergeCell","write_BrtMergeCell","BrtMarginKeys","write_ws_bin_cell","last_seen","ncell","write_BrtShortIsst","write_BrtCellIsst","write_BrtShortSt","write_BrtCellSt","write_BrtShortRk","write_BrtCellRk","write_BrtShortReal","write_BrtCellReal","write_BrtShortBool","write_BrtCellBool","write_BrtShortError","write_BrtCellError","write_BrtShortBlank","write_BrtCellBlank","write_MERGECELLS","write_COLINFOS","write_BrtColInfo","write_IGNOREECS","write_HLINKS","locidx","write_BrtHLink","write_WSVIEWS2","write_BrtBeginWsView","write_SHEETPROTECT","write_ws_bin","write_BrtWsProp","cap","write_CELLTABLE","write_AUTOFILTER","write_LEGACYDRAWING","WBPropsDef","badchars","check_ws_name","safe","check_wb","N","codes","cn","write_wb_xml","write_names","workbookPr","WBProps","Hidden","sheetId","Comment","localSheetId","write_BOOKVIEWS","vistab","write_wb_bin","write_BrtFileVersion","filterPrivacy","write_BrtWbProp","iTabID","strRelID","write_BrtBundleSh","write_BUNDLESHS","write_ws","write_cmnt","write_props_xlml","xlml_write_docprops","Custprops","BLACKLIST","xlml_write_custprops","write_name_xlml","write_ws_xlml_cell","attr","marr","mi","_v","write_ws_xlml_row","write_ws_xlml","write_ws_xlml_names","skip","write_ws_xlml_table","objects","scenarios","selectLockedCells","selectUnlockedCells","write_ws_xlml_wsopts","write_xlml","General","xf","write_sty_xlml","write_names_xlml","PSCLSID","write_xlscfb","wbpath","write_biff_buf","Keys","DSEntries","SEntries","CEntries","DocSummaryRE","SummaryRE","CEntries2","write_xls_props","vba","newpath","fill_vba_xls","cellFormula","Ptg","fBold","fItalic","fUnderline","fStrikeout","fOutline","fShadow","fCondense","fExtend","parse_FontFlags","bCharSet","xColorType","bR","bG","bB","icv","parse_BrtColor","scheme","ixfeParent","ifmt","cellStyles","colFirst","colLast","coldx","defaultThemeVersion","strName","autoCompressPictures","backupFile","checkCompatibility","hidePivotFieldList","promptedSolutions","publishItems","refreshAllConnections","saveExternalLinkValues","showBorderUnselectedTables","showInkAnnotation","showObjects","showPivotChartFilter","updateLinks","parse_BIFF5ExternSheet","rfx","fAlwaysCalc","relId","display","write_BIFF2Cell","write_ws_biff2_cell","write_BIFF2NUM","write_BIFF2BERR","write_BIFF2LABEL","write_biff2_buf","write_ws_biff2","write_FONTS_biff8","write_Font","write_ws_cols_biff8","write_ColInfo","write_ws_biff8_cell","write_Number","write_BoolErr","write_LabelSst","b8","write_Label","write_ws_biff8","_WB","_sheet","MAX_ROWS","write_Dimensions","write_Window2","write_MergeCells","HL","write_ws_biff8_hlinks","write_FEAT","write_biff8_global","_sheets","_wb","writezeroes","write_WriteAccess","write_RRTabId","parsexmlbool","safe1904","write_FMTS_biff8","write_CELLXFS_biff8","write_Country","parts","write_biff_continue","write_SST","blen","console","error","fix_write_opts","write_biff8_buf","make_html_row","CS","rowspan","colspan","editable","sheet_to_html","make_html_preamble","sheet_add_dom","or_R","or_C","getElementsByTagName","midx","is_dom_element_hidden","elts","children","hasAttribute","getAttribute","innerHTML","_t","Aelts","Aelti","parse_dom_table","element","get_computed_style","ownerDocument","defaultView","getComputedStyle","get_get_computed_style_function","getPropertyValue","write_styles_ods","master_styles","write_content_ods","null_cell_xml","ods","ROWS","textp","_Fref","text_p","_tgt","fods","cidx","colobj","write_automatic_styles_ods","write_ods","manifest","rdf","write_rdf","write_manifest","u8_to_dataview","array","DataView","buffer","byteOffset","byteLength","stru8","u8concat","u8a","reduce","acc","u8","parse_varint49","ptr","varint","write_varint49","varint_to_i32","i32","parse_shallow","num","write_shallow","proto","item","parse_iwa_file","_a","ai","messages","fl","merge","write_iwa_file","ias","ia","midata","aipayload","mid","parse_snappy_chunk","chunks","decompress_iwa_file","compress_iwa_file","frame","write_new_storage","dv","exp","mantissa","writeDecimal128LE","setFloat64","setUint32","write_old_storage","parse_TSP_Reference","write_tile_row","tri","_b","_c","_d","last_offset","cell_storage","_dv","_last_offset","_cell_storage","celload","_celload","setUint16","defaults","numbers","dependents","indices","packet2","deps","x2","y2","indices_varint","filter","ivi","some","mess","search","u8contains","docroot","xi","packet","sheetrootref","pb","cruidsref","oldbucket","_x","cruids","uuid","store","row_header_ref","base_bucket","_bucket","col_header_ref","sstref","sstroot","sentry","sx","sxi","sstdata","newsst","raw32","tile","tl","tileref","tileroot","tentry","tx","tiledata","rowload","R2","tilerow","raw3","write_numbers_iwa","wbrels","foo","wbext","vbafmt","threadedcomments","links","coreprops","extprops","custprops","themes","calcchains","drawings","TODO","_sn","_i","wsrels","need_vml","cf","rId1","write_sst","write_wb","write_sty","write_xlmeta","write_zip_xlsxb","needtc","person","displayName","userId","providerId","write_people_xml","write_zip_xlsx","write_cfb_ctr","write_zip_type","oopts","ftype","nodebuffer","string","generate","encrypt_agile","write_zip_denouement","write_string_type","bom","write_binary_type","writeSync","write_stxt_type","sheet_to_txt","sheet_to_csv","write_cfb_type","make_json_row","defval","isempty","defineProperty","enumerable","__rowNum__","rawNumbers","outi","counter","header_cnt","skipHidden","blankrows","qreg","make_csv_row","rs","txt","forceQuotes","endregex","strip","sheet_add_json","js","skipHeader","JS","ws_get_cell_stub","RC","cell_set_hyperlink","split_cell","json_to_sheet","table_to_sheet","table_to_book","sheet_to_formulae","cmds","sheet_to_row_object_array","sheet_get_cell","book_new","book_append_sheet","roll","book_set_sheet_visibility","sh","vis","wb_sheet_idx","cell_set_number_format","cell_set_internal_link","cell_add_comment","author","sheet_set_array_formula","dynamic","rng","rngstr","SHEET_VISIBLE","SHEET_HIDDEN","SHEET_VERY_HIDDEN","exportToExcel","tableData","fileName","finalData","label","XLSX.utils","xls","slk","socialcalc","Sh33tJS","resolve_book_type","_isSlot","_isVNode","__props","slots","useSlots","attrs","useAttrs","tableRef","tableFormRef","columns","isFormTable","formTableRules","emit","__emit","onMounted","nextTick","startSort","watch","initTable","onBeforeMount","renderType","includes","config","loadOptions","required","rules","getRules","sortDom","$el","querySelector","translate","Sortable","animation","handle","sortHandle","onEnd","oldIndex","newIndex","renderForm","component","_createVNode","createVNode","_resolveComponent","default","handleRule","isSelect","defaultRule","trigger","render","form","_slot2","rowKey","pageInfo","renderColumn","cellConf","scope","renderOperate","dynamicComponent","column","$index","_slot","event","Component","resolveComponent","restConfig","_mergeProps","modelValue","$event","placeholder","isFormCell","renderResult","needsValidation","isFragment","slotName","columnSlots","class","_createTextVNode","headerRender","headerSlotName","className","operate","op","onClick","withModifiers","_Fragment","model","renderTable","pagination","currentPage","pageIndex","pageSize","small","disabled","layout","background","total","onSizeChange","onCurrentChange","_slot3","exportDataToExcel","updateColumns","newColumns","tableFormValidate","validate","Promise","resolve","_hoisted_1","viewBox","Question","_ctx","_cache","_openBlock","openBlock","_createElementBlock","createElementBlock","_createElementVNode","formData","formRules","formColumn","initForm","formList","formParams","initialData","fillFormData","handleLinkOptions","hasLoadOptions","undefined","linkOptions","_linkedHandled","originOnChange","onChange","updateForm","notAutoLoadOptions","parentProp","parentValue","onUnmounted","formRef","getFormStyle","formStyle","gap","getGroupStyle","groupStyle","formLayout","Fragment","formProps","formItemClassName","labelWidth","renderChildComponent","conf","mergeProps","formItemSlots","labelClassName","promptConf","tooltipConf","groupWrapClassName","groupWrapStyle","groupTitleClassName","groupTitleStyle","groupName","groupClassName","renderFormItem","formValidate","versionKey","curVersion","updateSysVersion","localStorage","setItem","window","reload","delayUpdateSysVersion","updateApp","unmount","_sfc_main","_normalizeStyle","normalizeStyle","$props","_renderSlot","renderSlot","$slots","fileList","uploadFileList","fileObsUrl","upload","uploadFile","customUpload","fromData","FormData","append","uploadResourceApi","assets","fileUrl","onExceed","clearFiles","uid","genFileId","handleStart","uploadFiles","limit","getFileList","triggerRender","triggerText","tip","uploadTips","showLogo","Boolean","showTitle","logoCanJump","customConfig","iconStyle","created","auth.getUserConfig","methods","logoJumpHandle","auth.jumpToHome","$setup","$data","$options","_normalizeClass","icon","_createCommentVNode","createCommentVNode","titleStyle","_toDisplayString","toDisplayString","LogoTitleRender","constructor","domId","vueVersion","require","LogoTitle","$mount","createApp","mount"],"mappings":"0TAcM,MAAAA,EAAgBC,EAAAA,SAAS,CAC9BC,MAAO,MACPC,MAAM,EACNC,MAAO,GACPC,SAAS,EACTC,YAAY,EACZC,WAAW,IAENC,EAAQ,KAEbC,EAAkB,QAAKA,EAAkB,SACzCT,EAAcG,MAAO,CAAA,EAEhBM,EAAsC,CAAC,EACvCC,EAASC,UAEV,IAAAF,EAAwB,oBAAaA,EAAwB,eAA7D,CACJT,EAAcK,SAAU,EACpB,IACHI,EAAkB,cAAYA,EAAkB,SAChDT,EAAcK,SAAU,EACpBL,EAAcO,WAAiBC,UAC3BI,GACRZ,EAAcK,SAAU,CAAA,CAP8C,CAO9C,SAiBbQ,EAAA,CACZV,KAfYQ,OAAST,QAAOE,QAAOM,OAAAA,EAAQI,SAAQR,aAAYC,YAAWQ,aAAYC,mBAClFd,MAAqBA,MAAQA,GAC7BE,MAAqBA,MAAQA,QACd,IAAfE,IAA0BN,EAAcM,WAAaA,QACvC,IAAdC,IAAyBP,EAAcO,UAAYA,GACnDG,IAAkBD,EAAQ,OAAIC,GAC9BI,IAAkBL,EAAQ,OAAIK,GAC9BE,IAAwBP,EAAc,aAAIO,GAC1CD,SACGA,IAEPf,EAAcG,MAAO,CAAA,EAKrBK,m3BC1CK,MAAAS,EAAgBhB,EAAAA,SAAS,CAC9BC,MAAO,MACPC,MAAM,EACNC,MAAO,GACPC,SAAS,EACTC,YAAY,EACZC,WAAW,IAENC,EAAQ,KACbU,EAAkB,QAAKA,EAAkB,SACzCD,EAAcd,MAAO,CAAA,EAGhBe,EAAsC,CAAC,EACvCR,EAASC,UAEV,IAAAO,EAAwB,oBAAaA,EAAwB,eAA7D,CACJD,EAAcZ,SAAU,EACpB,IACHa,EAAkB,cAAYA,EAAkB,SAChDD,EAAcZ,SAAU,EACpBY,EAAcV,WAAiBC,UAC3BI,GACRK,EAAcZ,SAAU,CAAA,CAP8C,CAO9C,SAgBbQ,EAAA,CACZV,KAdYQ,OAAST,QAAOE,QAAOM,OAAAA,EAAQI,SAAQR,aAAYC,YAAWQ,aAAYC,mBAClFd,MAAqBA,MAAQA,GAC7BE,MAAqBA,MAAQA,QACd,IAAfE,IAA0BW,EAAcX,WAAaA,QACvC,IAAdC,IAAyBU,EAAcV,UAAYA,GACnDG,IAAkBQ,EAAQ,OAAIR,GAC9BI,IAAkBI,EAAQ,OAAIJ,GAC9BE,IAAwBE,EAAc,aAAIF,GAC1CD,SACGA,IAEPE,EAAcd,MAAO,CAAA,EAIrBK;;ACnDD,IAAIW,EAAO,CACXA,QAAe,UACcC,EAAe,KAExCC,EAAa,CAAE,IAAK,IAAK,IAAK,IAAK,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAyB9FC,EAAW,SAASC,IAAkD,GAA9BF,EAAWG,QAAQD,KAA6CH,EAAAG,EAAK,EAGjH,IAAIE,EAAS,SAASF,GAAwCD,EAASC,EAAM,EAC7E,SAASG,IAAaD,EAAO,MAHLH,EAAS,KAGgB,CAuBjD,IAGIK,EAHAC,EAAW,SAAcC,GAAkC,OAAAC,OAAOC,aAAaF,EAAK,EACpFG,EAAW,SAAcH,GAAkC,OAAAC,OAAOC,aAAaF,EAAK,EAsBpFI,EAAa,oEACjB,SAASC,EAAcC,GAGrB,IAFA,IAAIC,EAAI,GACJC,EAAK,EAAGC,EAAK,EAAGC,EAAK,EAAGC,EAAK,EAAGC,EAAK,EAAGC,EAAK,EAAGC,EAAK,EAChDC,EAAI,EAAGA,EAAIT,EAAMU,QAExBL,GADKH,EAAAF,EAAMW,WAAWF,OACX,EAELH,GAAK,EAALJ,IAAW,GADZC,EAAAH,EAAMW,WAAWF,OACK,EAErBF,GAAK,GAALJ,IAAY,GADbC,EAAAJ,EAAMW,WAAWF,OACM,EAC5BD,EAAU,GAALJ,EACDQ,MAAMT,GACRI,EAAKC,EAAK,GACDI,MAAMR,KACVI,EAAA,IAEPP,GAAKH,EAAWe,OAAOR,GAAMP,EAAWe,OAAOP,GAAMR,EAAWe,OAAON,GAAMT,EAAWe,OAAOL,GAE1F,OAAAP,CACT,CACA,SAASa,EAAcd,GACrB,IAAIC,EAAI,GACJC,EAAK,EAAGC,EAAK,EAAGC,EAAK,EAAWE,EAAK,EAAGC,EAAK,EAAGC,EAAK,EACjDR,EAAAA,EAAMe,QAAQ,eAAgB,IACtC,IAAA,IAASN,EAAI,EAAGA,EAAIT,EAAMU,QAGnBR,EAFAJ,EAAWT,QAAQW,EAAMa,OAAOJ,OAE1B,GADXH,EAAKR,EAAWT,QAAQW,EAAMa,OAAOJ,QAChB,EAChBR,GAAAN,OAAOC,aAAaM,GAEnBC,GAAK,GAALG,IAAY,GADlBC,EAAKT,EAAWT,QAAQW,EAAMa,OAAOJ,QACT,EACjB,KAAPF,IACGN,GAAAN,OAAOC,aAAaO,IAGrBC,GAAK,EAALG,IAAW,GADjBC,EAAKV,EAAWT,QAAQW,EAAMa,OAAOJ,OAE1B,KAAPD,IACGP,GAAAN,OAAOC,aAAaQ,IAGtB,OAAAH,CACT,CACA,IAAIe,EAAmC,WAAE,MAAyB,oBAAXC,QAA6C,oBAAZC,cAAuD,IAArBA,QAAQC,YAA8BD,QAAQC,SAASC,KAA1I,GAEnCC,EAAuC,WACvC,GAAkB,oBAAXJ,OAAwB,CAC7B,IAAAK,GAAQL,OAAOM,KAChB,IAACD,EAAU,IAASL,OAAAM,KAAK,MAAO,OAAU,OAAOC,GAAYF,GAAA,CAAK,CAC9D,OAAAA,EAAO,SAASG,EAAKC,GAAe,OAAAA,EAAO,IAAIT,OAAOQ,EAAKC,GAAO,IAAIT,OAAOQ,EAAK,EAAKR,OAAOM,KAAKI,KAAKV,OACjH,CACC,OAAO,WAAa,CACrB,CAP2C,GAU3C,SAASW,EAAYC,GAEjB,OAAAb,EAAgBC,OAAOa,MAAQb,OAAOa,MAAMD,GAAO,IAAIZ,OAAOY,GACrC,oBAAdE,WAA4B,IAAIA,WAAWF,GAAO,IAAIG,MAAMH,EAE3E,CAEA,SAASI,EAAeJ,GAEpB,OAAAb,EAAgBC,OAAOiB,YAAcjB,OAAOiB,YAAYL,GAAO,IAAIZ,OAAOY,GACjD,oBAAdE,WAA4B,IAAIA,WAAWF,GAAO,IAAIG,MAAMH,EAE3E,CAEA,IAAIM,EAAM,SAAaC,GACtB,OAAGpB,EAAgBK,EAAYe,EAAG,UAC3BA,EAAEC,MAAM,IAAIC,KAAI,SAAS5C,GAAiC,OAAkB,IAAlBA,EAAEiB,WAAW,EAAU,GACzF,EAEA,SAAS4B,EAAKH,GACb,GAA0B,oBAAhBI,YAA6B,OAAOL,EAAIC,GAElD,IADI,IAAAX,EAAM,IAAIe,YAAYJ,EAAE1B,QAAS+B,EAAO,IAAIV,WAAWN,GAClDhB,EAAE,EAAGA,GAAG2B,EAAE1B,SAAUD,EAAGgC,EAAKhC,GAAuB,IAAlB2B,EAAEzB,WAAWF,GAChD,OAAAgB,CACR,CAEA,SAASiB,EAAIC,GACT,GAAAX,MAAMY,QAAQD,UAAcA,EAAKL,KAAI,SAASO,GAAY,OAAAlD,OAAOC,aAAaiD,EAAG,IAAIC,KAAK,IAC/D,IAA9B,IAAI7C,EAAsB,GAAYQ,EAAI,EAAGA,EAAIkC,EAAKjC,SAAUD,EAAKR,EAAAQ,GAAKd,OAAOC,aAAa+C,EAAKlC,IAAY,OAAAR,EAAE6C,KAAK,GACvH,CAgBA,IAAIC,EAAU/B,EAAU,SAASgC,GAAQ,OAAO/B,OAAOgC,OAAOD,EAAKV,KAAI,SAASb,GAAO,OAAOR,OAAOiC,SAASzB,GAAOA,EAAMJ,EAAYI,EAAK,MAAU,SAASuB,GAC3J,GAAsB,oBAAfjB,WAA4B,CACjC,IAAAtB,EAAI,EAAG0C,EAAS,EAChB,IAAA1C,EAAI,EAAGA,EAAIuC,EAAKtC,SAAUD,EAAG0C,GAAUH,EAAKvC,GAAGC,OAC/C,IAAAT,EAAI,IAAI8B,WAAWoB,GACnBtB,EAAM,EACN,IAAApB,EAAI,EAAG0C,EAAS,EAAG1C,EAAIuC,EAAKtC,OAAQyC,GAAUtB,IAAOpB,EAErD,GADGoB,EAAAmB,EAAKvC,GAAGC,OACXsC,EAAKvC,aAAcsB,aAAcqB,IAAIJ,EAAKvC,GAAI0C,OAAM,IAC7B,iBAAXH,EAAKvC,GAAwB,KAAA,QACrC2C,IAAI,IAAIrB,WAAWiB,EAAKvC,IAAK0C,EAAM,CAEpC,OAAAlD,CACT,CACQ,MAAA,GAAGgD,OAAOI,MAAM,GAAIL,EAAKV,KAAI,SAASb,GAAc,OAAAO,MAAMY,QAAQnB,GAAOA,EAAM,GAAG6B,MAAMC,KAAK9B,EAAK,IAC1G,EAkCA,IAAI+B,EAAO,UAAWC,EAAO,mBAqB7B,SAASC,EAAQhE,GAAuD,IAA5B,IAAIO,EAAI,GAAIQ,EAAIf,EAAEgB,OAAO,EAASD,GAAG,GAAQR,GAAAP,EAAEmB,OAAOJ,KAAa,OAAAR,CAAE,CACjH,SAAS0D,EAAKC,EAAUC,GAAyB,IAAIC,EAAE,GAAGF,EAAU,OAAAE,EAAEpD,QAAQmD,EAAEC,EAAEC,GAAK,IAAIF,EAAEC,EAAEpD,QAAQoD,CAAE,CACzG,SAASE,EAAKJ,EAAUC,GAAyB,IAAIC,EAAE,GAAGF,EAAS,OAAAE,EAAEpD,QAAQmD,EAAEC,EAAEC,GAAK,IAAIF,EAAEC,EAAEpD,QAAQoD,CAAE,CACxG,SAASG,EAAML,EAAUC,GAAyB,IAAIC,EAAE,GAAGF,EAAU,OAAAE,EAAEpD,QAAQmD,EAAEC,EAAEA,EAAEC,GAAK,IAAIF,EAAEC,EAAEpD,OAAQ,CAG1G,IAAIwD,EAAqBC,KAAKC,IAAI,EAAE,IACpC,SAASC,EAAMT,EAAUC,GAA4B,OAAAD,EAAEM,GAAON,GAAGM,EAHjE,SAAgBN,EAAUC,GAAyB,IAAIC,EAAE,GAAGK,KAAKG,MAAMV,GAAW,OAAAE,EAAEpD,QAAQmD,EAAEC,EAAEC,GAAK,IAAIF,EAAEC,EAAEpD,QAAQoD,CAAE,CAGxCS,CAAOX,EAAEC,GAFxF,SAAgBD,EAAUC,GAAyB,IAAIC,EAAE,GAAGF,EAAU,OAAAE,EAAEpD,QAAQmD,EAAEC,EAAEC,GAAK,IAAIF,EAAEC,EAAEpD,QAAQoD,CAAE,CAEeU,CAAtBL,KAAKG,MAAMV,GAAoBC,EAAG,CAEtI,SAASY,EAAcrC,EAAc3B,GAAgD,OAAnBA,EAAIA,GAAK,EAAU2B,EAAE1B,QAAU,EAAID,GAA8B,MAAR,GAAhB2B,EAAEzB,WAAWF,KAA6C,MAAR,GAAlB2B,EAAEzB,WAAWF,EAAE,KAA6C,MAAR,GAAlB2B,EAAEzB,WAAWF,EAAE,KAA6C,MAAR,GAAlB2B,EAAEzB,WAAWF,EAAE,KAA6C,MAAR,GAAlB2B,EAAEzB,WAAWF,EAAE,KAA6C,KAAR,GAAlB2B,EAAEzB,WAAWF,EAAE,KAA4C,MAAR,GAAlB2B,EAAEzB,WAAWF,EAAE,GAAe,CAClV,IAAIiE,EAAiC,CACpC,CAAC,MAAO,UACR,CAAC,MAAO,UACR,CAAC,MAAO,WACR,CAAC,MAAO,aACR,CAAC,MAAO,YACR,CAAC,MAAO,UACR,CAAC,MAAO,aAELC,EAAmC,CACtC,CAAC,IAAK,MAAO,WACb,CAAC,IAAK,MAAO,YACb,CAAC,IAAK,MAAO,SACb,CAAC,IAAK,MAAO,SACb,CAAC,IAAK,MAAO,OACb,CAAC,IAAK,MAAO,QACb,CAAC,IAAK,MAAO,QACb,CAAC,IAAK,MAAO,UACb,CAAC,IAAK,MAAO,aACb,CAAC,IAAK,MAAO,WACb,CAAC,IAAK,MAAO,YACb,CAAC,IAAK,MAAO,aAoCd,IAAIC,EAAY,CACf,EAAI,UACJ,EAAI,IACJ,EAAI,OACJ,EAAI,QACJ,EAAI,WACJ,EAAI,KACJ,GAAI,QACJ,GAAI,WACJ,GAAI,QACJ,GAAI,UACJ,GAAI,SACJ,GAAI,WACJ,GAAI,QACJ,GAAI,SACJ,GAAI,aACJ,GAAI,gBACJ,GAAI,OACJ,GAAI,UACJ,GAAI,cACJ,GAAI,iBACJ,GAAI,sBACJ,GAAI,sBACJ,GAAI,2BACJ,GAAI,QACJ,GAAI,YACJ,GAAI,SACJ,GAAI,WACJ,GAAI,IACJ,GAAI,4BAMDC,EAAkB,CACrB,EAAI,GAAI,EAAI,GAAI,EAAI,GAAI,EAAI,GAE5B,GAAK,EAAG,GAAK,EAAG,GAAK,EAAG,GAAK,EAE7B,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAEpC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GACpC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAC5B,GAAK,EAAG,GAAK,EAAG,GAAK,EAAG,GAAK,EAE7B,GAAK,EAAG,GAAI,GACZ,GAAI,GAAI,GAAI,GAAI,GAAI,GACpB,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAC5B,GAAI,GAAI,GAAI,GAAI,GAAI,GACpB,GAAI,GAAI,GAAI,GAAI,GAAI,GACpB,GAAI,GAKDC,EAAkB,CAErB,EAAI,4BACJ,GAAI,4BAGJ,EAAI,iCACJ,GAAI,iCAGJ,EAAI,kCACJ,GAAI,kCAGJ,EAAI,uCACJ,GAAI,uCAGJ,GAAI,8CAGJ,GAAI,uDAGJ,GAAI,sDAGJ,GAAI,gEAGL,SAASC,EAASrF,EAAcsF,EAAcC,GAM7C,IALI,IAAAC,EAAMxF,EAAI,GAAS,EAAA,EACnByF,EAAIzF,EAAIwF,EACRE,EAAM,EAAGC,EAAM,EAAGC,EAAI,EACtBC,EAAM,EAAGC,EAAM,EAAGC,EAAI,EACtBC,EAAIvB,KAAKwB,MAAMR,GACbK,EAAMR,IAEXM,GADII,EAAAvB,KAAKwB,MAAMR,IACPE,EAAMD,EACdK,EAAIC,EAAIF,EAAMD,IACVJ,EAAIO,EAAK,QACbP,EAAI,GAAKA,EAAIO,GACPN,EAAAC,EAAWA,EAAAC,EACXC,EAAAC,EAAWA,EAAAC,EAGlB,GADGA,EAAIT,IAAQQ,EAAMR,GAASS,EAAAF,EAASD,EAAAF,IAAkBK,EAAAD,EAASF,EAAAD,KAC9DJ,EAAO,MAAO,CAAC,EAAGC,EAAMI,EAAGG,GAC/B,IAAIG,EAAIzB,KAAKwB,MAAMT,EAAMI,EAAEG,GAC3B,MAAO,CAACG,EAAGV,EAAII,EAAIM,EAAEH,EAAGA,EACzB,CACA,SAASI,EAAoBjC,EAAakC,EAAcC,GACvD,GAAGnC,EAAI,SAAWA,EAAI,EAAU,OAAA,KAC5B,IAAAoC,EAAU,EAAFpC,EAAMqC,EAAO9B,KAAKwB,MAAM,OAAS/B,EAAIoC,IAAQE,EAAI,EACzDC,EAAK,GACLC,EAAI,CAACpB,EAAEgB,EAAMK,EAAEJ,EAAMK,EAAE,OAAO1C,EAAEoC,GAAMC,EAAKM,EAAE,EAAEC,EAAE,EAAE3C,EAAE,EAAE4C,EAAE,EAAEC,EAAE,EAAEC,EAAE,EAAEf,EAAE,GAOzE,GANGzB,KAAKyC,IAAIR,EAAIE,GAAK,SAAUA,EAAI,GAChCR,GAAQA,EAAKe,WAAkBb,GAAA,MAC/BI,EAAIE,EAAI,QACVF,EAAIE,EAAI,EACK,SAARL,IAAiBG,EAAIC,EAAIJ,EAAO,IAAKD,IAAQI,EAAIpB,IAE3C,KAATgB,EAAqBG,EAAAJ,EAAK,CAAC,KAAK,GAAG,IAAM,CAAC,KAAK,EAAE,IAASG,EAAA,OAAE,GAC9C,IAATF,EAAoBG,EAAAJ,EAAK,CAAC,KAAK,EAAE,IAAM,CAAC,KAAK,EAAE,GAAQG,EAAA,MAC1D,CACDF,EAAO,MAAMA,EAEhB,IAAInC,EAAI,IAAIiD,KAAK,KAAM,EAAG,GAC1BjD,EAAEkD,QAAQlD,EAAEmD,UAAYhB,EAAO,GACxBG,EAAA,CAACtC,EAAEoD,cAAepD,EAAEqD,WAAW,EAAErD,EAAEmD,WAC1Cd,EAAMrC,EAAEsD,SACLnB,EAAO,KAAWE,GAAAA,EAAM,GAAK,GAC7BH,IAAIG,EAgFT,SAAuBF,EAAe/F,GAEpCA,EAAE,IAAM,IACJ,IAAAiG,EAAMF,EAAKmB,SACZnB,EAAO,KAAWE,GAAAA,EAAM,GAAK,GACzB,OAAAA,CACT,CAtFekB,CAAcvD,EAAGsC,GAChC,CAMQ,OALHC,EAAAG,EAAIJ,EAAK,GAAQC,EAAAI,EAAIL,EAAK,GAAQC,EAAAvC,EAAIsC,EAAK,GAC/CC,EAAIO,EAAIV,EAAO,GAAWA,EAAA9B,KAAKwB,MAAMM,EAAO,IAC5CG,EAAIM,EAAIT,EAAO,GAAWA,EAAA9B,KAAKwB,MAAMM,EAAO,IAC5CG,EAAIK,EAAIR,EACRG,EAAIR,EAAIM,EACDE,CACR,CACA,IAAIiB,MAA+BP,KAAK,KAAM,GAAI,GAAI,EAAG,EAAG,GACxDQ,IAAuCC,UACvCC,MAA+BV,KAAK,KAAM,EAAG,EAAG,EAAG,EAAG,GAC1D,SAASW,EAAc7D,EAAYiD,GAC9B,IAAAa,IAAuBH,UAGnB,OAFLV,EAAUa,GAAS,UACd9D,GAAK4D,IAAsBE,GAAA,QAC3BA,GAASJ,EAAoG,KAAxE1D,EAAE+D,oBAA+CN,EAAAM,uBAAuB,KACtH,CAIA,SAASC,EAAkB3H,GAClB,UAAAA,EAAEZ,QAAQ,KAAcY,EAAIA,EAAEc,QAAQ,2BAA4B,KAC3E,CAsBA,SAAS8G,EAAgBjE,GACxB,IAAuD3D,EAAnD6H,EAAI3D,KAAKwB,MAAMxB,KAAK4D,IAAI5D,KAAKyC,IAAIhD,IAAIO,KAAK6D,QAO9C,SALGF,OAAWA,IAAK,EAAQlE,EAAEqE,YAAY,GAAGH,GACpC3D,KAAKyC,IAAIkB,IAAM,EAjBxB,SAAuBlE,GAClB,IAAAsE,EAAKtE,EAAE,EAAE,GAAG,GACZ3D,EAAI2H,EAAkBhE,EAAEuE,QAAQ,KAAS,OAAAlI,EAAES,QAAUwH,IACrDjI,EAAA2D,EAAEqE,YAAY,KAAUvH,QAAUwH,EAD6BjI,EAE5D2D,EAAEwE,cAAc,EACxB,CAY+BC,CAAczE,GAC9B,KAANkE,EAAclE,EAAEuE,QAAQ,IAAIG,OAAO,EAAE,IAV9C,SAAuB1E,GACtB,IAAI3D,EAAI2H,EAAkBhE,EAAEuE,QAAQ,KACpC,OAAQlI,EAAES,QAAUkD,EAAE,EAAE,GAAG,KAAa,MAAN3D,GAAmB,OAANA,EAAc2D,EAAEqE,YAAY,GAAKhI,CACjF,CAQUsI,CAAc3E,GAEhBgE,EA3BR,SAA2B3H,GAC1B,UAAGA,EAAEZ,QAAQ,KAAmBY,EACzBA,EAAEc,QAAQ,8BAA8B,OAAOA,QAAQ,eAAe,QAC9E,CAwB0ByH,CAAkBvI,EAAEwI,eAC9C,CAaA,SAASC,EAAY9E,EAAWkC,GAC/B,cAAclC,GACb,IAAK,SAAiB,OAAAA,EACtB,IAAK,UAAW,OAAOA,EAAI,OAAS,QACpC,IAAK,SAAkB,OAAE,EAAFA,KAASA,EAAIA,EAAE+E,SAAS,IAAMd,EAAgBjE,GACrE,IAAK,YAAoB,MAAA,GACzB,IAAK,SACD,GAAK,MAALA,EAAkB,MAAA,GAClB,GAAAA,aAAakD,KAAM,OAAO8B,GAAW,GAAInB,EAAc7D,EAAGkC,GAAQA,EAAKe,UAAWf,GAEjF,MAAA,IAAI+C,MAAM,wCAA0CjF,EAC3D,CAUA,SAASkF,EAAeC,EAAiBC,EAAgBC,EAAKC,GACzD,IAA6B9C,EAA7BnG,EAAE,GAAIkJ,EAAG,EAAGC,EAAG,EAAG7C,EAAI0C,EAAI1C,EAAQ8C,EAAO,EAC7C,OAAON,GACN,KAAK,GACJxC,EAAI0C,EAAI1C,EAAI,IAEb,KAAK,IACL,OAAOyC,EAAItI,QACV,KAAK,EAAG,KAAK,EAAG0F,EAAMG,EAAI,IAAY8C,EAAA,EAAG,MACzC,QAASjD,EAAMG,EAAI,IAAc8C,EAAA,EAChC,MACF,KAAK,IACL,OAAOL,EAAItI,QACV,KAAK,EAAG,KAAK,EAAG0F,EAAM6C,EAAIzC,EAAG6C,EAAOL,EAAItI,OAAQ,MAChD,KAAK,EAAG,OAAOiE,EAAOsE,EAAIzC,EAAE,GAAG,GAC/B,KAAK,EAAG,OAAO7B,EAAOsE,EAAIzC,EAAE,GAAG,GAC/B,QAAS,OAAO7B,EAAOsE,EAAIzC,EAAE,GAAG,GAC/B,MACF,KAAK,IACL,OAAOwC,EAAItI,QACV,KAAK,EAAG,KAAK,EAAG0F,EAAM6C,EAAIpF,EAAGwF,EAAOL,EAAItI,OAAQ,MAChD,KAAK,EAAG,OAAOgE,EAAKuE,EAAIrD,GAAG,GAC3B,QAAS,OAAOlB,EAAKuE,EAAIrD,GAAG,GAC3B,MACF,KAAK,IACL,OAAOoD,EAAItI,QACV,KAAK,EAAG,KAAK,EAAS0F,EAAA,GAAG6C,EAAIxC,EAAE,IAAI,GAAI4C,EAAOL,EAAItI,OAAQ,MAC1D,QAAS,KAAM,oBAAsBsI,EACpC,MACF,KAAK,GACL,OAAOA,EAAItI,QACV,KAAK,EAAG,KAAK,EAAG0F,EAAM6C,EAAIxC,EAAG4C,EAAOL,EAAItI,OAAQ,MAChD,QAAS,KAAM,oBAAsBsI,EACpC,MACF,KAAK,GACL,OAAOA,EAAItI,QACV,KAAK,EAAG,KAAK,EAAG0F,EAAM6C,EAAIvC,EAAG2C,EAAOL,EAAItI,OAAQ,MAChD,QAAS,KAAM,sBAAwBsI,EACtC,MACF,KAAK,IACD,GAAO,KAAPA,GAAqB,MAAPA,GAAsB,MAAPA,GAAsB,OAAPA,GAAuB,QAAPA,EAAe,KAAM,sBAAwBA,EAC5G,OAAa,IAAVC,EAAI3C,GAAmB,KAAP0C,GAAqB,MAAPA,GAEfI,EAAfF,GAAO,EAAgB,IAARA,EAAY,IAAO,IACnB,IAARA,EAAY,GAAK,GAC3BC,EAAKhF,KAAKG,MAAO8E,GAAKH,EAAItC,EAAIsC,EAAI3C,MACzB,GAAG8C,IAASD,EAAA,GACV,MAARH,EAA2B,IAAPG,EAAW,IAAM,GAAGA,EAAGC,GAC1CnJ,EAAA0D,EAAKwF,EAAG,EAAID,GACL,OAARF,EAAqB/I,EAAEqI,OAAO,EAAE,GAC5B,IAAMrI,EAAEqI,OAAO,EAAEU,EAAItI,OAAO,KATmBiD,EAAKsF,EAAItC,EAAGqC,EAAItI,QAUvE,KAAK,GACL,OAAOsI,GACN,IAAK,MAAO,IAAK,OAAc5C,EAAM,GAAN6C,EAAIjE,EAAKiE,EAAIxC,EAAG,MAC/C,IAAK,MAAO,IAAK,OAAQL,EAAuB,IAAV,GAAN6C,EAAIjE,EAAKiE,EAAIxC,GAAMwC,EAAIvC,EAAG,MAC1D,IAAK,MAAO,IAAK,OAAQN,EAAkC,IAAV,IAAV,GAAN6C,EAAIjE,EAAKiE,EAAIxC,GAAMwC,EAAIvC,GAAMvC,KAAKG,MAAM2E,EAAItC,EAAEsC,EAAI3C,GAAI,MACvF,QAAS,KAAM,uBAAyB0C,EAChCK,EAAe,IAAfL,EAAItI,OAAe,EAAI,EAAG,MACnC,KAAK,IACE0F,EAAAG,EAAU8C,EAAA,EAGX,OADMA,EAAO,EAAI1F,EAAKyC,EAAKiD,GAAQ,EAE3C,CAKA,SAASC,GAASlH,GAEd,GAAAA,EAAE1B,QADG,EACiB,OAAA0B,EAEzB,IADI,IAAAmH,EAAKnH,EAAE1B,OAFH,EAEgBT,EAAImC,EAAEkG,OAAO,EAAEiB,GACjCA,GAAGnH,EAAE1B,OAAQ6I,GAHX,EAGqBtJ,IAAAA,EAAES,OAAS,EAAI,IAAM,IAAM0B,EAAEkG,OAAOiB,EAHzD,GAID,OAAAtJ,CACR,CACA,IAAIuJ,GAAO,KAYX,SAASC,GAAcT,EAAgBC,GAClC,IAAAhJ,EACAyJ,EAAMV,EAAI3J,QAAQ,KAAO2J,EAAI3J,QAAQ,KAAO,EAC7C,GAAA2J,EAAIW,MAAM,eAAgB,CACzB,GAAO,GAAPV,EAAiB,MAAA,SAAA,GACZA,EAAM,EAAG,MAAO,IAAMQ,GAAcT,GAAMC,GAC9C,IAAAW,EAASZ,EAAI3J,QAAQ,MAAoB,IAAXuK,IAAsBA,EAAAZ,EAAI3J,QAAQ,MAChE,IAAAwK,EAAK1F,KAAKwB,MAAMxB,KAAK4D,IAAIkB,GAAK9E,KAAK6D,QAAQ4B,EAG/C,GAFGC,EAAK,IAASA,GAAAD,IAES,KADrB3J,GAAAgJ,EAAI9E,KAAKC,IAAI,GAAGyF,IAAK5B,YAAYyB,EAAI,GAAGE,EAAOC,GAAID,IACnDvK,QAAQ,KAAa,CACrB,IAAAyK,EAAQ3F,KAAKwB,MAAMxB,KAAK4D,IAAIkB,GAAK9E,KAAK6D,QAG1C,KAF0B,IAAvB/H,EAAEZ,QAAQ,KAAaY,EAAIA,EAAEY,OAAO,GAAK,IAAMZ,EAAEqI,OAAO,GAAK,MAAQwB,EAAQ7J,EAAES,OAAOmJ,GACpF5J,GAAK,MAAQ6J,EAAQD,GACF,OAAlB5J,EAAEqI,OAAO,EAAE,IAEhBrI,GADAA,EAAIA,EAAEY,OAAO,GAAKZ,EAAEqI,OAAO,EAAEsB,GAAU,IAAM3J,EAAEqI,OAAO,EAAEsB,IAClD7I,QAAQ,aAAa,MAAMA,QAAQ,QAAQ,MAE9Cd,EAAAA,EAAEc,QAAQ,MAAM,IACvB,CACEd,EAAIA,EAAEc,QAAQ,4BAA2B,SAASgJ,EAAGC,EAAGC,EAAGC,GAAM,OAAOF,EAAKC,EAAKC,EAAG5B,OAAO,GAAGsB,EAAOC,GAAID,GAAU,IAAMM,EAAG5B,OAAOuB,GAAM,GAAI,GAC9I,MAAM5J,EAAIgJ,EAAIb,cAAcsB,GAGtB,OAFJV,EAAIW,MAAM,WAAa1J,EAAE0J,MAAM,cAAiB1J,EAAAA,EAAEqI,OAAO,EAAErI,EAAES,OAAO,GAAK,IAAMT,EAAEY,OAAOZ,EAAES,OAAO,IACjGsI,EAAIW,MAAM,QAAU1J,EAAE0J,MAAM,SAAY1J,EAAAA,EAAEc,QAAQ,MAAM,MACpDd,EAAEc,QAAQ,IAAI,IACtB,CACA,IAAIoJ,GAAQ,yBASZ,IAAIC,GAAO,iBACPC,GAAa,WACbC,GAAQ,sBACZ,SAASC,GAAMC,GAEd,IADA,IAAYC,EAARxK,EAAI,GACAQ,EAAI,EAAGA,GAAK+J,EAAI9J,SAAUD,EAAG,OAAQgK,EAAGD,EAAI7J,WAAWF,IAC9D,KAAK,GAAI,MACT,KAAK,GAAQR,GAAA,IAAK,MAClB,KAAK,GAAQA,GAAA,IAAK,MAClB,QAAaA,GAAAN,OAAOC,aAAa6K,GAE3B,OAAAxK,CACR,CACA,SAASyK,GAAIzB,EAAgBpF,GAA2B,IAAI8G,EAAKxG,KAAKC,IAAI,GAAGP,GAAI,MAAO,GAAIM,KAAKG,MAAM2E,EAAM0B,GAAIA,CAAI,CACrH,SAASC,GAAI3B,EAAgBpF,GACxB,IAAAgH,EAAQ5B,EAAM9E,KAAKwB,MAAMsD,GAAM0B,EAAKxG,KAAKC,IAAI,GAAGP,GAChD,OAAAA,GAAK,GAAKM,KAAKG,MAAMuG,EAAQF,IAAKjK,OAAe,EAC9CyD,KAAKG,MAAMuG,EAAQF,EAC3B,CAWA,SAASG,GAAc/B,EAAiBC,EAAgBC,GACpD,GAAuB,KAAvBF,EAAKpI,WAAW,KAAcqI,EAAIW,MAAMU,IAAa,CACvD,IAAIU,EAAO/B,EAAIjI,QAAQ,OAAO,IAAIA,QAAQ,MAAM,IAAIA,QAAQ,KAAK,IACjE,OAAGkI,GAAO,EAAU6B,GAAc,IAAKC,EAAM9B,GACtC,IAAM6B,GAAc,IAAKC,GAAO9B,GAAO,GAChD,CACI,GAAmC,KAAnCD,EAAIrI,WAAWqI,EAAItI,OAAS,GAAkB,OA5ElD,SAAsBqI,EAAiBC,EAAgBC,GAEtD,IADI,IAAAS,EAAMV,EAAItI,OAAS,EACS,KAA1BsI,EAAIrI,WAAW+I,EAAI,MAAaA,EACtC,OAAOsB,GAAUjC,EAAMC,EAAIV,OAAO,EAAEoB,GAAMT,EAAM9E,KAAKC,IAAI,GAAG,GAAG4E,EAAItI,OAAOgJ,IAC3E,CAwEkDuB,CAAalC,EAAMC,EAAKC,GACtE,QAAAD,EAAI3J,QAAQ,KAAoB,OAlFpC,SAAuB0J,EAAiBC,EAAgBC,GACnD,IAAAiC,EAAOlC,EAAIjI,QAAQyI,GAAK,IAAK2B,EAAMnC,EAAItI,OAASwK,EAAKxK,OACzD,OAAOsK,GAAUjC,EAAMmC,EAAMjC,EAAM9E,KAAKC,IAAI,GAAG,EAAE+G,IAAQpH,GAAK,IAAIoH,EACnE,CA+EoCC,CAAcrC,EAAMC,EAAKC,GACzD,QAAAD,EAAI3J,QAAQ,KAAoB,OAAAoK,GAAcT,EAAKC,GACtD,GAAyB,KAAtBD,EAAIrI,WAAW,GAAW,MAAO,IAAImK,GAAc/B,EAAKC,EAAIV,OAAsB,KAAfU,EAAInI,OAAO,GAAQ,EAAE,GAAGoI,GAC1F,IAAAhJ,EACAoL,EAAsBC,EAAIC,EAAIC,EAAOrH,KAAKyC,IAAIqC,GAAMwC,EAAOxC,EAAM,EAAI,IAAM,GAC5E,GAAAD,EAAIW,MAAM,gBAAiB8B,EAAOpH,EAAMmH,EAAKxC,EAAItI,QACjD,GAAAsI,EAAIW,MAAM,WAEZ,MAD2B,OAAvB1J,EAAAoE,EAAM4E,EAAI,MAAsBhJ,EAAA,IAC7BA,EAAES,OAASsI,EAAItI,OAAST,EAAIsK,GAAMvB,EAAIV,OAAO,EAAEU,EAAItI,OAAOT,EAAES,SAAWT,EAE3E,GAAAoL,EAAIrC,EAAIW,MAAMQ,IAAgB,OAtDnC,SAAsBkB,EAAqBG,EAAiBC,GAC3D,IAAIC,EAAMC,SAASN,EAAE,GAAG,IAAKO,EAAKzH,KAAKG,MAAMkH,EAAOE,GAAMG,EAAO1H,KAAKwB,MAAMiG,EAAGF,GAC3EI,EAAOF,EAAKC,EAAKH,EAAMK,EAAML,EACjC,OAAOD,GAAiB,IAATI,EAAa,GAAK,GAAGA,GAAQ,KAAe,IAARC,EAAY/H,GAAK,IAAKsH,EAAE,GAAG3K,OAAS,EAAI2K,EAAE,GAAG3K,QAAUsD,EAAK8H,EAAIT,EAAE,GAAG3K,QAAU2K,EAAE,GAAK,IAAMA,EAAE,GAAK1H,EAAKoI,EAAIV,EAAE,GAAG3K,QACrK,CAkDmCsL,CAAaX,EAAGG,EAAMC,GACxD,GAAGzC,EAAIW,MAAM,UAAkB,OAAA8B,EAAOpH,EAAMmH,EAAKxC,EAAItI,OAASsI,EAAI3J,QAAQ,MAC1E,GAAIgM,EAAIrC,EAAIW,MAAMS,IAEV,OADPnK,EAAIyK,GAAIzB,EAAKoC,EAAE,GAAG3K,QAAQK,QAAQ,aAAa,MAAMwJ,GAAMc,EAAE,KAAKtK,QAAQ,MAAM,IAAIwJ,GAAMc,EAAE,KAAKtK,QAAQ,YAAW,SAASgJ,EAAIC,GAAa,MAAA,IAAMA,EAAKjG,GAAK,IAAKwG,GAAac,EAAe,IAAI3K,OAAOsJ,EAAGtJ,gBACtMsI,EAAI3J,QAAQ,MAAeY,EAAIA,EAAEc,QAAQ,OAAO,KAGxD,GADMiI,EAAAA,EAAIjI,QAAQ,YAAa,MAC3BsK,EAAIrC,EAAIW,MAAM,gBACV,OAAA8B,EAAOf,GAAIc,EAAMH,EAAE,GAAG3K,QAAQK,QAAQ,kBAAkB,OAAOA,QAAQ,YAAY,OAAOA,QAAQ,OAAOsK,EAAE,GAAG3K,OAAO,KAAK,KAE9H,GAAA2K,EAAIrC,EAAIW,MAAM,qBAA8B,OAAA8B,EAAOnC,GAASjF,EAAMmH,EAAK,IAC3E,GAAIH,EAAIrC,EAAIW,MAAM,qBACjB,OAAOV,EAAM,EAAI,IAAM6B,GAAc/B,EAAMC,GAAMC,GAAOK,GAAS,IAAInF,KAAKwB,MAAMsD,GAvClF,SAAeA,EAAgBpF,GAC9B,OAAIA,GAAK,GAAKM,KAAKG,OAAO2E,EAAI9E,KAAKwB,MAAMsD,IAAM9E,KAAKC,IAAI,GAAGP,KAAKnD,OACxD,EAED,CACR,CAkCyFuL,CAAMhD,EAAKoC,EAAE,GAAG3K,UAAY,IAAMiD,EAAKiH,GAAI3B,EAAKoC,EAAE,GAAG3K,QAAQ2K,EAAE,GAAG3K,QAE1J,GAAI2K,EAAIrC,EAAIW,MAAM,YAAc,OAAOmB,GAAc/B,EAAKC,EAAIjI,QAAQ,SAAS,IAAIkI,GACnF,GAAIoC,EAAIrC,EAAIW,MAAM,2BAGV,OAFH1J,EAAAyD,EAAQoH,GAAc/B,EAAMC,EAAIjI,QAAQ,SAAS,IAAKkI,IACrDqC,EAAA,EACE5H,EAAQA,EAAQsF,EAAIjI,QAAQ,MAAM,KAAKA,QAAQ,SAAQ,SAASrB,GAAU,OAAA4L,EAAGrL,EAAES,OAAOT,EAAEY,OAAOyK,KAAU,MAAJ5L,EAAQ,IAAI,EAAG,KAEzH,GAAAsJ,EAAIW,MAAMW,IAEZ,MAAO,KADHrK,EAAA6K,GAAc/B,EAAM,aAAcE,IACvBX,OAAO,EAAE,GAAK,KAAOrI,EAAEqI,OAAO,EAAG,GAAK,IAAMrI,EAAEqI,OAAO,GAErE,IAAI4D,EAAK,GACT,GAAIb,EAAIrC,EAAIW,MAAM,+BAUV,OATP2B,EAAKnH,KAAKgI,IAAiBd,EAAE,GAAU3K,OAAO,GACzC6K,EAAAxG,EAASyG,EAAMrH,KAAKC,IAAI,GAAGkH,GAAI,GAAG,GACvCrL,EAAI,GAAKwL,EAEoB,MADxBS,EAAAlB,GAAU,IAAkBK,EAAE,GAAWE,EAAG,KAC3C1K,OAAOqL,EAAGxL,OAAO,KAAgBwL,EAAAA,EAAG5D,OAAO,EAAE4D,EAAGxL,OAAO,GAAK,KAC7DT,GAAAiM,EAAkBb,EAAE,GAAY,IAAmBA,EAAE,IAC1Da,EAAKjI,EAAMsH,EAAG,GAAGD,IACX5K,OAAS2K,EAAE,GAAG3K,WAAa6J,GAAMc,EAAE,GAAG/C,OAAO+C,EAAE,GAAG3K,OAAOwL,EAAGxL,SAAWwL,GACxEjM,GAAAiM,EAGN,GAAIb,EAAIrC,EAAIW,MAAM,iCAGV,OAFP2B,EAAKnH,KAAKgI,IAAIhI,KAAKiI,IAAIf,EAAE,GAAG3K,OAAQ2K,EAAE,GAAG3K,QAAQ,GAE1C+K,IADFF,EAAAxG,EAASyG,EAAMrH,KAAKC,IAAI,GAAGkH,GAAI,GAAG,IACrB,KAAKC,EAAG,GAAK,GAAK,MAAQ,KAAOA,EAAG,GAAKvH,EAAKuH,EAAG,GAAGD,GAAMD,EAAE,GAAK,IAAMA,EAAE,GAAKpH,EAAMsH,EAAG,GAAGD,GAAKvH,GAAK,IAAK,EAAEuH,EAAG,EAAID,EAAE,GAAG3K,OAAS2K,EAAE,GAAG3K,SAExJ,GAAI2K,EAAIrC,EAAIW,MAAM,YAEjB,OADI1J,EAAAoE,EAAM4E,EAAK,GACZD,EAAItI,QAAUT,EAAES,OAAeT,EAC3BsK,GAAMvB,EAAIV,OAAO,EAAEU,EAAItI,OAAOT,EAAES,SAAWT,EAEnD,GAAIoL,EAAIrC,EAAIW,MAAM,uBAAyB,CAC1C1J,EAAI,GAAKgJ,EAAId,QAAQhE,KAAKgI,IAAId,EAAE,GAAG3K,OAAO,KAAKK,QAAQ,YAAY,MAC9DuK,EAAArL,EAAEZ,QAAQ,KACX,IAAAgN,EAAOrD,EAAI3J,QAAQ,KAAOiM,EAAIgB,EAAOtD,EAAItI,OAAST,EAAES,OAAS2L,EACjE,OAAO9B,GAAMvB,EAAIV,OAAO,EAAE+D,GAAQpM,EAAI+I,EAAIV,OAAOU,EAAItI,OAAO4L,GAC9D,CACC,GAAIjB,EAAIrC,EAAIW,MAAM,sBAEV,OADP2B,EAAKV,GAAI3B,EAAKoC,EAAE,GAAG3K,QACZuI,EAAM,EAAI,IAAM6B,GAAc/B,EAAMC,GAAMC,GAAOK,GA5E1D,SAAaL,GACT,OAAAA,EAAM,YAAcA,GAAmB,WAAO,IAAIA,GAAO,EAAS,EAAJA,EAAUA,EAAI,EAAE,GAC1E,GAAG9E,KAAKwB,MAAMsD,EACtB,CAyEmEsD,CAAItD,IAAMlI,QAAQ,aAAa,OAAOA,QAAQ,SAAQ,SAASgJ,GAAa,MAAA,OAASA,EAAGrJ,OAAS,EAAIiD,EAAK,EAAE,EAAEoG,EAAGrJ,QAAU,IAAMqJ,CAAG,IAAM,IAAMpG,EAAK2H,EAAGD,EAAE,GAAG3K,QAE/N,OAAOsI,GACN,IAAK,aAAqB,OAAA8B,GAAc/B,EAAM,WAAYE,GAC1D,IAAK,UACL,IAAK,SACL,IAAK,QAAS,IAAIvJ,EAAI4J,GAASjF,EAAMmH,EAAK,IAAY,MAAM,MAAN9L,EAAY+L,EAAO/L,EAAI,GAC7E,IAAK,aAAc,OAAOoL,GAAc/B,EAAM,aAAaE,GAAKlI,QAAQ,OAAO,KAC/E,IAAK,WAAY,OAAO+J,GAAc/B,EAAM,WAAWE,GAAKlI,QAAQ,OAAO,KAG5E,MAAM,IAAI8H,MAAM,uBAAyBG,EAAM,IAChD,CAUA,SAASwD,GAAexD,EAAgBC,GACnC,IAAAhJ,EACAyJ,EAAMV,EAAI3J,QAAQ,KAAO2J,EAAI3J,QAAQ,KAAO,EAC7C,GAAA2J,EAAIW,MAAM,eAAgB,CACzB,GAAO,GAAPV,EAAiB,MAAA,SAAA,GACZA,EAAM,EAAG,MAAO,IAAMuD,GAAexD,GAAMC,GAC/C,IAAAW,EAASZ,EAAI3J,QAAQ,MAAoB,IAAXuK,IAAsBA,EAAAZ,EAAI3J,QAAQ,MAChE,IAAAwK,EAAK1F,KAAKwB,MAAMxB,KAAK4D,IAAIkB,GAAK9E,KAAK6D,QAAQ4B,EAG/C,GAFGC,EAAK,IAASA,GAAAD,KACZ3J,GAAAgJ,EAAI9E,KAAKC,IAAI,GAAGyF,IAAK5B,YAAYyB,EAAI,GAAGE,EAAOC,GAAID,IAClDD,MAAM,QAAS,CAChB,IAAAG,EAAQ3F,KAAKwB,MAAMxB,KAAK4D,IAAIkB,GAAK9E,KAAK6D,SAChB,IAAvB/H,EAAEZ,QAAQ,KAAaY,EAAIA,EAAEY,OAAO,GAAK,IAAMZ,EAAEqI,OAAO,GAAK,MAAQwB,EAAQ7J,EAAES,OAAOmJ,GACpF5J,GAAK,MAAQ6J,EAAQD,GACtB5J,EAAAA,EAAEc,QAAQ,MAAM,IACvB,CACEd,EAAIA,EAAEc,QAAQ,4BAA2B,SAASgJ,EAAGC,EAAGC,EAAGC,GAAM,OAAOF,EAAKC,EAAKC,EAAG5B,OAAO,GAAGsB,EAAOC,GAAID,GAAU,IAAMM,EAAG5B,OAAOuB,GAAM,GAAI,GAC9I,MAAM5J,EAAIgJ,EAAIb,cAAcsB,GAGtB,OAFJV,EAAIW,MAAM,WAAa1J,EAAE0J,MAAM,cAAiB1J,EAAAA,EAAEqI,OAAO,EAAErI,EAAES,OAAO,GAAK,IAAMT,EAAEY,OAAOZ,EAAES,OAAO,IACjGsI,EAAIW,MAAM,QAAU1J,EAAE0J,MAAM,SAAY1J,EAAAA,EAAEc,QAAQ,MAAM,MACpDd,EAAEc,QAAQ,IAAI,IACtB,CACA,SAAS0L,GAAc1D,EAAiBC,EAAgBC,GACpD,GAAuB,KAAvBF,EAAKpI,WAAW,KAAcqI,EAAIW,MAAMU,IAAa,CACvD,IAAIU,EAAO/B,EAAIjI,QAAQ,OAAO,IAAIA,QAAQ,MAAM,IAAIA,QAAQ,KAAK,IACjE,OAAGkI,GAAO,EAAUwD,GAAc,IAAK1B,EAAM9B,GACtC,IAAMwD,GAAc,IAAK1B,GAAO9B,GAAO,GAChD,CACI,GAAmC,KAAnCD,EAAIrI,WAAWqI,EAAItI,OAAS,GAAkB,OArClD,SAAuBqI,EAAiBC,EAAgBC,GAEvD,IADI,IAAAS,EAAMV,EAAItI,OAAS,EACS,KAA1BsI,EAAIrI,WAAW+I,EAAI,MAAaA,EACtC,OAAOsB,GAAUjC,EAAMC,EAAIV,OAAO,EAAEoB,GAAMT,EAAM9E,KAAKC,IAAI,GAAG,GAAG4E,EAAItI,OAAOgJ,IAC3E,CAiCkDgD,CAAc3D,EAAMC,EAAKC,GACvE,QAAAD,EAAI3J,QAAQ,KAAoB,OAjCpC,SAAwB0J,EAAiBC,EAAgBC,GACpD,IAAAiC,EAAOlC,EAAIjI,QAAQyI,GAAK,IAAK2B,EAAMnC,EAAItI,OAASwK,EAAKxK,OACzD,OAAOsK,GAAUjC,EAAMmC,EAAMjC,EAAM9E,KAAKC,IAAI,GAAG,EAAE+G,IAAQpH,GAAK,IAAIoH,EACnE,CA8BoCwB,CAAe5D,EAAMC,EAAKC,GAC1D,QAAAD,EAAI3J,QAAQ,KAAoB,OAAAmN,GAAexD,EAAKC,GACvD,GAAyB,KAAtBD,EAAIrI,WAAW,GAAW,MAAO,IAAI8L,GAAc1D,EAAKC,EAAIV,OAAsB,KAAfU,EAAInI,OAAO,GAAQ,EAAE,GAAGoI,GAC1F,IAAAhJ,EACAoL,EAAsBC,EAAIC,EAAIC,EAAOrH,KAAKyC,IAAIqC,GAAMwC,EAAOxC,EAAM,EAAI,IAAM,GAC5E,GAAAD,EAAIW,MAAM,gBAAiB8B,EAAO9H,EAAK6H,EAAKxC,EAAItI,QAChD,GAAAsI,EAAIW,MAAM,WAEZ,OADA1J,EAAK,GAAGgJ,EAAiB,IAARA,IAAehJ,EAAA,IACzBA,EAAES,OAASsI,EAAItI,OAAST,EAAIsK,GAAMvB,EAAIV,OAAO,EAAEU,EAAItI,OAAOT,EAAES,SAAWT,EAE3E,GAAAoL,EAAIrC,EAAIW,MAAMQ,IAAgB,OArKnC,SAAsBkB,EAAqBG,EAAiBC,GAC3D,OAAOA,GAAiB,IAATD,EAAa,GAAK,GAAGA,GAAQzH,GAAK,IAAKsH,EAAE,GAAG3K,OAAS,EAAI2K,EAAE,GAAG3K,OAC9E,CAmKmCkM,CAAavB,EAAGG,EAAMC,GACxD,GAAGzC,EAAIW,MAAM,UAAkB,OAAA8B,EAAO9H,EAAK6H,EAAKxC,EAAItI,OAASsI,EAAI3J,QAAQ,MACzE,GAAIgM,EAAIrC,EAAIW,MAAMS,IAMV,OAHPnK,GADAA,GAAK,GAAGgJ,GAAKlI,QAAQ,aAAa,MAAMwJ,GAAMc,EAAE,KAAKtK,QAAQ,MAAM,IAAIwJ,GAAMc,EAAE,MACzEtK,QAAQ,YAAW,SAASgJ,EAAIC,GAE9B,MAAA,IAAMA,EAAKjG,GAAK,IAAKwG,GAAMc,EAAE,IAAI3K,OAAOsJ,EAAGtJ,OAAQ,SACpDsI,EAAI3J,QAAQ,MAAeY,EAAIA,EAAEc,QAAQ,OAAO,KAGxD,GADMiI,EAAAA,EAAIjI,QAAQ,YAAa,MAC3BsK,EAAIrC,EAAIW,MAAM,gBACjB,OAAO8B,GAAQ,GAAGD,GAAMzK,QAAQ,kBAAkB,OAAOA,QAAQ,YAAY,OAAOA,QAAQ,OAAOsK,EAAE,GAAG3K,OAAO,KAAK,KAEjH,GAAA2K,EAAIrC,EAAIW,MAAM,qBAA8B,OAAA8B,EAAOnC,GAAU,GAAGkC,GACpE,GAAIH,EAAIrC,EAAIW,MAAM,qBACjB,OAAOV,EAAM,EAAI,IAAMwD,GAAc1D,EAAMC,GAAMC,GAAOK,GAAU,GAAGL,GAAQ,IAAMlF,GAAK,IAAIsH,EAAE,GAAG3K,QAElG,GAAI2K,EAAIrC,EAAIW,MAAM,YAAc,OAAO8C,GAAc1D,EAAKC,EAAIjI,QAAQ,SAAS,IAAIkI,GACnF,GAAIoC,EAAIrC,EAAIW,MAAM,2BAGV,OAFH1J,EAAAyD,EAAQ+I,GAAc1D,EAAMC,EAAIjI,QAAQ,SAAS,IAAKkI,IACrDqC,EAAA,EACE5H,EAAQA,EAAQsF,EAAIjI,QAAQ,MAAM,KAAKA,QAAQ,SAAQ,SAASrB,GAAU,OAAA4L,EAAGrL,EAAES,OAAOT,EAAEY,OAAOyK,KAAU,MAAJ5L,EAAQ,IAAI,EAAG,KAEzH,GAAAsJ,EAAIW,MAAMW,IAEZ,MAAO,KADHrK,EAAAwM,GAAc1D,EAAM,aAAcE,IACvBX,OAAO,EAAE,GAAK,KAAOrI,EAAEqI,OAAO,EAAG,GAAK,IAAMrI,EAAEqI,OAAO,GAErE,IAAI4D,EAAK,GACT,GAAIb,EAAIrC,EAAIW,MAAM,+BAUV,OATP2B,EAAKnH,KAAKgI,IAAiBd,EAAE,GAAU3K,OAAO,GACzC6K,EAAAxG,EAASyG,EAAMrH,KAAKC,IAAI,GAAGkH,GAAI,GAAG,GACvCrL,EAAI,GAAKwL,EAEoB,MADxBS,EAAAlB,GAAU,IAAkBK,EAAE,GAAWE,EAAG,KAC3C1K,OAAOqL,EAAGxL,OAAO,KAAgBwL,EAAAA,EAAG5D,OAAO,EAAE4D,EAAGxL,OAAO,GAAK,KAC7DT,GAAAiM,EAAkBb,EAAE,GAAY,IAAmBA,EAAE,IAC1Da,EAAKjI,EAAMsH,EAAG,GAAGD,IACX5K,OAAS2K,EAAE,GAAG3K,WAAa6J,GAAMc,EAAE,GAAG/C,OAAO+C,EAAE,GAAG3K,OAAOwL,EAAGxL,SAAWwL,GACxEjM,GAAAiM,EAGN,GAAIb,EAAIrC,EAAIW,MAAM,iCAGV,OAFP2B,EAAKnH,KAAKgI,IAAIhI,KAAKiI,IAAIf,EAAE,GAAG3K,OAAQ2K,EAAE,GAAG3K,QAAQ,GAE1C+K,IADFF,EAAAxG,EAASyG,EAAMrH,KAAKC,IAAI,GAAGkH,GAAI,GAAG,IACrB,KAAKC,EAAG,GAAK,GAAK,MAAQ,KAAOA,EAAG,GAAKvH,EAAKuH,EAAG,GAAGD,GAAMD,EAAE,GAAK,IAAMA,EAAE,GAAKpH,EAAMsH,EAAG,GAAGD,GAAKvH,GAAK,IAAK,EAAEuH,EAAG,EAAID,EAAE,GAAG3K,OAAS2K,EAAE,GAAG3K,SAExJ,GAAI2K,EAAIrC,EAAIW,MAAM,YAEjB,OADA1J,EAAI,GAAKgJ,EACND,EAAItI,QAAUT,EAAES,OAAeT,EAC3BsK,GAAMvB,EAAIV,OAAO,EAAEU,EAAItI,OAAOT,EAAES,SAAWT,EAEnD,GAAIoL,EAAIrC,EAAIW,MAAM,sBAAwB,CACzC1J,EAAI,GAAKgJ,EAAId,QAAQhE,KAAKgI,IAAId,EAAE,GAAG3K,OAAO,KAAKK,QAAQ,YAAY,MAC9DuK,EAAArL,EAAEZ,QAAQ,KACX,IAAAgN,EAAOrD,EAAI3J,QAAQ,KAAOiM,EAAIgB,EAAOtD,EAAItI,OAAST,EAAES,OAAS2L,EACjE,OAAO9B,GAAMvB,EAAIV,OAAO,EAAE+D,GAAQpM,EAAI+I,EAAIV,OAAOU,EAAItI,OAAO4L,GAC9D,CACC,GAAIjB,EAAIrC,EAAIW,MAAM,sBACV,OAAAV,EAAM,EAAI,IAAMwD,GAAc1D,EAAMC,GAAMC,GAAOK,GAAS,GAAGL,GAAKlI,QAAQ,aAAa,OAAOA,QAAQ,SAAQ,SAASgJ,GAAa,MAAA,OAASA,EAAGrJ,OAAS,EAAIiD,EAAK,EAAE,EAAEoG,EAAGrJ,QAAU,IAAMqJ,CAAG,IAAM,IAAMpG,EAAK,EAAE0H,EAAE,GAAG3K,QAE5N,OAAOsI,GACN,IAAK,UACL,IAAK,SACL,IAAK,QAAa,IAAAtJ,EAAI4J,GAAS,GAAGkC,GAAc,MAAM,MAAN9L,EAAY+L,EAAO/L,EAAI,GACvE,QACI,GAAAsJ,EAAIW,MAAM,aAAc,OAAO8C,GAAc1D,EAAMC,EAAI1F,MAAM,EAAE0F,EAAI6D,YAAY,MAAO5D,GAAOsB,GAAMvB,EAAI1F,MAAM0F,EAAI6D,YAAY,OAElI,MAAM,IAAIhE,MAAM,uBAAyBG,EAAM,IAChD,CACA,SAASgC,GAAUjC,EAAiBC,EAAgBC,GAC3C,OAAI,EAAJA,KAAWA,EAAMwD,GAAc1D,EAAMC,EAAKC,GAAO6B,GAAc/B,EAAMC,EAAKC,EACnF,CAkBA,IAAI6D,GAAc,kCAClB,SAASC,GAAY/D,GAEd,IADN,IAAIvI,EAAI,EAAeoC,EAAI,GAAI5C,EAAI,GAC7BQ,EAAIuI,EAAItI,QACb,OAAQmC,EAAImG,EAAInI,OAAOJ,IACtB,IAAK,IAAQgE,EAAcuE,EAAKvI,KAAQA,GAAA,GAAGA,IAAK,MAChD,IAAK,IAAK,KAAsC,KAAzBuI,EAAIrI,aAAaF,IAAcA,EAAIuI,EAAItI,WAAsBD,EAAG,MACvF,IAAK,KACL,IAAK,IAAQA,GAAA,EAAG,MAChB,IAAK,MAAOA,EAAG,MACf,IAAK,IAAK,IAAK,IACd,GAAuB,MAApBuI,EAAInI,OAAOJ,EAAE,IAAkC,MAApBuI,EAAInI,OAAOJ,EAAE,GAAmB,OAAA,EAE/D,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAEvD,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAY,OAAA,EAC7E,IAAK,IAAK,IAAK,IAAK,IAAK,IACrB,GAAmC,QAAnCuI,EAAIV,OAAO7H,EAAG,GAAGgI,cAAgC,OAAA,EACjD,GAAmC,UAAnCO,EAAIV,OAAO7H,EAAG,GAAGgI,cAAkC,OAAA,EACnD,GAAmC,UAAnCO,EAAIV,OAAO7H,EAAG,GAAGgI,cAAkC,OAAA,IACpDhI,EAAG,MACN,IAAK,IAEE,IADFR,EAAA4C,EACsB,MAApBmG,EAAInI,OAAOJ,MAAgBA,EAAIuI,EAAItI,QAAQT,GAAK+I,EAAInI,OAAOJ,GACjE,GAAGR,EAAE0J,MAAMmD,IAAqB,OAAA,EAChC,MACD,IAAK,IAEL,IAAK,IAAK,IAAK,IACd,KAAMrM,EAAIuI,EAAItI,SAAW,YAAYrB,QAAQwD,EAAEmG,EAAInI,SAASJ,KAAa,GAAG,MAAHoC,GAA8B,KAAnBmG,EAAInI,OAAOJ,EAAE,IAAa,KAAKpB,QAAQ2J,EAAInI,OAAOJ,EAAE,KAAS,KACjJ,MACD,IAAK,IAAK,KAAMuI,EAAInI,SAASJ,KAAOoC,IAAgB,MACpD,IAAK,MAAOpC,EAAuB,KAAjBuI,EAAInI,OAAOJ,IAA8B,KAAjBuI,EAAInI,OAAOJ,MAAaA,EAAG,MACrE,IAAK,IAAK,IAAK,MAAOA,EAAG,MACzB,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC9E,KAAAA,EAAIuI,EAAItI,QAAU,aAAarB,QAAQ2J,EAAInI,SAASJ,KAAS,IAAc,MAElF,UAAWA,EAGN,OAAA,CACR,CAkNA,IAAIuM,GAAW,wCACf,SAASC,GAAQrJ,EAAGgI,GAChB,GAAM,MAANA,EAAmB,OAAA,EACtB,IAAIsB,EAASC,WAAWvB,EAAG,IACpB,OAAAA,EAAG,IACT,IAAK,IAAS,GAAAhI,GAAKsJ,EAAe,OAAA,EAAM,MACxC,IAAK,IAAS,GAAAtJ,EAAKsJ,EAAe,OAAA,EAAM,MACxC,IAAK,IAAS,GAAAtJ,EAAKsJ,EAAe,OAAA,EAAM,MACxC,IAAK,KAAS,GAAAtJ,GAAKsJ,EAAe,OAAA,EAAM,MACxC,IAAK,KAAS,GAAAtJ,GAAKsJ,EAAe,OAAA,EAAM,MACxC,IAAK,KAAS,GAAAtJ,GAAKsJ,EAAe,OAAA,EAE5B,OAAA,CACR,CACA,SAASE,GAAWC,EAAczJ,GAC7B,IAAAoF,EA3RL,SAAuBA,GAGd,IAFR,IAAI5C,EAAwB,GACxBkH,GAAS,EACL7M,EAAI,EAAG8I,EAAI,EAAG9I,EAAIuI,EAAItI,SAAUD,EAAG,OAAeuI,EAAIrI,WAAWF,IACxE,KAAK,GACJ6M,GAAUA,EAAQ,MACnB,KAAK,GAAI,KAAK,GAAI,KAAK,KACpB7M,EAAG,MACN,KAAK,GACJ2F,EAAIA,EAAI1F,QAAUsI,EAAIV,OAAOiB,EAAE9I,EAAE8I,GACjCA,EAAI9I,EAAE,EAGR,GADA2F,EAAIA,EAAI1F,QAAUsI,EAAIV,OAAOiB,IACf,IAAX+D,EAAiB,MAAM,IAAIzE,MAAM,WAAaG,EAAM,0BAChD,OAAA5C,CACR,CA4QWmH,CAAcF,GACpBG,EAAIxE,EAAItI,OAAQ+M,EAAMzE,EAAIwE,EAAE,GAAGnO,QAAQ,KAExC,GADAmO,EAAE,GAAKC,GAAI,KAAMD,EACjBxE,EAAItI,OAAS,EAAS,MAAA,IAAImI,MAAM,iCAAmCG,EAAIlG,KAAK,KAAO,KACtF,GAAgB,iBAANc,EAAuB,MAAA,CAAC,EAAkB,IAAfoF,EAAItI,QAAgB+M,KAAOzE,EAAIA,EAAItI,OAAO,GAAG,KAClF,OAAOsI,EAAItI,QACV,KAAK,EAASsI,EAAAyE,KAAS,CAAC,UAAW,UAAW,UAAWzE,EAAI,IAAM,CAACA,EAAI,GAAIA,EAAI,GAAIA,EAAI,GAAI,KAAM,MAClG,KAAK,EAASA,EAAAyE,GAAS,EAAA,CAACzE,EAAI,GAAIA,EAAI,GAAIA,EAAI,GAAIA,EAAI,IAAM,CAACA,EAAI,GAAIA,EAAI,GAAIA,EAAI,GAAI,KAAM,MACzF,KAAK,EAASA,EAAAyE,GAAS,EAAA,CAACzE,EAAI,GAAIA,EAAI,GAAIA,EAAI,GAAIA,EAAI,IAAM,CAACA,EAAI,GAAIA,EAAI,GAAIA,EAAI,GAAI,KAGpF,IAAIuC,EAAK3H,EAAI,EAAIoF,EAAI,GAAKpF,EAAI,EAAIoF,EAAI,GAAKA,EAAI,GAC/C,IAAiC,IAA9BA,EAAI,GAAG3J,QAAQ,WAAe2J,EAAI,GAAG3J,QAAQ,KAAoB,MAAA,CAACmO,EAAGjC,GACxE,GAA8B,MAA3BvC,EAAI,GAAGW,MAAM,YAAiD,MAA3BX,EAAI,GAAGW,MAAM,WAAoB,CACtE,IAAI+D,EAAK1E,EAAI,GAAGW,MAAMqD,IAClBW,EAAK3E,EAAI,GAAGW,MAAMqD,IACtB,OAAOC,GAAQrJ,EAAG8J,GAAM,CAACF,EAAGxE,EAAI,IAAMiE,GAAQrJ,EAAG+J,GAAM,CAACH,EAAGxE,EAAI,IAAM,CAACwE,EAAGxE,EAAU,MAAN0E,GAAoB,MAANC,EAAa,EAAI,GAC9G,CACQ,MAAA,CAACH,EAAGjC,EACZ,CACA,SAAS3C,GAAWI,EAAsBpF,EAAU3D,GAC3C,MAALA,IAAWA,EAAI,CAAE,GACpB,IAAIiL,EAAO,GACX,cAAclC,GACb,IAAK,WACM,UAAPA,GAAmB/I,EAAE2N,OAAe3N,EAAE2N,OAC7B5E,EACZ,MACD,IAAK,SAGO,SAFD,IAAPA,GAAa/I,EAAE2N,OAAe3N,EAAE2N,QACX,MAAX3N,EAAE4N,MAAiB5N,EAAE4N,MAAiBjJ,GAAWoE,MACrCkC,EAAAjL,EAAE4N,OAAS5N,EAAE4N,MAAMhJ,EAAgBmE,KAAUpE,EAAUC,EAAgBmE,KACrF,MAARkC,IAAqBA,EAAApG,EAAgBkE,IAAQ,WAGlD,GAAGvE,EAAcyG,EAAK,GAAW,OAAAxC,EAAY9E,EAAG3D,GAC7C2D,aAAakD,OAAMlD,EAAI6D,EAAc7D,EAAG3D,EAAE4G,WACzC,IAAAwG,EAAID,GAAWlC,EAAMtH,GACtB,GAAAa,EAAc4I,EAAE,IAAY,OAAA3E,EAAY9E,EAAG3D,GAC3C,IAAM,IAAN2D,EAAgBA,EAAA,YAAgB,IAAM,IAANA,EAAiBA,EAAA,aAAA,GACtC,KAANA,GAAiB,MAALA,EAAkB,MAAA,GAC/B,OAxQR,SAAkBoF,EAAgBpF,EAAWkC,EAAcgI,GAIpD,IAHN,IAA8CC,EAAIxE,EAAGkB,EAAjDrE,EAAM,GAAInG,EAAI,GAAIQ,EAAI,EAAGoC,EAAI,GAAImL,EAAI,IACrCC,EAAG,IAEDxN,EAAIuI,EAAItI,QACb,OAAQmC,EAAImG,EAAInI,OAAOJ,IACtB,IAAK,IACD,IAACgE,EAAcuE,EAAKvI,GAAU,MAAA,IAAIoI,MAAM,0BAA4BhG,EAAI,OAAQmG,GACnF5C,EAAIA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAE,WAAenD,GAAA,EAAG,MAC/C,IAAK,IACJ,IAAIR,EAAE,GAAgC,MAA5BwK,EAAGzB,EAAIrI,aAAaF,KAAcA,EAAIuI,EAAItI,QAAcT,GAAAN,OAAOC,aAAa6K,GACtFrE,EAAIA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAE3D,KAAMQ,EAAG,MACtC,IAAK,KAAU,IAAAyH,EAAIc,EAAInI,SAASJ,GAAIqD,EAAW,MAANoE,GAAmB,MAANA,EAAaA,EAAI,IACtE9B,EAAIA,EAAI1F,QAAU,CAACoD,IAAKF,EAAEsE,KAAMzH,EAAG,MACpC,IAAK,IAAK2F,EAAIA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAE,KAASnD,GAAA,EAAG,MAClD,IAAK,IACJ2F,EAAIA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,OAAQnD,EAAG,MACtC,IAAK,IAAK,IAAK,IACX,GAAoB,MAApBuI,EAAInI,OAAOJ,EAAE,IAAkC,MAApBuI,EAAInI,OAAOJ,EAAE,GAAY,CACtD,GAAO,MAAJsN,GAA6E,OAA9DA,EAAAlI,EAAoBjC,EAAGkC,EAA0B,MAApBkD,EAAInI,OAAOJ,EAAE,KAAiC,MAAA,GACzF2F,EAAAA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAEoF,EAAIV,OAAO7H,EAAE,IAAWuN,EAAAnL,EAAMpC,GAAA,EAAG,KAClE,CAEG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACtDoC,EAAIA,EAAEqL,cAEP,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7D,GAAAtK,EAAI,EAAU,MAAA,GACjB,GAAO,MAAJmK,GAAoD,OAArCA,EAAAlI,EAAoBjC,EAAGkC,IAA2B,MAAA,GACvD,IAAT7F,EAAA4C,IAAWpC,EAAIuI,EAAItI,QAAUsI,EAAInI,OAAOJ,GAAGyN,gBAAkBrL,GAAM5C,GAAA4C,EAC9D,MAANA,GAAmC,MAAtBmL,EAAIE,gBAA2BrL,EAAA,KACtC,MAANA,IAAeA,EAAAoL,GAClB7H,EAAIA,EAAI1F,QAAU,CAACoD,EAAEjB,EAAGe,EAAE3D,GAAU+N,EAAAnL,EAAG,MACxC,IAAK,IAAK,IAAK,IAAK,IAAK,IACxB,IAAI+C,EAAE,CAAC9B,EAAEjB,EAAGe,EAAEf,GAMd,GALO,MAAJkL,IAAaA,EAAAlI,EAAoBjC,EAAGkC,IACD,QAAnCkD,EAAIV,OAAO7H,EAAG,GAAGgI,eAAkC,MAAJsF,IAAUnI,EAAEhC,EAAImK,EAAGtH,GAAK,GAAK,IAAM,KAAKb,EAAE9B,EAAI,IAAQmK,EAAA,IAAOxN,GAAA,GACrE,UAAlCuI,EAAIV,OAAO7H,EAAE,GAAGgI,eAAoC,MAAJsF,IAAUnI,EAAEhC,EAAImK,EAAGtH,GAAK,GAAK,KAAO,MAAMb,EAAE9B,EAAI,IAAQrD,GAAA,EAAMwN,EAAA,KAC5E,UAAlCjF,EAAIV,OAAO7H,EAAE,GAAGgI,eAAoC,MAAJsF,IAAUnI,EAAEhC,EAAImK,EAAGtH,GAAK,GAAK,KAAO,MAAMb,EAAE9B,EAAI,IAAQrD,GAAA,EAAMwN,EAAA,MAC/GrI,EAAE9B,EAAI,MAAOrD,GACb,MAAJsN,GAAoB,MAARnI,EAAE9B,EAAkB,MAAA,GAC/BsC,EAAAA,EAAI1F,QAAUkF,EAASoI,EAAAnL,EAAG,MAC/B,IAAK,IAEE,IADF5C,EAAA4C,EACsB,MAApBmG,EAAInI,OAAOJ,MAAgBA,EAAIuI,EAAItI,QAAQT,GAAK+I,EAAInI,OAAOJ,GACjE,GAAmB,MAAhBR,EAAEqD,OAAM,GAAa,KAAM,4BAA8BrD,EAAI,IAC7D,GAAAA,EAAE0J,MAAMmD,IAAc,CACxB,GAAO,MAAJiB,GAAoD,OAArCA,EAAAlI,EAAoBjC,EAAGkC,IAA2B,MAAA,GAChEM,EAAAA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAE3D,EAAEiO,eACxBF,EAAA/N,EAAEY,OAAO,EACf,MAASZ,EAAEZ,QAAQ,MAAW,IAC9BY,GAAKA,EAAE0J,MAAM,kBAAkB,IAAI,IAAI,IACnCoD,GAAY/D,KAAU5C,EAAAA,EAAI1F,QAAU,CAACoD,EAAE,IAAIF,EAAE3D,KAElD,MAED,IAAK,IACJ,GAAS,MAAN8N,EAAY,CACD,IAAT9N,EAAA4C,IAAWpC,EAAIuI,EAAItI,QAAgC,OAArBmC,EAAEmG,EAAInI,OAAOJ,KAAkBR,GAAA4C,EACjEuD,EAAIA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAE3D,GAAI,KACrC,CAEG,IAAK,IAAK,IAAK,IACP,IAAHA,EAAA4C,IAAWpC,EAAIuI,EAAItI,QAAU,YAAYrB,QAAQwD,EAAEmG,EAAInI,OAAOJ,QAAeR,GAAA4C,EACjFuD,EAAIA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAE3D,GAAI,MACjC,IAAK,IACG,IAAHA,EAAA4C,EAASmG,EAAInI,SAASJ,KAAOoC,GAAM5C,GAAA4C,EACvCuD,EAAIA,EAAI1F,QAAU,CAACoD,EAAEjB,EAAGe,EAAE3D,GAAU+N,EAAAnL,EAAG,MACxC,IAAK,MAAOpC,EAAuB,KAAjBuI,EAAInI,OAAOJ,IAA8B,KAAjBuI,EAAInI,OAAOJ,MAAaA,EAAG,MACrE,IAAK,IAAK,IAAK,IAAS2F,EAAAA,EAAI1F,QAAU,CAACoD,EAAU,IAAPgK,EAAS,IAAIjL,EAAIe,EAAEf,KAAMpC,EAAG,MACtE,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7E,IAAHR,EAAA4C,EAASpC,EAAIuI,EAAItI,QAAU,aAAarB,QAAQ2J,EAAInI,SAASJ,KAAM,GAAOR,GAAA+I,EAAInI,OAAOJ,GACzF2F,EAAIA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAE3D,GAAI,MACjC,IAAK,IAAKmG,EAAIA,EAAI1F,QAAU,CAACoD,EAAEjB,EAAGe,EAAEf,KAAMpC,EAAG,MAC7C,IAAK,IAAK2F,EAAIA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAE,OAAQnD,EAAG,MACjD,QACI,IAAuD,IAAvD,wCAAwCpB,QAAQwD,GAAiB,MAAA,IAAIgG,MAAM,0BAA4BhG,EAAI,OAASmG,GACvH5C,EAAIA,EAAI1F,QAAU,CAACoD,EAAE,IAAKF,EAAEf,KAAMpC,EAKjC,IAAiB0N,EAAjBC,EAAK,EAAGlF,EAAM,EACd,IAAAzI,EAAE2F,EAAI1F,OAAO,EAAGsN,EAAI,IAAKvN,GAAK,IAAKA,EAC/B,OAAA2F,EAAI3F,GAAGqD,GACb,IAAK,IAAK,IAAK,IAASsC,EAAA3F,GAAGqD,EAAImK,EAAQD,EAAA,IAAQI,EAAK,IAAQA,EAAA,GAAG,MAC/D,IAAK,KACAD,EAAI/H,EAAI3F,GAAGmD,EAAE+F,MAAM,YAAeT,EAAA/E,KAAKiI,IAAIlD,EAAIiF,EAAI,GAAGzN,OAAO,IAC9D0N,EAAK,IAAQA,EAAA,GAEjB,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAASJ,EAAA5H,EAAI3F,GAAGqD,EAAG,MACtD,IAAK,IAAgB,MAARkK,IAAmB5H,EAAA3F,GAAGqD,EAAI,IAAQsK,EAAK,IAAQA,EAAA,IAAK,MACjE,IAAK,IACJ,MACD,IAAK,IACDA,EAAK,GAAKhI,EAAI3F,GAAGmD,EAAE+F,MAAM,UAAcyE,EAAA,GACvCA,EAAK,GAAKhI,EAAI3F,GAAGmD,EAAE+F,MAAM,UAAcyE,EAAA,GACvCA,EAAK,GAAKhI,EAAI3F,GAAGmD,EAAE+F,MAAM,UAAcyE,EAAA,GAI7C,OAAOA,GACN,KAAK,EAAG,MACR,KAAK,EAEDL,EAAGzH,GAAK,KAAOyH,EAAGzH,EAAI,IAAKyH,EAAGpH,GAC9BoH,EAAGpH,GAAM,KAAMoH,EAAGpH,EAAI,IAAKoH,EAAGrH,GAC9BqH,EAAGrH,GAAM,KAAMqH,EAAGrH,EAAI,IAAKqH,EAAGtH,GACjC,MACD,KAAK,EAEDsH,EAAGzH,GAAK,KAAOyH,EAAGzH,EAAI,IAAKyH,EAAGpH,GAC9BoH,EAAGpH,GAAM,KAAMoH,EAAGpH,EAAI,IAAKoH,EAAGrH,GAKnC,IAAe2H,EAAXC,EAAO,GACX,IAAI7N,EAAE,EAAGA,EAAI2F,EAAI1F,SAAUD,EACnB,OAAA2F,EAAI3F,GAAGqD,GACb,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,MACxC,IAAK,IAASsC,EAAA3F,GAAGmD,EAAI,GAAQwC,EAAA3F,GAAGqD,EAAI,IAAK,MACzC,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAE9FsC,EAAI3F,GAAGmD,EAAIkF,EAAe1C,EAAI3F,GAAGqD,EAAEnD,WAAW,GAAIyF,EAAI3F,GAAGmD,EAAGmK,EAAI7E,GAC5D9C,EAAA3F,GAAGqD,EAAI,IAAK,MACjB,IAAK,IAAK,IAAK,IAEd,IADAuK,EAAK5N,EAAE,EACU,MAAX2F,EAAIiI,KACS,OAAjBxL,EAAEuD,EAAIiI,GAAIvK,IAAoB,MAANjB,IACjB,MAANA,GAAmB,MAANA,IAA2B,MAAbuD,EAAIiI,EAAG,KAA+B,MAAhBjI,EAAIiI,EAAG,GAAGvK,GAA6B,MAAhBsC,EAAIiI,EAAG,GAAGvK,GAA6B,MAAhBsC,EAAIiI,EAAG,GAAGzK,IAC7F,MAAbwC,EAAI3F,GAAGqD,IAAoB,MAANjB,GAAmB,MAANA,GAAmB,MAANA,IACzC,MAANA,IAA4B,MAAduD,EAAIiI,GAAIzK,GAA2B,MAAdwC,EAAIiI,GAAIzK,GAA0B,MAAbwC,EAAIiI,EAAG,IAA6B,KAAfjI,EAAIiI,EAAG,GAAGvK,KAExFsC,EAAI3F,GAAGmD,GAAKwC,EAAIiI,GAAIzK,EACpBwC,EAAIiI,GAAM,CAACzK,EAAE,GAAIE,EAAE,OAAQuK,EAEpBC,GAAAlI,EAAI3F,GAAGmD,EACfnD,EAAI4N,EAAG,EAAG,MACX,IAAK,IAASjI,EAAA3F,GAAGqD,EAAI,IAAKsC,EAAI3F,GAAGmD,EAAI8E,EAAY9E,EAAEkC,GAGjD,IAASyI,EAAKC,EAAdC,EAAK,GACN,GAAAH,EAAK5N,OAAS,EAAG,CACM,IAAtB4N,EAAK3N,WAAW,IACX4N,EAAA3K,EAAE,GAA0B,KAAvB0K,EAAK3N,WAAW,IAAaiD,EAAIA,EACtC4K,EAAAxD,GAAU,IAAKsD,EAAMC,KAGrBC,EAAAxD,GAAU,IAAKsD,EADtBC,EAAO3K,EAAE,GAAKkK,EAAO,GAAKlK,EAAIA,GAE3B2K,EAAM,GAAKnI,EAAI,IAAkB,KAAZA,EAAI,GAAGtC,IACvB0K,EAAAA,EAAKlG,OAAO,GACnBlC,EAAI,GAAGxC,EAAI,IAAMwC,EAAI,GAAGxC,IAG1ByK,EAAGG,EAAK9N,OAAO,EACf,IAAIgO,EAAQtI,EAAI1F,OACZ,IAAAD,EAAE,EAAGA,EAAI2F,EAAI1F,SAAUD,EAAG,GAAa,MAAV2F,EAAI3F,IAA0B,KAAZ2F,EAAI3F,GAAGqD,GAAYsC,EAAI3F,GAAGmD,EAAEvE,QAAQ,MAAW,EAAA,CAAUqP,EAAAjO,EAAG,KAAM,CACrH,IAAIkO,EAAMvI,EAAI1F,OACd,GAAGgO,IAAUtI,EAAI1F,SAAoC,IAA1B8N,EAAKnP,QAAQ,KAAa,CACpD,IAAIoB,EAAE2F,EAAI1F,OAAO,EAAGD,GAAI,IAAIA,EACd,MAAV2F,EAAI3F,KAA6C,IAA/B,KAAKpB,QAAQ+G,EAAI3F,GAAGqD,KACtCuK,GAAIjI,EAAI3F,GAAGmD,EAAElD,OAAO,GAAW2N,GAAAjI,EAAI3F,GAAGmD,EAAElD,OAAY0F,EAAA3F,GAAGmD,EAAI4K,EAAKlG,OAAO+F,EAAG,EAAGjI,EAAI3F,GAAGmD,EAAElD,SACjF2N,EAAK,EAAOjI,EAAA3F,GAAGmD,EAAI,IACpBwC,EAAI3F,GAAGmD,EAAI4K,EAAKlG,OAAO,EAAG+F,EAAG,GAASA,GAAA,GACzCjI,EAAA3F,GAAGqD,EAAI,IACH6K,EAAAlO,GAEN4N,GAAI,GAAKM,EAAMvI,EAAI1F,WAAYiO,GAAO/K,EAAI4K,EAAKlG,OAAO,EAAE+F,EAAG,GAAKjI,EAAIuI,GAAO/K,EACjF,MAAA,GACU8K,IAAUtI,EAAI1F,SAAoC,IAA1B8N,EAAKnP,QAAQ,KAAa,CAEzD,IADKgP,EAAAG,EAAKnP,QAAQ,KAAK,EACnBoB,EAAEiO,EAAOjO,GAAI,IAAKA,EAClB,GAAU,MAAV2F,EAAI3F,KAA6C,IAA/B,KAAKpB,QAAQ+G,EAAI3F,GAAGqD,GAAtC,CAGG,IAFJyF,EAAAnD,EAAI3F,GAAGmD,EAAEvE,QAAQ,MAAS,GAAAoB,IAAIiO,EAAMtI,EAAI3F,GAAGmD,EAAEvE,QAAQ,KAAK,EAAE+G,EAAI3F,GAAGmD,EAAElD,OAAO,EAC9E+N,EAAKrI,EAAI3F,GAAGmD,EAAE0E,OAAOiB,EAAE,GACjBA,GAAG,IAAKA,EACV8E,GAAI,IAA6B,MAAvBjI,EAAI3F,GAAGmD,EAAE/C,OAAO0I,IAAqC,MAAvBnD,EAAI3F,GAAGmD,EAAE/C,OAAO0I,MAAkBkF,EAAAD,EAAK3N,OAAOwN,KAAQI,GAE9FrI,EAAA3F,GAAGmD,EAAI6K,EACPrI,EAAA3F,GAAGqD,EAAI,IACH6K,EAAAlO,CAR4C,CAYrD,IAFG4N,GAAI,GAAKM,EAAMvI,EAAI1F,WAAYiO,GAAO/K,EAAI4K,EAAKlG,OAAO,EAAE+F,EAAG,GAAKjI,EAAIuI,GAAO/K,GACzEyK,EAAAG,EAAKnP,QAAQ,KAAK,EACnBoB,EAAEiO,EAAOjO,EAAE2F,EAAI1F,SAAUD,EAC5B,GAAa,MAAV2F,EAAI3F,MAA2C,IAA5B,MAAMpB,QAAQ+G,EAAI3F,GAAGqD,IAAarD,IAAMiO,GAA9D,CAGA,IAFAnF,EAAEnD,EAAI3F,GAAGmD,EAAEvE,QAAQ,MAAK,GAAIoB,IAAIiO,EAAMtI,EAAI3F,GAAGmD,EAAEvE,QAAQ,KAAK,EAAE,EAC9DoP,EAAKrI,EAAI3F,GAAGmD,EAAE0E,OAAO,EAAEiB,GACjBA,EAAEnD,EAAI3F,GAAGmD,EAAElD,SAAU6I,EACvB8E,EAAGG,EAAK9N,SAAc+N,GAAAD,EAAK3N,OAAOwN,MAElCjI,EAAA3F,GAAGmD,EAAI6K,EACPrI,EAAA3F,GAAGqD,EAAI,IACH6K,EAAAlO,CAR8D,CAU1E,CACA,CACC,IAAIA,EAAE,EAAGA,EAAE2F,EAAI1F,SAAUD,EAAgB,MAAV2F,EAAI3F,IAAc,KAAKpB,QAAQ+G,EAAI3F,GAAGqD,IAAO,IAC3EyK,EAAOT,EAAM,GAAKlK,EAAI,GAAKnD,EAAE,GAAoB,MAAf2F,EAAI3F,EAAE,GAAGmD,GAAaA,EAAEA,EAC1DwC,EAAI3F,GAAGmD,EAAIoH,GAAU5E,EAAI3F,GAAGqD,EAAGsC,EAAI3F,GAAGmD,EAAG2K,GACrCnI,EAAA3F,GAAGqD,EAAI,KAEZ,IAAI8K,EAAS,GACb,IAAInO,EAAE,EAAGA,IAAM2F,EAAI1F,SAAUD,EAAgB,MAAV2F,EAAI3F,KAAsBmO,GAAAxI,EAAI3F,GAAGmD,GAC7D,OAAAgL,CACR,CA0DQC,CAASxB,EAAE,GAAIzJ,EAAG3D,EAAGoN,EAAE,GAC/B,CACA,SAASyB,GAAS9F,EAAgBU,GAC9B,GAAc,iBAAPA,EAAiB,CAC1BA,GAAOA,IAAO,EAEd,IAAA,IAAQjJ,EAAI,EAAGA,EAAI,MAAUA,EAEzB,GAAgB,MAAhBmE,EAAUnE,IACV,GAAAmE,EAAUnE,IAAMuI,EAAK,CAAQU,EAAAjJ,EAAG,KAAM,OADNiJ,EAAM,IAASA,EAAAjJ,GAIhDiJ,EAAM,IAASA,EAAA,IACpB,CAGQ,OADP9E,EAAU8E,GAAOV,EACVU,CACR,CACA,SAASqF,GAAeC,GACvB,IAAA,IAAQvO,EAAE,EAAM,KAAHA,IAAaA,OACX,IAAXuO,EAAIvO,OAA2BuO,EAAIvO,GAAIA,EAC5C,CAEA,SAASwO,KAx7BT,IAAwBnL,EACnBA,IAAGA,EAAI,CAAE,GACbA,EAAE,GAAK,UACPA,EAAE,GAAK,IACPA,EAAE,GAAK,OACPA,EAAE,GAAK,QACPA,EAAE,GAAK,WACPA,EAAE,GAAK,KACPA,EAAE,IAAK,QACPA,EAAE,IAAK,WACPA,EAAE,IAAK,QACPA,EAAE,IAAK,UACPA,EAAE,IAAK,SACPA,EAAE,IAAK,WACPA,EAAE,IAAK,QACPA,EAAE,IAAK,SACPA,EAAE,IAAK,aACPA,EAAE,IAAK,gBACPA,EAAE,IAAK,OACPA,EAAE,IAAK,UACPA,EAAE,IAAK,cACPA,EAAE,IAAK,iBACPA,EAAE,IAAK,sBACPA,EAAE,IAAK,sBACPA,EAAE,IAAK,2BACPA,EAAE,IAAK,QACPA,EAAE,IAAK,YACPA,EAAE,IAAK,SACPA,EAAE,IAAK,WACPA,EAAE,IAAK,IACPA,EAAE,IAAK,2BA25BPc,EA15BOd,CA25BR,CAqDA,IAAIoL,GAAc,mCAmElB,IAAIC,GAAiC,WACrC,IAAIA,EAAQ,CAAE,EACdA,EAAMC,QAAU,QAsBhB,IAAIC,EAnBJ,WAGC,IAFA,IAAIxM,EAAI,EAAGgL,EAA0B,IAAI7L,MAAM,KAEvCsN,EAAG,EAAQ,KAALA,IAAYA,EASzBzM,EAAQ,GADRA,EAAQ,GADRA,EAAQ,GADRA,EAAQ,GADRA,EAAQ,GADRA,EAAQ,GADRA,EAAQ,GADRA,EAAQ,GADJA,EAAAyM,IACwB,UAAAzM,IAAM,EAAOA,IAAM,IACnB,UAAAA,IAAM,EAAOA,IAAM,IACnB,UAAAA,IAAM,EAAOA,IAAM,IACnB,UAAAA,IAAM,EAAOA,IAAM,IACnB,UAAAA,IAAM,EAAOA,IAAM,IACnB,UAAAA,IAAM,EAAOA,IAAM,IACnB,UAAAA,IAAM,EAAOA,IAAM,IACnB,UAAAA,IAAM,EAAOA,IAAM,EAC/CgL,EAAMyB,GAAKzM,EAGZ,MAA6B,oBAAf0M,WAA6B,IAAIA,WAAW1B,GAASA,CACpE,CAES2B,GAaL,IAAAC,EAZJ,SAA4BpJ,GAC3B,IAAIxD,EAAI,EAAGe,EAAI,EAAG0L,EAAI,EAAGzB,EAAgD,oBAAf0B,WAA6B,IAAIA,WAAW,MAAQ,IAAIvN,MAAM,MAEpH,IAAAsN,EAAI,EAAQ,KAALA,IAAYA,EAASzB,EAAAyB,GAAKjJ,EAAEiJ,GACvC,IAAIA,EAAI,EAAQ,KAALA,IAAYA,EAEtB,IADA1L,EAAIyC,EAAEiJ,GACFzM,EAAI,IAAMyM,EAAGzM,EAAI,KAAMA,GAAK,IAASe,EAAAiK,EAAMhL,GAAMe,IAAM,EAAKyC,EAAM,IAAJzC,GAEnE,IAAIwC,EAAM,GACN,IAAAkJ,EAAI,EAAQ,IAALA,IAAWA,EAAGlJ,EAAIkJ,EAAI,GAA2B,oBAAfC,WAA6B1B,EAAM6B,SAAa,IAAJJ,EAAa,IAAJA,EAAU,KAAOzB,EAAMvK,MAAU,IAAJgM,EAAa,IAAJA,EAAU,KAC3I,OAAAlJ,CACR,CACSuJ,CAAmBN,GACxBO,EAAKH,EAAG,GAAKI,EAAKJ,EAAG,GAAKK,EAAKL,EAAG,GAAKM,EAAKN,EAAG,GAAKO,EAAKP,EAAG,GAC5DQ,EAAKR,EAAG,GAAKS,EAAKT,EAAG,GAAKU,EAAKV,EAAG,GAAKW,EAAKX,EAAG,GAAKY,EAAKZ,EAAG,GAC5Da,EAAKb,EAAG,IAAKc,EAAKd,EAAG,IAAKe,EAAKf,EAAG,IAAKgB,EAAKhB,EAAG,IAAKiB,EAAKjB,EAAG,IAiDzDN,OAJPA,EAAMtB,MAAQwB,EACdF,EAAMwB,KA7CG,SAAWA,EAAiBC,GAEpC,IADA,IAAIC,GAAID,EACAnQ,EAAI,EAAGqQ,EAAIH,EAAKjQ,OAAQD,EAAIqQ,GAAID,EAAKA,IAAI,EAAKxB,EAA4B,KAAxBwB,EAAEF,EAAKhQ,WAAWF,OAC5E,OAAQoQ,CACT,EA0CA1B,EAAM1N,IAxCG,SAAU0D,EAAgCyL,GAElD,IADA,IAAIC,GAAID,EAA0BE,EAAI3L,EAAEzE,OAAS,GAAID,EAAI,EACnDA,EAAIqQ,GAAID,EACbH,EAAGvL,EAAE1E,KAAY,IAAJoQ,GACbJ,EAAGtL,EAAE1E,KAASoQ,GAAK,EAAK,KACxBL,EAAGrL,EAAE1E,KAASoQ,GAAK,GAAM,KACzBN,EAAGpL,EAAE1E,KAAQoQ,IAAM,IACnBP,EAAGnL,EAAE1E,MAAQ4P,EAAGlL,EAAE1E,MAAQ2P,EAAGjL,EAAE1E,MAAQ0P,EAAGhL,EAAE1E,MAC5CyP,EAAG/K,EAAE1E,MAAQwP,EAAG9K,EAAE1E,MAAQuP,EAAG7K,EAAE1E,MAAQsP,EAAG5K,EAAE1E,MAC5CqP,EAAG3K,EAAE1E,MAAQoP,EAAG1K,EAAE1E,MAAQmP,EAAGzK,EAAE1E,MAAQ4O,EAAGlK,EAAE1E,MAEvC,IADDqQ,GAAA,GACCrQ,EAAIqQ,GAAGD,EAAKA,IAAI,EAAKxB,EAAc,KAAVwB,EAAE1L,EAAE1E,OACnC,OAAQoQ,CACT,EA4BA1B,EAAM3E,IA1BG,SAAUA,EAAgBoG,GAE1B,IADR,IAAIC,GAAID,EACAnQ,EAAI,EAAGqQ,EAAItG,EAAI9J,OAAQmC,EAAI,EAAGgB,EAAI,EAAGpD,EAAIqQ,IAC5CjO,EAAA2H,EAAI7J,WAAWF,MACZ,IACNoQ,EAAKA,IAAI,EAAKxB,EAAS,KAALwB,EAAEhO,IACXA,EAAI,KAEbgO,GADKA,EAAAA,IAAI,EAAKxB,EAA2B,KAAvBwB,GAAK,IAAMhO,GAAG,EAAG,SAC1B,EAAKwM,EAAsB,KAAlBwB,GAAK,IAAO,GAAFhO,KACnBA,GAAK,OAAUA,EAAI,OAC5BA,EAAa,IAAN,KAAFA,GAAgBgB,EAAoB,KAApB2G,EAAI7J,WAAWF,KAIpCoQ,GADKA,GADAA,GADAA,EAAAA,IAAI,EAAKxB,EAA0B,KAAtBwB,GAAK,IAAMhO,GAAG,EAAG,QAC1B,EAAKwM,EAA2B,KAAvBwB,GAAK,IAAMhO,GAAG,EAAG,SAC1B,EAAKwM,EAAsC,KAAlCwB,GAAK,IAAMhN,GAAG,EAAG,IAAQ,EAAFhB,IAAM,QACtC,EAAKwM,EAAsB,KAAlBwB,GAAK,IAAO,GAAFhN,MAI5BgN,GADKA,GADAA,EAAAA,IAAI,EAAKxB,EAA4B,KAAxBwB,GAAK,IAAMhO,GAAG,GAAI,SAC3B,EAAKwM,EAA2B,KAAvBwB,GAAK,IAAMhO,GAAG,EAAG,SAC1B,EAAKwM,EAAsB,KAAlBwB,GAAK,IAAO,GAAFhO,KAG9B,OAAQgO,CACT,EAKO1B,CACP,CA1FqC,GA4FjC4B,cACJ,IAuFIC,EAvFAC,EAAU,CAAE,EAWhB,SAASC,EAAQC,GACb,GAA0B,KAA1BA,EAAEtQ,OAAOsQ,EAAEzQ,OAAS,GAAmB,OAAqC,IAArCyQ,EAAE7N,MAAM,MAAMjE,QAAQ,KAAe8R,EAAID,EAAQC,EAAE7N,MAAM,GAAG,IAClG,IAAAT,EAAIsO,EAAEtE,YAAY,KACtB,OAAoB,IAAZhK,EAAYsO,EAAIA,EAAE7N,MAAM,EAAGT,EAAE,EACtC,CAEA,SAASuO,EAASD,GACjB,GAA6B,KAA1BA,EAAEtQ,OAAOsQ,EAAEzQ,OAAS,GAAW,OAAO0Q,EAASD,EAAE7N,MAAM,OACtD,IAAAT,EAAIsO,EAAEtE,YAAY,KACtB,OAAoB,IAAZhK,EAAYsO,EAAIA,EAAE7N,MAAMT,EAAE,EACnC,CASS,SAAAwO,EAAe5P,EAAgBuE,GACpB,iBAATA,IAA0BA,EAAA,IAAIc,KAAKd,IACzC,IAAAsL,EAAiBtL,EAAKuL,WAE1BD,GADMA,EAAAA,GAAO,EAAItL,EAAKwL,eACT,EAAKxL,EAAKyL,eAAe,EAClChQ,EAAAiQ,YAAY,EAAGJ,GACf,IAAAK,EAAkB3L,EAAKiB,cAAgB,KAErC0K,GADNA,EAAMA,GAAO,EAAK3L,EAAKkB,WAAW,IACrB,EAAIlB,EAAKgB,UAClBvF,EAAAiQ,YAAY,EAAGC,EACpB,CAoBA,SAASC,EAAkBC,GAC1BC,GAAUD,EAAM,GAGhB,IAFI,IAAA5R,EAAA,CAAa,EACb8R,EAAQ,EACNF,EAAKrE,GAAKqE,EAAKnR,OAAS,GAAG,CAC5B,IAAAqI,EAAO8I,EAAKG,WAAW,GACvBC,EAAKJ,EAAKG,WAAW,GAAIE,EAAML,EAAKrE,EAAIyE,EACxCd,EAAI,CAAE,EACV,GAEM,QAFCpI,EAIM,GADHgJ,EAAAF,EAAKG,WAAW,MACVb,EAAEgB,MAAQN,EAAKG,WAAW,IAErCC,EAAK,IACI,EAARF,IAAWZ,EAAEiB,MAAQP,EAAKG,WAAW,IAC7B,EAARD,IAAWZ,EAAEkB,MAAQR,EAAKG,WAAW,KAEtCb,EAAEgB,QAAShB,EAAAmB,GAAK,IAAIxL,KAAa,IAARqK,EAAEgB,QAIhCN,EAAKrE,EAAI0E,EACTjS,EAAE8I,GAAQoI,CACZ,CACQ,OAAAlR,CACR,CAEA,SAASsS,IAAkB,OAAAvB,IAAOA,EAAK,CAAE,EAAE,CAClC,SAAAwB,EAAMC,EAAmBC,GAC/B,GAAW,IAAXD,EAAK,IAAyB,IAAXA,EAAK,GAAY,OAAOE,GAAUF,EAAMC,GAC9D,GAAuB,MAAT,GAAVD,EAAK,KAAwC,MAAT,GAARA,EAAK,IAAyB,OAy6CrD,SAAUA,EAAmBC,GACrC,GAA0C,iBAAvChQ,EAAI+P,EAAKnP,MAAM,EAAE,KAAK4K,cAAwC,MAAA,IAAIrF,MAAM,0BACvE,IAAA+J,EAAQF,GAAWA,EAAQE,MAAQ,GAEnCjQ,GAAQ3B,GAAWC,OAAOiC,SAASuP,GAAQA,EAAK9J,SAAS,UAAYjG,EAAI+P,IAAOpQ,MAAM,QACtFwQ,EAAK,EAAGC,EAAM,GAGlB,IAAID,EAAK,EAAGA,EAAKlQ,EAAKjC,SAAUmS,EAE/B,GADAC,EAAMnQ,EAAKkQ,GACP,sBAAsBE,KAAKD,KAC/BA,EAAMA,EAAIxP,MAAMwP,EAAIzT,QAAQ,SACxBuT,IAAMA,EAAOE,EAAIxP,MAAM,EAAGwP,EAAIjG,YAAY,KAAO,IAClDiG,EAAIxP,MAAM,EAAGsP,EAAKlS,SAAWkS,GAC1B,KAAAA,EAAKlS,OAAS,IAEnBkS,GADAA,EAAOA,EAAKtP,MAAM,EAAGsP,EAAKlS,OAAS,IACvB4C,MAAM,EAAGsP,EAAK/F,YAAY,KAAO,GAC1CiG,EAAIxP,MAAM,EAAEsP,EAAKlS,SAAWkS,KAIjC,IAAII,GAAarQ,EAAK,IAAM,IAAIgH,MAAM,oBACtC,IAAIqJ,EAAiB,MAAA,IAAInK,MAAM,4BAC/B,IAAIoK,EAAW,MAAQD,EAAU,IAAM,IAEnCE,EAA6B,GAAIC,EAA8B,GAC/DlT,EAAI,CACPiT,YACAC,aAEDC,EAASnT,GACT,IAAIoT,EAAUC,EAAO,EACrB,IAAIT,EAAK,EAAGA,EAAKlQ,EAAKjC,SAAUmS,EAAI,CAC/B,IAAAU,EAAO5Q,EAAKkQ,GACbU,IAASN,GAAYM,IAASN,EAAW,OACzCK,QAAmBrT,EAAG0C,EAAKW,MAAM+P,EAAUR,GAAKD,GACxCS,EAAAR,EACb,CACQ,OAAA5S,CACR,CAh9C8DuT,CAAUf,EAAMC,GAC3E,GAAAD,EAAK/R,OAAS,IAAK,MAAM,IAAImI,MAAM,iBAAmB4J,EAAK/R,OAAS,UACvE,IAAI+S,EAEAC,EACAC,EACAC,EACAC,EACAC,EALAC,EAAM,IAONC,EAA8B,GAG9BnC,EAAyBY,EAAKnP,MAAM,EAAE,KAC1CwO,GAAUD,EAAM,GAGZ,IAAAoC,EAmFJ,SAAwBpC,GACvB,GAAmB,IAAhBA,EAAKA,EAAKrE,IAAkC,IAApBqE,EAAKA,EAAKrE,EAAI,GAAmB,MAAA,CAAC,EAAG,GAE3DqE,EAAAqC,IAAIC,EAAkB,sBAI3BtC,EAAKrE,GAAK,GAGV,IAAIiG,EAAkB5B,EAAKG,WAAW,EAAG,KAEzC,MAAO,CAACH,EAAKG,WAAW,EAAE,KAAMyB,EACjC,CAhGSW,CAAevC,GAExB,OADA4B,EAAOQ,EAAG,IAET,KAAK,EAASF,EAAA,IAAK,MAAO,KAAK,EAASA,EAAA,KAAM,MAC9C,KAAK,EAAG,GAAY,GAATE,EAAG,GAAgB,OAAAtB,GAAUF,EAAMC,GAE9C,QAAe,MAAA,IAAI7J,MAAM,sCAAwC4K,GAIvD,MAARM,GAA4DjC,GAA7CD,EAAcY,EAAKnP,MAAM,EAAEyQ,GAAkC,IAE/E,IAAIM,EAAsB5B,EAAKnP,MAAM,EAAEyQ,IAqF9B,SAAalC,EAAiB4B,GACtC,IAAIa,EAAQ,EAOZ,OAHAzC,EAAKrE,GAAK,EAGF8G,EAAQzC,EAAKG,WAAW,IAC/B,KAAK,EAAM,GAAW,GAARyB,EAAW,MAAM,IAAI5K,MAAM,gCAAkCyL,GAAQ,MACnF,KAAK,GAAM,GAAW,GAARb,EAAW,MAAM,IAAI5K,MAAM,iCAAmCyL,GAAQ,MACpF,QAAe,MAAA,IAAIzL,MAAM,sCAAwCyL,GAI7DzC,EAAAqC,IAAI,OAAQ,uBAGZrC,EAAAqC,IAAI,eAAgB,aAC1B,CAtGAK,CAAa1C,EAAM4B,GAGnB,IAAIe,EAAqB3C,EAAKG,WAAW,EAAG,KACzC,GAAS,IAATyB,GAA0B,IAAZe,QAAqB,IAAI3L,MAAM,uCAAyC2L,GAGzF3C,EAAKrE,GAAK,EAGEoG,EAAA/B,EAAKG,WAAW,EAAG,KAG/BH,EAAKrE,GAAK,EAGLqE,EAAAqC,IAAI,WAAY,6BAGLL,EAAAhC,EAAKG,WAAW,EAAG,KAG5B0B,EAAA7B,EAAKG,WAAW,EAAG,KAGZ8B,EAAAjC,EAAKG,WAAW,EAAG,KAGjB2B,EAAA9B,EAAKG,WAAW,EAAG,KAGnC,IAAA,IAAQpM,GAAQ,EAAA2D,EAAI,EAAGA,EAAI,QAC1B3D,EAAIiM,EAAKG,WAAW,EAAG,MAClB,KAF4BzI,EAGjCyK,EAAUzK,GAAK3D,EAIZ,IAAA6O,EAmEK,SAAUhC,EAAmBsB,GAGrC,IAFA,IAAIW,EAAWvQ,KAAKwQ,KAAKlC,EAAK/R,OAAOqT,GAAK,EACtCU,EAA8B,GAC1BhU,EAAE,EAAGA,EAAIiU,IAAYjU,EAAWA,EAAAA,EAAE,GAAKgS,EAAKnP,MAAM7C,EAAEsT,GAAKtT,EAAE,GAAGsT,GAE/D,OADPU,EAAQC,EAAS,GAAKjC,EAAKnP,MAAMoR,EAASX,GACnCU,CACR,CAzEkCG,CAAUnC,EAAMsB,GAElDc,EAAWf,EAAaH,EAAec,EAASV,EAAKC,GAGrD,IAAIc,EA+JJ,SAA0BL,EAA6Bb,EAAsBI,EAA6BD,GACzG,IAAIgB,EAAKN,EAAQ/T,OAAQoU,EAA8B,GACnDE,EAA0B,GAAIvT,EAAwB,GAAIwT,EAAgC,GAC1FC,EAAUnB,EAAM,EAAGtT,EAAE,EAAG8I,EAAE,EAAG4L,EAAE,EAAG9G,EAAG,EACzC,IAAI5N,EAAE,EAAGA,EAAIsU,IAAMtU,EAGf,GAFHgB,EAAO,IACP0T,EAAK1U,EAAImT,IAAoBmB,IAAOI,GAAAJ,IACjCC,EAAKG,GAAL,CACHF,EAAY,GACZ,IAAIG,EAAO,GACP,IAAA7L,EAAE4L,EAAG5L,GAAG,GAAI,CACf6L,EAAK7L,IAAK,EACVyL,EAAKzL,IAAK,EACN9H,EAAAA,EAAIf,QAAU6I,EACR0L,EAAAI,KAAKZ,EAAQlL,IACvB,IAAI+L,EAAkBtB,EAAU7P,KAAKwB,MAAQ,EAAF4D,EAAIwK,IAE5C,GAAAA,EAAM,GADT1F,EAAS,EAAF9E,EAAO2L,GACG,MAAM,IAAIrM,MAAM,yBAA2BU,EAAI,MAAMwK,GACnE,IAACU,EAAQa,GAAO,MAEhB,GAAAF,EADH7L,EAAIgM,GAAcd,EAAQa,GAAOjH,IACrB,KACf,CACcyG,EAAAK,GAAM,CAACK,MAAO/T,EAAKkB,KAAK8S,GAAW,CAACR,IAfpC,CAiBN,OAAAH,CACR,CAxLiCY,CAAiBjB,EAASb,EAAWI,EAAWD,GAErEe,EAAAlB,GAAW+B,KAAO,aAC3BjC,EAAO,GAAKG,IAAkB+B,IAAwBd,EAAAjB,GAAe8B,KAAO,YAC/Eb,EAAYd,EAAU,IAAI2B,KAAO,OACjCb,EAAYd,UAAYA,EACxBc,EAAYf,IAAMA,EAGd,IAAyB8B,EAA0B,GAAI3C,EAA6B,GAAIC,EAA8B,IAkLjH,SAAeS,EAAsBkB,EAA4BL,EAA6BoB,EAAyBnC,EAAMoC,EAAO5C,EAAW6C,GAIvJ,IAHA,IAEwBJ,EAFpBK,EAAgB,EAAGC,EAAMJ,EAAMnV,OAAO,EAAE,EACxCwV,EAASpB,EAAYlB,GAAWjR,KAChClC,EAAI,EAAG0V,EAAU,EACf1V,EAAIyV,EAAOxV,OAAQD,GAAI,IAAK,CAC7B,IAAAoR,EAAyBqE,EAAO5S,MAAM7C,EAAGA,EAAE,KAC/CqR,GAAUD,EAAM,IACNsE,EAAAtE,EAAKG,WAAW,GAC1B2D,EAAOS,GAAUvE,EAAK,EAAEsE,EAAQF,GAChCJ,EAAMR,KAAKM,GACX,IAAI1V,EAAkB,CACrB0V,OACA5M,KAAO8I,EAAKG,WAAW,GACvBqE,MAAOxE,EAAKG,WAAW,GACvBlB,EAAOe,EAAKG,WAAW,EAAG,KAC1BsE,EAAOzE,EAAKG,WAAW,EAAG,KAC1BnB,EAAOgB,EAAKG,WAAW,EAAG,KAC1BuE,MAAO1E,EAAKG,WAAW,IACvBwE,MAAO3E,EAAKG,WAAW,EAAG,KAC1ByE,MAAO,EACPC,KAAM,GAGM,IADU7E,EAAKG,WAAW,GAAKH,EAAKG,WAAW,GAAKH,EAAKG,WAAW,GAAKH,EAAKG,WAAW,KACpF/R,EAAA0W,GAAKC,EAAU/E,EAAMA,EAAKrE,EAAE,IAEjC,IADUqE,EAAKG,WAAW,GAAKH,EAAKG,WAAW,GAAKH,EAAKG,WAAW,GAAKH,EAAKG,WAAW,KACpF/R,EAAAqS,GAAKsE,EAAU/E,EAAMA,EAAKrE,EAAE,IAC9CvN,EAAEwW,MAAQ5E,EAAKG,WAAW,EAAG,KAC7B/R,EAAEyW,KAAO7E,EAAKG,WAAW,EAAG,KACzB/R,EAAEyW,KAAO,GAAKzW,EAAEwW,MAAQ,IAAOxW,EAAAyW,KAAOzW,EAAE8I,KAAO,EAAG9I,EAAEwW,MAAQb,EAAY3V,EAAE0V,KAAO,IACtE,IAAX1V,EAAE8I,MACJiN,EAAgB/V,EAAEwW,MACf/C,EAAO,GAAKsC,IAAkBJ,IAAwBd,EAAAkB,GAAeL,KAAO,gBAEtE1V,EAAEyW,MAAQ,MACnBzW,EAAE4W,QAAU,WACgB,IAAzB/B,EAAY7U,EAAEwW,WAAkCxW,EAAEwW,OAASK,EAAgBrC,EAASxU,EAAEwW,MAAO3B,EAAYd,UAAWc,EAAYf,MACnIe,EAAY7U,EAAEwW,OAAOd,KAAO1V,EAAE0V,KAC5B1V,EAAA8W,QAAWjC,EAAY7U,EAAEwW,OAAO9T,KAAKW,MAAM,EAAErD,EAAEyW,QAEjDzW,EAAE4W,QAAU,UACT5W,EAAEyW,KAAO,EAAGzW,EAAEyW,KAAO,EAChBV,IAAkBJ,GAAc3V,EAAEwW,QAAUb,GAAcd,EAAYkB,KAC7E/V,EAAE8W,QAAUC,EAAe/W,EAAG6U,EAAYkB,GAAerT,MAAOmS,EAAYiB,IAAO,CAAA,GAAIpT,QAGtF1C,EAAE8W,SAAmBjF,GAAA7R,EAAE8W,QAAS,GACnCjB,EAAMH,GAAQ1V,EACdiT,EAAUmC,KAAKpV,EACjB,CACA,CAlOAgX,CAAerD,EAAWkB,EAAaL,EAASoB,EAAOnC,EAD9B,CAAE,EACyCR,EAAWW,GA6DtE,SAAiBqD,EAAqBC,EAAsBtB,GAI9DpV,IAHFA,IAAAA,EAAI,EAAGqQ,EAAI,EAAGwF,EAAI,EAAGzF,EAAI,EAAGtH,EAAI,EAAG0M,EAAKJ,EAAMnV,OAC9C0W,EAAwB,GAAIxR,EAAsB,GAEhDnF,EAAIwV,IAAMxV,EAAK2W,EAAI3W,GAAGmF,EAAEnF,GAAGA,EAAMA,EAAAA,GAAGoV,EAAMpV,GAEhD,KAAM8I,EAAI3D,EAAElF,SAAU6I,EAEjBuH,EAAAoG,EADJzW,EAAImF,EAAE2D,IACIuH,EAAOwF,EAAAY,EAAGzW,GAAG6V,EAAOzF,EAAAqG,EAAGzW,GAAGoQ,EACjCuG,EAAI3W,KAAOA,KACe,IAAzBqQ,GAAyBsG,EAAItG,KAAOA,IAAOrQ,EAAAA,GAAK2W,EAAItG,KACxC,IAAZwF,GAAYc,EAAId,KAAOA,IAAO7V,EAAAA,GAAK2W,EAAId,MAElC,IAANzF,IAA2BuG,EAAAvG,GAAKpQ,IAC1B,IAANqQ,GAAYrQ,GAAK2W,EAAI3W,KAAU2W,EAAAtG,GAAKsG,EAAI3W,GAAOmF,EAAEiH,YAAYiE,GAAKvH,GAAG3D,EAAEyP,KAAKvE,KACtE,IAANwF,GAAY7V,GAAK2W,EAAI3W,KAAU2W,EAAAd,GAAKc,EAAI3W,GAAOmF,EAAEiH,YAAYyJ,GAAK/M,GAAG3D,EAAEyP,KAAKiB,IAE5E7V,IAAAA,EAAE,EAAGA,EAAIwV,IAAMxV,EAAM2W,EAAI3W,KAAOA,KACP,IAAzB6V,GAAyBc,EAAId,KAAOA,EAAO7V,EAAAA,GAAK2W,EAAId,IACnC,IAAZxF,GAAYsG,EAAItG,KAAOA,IAAOrQ,EAAAA,GAAK2W,EAAItG,KAGhD,IAAIrQ,EAAE,EAAGA,EAAIwV,IAAMxV,EAClB,GAAkB,IAAfyW,EAAGzW,GAAGsI,KAAT,CAEA,IADItI,EAAAA,IACI2W,EAAI7N,GAAO,GAClBA,EAAI6N,EAAI7N,GACR4N,EAAG1W,GAAK0W,EAAG5N,GAAK,IAAM4N,EAAG1W,SACX,IAAN8I,IAAW,IAAO6N,EAAI7N,IAAMA,GAAK6N,EAAI7N,IAC9C6N,EAAI3W,IAAK,CAN0B,CAUpC,IADA0W,EAAG,IAAM,IACL1W,EAAE,EAAGA,EAAIwV,IAAMxV,EACA,IAAfyW,EAAGzW,GAAGsI,OAAyBoO,EAAG1W,IAAM,IAE7C,CA/FiB4W,CAAAnE,EAAWC,EAAW0C,GACvCA,EAAMvB,QAEN,IAAIrU,EAAI,CACPiT,YACAC,aAKM,OADJT,GAAWA,EAAQ4E,QAAOA,IAAM,CAACjD,SAAgBI,YAC7CxU,CACP,CAsFS,SAAA+W,EAAeO,EAAoBC,EAAsBzB,GAKjE,IAJA,IAAIU,EAAQc,EAAMd,MAAOC,EAAOa,EAAMb,KAElCzW,EAAI,GACJyJ,EAAM+M,EACJV,GAAQW,EAAO,GAAKhN,GAAO,GAC9BzJ,EAAAoV,KAAKmC,EAAQlU,MAAMoG,EAAM+N,EAAM/N,EAAM+N,EAAOA,IACtCf,GAAAe,EACF/N,EAAA6L,GAAcQ,EAAY,EAANrM,GAE3B,OAAgB,IAAbzJ,EAAES,OAAsBgX,GAAQ,GAC3B3U,EAAQ9C,GAAGqD,MAAM,EAAGiU,EAAMb,KACnC,CAIA,SAAS7B,EAAWnL,EAAgBiO,EAAgBlD,EAA6BV,EAAgBC,GAChG,IAAIpO,EAAegQ,EACnB,GAAGlM,IAAQkM,GACV,GAAW,IAAR+B,EAAiB,MAAA,IAAI9O,MAAM,0CAChC,IAAoC,IAAzBa,EAAyB,CAClC,IAAIwM,EAASzB,EAAQ/K,GAAMlD,GAAKuN,IAAM,GAAG,EACzC,IAAImC,EAAQ,OACZ,IAAA,IAAQzV,EAAI,EAAGA,EAAI+F,IACdZ,EAAI2P,GAAcW,EAAS,EAAFzV,MAAUmV,IADhBnV,EAEvBuT,EAAUqB,KAAKzP,GAELiP,EAAAU,GAAcW,EAAOnC,EAAI,GAAG4D,EAAM,EAAGlD,EAASV,EAAKC,EAChE,CACA,CAGA,SAAS8C,EAAgBrC,EAA6BgC,EAAkBzC,EAA6BD,EAAgBiB,GACpH,IAAIvT,EAAwB,GAAIwT,EAA2B,GACvDD,IAAMA,EAAO,IACjB,IAAIE,EAAUnB,EAAM,EAAGxK,EAAI,EAAG8E,EAAK,EAC/B,IAAA9E,EAAEkN,EAAOlN,GAAG,GAAI,CACnByL,EAAKzL,IAAK,EACN9H,EAAAA,EAAIf,QAAU6I,EACR0L,EAAAI,KAAKZ,EAAQlL,IACvB,IAAI+L,EAAOtB,EAAU7P,KAAKwB,MAAQ,EAAF4D,EAAIwK,IAEjC,GAAAA,EAAM,GADT1F,EAAS,EAAF9E,EAAO2L,GACG,MAAM,IAAIrM,MAAM,yBAA2BU,EAAI,MAAMwK,GACnE,IAACU,EAAQa,GAAO,MACnB/L,EAAIgM,GAAcd,EAAQa,GAAOjH,EACnC,CACQ,MAAA,CAACmH,MAAO/T,EAAKkB,KAAK8S,GAAW,CAACR,IACtC,CAkFS,SAAA2B,EAAU/E,EAA0B+F,GAC5C,OAAO,IAAI9Q,KAA6G,KAAnG+Q,GAAehG,EAAK+F,EAAO,GAAG,IAAKzT,KAAKC,IAAI,EAAE,IAAIyT,GAAehG,EAAK+F,GAAQ,IAAQ,aAC5G,CAoBS,SAAAxE,EAAS0E,EAAsBhS,GACvC,IAAI7F,EAAI6F,GAAQ,CAAA,EAAI8M,EAAO3S,EAAE2S,MAAQ,aAGlC,GAFCkF,EAAI3E,YAAW2E,EAAI3E,UAAY,IAC/B2E,EAAI5E,YAAW4E,EAAI5E,UAAY,IAChC4E,EAAI3E,UAAUzS,SAAWoX,EAAI5E,UAAUxS,OAAQ,MAAM,IAAImI,MAAM,8BACtC,IAAzBiP,EAAI3E,UAAUzS,SACZoX,EAAA3E,UAAU,GAAKP,EAAO,IAC1BkF,EAAI5E,UAAU,GAAM,CAAEyC,KAAM/C,EAAM7J,KAAM,IAEtC9I,EAAE8X,QAAOD,EAAI5E,UAAU,GAAGqD,MAAQtW,EAAE8X,OAGxC,SAAkBD,GACjB,IAAIE,EAAK,WACT,GAAGjH,GAAIkH,KAAKH,EAAK,IAAME,GAAK,OACxB,IAAA7G,EAAIuG,GAAQ,GAAIvG,EAAE,GAAK,GAAIA,EAAE,GAAKA,EAAE,GAAK,GAAIA,EAAE,GAAK,GACxD2G,EAAI5E,UAAUmC,KAAM,CAAEM,KAAMqC,EAAIjP,KAAM,EAAGgO,QAAQ5F,EAAGuF,KAAK,EAAG5F,EAAE,GAAIwF,EAAE,GAAIzF,EAAE,KAC1EiH,EAAI3E,UAAUkC,KAAKyC,EAAI3E,UAAU,GAAK6E,GACtCE,EAAYJ,EACb,CATCK,CAASL,EACV,CASS,SAAAI,EAAYJ,EAAsBzK,GAC1C+F,EAAS0E,GAEDrX,IADJ,IAAA2X,GAAK,EAAOhW,GAAI,EACZ3B,EAAIqX,EAAI3E,UAAUzS,OAAS,EAAGD,GAAK,IAAKA,EAAG,CAC9C,IAAA4X,EAAQP,EAAI5E,UAAUzS,GAC1B,OAAO4X,EAAMtP,MACZ,KAAK,EACD3G,EAAQgW,GAAA,GACJN,EAAI5E,UAAUoF,MAAOR,EAAI3E,UAAUmF,OAC1C,MACD,KAAK,EAAG,KAAK,EAAG,KAAK,EAChBlW,GAAA,EACDxB,MAAMyX,EAAM/B,EAAI+B,EAAMvH,EAAIuH,EAAMxH,KAASuH,GAAA,GACzCC,EAAM/B,GAAI,GAAM+B,EAAMvH,MAAUuH,EAAM/B,GAAK+B,EAAMvH,IAAQsH,GAAA,GAC5D,MACD,QAAcA,GAAA,EAEjB,CACI,GAACA,GAAO/K,EAAR,CAEH,IAAIkL,EAAM,IAAIzR,KAAK,KAAM,EAAG,IAAKyC,EAAI,EAEjCiP,EAAYC,OAAOC,cAAgBA,OAAO,MAAQ,CAAE,EACpD/V,EAAqC,GACzC,IAAIlC,EAAI,EAAGA,EAAIqX,EAAI3E,UAAUzS,SAAUD,EACtC+X,EAAUV,EAAI3E,UAAU1S,KAAM,EACD,IAA1BqX,EAAI5E,UAAUzS,GAAGsI,MACfpG,EAAA0S,KAAK,CAACyC,EAAI3E,UAAU1S,GAAIqX,EAAI5E,UAAUzS,KAE5C,IAAIA,EAAI,EAAGA,EAAIkC,EAAKjC,SAAUD,EAAG,CAChC,IAAI2W,EAAMlG,EAAQvO,EAAKlC,GAAG,KAC1B2B,EAAIoW,EAAUpB,MAERzU,EAAA0S,KAAK,CAAC+B,EAAM,CAChBzB,KAAMvE,EAASgG,GAAKrW,QAAQ,IAAI,IAChCgI,KAAM,EACNwN,MAAOoC,EACPhC,GAAI4B,EAAKjG,GAAIiG,EACbxB,QAAS,QAGVyB,EAAUpB,IAAO,EAEpB,CAIC,IAFKzU,EAAAiW,MAAK,SAASlZ,EAAE6G,GAAK,OAvelB,SAAQiH,EAAcnC,GAE9B,IADI,IAAAyF,EAAItD,EAAEnL,MAAM,KAAMiU,EAAIjL,EAAEhJ,MAAM,KAC1B5B,EAAI,EAAGoC,EAAI,EAAGgW,EAAI1U,KAAKgI,IAAI2E,EAAEpQ,OAAQ4V,EAAE5V,QAASD,EAAIoY,IAAKpY,EAAG,CAC/D,GAAAoC,EAAIiO,EAAErQ,GAAGC,OAAS4V,EAAE7V,GAAGC,OAAgB,OAAAmC,EAC3C,GAAGiO,EAAErQ,IAAM6V,EAAE7V,GAAW,OAAAqQ,EAAErQ,GAAK6V,EAAE7V,IAAU,EAAA,CAC7C,CACQ,OAAAqQ,EAAEpQ,OAAS4V,EAAE5V,MACrB,CAgekCoY,CAAQpZ,EAAE,GAAI6G,EAAE,GAAI,IACrDuR,EAAI3E,UAAY,GAAI2E,EAAI5E,UAAY,GAChCzS,EAAI,EAAGA,EAAIkC,EAAKjC,SAAUD,EAAKqX,EAAI3E,UAAU1S,GAAKkC,EAAKlC,GAAG,GAAIqX,EAAI5E,UAAUzS,GAAKkC,EAAKlC,GAAG,GAC7F,IAAIA,EAAI,EAAGA,EAAIkC,EAAKjC,SAAUD,EAAG,CAC5B,IAAAsY,EAAMjB,EAAI5E,UAAUzS,GACpBuX,EAAKF,EAAI3E,UAAU1S,GAOvB,GALAsY,EAAIpD,KAAQvE,EAAS4G,GAAIjX,QAAQ,IAAI,IACrCgY,EAAIjI,EAAIiI,EAAIzC,EAAIyC,EAAIlI,IAAMkI,EAAI1C,MAAQ,GACtC0C,EAAIrC,KAAOqC,EAAIhC,QAAUgC,EAAIhC,QAAQrW,OAAS,EAC9CqY,EAAItC,MAAQ,EACRsC,EAAAxC,MAASwC,EAAIxC,OAASoC,EACjB,IAANlY,EACFsY,EAAIlI,EAAIlO,EAAKjC,OAAS,EAAI,GAAI,EAC9BqY,EAAIrC,KAAO,EACXqC,EAAIhQ,KAAO,OACF,GAAgB,KAAhBiP,EAAG1U,OAAM,GAAY,CAC9B,IAAIiG,EAAE9I,EAAE,EAAE8I,EAAI5G,EAAKjC,QAAgBwQ,EAAQ4G,EAAI3E,UAAU5J,KAAKyO,IAAjCzO,GAE7B,IADAwP,EAAIlI,EAAItH,GAAK5G,EAAKjC,QAAc,EAAA6I,EAC5BA,EAAE9I,EAAE,EAAE8I,EAAI5G,EAAKjC,QAAgBwQ,EAAQ4G,EAAI3E,UAAU5J,KAAK2H,EAAQ8G,KAAzCzO,GAC7BwP,EAAIzC,EAAI/M,GAAK5G,EAAKjC,QAAc,EAAA6I,EAChCwP,EAAIhQ,KAAO,CACd,MACMmI,EAAQ4G,EAAI3E,UAAU1S,EAAE,IAAI,KAAOyQ,EAAQ8G,KAAKe,EAAIzC,EAAI7V,EAAI,GAC/DsY,EAAIhQ,KAAO,CAEd,CArDe,CAuDf,CAES,SAAAiQ,EAAOlB,EAAsBpF,GACjC,IAAAuG,EAAQvG,GAAW,CAAE,EAEzB,GAAqB,OAAlBuG,EAAMC,SAA0B,OAkiC3B,SAAUpB,EAAsBpF,GAcxC,IAbI,IAAA5M,EAAO4M,GAAW,CAAE,EACpBO,EAAWnN,EAAKmN,UAAY,UAG5B7M,EAAM,CACT,oBACA,+CAJD6M,EAAW,UAAYA,GAImC3P,MAAM,GAAK,IACpE,GACA,GACA,IAGGsP,EAAOkF,EAAI3E,UAAU,GAAIgG,EAAKvG,EAAMwG,EAAKtB,EAAI5E,UAAU,GACnDzS,EAAI,EAAGA,EAAIqX,EAAI3E,UAAUzS,SAAUD,EAG1C,GAFA0Y,EAAKrB,EAAI3E,UAAU1S,GAAG6C,MAAMsP,EAAKlS,SAC5B0Y,EAAAtB,EAAI5E,UAAUzS,IACZiW,MAAS0C,EAAGrC,SAAiB,YAANoC,EAA9B,CAGAA,EAAKA,EAAGpY,QAAQ,0CAA0C,SAAS8B,GAClE,MAAO,KAAOA,EAAElC,WAAW,GAAGgI,SAAS,IAAM,GAC7C,IAAE5H,QAAQ,oBAAoB,SAASuF,GACvC,MAAO,KAAOA,EAAE3F,WAAW,GAAGgI,SAAS,IAAM,GAChD,IASE,IANA,IAAI0Q,EAAKD,EAAGrC,QAERuC,EAAOtY,GAAWC,OAAOiC,SAASmW,GAAMA,EAAG1Q,SAAS,UAAYjG,EAAI2W,GAGpEE,EAAU,EAAGzI,EAAI3M,KAAKgI,IAAI,KAAMmN,EAAK5Y,QAAS+J,EAAK,EAC/C+O,EAAM,EAAGA,GAAO1I,IAAK0I,GAAS/O,EAAG6O,EAAK3Y,WAAW6Y,KAAS,IAAQ/O,EAAK,OAAQ8O,EACnF,IAAAE,EAAKF,GAAe,EAAJzI,EAAQ,EAE5B1K,EAAIiP,KAAKpC,GACT7M,EAAIiP,KAAK,sBAAwBvP,EAAK8M,MAAQ,uBAAyBuG,GACvE/S,EAAIiP,KAAK,+BAAiCoE,EAAK,mBAAqB,WACpErT,EAAIiP,KAAK,iBAAmBqE,GAAiBN,EAAID,IACjD/S,EAAIiP,KAAK,IAETjP,EAAIiP,KAAKoE,EAAKE,GAAuBL,GAAQM,GAAgBN,GAzBR,CA4B/C,OADHlT,EAAAiP,KAAKpC,EAAW,UACb7M,EAAItD,KAAK,OACjB,CAhlCoC+W,CAAU/B,EAAKmB,GAElD,GADAf,EAAYJ,GAEN,QADCmB,EAAMC,SACOY,OAuxBZA,SAAUhC,EAAsBpF,GACpC,IAAAuG,EAAQvG,GAAW,CAAE,EACrBtM,EAAM,GAAI2T,EAAQ,GAClB9Z,EAAeyX,GAAQ,GACvBsC,EAAUf,EAAMgB,YAAc,EAAI,EAAIlI,EAAQ,EAG9CtR,EAAI,EAAG8I,EAAI,EAEX2Q,EAAW,EAAG5G,EAAO,EACrBV,EAAOkF,EAAI3E,UAAU,GAAIgG,EAAKvG,EAAMwG,EAAKtB,EAAI5E,UAAU,GACvDiH,EAAO,GACPC,EAAQ,EAEZ,IAAI3Z,EAAI,EAAGA,EAAIqX,EAAI3E,UAAUzS,SAAUD,EAEtC,GADA0Y,EAAKrB,EAAI3E,UAAU1S,GAAG6C,MAAMsP,EAAKlS,SAAc0Y,EAAAtB,EAAI5E,UAAUzS,IACtDiW,MAAS0C,EAAGrC,SAAiB,YAANoC,EAA9B,CACA,IAAI1C,EAAQyD,EAGRG,EAAU3C,GAAQyB,EAAGzY,QACzB,IAAI6I,EAAI,EAAGA,EAAI4P,EAAGzY,SAAU6I,EAAW8Q,EAAA3I,YAAY,EAAsB,IAAnByH,EAAGxY,WAAW4I,IACpE8Q,EAAUA,EAAQ/W,MAAM,EAAG+W,EAAQ7M,GAC9B2M,EAAA7G,GAAQnE,GAAM1N,IAAY2X,EAAGrC,QAAyB,GAE3D,IAAIuD,EAASlB,EAAGrC,QACH,GAAViD,IAAsBM,EAAAC,EAAgBD,KAGzCra,EAAIyX,GAAQ,KACVhG,YAAY,EAAG,UACfzR,EAAAyR,YAAY,EAAG,IACfzR,EAAAyR,YAAY,EAAGK,GACf9R,EAAAyR,YAAY,EAAGsI,GAEdZ,EAAG9G,GAAmBjB,EAAApR,EAAGmZ,EAAG9G,IAC1BrS,EAAEyR,YAAY,EAAG,GACtBzR,EAAEyR,aAAY,EAAsByI,EAAK7G,IACvCrT,EAAAyR,YAAY,EAAsB4I,EAAO5Z,QACzCT,EAAAyR,YAAY,EAA6B0H,EAAGrC,QAAmBrW,QAC/DT,EAAAyR,YAAY,EAAG2I,EAAQ3Z,QACvBT,EAAAyR,YAAY,EAAG,GAEjBwI,GAAYja,EAAES,OACd0F,EAAIiP,KAAKpV,GACTia,GAAYG,EAAQ3Z,OACpB0F,EAAIiP,KAAKgF,GAMTH,GAAYI,EAAO5Z,OACnB0F,EAAIiP,KAAKiF,IAaTra,EAAIyX,GAAQ,KACVhG,YAAY,EAAG,UACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,IACfzR,EAAAyR,YAAY,EAAGK,GACf9R,EAAAyR,YAAY,EAAGsI,GACf/Z,EAAAyR,YAAY,EAAG,GACjBzR,EAAEyR,aAAY,EAAIyI,EAAK7G,IAErBrT,EAAAyR,YAAY,EAAG4I,EAAO5Z,QACtBT,EAAAyR,YAAY,EAAU0H,EAAGrC,QAAmBrW,QAC5CT,EAAAyR,YAAY,EAAG2I,EAAQ3Z,QACvBT,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG+E,GAEjB2D,GAASna,EAAEuN,EACXuM,EAAM1E,KAAKpV,GACXma,GAASC,EAAQ3Z,OACjBqZ,EAAM1E,KAAKgF,KACT/G,CAzEmD,CAuF/C,OAVPrT,EAAIyX,GAAQ,IACVzX,EAAAyR,YAAY,EAAG,WACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG4B,GACfrT,EAAAyR,YAAY,EAAG4B,GACfrT,EAAAyR,YAAY,EAAG0I,GACfna,EAAAyR,YAAY,EAAGwI,GACfja,EAAAyR,YAAY,EAAG,GAEV3O,EAAS,CAACA,EAASqD,GAAerD,EAAQgX,GAAQ9Z,GAC1D,CA/3BqB6Z,CAAUhC,EAAKmB,GAG/B,IAAAnI,EAAK,SAASgH,GAEjB,IADI,IAAA0C,EAAY,EAAGC,EAAW,EACtBha,EAAI,EAAGA,EAAIqX,EAAI5E,UAAUxS,SAAUD,EAAG,CACzCgS,IAAAA,EAAOqF,EAAI5E,UAAUzS,GACtB,GAACgS,EAAKsE,QAAN,CAECjJ,IAAAA,EAAO2E,EAAKsE,QAAQrW,OACrBoN,EAAO,IACNA,EAAO,KAAsBA,GAAAA,EAAO,IAAS,EAC3C2M,GAAa3M,EAAO,KAAW,EALnB,CAOrB,CAOE,IANA,IAAI0G,EAAWsD,EAAI3E,UAAUzS,OAAQ,GAAM,EAEvCga,EAAYF,EAAY,KAAS,EACjCG,GAFYH,EAAY,GAAM,GAERC,EAAWjG,EAAUkG,EAC3CE,EAAWD,EAAW,KAAS,EAC/BE,EAAYD,GAAW,IAAM,EAAIzW,KAAKwQ,MAAMiG,EAAQ,KAAK,KACrDD,EAAWC,EAAUC,EAAY,KAAS,EAAKD,GAASC,IAAcD,GAAW,IAAM,EAAIzW,KAAKwQ,MAAMiG,EAAQ,KAAK,KACvH9J,IAAAA,EAAK,CAAC,EAAG+J,EAAWD,EAASF,EAAUlG,EAASiG,EAAUD,EAAW,GAGlE1J,OAFPgH,EAAI5E,UAAU,GAAGwD,KAAO8D,GAAa,EACrC1J,EAAE,IAAMgH,EAAI5E,UAAU,GAAGuD,MAAM3F,EAAE,GAAGA,EAAE,GAAGA,EAAE,GAAGA,EAAE,GAAGA,EAAE,GAAGA,EAAE,KAAMA,EAAE,GAAG,GAAM,GACpEA,CACP,CAvBQ,CAuBNgH,GACC7X,EAAIyX,GAAQ5G,EAAE,IAAM,GACpBrQ,EAAI,EAAG4F,EAAI,EAEV5F,IAAAA,EAAI,EAAGA,EAAI,IAAKA,EAAGR,EAAEyR,YAAY,EAAGoJ,EAAWra,IAC/CA,IAAAA,EAAI,EAAGA,EAAI,IAAKA,EAAGR,EAAEyR,YAAY,EAAG,GAMpCjR,IALFR,EAAAyR,YAAY,EAAG,IACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,OACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACbjR,EAAI,EAAGA,EAAI,IAAKA,EAAGR,EAAEyR,YAAY,EAAG,GAUxC,IATEzR,EAAAyR,YAAY,EAAG,GACjBzR,EAAEyR,YAAY,EAAGZ,EAAE,IACnB7Q,EAAEyR,YAAY,EAAGZ,EAAE,GAAKA,EAAE,GAAKA,EAAE,GAAKA,EAAE,GAAK,GAC3C7Q,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,MACjBzR,EAAEyR,YAAY,EAAGZ,EAAE,GAAKA,EAAE,GAAKA,EAAE,GAAKA,EAAE,GAAK,EAAG8E,GAChD3V,EAAEyR,YAAY,EAAGZ,EAAE,IACjB7Q,EAAAyR,eAAgBZ,EAAE,GAAKA,EAAE,GAAK,EAAG8E,GACnC3V,EAAEyR,YAAY,EAAGZ,EAAE,IACfrQ,EAAI,EAAGA,EAAI,MAAOA,EAAKR,EAAAyR,aAAgBjR,EAAAA,EAAIqQ,EAAE,GAAKA,EAAE,GAAKrQ,GAAM,GAEjE,GAAAqQ,EAAE,GACJ,IAAIzK,EAAI,EAAGA,EAAIyK,EAAE,KAAMzK,EAAG,CACzB,KAAM5F,EAAI,IAAU,IAAJ4F,IAAW5F,EAAKR,EAAAyR,aAAgBjR,EAAAA,EAAIqQ,EAAE,GAAKA,EAAE,GAAKrQ,GAAM,GACtER,EAAAyR,eAAgBrL,IAAMyK,EAAE,GAAK,EAAI8E,EAAavP,EAAI,EACvD,CAEK,IAAA0U,EAAU,SAAS7S,GAClB,IAAA7B,GAAK6B,EAAGzH,EAAE4F,EAAE,IAAK5F,EAAKR,EAAAyR,aAAgBjR,EAAAA,EAAE,GACzCyH,MAAOzH,EAAKR,EAAAyR,eAAgBkE,GAC/B,EAED,IADAvP,EAAI5F,EAAI,EACJ4F,GAAGyK,EAAE,GAAIrQ,EAAE4F,IAAK5F,EAAKR,EAAAyR,aAAgB,EAAAsJ,EAAOC,SAChD,IAAI5U,GAAGyK,EAAE,GAAIrQ,EAAE4F,IAAK5F,EAAKR,EAAAyR,aAAgB,EAAAsJ,EAAOE,SACxCH,EAAAjK,EAAE,IACFiK,EAAAjK,EAAE,IAGV,IAFI,IAAAvH,EAAe,EAAGuE,EAAkB,EACpC2E,EAAoBqF,EAAI5E,UAAU,GAChC3J,EAAIuO,EAAI5E,UAAUxS,SAAU6I,GAC1BkJ,EAAAqF,EAAI5E,UAAU3J,IACZwN,WAETjJ,EAAO2E,EAAKsE,QAAQrW,QACV,OACV+R,EAAKgE,MAAQpQ,EACJ0U,EAAAjN,EAAO,KAAW,KAG5B,IADAiN,EAASjK,EAAE,GAAK,GAAM,GACV,IAAN7Q,EAAEuN,KAAakE,aAAY,EAAIsJ,EAAOpF,YAE5C,IADAvP,EAAI5F,EAAI,EACJ8I,EAAI,EAAGA,EAAIuO,EAAI5E,UAAUxS,SAAU6I,GAC/BkJ,EAAAqF,EAAI5E,UAAU3J,IACZwN,YAETjJ,EAAO2E,EAAKsE,QAAQrW,SACRoN,GAAQ,OACpB2E,EAAKgE,MAAQpQ,EACJ0U,EAAAjN,EAAO,IAAS,KAE1B,KAAY,IAAN7N,EAAEuN,KAAakE,aAAY,EAAIsJ,EAAOpF,YACxCnV,IAAAA,EAAI,EAAGA,EAAIqQ,EAAE,IAAI,IAAKrQ,EAAG,CACxB,IAAAuX,EAAKF,EAAI3E,UAAU1S,GACvB,GAAIuX,GAAoB,IAAdA,EAAGtX,OAAb,CAMO+R,EAAAqF,EAAI5E,UAAUzS,GACZ,IAANA,IAAcgS,EAAAgE,MAAQhE,EAAKiE,KAAOjE,EAAKgE,MAAQ,EAAIb,GACtD,IAAIuF,EAAwB,IAAN1a,GAAWwY,EAAMrG,MAASH,EAAKkD,KASrD,GARO7H,EAAA,GAAGqN,EAAIza,OAAO,GACnBT,EAAAyR,YAAY,GAAIyJ,EAAK,WACrBlb,EAAAyR,YAAY,EAAG5D,GACf7N,EAAAyR,YAAY,EAAGe,EAAK1J,MACpB9I,EAAAyR,YAAY,EAAGe,EAAK4D,OACpBpW,EAAAyR,aAAgB,EAAAe,EAAK3B,GACrB7Q,EAAAyR,aAAgB,EAAAe,EAAK6D,GACrBrW,EAAAyR,aAAgB,EAAAe,EAAK5B,GACnB4B,EAAK8D,MACFtW,EAAAyR,YAAY,GAAIe,EAAK8D,MAAO,YADnB,IAAIhN,EAAI,EAAGA,EAAI,IAAKA,EAAKtJ,EAAAyR,YAAY,EAAG,GAExDzR,EAAEyR,YAAY,EAAGe,EAAK+D,OAAS,GAC7BvW,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GACpCzR,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GACpCzR,EAAAyR,YAAY,EAAGe,EAAKgE,OACpBxW,EAAAyR,YAAY,EAAGe,EAAKiE,MAASzW,EAAAyR,YAAY,EAAG,EAlBhD,KALE,CACK,IAAAnI,EAAI,EAAGA,EAAI,KAAMA,EAAGtJ,EAAEyR,YAAY,EAAG,GACrC,IAAAnI,EAAI,EAAGA,EAAI,IAAKA,EAAGtJ,EAAEyR,YAAY,GAAK,GACtC,IAAAnI,EAAI,EAAGA,EAAI,KAAMA,EAAGtJ,EAAEyR,YAAY,EAAG,EAE5C,CAmBA,CACC,IAAIjR,EAAI,EAAGA,EAAIqX,EAAI5E,UAAUxS,SAAUD,EAGnC,IAFIgS,EAAAqF,EAAI5E,UAAUzS,IAEbiW,MAAQ,KAEf,GADEzW,EAAAuN,EAAKiF,EAAKgE,MAAM,GAAM,EACpBzV,GAAWC,OAAOiC,SAASuP,EAAKsE,SACnCtE,EAAKsE,QAAQqE,KAAKnb,EAAGA,EAAEuN,EAAG,EAAGiF,EAAKiE,MAEhCzW,EAAAuN,GAAMiF,EAAKiE,KAAO,KAAO,QACrB,CACN,IAAInN,EAAI,EAAGA,EAAIkJ,EAAKiE,OAAQnN,EAAGtJ,EAAEyR,YAAY,EAAGe,EAAKsE,QAAQxN,IAC7D,KAAU,IAAJA,IAAaA,EAAKtJ,EAAAyR,YAAY,EAAG,EAC3C,CAGC,IAAIjR,EAAI,EAAGA,EAAIqX,EAAI5E,UAAUxS,SAAUD,EAGtC,IAFOgS,EAAAqF,EAAI5E,UAAUzS,IAEbiW,KAAO,GAAKjE,EAAKiE,KAAO,KAC/B,GAAI1V,GAAWC,OAAOiC,SAASuP,EAAKsE,SACnCtE,EAAKsE,QAAQqE,KAAKnb,EAAGA,EAAEuN,EAAG,EAAGiF,EAAKiE,MAEhCzW,EAAAuN,GAAMiF,EAAKiE,KAAO,IAAM,OACpB,CACN,IAAInN,EAAI,EAAGA,EAAIkJ,EAAKiE,OAAQnN,EAAGtJ,EAAEyR,YAAY,EAAGe,EAAKsE,QAAQxN,IAC7D,KAAU,GAAJA,IAAYA,EAAKtJ,EAAAyR,YAAY,EAAG,EAC1C,CAGC,GAAI1Q,EACHf,EAAEuN,EAAIvN,EAAES,YAGR,KAAMT,EAAEuN,EAAIvN,EAAES,QAAUT,EAAAyR,YAAY,EAAG,GAEjC,OAAAzR,CACR,CApqBAgR,EAAQ7B,QAAU,QA0rBlB,IAmDIiM,EAnDA5D,EAAO,GAGP7B,GAAa,EAEbzB,EAAmB,mBACnB2G,EAAa,CAAC,IAAM,IAAM,GAAM,IAAM,IAAM,IAAM,GAAM,KACxDnC,EAAe,mCACfqC,EAAS,CAEZM,YAAY,EACZL,SAAS,EACTC,SAAS,EACTtF,aACA2F,UAAU,EAEVpH,mBACAqH,qBAAsB,OACtBC,WAAW,EACXC,UAAU,EACV/C,eAEAgD,WAAY,CAAC,UAAU,UAAU,SAAS,YAAY,WAAW,SAUlE,SAASjZ,EAAIzC,GAEZ,IADA,IAAImG,EAAM,IAAIpE,MAAM/B,EAAES,QACdD,EAAI,EAAGA,EAAIR,EAAES,SAAUD,EAAOA,EAAAA,GAAKd,OAAOC,aAAaK,EAAEQ,IAC1D,OAAA2F,EAAItD,KAAK,GACjB,CAiCA,SAASyX,EAAgB/C,GACxB,OAAO6D,EAAQA,EAAMO,eAAepE,GAAWqE,GAASrE,EACzD,CACI,IAAAsE,EAAa,CAAE,GAAI,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,EAAG,GAAI,EAAG,GAAI,EAAG,GAAI,EAAG,GAAI,EAAG,IAG7EC,EAAS,CAAI,EAAK,EAAK,EAAK,EAAK,EAAK,EAAK,EAAI,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,KAGvJC,EAAS,CAAG,EAAI,EAAI,EAAI,EAAI,EAAI,EAAI,EAAG,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,MAAO,MAAO,OAOrJ,IAHJ,IAFgB1M,EAASxL,EAEzBmY,EAAyC,oBAAfla,WAE1Bma,EAAWD,EAAmB,IAAIla,WAAW,KAAQ,GACjD6D,EAAI,EAAGA,EAAK,MAASA,EAAYsW,EAAAtW,IALZ9B,SAAkG,MAAlGA,EAA0B,SAAnCwL,EAKqC1J,IALhB,EAAI0J,GAAG,IAAsC,QAAjBA,GAAG,EAAIA,GAAG,MAA+B,GAAOxL,GAAG,EAAIA,IAOnH,SAAAqY,EAAW7M,EAAG8M,GAClB,IAAAC,EAAMH,EAAa,IAAJ5M,GACnB,OAAG8M,GAAK,EAAUC,IAAS,EAAED,GAC7BC,EAAOA,GAAO,EAAKH,EAAU5M,GAAG,EAAG,KAChC8M,GAAK,GAAWC,IAAS,GAAGD,GAC/BC,EAAOA,GAAO,EAAKH,EAAU5M,GAAG,GAAI,QACpB,GAAG8M,EACpB,CAGS,SAAAE,EAAY7a,EAAK8a,GAAM,IAAIrU,EAAQ,EAAHqU,EAAOC,EAAKD,IAAK,EAAa,OAAA9a,EAAI+a,IAAItU,GAAK,EAAI,EAAIzG,EAAI+a,EAAE,IAAI,MAAMtU,EAAI,CAAK,CAC5G,SAAAuU,EAAYhb,EAAK8a,GAAM,IAAIrU,EAAQ,EAAHqU,EAAOC,EAAKD,IAAK,EAAa,OAAA9a,EAAI+a,IAAItU,GAAK,EAAI,EAAIzG,EAAI+a,EAAE,IAAI,MAAMtU,EAAI,CAAK,CAE5G,SAAAwU,EAAYjb,EAAK8a,GAAM,IAAIrU,EAAQ,EAAHqU,EAAOC,EAAKD,IAAK,EAAa,OAAA9a,EAAI+a,IAAItU,GAAK,EAAI,EAAIzG,EAAI+a,EAAE,IAAI,MAAMtU,EAAI,EAAK,CAC5G,SAAAyU,EAAYlb,EAAK8a,GAAM,IAAIrU,EAAQ,EAAHqU,EAAOC,EAAKD,IAAK,EAAa,OAAA9a,EAAI+a,IAAItU,GAAK,EAAI,EAAIzG,EAAI+a,EAAE,IAAI,MAAMtU,EAAI,GAAK,CAG5G,SAAA0U,EAAYnb,EAAK8a,EAAIjN,GACzB,IAAApH,EAAQ,EAAHqU,EAAOC,EAAKD,IAAK,EAAIlP,GAAM,GAAGiC,GAAG,EACtC1L,EAAInC,EAAI+a,KAAOtU,EACnB,OAAGoH,EAAI,EAAIpH,EAAUtE,EAAIyJ,GACzBzJ,GAAKnC,EAAI+a,EAAE,IAAK,EAAEtU,EACfoH,EAAI,GAAKpH,EAAUtE,EAAIyJ,GAC1BzJ,GAAKnC,EAAI+a,EAAE,IAAK,GAAGtU,EAChBoH,EAAI,GAAKpH,EAAUtE,EAAIyJ,GAC1BzJ,GAAKnC,EAAI+a,EAAE,IAAK,GAAGtU,GACRmF,GACZ,CAGS,SAAAwP,EAAapb,EAAK8a,EAAI3Y,GAAK,IAAIsE,EAAS,EAALqU,EAAQC,EAAID,IAAO,EAM9D,OALGrU,GAAK,EAAGzG,EAAI+a,KAAW,EAAJ5Y,IAAUsE,GAE3BzG,EAAA+a,IAAO5Y,GAAKsE,EAAK,IACrBzG,EAAI+a,EAAE,IAAQ,EAAF5Y,IAAS,EAAEsE,GAEjBqU,EAAK,CACb,CAES,SAAAO,EAAarb,EAAK8a,EAAI3Y,GAI9B,OAFAA,GAAO,EAAFA,KADQ,EAAL2Y,GAER9a,EAFoB8a,IAAO,IAEjB3Y,EACH2Y,EAAK,CACb,CACS,SAAAQ,EAAatb,EAAK8a,EAAI3Y,GAC9B,IAAgB4Y,EAAID,IAAO,EAI3B,OAHM3Y,IADO,EAAL2Y,EAEJ9a,EAAA+a,IAAW,IAAJ5Y,EAAiBA,KAAA,EACxBnC,EAAA+a,EAAE,GAAK5Y,EACJ2Y,EAAK,CACb,CACS,SAAAS,EAAcvb,EAAK8a,EAAI3Y,GAC/B,IAAgB4Y,EAAID,IAAO,EAK3B,OAJM3Y,IADO,EAAL2Y,EAEJ9a,EAAA+a,IAAW,IAAJ5Y,EAAiBA,KAAA,EACxBnC,EAAA+a,EAAE,GAAS,IAAJ5Y,EACPnC,EAAA+a,EAAE,GAAK5Y,IAAM,EACV2Y,EAAK,EACb,CAGS,SAAAU,EAAQb,EAAGnK,GACf,IAAAnB,EAAIsL,EAAE1b,OAAQgG,EAAI,EAAEoK,EAAImB,EAAK,EAAEnB,EAAImB,EAAK,EAAGxR,EAAI,EAChD,GAAAqQ,GAAKmB,EAAW,OAAAmK,EACnB,GAAGpb,EAAS,CACP,IAAAf,EAAIgC,EAAeyE,GAEvB,GAAG0V,EAAEhB,KAAQgB,EAAAhB,KAAKnb,QACb,KAAMQ,EAAI2b,EAAE1b,SAAUD,EAAKA,EAAAA,GAAK2b,EAAE3b,GAChC,OAAAR,CACP,IAASgc,EAAkB,CACvB,IAAAiB,EAAI,IAAInb,WAAW2E,GACvB,GAAGwW,EAAE9Z,IAAO8Z,EAAA9Z,IAAIgZ,QACX,KAAM3b,EAAIqQ,IAAKrQ,EAAKA,EAAAA,GAAK2b,EAAE3b,GACzB,OAAAyc,CACT,CAEQ,OADPd,EAAE1b,OAASgG,EACJ0V,CACR,CAGA,SAASe,EAAgB7N,GAEhB7O,IADJ,IAAAR,EAAI,IAAI+B,MAAMsN,GACV7O,EAAI,EAAGA,EAAI6O,IAAK7O,EAAGR,EAAEQ,GAAK,EAC3B,OAAAR,CACR,CAGS,SAAAmd,GAAWC,EAAOC,EAAMC,GAC5B,IAAApa,EAAS,EAAG+E,EAAI,EAAGzH,EAAI,EAAG8I,EAAI,EAAGiU,EAAQ,EAAG1M,EAAIuM,EAAM3c,OAEtD+c,EAAYxB,EAAmB,IAAIyB,YAAY,IAAMP,EAAgB,IACrE1c,IAAAA,EAAI,EAAGA,EAAI,KAAMA,EAAGgd,EAAShd,GAAK,EAElCA,IAAAA,EAAIqQ,EAAGrQ,EAAI8c,IAAO9c,EAAG4c,EAAM5c,GAAK,EACpCqQ,EAAIuM,EAAM3c,OAEV,IAAIid,EAAQ1B,EAAmB,IAAIyB,YAAY5M,GAAKqM,EAAgBrM,GAGpE,IAAIrQ,EAAI,EAAGA,EAAIqQ,IAAKrQ,EACTgd,EAAAvV,EAAImV,EAAM5c,MACjB0C,EAAS+E,IAAY/E,EAAA+E,GACxByV,EAAMld,GAAK,EAGZ,IADAgd,EAAS,GAAK,EACVhd,EAAI,EAAGA,GAAK0C,IAAU1C,EAAGgd,EAAShd,EAAE,IAAO+c,EAASA,EAAQC,EAAShd,EAAE,IAAK,EAChF,IAAIA,EAAI,EAAGA,EAAIqQ,IAAKrQ,EAEP,IADZ+c,EAAQH,EAAM5c,MACCkd,EAAMld,GAAKgd,EAASD,EAAM,OAI1C,IAAII,EAAQ,EACZ,IAAInd,EAAI,EAAGA,EAAIqQ,IAAKrQ,EAEnB,GAAY,IADZmd,EAAQP,EAAM5c,IAGT,IADJ+c,EAAQrB,EAAWwB,EAAMld,GAAI0C,IAAUA,EAAOya,EAC1CrU,GAAK,GAAIpG,EAAS,EAAIya,GAAU,EAAGrU,GAAG,IAAKA,EAC9C+T,EAAKE,EAAOjU,GAAGqU,GAAiB,GAANA,EAAand,GAAG,EAGtC,OAAA0C,CACR,CAGA,IAAI0a,GAAW5B,EAAmB,IAAIyB,YAAY,KAAOP,EAAgB,KACrEW,GAAW7B,EAAmB,IAAIyB,YAAY,IAAOP,EAAgB,IACzE,IAAIlB,EAAkB,CACb,IAAA,IAAAxb,GAAI,EAAGA,GAAI,MAAOA,GAAGod,GAASpd,IAAK,EACvC,IAAAA,GAAI,EAAGA,GAAI,KAAMA,GAAGqd,GAASrd,IAAK,CACvC,EACA,WAGC,IAFA,IAAIsd,EAA0B,GAC1Btd,EAAI,EACHA,EAAE,GAAIA,IAAKsd,EAAM1I,KAAK,GAChB+H,GAAAW,EAAOD,GAAU,IAE5B,IAAIT,EAA0B,GAE9B,IADA5c,EAAI,EACEA,GAAG,IAAKA,IAAK4c,EAAMhI,KAAK,GAC9B,KAAM5U,GAAG,IAAKA,IAAK4c,EAAMhI,KAAK,GAC9B,KAAM5U,GAAG,IAAKA,IAAK4c,EAAMhI,KAAK,GAC9B,KAAM5U,GAAG,IAAKA,IAAK4c,EAAMhI,KAAK,GACnB+H,GAAAC,EAAOQ,GAAU,IAC5B,CAbD,GAaS,IAAAG,cAGR,IAFA,IAAIC,EAAYhC,EAAmB,IAAIla,WAAW,OAAU,GACxDwH,EAAI,EAAG4L,EAAI,EACT5L,EAAIyS,EAAOtb,OAAS,IAAK6I,EACxB,KAAA4L,EAAI6G,EAAOzS,EAAE,KAAM4L,EAAa8I,EAAA9I,GAAK5L,EAE5C,KAAK4L,EAAI,QAASA,EAAG8I,EAAU9I,GAAK,GAEpC,IAAI+I,EAAYjC,EAAmB,IAAIla,WAAW,KAAS,GACvD,IAAAwH,EAAI,EAAG4L,EAAI,EAAG5L,EAAIwS,EAAOrb,OAAS,IAAK6I,EACpC,KAAA4L,EAAI4G,EAAOxS,EAAE,KAAM4L,EAAa+I,EAAA/I,GAAK5L,EAgGrC,OAAA,SAAqB5G,EAAMyD,GACjC,OAAGzD,EAAKjC,OAAS,EA9FT,SAAaiC,EAAMyD,GAErB,IADN,IAAI+X,EAAO,EACLA,EAAOxb,EAAKjC,QAAQ,CACzB,IAAIoQ,EAAI3M,KAAKgI,IAAI,MAAQxJ,EAAKjC,OAASyd,GACnC3B,EAAI2B,EAAOrN,GAAKnO,EAAKjC,OAIzB,IAHI0F,EAAAsL,YAAY,GAAI8K,GAChBpW,EAAAsL,YAAY,EAAGZ,GACnB1K,EAAIsL,YAAY,EAAU,OAALZ,GACfA,KAAM,GAAG1K,EAAIA,EAAIoH,KAAO7K,EAAKwb,IACtC,CACE,OAAO/X,EAAIoH,CACb,CAmF6B4Q,CAAazb,EAAMyD,GAhFtC,SAAiBzD,EAAMyD,GAIzB,IAHN,IAAImW,EAAK,EACL4B,EAAO,EACPE,EAAQpC,EAAmB,IAAIyB,YAAY,OAAU,GACnDS,EAAOxb,EAAKjC,QAAQ,CACrB,IAAAoQ,EAA8B3M,KAAKgI,IAAI,MAAQxJ,EAAKjC,OAASyd,GAGjE,GAAGrN,EAAI,GAAP,CAMC,IAJQ,GADHyL,EAAAM,EAAazW,EAAKmW,KAAQ4B,EAAOrN,GAAKnO,EAAKjC,YAC/B6b,GAAA,GAAU,EAALA,IAClBnW,EAAAoH,EAAK+O,EAAK,EAAK,EACfnW,EAAAsL,YAAY,EAAGZ,GACnB1K,EAAIsL,YAAY,EAAU,OAALZ,GACfA,KAAM,GAAG1K,EAAIA,EAAIoH,KAAO7K,EAAKwb,KACnC5B,EAAa,EAARnW,EAAIoH,CAEb,KATG,CAWK+O,EAAAM,EAAazW,EAAKmW,KAAQ4B,EAAOrN,GAAKnO,EAAKjC,QAAU,GAE1D,IADA,IAAI4d,EAAO,EACLxN,KAAM,GAAG,CACV,IAAAjN,EAAIlB,EAAKwb,GAGTxU,KAAY4U,EAAO,EAEnB,IAAA5U,EAAQ0U,EAJHC,EAAkB,OAAlBA,GAAQ,EAAKza,QAKrB8F,IAAgB,MAAPwU,GACEA,IAAexU,GAAA,OACvBA,EAAQwU,GAAY,KAAAxb,EAAKgH,EAAQ4U,IAAS5b,EAAKwb,EAAOI,IAASA,EAAO,OAAOA,EAGjF,GAAGA,EAAO,EAAG,EAEZ1a,EAAIqa,EAAUK,KACN,GAAIhC,EAAKQ,EAAa3W,EAAKmW,EAAIL,EAASrY,EAAE,IAAI,GAAK,GAE7CkZ,EAAA3W,EAAKmW,EAAI,GAEtBQ,EAAa3W,EADPmW,GAAA,EACgBL,EAASrY,EAAE,KAAK,GAChC0Y,GAAA,GAEP,IAAIiC,EAAU3a,EAAI,EAAK,EAAMA,EAAI,GAAI,EAClC2a,EAAS,IACXxB,EAAc5W,EAAKmW,EAAIgC,EAAOxC,EAAOlY,IAC/B0Y,GAAAiC,GAGH3a,EAAAoa,EAAUE,EAAOxU,GACrB4S,EAAKQ,EAAa3W,EAAKmW,EAAIL,EAASrY,IAAI,GAClC0Y,GAAA,EAEN,IAAIkC,EAAS5a,EAAI,EAAI,EAAKA,EAAE,GAAI,EAC7B4a,EAAS,IACXzB,EAAc5W,EAAKmW,EAAI4B,EAAOxU,EAAQqS,EAAOnY,IACvC0Y,GAAAkC,GAEP,IAAA,IAAQ7Y,EAAI,EAAGA,EAAI2Y,IAAQ3Y,EACpByY,EAAAC,GAAe,MAAPH,EACdG,EAAoC,OAA3BA,GAAQ,EAAK3b,EAAKwb,MACzBA,EAEHrN,GAAIyN,EAAO,CAChB,MAEQ1a,GAAK,IAAKA,GAAQ,GACX0Y,EAAAO,EAAa1W,EAAKmW,EAAI,GAChCA,EAAKQ,EAAa3W,EAAKmW,EAAIL,EAASrY,IAC9Bwa,EAAAC,GAAe,MAAPH,IACZA,CAEP,CAEG5B,EAAKQ,EAAa3W,EAAKmW,EAAI,GAAK,CAzDnC,CA0DA,CAEE,OADInW,EAAAoH,GAAM+O,EAAK,GAAG,EAAG,EACdnW,EAAIoH,CACb,CAGSkR,CAAiB/b,EAAMyD,EAC9B,CACF,IAEA,SAASyV,GAASlZ,GACb,IAAAlB,EAAMiW,GAAQ,GAAGvT,KAAKwB,MAAkB,IAAZhD,EAAKjC,SACjCie,EAAMX,GAAYrb,EAAMlB,GACrB,OAAAA,EAAI6B,MAAM,EAAGqb,EACrB,CAGA,IAAIC,GAAW3C,EAAmB,IAAIyB,YAAY,OAASP,EAAgB,OACvE0B,GAAW5C,EAAmB,IAAIyB,YAAY,OAASP,EAAgB,OACvE2B,GAAW7C,EAAmB,IAAIyB,YAAY,KAASP,EAAgB,KACvE4B,GAAY,EAAGC,GAAY,EAGtB,SAAAC,GAAItc,EAAMwb,GAElB,IAAIe,EAAQxC,EAAY/Z,EAAMwb,GAAQ,IAClCgB,EAASzC,EAAY/Z,EAD0Bwb,GAAA,GACZ,EACnCiB,EAvQI,SAAY3d,EAAK8a,GAAM,IAAIrU,EAAQ,EAAHqU,EAAOC,EAAKD,IAAK,EAAa,OAAA9a,EAAI+a,IAAItU,GAAK,EAAI,EAAIzG,EAAI+a,EAAE,IAAI,MAAMtU,EAAI,EAAK,CAuQvGmX,CAAY1c,EADyBwb,GAAA,GACX,EAAWA,GAAA,EAUlD,IATA,IAAIjW,EAAI,EAGJmV,EAAQpB,EAAmB,IAAIla,WAAW,IAAMob,EAAgB,IAChEQ,EAAQ,CAAE,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GAChExa,EAAS,EACTsa,EAAYxB,EAAmB,IAAIla,WAAW,GAAKob,EAAgB,GACnEmC,EAAYrD,EAAmB,IAAIla,WAAW,GAAKob,EAAgB,GACnErM,EAAIuM,EAAM3c,OACND,EAAI,EAAGA,EAAI2e,IAAU3e,EAC5B4c,EAAMvB,EAAWrb,IAAMyH,EAAIuU,EAAY9Z,EAAMwb,GAC1Chb,EAAS+E,IAAY/E,EAAA+E,GACxBuV,EAASvV,KACDiW,GAAA,EAIT,IAAIX,EAAQ,EAEZ,IADAC,EAAS,GAAK,EACVhd,EAAI,EAAGA,GAAK0C,IAAU1C,EAAG6e,EAAU7e,GAAK+c,EAASA,EAAQC,EAAShd,EAAE,IAAK,EAC7E,IAAIA,EAAI,EAAGA,EAAIqQ,IAAKrQ,EAA4B,IAArB+c,EAAQH,EAAM5c,MAAUkd,EAAMld,GAAK6e,EAAU9B,MAExE,IAAII,EAAQ,EACZ,IAAInd,EAAI,EAAGA,EAAIqQ,IAAKrQ,EAEnB,GAAY,IADZmd,EAAQP,EAAM5c,IACC,CACd+c,EAAQtB,EAASyB,EAAMld,KAAM,EAAEmd,EAC/B,IAAA,IAAQrU,GAAK,GAAI,EAAEqU,GAAQ,EAAGrU,GAAG,IAAKA,EAAGuV,GAAStB,EAAOjU,GAAGqU,GAAiB,EAANA,EAAYnd,GAAG,CACzF,CAIC,IAAI8e,EAA2B,GAEzB,IADGpc,EAAA,EACHoc,EAAO7e,OAASwe,EAAQC,GAG7B,OADAhB,GAAgB,GADhBX,EAAQsB,GAASnC,EAAYha,EAAMwb,KAE3BX,KAAW,GAClB,KAAK,GAGJ,IAFItV,EAAA,EAAIoU,EAAY3Z,EAAMwb,GAAeA,GAAA,EACjCX,EAAA+B,EAAOA,EAAO7e,OAAS,GACzBwH,KAAM,GAAUqX,EAAAlK,KAAKmI,GAC3B,MACD,KAAK,GAEJ,IADItV,EAAA,EAAIuU,EAAY9Z,EAAMwb,GAAeA,GAAA,EACnCjW,KAAM,GAAUqX,EAAAlK,KAAK,GAC3B,MACD,KAAK,GAEJ,IADInN,EAAA,GAAKyU,EAAYha,EAAMwb,GAAeA,GAAA,EACpCjW,KAAO,GAAUqX,EAAAlK,KAAK,GAC5B,MACD,QACCkK,EAAOlK,KAAKmI,GACTra,EAASqa,IAAgBra,EAAAqa,GAM3B,IAAAgC,EAAKD,EAAOjc,MAAM,EAAG4b,GAAQO,EAAKF,EAAOjc,MAAM4b,GAC/Cze,IAAAA,EAAIye,EAAOze,EAAI,MAAOA,EAAG+e,EAAG/e,GAAK,EACjCA,IAAAA,EAAI0e,EAAQ1e,EAAI,KAAMA,EAAGgf,EAAGhf,GAAK,EAG9B,OAFKse,GAAA3B,GAAWoC,EAAIZ,GAAU,KACzBI,GAAA5B,GAAWqC,EAAIZ,GAAU,IAC9BV,CACR,CAiFS,SAAAuB,GAASlI,EAASmI,GAC1B,IACIvZ,EAhFI,SAAQzD,EAAMgd,GAEnB,GAAW,GAAXhd,EAAK,MAAuB,EAAVA,EAAK,IAAa,MAAO,CAACf,EAAY+d,GAAM,GAa1D,IAVP,IAAIxB,EAAO,EAGP9J,EAAS,EAETiG,EAASrY,EAAe0d,GAAa,GAAG,IACxCC,EAAO,EACPC,EAAKvF,EAAO5Z,SAAS,EACrBof,EAAY,EAAGC,EAAY,IAEjB,EAAP1L,IAEF,GADKA,EAAAoI,EAAY9Z,EAAMwb,GAAeA,GAAA,EACtC9J,IAAW,GAAM,EAoBb,IARGA,GAAU,GAAM,GAEdyL,EAAA,EAAeC,EAAA,IAGpB5B,EAAAc,GAAItc,EAAMwb,GACL2B,EAAAf,GAAuBgB,EAAAf,MAE5B,EACHW,GAAQE,EAAKD,EAAO,QAAkDC,GAA/BvF,EAAA2C,EAAQ3C,EAAQsF,EAAO,QAAoBlf,QAEtF,IAAIsf,EAAOpD,EAAYja,EAAMwb,EAAM2B,GAC/BG,EAAQ5L,IAAS,GAAM,EAAIwJ,GAASmC,GAAQpB,GAASoB,GAGzD,GAFA7B,GAAe,GAAP8B,GAAqBA,KAAA,KAEjB,EAAG,IAA8B,IAC7B,KAARA,EAAa,MAGpB,IAAIzB,GADIyB,GAAA,KACa,EAAK,EAAMA,EAAK,GAAI,EAAOzB,EAAS,IAAYA,EAAA,GACjE,IAAAtM,EAAM0N,EAAO7D,EAAOkE,GAErBzB,EAAS,IACJtM,GAAA0K,EAAYja,EAAMwb,EAAMK,GACvBL,GAAAK,GAIFwB,EAAApD,EAAYja,EAAMwb,EAAM4B,GAE/B5B,GAAe,IADf8B,EAAQ5L,IAAS,GAAM,EAAIyJ,GAASkC,GAAQnB,GAASmB,IAErD,IAAIvB,GADyBwB,KAAA,GACR,EAAI,EAAKA,EAAK,GAAI,EACnCC,EAAMlE,EAAOiE,GASjB,IAPGxB,EAAS,IACJyB,GAAAtD,EAAYja,EAAMwb,EAAMM,GACvBN,GAAAM,IAILkB,GAAOE,EAAK3N,IAA4C2N,GAA5BvF,EAAA2C,EAAQ3C,EAAQpI,EAAM,MAAkBxR,QAClEkf,EAAO1N,GAAOoI,EAAOsF,GAAQtF,EAAOsF,EAAOM,KAAQN,CAC7D,MA3B+BtF,EAAOsF,KAAUK,CA4BhD,KAvDM,CAEO,EAAP9B,IAAkBA,GAAA,GAAU,EAALA,IAEtB,IAAAlM,EAAKtP,EAAKwb,IAAO,GAAKxb,EAAgB,GAAVwb,IAAO,KAAO,EAG9C,GAFQA,GAAA,GAELlM,EAAK,EAEP,KADI0N,GAAOE,EAAKD,EAAO3N,IAA2C4N,GAA5BvF,EAAA2C,EAAQ3C,EAAQsF,EAAO3N,IAAiBvR,QACxEuR,KAAO,GAAKqI,EAAOsF,KAAUjd,EAAKwb,IAAO,GAAYA,GAAA,CAU/D,CAsCC,OAAGwB,EAAY,CAACrF,EAAS6D,EAAK,IAAK,GAC5B,CAAC7D,EAAOhX,MAAM,EAAGsc,GAAQzB,EAAK,IAAK,EAC3C,CAIWgC,CADC3I,EAAQlU,MAAMkU,EAAQhK,GAAG,GACZmS,GAExB,OADQnI,EAAAhK,GAAKpH,EAAI,GACVA,EAAI,EACZ,CAES,SAAAga,GAAcC,EAAKC,GAC3B,IAAGD,EACE,MAAM,IAAIxX,MAAMyX,EACtB,CAES,SAAA3N,GAAUF,EAAmBC,GACjC,IAAAb,EAAA,EACJC,GAAUD,EAAM,GAEhB,IACI5R,EAAI,CACPiT,UAFgC,GAGhCC,UAHkE,IAKnEC,EAASnT,EAAG,CAAE2S,KAAMF,EAAQE,OAIrB,IADHnS,IAAAA,EAAIoR,EAAKnR,OAAS,GACJ,IAAXmR,EAAKpR,IAA2B,IAAboR,EAAKpR,EAAE,IAA2B,GAAboR,EAAKpR,EAAE,IAA2B,GAAboR,EAAKpR,EAAE,KAAeA,GAAK,KAAKA,EACpGoR,EAAKrE,EAAI/M,EAAI,EAGboR,EAAKrE,GAAK,EACN,IAAA8F,EAAOzB,EAAKG,WAAW,GAC3BH,EAAKrE,GAAK,EACN,IAAA0M,EAAWrI,EAAKG,WAAW,GAK/B,IAFAH,EAAKrE,EAAI0M,EAELzZ,EAAI,EAAGA,EAAI6S,IAAQ7S,EAAG,CAEzBoR,EAAKrE,GAAK,GACN,IAAA+S,EAAM1O,EAAKG,WAAW,GACtB2N,EAAM9N,EAAKG,WAAW,GACtBmE,EAAUtE,EAAKG,WAAW,GAC1BwO,EAAO3O,EAAKG,WAAW,GACvByO,EAAO5O,EAAKG,WAAW,GAC3BH,EAAKrE,GAAK,EACN,IAAAoK,EAAS/F,EAAKG,WAAW,GACzB0O,EAAK9O,EAAyBC,EAAKvO,MAAMuO,EAAKrE,EAAE2I,EAAStE,EAAKrE,EAAE2I,EAAQqK,IACvE3O,EAAArE,GAAK2I,EAAUqK,EAAOC,EAE3B,IAAI3P,EAAIe,EAAKrE,EACbqE,EAAKrE,EAAIoK,EAAS,EAClB+I,GAAiB9O,EAAM0O,EAAKZ,EAAK1f,EAAGygB,GACpC7O,EAAKrE,EAAIsD,CACX,CACQ,OAAA7Q,CACR,CAIA,SAAS0gB,GAAiB9O,EAAiB0O,EAAgBZ,EAAgB1f,EAAoBygB,GAE9F7O,EAAKrE,GAAK,EACN,IAAAuE,EAAQF,EAAKG,WAAW,GACxB4O,EAAO/O,EAAKG,WAAW,GACvBhM,EA9sCL,SAAwBvE,GACvB,IAAI6P,EAA0B,MAApB7P,EAAIuQ,WAAW,GACrBL,EAA0B,MAApBlQ,EAAIuQ,WAAW,GACrB/I,MAAUnC,KACVjD,EAAU,GAAN8N,EACJnL,EAAU,IADemL,KAAA,GACAA,KAAA,EAC7B1I,EAAI4X,gBAAgB,GAChB5X,EAAA6X,YAAYnP,EAAM,MAClB1I,EAAA8X,SAASva,EAAE,GACfyC,EAAIlC,QAAQlD,GACZ,IAAI8C,EAAU,GAAN2K,EACJ5K,EAAU,IADe4K,KAAA,GAKtB,OAJsBA,KAAA,EAC7BrI,EAAI+X,SAAS1P,GACbrI,EAAIgY,WAAWva,GACXuC,EAAAiY,WAAWva,GAAG,GACXsC,CACR,CA8rCYkY,CAAetP,GAE1B,GAAW,KAARE,EAAsB,MAAA,IAAIlJ,MAAM,8BACvBgJ,EAAKG,WAAW,GAQb,IARX,IACAoP,EAAOvP,EAAKG,WAAW,GACvBqP,EAAOxP,EAAKG,WAAW,GAEvBmE,EAAUtE,EAAKG,WAAW,GAC1BwO,EAAO3O,EAAKG,WAAW,GAGvB2D,EAAO,GAAYlV,EAAI,EAAGA,EAAI0V,IAAW1V,EAAWkV,GAAAhW,OAAOC,aAAaiS,EAAKA,EAAKrE,MACtF,GAAGgT,EAAM,CACR,IAAIc,EAAK1P,EAAyBC,EAAKvO,MAAMuO,EAAKrE,EAAGqE,EAAKrE,EAAIgT,KAC1Dc,EAAG,QAAS,CAAE,GAAEhP,KAAItM,EAAOsb,EAAG,OAAQhP,MACrCoO,GAAI,CAAE,GAAE,QAAS,IAAIpO,KAAItM,EAAO0a,EAAG,OAAQpO,GAClD,CACCT,EAAKrE,GAAKgT,EAKV,IAAI7d,EAAOkP,EAAKvO,MAAMuO,EAAKrE,EAAGqE,EAAKrE,EAAI4T,GACvC,OAAOR,GACN,KAAK,EAAUje,EA1hBR,SAAgB6U,EAASmI,GACjC,IAAItE,EAAc,OAAAqE,GAASlI,EAASmI,GACpC,IACI4B,EAAU,IAAIC,EADDnG,EAAMmG,YAEnBpb,EAAMmb,EAAQE,cAAcjK,EAAQlU,MAAMkU,EAAQhK,GAAI+T,EAAQG,kBAE3D,OADPlK,EAAQhK,GAAK+T,EAAQI,UACdvb,CACR,CAmhBiBwb,CAAgB/P,EAAMwP,GAAO,MAC5C,KAAK,EAAG,MACR,QAAe,MAAA,IAAIxY,MAAM,sCAAwC+X,GAIlE,IAAIP,GAAM,EACC,EAARtO,IAEU,WADJF,EAAKG,WAAW,KACUH,EAAKG,WAAW,GAAUqO,GAAA,GACrDe,EAAAvP,EAAKG,WAAW,GAChBqP,EAAAxP,EAAKG,WAAW,IAGrBoP,GAAQb,GAAKH,GAAcC,EAAK,wBAA0BE,EAAM,OAASa,GACzEC,GAAQ1B,GAAKS,GAAcC,EAAK,0BAA4BV,EAAM,OAAS0B,GAGtEQ,GAAA5hB,EAAG0V,EAAMhT,EAAM,CAACmf,QAAQ,EAAMxP,GAAItM,GAC3C,CA0GA,IAAI+b,GAAkB,CACrBC,IAAO,YACPC,IAAO,WAEPC,IAAO,YACPC,IAAO,aACPC,IAAO,YAEPC,IAAO,oBACPC,KAAQ,iCACRC,QAAW,4BAGH,SAAA7I,GAAiBN,EAAiBD,GACvC,GAAAC,EAAGoJ,MAAO,OAAOpJ,EAAGoJ,MAEvB,IAAIC,EAAMrJ,EAAGzD,MAAQ,GAAInP,EAAIic,EAAI9Y,MAAM,eACpC,OAAAnD,GAAKub,GAAevb,EAAE,KAEtB2S,IACG3S,GAAAic,EAAMtJ,GAAIxP,MAAM,uBACboY,GAAevb,EAAE,IAJWub,GAAevb,EAAE,IAO/C,0BACR,CAGA,SAASoT,GAAgBjJ,GAGxB,IAFI,IAAAhO,EAAO5C,EAAc4Q,GACrB1Q,EAAI,GACAQ,EAAI,EAAGA,EAAIkC,EAAKjC,OAAQD,GAAI,GAAMR,EAAAoV,KAAK1S,EAAKW,MAAM7C,EAAGA,EAAE,KACxD,OAAAR,EAAE6C,KAAK,QAAU,MACzB,CAgBA,SAAS6W,GAAuB+I,GAC/B,IAAIC,EAAUD,EAAK3hB,QAAQ,2CAA2C,SAAS8B,GAC1E,IAAAqF,EAAIrF,EAAElC,WAAW,GAAGgI,SAAS,IAAIF,cACrC,MAAO,KAAmB,GAAZP,EAAExH,OAAc,IAAMwH,EAAIA,EAC1C,IAIyB,OAFxBya,EAAUA,EAAQ5hB,QAAQ,OAAQ,OAAOA,QAAQ,QAAS,QAE/CF,OAAO,KAAsB8hB,EAAA,MAAQA,EAAQrf,MAAM,IAI9D,IADA,IAAIrD,EAAsB,GAAIoC,GAFpBsgB,EAAAA,EAAQ5hB,QAAQ,aAAc,OAAOA,QAAQ,SAAU,SAASA,QAAQ,gBAAiB,UAErDsB,MAAM,QAC5CugB,EAAK,EAAGA,EAAKvgB,EAAM3B,SAAUkiB,EAAI,CACpC,IAAApY,EAAMnI,EAAMugB,GACb,GAAc,GAAdpY,EAAI9J,OACP,IAAA,IAAQD,EAAI,EAAGA,EAAI+J,EAAI9J,QAAS,CAC/B,IAAImiB,EAAM,GACNC,EAAMtY,EAAIlH,MAAM7C,EAAGA,EAAIoiB,GACD,KAAvBC,EAAIjiB,OAAOgiB,EAAM,GAAWA,IACA,KAAvBC,EAAIjiB,OAAOgiB,EAAM,GAAkBA,GAAA,EACZ,KAAvBC,EAAIjiB,OAAOgiB,EAAM,KAAkBA,GAAA,GAC3CC,EAAMtY,EAAIlH,MAAM7C,EAAGA,EAAIoiB,IACvBpiB,GAAKoiB,GACErY,EAAI9J,SAAeoiB,GAAA,KAC1B7iB,EAAEoV,KAAKyN,EACV,MAXwB7iB,EAAEoV,KAAK,GAY/B,CAEQ,OAAApV,EAAE6C,KAAK,OACf,CAiBS,SAAAigB,GAAWjL,EAAsBnV,EAAwBiQ,GAG5D,IAFL,IAAsCoQ,EAAlCC,EAAQ,GAAIC,EAAM,GAAIV,EAAQ,GAC9B3P,EAAK,EACJA,EAAK,KAAMA,EAAI,CACf,IAAAU,EAAO5Q,EAAKkQ,GAChB,IAAIU,GAAQA,EAAK5J,MAAM,SAAU,MAC7B,IAAAnD,EAAI+M,EAAK5J,MAAM,wBACnB,GAAGnD,EAAU,OAAAA,EAAE,GAAG0H,eACjB,IAAK,mBAA4B+U,EAAAzc,EAAE,GAAG2c,OAAQ,MAC9C,IAAK,eAAwBX,EAAAhc,EAAE,GAAG2c,OAAQ,MAC1C,IAAK,4BAAmCD,EAAA1c,EAAE,GAAG2c,OAEhD,CAEQ,SADLtQ,EACKqQ,EAAIhV,eACV,IAAK,SAAkB8U,EAAA7gB,EAAIrB,EAAc6B,EAAKW,MAAMuP,GAAI/P,KAAK,MAAO,MACpE,IAAK,mBAAoBkgB,EAhC3B,SAAgCrgB,GAI/B,IAHA,IAAI1C,EAAI,GAGA4S,EAAK,EAAGA,EAAKlQ,EAAKjC,SAAUmS,EAAI,CAEjC,IADF,IAAAU,EAAO5Q,EAAKkQ,GACVA,GAAMlQ,EAAKjC,QAA0C,KAAhC6S,EAAK1S,OAAO0S,EAAK7S,OAAS,MAAkB6S,EAAKjQ,MAAM,EAAGiQ,EAAK7S,OAAS,GAAKiC,IAAOkQ,GAC/G5S,EAAEoV,KAAK9B,EACT,CAGC,IAAA,IAAQ6P,EAAK,EAAGA,EAAKnjB,EAAES,SAAU0iB,EAAInjB,EAAEmjB,GAAMnjB,EAAEmjB,GAAIriB,QAAQ,sBAAsB,SAASgJ,GAAa,OAAApK,OAAOC,aAAa+L,SAAS5B,EAAGzG,MAAM,GAAI,IAAK,IACtJ,OAAOnB,EAAIlC,EAAE6C,KAAK,QACnB,CAmBmCugB,CAAuB1gB,EAAKW,MAAMuP,IAAM,MACzE,QAAe,MAAA,IAAIhK,MAAM,yCAA2Cqa,GAErE,IAAIzQ,EAAOoP,GAAQ/J,EAAKmL,EAAM3f,MAAMsP,EAAKlS,QAASsiB,EAAO,CAAClB,QAAQ,IAC/DU,MAAYA,MAAQA,EACxB,CAgGA,SAASX,GAAQ/J,EAAsBnC,EAAiBoB,EAAuBjR,GAC1E,IAAAgc,EAAShc,GAAQA,EAAKgc,OACtBA,GAAQ1O,EAAS0E,GACrB,IAAIrF,GAAQqP,GAAU/Q,GAAIkH,KAAKH,EAAKnC,GACpC,IAAIlD,EAAM,CACL,IAAA6Q,EAAmBxL,EAAI3E,UAAU,GAClCwC,EAAKrS,MAAM,EAAGggB,EAAM5iB,SAAW4iB,EAAeA,EAAA3N,GAE1B,KAAnB2N,EAAMhgB,OAAQ,KAAmBggB,GAAA,KACpCA,GAASA,EAAQ3N,GAAM5U,QAAQ,KAAK,MAErC0R,EAAQ,CAACkD,KAAMvE,EAASuE,GAAO5M,KAAM,GACjC+O,EAAA5E,UAAUmC,KAAK5C,GACfqF,EAAA3E,UAAUkC,KAAKiO,GACfxB,GAAY/Q,GAAAwS,MAAMC,OAAO1L,EAC/B,CASQ,OAPPrF,EAAKsE,QAAWA,EACXtE,EAAAiE,KAAOK,EAAUA,EAAQrW,OAAS,EACpCoF,IACCA,EAAKiS,QAAYtF,EAAA8D,MAAQzQ,EAAKiS,OAC9BjS,EAAKwM,KAASG,EAAAH,GAAKxM,EAAKwM,IACxBxM,EAAK6Q,KAASlE,EAAAkE,GAAK7Q,EAAK6Q,KAErBlE,CACR,CA+COxB,OArBPA,EAAQgH,KA9+BC,SAAKH,EAAsB2L,GACnC,IAAIC,EAAgC5L,EAAI3E,UAAU7Q,KAAI,SAAS5C,GAAK,OAAOA,EAAE+I,iBACzEkb,EAA4BD,EAAYphB,KAAI,SAAS5C,GAAS,IAAA6G,EAAI7G,EAAE2C,MAAM,KAAa,OAAAkE,EAAEA,EAAE7F,QAAyB,KAAfhB,EAAE4D,OAAQ,GAAW,EAAI,GAAI,IAClI6R,GAAgB,EACM,KAAvBsO,EAAK9iB,WAAW,IAA2BwU,GAAA,EAAMsO,EAAOC,EAAY,GAAGpgB,MAAM,MAASmgB,GACpFtO,GAA0B,IAAtBsO,EAAKpkB,QAAQ,KAClB,IAAAukB,EAAoBH,EAAKhb,cACzBP,GAAqB,IAANiN,EAAauO,EAAYrkB,QAAQukB,GAAUD,EAAQtkB,QAAQukB,GAC9E,IAAS,IAAN1b,EAAiB,OAAA4P,EAAI5E,UAAUhL,GAElC,IAAI1B,GAAKod,EAAOja,MAAMlG,GAGtB,IAFSmgB,EAAAA,EAAO7iB,QAAQyC,EAAK,IAC1BgD,IAAGod,EAASA,EAAO7iB,QAAQ0C,EAAK,MAC/ByE,EAAI,EAAGA,EAAIwb,EAAYhjB,SAAUwH,EAAG,CACvC,IAAI1B,EAAIkd,EAAYxb,GAAGnH,QAAQ0C,EAAK,KAAOigB,EAAYxb,IAAInH,QAAQyC,EAAK,KAAOogB,EAAe,OAAA9L,EAAI5E,UAAUhL,GAC5G,IAAI1B,EAAImd,EAAQzb,GAAGnH,QAAQ0C,EAAK,KAAOkgB,EAAQzb,IAAInH,QAAQyC,EAAK,KAAOogB,EAAe,OAAA9L,EAAI5E,UAAUhL,EACtG,CACQ,OAAA,IACR,EA69BA+I,EAAQ4S,KA1vCC,SAAKhS,EAA0Ba,GACnC,IAAA3J,EAAO2J,GAAWA,EAAQ3J,KAI9B,OAHIA,GACA/H,GAAWC,OAAOiC,SAAS2O,KAAc9I,EAAA,UAEtCA,GAAQ,UACd,IAAK,OAAkG,OAXhG,SAAUqI,EAAqBsB,GAEvC,OADQH,IACDC,EAAMxB,EAAG8S,aAAa1S,GAAWsB,EACzC,CAQyGqR,CAAUlS,EAAMa,GACvH,IAAK,SAAiH,OAAOF,EAAMrQ,EAAIrB,EAAc+Q,IAAQa,GAC7J,IAAK,SAAkG,OAAOF,EAAMrQ,EAAI0P,GAAOa,GAEzH,OAAAF,EAAkEX,EAAMa,EAChF,EAgvCAzB,EAAQuB,MAAQA,EAChBvB,EAAQ+S,MAv7BC,SAAMlM,EAAsBpF,GAChC,IAAAzS,EAAI+Y,EAAOlB,EAAKpF,GACb,OAAAA,GAAWA,EAAQ3J,MAAQ,UACjC,IAAK,OAA0E,WAArDiI,EAAAiT,cAAcvR,EAAQtB,SAAWnR,GAAoBA,EAC/E,IAAK,SAAU,MAAmB,iBAALA,EAAgBA,EAAIyC,EAAIzC,GACrD,IAAK,SAAU,OAAOF,EAA0B,iBAALE,EAAgBA,EAAIyC,EAAIzC,IACnE,IAAK,SAAa,GAAAe,SAAgBC,OAAOiC,SAASjD,GAAKA,EAAIoB,EAAYpB,GAEvE,IAAK,QAAS,MAAmB,iBAALA,EAAgBkC,EAAIlC,GAAKA,EAE/C,OAAAA,CACR,EA66BAgR,EAAQiT,UAr8BC,SAAWpM,EAAsB1G,EAAqBsB,GACtDH,IACJ,IAAAtS,EAAI+Y,EAAOlB,EAAKpF,GAEjB1B,EAAAiT,cAAc7S,EAAUnR,EAC5B,EAi8BAgR,EAAQsS,MAAQ,CACfY,QA/DD,SAAiBre,GAChB,IAAI7F,EAAsB,CAAA,EAEnB,OADPmT,EAASnT,EAAG6F,GACL7F,CACR,EA4DC4hB,WACAuC,QAhCQ,SAAQtM,EAAsBnC,GACtCvC,EAAS0E,GACT,IAAIrF,EAAO1B,GAAIkH,KAAKH,EAAKnC,GACtB,GAAAlD,EAAM,IAAA,IAAQlJ,EAAI,EAAGA,EAAIuO,EAAI5E,UAAUxS,SAAU6I,EAAM,GAAAuO,EAAI5E,UAAU3J,IAAMkJ,EAGtE,OAFHqF,EAAA5E,UAAUmR,OAAO9a,EAAG,GACpBuO,EAAA3E,UAAUkR,OAAO9a,EAAG,IACjB,EAED,OAAA,CACR,EAwBC+a,QAtBQ,SAAQxM,EAAsByM,EAAqBC,GAC3DpR,EAAS0E,GACT,IAAIrF,EAAO1B,GAAIkH,KAAKH,EAAKyM,GACtB,GAAA9R,EAAM,IAAA,IAAQlJ,EAAI,EAAGA,EAAIuO,EAAI5E,UAAUxS,SAAU6I,EAAM,GAAAuO,EAAI5E,UAAU3J,IAAMkJ,EAGtE,OAFPqF,EAAI5E,UAAU3J,GAAGoM,KAAOvE,EAASoT,GAC7B1M,EAAA3E,UAAU5J,GAAKib,GACZ,EAED,OAAA,CACR,EAcChB,OAZD,SAAgB1L,GAAiCI,EAAYJ,GAAK,EAAM,EAavE2M,aACAC,cACA5S,aACA/O,UACA4hB,SAr7BD,SAAkBC,GAAY,IAC7B,IACIrD,EAAU,IAAIC,EADDoD,EAAKpD,YAGnB,GADKD,EAAAE,cAAc,IAAI1f,WAAW,CAAC,EAAG,IAAKwf,EAAQG,mBACnDH,EAAQI,UACN,MAAM,IAAI9Y,MAAM,kCADSwS,EAAAuJ,CAE/B,OAAQpjB,GAAmE,CAAA,EAg7B1Ewc,YAAanC,GACbgJ,YAAanF,GACb1E,UAGM/J,CACP,IAOA,SAAS6T,GAAQniB,GAChB,MAAmB,iBAATA,EAA0BJ,EAAKI,GACtCX,MAAMY,QAAQD,GAx7FlB,SAAaA,GACZ,GAAyB,oBAAfZ,WAAkC,MAAA,IAAI8G,MAAM,eAC/C,OAAA,IAAI9G,WAAWY,EACvB,CAq7FgCoiB,CAAIpiB,GAC5BA,CACR,CAEA,SAASqiB,GAAS/B,EAAkBzL,EAAiB9V,GAGjD,GAAgB,oBAATujB,KAAsB,CAE/B,GAAGvjB,GAAyB,iBAAX8V,SAA4B9V,GAC5C,IAAK,OAAQ8V,EAAU,IAAI0N,YAAYxjB,GAAKyjB,OAAO3N,GAAU,MAC7D,IAAK,SAAUA,EAAUjV,EAAKiV,GAAU,MAExC,QAAe,MAAA,IAAI3O,MAAM,wBAA0BnH,GAE7C,OAAAujB,KAAKhB,cAAchB,EAAOzL,EACnC,CACC,IAAI7U,EAAe,QAAPjB,EAAiB0jB,GAAU5N,GAAWA,EAElD,GAA0B,oBAAhB6N,YAAoC,OAAAA,YAAY1iB,EAAMsgB,GAC7D,GAAgB,oBAATqC,KAAsB,CAC3B,IAAAzT,EAAO,IAAIyT,KAAK,CAACR,GAAQniB,IAAQ,CAACoG,KAAK,6BAExC,GAAqB,oBAAdwc,WAA6BA,UAAUC,WAAmB,OAAAD,UAAUC,WAAW3T,EAAMoR,GAE/F,GAAqB,oBAAXwC,OAA+B,OAAAA,OAAO5T,EAAMoR,GACnD,GAAe,oBAARyC,KAA2C,oBAAbC,UAA4BA,SAASC,eAAiBF,IAAIG,gBAAiB,CAC9G,IAAAC,EAAMJ,IAAIG,gBAAgBhU,GAE3B,GAAkB,iBAAXkU,QAAiE,mBAAlCA,OAAOC,WAAW,CAAA,GAAIC,SAEvD,OADJP,IAAIQ,iBAAyC,oBAAfC,wBAAuC,WAAaT,IAAIQ,gBAAgBJ,EAAK,GAAI,KAC3GC,OAAOC,UAAUC,SAAS,CAAEH,MAAU1U,SAAU6R,EAAOwC,QAAQ,IAEnE,IAAAvI,EAAIyI,SAASC,cAAc,KAC5B,GAAc,MAAd1I,EAAE+I,SAKG,OAHP/I,EAAE+I,SAAWhD,EAAO/F,EAAEkJ,KAAON,EAAcH,SAAAU,KAAKC,YAAYpJ,GAAIA,EAAEqJ,QACSZ,SAAAU,KAAKG,YAAYtJ,GACzFwI,IAAIQ,iBAAyC,oBAAfC,wBAAuC,WAAaT,IAAIQ,gBAAgBJ,EAAK,GAAI,KAC3GA,CAEX,CACA,CAEI,GAAa,oBAANW,GAAqC,oBAATC,MAA0C,oBAAXC,OAA4B,IAE5F,IAAAvgB,EAAMsgB,KAAKzD,GAEyB,OAFjB7c,EAAIwgB,KAAK,KAAMxgB,EAAIygB,SAAW,SAClD7kB,MAAMY,QAAQ4U,KAAUA,EAAU9U,EAAI8U,IACzCpR,EAAI4d,MAAMxM,GAAUpR,EAAI/H,QAAgBmZ,CACxC,OAAOhW,GAAQ,IAACA,EAAEslB,UAAYtlB,EAAEslB,QAAQnd,MAAM,YAAmB,MAAAnI,CAAE,CAC9D,MAAA,IAAIqH,MAAM,oBAAsBoa,EACvC,CAeA,SAAS8D,GAAK9mB,GAEL,IADR,IAAI+mB,EAAKvO,OAAOsO,KAAK9mB,GAAIgnB,EAAK,GACtBxmB,EAAI,EAAGA,EAAIumB,EAAGtmB,SAAUD,EAAMgY,OAAOyO,UAAUC,eAAe5jB,KAAKtD,EAAG+mB,EAAGvmB,KAAQwmB,EAAA5R,KAAK2R,EAAGvmB,IAC1F,OAAAwmB,CACR,CAEA,SAASG,GAAUC,EAAaC,GAE/B,IADA,IAAIrnB,EAAK,GAAasnB,EAAIR,GAAKM,GACvB5mB,EAAI,EAAGA,IAAM8mB,EAAE7mB,SAAUD,EAA2B,MAArBR,EAAEonB,EAAIE,EAAE9mB,IAAI6mB,MAAiBrnB,EAAAonB,EAAIE,EAAE9mB,IAAI6mB,IAAQC,EAAE9mB,IACjF,OAAAR,CACR,CAEA,SAASunB,GAAMH,GAEd,IADA,IAAIpnB,EAAK,GAAasnB,EAAIR,GAAKM,GACvB5mB,EAAI,EAAGA,IAAM8mB,EAAE7mB,SAAUD,EAAKR,EAAAonB,EAAIE,EAAE9mB,KAAO8mB,EAAE9mB,GAC9C,OAAAR,CACR,CAEA,SAASwnB,GAAUJ,GAElB,IADA,IAAIpnB,EAAK,GAAasnB,EAAIR,GAAKM,GACvB5mB,EAAI,EAAGA,IAAM8mB,EAAE7mB,SAAUD,EAAKR,EAAAonB,EAAIE,EAAE9mB,KAAOkL,SAAS4b,EAAE9mB,GAAG,IAC1D,OAAAR,CACR,CAWA,IAAIynB,OAA4B5gB,KAAK,KAAM,GAAI,GAAI,EAAG,EAAG,GACzD,SAAS6gB,GAAQ/jB,EAAYiD,GAI5B,SAH2BU,cAEUA,UAA+F,OAAnEI,oBAA4C+f,GAAA/f,uBAC7FigB,KACjB,CACA,IAAIC,OAA2B/gB,KAC3B8gB,MAAiCrgB,UAAqG,QAAnEI,oBAA4C+f,GAAA/f,qBAC/GmgB,MAAiCngB,oBACrC,SAASogB,GAAQnkB,GACZ,IAAAwC,MAAUU,KAKP,OAJPV,EAAI4hB,QAAY,GAAJpkB,EAAS,GAAK,GAAK,IAAOgkB,IAClCxhB,EAAIuB,sBAAwBmgB,IAC3B1hB,EAAA4hB,QAAQ5hB,EAAImB,UAAoD,KAAvCnB,EAAIuB,oBAAsBmgB,KAEjD1hB,CACR,CA6BA,IAAI6hB,GAAkC,IAAAnhB,KAAK,4BACvCohB,SAA8DD,GAAAhhB,eAA8B,IAAIH,KAAK,WAAamhB,GAClHE,GAAqD,MAAjBD,GAAAjhB,cAExC,SAASmhB,GAAU5d,EAAqB6d,GACnC,IAAAxkB,EAAI,IAAIiD,KAAK0D,GACjB,GAAG2d,GAIK,OAFJE,EAAU,EAAGxkB,EAAEmkB,QAAQnkB,EAAE0D,UAAoC,GAAxB1D,EAAE8D,oBAA2B,KAC7D0gB,EAAU,GAAGxkB,EAAEmkB,QAAQnkB,EAAE0D,UAAoC,GAAxB1D,EAAE8D,oBAA2B,KACnE9D,EAEL,GAAA2G,aAAe1D,KAAa,OAAA0D,EAC5B,GAA8B,MAA9B0d,GAAajhB,gBAA0BrG,MAAMiD,EAAEoD,eAAgB,CAC7D,IAAA7E,EAAIyB,EAAEoD,cACV,OAAGuD,EAAInL,QAAQ,GAAK+C,OACpByB,EAAEid,YAAYjd,EAAEoD,cAAgB,KADIpD,CAEtC,CACK,IAAAyL,EAAI9E,EAAIb,MAAM,SAAS,CAAC,OAAO,IAAI,KAAK,IAAI,IAAI,KAChDvD,EAAM,IAAIU,MAAMwI,EAAE,IAAKA,EAAE,GAAK,GAAIA,EAAE,IAAMA,EAAE,IAAI,GAAMA,EAAE,IAAI,GAAMA,EAAE,IAAI,GAErE,OADJ9E,EAAInL,QAAQ,UAAiB+G,EAAA,IAAIU,KAAKV,EAAImB,UAAsC,GAA1BnB,EAAIuB,oBAA2B,MACjFvB,CACR,CAEA,SAASkiB,GAAOC,EAAuBC,GACtC,GAAGxnB,GAAWC,OAAOiC,SAASqlB,GAKtB,OAAAA,EAAI5f,SAAS,UAGlB,GAAuB,oBAAhB8f,YAAiC,IAK1C,IAAIpM,EAAM,CACT,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAChE,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAChE,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAChE,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAChE,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAChE,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAAQ,IAAU,IAChE,IAAU,IAAQ,IAAU,IAAQ,IAAU,KAGxC,OADJra,MAAMY,QAAQ2lB,KAAYA,EAAA,IAAIxmB,WAAWwmB,IACrC,IAAIE,YAAY,UAAUC,OAAOH,GAAKxnB,QAAQ,kCAAkC,SAAS8B,GAAY,OAAAwZ,EAAIxZ,IAAMA,IACtH,OAAOrB,GAAG,CAGX,IADA,IAAIvB,EAAI,GACAQ,EAAI,EAAGA,GAAK8nB,EAAI7nB,SAAUD,EAAKR,EAAAoV,KAAK1V,OAAOC,aAAa2oB,EAAI9nB,KAC7D,OAAAR,EAAE6C,KAAK,GACf,CAEA,SAAS6lB,GAAI1oB,GACZ,GAAkB,oBAAR2oB,OAAwB5mB,MAAMY,QAAQ3C,GAAI,OAAO2oB,KAAKpW,MAAMoW,KAAKC,UAAU5oB,IACrF,GAAe,iBAALA,GAAsB,MAALA,EAAkB,OAAAA,EAC7C,GAAGA,aAAa6G,KAAM,OAAO,IAAIA,KAAK7G,EAAEsH,WACxC,IAAInB,EAAM,CAAE,EACZ,IAAA,IAAQ+O,KAAKlV,EAAMwY,OAAOyO,UAAUC,eAAe5jB,KAAKtD,EAAGkV,OAAQA,GAAKwT,GAAI1oB,EAAEkV,KACvE,OAAA/O,CACR,CAEA,SAASrC,GAAKlB,EAAa2K,GAA6C,IAAlB,IAAIvN,EAAI,GAAUA,EAAES,OAAS8M,GAAMvN,GAAA4C,EAAU,OAAA5C,CAAE,CAGrG,SAAS6oB,GAAS1mB,GACb,IAAAwB,EAAemlB,OAAO3mB,GACvB,IAACxB,MAAMgD,UAAWolB,SAASplB,GAAKA,EAAIqlB,IACvC,IAAI,KAAKlW,KAAK3Q,GAAW,OAAAwB,EACzB,IAAIslB,EAAK,EACL/f,EAAK/G,EAAErB,QAAQ,iBAAiB,QAAQA,QAAQ,OAAO,IAAIA,QAAQ,QAAQ,WAA+B,OAAZmoB,GAAA,IAAY,EAAG,IAC9G,OAACtoB,MAAMgD,EAAImlB,OAAO5f,KACrBA,EAAKA,EAAGpI,QAAQ,cAAa,SAASgJ,EAAIC,GAAuB,OAAjBkf,GAAMA,EAAWlf,CAAG,IAChEpJ,MAAMgD,EAAImlB,OAAO5f,IACdvF,EAD2BA,EAAIslB,GAFJtlB,EAAIslB,CAIvC,CACA,IAAIC,GAAe,CAAC,UAAW,WAAY,QAAS,QAAS,MAAO,OAAQ,OAAQ,SAAU,YAAa,UAAW,WAAY,YAClI,SAASC,GAAUhnB,GACd,IAAAnC,EAAI,IAAI6G,KAAK1E,GAAIkN,EAAI,IAAIxI,KAAKmiB,KAC9B1iB,EAAItG,EAAEopB,UAAW7iB,EAAIvG,EAAEiH,WAAYrD,EAAI5D,EAAE+G,UAC1C,GAAApG,MAAMiD,GAAW,OAAAyL,EAChB,IAAAga,EAAQlnB,EAAE8L,cACX,GAAAob,EAAM3f,MAAM,oDAEX,IADH2f,EAAQA,EAAMvoB,QAAQ,UAAU,IAAIA,QAAQ,6BAA6B,KAChEL,OAAS,OAAKyoB,GAAa9pB,QAAQiqB,GAAqB,OAAAha,OACxD,GAAAga,EAAM3f,MAAM,SAAiB,OAAA2F,EACvC,OAAG/I,EAAI,GAAKA,EAAI,KAAa+I,GACzB9I,EAAI,GAAK3C,EAAI,IAAW,KAAL0C,EAAiBtG,EACrCmC,EAAEuH,MAAM,iBAAyB2F,EAC7BrP,CACR,CA8EA,SAASspB,GAAaC,EAAK/F,EAAM1M,GAChC,GAAGyS,EAAIrW,UAAW,CAEZ,IAAAsW,EADF,GAAkB,iBAAX1S,EAMT,OAJkB0S,EAAfzoB,EAAeK,EAAY0V,GAztGjC,SAAoBA,GAGnB,IAFA,IAAI3Q,EAAM,GAAIsjB,EAAO,EAAG5Y,EAAIiG,EAAQrW,OAAS,IACzCT,EAAI2B,EAAYmV,EAAQrW,OAAS,KAC7BipB,EAAO,EAAGA,EAAO5S,EAAQrW,SAAUipB,EAAM,CAC5C,IAAA9mB,EAAIkU,EAAQpW,WAAWgpB,GAC3B,GAAG9mB,EAAI,IAAQ5C,EAAAypB,KAAU7mB,OAAA,GACjBA,EAAI,KACX5C,EAAEypB,KAAW,IAAM7mB,GAAG,EAAG,GACvB5C,EAAAypB,KAAW,IAAO,GAAF7mB,OACT,GAAAA,GAAK,OAAUA,EAAI,MAAQ,CACpCA,EAAa,IAAN,KAAFA,GACL,IAAIgB,EAA+B,KAA3BkT,EAAQpW,aAAagpB,GAC7B1pB,EAAEypB,KAAW,IAAM7mB,GAAG,EAAG,EACzB5C,EAAEypB,KAAW,IAAM7mB,GAAG,EAAG,GACzB5C,EAAEypB,KAAW,IAAM7lB,GAAG,EAAG,IAAQ,EAAFhB,IAAM,EACnC5C,EAAAypB,KAAW,IAAO,GAAF7lB,CACrB,MACG5D,EAAEypB,KAAW,IAAM7mB,GAAG,GAAI,GAC1B5C,EAAEypB,KAAW,IAAM7mB,GAAG,EAAG,GACvB5C,EAAAypB,KAAW,IAAO,GAAF7mB,EAEhB6mB,EAAO5Y,IACT1K,EAAIiP,KAAKpV,EAAEqD,MAAM,EAAGomB,IACbA,EAAA,EACPzpB,EAAI2B,EAAY,OACZkP,EAAA,MAEP,CAEC,OADA1K,EAAIiP,KAAKpV,EAAEqD,MAAM,EAAGomB,IACb3mB,EAAQqD,EAChB,CA8rGcwjB,CAAW7S,GACfhG,GAAIwS,MAAM1B,QAAQ2H,EAAK/F,EAAMgG,GAErC1Y,GAAIwS,MAAM1B,QAAQ2H,EAAK/F,EAAM1M,EAC/B,MACMyS,EAAI/W,KAAKgR,EAAM1M,EACrB,CAEA,SAAS8S,KAAmB,OAAA9Y,GAAIwS,MAAMY,SAAU,CAuBhD,IAAI2F,GAAa,8DA2CbC,MAPY,CACf,SAAU,IACV,SAAU,IACV,OAAQ,IACR,OAAQ,IACR,QAAS,MAiBNC,GAAS,WAAYC,GAAW,gCACpC,SAASC,GAAUxH,GAElB,OADQA,EAAO,IACN3hB,QAAQipB,IAAU,SAASzjB,GAAK,OAAOwjB,GAAUxjB,EAAK,IAAExF,QAAQkpB,IAAS,SAAS7nB,GAAY,MAAA,MAAQ,MAAMA,EAAEzB,WAAW,GAAGgI,SAAS,KAAKrF,OAAM,GAAM,GAAI,GACpK,CACA,SAAS6mB,GAAazH,GAA6B,OAAOwH,GAAUxH,GAAM3hB,QAAQ,KAAK,UAAW,CAElG,IAAIqpB,GAAe,mBA2BnB,SAASC,GAAUC,GAEX,IADP,IAAIlkB,EAAM,GAAI3F,EAAI,EAAGoC,EAAI,EAAGgB,EAAI,EAAGrC,EAAI,EAAG6L,EAAI,EAAGnF,EAAI,EAC9CzH,EAAI6pB,EAAK5pB,SACXmC,EAAAynB,EAAK3pB,WAAWF,MACZ,IAAc2F,GAAAzG,OAAOC,aAAaiD,IACtCgB,EAAAymB,EAAK3pB,WAAWF,KAChBoC,EAAE,KAAOA,EAAE,KAAOwK,GAAU,GAAJxK,IAAW,EAAIwK,GAAU,GAAJxJ,EAAgBuC,GAAAzG,OAAOC,aAAayN,KACjF7L,EAAA8oB,EAAK3pB,WAAWF,KAChBoC,EAAI,IAAcuD,GAAAzG,OAAOC,cAAmB,GAAJiD,IAAW,IAAY,GAAJgB,IAAW,EAAU,GAAJrC,IAEzE0G,IAAI,EAAJrF,IAAU,IAAY,GAAJgB,IAAW,IAAY,GAAJrC,IAAW,EAAU,IAD7D6L,EAAAid,EAAK3pB,WAAWF,OACkD,MACtE2F,GAAOzG,OAAOC,aAAa,OAAWsI,IAAI,GAAI,OAC9C9B,GAAOzG,OAAOC,aAAa,OAAY,KAAFsI,OAE/B,OAAA9B,CACR,CAEA,SAASmkB,GAAU5nB,GAClB,IAAsCuF,EAAGzH,EAAuBoC,EAA5DuD,EAAMxE,EAAY,EAAEe,EAAKjC,QAAe6I,EAAI,EAAG4L,EAAI,EAAGqV,EAAG,EAC7D,IAAI/pB,EAAI,EAAGA,EAAIkC,EAAKjC,OAAQD,GAAG8I,EAC1BA,EAAA,GACA1G,EAAEF,EAAKhC,WAAWF,IAAM,IAASyH,EAAArF,EAC7BA,EAAI,KAAOqF,EAAW,IAAJ,GAAFrF,IAA+B,GAArBF,EAAKhC,WAAWF,EAAE,IAAU8I,EAAA,GACtD1G,EAAI,KAAOqF,EAAS,MAAJ,GAAFrF,GAAqC,IAAJ,GAArBF,EAAKhC,WAAWF,EAAE,KAAgC,GAArBkC,EAAKhC,WAAWF,EAAE,IAAU8I,EAAA,IAChFA,EAAA,EACLrB,EAAO,QAAH,EAAJrF,GAAwC,MAAJ,GAArBF,EAAKhC,WAAWF,EAAE,IAAsC,IAAJ,GAArBkC,EAAKhC,WAAWF,EAAE,KAAgC,GAArBkC,EAAKhC,WAAWF,EAAE,IACjF+pB,EAAA,QAAZtiB,GAAA,SAA2B,GAAI,MAAOA,EAAI,OAAY,KAAFA,IAEhD,IAAPsiB,IAAgBpkB,EAAA+O,KAAU,IAAHqV,EAAYpkB,EAAA+O,KAAOqV,IAAK,EAAQA,EAAA,GACtDpkB,EAAA+O,KAAOjN,EAAE,IAAS9B,EAAA+O,KAAOjN,IAAI,EAElC,OAAO9B,EAAI9C,MAAM,EAAE6R,GAAGxM,SAAS,OAChC,CAEA,SAAS8hB,GAAU9nB,GAAQ,OAAOtB,EAAYsB,EAAM,UAAUgG,SAAS,OAAQ,CAE/E,IAAI+hB,GAAa,qBACbC,GAAW3pB,IAAmCypB,GAAAC,KAAsCL,GAAAK,KAAeD,OAAoCC,KAAsCL,GAAAK,KAAeH,KAAcF,GAE1MjF,GAA2BpkB,EAAU,SAAS2B,GAAQ,OAAOtB,EAAYsB,EAAM,QAAQgG,SAAS,SAAY,EAAG,SAAS2hB,GAErH,IADN,IAAIlkB,EAAwB,GAAI3F,EAAI,EAAGoC,EAAI,EAAGgB,EAAI,EAC5CpD,EAAI6pB,EAAK5pB,QAEd,OADImC,EAAAynB,EAAK3pB,WAAWF,MACb,GACN,KAAKoC,EAAI,IAAKuD,EAAIiP,KAAK1V,OAAOC,aAAaiD,IAAK,MAChD,KAAKA,EAAI,KACRuD,EAAIiP,KAAK1V,OAAOC,aAAa,KAAOiD,GAAK,KACzCuD,EAAIiP,KAAK1V,OAAOC,aAAa,KAAW,GAAJiD,KACpC,MACD,KAAKA,GAAK,OAASA,EAAI,MACjBA,GAAA,MAAOgB,EAAIymB,EAAK3pB,WAAWF,KAAO,OAASoC,GAAG,IACnDuD,EAAIiP,KAAK1V,OAAOC,aAAa,KAAQiE,GAAI,GAAM,KAC/CuC,EAAIiP,KAAK1V,OAAOC,aAAa,KAAQiE,GAAI,GAAM,MAC/CuC,EAAIiP,KAAK1V,OAAOC,aAAa,KAAQiE,GAAK,EAAK,MAC/CuC,EAAIiP,KAAK1V,OAAOC,aAAa,KAAW,GAAJiE,KACpC,MACD,QACCuC,EAAIiP,KAAK1V,OAAOC,aAAa,KAAOiD,GAAK,MACzCuD,EAAIiP,KAAK1V,OAAOC,aAAa,KAAQiD,GAAK,EAAK,MAC/CuD,EAAIiP,KAAK1V,OAAOC,aAAa,KAAW,GAAJiD,KAGhC,OAAAuD,EAAItD,KAAK,GACjB,EAYI8nB,GAA8D,WACjE,IAAIC,EAAuC,CAC1C,CAAC,OAAQ,KAAM,CAAC,SAAU,KAC1B,CAAC,OAAQ,KAAM,CAAC,OAAQ,KAAM,CAAC,KAAQ,KAAM,CAAC,KAAQ,KAAM,CAAC,MAAQ,MACpEvoB,KAAI,SAAS5C,GAA0B,MAAO,CAAC,IAAIorB,OAAO,IAAMprB,EAAE,GAAK,IAAK,MAAOA,EAAE,OAChF,OAAA,SAAoB8K,GAc1B,IAbA,IAAIvK,EAAIuK,EAELzJ,QAAQ,cAAe,IAEvBA,QAAQ,cAAc,IAEtBA,QAAQ,QAAQ,KAAKA,QAAQ,QAAQ,KAErCA,QAAQ,cAAe,KAEvBA,QAAQ,uBAAuB,MAE/BA,QAAQ,WAAW,IACdN,EAAI,EAAGA,EAAIoqB,EAASnqB,SAAUD,EAAOR,EAAAA,EAAEc,QAAQ8pB,EAASpqB,GAAG,GAAIoqB,EAASpqB,GAAG,IAC5E,OAAAR,CACP,CACF,CAtBkE,GA8C9D8qB,GAAU,eACd,SAASC,GAAS3d,EAAa4d,GAAkC,MAAA,IAAM5d,GAAK4d,EAAEthB,MAAMohB,IAAS,wBAA0B,IAAM,IAAME,EAAI,KAAO5d,EAAI,GAAI,CAEtJ,SAAS6d,GAAW1O,GAAgB,OAAOuK,GAAKvK,GAAGla,KAAI,SAAS6S,GAAK,MAAO,IAAMA,EAAI,KAAOqH,EAAErH,GAAK,GAAI,IAAGrS,KAAK,GAAI,CACpH,SAASqoB,GAAU9d,EAAa4d,EAAczO,GAAY,MAAA,IAAMnP,GAAW,MAALmP,EAAa0O,GAAW1O,GAAK,KAAa,MAALyO,GAAcA,EAAEthB,MAAMohB,IAAS,wBAA0B,IAAM,IAAME,EAAI,KAAO5d,EAAI,KAAO,GAAI,CAE1M,SAAS+d,GAAavnB,EAAYC,GAAiC,IAAE,OAAOD,EAAEwnB,cAActqB,QAAQ,QAAQ,GAAM,OAAOS,GAAK,GAAGsC,EAAS,MAAAtC,EAAY,MAAA,EAAG,CA0BzJ,IAAI8pB,GACS,0EADTA,GAES,0EAFTA,GAGQ,4EAHRA,GAIC,+DAJDA,GAKG,+DALHA,GAMI,0EANJA,GAOG,mCAPHA,GAQQ,4BARRA,GASS,+BATTA,GAWE,sEAXFA,GAaG,uEAbHA,GAcI,4CAdJA,GAeI,mCAGJC,GAAa,CAChB,4DACA,gDACA,sDACA,oDAGGC,GACK,0CADLA,GAEK,yCAFLA,GAGK,+CAHLA,GAIK,4CAJLA,GAKK,yBALLA,GAMK,gCANLA,GAOK,kCA6BT,IAAIC,GAAc,SAASzoB,GAAmE,IAAd,IAAAtD,EAAE,GAAoBe,EAAE,EAAEA,EAAEuC,EAAK,GAAGtC,SAASD,KAAMuC,EAAK,GAAGvC,WAAY8I,EAAE,EAAEuH,EAAE9N,EAAK,GAAGvC,GAAGC,OAAO6I,EAAEuH,EAAEvH,GAA5F,QAAoG8L,KAAKhS,MAAM3D,EAAGsD,EAAK,GAAGvC,GAAG6C,MAAMiG,EAAEA,EAArI,QAAmJ,OAAA7J,CAAI,EAC1O+V,GAAazU,EAAU,SAASgC,GAAgB,OAAAA,EAAK,GAAGtC,OAAS,GAAKO,OAAOiC,SAASF,EAAK,GAAG,IAAO/B,OAAOgC,OAAOD,EAAK,GAAGV,KAAI,SAAS5C,GAAK,OAAOuB,OAAOiC,SAASxD,GAAKA,EAAI2B,EAAY3B,OAAU+rB,GAAYzoB,EAAM,EAAIyoB,GAEzNC,GAAa,SAAStP,EAAsBha,EAAaZ,GAAwD,IAA7B,IAAI2H,EAAqB,GAAY1I,EAAE2B,EAAG3B,EAAEe,EAAGf,GAAG,EAAG0I,EAAGkM,KAAK1V,OAAOC,aAAa+rB,GAAevP,EAAE3b,KAAM,OAAO0I,EAAGrG,KAAK,IAAI/B,QAAQyC,EAAK,GAAM,EAClO4S,GAAYpV,EAAU,SAASob,EAAsBha,EAAaZ,GAA8B,OAACP,OAAOiC,SAASkZ,GAAqEA,EAAEzT,SAAS,UAAUvG,EAAEZ,GAAGT,QAAQyC,EAAK,IAAjEkoB,GAAWtP,EAAEha,EAAEZ,EAA8E,EAAGkqB,GAE5PE,GAAa,SAASxP,EAAsBha,EAAaoL,GAAwD,IAA7B,IAAIrE,EAAqB,GAAY1I,EAAE2B,EAAG3B,EAAE2B,EAAEoL,IAAK/M,EAAM0I,EAAAkM,MAAM,IAAM+G,EAAE3b,GAAGkI,SAAS,KAAKrF,WAAmB,OAAA6F,EAAGrG,KAAK,GAAM,EAC7M+oB,GAAY7qB,EAAU,SAASob,EAAsBha,EAAaoL,GAA2B,OAAOvM,OAAOiC,SAASkZ,GAAkCA,EAAEzT,SAAS,MAAMvG,EAAEA,EAAEoL,GAAKoe,GAAWxP,EAAEha,EAAEoL,EAAG,EAAKoe,GAEvME,GAAU,SAAS1P,EAAsBha,EAAaZ,GAA2B,IAAX,IAAI2H,EAAG,GAAY1I,EAAE2B,EAAG3B,EAAEe,EAAGf,IAAK0I,EAAGkM,KAAK1V,OAAOC,aAAamsB,GAAY3P,EAAE3b,KAAa,OAAA0I,EAAGrG,KAAK,GAAM,EAC7KkpB,GAAShrB,EAAU,SAAgBob,EAAuBha,EAAcZ,GAAgB,OAAQP,OAAOiC,SAASkZ,GAAqCA,EAAEzT,SAAS,OAAOvG,EAAEZ,GAAKsqB,GAAQ1P,EAAEha,EAAEZ,EAAK,EAAGsqB,GAElMG,GAAW,SAAS7P,EAAsB3b,GAAoB,IAAAoB,EAAMgW,GAAeuE,EAAE3b,GAAW,OAAAoB,EAAM,EAAImqB,GAAO5P,EAAG3b,EAAE,EAAEA,EAAE,EAAEoB,EAAI,GAAK,EAAG,EACxIqqB,GAAUD,GAEVE,GAAW,SAAS/P,EAAsB3b,GAAoB,IAAAoB,EAAMgW,GAAeuE,EAAE3b,GAAW,OAAAoB,EAAM,EAAImqB,GAAO5P,EAAG3b,EAAE,EAAEA,EAAE,EAAEoB,EAAI,GAAK,EAAG,EACxIuqB,GAAUD,GAEVE,GAAY,SAASjQ,EAAsB3b,GAAgB,IAAIoB,EAAM,EAAEgW,GAAeuE,EAAE3b,GAAW,OAAAoB,EAAM,EAAImqB,GAAO5P,EAAG3b,EAAE,EAAEA,EAAE,EAAEoB,EAAI,GAAK,EAAG,EAC3IyqB,GAAWD,GAEXE,GAAU,SAAenQ,EAAsB3b,GAAoB,IAAAoB,EAAMgW,GAAeuE,EAAE3b,GAAW,OAAAoB,EAAM,EAAIuU,GAAUgG,EAAG3b,EAAE,EAAEA,EAAE,EAAEoB,GAAO,EAAG,EAC9I2qB,GAASD,GAETE,GAAW,SAASrQ,EAAsB3b,GAAoB,IAAAoB,EAAMgW,GAAeuE,EAAE3b,GAAW,OAAAoB,EAAM,EAAImqB,GAAO5P,EAAG3b,EAAE,EAAEA,EAAE,EAAEoB,GAAO,EAAG,EACtI6qB,GAAUD,GAEVE,GAAY,SAASvQ,EAAuB1S,GAAyB,OAtDzE,SAAwB0S,EAAuB1S,GAItC,IAHR,IAAItH,EAAI,EAAI,GAAKga,EAAE1S,EAAM,KAAO,GAC5BlI,IAAmB,IAAb4a,EAAE1S,EAAM,KAAc,IAAO0S,EAAE1S,EAAM,KAAO,EAAK,IACvDlD,EAAc,GAAT4V,EAAE1S,EAAI,GACPjJ,EAAI,EAAGA,GAAK,IAAKA,EAAG+F,EAAQ,IAAJA,EAAU4V,EAAE1S,EAAMjJ,GAClD,OAAQ,MAALe,EAAwB,GAALgF,EAAUpE,GAAIwqB,KAAY3D,KACxC,GAALznB,EAAYA,GAAA,MACHA,GAAA,KAAWgF,GAAArC,KAAKC,IAAI,EAAE,KAC3BhC,EAAI+B,KAAKC,IAAI,EAAG5C,EAAI,IAAMgF,EAClC,CA6CyEqmB,CAAezQ,EAAG1S,EAAK,EAC5FojB,GAAWH,GAEXI,GAAS,SAAkB7P,GAAK,OAAOlb,MAAMY,QAAQsa,IAA6B,oBAAfnb,YAA8Bmb,aAAanb,UAAc,EAE7Hf,IACQkrB,GAAA,SAAiB9P,EAAuB3b,GAAmB,IAACQ,OAAOiC,SAASkZ,GAA2C,OAAA6P,GAAS7P,EAAG3b,GAAQ,IAAAoB,EAAMua,EAAE4Q,aAAavsB,GAAW,OAAAoB,EAAM,EAAIua,EAAEzT,SAAS,OAAOlI,EAAE,EAAEA,EAAE,EAAEoB,EAAI,GAAK,EAAG,EAC3NuqB,GAAA,SAAiBhQ,EAAuB3b,GAAmB,IAACQ,OAAOiC,SAASkZ,GAA2C,OAAA+P,GAAS/P,EAAG3b,GAAQ,IAAAoB,EAAMua,EAAE4Q,aAAavsB,GAAW,OAAAoB,EAAM,EAAIua,EAAEzT,SAAS,OAAOlI,EAAE,EAAEA,EAAE,EAAEoB,EAAI,GAAK,EAAG,EAC1NyqB,GAAA,SAAkBlQ,EAAuB3b,GAAmB,IAACQ,OAAOiC,SAASkZ,GAA2C,OAAAiQ,GAAUjQ,EAAG3b,GAAI,IAAIoB,EAAM,EAAEua,EAAE4Q,aAAavsB,GAAW,OAAA2b,EAAEzT,SAAS,UAAUlI,EAAE,EAAEA,EAAE,EAAEoB,EAAI,EAAG,EACrN2qB,GAAA,SAAgBpQ,EAAuB3b,GAAmB,IAACQ,OAAOiC,SAASkZ,GAA2C,OAAAmQ,GAAQnQ,EAAG3b,GAAQ,IAAAoB,EAAMua,EAAE4Q,aAAavsB,GAAI,OAAO2b,EAAEzT,SAAS,UAAUlI,EAAE,EAAEA,EAAE,EAAEoB,EAAK,EAC1M6qB,GAAA,SAAiBtQ,EAAuB3b,GAAmB,IAACQ,OAAOiC,SAASkZ,GAA2C,OAAAqQ,GAASrQ,EAAG3b,GAAQ,IAAAoB,EAAMua,EAAE4Q,aAAavsB,GAAI,OAAO2b,EAAEzT,SAAS,OAAOlI,EAAE,EAAEA,EAAE,EAAEoB,EAAK,EACzMirB,GAAA,SAAiB1Q,EAAuB3b,GAAgB,OAAGQ,OAAOiC,SAASkZ,GAAuCA,EAAE6Q,aAAaxsB,GAAWksB,GAAUvQ,EAAE3b,EAAK,EAC/JssB,GAAA,SAAkB7P,GAAY,OAAAjc,OAAOiC,SAASga,IAAMlb,MAAMY,QAAQsa,IAA6B,oBAAfnb,YAA8Bmb,aAAanb,UAAc,GAenJ,IAAIgqB,GAAc,SAAS3P,EAAuB1S,GAA6B,OAAO0S,EAAE1S,EAAO,EAC3FiiB,GAAiB,SAASvP,EAAuB1S,GAA6B,WAAQ0S,EAAE1S,EAAI,GAAW0S,EAAE1S,EAAO,EAChHwjB,GAAgB,SAAS9Q,EAAuB1S,GAAiC,IAAApD,MAAK8V,EAAE1S,EAAI,GAAW0S,EAAE1S,GAAM,OAAQpD,EAAI,MAAUA,GAAwB,GAAlB,MAASA,EAAI,EAAW,EACnKuR,GAAiB,SAASuE,EAAuB1S,GAA6B,OAAO0S,EAAE1S,EAAI,IAAI,GAAG,KAAK0S,EAAE1S,EAAI,IAAI,KAAK0S,EAAE1S,EAAI,IAAI,GAAG0S,EAAE1S,EAAO,EAC5I6L,GAAgB,SAAS6G,EAAuB1S,GAA6B,OAAQ0S,EAAE1S,EAAI,IAAI,GAAK0S,EAAE1S,EAAI,IAAI,GAAK0S,EAAE1S,EAAI,IAAI,EAAG0S,EAAE1S,EAAO,EACzIyjB,GAAgB,SAAS/Q,EAAuB1S,GAA6B,OAAQ0S,EAAE1S,IAAM,GAAK0S,EAAE1S,EAAI,IAAI,GAAK0S,EAAE1S,EAAI,IAAI,EAAG0S,EAAE1S,EAAI,EAAK,EAE7I,SAAS+a,GAAU/N,EAAiB5S,GAC/B,IAAMspB,EAAsBC,EAAWnlB,EAAGuG,EAAIhO,EAAG6sB,EAAjDrtB,EAAE,GAA8BstB,EAAG,GACvC,OAAOzpB,GACN,IAAK,OAEJ,GADAwpB,EAAME,KAAKhgB,EACRxM,GAAWC,OAAOiC,SAASsqB,QAAWA,KAAKlqB,MAAMkqB,KAAKhgB,EAAGggB,KAAKhgB,EAAE,EAAEkJ,GAAM/N,SAAS,oBAC3ElI,EAAI,EAAGA,EAAIiW,IAAQjW,EAAKR,GAAGN,OAAOC,aAAa+rB,GAAe6B,KAAMF,IAAYA,GAAA,EACjF5W,GAAA,EACR,MAED,IAAK,OAAQzW,EAAI+rB,GAAOwB,KAAMA,KAAKhgB,EAAGggB,KAAKhgB,EAAIkJ,GAAO,MACtD,IAAK,UAAmBA,GAAA,EAAGzW,EAAImW,GAAUoX,KAAMA,KAAKhgB,EAAGggB,KAAKhgB,EAAIkJ,GAAO,MAEvE,IAAK,OAEC,OAAO+N,GAAUlhB,KAAKiqB,KAAM9W,EAAM,QAIxC,IAAK,aAAkBzW,EAAAisB,GAAQsB,KAAMA,KAAKhgB,GAAIkJ,EAAO,EAAImB,GAAe2V,KAAMA,KAAKhgB,GAAI,MACvF,IAAK,WAAgBvN,EAAAmsB,GAAQoB,KAAMA,KAAKhgB,GAAIkJ,EAAO,EAAImB,GAAe2V,KAAMA,KAAKhgB,GAAI,MAErF,IAAK,SAAcvN,EAAAqsB,GAASkB,KAAMA,KAAKhgB,GAAIkJ,EAAO,EAAI,EAAImB,GAAe2V,KAAMA,KAAKhgB,GAAI,MAExF,IAAK,OAAQkJ,EAAO,EAAKmB,GAAe2V,KAAMA,KAAKhgB,GAAQvN,EAAAusB,GAAOgB,KAAMA,KAAKhgB,GAAc,EAAPkJ,IAAqBA,GAAA,GAAG,MAE5G,IAAK,QAASA,EAAO,EAAKmB,GAAe2V,KAAMA,KAAKhgB,GAAQvN,EAAAysB,GAAQc,KAAMA,KAAKhgB,GAAc,EAAPkJ,IAAqBA,GAAA,GAAY,EAAPA,IAAc,MAE9H,IAAK,OACJ,IADmBA,EAAA,EAAOzW,EAAA,GACqB,KAAxCiI,EAAE6jB,GAAYyB,KAAMA,KAAKhgB,EAAIkJ,OAAiB6W,EAAAlY,KAAK5V,EAASyI,IAC/DjI,EAAAstB,EAAGzqB,KAAK,IAAK,MAClB,IAAK,QACJ,IADoB4T,EAAA,EAAOzW,EAAA,GACmB,KAAvCiI,EAAEyjB,GAAe6B,KAAKA,KAAKhgB,EAAGkJ,KAAe6W,EAAAlY,KAAK5V,EAASyI,IAAUwO,GAAA,EACtEA,GAAA,EAAOzW,EAAAstB,EAAGzqB,KAAK,IAAK,MAG3B,IAAK,YACJ,IADqB7C,EAAA,GAAIqtB,EAAME,KAAKhgB,EAChC/M,EAAI,EAAGA,EAAIiW,IAAQjW,EAAG,CACzB,GAAG+sB,KAAKC,OAAuC,IAA/BD,KAAKC,KAAKpuB,QAAQiuB,GAI1B,OAHHplB,EAAA6jB,GAAYyB,KAAMF,GACtBE,KAAKhgB,EAAI8f,EAAM,EACf7e,EAAKgW,GAAUlhB,KAAKiqB,KAAM9W,EAAKjW,EAAGyH,EAAI,YAAc,aAC7CqlB,EAAGzqB,KAAK,IAAM2L,EAEtB8e,EAAGlY,KAAK5V,EAASksB,GAAe6B,KAAMF,KACjCA,GAAA,CACT,CAASrtB,EAAAstB,EAAGzqB,KAAK,IAAa4T,GAAA,EAAG,MAE/B,IAAK,QAML,IAAK,YACJ,IADqBzW,EAAA,GAAIqtB,EAAME,KAAKhgB,EAChC/M,EAAI,EAAGA,GAAKiW,IAAQjW,EAAG,CAC1B,GAAG+sB,KAAKC,OAAuC,IAA/BD,KAAKC,KAAKpuB,QAAQiuB,GAI1B,OAHHplB,EAAA6jB,GAAYyB,KAAMF,GACtBE,KAAKhgB,EAAI8f,EAAM,EACf7e,EAAKgW,GAAUlhB,KAAKiqB,KAAM9W,EAAKjW,EAAGyH,EAAI,YAAc,aAC7CqlB,EAAGzqB,KAAK,IAAM2L,EAEtB8e,EAAGlY,KAAK5V,EAASssB,GAAYyB,KAAMF,KAC9BA,GAAA,CACL,CAAKrtB,EAAAstB,EAAGzqB,KAAK,IAAK,MAEpB,QACD,OAAO4T,GACN,KAAK,EAAoD,OAA5C0W,EAAArB,GAAYyB,KAAMA,KAAKhgB,GAASggB,KAAAhgB,IAAY4f,EACzD,KAAK,EAAwF,OAArFA,GAAY,MAANtpB,EAAYopB,GAAgBvB,IAAgB6B,KAAMA,KAAKhgB,GAAIggB,KAAKhgB,GAAK,EAAU4f,EAC7F,KAAK,EAAG,KAAK,EACT,MAAM,MAANtpB,GAAgC,IAAjB0pB,KAAKA,KAAKhgB,EAAE,IAClB6f,EAAAxV,GAAe2V,KAAMA,KAAKhgB,GAAIggB,KAAKhgB,GAAK,EAAY6f,IADfD,GAAO1W,EAAO,EAAKnB,GAAgB4X,IAAeK,KAAMA,KAAKhgB,GAAIggB,KAAKhgB,GAAK,EAAU4f,GAEvI,KAAK,EAAG,KAAK,EACZ,GAAS,MAANtpB,EAGkB,OAFNupB,EAAH,GAAR3W,EAAgBoW,GAASU,KAAMA,KAAKhgB,GAC7Bsf,GAAS,CAACU,KAAKA,KAAKhgB,EAAE,GAAGggB,KAAKA,KAAKhgB,EAAE,GAAGggB,KAAKA,KAAKhgB,EAAE,GAAGggB,KAAKA,KAAKhgB,EAAE,GAAGggB,KAAKA,KAAKhgB,EAAE,GAAGggB,KAAKA,KAAKhgB,EAAE,GAAGggB,KAAKA,KAAKhgB,EAAE,GAAGggB,KAAKA,KAAKhgB,EAAE,IAAK,GAC9IggB,KAAKhgB,GAAK,EAAU6f,EACP3W,EAAA,EAEf,KAAK,GAAIzW,EAAI4rB,GAAU2B,KAAMA,KAAKhgB,EAAGkJ,IAEjB,OAArB8W,KAAKhgB,GAAGkJ,EAAazW,CACtB,CAEA,IAAIytB,GAAkB,SAAStR,EAAuBnT,EAAgBS,GAA6B0S,EAAA1S,GAAc,IAANT,EAAamT,EAAE1S,EAAI,GAAOT,IAAQ,EAAK,IAAOmT,EAAE1S,EAAI,GAAOT,IAAQ,GAAM,IAAOmT,EAAE1S,EAAI,GAAOT,IAAQ,GAAM,GAAQ,EAC1N0kB,GAAkB,SAASvR,EAAuBnT,EAAgBS,GAA6B0S,EAAA1S,GAAc,IAANT,EAAamT,EAAE1S,EAAI,GAAOT,GAAO,EAAK,IAAOmT,EAAE1S,EAAI,GAAOT,GAAO,GAAM,IAAOmT,EAAE1S,EAAI,GAAOT,GAAO,GAAM,GAAQ,EACvN2kB,GAAkB,SAASxR,EAAuBnT,EAAgBS,GAA6B0S,EAAA1S,GAAc,IAANT,EAAamT,EAAE1S,EAAI,GAAOT,IAAQ,EAAK,GAAQ,EAE1J,SAAS4kB,GAAW/pB,EAAcmF,EAAuBoE,GACpD,IAAAqJ,EAAO,EAAGjW,EAAI,EAClB,GAAS,SAAN4M,EAAc,CAEhB,IAAI5M,EAAI,EAAGA,GAAKwI,EAAIvI,SAAUD,EAAGmtB,GAAgBJ,KAAMvkB,EAAItI,WAAWF,GAAI+sB,KAAKhgB,EAAI,EAAI/M,GACvFiW,EAAO,EAAIzN,EAAIvI,MACjB,MAAA,GAAiB,SAAN2M,EAAc,CAYtB,IAFMpE,EAAAA,EAAIlI,QAAQ,gBAAiB,KAE/BN,EAAI,EAAGA,GAAKwI,EAAIvI,SAAUD,EAAQ+sB,KAAAA,KAAKhgB,EAAI/M,GAA0B,IAApBwI,EAAItI,WAAWF,GAErEiW,EAAOzN,EAAIvI,MACb,KAAA,IAAiB,QAAN2M,EAAa,CAChB,KAAA5M,EAAIqD,IAAKrD,EAEd+sB,KAAKA,KAAKhgB,KAAQ7B,SAAS1C,EAAI3F,MAAM,EAAE7C,EAAG,EAAEA,EAAE,GAAI,KAAK,EAC/C,OAAA+sB,IACX,CAAA,GAAiB,YAANngB,EAAiB,CAEzB,IAAIwV,EAAiB1e,KAAKgI,IAAIqhB,KAAKhgB,EAAI1J,EAAG0pB,KAAK9sB,QAC3C,IAAAD,EAAI,EAAGA,EAAI0D,KAAKgI,IAAIlD,EAAIvI,OAAQoD,KAAMrD,EAAG,CACxC,IAAAgK,EAAKxB,EAAItI,WAAWF,GACnB+sB,KAAAA,KAAKhgB,KAAa,IAAL/C,EACb+iB,KAAAA,KAAKhgB,KAAQ/C,GAAM,CAC5B,CACG,KAAM+iB,KAAKhgB,EAAIqV,GAAU2K,KAAAA,KAAKhgB,KAAO,EAC9B,OAAAggB,IACR,QAAiD1pB,GACjD,KAAM,EAAU4S,EAAA,EAAQ8W,KAAAA,KAAKhgB,GAAS,IAAJvE,EAAU,MAC5C,KAAM,EAAUyN,EAAA,EAAQ8W,KAAAA,KAAKhgB,GAAS,IAAJvE,EAAmBA,KAAA,EAAGukB,KAAKA,KAAKhgB,EAAE,GAAS,IAAJvE,EAAU,MACnF,KAAM,EAAUyN,EAAA,EAAQ8W,KAAAA,KAAKhgB,GAAS,IAAJvE,EAAmBA,KAAA,EAAGukB,KAAKA,KAAKhgB,EAAE,GAAS,IAAJvE,EAAmBA,KAAA,EAAGukB,KAAKA,KAAKhgB,EAAE,GAAS,IAAJvE,EAAU,MAC1H,KAAM,EAAUyN,EAAA,EAAmBgX,GAAAF,KAAMvkB,EAAKukB,KAAKhgB,GAAI,MACvD,KAAM,EAAa,GAAHkJ,EAAA,EAAY,MAANrJ,EAAW,EA/MnC,SAAyB+O,EAAuBxY,EAAc8F,GACzD,IAAAokB,GAASlqB,EAAI,GAAO,EAAEA,IAAK,IAAc,EAAI,IAAM,EAAIpC,EAAI,EAAGgF,EAAI,EAClEunB,EAAKD,GAAOlqB,EAAKA,EACjBolB,SAAS+E,GACC,GAANA,EAASvsB,EAAIgF,EAAI,GAExBhF,EAAI2C,KAAKwB,MAAMxB,KAAK4D,IAAIgmB,GAAM5pB,KAAK6pB,KACnCxnB,EAAIunB,EAAK5pB,KAAKC,IAAI,EAAG,GAAK5C,GACtBA,IAAgB,QAACwnB,SAASxiB,IAAOA,EAAIrC,KAAKC,IAAI,EAAE,KAAa5C,GAAA,MACrDgF,GAAArC,KAAKC,IAAI,EAAE,IAAQ5C,GAAA,QANRA,EAAA,KAAWgF,EAAA5F,MAAMgD,GAAK,MAAS,GAQvD,IAAA,IAAQnD,EAAI,EAAGA,GAAK,IAAKA,EAAG+F,GAAG,IAAO4V,EAAA1S,EAAMjJ,GAAS,IAAJ+F,EACjD4V,EAAE1S,EAAM,IAAW,GAAJlI,IAAa,EAAU,GAAJgF,EAClC4V,EAAE1S,EAAM,GAAMlI,GAAK,EAAKssB,CACzB,CAiMqDG,CAAAT,KAAMvkB,EAAKukB,KAAKhgB,GAAI,KAAM,CAE7E,KAAK,GAAI,MACT,KAAK,EAAWkJ,EAAA,EAAkBiX,GAAAH,KAAMvkB,EAAKukB,KAAKhgB,GACpD,CACwB,OAAvBggB,KAAKhgB,GAAKkJ,EAAa8W,IACxB,CAEA,SAAS9I,GAAWwJ,EAAmBC,GACtC,IAAI3nB,EAAIqlB,GAAU2B,KAAKA,KAAKhgB,EAAE0gB,EAAOxtB,QAAQ,GAC1C,GAAA8F,IAAM0nB,EAAc,MAAA,IAAIrlB,MAAMslB,EAAM,YAAcD,EAAS,QAAU1nB,GACnEgnB,KAAAhgB,GAAK0gB,EAAOxtB,QAAQ,CAC1B,CAEA,SAASoR,GAAUD,EAAMuc,GACxBvc,EAAKrE,EAAI4gB,EACJvc,EAAAG,WAAoByS,GACzB5S,EAAKqC,IAAMwQ,GACX7S,EAAKH,YAAcmc,EACpB,CAEA,SAASQ,GAAUxc,EAAMnR,GAAoCmR,EAAKrE,GAAK9M,CAAO,CAE9E,SAASgX,GAAQzF,GACZ,IAAAhS,EAAI2B,EAAYqQ,GAEb,OADPH,GAAU7R,EAAG,GACNA,CACR,CAuBA,SAASquB,KACR,IAAItrB,EAAwB,GAAIurB,EAAQvtB,EAAU,IAAM,KACpDwtB,EAAS,SAAmBvc,GAC3B,IAAAhS,EAAeyX,GAAQzF,GAEpB,OADPH,GAAU7R,EAAG,GACNA,CACP,EAEGwuB,EAAmBD,EAAOD,GAE1BG,EAAS,WACRD,IACDA,EAAO/tB,OAAS+tB,EAAOjhB,KAAKihB,EAASA,EAAOnrB,MAAM,EAAGmrB,EAAOjhB,IAAWA,EAAIihB,EAAO/tB,QAClF+tB,EAAO/tB,OAAS,GAAGsC,EAAKqS,KAAKoZ,GACvBA,EAAA,KACT,EAEGE,EAAO,SAAiB1c,GAC3B,OAAGwc,GAAWxc,EAAMwc,EAAO/tB,OAAS+tB,EAAOjhB,EAAYihB,GAC/CC,IACAD,EAASD,EAAOrqB,KAAKiI,IAAI6F,EAAG,EAAGsc,IACvC,EASD,MAAQ,CAAEI,OAAWtZ,KAFV,SAAiB5T,OAA8C,OAApBgtB,EAAAhtB,GAAe+L,IAAWihB,EAAOjhB,EAAIihB,EAAO/tB,QAAQiuB,EAAKJ,EAAS,EAExF1L,IAPtB,WAET,OADQ6L,IACD3rB,EAAQC,EACf,EAIwC4rB,MAAM5rB,EAChD,CAEA,SAAS6rB,GAAaC,EAAiB/lB,EAAiByO,EAAS9W,GAC5D,IAAsB8M,EAAtB1J,GAAgBiF,EACjB,IAAAnI,MAAMkD,GAAN,CACCpD,IAAQA,EAASquB,GAAejrB,GAAGqN,IAAMqG,GAAS,IAAI9W,QAAU,GACpE8M,EAAI,GAAK1J,GAAK,IAAO,EAAI,GAAK,EAC3BpD,GAAU,OAAQ8M,EAAM9M,GAAU,SAAU8M,EAAM9M,GAAU,WAAY8M,EACvE,IAAAvN,EAAI6uB,EAAGH,KAAKnhB,GACb1J,GAAK,IAAQ7D,EAAAyR,YAAY,EAAG5N,IAE9B7D,EAAEyR,YAAY,EAAgB,KAAR,IAAJ5N,IAChB7D,EAAAyR,YAAY,EAAI5N,GAAK,IAExB,IAAA,IAAQrD,EAAI,EAAQ,GAALA,IAAUA,EAAG,CAC3B,KAAGC,GAAU,KACR,CAAIT,EAAAyR,YAAY,EAAGhR,GAAS,KAAM,CADlBT,EAAEyR,YAAY,EAAmB,KAAN,IAAThR,IAAiCA,IAAA,CAE1E,CAC4BA,EAAS,GAAKqsB,GAAOvV,IAAUsX,EAAGzZ,KAAKmC,EAdrD,CAed,CAEA,SAASwX,GAAeC,EAAsB/c,EAAapM,GACtD,IAAAM,EAAMuiB,GAAIsG,GAQd,GAPG/c,EAAI9P,GACHgE,EAAI8oB,OAAU9oB,EAAAvD,GAAKqP,EAAI9P,EAAES,GACzBuD,EAAI+oB,OAAU/oB,EAAAiF,GAAK6G,EAAI9P,EAAEiJ,KAEzBjF,EAAI8oB,OAAU9oB,EAAAvD,GAAKqP,EAAIrP,GACvBuD,EAAI+oB,OAAU/oB,EAAAiF,GAAK6G,EAAI7G,KAEvBvF,GAAQA,EAAKspB,KAAO,GAAI,CAC3B,KAAMhpB,EAAIvD,GAAK,KAAOuD,EAAIvD,GAAK,IAC/B,KAAMuD,EAAIiF,GAAK,OAASjF,EAAIiF,GAAK,KACnC,CACQ,OAAAjF,CACR,CAEA,SAASipB,GAAgBJ,EAAMK,EAAOxpB,GACjC,IAAAM,EAAMuiB,GAAIsG,GAGP,OAFP7oB,EAAIhE,EAAI4sB,GAAe5oB,EAAIhE,EAAGktB,EAAMltB,EAAG0D,GACvCM,EAAI5E,EAAIwtB,GAAe5oB,EAAI5E,EAAG8tB,EAAMltB,EAAG0D,GAChCM,CACR,CAEA,SAASmpB,GAAgB1sB,EAAmBusB,GAC3C,GAAGvsB,EAAEqsB,MAAQrsB,EAAEA,EAAI,EAAiB,IAAZA,EAAI8lB,GAAI9lB,GAAUA,EAAEA,EAAI,KAAKA,GAAMusB,EAAO,EAAK,MAAS,IAChF,GAAGvsB,EAAEssB,MAAQtsB,EAAEwI,EAAI,EAAuB,IAAlBxI,EAAI8lB,GAAI9lB,GAAUA,EAAEwI,EAAI,GAAKxI,EAAAwI,GAAM+jB,EAAO,EAAK,QAAaA,EAAO,EAAK,MAAU,MACtG,IAAAhtB,EAAIotB,GAAY3sB,GAGb,OAFHA,EAAEqsB,MAAkB,MAAVrsB,EAAEqsB,OAAc9sB,EAAYA,EAyBgBrB,QAAQ,WAAW,SAxBzE8B,EAAEssB,MAAkB,MAAVtsB,EAAEssB,OAAc/sB,EAmB/B,SAAiBkX,GAAqC,OAAAA,EAAKvY,QAAQ,kBAAkB,SAAU,CAnB5D0uB,CAAQrtB,IACnCA,CACR,CAEA,SAASstB,GAAiBrkB,EAAGvF,GAC5B,OAAY,GAATuF,EAAEjJ,EAAEiJ,GAAWA,EAAEjJ,EAAE+sB,MAClB9jB,EAAE7J,EAAE6J,IAAMvF,EAAKspB,MAAQ,GAAK,QAAWtpB,EAAKspB,MAAQ,EAAI,MAAU,QAAa/jB,EAAE7J,EAAE2tB,KAI3E,GAAT9jB,EAAEjJ,EAAES,GAAWwI,EAAEjJ,EAAE8sB,MAClB7jB,EAAE7J,EAAEqB,IAAMiD,EAAKspB,MAAQ,GAAK,MAAS,MAAU/jB,EAAE7J,EAAE0tB,KAIhDK,GAAgBlkB,EAAEjJ,EAAG0D,EAAKspB,MAAQ,IAAMG,GAAgBlkB,EAAE7J,EAAGsE,EAAKspB,OAH/D/jB,EAAEjJ,EAAE+sB,KAAO,GAAK,KAAOQ,GAAWtkB,EAAEjJ,EAAEiJ,GAAK,KAAOA,EAAE7J,EAAE2tB,KAAO,GAAK,KAAOQ,GAAWtkB,EAAE7J,EAAE6J,IALxFA,EAAEjJ,EAAE8sB,KAAO,GAAK,KAAOU,GAAWvkB,EAAEjJ,EAAES,GAAK,KAAOwI,EAAE7J,EAAE0tB,KAAO,GAAK,KAAOU,GAAWvkB,EAAE7J,EAAEqB,EASnG,CACA,SAASgtB,GAAWC,GAAgC,OAAOnkB,SAAmBmkB,EAGjB/uB,QAAQ,WAAW,MAHM,IAAM,CAAE,CAC9F,SAAS4uB,GAAW7c,GAA6B,MAAO,IAAMA,EAAM,EAAG,CAIvE,SAASid,GAAWC,GAA+E,IAA/C,IAAIntB,EAAcmtB,EAGTjvB,QAAQ,aAAa,MAHH8C,EAAI,EAAGpD,EAAI,EAASA,IAAMoC,EAAEnC,SAAUD,EAAOoD,EAAA,GAAGA,EAAIhB,EAAElC,WAAWF,GAAK,GAAI,OAAOoD,EAAI,CAAE,CACtK,SAAS+rB,GAAWK,GAA6B,GAAGA,EAAM,EAAG,MAAM,IAAIpnB,MAAM,kBAAoBonB,GAAM,IAAI7tB,EAAE,GAAI,MAAM6tB,EAAKA,EAAKA,EAAI9rB,KAAKwB,OAAOsqB,EAAI,GAAG,MAAStwB,OAAOC,cAAeqwB,EAAI,GAAG,GAAM,IAAM7tB,EAAU,OAAAA,CAAE,CAMtN,SAAS8tB,GAAY5W,GAEpB,IADI,IAAAhD,EAAI,EAAGzF,EAAI,EACPpQ,EAAI,EAAGA,EAAI6Y,EAAK5Y,SAAUD,EAAG,CAChC,IAAAgK,EAAK6O,EAAK3Y,WAAWF,GACtBgK,GAAM,IAAMA,GAAM,GAAQ6L,EAAA,GAAKA,GAAK7L,EAAK,IACpCA,GAAM,IAAMA,GAAM,KAAQoG,EAAA,GAAKA,GAAKpG,EAAK,IACnD,CACC,MAAO,CAAE5H,EAAGgO,EAAI,EAAGxF,EAAEiL,EAAI,EAC1B,CAEA,SAASkZ,GAAYP,GAGpB,IAFI,IAAAgB,EAAMhB,EAAKpsB,EAAI,EACfT,EAAE,GACA6tB,EAAKA,GAAMA,EAAI,GAAG,GAAI,EAAO7tB,EAAAzC,OAAOC,cAAeqwB,EAAI,GAAG,GAAM,IAAM7tB,EACrE,OAAAA,GAAK6sB,EAAK5jB,EAAI,EACtB,CACA,SAAS8kB,GAAab,GACjB,IAAA5lB,EAAM4lB,EAAMjwB,QAAQ,KACrB,OAAW,GAAXqK,EAAkB,CAAEtH,EAAG8tB,GAAYZ,GAAQ9tB,EAAG0uB,GAAYZ,IACtD,CAAEltB,EAAG8tB,GAAYZ,EAAMhsB,MAAM,EAAGoG,IAAOlI,EAAG0uB,GAAYZ,EAAMhsB,MAAMoG,EAAM,IAChF,CAEA,SAAS0mB,GAAaC,EAA0BC,GAC/C,YAAiB,IAAPA,GAAoC,iBAAPA,EAE/BF,GAAaC,EAAGjuB,EAAGiuB,EAAG7uB,IAGb,iBAAP6uB,IAAiBA,EAAKb,GAAaa,IAC5B,iBAAPC,IAAiBA,EAAKd,GAAac,IAGtCD,GAAMC,EAAKD,EAAKA,EAAK,IAAMC,EACnC,CAEA,SAASC,GAAkBjB,GAC1B,IAAIrvB,EAAI,CAACmC,EAAE,CAACS,EAAE,EAAEwI,EAAE,GAAG7J,EAAE,CAACqB,EAAE,EAAEwI,EAAE,IAC1B3B,EAAM,EAAGjJ,EAAI,EAAGgK,EAAK,EACrB5I,EAAMytB,EAAM5uB,OAChB,IAAIgJ,EAAM,EAAGjJ,EAAIoB,MACZ4I,EAAG6kB,EAAM3uB,WAAWF,GAAG,IAAM,GAAKgK,EAAK,MADpBhK,EAEvBiJ,EAAM,GAAGA,EAAMe,EAIhB,IAFExK,EAAAmC,EAAES,IAAM6G,EAENA,EAAM,EAAGjJ,EAAIoB,MACZ4I,EAAG6kB,EAAM3uB,WAAWF,GAAG,IAAM,GAAKgK,EAAK,KADpBhK,EAEvBiJ,EAAM,GAAGA,EAAMe,EAIb,GAFDxK,EAAAmC,EAAEiJ,IAAM3B,EAEPjJ,IAAMoB,GAAa,IAAN4I,EAA6C,OAA/BxK,EAAAuB,EAAEqB,EAAE5C,EAAEmC,EAAES,EAAK5C,EAAAuB,EAAE6J,EAAEpL,EAAEmC,EAAEiJ,EAAUpL,EAG7D,MAFEQ,EAEEiJ,EAAM,EAAGjJ,GAAKoB,MACb4I,EAAG6kB,EAAM3uB,WAAWF,GAAG,IAAM,GAAKgK,EAAK,MADnBhK,EAExBiJ,EAAM,GAAGA,EAAMe,EAIhB,IAFExK,EAAAuB,EAAEqB,IAAM6G,EAENA,EAAM,EAAGjJ,GAAKoB,MACb4I,EAAG6kB,EAAM3uB,WAAWF,GAAG,IAAM,GAAKgK,EAAK,KADnBhK,EAExBiJ,EAAM,GAAGA,EAAMe,EAGT,OADLxK,EAAAuB,EAAE6J,IAAM3B,EACHzJ,CACR,CAEA,SAASuwB,GAAiBvB,EAAerrB,GACxC,IAAIgC,EAAe,KAAVqpB,EAAKnrB,GAAYF,aAAakD,KACpC,GAAU,MAAVmoB,EAAKwB,EAAe,IAAU,OAAAxB,EAAK/mB,EAAIU,GAAWqmB,EAAKwB,EAAG7qB,EAAI+hB,GAAQ/jB,GAAKA,EAAI,OAASpC,GAAG,CAC1F,IAAE,OAAQytB,EAAK/mB,EAAIU,IAAYqmB,EAAKyB,IAAI,CAAE,GAAEC,WAAW/qB,EAAI,GAAK,GAAKA,EAAI+hB,GAAQ/jB,GAAKA,EAAM,OAAOpC,GAAK,MAAO,GAAGoC,CAAE,CACzH,CAEA,SAASgtB,GAAY3B,EAAerrB,EAAW3D,GAC3C,OAAQ,MAARgvB,GAA0B,MAAVA,EAAKnrB,GAAuB,KAAVmrB,EAAKnrB,EAAiB,QAC7C,IAAXmrB,EAAK/mB,EAAwB+mB,EAAK/mB,GACxB,KAAV+mB,EAAKnrB,IAAamrB,EAAKwB,GAAKxwB,GAAKA,EAAE2N,SAAaqhB,EAAAwB,EAAIxwB,EAAE2N,QAC5C,KAAVqhB,EAAKnrB,EAAiB+sB,GAAK5B,EAAKrrB,IAAMqrB,EAAKrrB,EACpB4sB,GAAiBvB,EAAnC,MAALrrB,EAA8CqrB,EAAKrrB,EACxBA,GAC/B,CAEA,SAASktB,GAAkBC,EAAqBjrB,GAC/C,IAAIwJ,EAAIxJ,GAAQA,EAAKirB,MAAQjrB,EAAKirB,MAAQ,SACtCC,EAAS,CAAE,EACf,OADiBA,EAAO1hB,GAAKyhB,EACtB,CAAEE,WAAY,CAAC3hB,GAAI4hB,OAAQF,EACnC,CAEA,SAASG,GAAcC,EAAoBzuB,EAAcmD,GACpD,IAAA7F,EAAI6F,GAAQ,CAAE,EACdurB,EAAQD,EAAMpvB,MAAMY,QAAQwuB,GAAOnxB,EAAEoxB,MAErCC,EAAmBF,IAAQC,EAAS,GAAe,CAAE,GACrDE,EAAK,EAAGC,EAAK,EACd,GAAAF,GAAkB,MAAZrxB,EAAEwxB,OAAgB,CAC1B,GAAsB,iBAAZxxB,EAAEwxB,SAAyBxxB,EAAEwxB,WAClC,CACA,IAAAC,EAA6C,iBAAZzxB,EAAEwxB,OAAqBvB,GAAYjwB,EAAEwxB,QAAUxxB,EAAEwxB,OACtFF,EAAKG,EAAQrmB,EAAGmmB,EAAKE,EAAQ7uB,CAChC,CACMyuB,EAAG,UAASA,EAAG,QAAU,QAC/B,CACC,IAAIhC,EAAmB,CAACltB,EAAG,CAACS,EAAE,IAAUwI,EAAE,KAAW7J,EAAG,CAACqB,EAAE,EAAGwI,EAAE,IAC7D,GAAAimB,EAAG,QAAS,CACd,IAAIK,EAASpB,GAAkBe,EAAG,SAC5BhC,EAAAltB,EAAES,EAAI8uB,EAAOvvB,EAAES,EACfysB,EAAAltB,EAAEiJ,EAAIsmB,EAAOvvB,EAAEiJ,EACfikB,EAAA9tB,EAAEqB,EAAIsB,KAAKiI,IAAIkjB,EAAM9tB,EAAEqB,EAAG8uB,EAAOnwB,EAAEqB,GACnCysB,EAAA9tB,EAAE6J,EAAIlH,KAAKiI,IAAIkjB,EAAM9tB,EAAE6J,EAAGsmB,EAAOnwB,EAAE6J,OACtCkmB,IAAgBjC,EAAA9tB,EAAE6J,EAAIkmB,EAAKI,EAAOnwB,EAAE6J,EAAI,EAC7C,CACC,IAAA,IAAQiL,EAAI,EAAGA,GAAK3T,EAAKjC,SAAU4V,EAC/B,GAAC3T,EAAK2T,GAAN,CACA,IAACtU,MAAMY,QAAQD,EAAK2T,IAAK,MAAM,IAAIzN,MAAM,2CACpC,IAAA,IAAAgI,EAAI,EAAGA,GAAKlO,EAAK2T,GAAG5V,SAAUmQ,EACrC,QAAyB,IAAflO,EAAK2T,GAAGzF,GAAlB,CACA,IAAIoe,EAAiB,CAACrrB,EAAGjB,EAAK2T,GAAGzF,IAC7B+gB,EAAML,EAAKjb,EAAGub,EAAML,EAAK3gB,EAK7B,GAJGye,EAAMltB,EAAEiJ,EAAIumB,IAAKtC,EAAMltB,EAAEiJ,EAAIumB,GAC7BtC,EAAMltB,EAAES,EAAIgvB,IAAKvC,EAAMltB,EAAES,EAAIgvB,GAC7BvC,EAAM9tB,EAAE6J,EAAIumB,IAAKtC,EAAM9tB,EAAE6J,EAAIumB,GAC7BtC,EAAM9tB,EAAEqB,EAAIgvB,IAAKvC,EAAM9tB,EAAEqB,EAAIgvB,IAC7BlvB,EAAK2T,GAAGzF,IAA4B,iBAAflO,EAAK2T,GAAGzF,IAAoB7O,MAAMY,QAAQD,EAAK2T,GAAGzF,KAASlO,EAAK2T,GAAGzF,aAAc/J,KAGrG,GADA9E,MAAMY,QAAQqsB,EAAKrrB,KAAMqrB,EAAK5hB,EAAI1K,EAAK2T,GAAGzF,GAAG,GAASoe,EAAArrB,EAAIqrB,EAAKrrB,EAAE,IACtD,OAAXqrB,EAAKrrB,EACJ,GAAAqrB,EAAK5hB,EAAG4hB,EAAKnrB,EAAI,SAAA,GACZ7D,EAAE6xB,UAAa7C,EAAKnrB,EAAI,IAAKmrB,EAAKrrB,EAAI,MAAE,KACvC3D,EAAE8xB,WAAY,WACbjuB,EAAI,GAAA,KAEW,iBAAXmrB,EAAKrrB,IAAqBE,EAAI,IACnB,kBAAXmrB,EAAKrrB,IAAsBE,EAAI,IACtCmrB,EAAKrrB,aAAakD,MACzBmoB,EAAKwB,EAAIxwB,EAAE2N,QAAUhJ,EAAU,IAC5B3E,EAAE+xB,WAAa/C,EAAKnrB,EAAI,IAAKmrB,EAAK/mB,EAAIU,GAAWqmB,EAAKwB,EAAG9I,GAAQsH,EAAKrrB,MAClEqrB,EAAKnrB,EAAI,IAAUmrB,EAAArrB,EAAI+jB,GAAQsH,EAAKrrB,GAAIqrB,EAAK/mB,EAAIU,GAAWqmB,EAAKwB,EAAGxB,EAAKrrB,OAEvEE,EAAI,SAhBiGmrB,EAAOtsB,EAAK2T,GAAGzF,GAkB/H,GAAGwgB,EACEC,EAAGM,KAASN,EAAAM,GAAO,IACpBN,EAAGM,GAAKC,IAAQP,EAAGM,GAAKC,GAAKpB,IAAQxB,EAAAwB,EAAIa,EAAGM,GAAKC,GAAKpB,GACtDa,EAAAM,GAAKC,GAAO5C,MACT,CACN,IAAIgD,EAAWzC,GAAa,CAAC3sB,EAAEgvB,EAAIxmB,EAAEumB,IAClCN,EAAGW,IAAaX,EAAGW,GAAUxB,IAAQxB,EAAAwB,EAAIa,EAAGW,GAAUxB,GACzDa,EAAGW,GAAYhD,CACnB,CAjCyC,CAH1B,CAwCP,OADJK,EAAMltB,EAAES,EAAI,QAAa,QAAUutB,GAAad,IAC5CgC,CACR,CACA,SAASY,GAAavvB,EAAcmD,GAAsC,OAAAqrB,GAAc,KAAMxuB,EAAMmD,EAAM,CAK1G,SAASqsB,GAAezyB,EAAcO,GAG9B,OAFFA,IAAOA,EAAAyX,GAAQ,IAClBzX,EAAAyR,YAAY,EAAGhS,GACVO,CACR,CAGA,SAASmyB,GAAmBzvB,GACvB,IAAA0vB,EAAgB1vB,EAAKqP,WAAW,GACpC,OAAyB,IAAlBqgB,EAAsB,GAAK1vB,EAAKqP,WAAWqgB,EAAe,OAClE,CACA,SAASC,GAAmB3vB,EAAiB1C,GAC5C,IAAIsyB,GAAQ,EAGZ,OAH4B,MAALtyB,IAAqBsyB,GAAA,EAAMtyB,EAAIyX,GAAQ,EAAI,EAAI/U,EAAKjC,SACzET,EAAAyR,YAAY,EAAG/O,EAAKjC,QAClBiC,EAAKjC,OAAS,KAAKgR,YAAY,EAAG/O,EAAM,QACrC4vB,EAAQtyB,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,CAClC,CASA,SAASuyB,GAAa7vB,GACd,MAAA,CAAE8vB,IAAK9vB,EAAKqP,WAAW,GAAI0gB,KAAM/vB,EAAKqP,WAAW,GACzD,CASA,SAAS2gB,GAAchwB,EAAMjC,GAC5B,IAAI+V,EAAQ9T,EAAK6K,EACbuE,EAAQpP,EAAKqP,WAAW,GACxBxH,EAAM4nB,GAAmBzvB,GACzBiwB,EAAY,GACZnC,EAAK,CAAE3sB,EAAG0G,EAAKgS,EAAGhS,GACjB,GAAQ,EAARuH,EAAkB,CAGb,IADL,IAAA8gB,EAAelwB,EAAKqP,WAAW,GAC1BvR,EAAI,EAAGA,GAAKoyB,IAAgBpyB,EAAamyB,EAAAvd,KAAKmd,GAAa7vB,IACpE8tB,EAAEplB,EAAIunB,CACR,QACQvnB,EAAI,CAAC,CAAEonB,IAAK,EAAGC,KAAM,IAKrB,OADP/vB,EAAK6K,EAAIiJ,EAAQ/V,EACV+vB,CACR,CASA,IAAIqC,GAAuBH,GAC3B,SAASI,GAAqBvoB,EAAkBvK,GAE/C,IAAIsyB,GAAQ,EAKZ,OAL4B,MAALtyB,IAAqBsyB,GAAA,EAAMtyB,EAAIyX,GAAQ,GAAK,EAAIlN,EAAI1G,EAAEpD,SAC3ET,EAAAyR,YAAY,EAAG,GACE4gB,GAAA9nB,EAAI1G,EAAG7D,GACxBA,EAAAyR,YAAY,EAAG,GAzClB,SAAsBshB,EAAK/yB,GACrBA,IAAOA,EAAAyX,GAAQ,IAClBzX,EAAAyR,YAAY,EAAc,GAC1BzR,EAAAyR,YAAY,EAAe,EAE9B,CAqCcuhB,CAAA,EAAqBhzB,GAC3BsyB,EAAQtyB,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,CAClC,CAGA,SAASizB,GAAevwB,GACnB,IAAAstB,EAAMttB,EAAKqP,WAAW,GACtBmhB,EAAYxwB,EAAKqP,WAAW,GAGzB,OAFMmhB,GAAAxwB,EAAKqP,WAAW,IAAM,GAC9BrP,EAAA6K,IACE,CAAE3K,EAAGotB,EAAKkD,YAClB,CACA,SAASC,GAAenE,EAAchvB,GAK9B,OAJE,MAALA,IAAeA,EAAAyX,GAAQ,IACzBzX,EAAAyR,aAAgB,EAAAud,EAAKpsB,GACvB5C,EAAEyR,YAAY,EAAGud,EAAKkE,WAAalE,EAAK7sB,GACtCnC,EAAAyR,YAAY,EAAG,GACVzR,CACR,CAGA,SAASozB,GAAoB1wB,GACxB,IAAAwwB,EAAYxwB,EAAKqP,WAAW,GAGzB,OAFMmhB,GAAAxwB,EAAKqP,WAAW,IAAK,GAC7BrP,EAAA6K,IACE,CAAE3K,GAAE,EAAIswB,YAChB,CACA,SAASG,GAAoBrE,EAAchvB,GAInC,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,IAC1BzX,EAAEyR,YAAY,EAAGud,EAAKkE,WAAalE,EAAK7sB,GACtCnC,EAAAyR,YAAY,EAAG,GACVzR,CACR,CAGA,IAAIszB,GAAqBnB,GACrBoB,GAAqBlB,GAGzB,SAASmB,GAA2B9wB,GAC/B,IAAA0vB,EAAgB1vB,EAAKqP,WAAW,GAC7B,OAAkB,IAAlBqgB,GAAyC,aAAlBA,EAA+B,GAAK1vB,EAAKqP,WAAWqgB,EAAe,OAClG,CACA,SAASqB,GAA2B/wB,EAAiB1C,GACpD,IAAIsyB,GAAQ,EAGZ,OAH4B,MAALtyB,IAAqBsyB,GAAA,EAAMtyB,EAAIyX,GAAQ,MAC9DzX,EAAEyR,YAAY,EAAG/O,EAAKjC,OAAS,EAAIiC,EAAKjC,OAAS,YAC7CiC,EAAKjC,OAAS,KAAKgR,YAAY,EAAG/O,EAAM,QACrC4vB,EAAQtyB,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,CAClC,CAGA,IAAI0zB,GAAyBvB,GAIzBwB,GAAcH,GACdI,GAAcH,GAIlB,SAASI,GAAenxB,GACvB,IAAIyZ,EAAIzZ,EAAKW,MAAMX,EAAK6K,EAAG7K,EAAK6K,EAAI,GAChCumB,EAAgB,EAAP3X,EAAE,GAAS4X,EAAe,EAAP5X,EAAE,GAClCzZ,EAAK6K,GAAK,EACV,IAAIymB,EAAc,IAATD,EAAalH,GAAS,CAAC,EAAG,EAAG,EAAG,EAAW,IAAP1Q,EAAE,GAAYA,EAAE,GAAIA,EAAE,GAAIA,EAAE,IAAK,GAAK7G,GAAc6G,EAAG,IAAM,EACnG,OAAA2X,EAASE,EAAK,IAAOA,CAC7B,CACA,SAASC,GAAevxB,EAAiB1C,GAC/B,MAALA,IAAeA,EAAAyX,GAAQ,IAC3B,IAAIqc,EAAQ,EAAGC,EAAO,EAAGG,EAAc,IAAPxxB,EAG5B,GAFCA,IAAgB,EAAPA,IAAeA,IAAwB,WAAAA,EAAQ,GAAK,GAAeqxB,EAAA,EACvEG,IAAgB,EAAPA,IAAeA,IAAwB,WAAAA,EAAQ,GAAK,KAAeH,EAAA,EAAWD,EAAA,IAC7FC,EACO,MAAA,IAAInrB,MAAM,wBAA0BlG,KADnC+O,aAAY,IAAMqiB,EAAQI,EAAOxxB,IAAS,IAAMoxB,EAAQ,GAErE,CAIA,SAASK,GAAUzxB,GAClB,IAAIssB,EAAkB,CAAE7sB,EAAG,CAAE,EAAEZ,EAAG,CAAE,GAK7B,OAJPytB,EAAK7sB,EAAEiJ,EAAI1I,EAAKqP,WAAW,GAC3Bid,EAAKztB,EAAE6J,EAAI1I,EAAKqP,WAAW,GAC3Bid,EAAK7sB,EAAES,EAAIF,EAAKqP,WAAW,GAC3Bid,EAAKztB,EAAEqB,EAAIF,EAAKqP,WAAW,GACpBid,CACR,CAWA,IAAIoF,GAAqBD,GACrBE,GAXJ,SAAmBjpB,EAAapL,GAMxB,OALFA,IAAOA,EAAAyX,GAAQ,KACpBzX,EAAEyR,YAAY,EAAGrG,EAAEjJ,EAAEiJ,GACrBpL,EAAEyR,YAAY,EAAGrG,EAAE7J,EAAE6J,GACrBpL,EAAEyR,YAAY,EAAGrG,EAAEjJ,EAAES,GACrB5C,EAAEyR,YAAY,EAAGrG,EAAE7J,EAAEqB,GACd5C,CACR,EA4BA,SAASs0B,GAAW5xB,GACnB,GAAGA,EAAKjC,OAASiC,EAAK6K,EAAI,EAAS,KAAA,4BAC5B,OAAA7K,EAAKqP,WAAW,EAAG,IAC3B,CACA,SAASwiB,GAAW7xB,EAAM1C,GAAK,OAAQA,GAAKyX,GAAQ,IAAIhG,YAAY,EAAG/O,EAAM,IAAK,CAmClF,SAAS8xB,GAAepe,EAAOpW,GAE1B,GADCA,IAAOA,EAAAyX,GAAQ,KACfrB,GAASA,EAAMqe,KAAyD,OAA/Cz0B,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GAAWzR,EAC1D,MAAfoW,EAAMse,OACP10B,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG2E,EAAMse,QACE,MAAfte,EAAMue,OACd30B,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG2E,EAAMue,SAErB30B,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,IAEd,IAAAmjB,EAAMxe,EAAMye,MAAQ,EAIxB,GAHID,EAAM,EAAUA,GAAA,MACXA,EAAM,IAAUA,GAAA,OACvB50B,EAAAyR,YAAY,EAAGmjB,GACZxe,EAAM0e,KAAsB,MAAf1e,EAAMue,MAIjB,CACF,IAAAG,EAAO1e,EAAM0e,KAAO,SACN,iBAAPA,IAAwBA,GAAA,SAAWA,EAAIpsB,SAAS,KAAKrF,OAAQ,IACtErD,EAAAyR,YAAY,EAAG/F,SAASopB,EAAIzxB,MAAM,EAAG,GAAI,KACzCrD,EAAAyR,YAAY,EAAG/F,SAASopB,EAAIzxB,MAAM,EAAG,GAAI,KACzCrD,EAAAyR,YAAY,EAAG/F,SAASopB,EAAIzxB,MAAM,EAAG,GAAI,KACzCrD,EAAAyR,YAAY,EAAG,IACnB,MAVIzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GASX,OAAAzR,CACR,CAoDA,IAoCI+0B,GAAc,GAKdC,GAAmB,CACf,EAAa,CAAE3lB,EAAG,WAAYxL,EA1CpB,GA2CV,EAAa,CAAEwL,EAAG,WAAYxL,EAAGkxB,IACjC,EAAa,CAAE1lB,EAAG,qBAAsBxL,EAAGkxB,IAC3C,EAAa,CAAE1lB,EAAG,YAAaxL,EA5CrB,GA6CV,EAAa,CAAEwL,EAAG,YAAaxL,EA7CrB,GA8CV,EAAa,CAAEwL,EAAG,iBAAkBxL,EA9C1B,GA+CV,EAAa,CAAEwL,EAAG,aAAcxL,EA/CtB,GAgDV,EAAa,CAAEwL,EAAG,YAAaxL,EAhDrB,GAiDV,EAAa,CAAEwL,EAAG,cAAexL,EAjDvB,GAkDV,GAAa,CAAEwL,EAAG,sBAAuBxL,EAlD/B,GAmDV,GAAa,CAAEwL,EAAG,YAAaxL,EA5CrB,IA6CV,GAAa,CAAEwL,EAAG,eAAgBxL,EArBlB,MAsBhB,GAAa,CAAEwL,EAAG,gBAAiBxL,EArBnB,MAsBhB,GAAa,CAAEwL,EAAG,UAAWxL,EAAGkxB,IAChC,GAAa,CAAE1lB,EAAG,UAAWxL,EAAGkxB,IAChC,GAAa,CAAE1lB,EAAG,gBAAiBxL,EAjDzB,IAkDV,GAAa,CAAEwL,EAAG,iBAAkBxL,EAzD1B,GA0DV,GAAa,CAAEwL,EAAG,YAAaxL,EAnDrB,IAoDV,GAAa,CAAEwL,EAAG,oBAAqBxL,EApD7B,IAqDV,GAAa,CAAEwL,EAAG,aAAcxL,EA5DtB,EA4DgCqN,EAAG,WAC7C,GAAa,CAAE7B,EAAG,SAAUxL,EAxClB,IAyCV,GAAa,CAAEwL,EAAG,cAAexL,EAAGkxB,IACpC,GAAa,CAAE1lB,EAAG,gBAAiBxL,EAAGkxB,IACtC,GAAa,CAAE1lB,EAAG,WAAYxL,EAAGkxB,IACjC,GAAa,CAAE1lB,EAAG,UAAWxL,EAAGkxB,IAChC,IAAa,CAAE,EAEf,WAAmB,CAAE1lB,EAAG,SAAUxL,EAvDxB,IAwDV,WAAmB,CAAEwL,EAAG,WAAYxL,EAxD1B,IAyDV,WAAmB,CAAA,GAIvBoxB,GAAe,CACX,EAAa,CAAE5lB,EAAG,WAAYxL,EA5EpB,GA6EV,EAAa,CAAEwL,EAAG,QAASxL,EAAGkxB,IAC9B,EAAa,CAAE1lB,EAAG,UAAWxL,EAAGkxB,IAChC,EAAa,CAAE1lB,EAAG,SAAUxL,EAAGkxB,IAC/B,EAAa,CAAE1lB,EAAG,WAAYxL,EAAGkxB,IACjC,EAAa,CAAE1lB,EAAG,WAAYxL,EAAGkxB,IACjC,EAAa,CAAE1lB,EAAG,WAAYxL,EAAGkxB,IACjC,EAAa,CAAE1lB,EAAG,aAAcxL,EAAGkxB,IACnC,EAAa,CAAE1lB,EAAG,YAAaxL,EAAGkxB,IAClC,GAAa,CAAE1lB,EAAG,WAAYxL,EAhEpB,IAiEV,GAAa,CAAEwL,EAAG,cAAexL,EAjEvB,IAkEV,GAAa,CAAEwL,EAAG,cAAexL,EAlEvB,IAmEV,GAAa,CAAEwL,EAAG,eAAgBxL,EAnExB,IAoEV,GAAa,CAAEwL,EAAG,YAAaxL,EAxFrB,GAyFV,GAAa,CAAEwL,EAAG,YAAaxL,EAzFrB,GA0FV,GAAa,CAAEwL,EAAG,YAAaxL,EA1FrB,GA2FV,GAAa,CAAEwL,EAAG,YAAaxL,EAhErB,IAiEV,GAAa,CAAEwL,EAAG,cAAexL,EAAGkxB,IACpC,GAAa,CAAE1lB,EAAG,cAAexL,EA7FvB,GA8FV,IAAa,CAAE,EAEf,WAAmB,CAAEwL,EAAG,SAAUxL,EAnFxB,IAoFV,WAAmB,CAAEwL,EAAG,WAAYxL,EApF1B,IAqFV,WAAmB,CAAA,GAgF3B,SAASqxB,GAAO5M,GAAoE,OAAAA,EAAIjmB,KAAI,SAAS5C,GAAY,MAAA,CAAEA,GAAG,GAAI,IAAKA,GAAG,EAAG,IAAM,IAAFA,EAAO,GAAI,CAIpJ,IA4FI01B,MA5F+BD,GAAA,CAElC,EACA,SACA,SACA,MACA,IACA,SACA,SACA,MAGA,EACA,SACA,SACA,MACA,IACA,SACA,SACA,MAEA,QACA,MACA,IACA,QACA,QACA,MACA,SACA,QACA,SACA,SACA,SACA,SACA,QACA,SACA,MACA,SAEA,IACA,SACA,SACA,MACA,QACA,QACA,MACA,IACA,MACA,SACA,SACA,SACA,SACA,SACA,SACA,SAEA,QACA,QACA,SACA,SACA,SACA,SACA,QACA,QACA,MACA,QACA,MACA,QACA,SACA,SACA,QACA,QAGA,SACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,KAKGtE,GAAO,CACH,EAAa,SACb,EAAa,UACb,GAAa,UACb,GAAa,QACb,GAAa,SACb,GAAa,QACb,GAAa,OACb,GAAa,gBACb,IAAa,SAmBjBwE,GAAgC,CAEnC,6EAA8E,YAC9E,uDAAwD,YACxD,0DAA2D,YAC3D,uDAAwD,YACxD,gFAAiF,YAGjF,4EAA6E,SAC7E,qCAAsC,SACtC,sCAAuC,OAGvC,6EAA8E,SAC9E,sCAAuC,SAGvC,0CAA2C,SAC3C,sCAAuC,SACvC,0CAA2C,OAC3C,sCAAuC,OAGvC,8EAA+E,UAC/E,uCAAwC,UAGxC,gFAAiF,OACjF,yCAA0C,OAG1C,yEAA0E,SAC1E,kCAAmC,SAGnC,6DAA8D,YAC9D,sEAAuE,YACvE,wEAAyE,WAGzE,wEAAyE,OACzE,6EAA8E,OAG9E,2EAA4E,WAC5E,oCAAqC,WACrC,gDAAiD,mBACjD,sCAAuC,SAGvC,gFAAiF,WACjF,yCAA0C,WAG1C,sCAAuC,OACvC,6EAA8E,OAG9E,oEAAqE,OAGrE,gDAAiD,OAGjD,2CAA4C,OAG5C,wCAAyC,OAGzC,qCAAsC,aACtC,4EAA6E,aAG7E,8EAA+E,OAG/E,oCAAqC,OACrC,wCAAyC,OAGzC,4CAA6C,OAG7C,uCAAwC,OACxC,8EAA+E,OAG/E,wCAAyC,QACzC,+EAAgF,QAGhF,gDAAiD,OACjD,6CAA8C,OAC9C,uFAAwF,OACxF,oFAAqF,OAGrF,sCAAuC,OACvC,6EAA8E,OAG9E,qCAAsC,OACtC,2CAA4C,OAC5C,uCAAwC,OACxC,kFAAmF,OACnF,8EAA+E,OAC/E,4EAA6E,OAG7E,4CAA6C,OAC7C,mFAAoF,OAGpF,kCAAmC,OACnC,uCAAwC,OACxC,sCAAuC,OACvC,2CAA4C,OAG5C,qCAAsC,OAGtC,iCAAkC,OAClC,wEAAyE,OAGzE,0DAA2D,SAG3D,kEAAmE,OAGnE,wCAAyC,OACzC,6CAA8C,OAG9C,uCAAwC,MACxC,gDAAiD,OAGjD,iDAAkD,OAClD,uFAAwF,OAGxF,iDAAkD,OAGlD,2DAA4D,OAG5D,sCAAuC,OAGvC,4DAA6D,WAC7D,0EAA2E,OAC3E,4EAA6E,OAC7E,0EAA2E,OAC3E,4EAA6E,OAC7E,2EAA4E,OAG5E,2DAA4D,OAE5D,2DAA4D,OAC5D,0DAA2D,OAG3D,YAAa,OAEbtE,MAAS,MAGNuE,GAAU,CACZC,UAAW,CACVC,KAAM,6EACNC,KAAM,uDACNC,KAAM,0DACNC,KAAM,uDACNC,KAAM,iFAEPC,KAAM,CACLL,KAAM,gFACNE,KAAM,0CAEPI,SAAU,CACTN,KAAM,2EACNE,KAAM,qCAEP1E,OAAQ,CACPwE,KAAM,4EACNE,KAAM,sCAEPK,OAAQ,CACPP,KAAM,6EACNE,KAAM,uCAEPM,QAAS,CACRR,KAAM,8EACNE,KAAM,wCAEPO,OAAQ,CACPT,KAAM,0CACNE,KAAM,uCAEPQ,SAAU,CACTV,KAAM,gFACNE,KAAM,0CAEPS,OAAQ,CACPX,KAAM,yEACNE,KAAM,oCAqCT,SAASU,GAASzf,EAAI7Q,GACjB,IAE0BlC,EAF1ByyB,EA55DL,SAAmBhP,GAElB,IADA,IAAIpnB,EAAsB,GAAasnB,EAAIR,GAAKM,GACxC5mB,EAAI,EAAGA,IAAM8mB,EAAE7mB,SAAUD,EACb,MAAhBR,EAAEonB,EAAIE,EAAE9mB,OAAcR,EAAEonB,EAAIE,EAAE9mB,KAAO,IACtCR,EAAAonB,EAAIE,EAAE9mB,KAAK4U,KAAKkS,EAAE9mB,IAEd,OAAAR,CACR,CAq5D2Cq2B,CAAUjB,IAEhDp1B,EAAsB,GACxBA,EAAAA,EAAES,QAAWopB,GACf7pB,EAAEA,EAAES,QAAUyqB,GAAU,QAAS,KAAM,CACtCoL,MAASjL,GACT,YAAaA,GACb,YAAaA,KAGdrrB,EAAIA,EAAEgD,OAAO,CACZ,CAAC,MAAO,mBACR,CAAC,MAAO,2DACR,CAAC,MAAO,4DACR,CAAC,OAAQ,4DAET,CAAC,MAAO,aACR,CAAC,MAAO,aACR,CAAC,MAAO,aACR,CAAC,MAAO,eACR,CAAC,MAAO,eACR,CAAC,MAAO,cAAe,CAAC,OAAQ,cAChC,CAAC,MAAO,cAAe,CAAC,OAAQ,cAChC,CAAC,MAAO,mBACR,CAAC,OAAQ,6DACRX,KAAI,SAAS5C,GACd,OAAOyrB,GAAU,UAAW,KAAM,CAACqL,UAAY92B,EAAE,GAAI+2B,YAAe/2B,EAAE,IACxE,KAGK,IAAAg3B,EAAK,SAASxuB,GACdyO,EAAGzO,IAAMyO,EAAGzO,GAAGxH,OAAS,IACtBkD,EAAA+S,EAAGzO,GAAG,GACVjI,EAAEA,EAAES,QAAWyqB,GAAU,WAAY,KAAM,CAC1CwL,UAAqB,KAAR/yB,EAAE,GAAY,GAAG,KAAOA,EACrC6yB,YAAenB,GAAQptB,GAAGpC,EAAK8wB,WAAatB,GAAQptB,GAAS,OAG/D,EAGG2uB,EAAK,SAAS3uB,IAChByO,EAAGzO,IAAI,IAAI4uB,SAAQ,SAASlzB,GAC5B3D,EAAEA,EAAES,QAAWyqB,GAAU,WAAY,KAAM,CAC1CwL,UAAqB,KAAR/yB,EAAE,GAAY,GAAG,KAAOA,EACrC6yB,YAAenB,GAAQptB,GAAGpC,EAAK8wB,WAAatB,GAAQptB,GAAS,MAEjE,GACE,EAGG6uB,EAAK,SAASjzB,IAChB6S,EAAG7S,IAAI,IAAIgzB,SAAQ,SAASlzB,GAC5B3D,EAAEA,EAAES,QAAWyqB,GAAU,WAAY,KAAM,CAC1CwL,UAAqB,KAAR/yB,EAAE,GAAY,GAAG,KAAOA,EACrC6yB,YAAeJ,EAAQvyB,GAAG,IAE9B,GACE,EAeM,OAbP4yB,EAAG,aACHG,EAAG,UACHA,EAAG,UACHE,EAAG,UACH,CAAC,OAAQ,UAAUD,QAAQJ,GAC3B,CAAC,YAAa,WAAY,aAAaI,QAAQC,GAC/CA,EAAG,OACHA,EAAG,YACHA,EAAG,oBACHA,EAAG,YACHF,EAAG,YACHE,EAAG,UACA92B,EAAES,OAAO,IAAMT,EAAAA,EAAES,QAAW,WAAaT,EAAE,GAAGA,EAAE,GAAGc,QAAQ,KAAK,MAC5Dd,EAAE6C,KAAK,GACf,CAEA,IAAIk0B,GAAQ,CACXC,GAAI,qFAEJC,MAAO,gFACPC,IAAK,iFACLC,MAAO,uFACPC,MAAO,0FAIPC,KAAM,+EACNC,WAAY,wFACZC,UAAW,0FACXC,WAAY,wFACZC,IAAK,oFACLC,IAAK,6EACLC,MAAO,4EAIPC,GAAI,CACH,gFACA,qEAKDC,KAAM,8EACNC,OAAQ,oFACRC,MAAO,4EACPC,OAAQ,mEACRC,IAAK,qEAKN,SAASC,GAAc1lB,GAClB,IAAAnD,EAAImD,EAAK5F,YAAY,KAClB,OAAA4F,EAAKnP,MAAM,EAAEgM,EAAE,GAAK,SAAWmD,EAAKnP,MAAMgM,EAAE,GAAK,OACzD,CA0BA,SAAS8oB,GAAWC,GACnB,IAAIp4B,EAAI,CAAC6pB,GAAYqB,GAAU,gBAAiB,KAAM,CAErDoL,MAASjL,MAMH,OAJPvE,GAAKsR,EAAK,QAAQvB,SAAQ,SAASwB,GAChCr4B,EAAAA,EAAES,QAAWyqB,GAAU,eAAgB,KAAMkN,EAAK,OAAOC,GAC7D,IACIr4B,EAAES,OAAO,IAAMT,EAAAA,EAAES,QAAW,mBAAqBT,EAAE,GAAGA,EAAE,GAAGc,QAAQ,KAAK,MACpEd,EAAE6C,KAAK,GACf,CAEA,SAASy1B,GAASF,EAAMG,EAAgBnrB,EAAGtE,EAAM0vB,EAAQC,GAIxD,GAHID,IAAQA,EAAS,CAAE,GACnBJ,EAAK,SAAaA,EAAA,OAAS,CAAE,GAC7BA,EAAK,UAASA,EAAK,QAAU,GAC9BG,EAAM,EAAO,IAAAA,EAAMH,EAAK,QAASA,EAAK,OAAO,MAAQG,KAAQA,GAO7D,GANEH,EAAA,QAAUG,EAAM,EACrBC,EAAOE,GAAK,MAAQH,EACpBC,EAAOG,KAAO7vB,EACd0vB,EAAOI,OAASxrB,EAER,CAAC2pB,GAAKE,MAAOF,GAAKI,MAAOJ,GAAKK,OAAOh4B,QAAQo5B,EAAOG,OAAQ,MAAWE,WAAa,YACzFT,EAAK,OAAOI,EAAOE,IAAW,MAAA,IAAI9vB,MAAM,sBAAwB2vB,GAG5D,OAFPH,EAAK,OAAOI,EAAOE,IAAMF,EACzBJ,GAAM,IAAMI,EAAOI,QAAQ93B,QAAQ,KAAK,MAAQ03B,EACzCD,CACR,CAiCA,SAASO,GAAetmB,EAAiBgX,EAAgBuP,GACjD,MAAA,CACN,iCAAmCvmB,EAAO,OAC1C,8EAAgFumB,GAAO,OAAS,IAAMvP,EAAM,QAC5G,0BACC3mB,KAAK,GACR,CAoBA,SAASm2B,KACD,MAAA,sSAA6Sj6B,EAAKoQ,QAAU,wDACpU,CAIA,IAAImoB,GAAuC,CAC1C,CAAC,cAAe,YAChB,CAAC,mBAAoB,iBACrB,CAAC,cAAe,YAChB,CAAC,oBAAqB,cACtB,CAAC,iBAAkB,eACnB,CAAC,cAAe,aAChB,CAAC,aAAc,WACf,CAAC,aAAc,UACf,CAAC,iBAAkB,YACnB,CAAC,gBAAiB,cAClB,CAAC,cAAe,YAChB,CAAC,aAAc,WACf,CAAC,WAAY,SACb,CAAC,kBAAmB,cAAe,QACnC,CAAC,mBAAoB,eAAgB,SA0BtC,SAAS2B,GAAQ7rB,EAAG4d,EAAGzO,EAAGvc,EAAGkR,GACjB,MAARA,EAAE9D,IAAmB,MAAL4d,GAAmB,KAANA,IAChC9Z,EAAE9D,GAAK4d,EACPA,EAAIf,GAAUe,GACZhrB,EAAAA,EAAES,QAAW8b,EAAI2O,GAAU9d,EAAE4d,EAAEzO,GAAKwO,GAAS3d,EAAE4d,GAClD,CAEA,SAASkO,GAAiB/5B,EAAI6Z,GACzB,IAAAnT,EAAOmT,GAAS,CAAE,EAClBhZ,EAAI,CAAC6pB,GAAYqB,GAAU,oBAAqB,KAAM,CAEzD,WAAYG,GACZ,WAAYA,GACZ,gBAAiBA,GACjB,iBAAkBA,GAClB,YAAaA,MACTna,EAAI,CAAE,EACR,IAAC/R,IAAO0G,EAAKszB,MAAc,OAAAn5B,EAAE6C,KAAK,IAElC1D,IACmB,MAAlBA,EAAGi6B,aAAqBH,GAAQ,kBAA6C,iBAAnB95B,EAAGi6B,YAA2Bj6B,EAAGi6B,YAAcjO,GAAahsB,EAAGi6B,YAAavzB,EAAKwzB,KAAM,CAAC,WAAW,kBAAmBr5B,EAAGkR,GAChK,MAAnB/R,EAAGm6B,cAAsBL,GAAQ,mBAA+C,iBAApB95B,EAAGm6B,aAA4Bn6B,EAAGm6B,aAAenO,GAAahsB,EAAGm6B,aAAczzB,EAAKwzB,KAAM,CAAC,WAAW,kBAAmBr5B,EAAGkR,IAG5L,IAAA,IAAQ1Q,EAAI,EAAGA,GAAK82B,GAAW72B,SAAUD,EAAG,CACvC,IAAA4M,EAAIkqB,GAAW92B,GACfmD,EAAIkC,EAAKszB,OAA6B,MAApBtzB,EAAKszB,MAAM/rB,EAAE,IAAcvH,EAAKszB,MAAM/rB,EAAE,IAAMjO,EAAKA,EAAGiO,EAAE,IAAM,MAC3E,IAANzJ,EAAgBA,EAAA,KACL,IAANA,EAAiBA,EAAA,IACL,iBAALA,IAAeA,EAAIjE,OAAOiE,IACjC,MAALA,GAAmBs1B,GAAA7rB,EAAE,GAAIzJ,EAAG,KAAM3D,EAAGkR,EAC1C,CAEQ,OADJlR,EAAES,OAAO,IAAMT,EAAAA,EAAES,QAAW,uBAAyBT,EAAE,GAAGA,EAAE,GAAGc,QAAQ,KAAK,MACxEd,EAAE6C,KAAK,GACf,CAGA,IAAI00B,GAAsC,CACzC,CAAC,cAAe,cAAe,UAC/B,CAAC,aAAc,aAAc,UAC7B,CAAC,UAAW,UAAW,UACvB,CAAC,cAAe,cAAe,UAC/B,CAAC,UAAW,UAAW,UACvB,CAAC,oBAAqB,oBAAqB,QAC3C,CAAC,YAAa,YAAa,QAC3B,CAAC,gBAAiB,gBAAiB,QACnC,CAAC,YAAa,YAAa,QAC3B,CAAC,eAAgB,eAAgB,OACjC,CAAC,gBAAiB,gBAAiB,QAGhCgC,GAAmB,CACtB,aAAe,aACf,cAAe,eACf,cAAe,cAsEhB,SAASC,GAAgBr6B,GACpB,IAAAa,EAAsB,GAAIy5B,EAAIvO,GAuB3B,OAtBH/rB,IAAIA,EAAK,CAAE,GACfA,EAAGu6B,YAAc,UACf15B,EAAAA,EAAES,QAAWopB,GACf7pB,EAAEA,EAAES,QAAWyqB,GAAU,aAAc,KAAM,CAC5CoL,MAASjL,GACT,WAAYA,KAGHkM,GAAAV,SAAQ,SAASzpB,GAC1B,QAAgB,IAAbjO,EAAGiO,EAAE,IAAR,CACI,IAAAzJ,EACG,OAAAyJ,EAAE,IACR,IAAK,SAAUzJ,EAAIsmB,GAAUvqB,OAAOP,EAAGiO,EAAE,MAAO,MAChD,IAAK,OAAQzJ,EAAIxE,EAAGiO,EAAE,IAAM,OAAS,aAE7B,IAANzJ,IAAiB3D,EAAEA,EAAES,QAAWg5B,EAAErsB,EAAE,GAAIzJ,GANhB,CAO7B,IAGG3D,EAAAA,EAAES,QAAWg5B,EAAE,eAAgBA,EAAE,YAAaA,EAAE,aAAc,mCAAmCA,EAAE,aAAcA,EAAE,QAAS/5B,OAAOP,EAAGw6B,cAAe,CAACljB,KAAK,EAAGmjB,SAAS,aACvK55B,EAAAA,EAAES,QAAWg5B,EAAE,gBAAiBA,EAAE,YAAat6B,EAAG6xB,WAAW3uB,KAAI,SAASF,GAAY,MAAA,aAAe8nB,GAAU9nB,GAAK,aAAgB,IAAEU,KAAK,IAAK,CAAC4T,KAAMtX,EAAGw6B,WAAYC,SAAS,WAC9K55B,EAAES,OAAO,IAAMT,EAAAA,EAAES,QAAW,gBAAkBT,EAAE,GAAGA,EAAE,GAAGc,QAAQ,KAAK,MACjEd,EAAE6C,KAAK,GACf,CA+CA,SAASg3B,GAAiB16B,GACzB,IAAIa,EAAI,CAAC6pB,GAAYqB,GAAU,aAAc,KAAM,CAClDoL,MAASjL,GACT,WAAYA,MAEb,IAAIlsB,EAAW,OAAAa,EAAE6C,KAAK,IACtB,IAAIi3B,EAAM,EASH,OARPhT,GAAK3nB,GAAI03B,SAAQ,SAAkB3hB,KAAO4kB,EACvC95B,EAAAA,EAAES,QAAWyqB,GAAU,WAr5D3B,SAAkB/oB,GACjB,cAAcA,GACb,IAAK,SACJ,IAAInC,EAAIkrB,GAAU,YAAajB,GAAU9nB,IAElC,OADMnC,EAAEc,QAAQ,UAAW,WAEnC,IAAK,SAAiB,OAAAoqB,IAAa,EAAF/oB,IAAMA,EAAE,QAAQ,QAAS8nB,GAAUvqB,OAAOyC,KAC3E,IAAK,UAAW,OAAO+oB,GAAU,UAAU/oB,EAAE,OAAO,SAErD,GAAGA,aAAa0E,KAAM,OAAOqkB,GAAU,cAAeC,GAAahpB,IAC7D,MAAA,IAAIyG,MAAM,uBAAyBzG,EAC1C,CA04DuC43B,CAAS56B,EAAG+V,IAAW,CAC3D8kB,MAAS,yCACTF,IAAOA,EACPpkB,KAAQuU,GAAU/U,IAErB,IACIlV,EAAES,OAAO,IAAMT,EAAAA,EAAES,QAAU,gBAAiBT,EAAE,GAAGA,EAAE,GAAGc,QAAQ,KAAK,MAC/Dd,EAAE6C,KAAK,GACf,CAEA,IAAIo3B,GAAkB,CACrBC,MAAO,QACPC,QAAS,UACTC,OAAQ,SACRC,SAAU,WACVC,SAAU,cACVC,WAAY,aACZC,UAAW,WACXd,YAAa,UAEbe,YAAa,cACbrB,YAAa,UACbE,aAAc,YAIdoB,SAAU,WAEVC,QAAS,UACTC,QAAS,UAOTC,WAAY,UAEZC,cAAe,gBACfC,WAAY,aACZC,SAAU,YAwMX,SAASC,GAAyBnyB,EAAiBoyB,GAClD,IAAIl7B,EAAIyX,GAAQ,GAAIvG,EAAIuG,GAAQ,GAEhC,OADAzX,EAAEyR,YAAY,EAAW,IAAR3I,EAAe,GAAOA,GAChCA,GACN,KAAK,EAAkBoI,EAAAO,eAAgBypB,GAAQ,MAC/C,KAAK,GAAgBhqB,EAAIuG,GAAQ,IAAMhG,YAAY,EAAGypB,EAAO,KAAM,MACnE,KAAK,GAAkBhqB,EAAEO,YAAY,EAAGypB,EAAQ,EAAO,GAAO,MAC9D,KAAK,GAA6GhqB,EA3IpH,SAAwBlL,GACnB,IACAnC,GADuB,iBAARmC,EAAoB,IAAIa,KAAKA,KAAK0L,MAAMvM,IAASA,GACvDsB,UAAY,IAAO,YAC5BiG,EAAI1J,EAAIK,KAAKC,IAAI,EAAE,IAAKoY,GAAK1Y,EAAI0J,GAAKrJ,KAAKC,IAAI,EAAE,IACtCoY,GAAA,IACf,IAAItU,GADCsF,GAAA,KACQrJ,KAAKC,IAAI,EAAE,IAAO,EAC5B8D,EAAI,IAAKsF,GAAQrJ,KAAKC,IAAI,EAAE,IAAUoY,GAAAtU,GACrC,IAAAjI,EAAIyX,GAAQ,GAAqD,OAA/CzX,EAAAyR,YAAY,EAAGlE,GAAMvN,EAAAyR,YAAY,EAAG8K,GAAWvc,CACtE,CAmIwHm7B,CAAeD,GAAQ,MAC7I,KAAK,GACL,KAAK,GAKJ,KAHIhqB,EAAAuG,GAAQ,EAAI,GAAKyjB,EAAMz6B,OAAS,IAAMy6B,EAAMz6B,OAAS,EAAI,EAAI,KAC/DgR,YAAY,EAAGypB,EAAMz6B,OAAS,GAC9ByQ,EAAAO,YAAY,EAAGypB,EAAO,QAClBhqB,EAAE3D,GAAK2D,EAAEzQ,QAAUyQ,EAAAO,YAAY,EAAG,GACxC,MACD,QAAS,MAAM,IAAI7I,MAAM,wCAA0CE,EAAO,IAAMoyB,GAEjF,OAAOp4B,EAAQ,CAAC9C,EAAGkR,GACpB,CA4FA,IAAIkqB,GAAY,CAAE,WAAY,YAAa,gBAAiB,cAAe,mBAAoB,SAC/F,SAASC,GAAoBryB,GAC5B,cAAcA,GACb,IAAK,UAAkB,OAAA,GACvB,IAAK,SAAmB,OAAI,EAAJA,IAAQA,EAAO,EAAO,EAC9C,IAAK,SAAiB,OAAA,GACtB,IAAK,SAAa,GAAAA,aAAenC,KAAa,OAAA,GAExC,OAAA,CACR,CACA,SAASy0B,GAAkBC,EAASC,EAAIC,GACnC,IAAAC,EAAMjkB,GAAQ,GAAIkkB,EAAO,GAAIC,EAAO,GACpC5pB,EAAK,EAAGxR,EAAI,EAEZq7B,EAAKpkB,GAAQ,GAAIqkB,EAAMrkB,GAAQ,GAOnC,GANGokB,EAAApqB,YAAY,EAAG,GACfoqB,EAAApqB,YAAY,EAAG,MACdqqB,EAAArqB,YAAY,EAAG,GACnBmqB,EAAKxmB,KAAKymB,GAAKF,EAAKvmB,KAAK0mB,GACzB9pB,GAAM,EAAI6pB,EAAGp7B,QAET+6B,EAAI,EACPM,EAAMrkB,GAAQ,IACVhG,YAAY,EAAG,GACnBkqB,EAAKI,QAAQD,GAEb,IAAI/4B,EAAO,CAAC0U,GAAQ,IAEpB,IADA1U,EAAK,GAAG0O,YAAY,EAAG8pB,EAAQ96B,QAC3BD,EAAI,EAAGA,EAAI+6B,EAAQ96B,SAAUD,EAAG,CACnC,IAAI06B,EAAQK,EAAQ/6B,GAAG,GAKvB,KAJKq7B,EAAApkB,GAAQ,EAAQ,GAAKyjB,EAAMz6B,OAAS,IAAMy6B,EAAMz6B,OAAS,EAAI,EAAI,KACnEgR,YAAY,EAAGjR,EAAE,GACpBq7B,EAAGpqB,YAAY,EAAGypB,EAAMz6B,OAAS,GAC9Bo7B,EAAApqB,YAAY,EAAGypB,EAAO,QACnBW,EAAGtuB,GAAKsuB,EAAGp7B,QAAWo7B,EAAApqB,YAAY,EAAG,GAC3C1O,EAAKqS,KAAKymB,EACb,CACEA,EAAK/4B,EAAQC,GACb64B,EAAKG,QAAQF,GACb7pB,GAAM,EAAI6pB,EAAGp7B,MACf,CAEC,IAAID,EAAI,EAAGA,EAAI+6B,EAAQ96B,SAAUD,EAC7B,KAAAg7B,GAAOA,EAAGD,EAAQ/6B,GAAG,QACrB46B,GAAUh8B,QAAQm8B,EAAQ/6B,GAAG,KAAY,GAAA+4B,GAAiBn6B,QAAQm8B,EAAQ/6B,GAAG,KAAU,IACtE,MAAjB+6B,EAAQ/6B,GAAG,GAAd,CAEA,IAAIwI,EAAMuyB,EAAQ/6B,GAAG,GAAIiJ,EAAM,EAC/B,GAAG+xB,EAAI,CAEF,IAAAQ,EAASP,EADbhyB,GAAO+xB,EAAGD,EAAQ/6B,GAAG,KAErB,GAAc,WAAXw7B,EAAM9qB,GAAgC,iBAAPlI,EAAiB,CAE9C,IAAAsf,EAAMtf,EAAI5G,MAAM,KACZ4G,IAACsf,EAAI,IAAK,MAASA,EAAI,IAAK,EACxC,CACQuT,EAAAZ,GAAyBe,EAAMn4B,EAAGmF,EAC1C,KAAS,CACF,IAAA5C,EAAIi1B,GAAoBryB,IAChB,GAAT5C,IAAeA,EAAA,GAAM4C,EAAMtJ,OAAOsJ,IAChC6yB,EAAAZ,GAAyB70B,EAAG4C,EACpC,CACE4yB,EAAKxmB,KAAKymB,IAEVC,EAAMrkB,GAAQ,IACVhG,YAAY,EAAI+pB,EAAW/xB,EAAN,EAAEjJ,GAC3Bm7B,EAAKvmB,KAAK0mB,GAEV9pB,GAAM,EAAI6pB,EAAGp7B,MAvBa,CA0BvB,IAAAwH,EAAI,GAAK2zB,EAAKn7B,OAAS,GAC3B,IAAID,EAAI,EAAGA,EAAIo7B,EAAKn7B,SAAUD,EAAKm7B,EAAKn7B,GAAGiR,YAAY,EAAGxJ,GAASA,GAAA2zB,EAAKp7B,GAAGC,OAGpE,OAFHi7B,EAAAjqB,YAAY,EAAGO,GACf0pB,EAAAjqB,YAAY,EAAGmqB,EAAKn7B,QACjBqC,EAAQ,CAAC44B,GAAK14B,OAAO24B,GAAM34B,OAAO44B,GAC1C,CAqCA,SAASK,GAAwBV,EAASjlB,EAAOklB,EAAIC,EAAqCS,EAAmBC,GAC5G,IAAIT,EAAMjkB,GAAQykB,EAAW,GAAK,IAC9Bn5B,EAAO,CAAC24B,GACRA,EAAAjqB,YAAY,EAAG,OACfiqB,EAAAjqB,YAAY,EAAG,GACfiqB,EAAAjqB,YAAY,EAAG,WACnBiqB,EAAIjqB,YAAY,GAAIX,GAAIwS,MAAMvI,OAAOrC,aAAc,OACnDgjB,EAAIjqB,YAAY,EAAIyqB,EAAW,EAAI,GAC/BR,EAAAjqB,YAAY,GAAI6E,EAAO,OAC3BolB,EAAIjqB,YAAY,EAAIyqB,EAAW,GAAK,IACpC,IAAIE,EAAMd,GAAkBC,EAASC,EAAIC,GAGzC,GAFA14B,EAAKqS,KAAKgnB,GAEPF,EAAU,CACZ,IAAIG,EAAMf,GAAkBY,EAAU,KAAM,MACxCR,EAAAjqB,YAAY,GAAI0qB,EAAQ,OAC5BT,EAAIjqB,YAAY,EAAG,GAAK2qB,EAAI37B,QAC5BsC,EAAKqS,KAAKinB,EACZ,CACC,OAAOv5B,EAAQC,EAChB,CAaA,SAASu5B,GAAU34B,EAAW3D,GAAyD,OAAhDA,IAAKA,EAAAyX,GAAQ,IAAIzX,EAAEyR,YAAY,KAAM9N,GAAW3D,CAAE,CAEzF,SAASu8B,GAAY3qB,GAAgD,OAAAA,EAAKG,WAAW,EAAG,IAAK,CAC7F,SAASyqB,GAAY74B,EAAc3D,GAAsD,OAA7CA,IAAKA,EAAAyX,GAAQ,IAAMzX,EAAAyR,YAAY,EAAG9N,GAAW3D,CAAE,CAU3F,SAASy8B,GAAU94B,EAAGE,EAAc7D,GAI5B,OAHHA,IAAOA,EAAAyX,GAAQ,IACjBzX,EAAAyR,YAAY,EAAU,KAAL5N,GAAaF,KAAOA,GACvC3D,EAAEyR,YAAY,EAAU,KAAL5N,EAAY,EAAI,GAC5B7D,CACR,CAGA,SAAS08B,GAA2B9qB,EAAMnR,EAAQoF,GAC7C,IAAA82B,EAAM/qB,EAAKG,WAAWlM,GAAQA,EAAKspB,MAAQ,GAAK,EAAI,GACpDvI,EAAW,aAEZ/gB,GAAQA,EAAKspB,KACZtpB,GAAqB,GAAbA,EAAKspB,MAGM,IAAbtpB,EAAKspB,OACHvI,EAAA,QAHKhV,EAAKG,WAAW,KACL6U,EAAA,aAOrB,OAHJ/gB,EAAKspB,MAAQ,GAAKtpB,EAAKspB,MAAQ,IAAcvI,EAAA,SACxC+V,EAAM/qB,EAAKG,WAAW4qB,EAAK/V,GAAY,EAGhD,CAsBA,SAASgW,GAAkCC,GACtC,IAAAtyB,EAAOsyB,EAAMh5B,GAAG,GAEhB63B,EAAMjkB,GAAQ,GACdikB,EAAAjqB,YAAY,EAAGlH,EAAI9J,QACnBi7B,EAAAjqB,YAAY,EAA+B,GAG/C,IAAIqrB,EAAQrlB,GAAQ,EAAIlN,EAAI9J,QAK5B,OAJAq8B,EAAMrrB,YAAY,EAAIlH,EAAI9J,OAAQ8J,EAAK,WAIhCzH,EAFG,CAAC44B,EAAKoB,GAGjB,CA6BA,SAASC,GAAsBxyB,EAAK1E,EAAM7F,GAKlC,OAJHA,IAAGA,EAAIyX,GAAQ,EAAI,EAAIlN,EAAI9J,SAC7BT,EAAAyR,YAAY,EAAGlH,EAAI9J,QACnBT,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,GAAIlH,EAAK,WAChBvK,CACR,CAyDA,SAASg9B,GAAsBzyB,EAAgBvK,GAC1CA,IAAGA,EAAIyX,GAAQ,EAAiB,EAAblN,EAAI9J,SAC3BT,EAAEyR,YAAY,EAAG,EAAIlH,EAAI9J,QACzB,IAAA,IAAQD,EAAI,EAAGA,EAAI+J,EAAI9J,SAAUD,EAAGR,EAAEyR,YAAY,EAAGlH,EAAI7J,WAAWF,IAE7D,OADLR,EAAAyR,YAAY,EAAG,GACVzR,CACR,CA4BA,SAASi9B,GAAgBC,GACxB,IAAI/2B,EAAMsR,GAAQ,KAAMjX,EAAI,EACxBo4B,EAASsE,EAAGtE,OACQ,WAArBA,EAAOv1B,MAAM,EAAE,KAAiBu1B,EAASA,EAAOv1B,MAAM,IACrD,IAAA85B,EAAUvE,EAAOx5B,QAAQ,KACzBg+B,EAAID,GAAU,EAAK,GAAO,GACvB,OAAAvE,EAAOh4B,OAAO,IAAM,IAAK,IAAOw8B,EAAA,GAAM,MAAO,IAAK,IAAQA,IAAA,EAC7Dj3B,EAAAsL,YAAY,EAAE,GAAQtL,EAAAsL,YAAY,EAAG2rB,GACzC,IAAI16B,EAAO,CAAC,EAAE,QAAQ,QAAQ,QAAQ,IAAK,IAAIlC,EAAI,EAAGA,EAAIkC,EAAKjC,SAAUD,EAAG2F,EAAIsL,YAAY,EAAG/O,EAAKlC,IACpG,GAAQ,IAAL48B,EAEFJ,GADSpE,EAAAA,EAAOv1B,MAAM,GACQ8C,QAChC,GAAe,EAAJi3B,EAAU,CAEnB,IADO16B,EAAA,kDAAkDN,MAAM,KAC3D5B,EAAI,EAAGA,EAAIkC,EAAKjC,SAAUD,EAAO2F,EAAAsL,YAAY,EAAG/F,SAAShJ,EAAKlC,GAAI,KACtE,IAAI68B,EAAYF,GAAU,EAAKvE,EAAOv1B,MAAM,EAAG85B,GAAWvE,EAE1D,IADAzyB,EAAIsL,YAAY,EAAG,GAAG4rB,EAAU58B,OAAS,IACrCD,EAAI,EAAGA,EAAI68B,EAAU58B,SAAUD,EAAG2F,EAAIsL,YAAY,EAAG4rB,EAAU38B,WAAWF,IAC1E2F,EAAAsL,YAAY,EAAG,GACZ,EAAJ2rB,GAAUJ,GAAsBG,GAAU,EAAKvE,EAAOv1B,MAAM85B,EAAQ,GAAI,GAAIh3B,EACjF,KAAQ,CAEN,IADOzD,EAAA,kDAAkDN,MAAM,KAC3D5B,EAAI,EAAGA,EAAIkC,EAAKjC,SAAUD,EAAO2F,EAAAsL,YAAY,EAAG/F,SAAShJ,EAAKlC,GAAI,KAEtE,IADA,IAAI6E,EAAI,EACuB,OAAzBuzB,EAAOv1B,MAAQ,EAAFgC,EAAM,EAAFA,EAAI,IAAoC,QAAzBuzB,EAAOv1B,MAAQ,EAAFgC,EAAM,EAAFA,EAAI,MAAcA,EAGzE,IAFIc,EAAAsL,YAAY,EAAGpM,GACnBc,EAAIsL,YAAY,EAAGmnB,EAAOn4B,OAAS,EAAI4E,EAAI,GACvC7E,EAAI,EAAGA,EAAIo4B,EAAOn4B,OAAS,EAAI4E,IAAK7E,EAAO2F,EAAAsL,YAAY,EAAkC,IAA/BmnB,EAAOl4B,WAAWF,EAAI,EAAI6E,IAIpF,IAHAc,EAAAsL,YAAY,EAAG,GACftL,EAAAsL,YAAY,EAAG,OACftL,EAAAsL,YAAY,EAAG,OACfjR,EAAI,EAAGA,EAAI,IAAKA,EAAG2F,EAAIsL,YAAY,EAAG,EAC5C,CACC,OAAOtL,EAAI9C,MAAM,EAAG8C,EAAIoH,EACzB,CAgBA,SAAS+vB,GAAcjnB,EAAczF,EAAc2sB,EAAkBv9B,GAK7D,OAJHA,IAAOA,EAAAyX,GAAQ,IACjBzX,EAAAyR,YAAY,EAAG4E,GACfrW,EAAAyR,YAAY,EAAGb,GACf5Q,EAAAyR,YAAY,EAAG8rB,GAAM,GAChBv9B,CACR,CAeA,SAASw9B,GAAU5rB,EAAMnR,EAAQoF,GAChC,IAAIoC,EAAIpC,EAAKspB,KAAO,EAAI,EAAI,EAErB,MAAA,CADQvd,EAAKG,WAAW9J,GAAgB2J,EAAKG,WAAW9J,EAAE,KAAiB2J,EAAKG,WAAW9J,EAAE,KAErG,CAsBA,SAASw1B,GAAY7rB,GAChB,IAAA8rB,EAAU9rB,EAAKG,WAAW,GAC1B4rB,EAAS/rB,EAAKG,WAAW,GAG7B,MAAO,CAAC5P,EAAE,CAACS,EAFIgP,EAAKG,WAAW,GAER3G,EAAEsyB,GAAUn8B,EAAE,CAACqB,EADxBgP,EAAKG,WAAW,GACkB3G,EAAEuyB,GACnD,CACA,SAASC,GAAYxyB,EAAapL,GAM1B,OALHA,IAAOA,EAAAyX,GAAQ,IACnBzX,EAAEyR,YAAY,EAAGrG,EAAEjJ,EAAEiJ,GACrBpL,EAAEyR,YAAY,EAAGrG,EAAE7J,EAAE6J,GACrBpL,EAAEyR,YAAY,EAAGrG,EAAEjJ,EAAES,GACrB5C,EAAEyR,YAAY,EAAGrG,EAAE7J,EAAEqB,GACd5C,CACR,CAoGA,SAAS69B,GAAUC,EAAiBj6B,EAAc7D,GAC7C,IAAAuc,EAAI,KAAQtU,EAAI,GACpB,OAAOjI,EAAE22B,UACR,IAAK,QAKL,IAAK,MAAO,MAJZ,IAAK,QAAapa,EAAA,KAAYtU,EAAA,EAAG,MACjC,IAAK,QAAasU,EAAA,EAAYtU,EAAA,EAAG,MACjC,IAAK,QAAasU,EAAA,EAAYtU,EAAA,EAAG,MACjC,IAAK,QAAasU,EAAA,EAAYtU,EAAA,EAAG,MAEjC,QAAe,MAAA,IAAIW,MAAM,4BAEtB,IAAAzC,EAAMsR,GAAQxP,GAWX,OAVH9B,EAAAsL,YAAY,EAAG8K,GACfpW,EAAAsL,YAAY,EAAG5N,GAChBoE,EAAI,GAAO9B,EAAAsL,YAAY,EAAG,OAC1BxJ,EAAI,GAAO9B,EAAAsL,YAAY,EAAG,MAC1BxJ,EAAI,IACF9B,EAAAsL,YAAY,EAAG,OACftL,EAAAsL,YAAY,EAAG,GACftL,EAAAsL,YAAY,EAAG,MACftL,EAAAsL,YAAY,EAAG,IAEbtL,CACR,CAoDA,SAAS43B,GAAkBr7B,EAAMmD,GAChC,IAAIoC,GAAMpC,GAAQA,EAAKspB,MAAQ,EAAI,EAAI,EACnCnvB,EAAIyX,GAAQ,EAAIxP,EAAIvF,EAAKgT,KAAKjV,QAChCT,EAAAyR,YAAY,EAAG/O,EAAKyrB,KACtBnuB,EAAEyR,YAAY,EAAG/O,EAAKs7B,IAAM,GAC1Bh+B,EAAAyR,YAAY,EAAG/O,EAAKoL,IACtB9N,EAAEyR,YAAY,EAAG/O,EAAKgT,KAAKjV,QACxBoF,EAAKspB,MAAQ,GAAKnvB,EAAAyR,YAAY,EAAG,GAClCzR,EAAAyR,YAAYxJ,EAAIvF,EAAKgT,KAAKjV,OAAQiC,EAAKgT,KAAM7P,EAAKspB,KAAO,EAAI,OAAS,WACxE,IAAIhpB,EAAMnG,EAAEqD,MAAM,EAAGrD,EAAEuN,GACH,OAApBpH,EAAIoH,EAAIvN,EAAEuN,EAAUpH,CACrB,CAmMA,SAAS83B,GAAaz9B,EAAc4M,EAAcvH,EAAM7F,GACnD,IAAAk+B,EAAMr4B,GAAsB,GAAbA,EAAKspB,KACpBnvB,IAAGA,EAAIyX,GAAQymB,EAAM,EAAI9wB,EAAE3M,OAAW,EAAI,EAAI2M,EAAE3M,SAClDT,EAAAyR,YAAY,EAAGjR,GACjBR,EAAEyR,YAAaysB,EAAK,EAAI,EAAI9wB,EAAE3M,QAC1By9B,GAAMl+B,EAAAyR,YAAY,EAAG,GACvBzR,EAAAyR,aAAaysB,EAAK,EAAI,GAAK9wB,EAAE3M,OAAQ2M,EAAI8wB,EAAK,OAAS,WACrD,IAAA/3B,EAAOnG,EAAES,OAAST,EAAEuN,EAAKvN,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,EAExC,OADK,MAATmG,EAAIoH,IAAWpH,EAAIoH,EAAIpH,EAAI1F,QACvB0F,CACR,CA0GA,SAASg4B,GAASz7B,EAAM07B,EAAOv4B,EAAM7F,GAChC,IAAAk+B,EAAMr4B,GAAsB,GAAbA,EAAKspB,KACpBnvB,IAAGA,EAAIyX,GAAQymB,EAAK,GAAK,KAC3Bl+B,EAAAyR,YAAY,EAAG,GACd/O,EAAK27B,OACPr+B,EAAEyR,YAAY,EAAI/O,EAAKguB,UAAU,GAC/B1wB,EAAAyR,YAAY,EAAG,SAEjBzR,EAAEyR,YAAY,EAAI/O,EAAKguB,UAAU,GAC/B1wB,EAAAyR,YAAY,EAAI2sB,GAAO,IAE1B,IAAIhxB,EAAI,EAMD,OALJ1K,EAAKguB,SAAW,GAAKwN,IAAS9wB,GAAA,MAC/BpN,EAAAyR,YAAY,EAAGrE,GACfpN,EAAAyR,YAAY,EAAG,GACbysB,GAAMl+B,EAAAyR,YAAY,EAAG,GACvBzR,EAAAyR,YAAY,EAAG,GACVzR,CACR,CAoTA,SAASs+B,GAAYpB,GAChB,IAAAqB,EAAI9mB,GAAQ,IACZ+mB,EAAMvO,GAAYiN,EAAG,IACvBqB,EAAA9sB,YAAY,EAAG+sB,EAAIpzB,GAAMmzB,EAAA9sB,YAAY,EAAG+sB,EAAIpzB,GAC5CmzB,EAAA9sB,YAAY,EAAG+sB,EAAI57B,GAAM27B,EAAA9sB,YAAY,EAAG+sB,EAAI57B,GAE9C,IADI,IAAA0T,EAAQ,kDAAkDlU,MAAM,KAC5D5B,EAAI,EAAGA,EAAI,KAAMA,EAAG+9B,EAAE9sB,YAAY,EAAG/F,SAAS4K,EAAM9V,GAAI,KACzD,OAAAsC,EAAQ,CAACy7B,EAAGtB,GAAgBC,EAAG,KACvC,CAWA,SAASuB,GAAmBvB,GACvB,IAAA1tB,EAAK0tB,EAAG,GAAGwB,QACXH,EAAI9mB,GAAQ,GAAK,GAAKjI,EAAG/O,OAAS,IACpC89B,EAAA9sB,YAAY,EAAG,MACjB,IAAI+sB,EAAMvO,GAAYiN,EAAG,IACvBqB,EAAA9sB,YAAY,EAAG+sB,EAAIpzB,GAAMmzB,EAAA9sB,YAAY,EAAG+sB,EAAIpzB,GAC5CmzB,EAAA9sB,YAAY,EAAG+sB,EAAI57B,GAAM27B,EAAA9sB,YAAY,EAAG+sB,EAAI57B,GAC9C,IAAA,IAAQpC,EAAI,EAAGA,EAAIgP,EAAG/O,SAAUD,EAAG+9B,EAAE9sB,YAAY,EAAGjC,EAAG9O,WAAWF,IAE3D,OADL+9B,EAAA9sB,YAAY,EAAG,GACV8sB,CACR,CAsLA,IAAII,GAA+B,WACnC,IAAIC,EAAmB,CAEf,EAAe,IAAsB,EAAe,IACpD,EAAc,KAAuB,EAAa,IAClD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAc,KACnD,IAAc,KAAuB,IAAa,MAClD,IAAa,MAAwB,IAAa,MAClD,IAAc,KAAuB,IAAc,KACnD,IAAc,KAAuB,IAAc,KAGnD,EAAa,MAAwB,EAAe,IACpD,EAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAe,IAAsB,GAAe,IACpD,GAAc,KAAuB,GAAc,KACnD,GAAc,KAAuB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAc,KAEnD,IAAa,OAEjBC,EAAkBtX,GAAM,CACpB,EAAe,IAAsB,EAAe,IACpD,EAAc,KAAuB,EAAa,IAClD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAe,IACpD,IAAe,IAAsB,IAAc,KACnD,IAAc,KAAuB,IAAa,MAClD,IAAa,MAAwB,IAAa,MAClD,IAAc,KAAuB,IAAc,KACnD,IAAc,KAAuB,IAAc,KACnD,EAAa,QAsKZ,SAAAuX,EAAat9B,EAAKqE,GACtB,IAAA7F,EAAI6F,GAAQ,CAAE,EACd7F,EAAE2N,SAAQ3N,EAAE2N,OAAS,YACzB,IAAI0jB,EAAKY,GAtKD,SAAWzwB,EAAKqE,GACxB,IAAIM,EAAc,GACdvC,EAAejC,EAAY,GAC/B,OAAOkE,EAAKiD,MACX,IAAK,SAAclF,EAAA1B,EAAIrB,EAAcW,IAAO,MAC5C,IAAK,SAAUoC,EAAI1B,EAAIV,GAAM,MAC7B,IAAK,SACL,IAAK,QAAaoC,EAAApC,EAEnBqQ,GAAUjO,EAAG,GAGT,IAAAm7B,EAAKn7B,EAAEmO,WAAW,GAClBitB,KAAe,IAALD,GACVE,GAAM,EAAOC,GAAK,EACtB,OAAOH,GACN,KAAK,EACL,KAAK,EAKL,KAAK,IACL,KAAK,IAGL,KAAK,IAAM,MARX,KAAK,GACL,KAAK,GAAYE,GAAA,EAAaD,GAAA,EAAM,MAKpC,KAAK,IAAWE,GAAA,EAAM,MAItB,QAAS,MAAM,IAAIt2B,MAAM,4BAA8Bm2B,EAAGr2B,SAAS,KAGhE,IAAAy2B,EAAO,EAAGC,EAAO,IACZ,GAANL,IAAmBI,EAAAv7B,EAAEmO,WAAW,IACnCnO,EAAE2J,GAAK,EACE,GAANwxB,IAAmBI,EAAAv7B,EAAEmO,WAAW,IAChCotB,EAAO,UAAgBA,EAAA,KAEjB,GAANJ,IAAmBK,EAAAx7B,EAAEmO,WAAW,IAC/B,IAAAstB,EAAOz7B,EAAEmO,WAAW,GAELutB,EAAaz5B,EAAK05B,UAAY,KACxC,GAANR,IACFn7B,EAAE2J,GAAG,GACO3J,EAAEmO,WAAW,GAIX,IAAXnO,EAAEA,EAAE2J,OAAuBqxB,EAAiBh7B,EAAEA,EAAE2J,KACnD3J,EAAE2J,GAAG,EAEL3J,EAAE2J,GAAG,GAEH2xB,MAAM3xB,GAAK,IAMd,IAHA,IAAIiyB,EAA6B,GAAIC,EAAsB,GACvDC,EAAOx7B,KAAKgI,IAAItI,EAAEnD,OAAe,GAANs+B,EAAa,IAASK,EAAO,IAAMH,EAAM,IAAM,IAC1E1U,EAAK2U,EAAK,GAAK,GACbt7B,EAAE2J,EAAImyB,GAAkB,IAAV97B,EAAEA,EAAE2J,IAWvB,QAVAkyB,EAAS,CAAA,GACH/pB,KAAOnW,EAAS+jB,MAAMmF,OAAO6W,EAAY17B,EAAEP,MAAMO,EAAE2J,EAAG3J,EAAE2J,EAAEgd,IAAKzpB,QAAQ,mBAAmB,IAChG8C,EAAE2J,GAAKgd,EACPkV,EAAM32B,KAAOpJ,OAAOC,aAAaiE,EAAEmO,WAAW,IACrC,GAANgtB,GAAeG,MAAUvnB,OAAS/T,EAAEmO,WAAW,IAC5C0tB,EAAA79B,IAAMgC,EAAEmO,WAAW,GAChB,GAANgtB,IAAYU,EAAM9nB,OAAS/T,EAAEmO,WAAW,IACrC0tB,EAAA90B,IAAM/G,EAAEmO,WAAW,GACtB0tB,EAAM/pB,KAAKjV,QAAQ++B,EAAOpqB,KAAKqqB,GACzB,GAANV,IAAcn7B,EAAA2J,GAAK2xB,EAAK,GAAK,IACzBO,EAAM32B,MACZ,IAAK,MACCm2B,GAAoB,GAAbQ,EAAM79B,MAAaiE,EAAKwzB,IACpC,MACD,IAAK,IACL,IAAK,IACDxzB,EAAKwzB,IACR,MACD,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACJ,MACD,QAAS,MAAM,IAAIzwB,MAAM,uBAAyB62B,EAAM32B,MAK1D,GADc,KAAXlF,EAAEA,EAAE2J,KAAa3J,EAAE2J,EAAI6xB,EAAK,GACR,KAApBx7B,EAAEmO,WAAW,GAAmB,MAAA,IAAInJ,MAAM,4BAA8BhF,EAAE2J,EAAI,IAAM3J,EAAEA,EAAE2J,IAC3F3J,EAAE2J,EAAI6xB,EAGF,IAAA/oB,EAAI,EAAGzF,EAAI,EAEf,IADIzK,EAAA,GAAK,GACLyK,EAAI,EAAGA,GAAK4uB,EAAO/+B,SAAUmQ,EAAOzK,EAAA,GAAGyK,GAAK4uB,EAAO5uB,GAAG8E,KAC1D,KAAMypB,KAAS,GACd,GAAc,KAAXv7B,EAAEA,EAAE2J,GAOP,MAFE3J,EAAE2J,EACApH,IAAEkQ,GAAK,GAAQzF,EAAA,EACfA,EAAI,EAAGA,GAAK4uB,EAAO/+B,SAAUmQ,EAAG,CAC/B,IAAAlG,EAAK9G,EAAEP,MAAMO,EAAE2J,EAAG3J,EAAE2J,EAAEiyB,EAAO5uB,GAAGhP,KAAQgC,EAAA2J,GAAGiyB,EAAO5uB,GAAGhP,IACzDiQ,GAAUnH,EAAI,GACd,IAAIvI,EAAI5C,EAAS+jB,MAAMmF,OAAO6W,EAAY50B,GACnC,OAAA80B,EAAO5uB,GAAG9H,MAChB,IAAK,IAED3G,EAAE+gB,OAAOziB,SAAY0F,EAAAkQ,GAAGzF,GAAKzO,EAAErB,QAAQ,OAAO,KACjD,MACD,IAAK,IACY,IAAbqB,EAAE1B,OAAc0F,EAAIkQ,GAAGzF,GAAK,IAAI/J,MAAM1E,EAAEkB,MAAM,EAAE,IAAKlB,EAAEkB,MAAM,EAAE,GAAG,GAAIlB,EAAEkB,MAAM,EAAE,IAC1E8C,EAAAkQ,GAAGzF,GAAKzO,EACjB,MACD,IAAK,IAAKgE,EAAIkQ,GAAGzF,GAAK1D,WAAW/K,EAAE+gB,QAAS,MAC5C,IAAK,IAAK,IAAK,IAAK/c,EAAIkQ,GAAGzF,GAAKsuB,EAA8B,WAAzBx0B,EAAGqH,YAAe,EAAA,KAAoBrH,EAAGqH,WAAW,EAAG,KAAM,MAClG,IAAK,IAAK,OAAO5P,EAAE+gB,OAAO1a,eACzB,IAAK,IAAK,IAAK,IAASrC,EAAAkQ,GAAGzF,IAAK,EAAM,MACtC,IAAK,IAAK,IAAK,IAASzK,EAAAkQ,GAAGzF,IAAK,EAAO,MACvC,IAAK,GAAI,IAAK,IAAK,MACnB,QAAS,MAAM,IAAIhI,MAAM,uBAAyBzG,EAAI,KACpD,MACH,IAAK,IACD,IAAC68B,EAAY,MAAA,IAAIp2B,MAAM,gCAAkCm2B,EAAGr2B,SAAS,KACxEvC,EAAIkQ,GAAGzF,GAAK,YAAcsuB,EAAKxzB,SAASvJ,EAAE+gB,OAAQ,IAAKxY,EAAGqH,WAAW,IACrE,MACD,IAAK,KACJ5P,EAAIA,EAAErB,QAAQ,UAAU,IAAIoiB,SAEf,KAAL/gB,IAAUgE,EAAIkQ,GAAGzF,IAAMzO,GAAK,GAAG,MACxC,IAAK,IAEAgE,EAAAkQ,GAAGzF,GAAK,IAAI/J,KAAK6D,EAAGqH,YAAW,EAAI,KAAO,aAC9C,MACD,IAAK,IAAK5L,EAAIkQ,GAAGzF,GAAK,IAAI/J,KAAqC,OAA/B6D,EAAGqH,WAAW,GAAK,SAAwBrH,EAAGqH,WAAW,IAAK,MAC9F,IAAK,IAAK5L,EAAIkQ,GAAGzF,GAAKlG,EAAGqH,WAAW,EAAE,KAAK,IAAOrH,EAAGqH,WAAW,EAAG,KAAK,IAAK7N,KAAKC,IAAI,EAAE,IAAK,MAC7F,IAAK,IAASgC,EAAAkQ,GAAGzF,IAAMlG,EAAGqH,cAAe,KAAM,MAC/C,IAAK,IAAK,GAAGktB,GAAwB,GAAjBO,EAAO5uB,GAAGhP,IAAU,CAAEuE,EAAIkQ,GAAGzF,GAAKlG,EAAGqH,WAAW,EAAE,KAAM,KAAM,CAElF,IAAK,IAAK,IAAK,IAAQrH,EAAA6C,GAAKiyB,EAAO5uB,GAAGhP,IAAK,MAC3C,IAAK,IACJ,GAAsB,eAAnB49B,EAAO5uB,GAAG8E,KAAuB,MAErC,QAAS,MAAM,IAAI9M,MAAM,6BAA+B42B,EAAO5uB,GAAG9H,MAEtE,MAjDGlF,EAAE2J,GAAG8xB,EAmDP,GAAS,GAANN,GAAen7B,EAAE2J,EAAI3J,EAAEnD,QAAsB,IAAZmD,EAAEA,EAAE2J,KAAoB,MAAA,IAAI3E,MAAM,2BAA6BhF,EAAE2J,EAAE,GAAK,OAAS3J,EAAEnD,OAAS,IAAMmD,EAAEA,EAAE2J,EAAE,GAAG7E,SAAS,KAGjJ,OAFJ7C,GAAQA,EAAK85B,YAAWx5B,EAAMA,EAAI9C,MAAM,EAAGwC,EAAK85B,YACnD95B,EAAK84B,IAAMa,EACJr5B,CACR,CAKuBy5B,CAAWp+B,EAAKxB,GAAIA,GAMnC,OALPqxB,EAAG,SAAWrxB,EAAE2+B,IAAIt8B,KAAI,SAASo9B,GAAgB,MAAA,CAChDI,IAAKJ,EAAM79B,IACX+8B,IAAKc,EACJ,WACKz/B,EAAE2+B,IACFtN,CACR,CAQA,IAAIyO,EAAQ,CAAE56B,EAAK,EAAG0L,EAAK,IAAKC,EAAK,EAAG9L,EAAK,EAAG,IAAK,EAAG,GAAI,GAsHpD,MAAA,CACNg7B,YA7HO,SAAgBv+B,EAAKqE,GACzB,IAAE,OAAOgrB,GAAkBiO,EAAat9B,EAAKqE,GAAOA,EAAM,OACxDtE,GAAQ,GAAAsE,GAAQA,EAAKwzB,IAAW,MAAA93B,CAAE,CACxC,MAAQ,CAACyvB,WAAW,GAAGC,OAAO,CAAA,EAC/B,EA0HE+O,SAAUlB,EACVmB,WAxHO,SAAa5O,EAAkBxrB,GACnC,IAAA7F,EAAI6F,GAAQ,CAAE,EAElB,IADI7F,EAAEu/B,UAAY,GAAUlgC,GAACW,EAAEu/B,UAClB,UAAVv/B,EAAE8I,KAAwB,MAAA,IAAIF,MAAM,iCACvC,IAAIimB,EAAKR,KACL6R,EAAcC,GAAc9O,EAAI,CAACjd,OAAO,EAAGiD,KAAI,EAAM0a,WAAU,IAC/DqO,EAAUF,EAAI,GAAIx9B,EAAOw9B,EAAI78B,MAAM,GAAIg9B,EAAOhP,EAAG,UAAY,GAC7D7wB,EAAI,EAAG8I,EAAI,EAAGg3B,EAAO,EAAGjB,EAAO,EACnC,IAAI7+B,EAAI,EAAGA,EAAI4/B,EAAQ3/B,SAAUD,EAC3B,KAAA6/B,EAAK7/B,IAAI,CAAE,GAAEm+B,KAAK,CAAA,GAAIjpB,KAAQ0qB,EAAQ5/B,GAAK6/B,EAAK7/B,GAAGm+B,IAAIjpB,OAAQ4qB,OACjE,GAAc,MAAdF,EAAQ5/B,GAAR,CAGH,KAFE8/B,EACuB,iBAAfF,EAAQ5/B,KAAiB4/B,EAAQ5/B,GAAK4/B,EAAQ5/B,GAAGkI,SAAS,KAC3C,iBAAf03B,EAAQ5/B,SAAuB,IAAIoI,MAAM,2BAA6Bw3B,EAAQ5/B,GAAK,YAAe4/B,EAAQ5/B,GAAM,KAC1H,GAAG4/B,EAAQhhC,QAAQghC,EAAQ5/B,MAAQA,EAAG,IAAI8I,EAAE,EAAGA,EAAE,OAAOA,EACpD,IAA6C,GAA7C82B,EAAQhhC,QAAQghC,EAAQ5/B,GAAK,IAAM8I,GAAU,CAAU82B,EAAA5/B,IAAM,IAAM8I,EAAG,KAAM,CALzD,CAOxB,IAAI+lB,EAAQiB,GAAkBe,EAAG,SAC7BkP,EAA6B,GAC7BC,EAA8B,GAC9BC,EAAgC,GAChC,IAAAjgC,EAAI,EAAGA,GAAK6uB,EAAM9tB,EAAEqB,EAAIysB,EAAMltB,EAAES,IAAKpC,EAAG,CAC3C,IAAIkgC,EAAQ,GAAIC,EAAS,GAAIz9B,EAAS,EAClC8sB,EAAqB,GACzB,IAAI1mB,EAAE,EAAGA,EAAI5G,EAAKjC,SAAU6I,EACV,MAAd5G,EAAK4G,GAAG9I,IAAgBwvB,EAAA5a,KAAK1S,EAAK4G,GAAG9I,IAEzC,GAAiB,GAAdwvB,EAAIvvB,QAA6B,MAAd2/B,EAAQ5/B,GAA9B,CACA,IAAI8I,EAAI,EAAGA,EAAI0mB,EAAIvvB,SAAU6I,EAAG,CACxB,cAAO0mB,EAAI1mB,IAEjB,IAAK,SAAmBq3B,EAAA,IAAK,MAC7B,IAAK,SAGL,QAAkBA,EAAA,UAFlB,IAAK,UAAoBA,EAAA,IAAK,MAC9B,IAAK,SAAUA,EAAS3Q,EAAI1mB,aAAczC,KAAO,IAAM,IAG/C3D,EAAAgB,KAAKiI,IAAIjJ,EAAQxD,OAAOswB,EAAI1mB,IAAI7I,QACjCigC,EAAAA,GAASA,GAASC,EAAS,IAAMA,CAE5C,CACKz9B,EAAS,MAAcA,EAAA,KAGb,MAFby9B,IAAWN,EAAK7/B,IAAI,IAAIm+B,KAAK,CAAA,GAAI71B,OAG7Bu3B,EAAK7/B,GAAGm+B,IAAI/8B,IAAMsB,IAAiBA,EAAAm9B,EAAK7/B,GAAGm+B,IAAI/8B,KAEvC,KAAT8+B,GAA0B,KAAVC,IACVD,EAAA,IACRD,EAAYjgC,GAAK6/B,EAAK7/B,GAAGm+B,IAAIh0B,IACpBzH,EAAAm9B,EAAK7/B,GAAGm+B,IAAI/8B,KAEZ4+B,EAAAhgC,GAAc,KAATkgC,GAA0B,KAAVC,EAAgBz9B,EAAU48B,EAAMY,IAAU,EACzErB,GAAQmB,EAAUhgC,GAClB+/B,EAAS//B,GAAKkgC,CA3B0D,MAA5BH,EAAS//B,GAAK,GA4B5D,CAEK,IAAA+b,EAAIsS,EAAGH,KAAK,IAKZ,IAJFnS,EAAA9K,YAAY,EAAG,WACf8K,EAAA9K,YAAY,EAAG/O,EAAKjC,QACtB8b,EAAE9K,YAAY,EAAG,IAAM,GAAK6uB,GAC1B/jB,EAAA9K,YAAY,EAAG4tB,GACb7+B,EAAE,EAAGA,EAAI,IAAKA,EAAG+b,EAAE9K,YAAY,EAAG,GAGlC,IAFF8K,EAAA9K,YAAY,IAAmBotB,EAA6B7/B,IAAwB,IAAO,GAEzFwB,EAAI,EAAG8I,EAAI,EAAG9I,EAAI4/B,EAAQ3/B,SAAUD,EACpC,GAAc,MAAd4/B,EAAQ5/B,GAAR,CACC,IAAAogC,EAAK/R,EAAGH,KAAK,IACbmS,GAAMT,EAAQ5/B,GAAG6C,WAAa,0BAAgDA,MAAM,EAAG,IACxFu9B,EAAAnvB,YAAY,EAAGovB,EAAI,QACnBD,EAAAnvB,YAAY,EAAkB,KAAf8uB,EAAS//B,GAAY,IAAM+/B,EAAS//B,GAAI,QACvDogC,EAAAnvB,YAAY,EAAGnI,GACfs3B,EAAAnvB,YAAY,EAAG+uB,EAAUhgC,IAAMs/B,EAAMS,EAAS//B,KAAO,GACxDogC,EAAGnvB,YAAY,EAAGgvB,EAAYjgC,IAAM,GACjCogC,EAAAnvB,YAAY,EAAG,GACfmvB,EAAAnvB,YAAY,EAAG,GACfmvB,EAAAnvB,YAAY,EAAG,GACfmvB,EAAAnvB,YAAY,EAAG,GACfmvB,EAAAnvB,YAAY,EAAG,GAClBnI,GAAMk3B,EAAUhgC,IAAMs/B,EAAMS,EAAS//B,KAAO,CAbrB,CAgBpB,IAAAsgC,EAAKjS,EAAGH,KAAK,KAEb,IADDoS,EAAArvB,YAAY,EAAG,IACdjR,EAAE,EAAGA,EAAI,KAAKA,EAAGsgC,EAAGrvB,YAAY,EAAG,GACvC,IAAIjR,EAAE,EAAGA,EAAIkC,EAAKjC,SAAUD,EAAG,CAC1B,IAAAugC,EAAOlS,EAAGH,KAAK2Q,GAEnB,IADK0B,EAAAtvB,YAAY,EAAG,GAChBnI,EAAE,EAAGA,EAAE82B,EAAQ3/B,SAAU6I,EACzB,GAAc,MAAd82B,EAAQ92B,GACJ,OAAAi3B,EAASj3B,IACf,IAAK,IAAKy3B,EAAKtvB,YAAY,EAAiB,MAAd/O,EAAKlC,GAAG8I,GAAa,GAAO5G,EAAKlC,GAAG8I,GAAK,GAAO,IAAO,MACrF,IAAK,IAAUy3B,EAAAtvB,YAAY,EAAG/O,EAAKlC,GAAG8I,IAAI,EAAG,KAAM,MACnD,IAAK,IACJ,IAAI03B,EAAK,IAET,IADwB,iBAAdt+B,EAAKlC,GAAG8I,KAAgB03B,EAAKt+B,EAAKlC,GAAG8I,GAAGpB,QAAQu4B,EAAYn3B,IAAI,IACtEg3B,EAAK,EAAGA,EAAOE,EAAUl3B,GAAG03B,EAAGvgC,SAAU6/B,EAAWS,EAAAtvB,YAAY,EAAG,IAClEsvB,EAAAtvB,YAAY,EAAGuvB,EAAI,QACxB,MACD,IAAK,IACAt+B,EAAKlC,GAAG8I,IAEXy3B,EAAKtvB,YAAY,GAAI,OAAO/O,EAAKlC,GAAG8I,GAAGtC,eAAe3D,OAAM,GAAK,QACjE09B,EAAKtvB,YAAY,GAAI,MAAM/O,EAAKlC,GAAG8I,GAAGrC,WAAW,IAAI5D,OAAM,GAAK,QAChE09B,EAAKtvB,YAAY,GAAI,KAAK/O,EAAKlC,GAAG8I,GAAGvC,WAAW1D,OAAM,GAAK,SAJvC09B,EAAAtvB,YAAY,EAAG,WAAY,QAK9C,MACH,IAAK,IACJ,IAAIwvB,EAAKvhC,OAAqB,MAAdgD,EAAKlC,GAAG8I,GAAa5G,EAAKlC,GAAG8I,GAAK,IAAIjG,MAAM,EAAGm9B,EAAUl3B,IAEzE,IADKy3B,EAAAtvB,YAAY,EAAGwvB,EAAI,QACpBX,EAAK,EAAGA,EAAOE,EAAUl3B,GAAG23B,EAAGxgC,SAAU6/B,EAAWS,EAAAtvB,YAAY,EAAG,IAI5E,CAEC,OADAod,EAAGH,KAAK,GAAGjd,YAAY,EAAG,IACnBod,EAAGjM,KACX,EAMA,CA3WmC,GA6W/Bse,GAAgC,WAEnC,IAAIC,EAAgB,CACnBC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAC3CC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAaC,GAAG,IACnCC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAaC,GAAG,IACnCC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IACnCC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAaC,GAAG,IACnCC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAC3CC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAaC,GAAG,IACnCC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAaC,GAAG,IACnCC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IACnCC,GAAG,IAAKC,GAAG,IAAKC,GAAG,IAAaC,GAAG,IACnCC,GAAG,IAAKC,GAAG,IAAKx+B,EAAE,IAAM6qB,EAAE,IAAMvT,EAAE,IAAM3T,EAAE,IAC1C86B,GAAG,IAAKC,GAAG,IAAKC,GAAG,IACnB59B,EAAE,IAAM9D,EAAE,IAAMyT,EAAE,IAAM,KAAK,IACtB,EAAS,IAAe,EAAS,IAAa,EAAS,IACvD,EAAS,IAAe,EAAS,IAAa,EAAS,IACvD,EAAS,IAAQ7Q,EAAE,IAAM0P,EAAE,IAAMiH,EAAE,IAAM3b,EAAE,IAAM+M,EAAE,IAAMpL,EAAE,IAAMmE,EAAE,IAC1E,IAAI,IAAK,IAAI,IAAK,IAAI,IAAK,IAAI,IAAK,IAAI,IAAK,IAAI,IAAK,KAAK,IAC3D,IAAI,IAAK,IAAI,IAAK,IAAI,IAAK,IAAI,IAAK,IAAI,IAAK,IAAI,IAAK,IAAI,KAEvDi+B,EAAkB,IAAI1Z,OAAO,MAAa/D,GAAKqa,GAAct+B,KAAK,KAAK/B,QAAQ,SAAU,SAASA,QAAQ,YAAY,QAAU,QAAS,MACzI0jC,EAAe,SAASC,EAAG16B,GAAS,IAAA/J,EAAImhC,EAAap3B,GAAK,MAAmB,iBAAL/J,EAAgBJ,EAASI,GAAKA,CAAI,EAC1G0kC,EAAmB,SAAS56B,EAAIC,EAAIC,GAAU,IAAA26B,EAAU56B,EAAGrJ,WAAW,GAAK,IAAO,EAAMsJ,EAAGtJ,WAAW,GAAK,GAAO,OAAgB,IAATikC,EAAc76B,EAAKlK,EAAS+kC,EAAS,EAYzJ,SAAAC,EAAgBr6B,EAAgB1E,GACxC,IAIcyD,EAJVu7B,EAAUt6B,EAAInI,MAAM,WAAYiU,GAAI,EAAIzF,GAAI,EAAIvF,EAAK,EAAGy5B,EAAK,EAAGxc,EAAc,GAC9Eyc,EAA4B,GAC5BC,EAAmC,KACnCC,EAAM,CAAA,EAAIC,EAA6B,GAAIC,EAA6B,GAAIC,EAAuB,GACnGC,EAAO,EAEX,KADIx/B,EAAK05B,UAAY,GAAUlgC,GAACwG,EAAK05B,UAC9Bl0B,IAAOw5B,EAAQpkC,SAAU4K,EAAI,CAC5Bg6B,EAAA,EACP,IAEkBr8B,EAFds8B,EAAKT,EAAQx5B,GAAI6X,OAAOpiB,QAAQ,kCAAmC4jC,GAAkB5jC,QAAQyjC,EAAiBC,GAC9Ge,EAAOD,EAAKxkC,QAAQ,MAAO,MAAUsB,MAAM,KAAKC,KAAI,SAAS5C,GAAY,OAAAA,EAAEqB,QAAQ,UAAW,QAC9F0kC,EAAGD,EAAO,GACd,GAAGD,EAAK7kC,OAAS,EAAG,OAAO+kC,GAC3B,IAAK,KACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IAAK,MACV,IAAK,IACsB,KAAvBD,EAAO,GAAG3kC,OAAO,IACXmkC,EAAA3vB,KAAKkwB,EAAKjiC,MAAM,GAAGvC,QAAQ,MAAO,MAC3C,MACD,IAAK,IACD,IAAA2kC,GAAW,EAAOC,GAAW,EAAOC,GAAW,EAAOC,GAAW,EAAOtU,GAAK,EAAIC,GAAK,EAC1F,IAAIuT,EAAG,EAAGA,EAAGS,EAAO9kC,SAAUqkC,EAAI,OAAOS,EAAOT,GAAIlkC,OAAO,IAC1D,IAAK,IA6BL,IAAK,IAAK,MA5BV,IAAK,IAAKgQ,EAAIlF,SAAS65B,EAAOT,GAAIzhC,MAAM,IAAI,EAAcqiC,GAAA,EAAM,MAChE,IAAK,IAEA,IADJrvB,EAAI3K,SAAS65B,EAAOT,GAAIzhC,MAAM,IAAI,EAAOqiC,IAAc90B,EAAA,GACnDtH,EAAIgf,EAAI7nB,OAAQ6I,GAAK+M,IAAK/M,EAAGgf,EAAIhf,GAAK,GAC1C,MACD,IAAK,IAEiB,OADrBN,EAAMu8B,EAAOT,GAAIzhC,MAAM,IAChBzC,OAAO,GAAkBoI,EAAAA,EAAI3F,MAAM,EAAE2F,EAAIvI,OAAS,GACzC,SAARuI,EAAsBA,GAAA,EACd,UAARA,EAAuBA,GAAA,EACtBrI,MAAMkoB,GAAS7f,IAGbrI,MAAMwoB,GAAUngB,GAAKjC,aAC/BiC,EAAMmf,GAAUnf,KAHhBA,EAAM6f,GAAS7f,GACS,OAArBg8B,GAA6Bl4B,GAAYk4B,KAAmBh8B,EAAM8e,GAAQ9e,KAKnEy8B,GAAA,EACX,MACD,IAAK,IACOG,GAAA,EACX,IAAIC,EAAUC,GAASP,EAAOT,GAAIzhC,MAAM,GAAI,CAAC+H,EAAEiL,EAAEzT,EAAEgO,IAC/C0X,EAAAjS,GAAGzF,GAAK,CAAC0X,EAAIjS,GAAGzF,GAAIi1B,GACxB,MACD,IAAK,IACOF,GAAA,EACPrd,EAAAjS,GAAGzF,GAAK,CAAC0X,EAAIjS,GAAGzF,GAAI,OACxB,MAED,IAAK,IAAK0gB,EAAK5lB,SAAS65B,EAAOT,GAAIzhC,MAAM,IAAI,EAAG,MAChD,IAAK,IAAKkuB,EAAK7lB,SAAS65B,EAAOT,GAAIzhC,MAAM,IAAI,EAAG,MAChD,QAAS,GAAGwC,GAAQA,EAAKwzB,UAAW,IAAIzwB,MAAM,mBAAqB08B,GAOpE,GALGG,IACCnd,EAAIjS,GAAGzF,IAA0B,GAApB0X,EAAIjS,GAAGzF,GAAGnQ,OAAiB6nB,EAAAjS,GAAGzF,GAAG,GAAK5H,EAC7Csf,EAAAjS,GAAGzF,GAAK5H,EACEg8B,EAAA,MAEjBW,EAAU,CACZ,GAAGC,EAAU,MAAM,IAAIh9B,MAAM,+CAC7B,IAAIm9B,EAAUzU,GAAK,GAAMhJ,EAAIgJ,GAAIC,GAC9B,IAACwU,IAAYA,EAAQ,GAAI,MAAM,IAAIn9B,MAAM,wCAC5C0f,EAAIjS,GAAGzF,GAAG,GAAKo1B,GAAkBD,EAAQ,GAAI,CAAC36B,EAAGiL,EAAIib,EAAI1uB,EAAGgO,EAAI2gB,GACpE,CACG,MACA,IAAK,IACL,IAAI0U,EAAS,EACb,IAAInB,EAAG,EAAGA,EAAGS,EAAO9kC,SAAUqkC,EAAI,OAAOS,EAAOT,GAAIlkC,OAAO,IAC1D,IAAK,IAAKgQ,EAAIlF,SAAS65B,EAAOT,GAAIzhC,MAAM,IAAI,IAAK4iC,EAAQ,MACzD,IAAK,IAEA,IADJ5vB,EAAI3K,SAAS65B,EAAOT,GAAIzhC,MAAM,IAAI,EAC9BiG,EAAIgf,EAAI7nB,OAAQ6I,GAAK+M,IAAK/M,EAAGgf,EAAIhf,GAAK,GAC1C,MACD,IAAK,IAAK+7B,EAAO35B,SAAS65B,EAAOT,GAAIzhC,MAAM,IAAM,GAAI,MACrD,IAAK,IACL,IAAK,IAIL,IAAK,IACL,IAAK,IACL,IAAK,IAAK,MALV,IAAK,IACe2hC,EAAAD,EAAQr5B,SAAS65B,EAAOT,GAAIzhC,MAAM,KACrD,MAID,IAAK,IAEJ,IADA+hC,EAAKG,EAAOT,GAAIzhC,MAAM,GAAGjB,MAAM,KAC3BkH,EAAIoC,SAAS05B,EAAG,GAAI,IAAK97B,GAAKoC,SAAS05B,EAAG,GAAI,MAAO97B,EACxD+7B,EAAO35B,SAAS05B,EAAG,GAAI,IACfD,EAAA77B,EAAE,GAAc,IAAT+7B,EAAa,CAACa,QAAO,GAAO,CAACrG,IAAIwF,GAAmBc,GAAAhB,EAAQ77B,EAAE,IAC5E,MACH,IAAK,IAEA67B,EADJv0B,EAAIlF,SAAS65B,EAAOT,GAAIzhC,MAAM,IAAI,KACV8hC,EAAAv0B,GAAK,CAAE,GAC/B,MACD,IAAK,IAEAs0B,EADJ7uB,EAAI3K,SAAS65B,EAAOT,GAAIzhC,MAAM,IAAI,KACV6hC,EAAA7uB,GAAK,CAAE,GAC5BgvB,EAAO,GAAaH,EAAA7uB,GAAG+vB,IAAMf,EAAMH,EAAQ7uB,GAAGgwB,IAAMC,GAAMjB,IAC5C,IAATA,IAAoBH,EAAA7uB,GAAG6vB,QAAS,GACxC,MACD,QAAS,GAAGrgC,GAAQA,EAAKwzB,UAAW,IAAIzwB,MAAM,mBAAqB08B,GAEjEW,EAAS,IAAsBjB,EAAA,MAAM,MACxC,QAAS,GAAGn/B,GAAQA,EAAKwzB,UAAW,IAAIzwB,MAAM,mBAAqB08B,GAEtE,CAIS,OAHJJ,EAAQzkC,OAAS,IAAGwkC,EAAI,SAAWC,GACnCC,EAAQ1kC,OAAS,IAAGwkC,EAAI,SAAWE,GACnCt/B,GAAQA,EAAK85B,YAAWrX,EAAMA,EAAIjlB,MAAM,EAAGwC,EAAK85B,YAC5C,CAACrX,EAAK2c,EACf,CAEU,SAAAsB,EAAc3iC,EAAeiC,GACjC,IAAA2gC,EA9HI,SAAY5iC,EAAeiC,GACnC,OAAOA,EAAKiD,MACX,IAAK,SAAU,OAAO87B,EAAgB/jC,EAAc+C,GAAIiC,GACxD,IAAK,SAAiB,OAAA++B,EAAgBhhC,EAAGiC,GACzC,IAAK,SAAU,OAAO++B,EAAgB7jC,GAAWC,OAAOiC,SAASW,GAAKA,EAAE8E,SAAS,UAAYjG,EAAImB,GAAIiC,GACrG,IAAK,QAAS,OAAO++B,EAAgBvc,GAAOzkB,GAAIiC,GAEjD,MAAM,IAAI+C,MAAM,qBAAuB/C,EAAKiD,KAC9C,CAsHe29B,CAAY7iC,EAAGiC,GACxBq6B,EAAMsG,EAAO,GAAInV,EAAKmV,EAAO,GAC7BxmC,EAAIiyB,GAAaiO,EAAKr6B,GAEnB,OADPihB,GAAKuK,GAAIwF,SAAQ,SAAS3hB,GAAOlV,EAAAkV,GAAKmc,EAAGnc,EAAG,IACrClV,CACT,CAIC,SAAS0mC,EAAmB1X,EAAeqC,EAAkBhb,EAAczF,GAC1E,IAAI5Q,EAAI,OAASqW,EAAE,GAAK,MAAQzF,EAAE,GAAK,KACvC,OAAOoe,EAAKnrB,GACX,IAAK,IACJ7D,GAAMgvB,EAAKrrB,GAAG,EACXqrB,EAAK5hB,IAAM4hB,EAAKoO,IAAQp9B,GAAA,KAAO2mC,GAAS3X,EAAK5hB,EAAG,CAAChC,EAAEiL,EAAGzT,EAAEgO,KAAK,MACjE,IAAK,IAAU5Q,GAAAgvB,EAAKrrB,EAAI,OAAS,QAAS,MAC1C,IAAK,IAAU3D,GAAAgvB,EAAK/mB,GAAK+mB,EAAKrrB,EAAG,MACjC,IAAK,IAAK3D,GAAK,KAAOgvB,EAAK/mB,GAAK+mB,EAAKrrB,GAAK,IAAK,MAC/C,IAAK,IAAU3D,GAAA,IAAMgvB,EAAKrrB,EAAE7C,QAAQ,KAAK,IAAIA,QAAQ,KAAM,MAAQ,IAE7D,OAAAd,CACT,CAgDQ,OArMPmhC,EAAa,KAAO,IAqMb,CACNpB,YA/DQ,SAAiBn8B,EAAeiC,GAAqB,OAAOgrB,GAAkB0V,EAAc3iC,EAAGiC,GAAOA,EAAM,EAgEpHm6B,SAAUuG,EACVtG,WA1BQ,SAAc5O,EAAkBxrB,GACxC,IACuCmpB,EAzBZ7oB,EAwBvBygC,EAA6B,CAAC,eAAgB5mC,EAAsB,GACpEoL,EAAIklB,GAAkBe,EAAG,SACzBD,EAAQrvB,MAAMY,QAAQ0uB,GACtBwV,EAAK,OAETD,EAASxxB,KAAK,cACdwxB,EAASxxB,KAAK,mBACXic,EAAG,WA/BqBlrB,EA+BQygC,EAAUvV,EAAG,SA9B3CwF,SAAQ,SAAS7G,EAAKxvB,GAC1B,IAAIsmC,EAAM,OAAStmC,EAAE,GAAK,KAAOA,EAAE,GAAK,IACrCwvB,EAAIkW,OAAeY,GAAA,KAEE,iBAAb9W,EAAIlyB,OAAsBkyB,EAAI+W,MAAS/W,EAAA+W,IAAMC,GAAShX,EAAIlyB,QAC/C,iBAAXkyB,EAAI+W,KAAoB/W,EAAI6P,MAAS7P,EAAA6P,IAAMoH,GAAQjX,EAAI+W,MAC5C,iBAAX/W,EAAI6P,SAAwB37B,KAAKG,MAAM2rB,EAAI6P,OAErB,KAA9BiH,EAAIlmC,OAAOkmC,EAAIrmC,OAAS,IAAe0F,EAAAiP,KAAK0xB,EAClD,KAsBKzV,EAAG,UAnBE,SAAmBlrB,EAAuB+gC,GAC7CA,EAAArQ,SAAQ,SAAShkB,EAAKrS,GAC1B,IAAIsmC,EAAM,KACPj0B,EAAIqzB,OAAeY,GAAA,MACdj0B,EAAIuzB,IAAKU,GAAO,IAAM,GAAKj0B,EAAIuzB,IAAM,IACrCvzB,EAAIwzB,MAAYS,GAAA,IAAM,GAAKK,GAAMt0B,EAAIwzB,KAAO,KACjDS,EAAIrmC,OAAS,GAAG0F,EAAIiP,KAAK0xB,EAAM,KAAOtmC,EAAE,GAC9C,GACA,EAWqComC,EAAUvV,EAAG,UAEhDuV,EAASxxB,KAAK,OAAShK,EAAE7J,EAAE6J,EAAIA,EAAEjJ,EAAEiJ,EAAI,GAAK,MAAQA,EAAE7J,EAAEqB,EAAIwI,EAAEjJ,EAAES,EAAI,GAAK,KAAO,CAACwI,EAAEjJ,EAAES,EAAEwI,EAAEjJ,EAAEiJ,EAAEA,EAAE7J,EAAEqB,EAAEwI,EAAE7J,EAAE6J,GAAGvI,KAAK,MACvG,IAAA,IAAAwT,EAAIjL,EAAEjJ,EAAEiJ,EAAGiL,GAAKjL,EAAE7J,EAAE6J,IAAKiL,EACxB,IAAA,IAAAzF,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAAG,CACnC,IAAIw2B,EAAQ7X,GAAY,CAACnkB,EAAEiL,EAAEzT,EAAEgO,KACxBoe,EAAAoC,GAASC,EAAGhb,IAAI,IAAIzF,GAAIygB,EAAG+V,MACX,MAAVpY,EAAKrrB,GAAeqrB,EAAK5hB,IAAK4hB,EAAKoO,IAChDp9B,EAAEoV,KAAKsxB,EAAmB1X,EAAMqC,EAAIhb,EAAGzF,GAC3C,CAES,OAAAg2B,EAAS/jC,KAAKgkC,GAAMA,EAAK7mC,EAAE6C,KAAKgkC,GAAMA,EAAK,IAAMA,CAC1D,EAOA,CAnOoC,GAqOhCQ,GAA+B,WAUzB,SAAAC,EAAe/8B,EAAgB1E,GAEvC,IADA,IAAIg/B,EAAUt6B,EAAInI,MAAM,MAAOiU,GAAQ,EAAAzF,GAAQ,EAAAvF,EAAK,EAAGid,EAAc,GAC9Djd,IAAOw5B,EAAQpkC,SAAU4K,EAC/B,GAA2B,QAAvBw5B,EAAQx5B,GAAI6X,QAChB,KAAI7M,EAAI,GAAR,CAKA,IAJA,IAAI4f,EAAW4O,EAAQx5B,GAAI6X,OAAO9gB,MAAM,KACpC0G,EAAOmtB,EAAS,GAAIiF,EAAQjF,EAAS,GAErCvzB,EAAOmiC,IADTx5B,IACwB,GACe,GAAjC3I,EAAKgH,MAAM,SAAS,IAAIjJ,QAAe4K,EAAKw5B,EAAQpkC,OAAS,GAAGiC,GAAQ,KAAOmiC,IAAUx5B,GAEjG,OADA3I,EAAOA,EAAKwgB,QACHpa,GACR,KAAK,EACJ,GAAa,QAATpG,EAAgB,CAAM4lB,IAAEjS,GAAK,GAAQzF,EAAA,EAAG,QAAS,IACnC,QAATlO,QAAsB,IAAIkG,MAAM,oCAAsClG,GAC/E,MACD,KAAK,EACQ,SAATA,EAAiB4lB,EAAIjS,GAAGzF,IAAK,EACf,UAATlO,EAAkB4lB,EAAIjS,GAAGzF,IAAK,EAC7BjQ,MAAMkoB,GAASqS,IACfv6B,MAAMwoB,GAAU+R,GAAOn0B,WACvBuhB,EAAAjS,GAAGzF,GAAKsqB,EAD2B5S,EAAIjS,GAAGzF,GAAKuX,GAAU+S,GAD7B5S,EAAAjS,GAAGzF,GAAKiY,GAASqS,KAGpDtqB,EAAG,MACN,KAAK,GAEGlO,GADPA,EAAOA,EAAKW,MAAM,EAAEX,EAAKjC,OAAO,IACpBK,QAAQ,MAAO,OACN4B,EAAKgH,MAAM,aAAmBhH,EAAAA,EAAKW,MAAM,GAAK,IACnEilB,EAAIjS,GAAGzF,KAAgB,KAATlO,EAAcA,EAAO,KAGrC,GAAa,QAATA,EAAgB,KA1BT,OAD6B4lB,IAAEjS,GAAK,GAAQzF,EAAA,EA8BjD,OADJ/K,GAAQA,EAAK85B,YAAWrX,EAAMA,EAAIjlB,MAAM,EAAGwC,EAAK85B,YAC5CrX,CACT,CAEU,SAAAif,EAAah9B,EAAgB1E,GAAsB,OAAOosB,GA7C1D,SAAWruB,EAAeiC,GAClC,OAAOA,EAAKiD,MACX,IAAK,SAAU,OAAOw+B,EAAezmC,EAAc+C,GAAIiC,GACvD,IAAK,SAAiB,OAAAyhC,EAAe1jC,EAAGiC,GACxC,IAAK,SAAU,OAAOyhC,EAAevmC,GAAWC,OAAOiC,SAASW,GAAKA,EAAE8E,SAAS,UAAYjG,EAAImB,GAAIiC,GACpG,IAAK,QAAS,OAAOyhC,EAAejf,GAAOzkB,GAAIiC,GAEhD,MAAM,IAAI+C,MAAM,qBAAuB/C,EAAKiD,KAC9C,CAqCiF0+B,CAAWj9B,EAAK1E,GAAOA,EAAM,CA2DtG,MAAA,CACNk6B,YA3DQ,SAAgBx1B,EAAgB1E,GAAqB,OAAOgrB,GAAkB0W,EAAah9B,EAAK1E,GAAOA,EAAM,EA4DrHm6B,SAAUuH,EACVtH,WA3D2C,WAC3C,IAAIwH,EAAa,SAAYznC,EAAqB0nC,EAAkB/jC,EAAc0L,EAAclN,GAC/FnC,EAAEoV,KAAKsyB,GACL1nC,EAAAoV,KAAKzR,EAAI,IAAM0L,GACjBrP,EAAEoV,KAAK,IAAMjT,EAAErB,QAAQ,KAAK,MAAQ,IACpC,EACG6mC,EAAa,SAAY3nC,EAAqB8I,EAAiBnF,EAAWxB,GAC3EnC,EAAAoV,KAAKtM,EAAO,IAAMnF,GAClB3D,EAAAoV,KAAa,GAARtM,EAAY,IAAM3G,EAAErB,QAAQ,KAAK,MAAQ,IAAMqB,EACtD,EACM,OAAA,SAAsBkvB,GAC5B,IACuCrC,EADnChvB,EAAsB,GACtBoL,EAAIklB,GAAkBe,EAAG,SACzBD,EAAQrvB,MAAMY,QAAQ0uB,GAC1BoW,EAAWznC,EAAG,QAAS,EAAG,EAAG,WAClBynC,EAAAznC,EAAG,UAAW,EAAGoL,EAAE7J,EAAE6J,EAAIA,EAAEjJ,EAAEiJ,EAAI,EAAE,IACnCq8B,EAAAznC,EAAG,SAAU,EAAGoL,EAAE7J,EAAEqB,EAAIwI,EAAEjJ,EAAES,EAAI,EAAE,IAC7C6kC,EAAWznC,EAAG,OAAQ,EAAG,EAAE,IACnB,IAAA,IAAAqW,EAAIjL,EAAEjJ,EAAEiJ,EAAGiL,GAAKjL,EAAE7J,EAAE6J,IAAKiL,EAAG,CACxBsxB,EAAA3nC,GAAO,EAAA,EAAG,OACb,IAAA,IAAA4Q,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAAG,CACnC,IAAIw2B,EAAQ7X,GAAY,CAACnkB,EAAEiL,EAAEzT,EAAEgO,IAE/B,GADOoe,EAAAoC,GAASC,EAAGhb,IAAI,IAAIzF,GAAKygB,EAAG+V,GAEnC,OAAOpY,EAAKnrB,GACX,IAAK,IACJ,IAAImF,EAAegmB,EAAK/mB,EACpBe,GAAiB,MAAVgmB,EAAKrrB,MAAiBqrB,EAAKrrB,GAC5B,MAAPqF,EACWgmB,EAAK5hB,IAAM4hB,EAAKoO,EAAcuK,EAAA3nC,EAAG,EAAG,EAAG,IAAMgvB,EAAK5hB,GAC/Cu6B,EAAA3nC,EAAG,EAAG,EAAG,IAErB2nC,EAAW3nC,EAAG,EAAGgJ,EAAK,KAC3B,MACD,IAAK,IACO2+B,EAAA3nC,EAAG,EAAGgvB,EAAKrrB,EAAI,EAAI,EAAGqrB,EAAKrrB,EAAI,OAAS,SACnD,MACD,IAAK,IACJgkC,EAAW3nC,EAAG,EAAG,EAAeW,MAAMquB,EAAKrrB,GAAMqrB,EAAKrrB,EAAI,KAAOqrB,EAAKrrB,EAAI,KAC1E,MACD,IAAK,IACAqrB,EAAK/mB,IAAQ+mB,EAAA/mB,EAAIU,GAAWqmB,EAAKwB,GAAK7rB,EAAU,IAAK+iB,GAAQS,GAAU6G,EAAKrrB,MACrEgkC,EAAW3nC,EAAG,EAAGgvB,EAAK/mB,EAAG,KAEpC,MACD,QAAoB0/B,EAAA3nC,EAAG,EAAG,EAAG,SAtBP2nC,EAAA3nC,EAAG,EAAG,EAAG,GAwBrC,CACA,CACc2nC,EAAA3nC,GAAO,EAAA,EAAG,OAId,OAFEA,EAAE6C,KADF,OAIT,CACH,CAvD6C,GA6D7C,CA9GmC,GAgH/B+kC,GAA+B,WAElC,SAAS1iB,EAAO/iB,GAAkC,OAAAA,EAAErB,QAAQ,MAAO,OAAOA,QAAQ,KAAM,OAAOA,QAAQ,MAAM,MAAO,CA2B3G,SAAA+mC,EAAajkC,EAAciC,GAAsB,OAAOosB,GAzBxD,SAAW1nB,EAAgB1E,GAEnC,IADA,IAAIg/B,EAAUt6B,EAAInI,MAAM,MAAOiU,GAAQ,EAAAzF,GAAQ,EAAAvF,EAAK,EAAGid,EAAc,GAC9Djd,IAAOw5B,EAAQpkC,SAAU4K,EAAI,CACnC,IAAIk6B,EAASV,EAAQx5B,GAAI6X,OAAO9gB,MAAM,KACnC,GAAc,SAAdmjC,EAAO,GAAP,CACH,IAAIlwB,EAAO4a,GAAYsV,EAAO,IAC3B,GAAAjd,EAAI7nB,QAAU4U,EAAKjK,EAAG,IAAIiL,EAAIiS,EAAI7nB,OAAQ4V,GAAKhB,EAAKjK,IAAKiL,EAAOiS,EAAIjS,KAAQiS,EAAAjS,GAAK,IAE7E,OADPA,EAAIhB,EAAKjK,EAAGwF,EAAIyE,EAAKzS,EACd2iC,EAAO,IACb,IAAK,IAAKjd,EAAIjS,GAAGzF,GAAY20B,EAAO,GAZazkC,QAAQ,OAAO,MAAMA,QAAQ,OAAO,KAAKA,QAAQ,OAAO,MAYhE,MACzC,IAAK,IAAKwnB,EAAIjS,GAAGzF,IAAM20B,EAAO,GAAI,MAClC,IAAK,MAAO,IAAI1E,EAAK0E,EAAOA,EAAO9kC,OAAS,GAE5C,IAAK,MAEE,OADC8kC,EAAO,GACEjd,EAAAjS,GAAGzF,MAAM20B,EAAO,GACtBjd,EAAIjS,GAAGzF,IAAM20B,EAAO,GAEd,OAAbA,EAAO,OAAiBlvB,GAAGzF,GAAK,CAAC0X,EAAIjS,GAAGzF,GAAIiwB,IAdxB,CAgB5B,CAES,OADJh7B,GAAQA,EAAK85B,YAAWrX,EAAMA,EAAIjlB,MAAM,EAAGwC,EAAK85B,YAC5CrX,CACT,CAE+Ewf,CAAWlkC,EAAGiC,GAAOA,EAAM,CAGzG,IAAIuO,EAAS,CACZ,yBACA,oBACA,4EACCvR,KAAK,MAEHklC,EAAM,CACT,qCACA,2CACCllC,KAAK,MAAQ,KAGXmlC,EAAO,CACV,wCACA,cACCnlC,KAAK,MAEH+f,EAAM,uCAEV,SAASqlB,EAAkB5W,GAC1B,IAAIA,IAAOA,EAAG,QAAgB,MAAA,GAItB,IAHR,IAAyDrC,EAArDhvB,EAAsB,GAAIstB,EAAuB,GAAU8Z,EAAQ,GACnEh8B,EAAI8kB,GAAamB,EAAG,SACpBD,EAAQrvB,MAAMY,QAAQ0uB,GAClBhb,EAAIjL,EAAEjJ,EAAEiJ,EAAGiL,GAAKjL,EAAE7J,EAAE6J,IAAKiL,EACxB,IAAA,IAAAzF,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAGhC,GAFAw2B,EAAQ7X,GAAY,CAACnkB,EAAEiL,EAAEzT,EAAEgO,KACpBoe,EAAAoC,GAASC,EAAGhb,IAAI,IAAIzF,GAAKygB,EAAG+V,KACb,MAAVpY,EAAKrrB,GAAwB,MAAXqrB,EAAKnrB,EAAnC,CAEA,OADKypB,EAAA,CAAC,OAAQ8Z,EAAO,KACdpY,EAAKnrB,GACX,IAAK,IAAK,IAAK,MAAOypB,EAAGlY,KAAK8P,EAAO8J,EAAKrrB,IAAK,MAC/C,IAAK,IACAqrB,EAAK5hB,GACFkgB,EAAG,GAAG,MAAOA,EAAG,GAAG,IAAQA,EAAA,GAAG0B,EAAKrrB,EAAG2pB,EAAG,GAAGpI,EAAO8J,EAAK5hB,KADjDkgB,EAAG,GAAG,IAAQA,EAAA,GAAG0B,EAAKrrB,GAEpC,MACD,IAAK,IACJ2pB,EAAG,GAAK,MAAM0B,EAAK5hB,EAAE,IAAI,KAAMkgB,EAAG,GAAG,KAAMA,EAAG,GAAG0B,EAAKrrB,EAAE,IAAI,IACzD2pB,EAAA,GAAKpI,EAAO8J,EAAK5hB,IAAI4hB,EAAKrrB,EAAE,OAAO,UACtC,MACD,IAAK,IACJ,IAAIE,EAAI6jB,GAAQS,GAAU6G,EAAKrrB,IAC/B2pB,EAAG,GAAK,MAAOA,EAAG,GAAK,KAASA,EAAA,GAAK,GAAGzpB,EACrCypB,EAAA,GAAK0B,EAAK/mB,GAAKU,GAAWqmB,EAAKwB,GAAK7rB,EAAU,IAAKd,GACtD,MACD,IAAK,IAAK,SAEX7D,EAAEoV,KAAKkY,EAAGzqB,KAAK,KAnB+B,CAyBzC,OAHP7C,EAAEoV,KAAK,YAAchK,EAAE7J,EAAEqB,EAAEwI,EAAEjJ,EAAES,EAAE,GAAK,OAASwI,EAAE7J,EAAE6J,EAAEA,EAAEjJ,EAAEiJ,EAAE,GAAK,UAChEpL,EAAEoV,KAAK,2BAEApV,EAAE6C,KAAK,KAChB,CAOQ,MAAA,CACNk9B,YAhEQ,SAAgBn8B,EAAciC,GAAqB,OAAOgrB,GAAkBgX,EAAajkC,EAAGiC,GAAOA,EAAM,EAiEjHm6B,SAAU6H,EACV5H,WARD,SAAsB5O,GACd,MAAA,CAACjd,EAAQ2zB,EAAKC,EAAMD,EAAKE,EAAkB5W,GAAKzO,GAAK/f,KAAK,KAEnE,EAOA,CAlGmC,GAoG/BqlC,GAA+B,WAClC,SAASC,EAAazlC,EAAiB4lB,EAAajS,EAAczF,EAAc5Q,GAC5EA,EAAEqX,IAAKiR,EAAIjS,GAAGzF,GAAKlO,EACL,KAATA,IACS,SAATA,EAAiB4lB,EAAIjS,GAAGzF,IAAK,EACpB,UAATlO,EAAkB4lB,EAAIjS,GAAGzF,IAAK,EAC7BjQ,MAAMkoB,GAASnmB,IACf/B,MAAMwoB,GAAUzmB,GAAMqE,WACtBuhB,EAAAjS,GAAGzF,GAAKlO,EAD0B4lB,EAAIjS,GAAGzF,GAAKuX,GAAUzlB,GAD7B4lB,EAAAjS,GAAGzF,GAAKiY,GAASnmB,GAGvD,CA6BC,IAAI0lC,EAAa,CACT,GAAa,IACb,EAAa,KACb,GAAa,IACb,IAAa,KAIjBC,EAAoB,CAChB,GAAa,EACb,EAAa,EACb,GAAa,EACb,IAAa,GAGrB,SAASC,EAAU/9B,GAElB,IADA,IAAImN,EAAM,CAAA,EAAI6wB,GAAQ,EAAO3lB,EAAM,EAAGpY,EAAK,EACtCoY,EAAMrY,EAAI9J,SAASmiB,EACQ,KAA3BpY,EAAGD,EAAI7J,WAAWkiB,OAAwB2lB,GACrCA,GAAS/9B,KAAM49B,IAAY1wB,EAAIlN,IAAOkN,EAAIlN,IAAK,GAAG,GAIxD,IAAAoY,KADJpY,EAAK,GACMkN,EAAUc,OAAOyO,UAAUC,eAAe5jB,KAAKoU,EAAKkL,IAC9DpY,EAAG4K,KAAK,CAAEsC,EAAIkL,GAAMA,IAGhB,IAACpY,EAAG/J,OAEJ,IAAAmiB,KADElL,EAAA2wB,EACe7vB,OAAOyO,UAAUC,eAAe5jB,KAAKoU,EAAKkL,IAC9DpY,EAAG4K,KAAK,CAAEsC,EAAIkL,GAAMA,IAMtB,OAFGpY,EAAAmO,MAAK,SAASsE,EAAGd,GAAK,OAAOc,EAAE,GAAKd,EAAE,IAAMksB,EAAkBprB,EAAE,IAAMorB,EAAkBlsB,EAAE,OAEtFisB,EAAW59B,EAAG6N,MAAM,KAAO,EACpC,CAEU,SAAAmwB,EAAiBj+B,EAAgB1E,GACrC,IAAA7F,EAAI6F,GAAQ,CAAE,EACdkiC,EAAM,GAEN1W,EAAmBrxB,EAAEoxB,MAAS,GAAe,CAAA,EAC7C/B,EAAmB,CAACltB,EAAG,CAACS,EAAE,EAAGwI,EAAE,GAAI7J,EAAG,CAACqB,EAAE,EAAGwI,EAAE,IAE7B,QAAlBb,EAAIlH,MAAM,EAAE,GAEU,IAArBkH,EAAI7J,WAAW,IAAiC,IAArB6J,EAAI7J,WAAW,IACtCqnC,EAAAx9B,EAAI3J,OAAO,GAAU2J,EAAAA,EAAIlH,MAAM,IAGT,IAArBkH,EAAI7J,WAAW,IAAiC,IAArB6J,EAAI7J,WAAW,IAC3CqnC,EAAAx9B,EAAI3J,OAAO,GAAU2J,EAAAA,EAAIlH,MAAM,IAE3B0kC,EAAAO,EAAU/9B,EAAIlH,MAAM,EAAE,SAE1BrD,GAAKA,EAAEyoC,GAAUzoC,EAAEyoC,GAChBH,EAAU/9B,EAAIlH,MAAM,EAAE,OACjC,IAAIgT,EAAI,EAAGzF,EAAI,EAAGjN,EAAI,EAClB6S,EAAQ,EAAGoM,EAAM,EAAG8lB,EAAQX,EAAIrnC,WAAW,GAAI6nC,GAAQ,EAAO/9B,EAAG,EAAGm+B,EAAQp+B,EAAI7J,WAAW,GACzF6J,EAAAA,EAAIzJ,QAAQ,SAAU,MAC5B,IAj+NoB6M,EACjB5E,EAg+NC6/B,EAA8B,MAAZ5oC,EAAE2N,QAj+NJA,EAi+NkC3N,EAAE2N,OA/9NnD5E,GADFA,EAAuB,iBAAV4E,EAAqBhJ,EAAUgJ,GAAUA,GAChD7M,QAAQmO,GAAa,UACxB,IAAI4b,OAAO,IAAM9hB,EAAM,MA89NqC,KAClE,SAAS8/B,IACR,IAAI1mC,EAAIoI,EAAIlH,MAAMmT,EAAOoM,GACrBoM,EAAQ,CAAA,EAEZ,GADkB,KAAf7sB,EAAEvB,OAAO,IAAuC,KAA1BuB,EAAEvB,OAAOuB,EAAE1B,OAAS,KAAW0B,EAAIA,EAAEkB,MAAM,MAAMvC,QAAQ,MAAM,MACxE,IAAbqB,EAAE1B,OAAcuuB,EAAKnrB,EAAI,SAAA,GACpB7D,EAAEqX,IAAO2X,EAAKnrB,EAAI,IAAKmrB,EAAKrrB,EAAIxB,OAChC,GAAoB,IAApBA,EAAE+gB,OAAOziB,OAAgBuuB,EAAKnrB,EAAI,IAAKmrB,EAAKrrB,EAAIxB,OAChD,GAAmB,IAAnBA,EAAEzB,WAAW,GACE,IAAnByB,EAAEzB,WAAW,IAA4C,IAA9ByB,EAAEzB,WAAWyB,EAAE1B,OAAS,IAAcuuB,EAAKnrB,EAAI,IAAUmrB,EAAArrB,EAAIxB,EAAEkB,MAAM,MAAMvC,QAAQ,MAAM,MAqmH3G,GApmHMqB,EAomHhB1B,QApmHsBuuB,EAAKnrB,EAAI,IAAUmrB,EAAA5hB,EAAIjL,EAAEkB,MAAM,KAChD2rB,EAAKnrB,EAAI,IAAKmrB,EAAKrrB,EAAIxB,QAAI,GACtB,QAALA,EAAe6sB,EAAKnrB,EAAI,IAAKmrB,EAAKrrB,GAAI,OAAK,GACtC,SAALxB,EAAgB6sB,EAAKnrB,EAAI,IAAKmrB,EAAKrrB,GAAI,UACtChD,MAAMgD,EAAIklB,GAAS1mB,IACpB,IAACxB,MAAMwoB,GAAUhnB,GAAG4E,YAAc6hC,GAAOzmC,EAAEuH,MAAMk/B,GAAM,CAC9D5Z,EAAKwB,EAAIxwB,EAAE2N,QAAUhJ,EAAU,IAC/B,IAAIuQ,EAAI,EACL0zB,GAAOzmC,EAAEuH,MAAMk/B,KAASzmC,EA9+N/B,SAAoBoI,EAAgBoD,EAAmBjE,GAClD,IAAAo/B,GAAQ,EAAAviC,GAAQ,EAAA3C,KAAQ4C,GAAI,EAAIC,GAAI,EAAIC,GAAI,GAC/CiH,EAAOjE,MAAMuF,KAAc,IAAI4nB,SAAQ,SAASxnB,EAAG7O,GACnD,IAAImD,EAAI+H,SAAShC,EAAMlJ,EAAE,GAAI,IAC7B,OAAO6O,EAAEpB,cAAcrN,OAAO,IAC7B,IAAK,IAASkoC,EAAAnlC,EAAG,MAAO,IAAK,IAASC,EAAAD,EAAG,MACzC,IAAK,IAAS6C,EAAA7C,EAAG,MAAO,IAAK,IAAS+C,EAAA/C,EAAG,MACzC,IAAK,IAAQ6C,GAAK,EAAOC,EAAA9C,EAAY4C,EAAA5C,EAExC,IACI+C,GAAK,IAAU,GAALD,GAAWF,GAAK,IAASE,EAAAF,EAAOA,GAAA,GAC7C,IAAIwiC,GAAY,IAAMD,GAAG,EAAEA,GAAG,IAAIjiC,MAAOG,gBAAgB3D,OAAM,GAAM,KAAO,MAAQkD,GAAG,EAAEA,EAAE,IAAIlD,OAAQ,GAAI,KAAO,MAAQO,GAAG,EAAEA,EAAE,IAAIP,OAAQ,GACxH,GAAlB0lC,EAAQtoC,SAAasoC,EAAU,IAAMA,GACnB,GAAlBA,EAAQtoC,SAAasoC,EAAU,KAAOA,GACrC,IAAAC,GAAY,MAAQxiC,GAAG,EAAEA,EAAE,IAAInD,OAAM,GAAM,KAAO,MAAQoD,GAAG,EAAEA,EAAE,IAAIpD,OAAM,GAAM,KAAO,MAAQqD,GAAG,EAAEA,EAAE,IAAIrD,OAAQ,GACvH,OAAc,GAAXmD,IAAsB,GAAXC,OAAWC,EAAgBqiC,GAC3B,GAAXD,IAAsB,GAAXviC,OAAW3C,EAAgBolC,EAClCD,EAAU,IAAMC,CACxB,CA49N+BC,CAAW9mC,EAAGnC,EAAE2N,OAASxL,EAAEuH,MAAMk/B,IAAM,IAAQ1zB,EAAA,GACvElV,EAAE+xB,WAAa/C,EAAKnrB,EAAI,IAAUmrB,EAAArrB,EAAIwkB,GAAUhmB,EAAG+S,KAC/C8Z,EAAKnrB,EAAI,IAAKmrB,EAAKrrB,EAAI+jB,GAAQS,GAAUhmB,EAAG+S,MACjC,IAAflV,EAAEkpC,WAAyBla,EAAA/mB,EAAIU,GAAWqmB,EAAKwB,EAAGxB,EAAKrrB,aAAakD,KAAO6gB,GAAQsH,EAAKrrB,GAAGqrB,EAAKrrB,IAC/F3D,EAAEmpC,eAAena,EAAKwB,CAC9B,MACIxB,EAAKnrB,EAAI,IACTmrB,EAAKrrB,EAAIxB,OAXyB6sB,EAAKnrB,EAAI,KAAuB,IAAf7D,EAAEkpC,WAAoBla,EAAK/mB,EAAI9F,GAAG6sB,EAAKrrB,EAAIA,EAmB5F,GANU,KAAVqrB,EAAKnrB,IACA7D,EAAEoxB,OAAaC,EAAGhb,KAAOgb,EAAAhb,GAAK,IAAOgb,EAAAhb,GAAGzF,GAAKoe,GAC7CqC,EAAA9B,GAAY,CAAC3sB,EAAEgO,EAAExF,EAAEiL,KAAO2Y,GAClCxY,EAAQoM,EAAI,EAAa+lB,EAAAp+B,EAAI7J,WAAW8V,GACrC6Y,EAAM9tB,EAAEqB,EAAIgO,IAAGye,EAAM9tB,EAAEqB,EAAIgO,GAC3Bye,EAAM9tB,EAAE6J,EAAIiL,IAAGgZ,EAAM9tB,EAAE6J,EAAIiL,GAC3B7L,GAAMk+B,IAAS93B,OAAsB,GAARA,EAAA,IAAKyF,EAAMrW,EAAE2/B,WAAa3/B,EAAE2/B,WAAatpB,EAAU,OAAA,CACtF,CACS+yB,EAAA,KAAKxmB,EAAMrY,EAAI9J,SAASmiB,EAAK,OAAQpY,EAAGD,EAAI7J,WAAWkiB,IAC7D,KAAK,GAAqB,KAAZ+lB,IAAkBJ,GAASA,GAAO,MAChD,KAAKG,EAAO,KAAK,GAAM,KAAK,GAAM,IAAIH,GAASM,IAAqB,MAAAO,EAM9D,OAHJxmB,EAAMpM,EAAQ,GAAgBqyB,IAE9BxX,EAAA,QAAUlB,GAAad,GACnBgC,CACT,CAEU,SAAAgY,EAAiB9+B,EAAgB1E,GACzC,OAAKA,GAAQA,EAAKqiC,IACfriC,EAAK4iC,IACa,QAAlBl+B,EAAIlH,MAAM,EAAE,IACZkH,EAAInL,QAAQ,OAAS,GAAKmL,EAAInL,QAAQ,MAAQ,GAAKmL,EAAInL,QAAQ,MAAQ,EAFvDopC,EAAiBj+B,EAAK1E,GAGlCosB,GA5IC,SAAe7kB,EAAcvH,GACjC,IAAA7F,EAAI6F,GAAQ,CAAE,EACdyiB,EAAe,GACnB,IAAIlb,GAAkB,IAAbA,EAAE3M,OAAqB,OAAA6nB,EAGhC,IAFI,IAAAghB,EAAQl8B,EAAEhL,MAAM,UAChByO,EAAIy4B,EAAM7oC,OAAS,EACjBoQ,GAAK,GAAyB,IAApBy4B,EAAMz4B,GAAGpQ,UAAgBoQ,EAGnC,IAFF,IAAA2F,EAAQ,GAAI/M,EAAM,EAClB4M,EAAI,EACFA,GAAKxF,IAAKwF,GAEL,IADV5M,EAAM6/B,EAAMjzB,GAAGjX,QAAQ,MACHqK,EAAA6/B,EAAMjzB,GAAG5V,OAAagJ,IAClC+M,EAAAtS,KAAKiI,IAAIqK,EAAO/M,GAEzB,IAAI4M,EAAI,EAAGA,GAAKxF,IAAKwF,EAAG,CACnBiS,EAAAjS,GAAK,GAET,IAAIzF,EAAI,EAEJ,IADJu3B,EAAamB,EAAMjzB,GAAGhT,MAAM,EAAGmT,GAAO0M,OAAQoF,EAAKjS,EAAGzF,EAAG5Q,GACrD4Q,EAAI,EAAGA,IAAM04B,EAAMjzB,GAAG5V,OAAS+V,GAAO,GAAK,IAAK5F,EACnDu3B,EAAamB,EAAMjzB,GAAGhT,MAAMmT,EAAY,IAAL5F,EAAE,GAAM4F,EAAQ,GAAF5F,GAAMsS,OAAOoF,EAAIjS,EAAEzF,EAAE5Q,EAC1E,CAES,OADJA,EAAE2/B,YAAWrX,EAAMA,EAAIjlB,MAAM,EAAGrD,EAAE2/B,YAC9BrX,CACT,CAoHsBihB,CAAeh/B,EAAK1E,GAAOA,GAJhB2iC,EAAiBj+B,EAAK1E,EAKvD,CAEU,SAAA2jC,EAAa5lC,EAAeiC,GACpC,IAAI0E,EAAM,GAAIk/B,EAAqB,UAAb5jC,EAAKiD,KAAmB,CAAC,EAAE,EAAE,EAAE,GAg5dvD,SAAmBsE,EAAcpN,GAChC,IAAIP,EAAI,GACR,QAAQO,GAAG,IAAI8I,MAAQ,UACtB,IAAK,SAGL,IAAK,QAAiB,MAAA,CAACsE,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,IAFnE,IAAK,SAAU3N,EAAIoB,EAAcuM,EAAE/J,MAAM,EAAE,KAAM,MACjD,IAAK,SAAc5D,EAAA2N,EAAG,MAEtB,QAAS,MAAM,IAAIxE,MAAM,sBAAwB5I,GAAKA,EAAE8I,MAAQ,cAEjE,MAAO,CAACrJ,EAAEiB,WAAW,GAAIjB,EAAEiB,WAAW,GAAIjB,EAAEiB,WAAW,GAAIjB,EAAEiB,WAAW,GAAIjB,EAAEiB,WAAW,GAAIjB,EAAEiB,WAAW,GAAIjB,EAAEiB,WAAW,GAAIjB,EAAEiB,WAAW,GAC7I,CA15d4DgpC,CAAU9lC,EAAGiC,GACvE,OAAOA,EAAKiD,MACX,IAAK,SAAUyB,EAAM1J,EAAc+C,GAAI,MACvC,IAAK,SAOL,IAAK,SAAgB2G,EAAA3G,EAAG,MANxB,IAAK,SACgB,OAAjBiC,EAAK05B,SAAyBh1B,EAAA3G,EAAE8E,SAAS,SACpC7C,EAAK05B,SACRh1B,EAAMxJ,GAAWC,OAAOiC,SAASW,GAAKA,EAAE8E,SAAS,UAAYjG,EAAImB,IACtE,MACD,IAAK,QAAS2G,EAAM8d,GAAOzkB,GAAI,MAE/B,QAAS,MAAM,IAAIgF,MAAM,qBAAuB/C,EAAKiD,MAKtD,OAHe,KAAZ2gC,EAAM,IAA0B,KAAZA,EAAM,IAA0B,KAAZA,EAAM,GAAYl/B,EAAMmgB,GAASngB,EAAIlH,MAAM,IACjE,UAAbwC,EAAKiD,MAAiC,UAAbjD,EAAKiD,MAAqC,OAAjBjD,EAAK05B,SAAyBh1B,EAAAmgB,GAASngB,GACxF1E,EAAKiD,KACQ,uBAAnByB,EAAIlH,MAAM,EAAE,IAAqCukC,GAAI5H,SAAsB,UAAbn6B,EAAKiD,KAAmByB,EAAMmgB,GAASngB,GAAM1E,GACvGwjC,EAAiB9+B,EAAK1E,EAC/B,CAuBQ,MAAA,CACNk6B,YAtBQ,SAAgBn8B,EAAeiC,GAAqB,OAAOgrB,GAAkB2Y,EAAa5lC,EAAGiC,GAAOA,EAAM,EAuBlHm6B,SAAUwJ,EACVvJ,WAtBD,SAAsB5O,GAIb,IAHR,IACuCrC,EADnChvB,EAAsB,GACtBoL,EAAIklB,GAAkBe,EAAG,SACzBD,EAAQrvB,MAAMY,QAAQ0uB,GAClBhb,EAAIjL,EAAEjJ,EAAEiJ,EAAGiL,GAAKjL,EAAE7J,EAAE6J,IAAKiL,EAAG,CAE3B,IADR,IAAIiX,EAAuB,GACnB1c,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAAG,CACnC,IAAIw2B,EAAQ7X,GAAY,CAACnkB,EAAEiL,EAAEzT,EAAEgO,IAE/B,IADOoe,EAAAoC,GAASC,EAAGhb,IAAI,IAAIzF,GAAKygB,EAAG+V,KACb,MAAVpY,EAAKrrB,EAAjB,CAEM,IADF,IAAAsE,GAAK+mB,EAAK/mB,IAAM0oB,GAAY3B,GAAOA,EAAK/mB,IAAM,IAAI5E,MAAM,EAAE,IACxD4E,EAAExH,OAAS,IAASwH,GAAA,IAC1BqlB,EAAGlY,KAAKnN,GAAW,IAAN2I,EAAU,IAAM,IAHiC,MAAhC0c,EAAGlY,KAAK,aAI1C,CACGpV,EAAEoV,KAAKkY,EAAGzqB,KAAK,IAClB,CACS,OAAA7C,EAAE6C,KAAK,KAChB,EAOA,CAzMmC,GAyN/B8mC,GAA+B,WACzB,SAAAC,EAAYlnC,EAAMmnC,EAAuBhkC,GACjD,GAAInD,EAAJ,CACUmP,GAAAnP,EAAMA,EAAK6K,GAAK,GAEpB,IADF,IAAAu8B,EAAOjkC,EAAKikC,MAAQC,EAClBrnC,EAAK6K,EAAI7K,EAAKjC,QAAQ,CACvB,IAAA+kC,EAAK9iC,EAAKqP,WAAW,GACrBsE,EAAIyzB,EAAKtE,IAAOsE,EAAK,OACrBrpC,EAASiC,EAAKqP,WAAW,GACzBE,EAAMvP,EAAK6K,EAAI9M,EACfmD,EAAIyS,EAAEjJ,GAAKiJ,EAAEjJ,EAAE1K,EAAMjC,EAAQoF,GAEjC,GADAnD,EAAK6K,EAAI0E,EACN43B,EAAGjmC,EAAGyS,EAAGmvB,GAAK,MACpB,CAXY,CAYZ,CAYU,SAAAwE,EAAsBpmC,EAAGiC,GAC9B,IAACjC,EAAU,OAAAA,EACV,IAAA5D,EAAI6F,GAAQ,CAAE,EAEd1D,EAAoBnC,EAAEoxB,MAAQ,GAAK,CAAE,EAAY/hB,EAAI,SAAU46B,EAAS,GAAIC,EAAO,EACnFnZ,EAAS,CAAE,EAAEoZ,EAAS,GAAIC,EAAY,GAEtCC,EAAW,CAACloC,EAAG,CAACiJ,EAAE,EAAGxI,EAAE,GAAIrB,EAAG,CAAC6J,EAAE,EAAGxI,EAAE,IACtC+8B,EAAY3/B,EAAE2/B,WAAa,EAE5B,GAAQ,GAAR/7B,EAAE,KACO,GAARA,EAAE,IAAsB,GAARA,EAAE,KACjBA,EAAEnD,QAAU,IAAe,GAATmD,EAAE,KAAyB,MAAVA,EAAE,IAAoB,MAAA,IAAIgF,MAAM,oCAIrE,GAAQ,GAARhF,EAAE,GACJ5D,EAAE8pC,KAAOC,EACTH,EAAYhmC,GAAG,SAASoF,EAAKqN,EAAGmvB,GAAM,OAAOA,GAC5C,KAAK,EACJxlC,EAAEsqC,KAAOthC,EACNA,GAAO,OAAQhJ,EAAEuqC,MAAO,GAC3B,MACD,KAAK,EAAiBF,EAAArhC,EAAK,MAC3B,KAAK,IAASA,IAAcihC,EAAAjhC,GAAK,MACjC,KAAK,IAAeihC,EAAAjhC,EAAK,MACzB,KAAK,GACL,KAAK,GACAhJ,EAAEuqC,OAAMvhC,EAAI,GAAGrF,EAAIqF,EAAI,GAAGrF,EAAEN,MAAM,IAEvC,KAAK,GACL,KAAK,GACL,KAAK,GAEK,IAANmiC,KAAiC,KAAlBx8B,EAAI,MAAgC,GAATA,EAAI,IAAa,IAAe,GAATA,EAAI,IAAa,KACpFA,EAAI,GAAGwnB,EAAIxwB,EAAE2N,QAAUhJ,EAAU,IAC9B3E,EAAE+xB,YAAiB/oB,EAAA,GAAGnF,EAAI,IAAKmF,EAAI,GAAGrF,EAAImkB,GAAQ9e,EAAI,GAAGrF,KAG1D3D,EAAEuqC,MACDvhC,EAAI,GAAKkhC,IACT/nC,EAAA,QAAUguB,GAAaka,GACzBtZ,EAAO1hB,GAAKlN,EACZgoC,EAAO/0B,KAAK/F,GACZlN,EAAKnC,EAAEoxB,MAAQ,GAAK,CAAA,EACpBiZ,EAAW,CAACloC,EAAG,CAACiJ,EAAE,EAAGxI,EAAE,GAAIrB,EAAG,CAAC6J,EAAE,EAAGxI,EAAE,IACtCsnC,EAAOlhC,EAAI,GAAQqG,EAAA46B,GAAU,SAAWC,EAAO,GAAaD,EAAA,IAI1D,IAAAO,EAAUxqC,EAAEoxB,OAASjvB,EAAE6G,EAAI,GAAGoC,IAAI,IAAIpC,EAAI,GAAGpG,GAAKT,EAAEotB,GAAYvmB,EAAI,KACxE,GAAGwhC,EAAS,CACHA,EAAA3mC,EAAImF,EAAI,GAAGnF,EAAW2mC,EAAA7mC,EAAIqF,EAAI,GAAGrF,EAC1B,MAAZqF,EAAI,GAAGwnB,IAAmBga,EAAAha,EAAIxnB,EAAI,GAAGwnB,GACzB,MAAZxnB,EAAI,GAAGoE,IAAmBo9B,EAAAp9B,EAAIpE,EAAI,GAAGoE,GACxC,KACN,CACQpN,EAAEoxB,OACAjvB,EAAE6G,EAAI,GAAGoC,KAAIjJ,EAAE6G,EAAI,GAAGoC,GAAK,IAC7BjJ,EAAA6G,EAAI,GAAGoC,GAAGpC,EAAI,GAAGpG,GAAKoG,EAAI,MACpBumB,GAAYvmB,EAAI,KAAOA,EAAI,GAGrC,GAAGhJ,OACP,IAAoB,IAAR4D,EAAE,IAAsB,IAARA,EAAE,GAqCf,MAAA,IAAIgF,MAAM,0BAA4BhF,EAAE,IApCpD5D,EAAE8pC,KAAOW,EACE,IAAR7mC,EAAE,KAAc5D,EAAEuqC,MAAO,EAAM3mC,EAAE2J,EAAI,GACxCq8B,EAAYhmC,GAAG,SAASoF,EAAKqN,EAAGmvB,GAAM,OAAOA,GAC5C,KAAK,IAAUn2B,EAAArG,EAAK,MACpB,KAAK,GACAA,EAAA,GAAGrF,EAAIqF,EAAI,GAAGrF,EAAEN,MAAM,GAE3B,KAAK,GACL,KAAK,GACL,KAAK,GACL,KAAK,GACL,KAAK,GACL,KAAK,GASJ,GARG2F,EAAI,GAAKkhC,IACT/nC,EAAA,QAAUguB,GAAaka,GACzBtZ,EAAO1hB,GAAKlN,EACZgoC,EAAO/0B,KAAK/F,GACZlN,EAAKnC,EAAEoxB,MAAQ,GAAK,CAAA,EACpBiZ,EAAW,CAACloC,EAAG,CAACiJ,EAAE,EAAGxI,EAAE,GAAIrB,EAAG,CAAC6J,EAAE,EAAGxI,EAAE,IACtCsnC,EAAOlhC,EAAI,GAAIqG,EAAI,SAAW66B,EAAO,IAEnCvK,EAAY,GAAK32B,EAAI,GAAGoC,GAAKu0B,EAAW,MACxC3/B,EAAEoxB,OACAjvB,EAAE6G,EAAI,GAAGoC,KAAIjJ,EAAE6G,EAAI,GAAGoC,GAAK,IAC7BjJ,EAAA6G,EAAI,GAAGoC,GAAGpC,EAAI,GAAGpG,GAAKoG,EAAI,MACpBumB,GAAYvmB,EAAI,KAAOA,EAAI,GACjCqhC,EAAS9oC,EAAEqB,EAAIoG,EAAI,GAAGpG,IAAGynC,EAAS9oC,EAAEqB,EAAIoG,EAAI,GAAGpG,GAC/CynC,EAAS9oC,EAAE6J,EAAIpC,EAAI,GAAGoC,IAAGi/B,EAAS9oC,EAAE6J,EAAIpC,EAAI,GAAGoC,GAClD,MACD,KAAK,GACDpC,EAAI,QAASohC,EAAUphC,EAAI,MAAQ,IAAMA,EAAI,MAAQ,IACxD,MACD,KAAK,KACJohC,EAAUphC,EAAI,IAAMA,EAAI,GAAOA,EAAI,IAAMkhC,IAAM76B,EAAIrG,EAAI,IAExD,GAAGhJ,EACkD,CAIpD,GAHDmC,EAAA,QAAUguB,GAAaka,GAClBtZ,EAAAkZ,GAAU56B,GAAKlN,EACfgoC,EAAA/0B,KAAK60B,GAAU56B,IAClB+6B,EAAU3pC,OAAQ,MAAO,CAAEuwB,WAAYmZ,EAAQlZ,OAAQF,GAG3D,IAFA,IAAI2Z,EAAU,GAAIC,EAAS,GAEnBnqC,EAAI,EAAGA,EAAI4pC,EAAU3pC,SAAUD,EAAMuwB,EAAOoZ,EAAO3pC,KAC1DmqC,EAAOv1B,KAAKg1B,EAAU5pC,IAAM2pC,EAAO3pC,IACnCkqC,EAAQN,EAAU5pC,IAAMuwB,EAAOqZ,EAAU5pC,KAAOuwB,EAAOoZ,EAAO3pC,MAEvDmqC,EAAAv1B,KAAKg1B,EAAU5pC,IACtBkqC,EAAQN,EAAU5pC,IAAO,CAAE,OAAQ,OAEpC,MAAO,CAAEwwB,WAAY2Z,EAAQ1Z,OAAQyZ,EACvC,CA8IU,SAAAE,EAAWh5B,EAAMnR,EAAQoF,GACjC,IAAI7F,EAAI,CAAC,CAAC4C,EAAE,EAAEwI,EAAE,GAAI,CAACvH,EAAE,IAAIF,EAAE,GAAI,EAAG,GAU7B,OATJkC,EAAK0kC,MAAqB,OAAb1kC,EAAKykC,MACpBtqC,EAAE,GAAG4C,EAAIgP,EAAKG,WAAW,GACzB/R,EAAE,GAAK4R,EAAKG,WAAW,GACvB/R,EAAE,GAAGoL,EAAIwG,EAAKG,WAAW,GACzBH,EAAKrE,GAAG,IAERvN,EAAE,GAAK4R,EAAKG,WAAW,GACvB/R,EAAE,GAAG4C,EAAIgP,EAAKG,WAAW,GAAI/R,EAAE,GAAGoL,EAAIwG,EAAKG,WAAW,IAEhD/R,CACT,CAEU,SAAA6qC,EAAYj5B,EAAMnR,EAAQoF,GAC9B,IAAAoM,EAAML,EAAKrE,EAAI9M,EACfT,EAAI4qC,EAAWh5B,EAAMnR,EAAQoF,GAE9B,GADD7F,EAAA,GAAG6D,EAAI,IACO,OAAbgC,EAAKykC,KAAgB,CAClB14B,EAAArE,IACD,IAAA3L,EAAMgQ,EAAKG,WAAW,GAEnB,OADP/R,EAAE,GAAG2D,EAAIiO,EAAKG,WAAWnQ,EAAK,QACvB5B,CACV,CAGS,OAFJ6F,EAAK0kC,MAAW34B,EAAArE,IACjBvN,EAAA,GAAG2D,EAAIiO,EAAKG,WAAWE,EAAML,EAAKrE,EAAG,QAChCvN,CACT,CACU,SAAA8qC,EAAYz0B,EAAGzF,EAAGzO,GAE1B,IAAInC,EAAIyX,GAAQ,EAAItV,EAAE1B,QACpBT,EAAAyR,YAAY,EAAG,KACfzR,EAAAyR,YAAY,EAAGb,GACf5Q,EAAAyR,YAAY,EAAG4E,GACfrW,EAAAyR,YAAY,EAAG,IACjB,IAAA,IAAQjR,EAAI,EAAGA,EAAIR,EAAES,SAAUD,EAAG,CAC7B,IAAAgK,EAAKrI,EAAEzB,WAAWF,GACtBR,EAAEyR,YAAY,EAAGjH,GAAM,IAAO,GAAOA,EACxC,CAES,OADLxK,EAAAyR,YAAY,EAAG,GACVzR,CACT,CAOU,SAAA+qC,EAAc10B,EAAGzF,EAAGjN,GACxB,IAAA3D,EAAIyX,GAAQ,GAKT,OAJLzX,EAAAyR,YAAY,EAAG,KACfzR,EAAAyR,YAAY,EAAGb,GACf5Q,EAAAyR,YAAY,EAAG4E,GACfrW,EAAAyR,YAAY,EAAG9N,EAAG,KACb3D,CACT,CAOU,SAAAgrC,EAAa30B,EAAGzF,EAAGjN,GACvB,IAAA3D,EAAIyX,GAAQ,IAKT,OAJLzX,EAAAyR,YAAY,EAAG,KACfzR,EAAAyR,YAAY,EAAGb,GACf5Q,EAAAyR,YAAY,EAAG4E,GACfrW,EAAAyR,YAAY,EAAG9N,EAAG,KACb3D,CACT,CAgBU,SAAAirC,EAAa/lC,EAAG2C,EAAGmoB,GAC3B,IAAIkb,EAAU,MAAJrjC,EAGF,OADRA,GAAKqjC,EAAMhmC,EAAI,KADV2C,IAAA,QACsB,KAAUA,EAAI,MAASA,IAC1CqjC,EAAM,GAAK,MAAQlb,EAAML,GAAW9nB,GAAK6nB,GAAW7nB,GAC9D,CAMC,IAAIsjC,EAAU,CACb,GAAM,CAAC,QAAS,GAChB,GAAM,CAAC,OAAQ,GACf,GAAM,CAAC,MAAO,GACd,GAAM,CAAC,MAAO,IACd,GAAM,CAAC,WAAY,IACnB,GAAM,CAAC,SAAU,IACjB,GAAM,CAAC,OAAQ,IACf,GAAM,CAAC,OAAQ,IACf,IAAM,CAAC,IAAK,IAETC,EAAW,CACZ,GAAM,GAAM,GAAM,GAAM,GAAM,GAAM,GAAM,GAC1C,GAAK,IAAM,IAAM,IAAM,IAAM,IAAM,IAAK,KAC1C,KAAM,KAAO,IAAM,IAAO,GAAM,GAAM,GAAM,GAC3C,IAAO,GAAM,GAAM,GAAM,GAAM,GAAM,GAAM,IAmE7C,SAASC,EAAaz5B,GACrB,IAAI5R,EAAI,CAAC,CAAC4C,EAAE,EAAEwI,EAAE,GAAI,CAACvH,EAAE,IAAIF,EAAE,GAAI,GAE1B,OADP3D,EAAE,GAAGoL,EAAIwG,EAAKG,WAAW,GAAI/R,EAAE,GAAK4R,EAAKA,EAAKrE,KAAMvN,EAAE,GAAG4C,EAAIgP,EAAKA,EAAKrE,KAChEvN,CACT,CAQC,SAASsrC,EAAej1B,EAAGzF,EAAG26B,EAAOppC,GAEpC,IAAInC,EAAIyX,GAAQ,EAAItV,EAAE1B,QACpBT,EAAAyR,YAAY,EAAG4E,GACfrW,EAAAyR,YAAY,EAAG85B,GACfvrC,EAAAyR,YAAY,EAAGb,GACf5Q,EAAAyR,YAAY,EAAG,IACjB,IAAA,IAAQjR,EAAI,EAAGA,EAAI2B,EAAE1B,SAAUD,EAAG,CAC7B,IAAAgK,EAAKrI,EAAEzB,WAAWF,GACtBR,EAAEyR,YAAY,EAAGjH,GAAM,IAAO,GAAOA,EACxC,CAES,OADLxK,EAAAyR,YAAY,EAAG,GACVzR,CACT,CAsBU,SAAAwrC,EAAgB55B,EAAMnR,GAC1B,IAAAT,EAAIqrC,EAAaz5B,GACjB65B,EAAK75B,EAAKG,WAAW,GACrB25B,EAAK95B,EAAKG,WAAW,GACrBxQ,EAAIqQ,EAAKG,WAAW,GACxB,GAAQ,OAALxQ,EAIK,OAHG,IAAPkqC,GAAmB,aAAPC,GAAuB1rC,EAAA,GAAG6D,EAAI,IAAO7D,EAAA,GAAG2D,EAAI,IAC5C,IAAP8nC,GAAmB,aAAPC,GAAuB1rC,EAAA,GAAG6D,EAAI,IAAO7D,EAAA,GAAG2D,EAAI,IAC3D3D,EAAE,GAAG2D,EAAI,EACP3D,EAER,IAAImC,EAAQ,MAAJZ,EAED,OAFaA,GAAO,MAAFA,GAAY,MACrCvB,EAAE,GAAG2D,GAAK,EAAM,EAAFxB,IAAQupC,EAAKxnC,KAAKC,IAAI,EAAG5C,EAAE,IAAMkqC,EAAKvnC,KAAKC,IAAI,EAAG5C,IACzDvB,CACT,CACC,SAAS2rC,EAAgBt1B,EAAGzF,EAAG26B,EAAO5nC,GACjC,IAAA3D,EAAIyX,GAAQ,IAIhB,GAHEzX,EAAAyR,YAAY,EAAG4E,GACfrW,EAAAyR,YAAY,EAAG85B,GACfvrC,EAAAyR,YAAY,EAAGb,GACT,GAALjN,EAIK,OAHL3D,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,OACVzR,EAER,IAAkByrC,EAAdtpC,EAAI,EAAGZ,EAAI,EAAWmqC,EAAK,EAexB,OAdJ/nC,EAAI,IAASxB,EAAA,EAAGwB,GAAKA,GACpBpC,EAAe,EAAf2C,KAAK0nC,KAAKjoC,GAGP,YADP+nC,GADA/nC,GAAKO,KAAKC,IAAI,EAAG5C,EAAE,OACR,OACwBA,EAAGmqC,GAAR/nC,GAAA,KAAmB,GAC5CA,GAAA+nC,EACCA,GAAA,WACEA,KAAA,EAERD,GADK9nC,GAAAO,KAAKC,IAAI,EAAG,OACR,EACPnE,EAAAyR,YAAY,EAAGg6B,GACfzrC,EAAAyR,YAAY,EAAGi6B,GACZnqC,GAAA,OAAUY,EAAI,MAAS,GAC1BnC,EAAAyR,YAAY,EAAGlQ,GACVvB,CACT,CAeU,SAAA6rC,EAAgBj6B,EAAMnR,GAC1B,IAAAT,EAAIqrC,EAAaz5B,GACjB65B,EAAK75B,EAAKG,WAAW,EAAE,KAEpB,OADL/R,EAAA,GAAG2D,EAAI8nC,EACFzrC,CACT,CAQU,SAAA8rC,EAAkBl6B,EAAMnR,GACzB,OAA6B,GAA7BmR,EAAKA,EAAKrE,EAAI9M,EAAS,GAAUmR,EAAKG,WAAWtR,EAAQ,QAAU,EAC5E,CAgCU,SAAAsrC,EAAwBr2B,EAAM61B,GACtC,IAAIplC,EAAMsR,GAAQ,EAAI/B,EAAKjV,QACvB0F,EAAAsL,YAAY,EAAG,MACftL,EAAAsL,YAAY,EAAG85B,GACnB,IAAA,IAAQ/qC,EAAI,EAAGA,EAAIkV,EAAKjV,SAAUD,EAAG,CAChC,IAAAgK,EAAKkL,EAAKhV,WAAWF,GACzB2F,EAAIA,EAAIoH,KAAO/C,EAAK,IAAO,GAAOA,CACrC,CAES,OADHrE,EAAAA,EAAIoH,KAAO,EACRpH,CACT,CAEC,IAAI4jC,EAAU,CACN,EAAe,CAAE16B,EAAE,MAAOjC,EAAEmvB,IAC5B,EAAe,CAAEltB,EAAE,OACnB,EAAe,CAAEA,EAAE,YACnB,EAAe,CAAEA,EAAE,aACnB,EAAe,CAAEA,EAAE,SACnB,EAAe,CAAEA,EAAE,QACnB,EAAe,CAAEA,EAAE,QAASjC,EAzX3B,SAAYwE,EAAMnR,EAAQoF,GAClC,IAAI7F,EAAI,CAACmC,EAAE,CAACS,EAAE,EAAEwI,EAAE,GAAG7J,EAAE,CAACqB,EAAE,EAAEwI,EAAE,IAC3B,OAAU,GAAV3K,GAAeoF,EAAK0kC,MACtBvqC,EAAEmC,EAAES,EAAIgP,EAAKG,WAAW,GACnBH,EAAArE,IACLvN,EAAEmC,EAAEiJ,EAAIwG,EAAKG,WAAW,GACxB/R,EAAEuB,EAAEqB,EAAIgP,EAAKG,WAAW,GACnBH,EAAArE,IACLvN,EAAEuB,EAAE6J,EAAIwG,EAAKG,WAAW,GACjB/R,IAERA,EAAEmC,EAAES,EAAIgP,EAAKG,WAAW,GACxB/R,EAAEmC,EAAEiJ,EAAIwG,EAAKG,WAAW,GACX,IAAVtR,GAAgBoF,EAAK0kC,SAAWh9B,GAAK,GACxCvN,EAAEuB,EAAEqB,EAAIgP,EAAKG,WAAW,GACxB/R,EAAEuB,EAAE6J,EAAIwG,EAAKG,WAAW,GACX,IAAVtR,GAAgBoF,EAAK0kC,SAAWh9B,GAAK,GAC5B,OAATvN,EAAEmC,EAAES,MAAeT,EAAES,EAAI5C,EAAEuB,EAAEqB,EAAI5C,EAAEmC,EAAEiJ,EAAIpL,EAAEuB,EAAE6J,EAAI,GAC7CpL,EACT,GAuWS,EAAe,CAAEqP,EAAE,WACnB,EAAe,CAAEA,EAAE,SACnB,EAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,QACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,UAAWjC,EAxT7B,SAAcwE,EAAMnR,EAAQoF,GACpC,IAAI7F,EAAI4qC,EAAWh5B,EAAMnR,EAAQoF,GAE1B,OADP7F,EAAE,GAAG2D,EAAIiO,EAAKG,WAAW,EAAG,KACrB/R,CACT,GAqTS,GAAe,CAAEqP,EAAE,SAAUjC,EA3S5B,SAAawE,EAAMnR,EAAQoF,GACnC,IAAI7F,EAAI4qC,EAAWh5B,EAAMnR,EAAQoF,GAE1B,OADP7F,EAAE,GAAG2D,EAAIiO,EAAKG,WAAW,EAAG,KACrB/R,CACT,GAwSS,GAAe,CAAEqP,EAAE,QAASjC,EAAEy9B,GAC9B,GAAe,CAAEx7B,EAAE,UAAWjC,EA/R7B,SAAcwE,EAAMnR,EAAQoF,GAChC,IAAAoM,EAAML,EAAKrE,EAAI9M,EACfT,EAAI4qC,EAAWh5B,EAAMnR,EAAQoF,GAG9B,GADH7F,EAAE,GAAG2D,EAAIiO,EAAKG,WAAW,EAAG,KACzBlM,EAAK0kC,KAAM34B,EAAKrE,EAAI0E,MAClB,CACA,IAAApE,EAAO+D,EAAKG,WAAW,IAoCpB,SAAgBH,EAAM5R,GAC9B6R,GAAUD,EAAM,GACZ,IAAAzL,EAAM,GAAI6lC,EAAO,EAAG31B,EAAI,GAAIzF,EAAI,GAAIq7B,EAAO,GAAIC,EAAO,GACpD,KAAAt6B,EAAKrE,EAAIqE,EAAKnR,QAAQ,CACvB,IAAA+J,EAAKoH,EAAKA,EAAKrE,KACnB,OAAO/C,GACN,KAAK,EAAMrE,EAAIiP,KAAKxD,EAAKG,WAAW,EAAG,MAAO,MAC9C,KAAK,EACAnB,EAAAq6B,EAAajrC,EAAE,GAAG4C,EAAGgP,EAAKG,WAAW,IAAI,GACzCsE,EAAA40B,EAAajrC,EAAE,GAAGoL,EAAGwG,EAAKG,WAAW,IAAI,GACzC5L,EAAAiP,KAAKxE,EAAIyF,GACZ,MACF,KAAK,EACA,IAAAzT,EAAIqoC,EAAajrC,EAAE,GAAG4C,EAAGgP,EAAKG,WAAW,IAAI,GAC7C3G,EAAI6/B,EAAajrC,EAAE,GAAGoL,EAAGwG,EAAKG,WAAW,IAAI,GAC7CnB,EAAAq6B,EAAajrC,EAAE,GAAG4C,EAAGgP,EAAKG,WAAW,IAAI,GACzCsE,EAAA40B,EAAajrC,EAAE,GAAGoL,EAAGwG,EAAKG,WAAW,IAAI,GAC7C5L,EAAIiP,KAAKxS,EAAIwI,EAAI,IAAMwF,EAAIyF,GAC1B,MACF,KAAK,EACD,GAAAzE,EAAKrE,EAAIqE,EAAKnR,OAAsD,OACvE,MACD,KAAK,EAAM0F,EAAIiP,KAAK,IAAMjP,EAAIkS,MAAQ,KAAM,MAC5C,KAAK,EAAMlS,EAAIiP,KAAKxD,EAAKG,WAAW,IAAK,MACzC,KAAK,EAEe,IAAnB,IAAI6G,EAAI,GAAWpO,EAAKoH,EAAKA,EAAKrE,MAAYqL,GAAAlZ,OAAOC,aAAa6K,GAClErE,EAAIiP,KAAK,IAAMwD,EAAE9X,QAAQ,KAAM,MAAQ,KACtC,MAEF,KAAK,EAAMqF,EAAIiP,KAAK,IAAMjP,EAAIkS,OAAQ,MACtC,KAAK,GAAMlS,EAAIiP,KAAK,IAAMjP,EAAIkS,OAAQ,MACtC,KAAK,GAAMlS,EAAIiP,KAAK,OAASjP,EAAIkS,MAAQ,KAAM,MAE/C,KAAK,GAAM,KAAK,GACf6zB,EAAO/lC,EAAIkS,MAAO4zB,EAAO9lC,EAAIkS,MAC7BlS,EAAIiP,KAAK,CAAC,MAAO,MAAM5K,EAAK,IAAQ,IAAMyhC,EAAO,IAAMC,EAAO,KAC7D,MAEF,QACC,GAAG1hC,EAAK,IAAQ4gC,EAAS5gC,GACxB0hC,EAAO/lC,EAAIkS,MAAO4zB,EAAO9lC,EAAIkS,MAC7BlS,EAAIiP,KAAK62B,EAAOb,EAAS5gC,GAAM0hC,OACrC,KAAef,EAAQ3gC,GAOvB,OAJS,GADQ,KADJwhC,EAAAb,EAAQ3gC,GAAI,MACGwhC,EAAAp6B,EAAKA,EAAKrE,MAC7By+B,EAAO7lC,EAAI1F,OAAoG,OAClH,IAAI0rC,EAAOhmC,EAAI9C,OAAO2oC,GACtB7lC,EAAI1F,QAAUurC,EACV7lC,EAAAiP,KAAK+1B,EAAQ3gC,GAAI,GAAK,IAAM2hC,EAAKtpC,KAAK,KAAO,IAOtC,EAEjB,CACmB,GAAdsD,EAAI1F,SAAaT,EAAE,GAAGoN,EAAI,GAAKjH,EAAI,GAExC,CAhGmBimC,CAAAx6B,EAAKvO,MAAMuO,EAAKrE,EAAGqE,EAAKrE,EAAIM,GAAO7N,GACnD4R,EAAKrE,GAAKM,CACb,CACS,OAAA7N,CACT,GAoRS,GAAe,CAAEqP,EAAE,SACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,WACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,WACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,WACnB,GAAe,CAAEA,EAAE,YACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,WACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,aACnB,GAAe,CAAEA,EAAE,eACnB,GAAe,CAAEA,EAAE,aACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,SAAUjC,EAAEy9B,GAC/B,GAAe,CAAEx7B,EAAE,YACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,aACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,aACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,aACnB,GAAe,CAAEA,EAAE,QACnB,GAAe,CAAEA,EAAE,YACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,SACnB,IAAe,CAAEA,EAAE,aACnB,IAAe,CAAEA,EAAE,aACnB,IAAe,CAAEA,EAAE,WACnB,IAAe,CAAEA,EAAE,aACnB,IAAe,CAAEA,EAAE,cAAejC,EAAE0+B,GACpC,IAAe,CAAEz8B,EAAE,cAAejC,EAzGjC,SAAkBwE,EAAMnR,GAC5B,IAAAmB,EAAMgQ,EAAKA,EAAKrE,KACjB3L,EAAMnB,EAAS,IAAGmB,EAAMnB,EAAS,GAClB,IAAlB,IAAIT,EAAI,GAAUA,EAAES,OAASmB,GAAK5B,GAAKN,OAAOC,aAAaiS,EAAKA,EAAKrE,MAC9D,OAAAvN,CACT,GAqGS,MAAe,CAAEqP,EAAE,KAGvBo7B,EAAU,CACN,EAAe,CAAEp7B,EAAE,OACnB,EAAe,CAAEA,EAAE,OACnB,EAAe,CAAEA,EAAE,YACnB,EAAe,CAAEA,EAAE,WACnB,EAAe,CAAEA,EAAE,aACnB,EAAe,CAAEA,EAAE,gBACnB,EAAe,CAAEA,EAAE,eACnB,EAAe,CAAEA,EAAE,eACnB,EAAe,CAAEA,EAAE,gBACnB,EAAe,CAAEA,EAAE,aACnB,GAAe,CAAEA,EAAE,eACnB,GAAe,CAAEA,EAAE,aACnB,GAAe,CAAEA,EAAE,cACnB,GAAe,CAAEA,EAAE,YACnB,GAAe,CAAEA,EAAE,gBACnB,GAAe,CAAEA,EAAE,aACnB,GAAe,CAAEA,EAAE,eACnB,GAAe,CAAEA,EAAE,aACnB,GAAe,CAAEA,EAAE,eACnB,GAAe,CAAEA,EAAE,MACnB,GAAe,CAAEA,EAAE,WACnB,GAAe,CAAEA,EAAE,UACnB,GAAe,CAAEA,EAAE,UAAWjC,EAvP7B,SAAewE,EAAMnR,GACzB,IAAAT,EAAIqrC,EAAaz5B,GAGd,OAFL5R,EAAA,GAAG6D,EAAI,IACT7D,EAAE,GAAG2D,EAAIiO,EAAKG,WAAWtR,EAAS,EAAG,QAC9BT,CACT,GAmPS,GAAe,CAAEqP,EAAE,WAAYjC,EAAEo+B,GACjC,GAAe,CAAEn8B,EAAE,WAAYjC,EApO9B,SAAgBwE,EAAMnR,GAC1B,IAAAT,EAAIqrC,EAAaz5B,GACrB5R,EAAE,GAAG2D,EAAIiO,EAAKG,WAAW,GACzB,IAAIpO,EAAI3D,EAAE,GAAG2D,GAAK,EAClB,GAAY,EAAT3D,EAAE,GAAG2D,EACP,OAAW,EAAJA,GACN,KAAK,EAAGA,EAAe,KAAVA,GAAK,GAAW,MAC7B,KAAK,EAAGA,EAAe,KAAVA,GAAK,GAAU,MAC5B,KAAK,EAAGA,GAAKA,GAAK,GAAK,GAAI,MAC3B,KAAK,EAAGA,GAAKA,GAAK,GAAK,IAAK,MAC5B,KAAK,EAAGA,GAAKA,GAAK,GAAK,IAAM,MAC7B,KAAK,EAAGA,GAAKA,GAAK,GAAK,IAAO,MAC9B,KAAK,EAAGA,GAAKA,GAAK,GAAK,GAAI,MAC3B,KAAK,EAAGA,GAAKA,GAAK,GAAK,GAIlB,OADL3D,EAAA,GAAG2D,EAAIA,EACF3D,CACT,GAmNS,GAAe,CAAEqP,EAAE,YAAajC,EArK/B,SAAiBwE,EAAMnR,GAC3B,IAAAT,EAAIwrC,EAAgB55B,GAEjB,OADPA,EAAKrE,GAAK9M,EAAS,GACZT,CACT,GAkKS,GAAe,CAAEqP,EAAE,aACnB,GAAe,CAAEA,EAAE,UAAWjC,EAxH7B,SAAcwE,EAAMnR,GAEtB,IADN,IAAIT,EAAI,CAAE,EAAEiS,EAAML,EAAKrE,EAAI9M,EACrBmR,EAAKrE,EAAI0E,GAAK,CACf,IAAAnE,EAAK8D,EAAKG,WAAW,GACzB,GAAS,MAANjE,EAAc,CAGV,IAFN9N,EAAE8N,GAAM,CAAC,EAAG,IACZ9N,EAAE8N,GAAI,GAAK8D,EAAKG,WAAW,GACrBH,EAAKA,EAAKrE,IAAQvN,EAAA8N,GAAI,IAAMpO,OAAOC,aAAaiS,EAAKA,EAAKrE,IAAUqE,EAAArE,IAAYqE,EAAArE,GAC1F,CAEA,CACS,OAAAvN,CACT,GA6GS,GAAe,CAAEqP,EAAE,eACnB,GAAe,CAAEA,EAAE,eACnB,GAAe,CAAEA,EAAE,eACnB,GAAe,CAAEA,EAAE,OACnB,GAAe,CAAEA,EAAE,WACnB,GAAe,CAAEA,EAAE,SACnB,GAAe,CAAEA,EAAE,eACnB,GAAe,CAAEA,EAAE,MACnB,GAAe,CAAEA,EAAE,WAAYjC,EA1K9B,SAAgBwE,EAAMnR,GAC1B,IAAAT,EAAIqrC,EAAaz5B,GACjB65B,EAAK75B,EAAKG,WAAW,GAElB,OADL/R,EAAA,GAAG2D,EAAI8nC,GAAM,EACRzrC,CACT,GAsKS,GAAe,CAAEqP,EAAE,MACnB,GAAe,CAAEA,EAAE,WAAYjC,EAAEy+B,GACjC,GAAe,CAAEx8B,EAAE,YAAajC,EA/J/B,SAAiBwE,EAAMnR,GAC3B,IAAAT,EAAI6rC,EAAgBj6B,GAEjB,OADPA,EAAKrE,GAAK9M,EAAS,GACZT,CACT,GA4JS,IAAe,CAAEqP,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,cAAejC,EAAE0+B,GACpC,IAAe,CAAEz8B,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,E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,IAAK,QACL,IAAK,QACL,IAAK,UACL,IAAK,UACL,IAAK,QACL,IAAK,MACL,IAAK,cACL,IAAK,iBACL,IAAK,UACL,IAAK,aACL,IAAK,eACL,IAAK,eACL,IAAK,aACL,IAAK,cACL,IAAK,cACL,IAAK,kBACL,IAAK,YACL,IAAK,iBACL,IAAK,cACL,IAAK,eACL,IAAK,eACL,IAAK,YACL,IAAK,QACL,IAAK,YACL,IAAK,UACL,IAAK,gBACL,IAAK,UACL,IAAK,aACL,IAAK,aACL,IAAK,gBACL,IAAK,YACL,IAAK,aACL,IAAK,UACL,IAAK,OACL,IAAK,cACL,IAAK,UACL,IAAK,YACL,IAAK,iBACL,IAAK,cACL,IAAK,oBACL,IAAK,gBACL,IAAK,eACL,IAAK,iBACL,IAAK,kBACL,IAAK,cACL,IAAK,qBACL,IAAK,SACL,IAAK,cACL,IAAK,WACL,IAAK,WACL,IAAK,eACL,IAAK,eACL,IAAK,iBACL,IAAK,eACL,IAAK,kBACL,IAAK,qBACL,IAAK,aACL,IAAK,YACL,IAAK,YACL,IAAK,gBACL,IAAK,cACL,IAAK,eACL,IAAK,kBACL,IAAK,oBACL,IAAK,kBACL,IAAK,iBACL,IAAK,UACL,IAAK,YACL,IAAK,YACL,IAAK,aACL,IAAK,cACL,IAAK,UACL,IAAK,SACL,IAAK,cACL,IAAK,UACL,IAAK,oBACL,IAAK,kBACL,IAAK,QACL,IAAK,aACL,IAAK,YACL,IAAK,cACL,IAAK,mBACL,IAAK,oBACL,IAAK,cACL,IAAK,cACL,IAAK,mBACL,IAAK,eACL,IAAK,aACL,IAAK,eACL,IAAK,gBACL,IAAK,aACL,IAAK,cACL,IAAK,cACL,IAAK,iBACL,IAAK,YACL,IAAK,cACL,IAAK,eACL,IAAK,aACL,IAAK,aACL,IAAK,gBACL,IAAK,eACL,IAAK,kBACL,IAAK,gBACL,IAAK,qBACL,IAAK,WACL,IAAK,OACL,IAAK,gBACL,IAAK,kBACL,IAAK,aACL,IAAK,aACL,IAAK,eACL,IAAK,iBACL,IAAK,cACL,IAAK,iBACL,IAAK,qBACL,IAAK,YACL,IAAK,oBACL,IAAK,WACL,IAAK,cACL,IAAK,iBACL,IAAK,WACL,IAAK,eACL,IAAK,gBACL,IAAK,gBACL,IAAK,mBACL,IAAK,iBACL,IAAK,eACL,IAAK,cACL,IAAK,YACL,IAAK,kBACL,IAAK,oBACL,IAAK,iBACL,IAAK,YACL,IAAK,aACL,IAAK,oBACL,IAAK,aACL,IAAK,eACL,IAAK,iBACL,IAAK,kBACL,IAAK,eACL,IAAK,gBACL,IAAK,gBACL,IAAK,qBACL,IAAK,mBACL,IAAK,qBACL,IAAK,yBACL,IAAK,cACL,IAAK,aACL,IAAK,mBACL,IAAK,sBACL,IAAK,eACL,IAAK,eACL,IAAK,gBACL,IAAK,cACL,IAAK,kBACL,IAAK,cACL,IAAK,gBACL,IAAK,kBACL,IAAK,2BACL,IAAK,eACL,IAAK,iBACL,IAAK,aACL,IAAK,iBACL,IAAK,YACL,IAAK,mBACL,IAAK,cACL,IAAK,wBACL,IAAK,kBACL,IAAK,qBACL,IAAK,kBACL,IAAK,kBACL,IAAK,kBACL,IAAK,qBACL,IAAK,aACL,IAAK,iBACL,IAAK,eACL,IAAK,mBACL,IAAK,aACL,IAAK,eACL,IAAK,kBACL,IAAK,gBACL,IAAK,gBACL,IAAK,kBACL,IAAK,kBACL,IAAK,gBACL,IAAK,iBACL,IAAK,uBACL,IAAK,0BACL,IAAK,iBACL,IAAK,eACL,IAAK,YACL,IAAK,cACL,IAAK,aACL,IAAK,iBACL,IAAK,kBACL,IAAK,kBACL,IAAK,gBACL,IAAK,kBACL,IAAK,gBACL,IAAK,gBACL,IAAK,qBACL,IAAK,cACL,IAAK,mBACL,IAAK,uBACL,IAAK,mBACL,IAAK,kBACL,IAAK,mBACL,IAAK,cACL,IAAK,iBACL,IAAK,kBACL,IAAK,eACL,IAAK,eACL,IAAK,oBACL,IAAK,sBACL,IAAK,sBACL,IAAK,mBACL,IAAK,qBACL,IAAK,qBACL,IAAK,gBACL,IAAK,aACL,IAAK,YACL,IAAK,cACL,IAAK,mBACL,IAAK,gBACL,IAAK,wBACL,IAAK,qBACL,IAAK,SACL,IAAK,kBACL,IAAK,gBACL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L,IAAK,OACL,IAAK,WACL,IAAK,UACL,IAAK,OACL,IAAK,UACL,IAAK,YACL,IAAK,UACL,IAAK,OACL,IAAK,UACL,IAAK,UACL,IAAK,OACL,IAAK,WACL,IAAK,gBACL,IAAK,aACL,IAAK,eACL,IAAK,WACL,IAAK,YACL,IAAK,WACL,IAAK,OACL,IAAK,SACL,IAAK,OACL,IAAK,UACL,IAAK,QACL,IAAK,QACL,IAAK,YACL,IAAK,UACL,IAAK,aACL,IAAK,aACL,IAAK,WACL,IAAK,QACL,IAAK,UACL,IAAK,WACL,IAAK,QACL,IAAK,SACL,IAAK,OACL,IAAK,OACL,IAAK,UACL,IAAK,YACL,IAAK,MACL,IAAK,OACL,IAAK,OACL,IAAK,UACL,IAAK,UACL,IAAK,QACL,IAAK,MACL,IAAK,OACL,IAAK,UACL,IAAK,SACL,IAAK,WACL,IAAK,SACL,IAAK,aACL,IAAK,OACL,IAAK,OACL,IAAK,OACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,OACL,IAAK,gBACL,IAAK,WACL,IAAK,aACL,IAAK,cACL,IAAK,gBACL,IAAK,kBACL,IAAK,gBACL,IAAK,WACL,IAAK,OACL,IAAK,QACL,IAAK,aACL,IAAK,KACL,IAAK,QACL,IAAK,SACL,IAAK,YACL,IAAK,cACL,IAAK,iBACL,IAAK,OACL,IAAK,gBACL,IAAK,WACL,IAAK,cACL,IAAK,WACL,IAAK,iBACL,IAAK,aACL,IAAK,YACL,IAAK,eACL,IAAK,eACL,IAAK,cACL,IAAK,aACL,IAAK,cACL,IAAK,eACL,IAAK,SACL,IAAK,WACL,IAAK,UACL,IAAK,UACL,IAAK,YACL,IAAK,UACL,IAAK,SACL,IAAK,SACL,IAAK,aACL,IAAK,YACL,IAAK,OACL,IAAK,YACL,IAAK,QACL,IAAK,OACL,IAAK,SACL,IAAK,YACL,IAAK,QACL,IAAK,YACL,IAAK,WACL,IAAK,UACL,IAAK,cACL,IAAK,cACL,IAAK,SACL,IAAK,eACL,IAAK,WACL,IAAK,YACL,IAAK,UACL,IAAK,WACL,IAAK,cACL,IAAK,MACL,IAAK,SACL,IAAK,UACL,IAAK,QACL,IAAK,UACL,IAAK,UACL,IAAK,WACL,IAAK,WACL,IAAK,UACL,IAAK,SACL,IAAK,QACL,IAAK,WACL,IAAK,QACL,IAAK,YACL,IAAK,UACL,IAAK,MACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,OACL,IAAK,QACL,IAAK,UACL,IAAK,UACL,IAAK,QACL,IAAK,OACL,IAAK,OACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,WACL,IAAK,aACL,IAAK,cACL,IAAK,OACL,IAAK,WACL,IAAK,OACL,IAAK,gBACL,IAAK,YACL,IAAK,cACL,IAAK,QACL,IAAK,iBACL,IAAK,kBACL,IAAK,kBACL,IAAK,iBACL,IAAK,UACL,IAAK,UACL,IAAK,WACL,IAAK,QACL,IAAK,UACL,IAAK,aACL,IAAK,eACL,IAAK,oBACL,IAAK,QACL,IAAK,UACL,IAAK,aACL,IAAK,eACL,IAAK,QACL,IAAK,cACL,IAAK,cACL,IAAK,WACL,IAAK,eACL,IAAK,YACL,IAAK,WACL,IAAK,WACL,IAAK,OACL,IAAK,OACL,IAAK,UACL,IAAK,QACL,IAAK,SACL,IAAK,OACL,IAAK,WACL,IAAK,gBACL,IAAK,YACL,IAAK,kBACL,IAAK,eACL,IAAK,gBACL,IAAK,mBACL,IAAK,cACL,IAAK,gBACL,IAAK,cACL,IAAK,WACL,IAAK,MACL,IAAK,YACL,IAAK,aACL,IAAK,qBACL,IAAK,mBACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,QACL,IAAK,QACL,IAAK,UACL,IAAK,QACL,IAAK,SACL,IAAK,OACL,IAAK,SACL,IAAK,UACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,aACL,IAAK,cACL,IAAK,YACL,IAAK,SACL,IAAK,UACL,IAAK,QACL,IAAK,YACL,IAAK,YACL,IAAK,aACL,IAAK,SACL,IAAK,WACL,IAAK,QACL,IAAK,SACL,IAAK,SACL,IAAK,QACL,IAAK,SACL,IAAK,MACL,IAAK,OACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,OACL,IAAK,OACL,IAAK,WACL,IAAK,WACL,IAAK,UACL,IAAK,WACL,IAAK,OACL,IAAK,YACL,IAAK,YACL,IAAK,UACL,IAAK,aACL,IAAK,aACL,IAAK,QACL,IAAK,QACL,IAAK,WACL,IAAK,WACL,IAAK,UACL,IAAK,SACL,IAAK,WACL,IAAK,UACL,IAAK,QACL,IAAK,UACL,IAAK,WACL,IAAK,YACL,IAAK,WACL,IAAK,aACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,WACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,cACL,IAAK,UACL,IAAK,YACL,IAAK,WACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,WACL,IAAK,UACL,IAAK,cACL,IAAK,MACL,IAAK,cACL,IAAK,MACL,IAAK,aACL,IAAK,gBACL,IAAK,UACL,IAAK,eACL,IAAK,UACL,IAAK,WACL,IAAK,SACL,IAAK,YACL,IAAK,cAEHD,GAAW,CACb,EAAG,EACH,EAAG,EACH,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,MAAO,GAuCT,IAAImF,GAAiC,oBAARC,IAE7B,SAASC,GAAWnP,EAAaxiC,EAAgB6R,GAC5C,IAAA5b,EAAI,EAAGoB,EAAMmrC,EAAItsC,OACrB,GAAG2b,GACC,GAAA4/B,GAAkB5/B,EAAI+/B,IAAI5xC,GAAOiO,OAAOyO,UAAUC,eAAe5jB,KAAK8Y,EAAK7R,GAE7E,IADA,IAAI6xC,EAASJ,GAAkB5/B,EAAIigC,IAAI9xC,GAAO6R,EAAI7R,GAC5C/J,EAAI47C,EAAO37C,SAAUD,EAC1B,GAAGusC,EAAIqP,EAAO57C,IAAIqD,IAAM0G,EAAqB,OAAVwiC,EAAAG,QAAiBkP,EAAO57C,QAGvD,KAAMA,EAAIoB,IAAOpB,EACvB,GAAGusC,EAAIvsC,GAAGqD,IAAM0G,EAA4B,OAAjBwiC,EAAAG,QAAiB1sC,EAYtC,OAVPusC,EAAInrC,GAAQ,CAACiC,EAAE0G,GAAmBwiC,EAAAG,QAAcH,EAAAK,SAC7ChxB,IACC4/B,IACE5/B,EAAI+/B,IAAI5xC,IAAU6R,EAAAjZ,IAAIoH,EAAK,IAC/B6R,EAAIigC,IAAI9xC,GAAK6K,KAAKxT,KAEd4W,OAAOyO,UAAUC,eAAe5jB,KAAK8Y,EAAK7R,KAAM6R,EAAI7R,GAAO,IAC3D6R,EAAA7R,GAAK6K,KAAKxT,KAGTA,CACR,CAEA,SAAS06C,GAAU1rC,EAAcof,GAChC,IAAI9e,EAAK,CAAChF,IAAI0E,EAAE,EAAEzE,IAAIyE,EAAE,GAEpBivB,GAAM,EASH,OARJ7P,EAAIwe,MAAKA,GAAMxe,EAAIwe,KACN,MAAbxe,EAAIlyB,MAAeoT,EAAE29B,YAAc,EACnB,MAAX7e,EAAI+W,IAAmBlH,EAAAoH,GAAQjX,EAAI+W,KACxB,MAAX/W,EAAI6P,MAAaA,EAAM7P,EAAI6P,KAChCA,GAAU,GAAI3uB,EAAApT,MAAQ4wC,GAAW7O,GAAM3uB,EAAE29B,YAAc,GACrC,MAAb7e,EAAIlyB,QAAeoT,EAAEpT,MAAQkyB,EAAIlyB,OACtCkyB,EAAIkW,SAAQh1B,EAAEg1B,QAAS,GACV,MAAblW,EAAIusB,QAAmBrrC,EAAAsrC,aAAetrC,EAAEqrC,MAAQvsB,EAAIusB,OAChDrrC,CACR,CAEA,SAASurC,GAAgBC,EAAqBC,GAC7C,GAAID,EAAJ,CACA,IAAIE,EAAO,CAAC,GAAK,GAAK,IAAM,IAAM,GAAK,IAElB,MAAlBF,EAAQG,OAAwBH,EAAAG,KAASD,EAAK,IAC5B,MAAlBF,EAAQI,QAAwBJ,EAAAI,MAASF,EAAK,IAC5B,MAAlBF,EAAQK,MAAwBL,EAAAK,IAASH,EAAK,IAC5B,MAAlBF,EAAQM,SAAwBN,EAAAM,OAASJ,EAAK,IAC5B,MAAlBF,EAAQtoC,SAAwBsoC,EAAAtoC,OAASwoC,EAAK,IAC5B,MAAlBF,EAAQO,SAAwBP,EAAAO,OAASL,EAAK,GARpC,CASd,CAEA,SAASM,GAAehnB,EAAuBlH,EAAenpB,GACzD,IAAA2qB,EAAI3qB,EAAKs3C,OAAiB,MAAVnuB,EAAKwB,EAAYxB,EAAKwB,EAAI,WAC1ChwB,EAAI,GAAMoB,EAAMs0B,EAAOz1B,OACxB,GAAK,MAAL+vB,GAAa3qB,EAAKu3C,IACd,KAAA58C,EAAI,MAASA,KAAqB,MAAfqF,EAAKu3C,IAAI58C,GAAY,CACpCqO,GAAAmgB,EAAKwB,EAAGhwB,GAEZqF,EAAAu3C,IAAI58C,GAAKwuB,EAAKwB,EACnB3qB,EAAKs3C,OAAOnuB,EAAKwB,GAAKA,EAAIhwB,EAC1B,KACH,CAEC,IAAIA,EAAI,EAAGA,GAAKoB,IAAOpB,EAAM,GAAA01B,EAAO11B,GAAGkwB,WAAaF,EAAU,OAAAhwB,EASvD,OARP01B,EAAOt0B,GAAO,CACb8uB,SAASF,EACT6sB,OAAO,EACPC,OAAO,EACPC,SAAS,EACTpM,KAAK,EACLqM,kBAAkB,GAEZ57C,CACR,CAyCA,SAAS67C,GAASpsB,EAAkBmoB,EAAkBh5C,GAClD,GAAA6wB,GAAMA,EAAG,QAAS,CACpB,IAAIhC,EAAQiB,GAAkBe,EAAG,SAC9B,GAAAhC,EAAM9tB,EAAEqB,EAAIysB,EAAMltB,EAAES,GAAKysB,EAAM9tB,EAAE6J,EAAIikB,EAAMltB,EAAEiJ,EAAG,MAAM,IAAIxC,MAAM,cAAgBpI,EAAI,MAAQ6wB,EAAG,QACpG,CACA,CAsIA,IAAIqsB,GAAqB,CAAC,UAAW,YAAa,oBAAqB,uBACnEC,GAAoB,CACvB,gBAAiB,aAAc,cAC/B,gBAAiB,aAAc,mBAC/B,gBAAiB,aACjB,OAAQ,aAAc,eAwHvB,SAASC,GAAkB5uB,EAAewP,EAAKnN,EAAIxrB,GAElD,GADGmpB,EAAKpsB,GAAGyuB,EAAG,aAAajc,KAAK,CAACopB,EAAKxP,EAAKpsB,SAC7B,IAAXosB,EAAKrrB,GAAqC,iBAAXqrB,EAAK5hB,GAA6B,MAAX4hB,EAAKnrB,IAAcmrB,EAAK5hB,EAAU,MAAA,GAC3F,IAAIoB,EAAK,GACLqvC,EAAO7uB,EAAKnrB,EAAGi6C,EAAO9uB,EAAKrrB,EAC/B,GAAc,MAAXqrB,EAAKnrB,EAAW,OAAOmrB,EAAKnrB,GAC9B,IAAK,IAAU2K,EAAAwgB,EAAKrrB,EAAI,IAAM,IAAK,MACnC,IAAK,IAAK6K,EAAK,GAAGwgB,EAAKrrB,EAAG,MAC1B,IAAK,IAAU6K,EAAAoiB,GAAK5B,EAAKrrB,GAAI,MAC7B,IAAK,IACDkC,GAAQA,EAAKksB,UAAWvjB,EAAK2Z,GAAU6G,EAAKrrB,GAAK,GAAEynB,gBAErD4D,EAAOtG,GAAIsG,IACNnrB,EAAI,IACT2K,EAAK,IAAIwgB,EAAKrrB,EAAI+jB,GAAQS,GAAU6G,EAAKrrB,WAErB,IAAXqrB,EAAKwB,IAAwBxB,EAAAwB,EAAI7rB,EAAU,KACrD,MACD,QAAS6J,EAAKwgB,EAAKrrB,EAEhB,IAAAA,EAAIonB,GAAS,IAAKd,GAAUzb,IAAMxO,EAAK,CAACoL,EAAEozB,GAE1Cwc,EAAKkC,GAAer3C,EAAKwpC,QAASrgB,EAAMnpB,GAE5C,OADU,IAAPm1C,IAAUh7C,EAAEmC,EAAI64C,GACZhsB,EAAKnrB,GACX,IAAK,IAIL,IAAK,IAAK,MAHV,IAAK,IAAK7D,EAAE6D,EAAI,IAAK,MACrB,IAAK,IAAK7D,EAAE6D,EAAI,IAAK,MACrB,IAAK,IAAK7D,EAAE6D,EAAI,IAAK,MAErB,QAAY,GAAU,MAAVmrB,EAAKrrB,EAAW,QAASqrB,EAAKnrB,EAAG,KAAM,CAClD,GAAGmrB,EAAKrrB,EAAElD,OAAS,MAAa,MAAA,IAAImI,MAAM,gDACvC,GAAA/C,GAAQA,EAAKmnC,QAAS,CACpBrpC,EAAAonB,GAAS,IAAK,GAAGmxB,GAAWr2C,EAAKk4C,QAAS/uB,EAAKrrB,EAAGkC,EAAKm4C,aAC3Dh+C,EAAE6D,EAAI,IAAK,KACf,CACG7D,EAAE6D,EAAI,MAGR,GADGmrB,EAAKnrB,GAAKg6C,IAAQ7uB,EAAKnrB,EAAIg6C,EAAM7uB,EAAKrrB,EAAIm6C,GACzB,iBAAV9uB,EAAK5hB,GAAiB4hB,EAAK5hB,EAAG,CACvC,IAAI9B,EAAK0jB,EAAKoO,GAAKpO,EAAKoO,EAAE/5B,MAAM,EAAGm7B,EAAI/9B,SAAW+9B,EAAM,CAAC36B,EAAE,QAAS26B,IAAIxP,EAAKoO,GAAK,KAC9Ez5B,EAAAunB,GAAU,IAAKjB,GAAU+E,EAAK5hB,GAAI9B,IAAiB,MAAV0jB,EAAKrrB,EAAYA,EAAI,GACpE,CAGQ,OAFJqrB,EAAKzhB,GAAG8jB,EAAG,UAAUjc,KAAK,CAACopB,EAAKxP,EAAKzhB,IACrCyhB,EAAKjqB,IAAG/E,EAAEi+C,GAAK,GACX/yB,GAAU,IAAKvnB,EAAG3D,EAC1B,CAyOA,SAASk+C,GAAaz0C,EAAgB5D,EAAMi4B,EAAiB1F,GAC5D,IAI4B8R,EAJxBlqC,EAAI,CAAC6pB,GAAYqB,GAAU,YAAa,KAAM,CACjDoL,MAAShL,GAAW,GACpB,UAAWD,MAERlpB,EAAI27B,EAAG9M,WAAWvnB,GAAgB00C,EAAQ,GAC1C9sB,EAAKyM,EAAG7M,OAAO9uB,GACV,MAANkvB,IAAYA,EAAK,CAAE,GAClB,IAAAmN,EAAMnN,EAAG,SAAW,KACpBhC,EAAQiB,GAAkBkO,GAC9B,GAAGnP,EAAM9tB,EAAEqB,EAAI,OAAUysB,EAAM9tB,EAAE6J,EAAI,QAAS,CAC7C,GAAGvF,EAAKwzB,IAAK,MAAM,IAAIzwB,MAAM,SAAW41B,EAAM,uCAC9CnP,EAAM9tB,EAAEqB,EAAIsB,KAAKgI,IAAImjB,EAAM9tB,EAAEqB,EAAG,OAChCysB,EAAM9tB,EAAE6J,EAAIlH,KAAKgI,IAAImjB,EAAM9tB,EAAEqB,EAAG,SAChC47B,EAAMrO,GAAad,EACrB,CACK+I,IAAMA,EAAO,CAAE,GAChB/G,EAAA,aAAe,GAClB,IAAI+sB,EAAW,IA5bhB,SAA8B/sB,EAAIyM,EAAIr0B,EAAK5D,EAAM7F,GAChD,IAAIq+C,GAAS,EACTC,EAAQ,GAAI/mC,EAAU,KAC1B,GAAqB,SAAlB1R,EAAK8wB,UAAuBmH,EAAGygB,OAAQ,CACrC,IAAAC,EAAQ1gB,EAAG9M,WAAWvnB,GACtB,IAAKq0B,EAAG2gB,WAAkBD,EAAA1gB,EAAG2gB,SAASxtB,OAAOxnB,GAAKi1C,UAAYF,EAAQ,OAAOj9C,GAAG,CAC3E88C,GAAA,EACTC,EAAMK,SAAWx5B,GAAU8E,GAAUu0B,GACvC,CAEI,GAAAntB,GAAMA,EAAG,YAAa,CACxB,IAAIutB,EAAe,CAACC,aAAa,EAAGC,aAAa,GAC9CztB,EAAG,YAAY0tB,UAAoBF,aAAe,GAClDxtB,EAAG,YAAYwrB,SAAmBiC,aAAe,GACpDvnC,GAAWA,GAAS,IAAM2T,GAAU,YAAa,KAAM0zB,EACzD,EAEKP,GAAW9mC,KACfvX,EAAEA,EAAES,QAAWyqB,GAAU,UAAW3T,EAAS+mC,GAC9C,CA2aCU,CAAqB3tB,EAAIyM,EAAIr0B,EAAK5D,EAAM7F,GAEtCA,EAAAA,EAAES,QAAWyqB,GAAU,YAAa,KAAM,CAACsT,IAAOA,IAEpDx+B,EAAEA,EAAES,QAtTL,SAAiC4wB,EAAIxrB,EAAM4D,EAAKq0B,GAC3C,IAAAmhB,EAAS,CAACC,eAAe,KAGtB,SADDphB,GAAI,CAAE,GAAE2gB,UAAU,IAAIU,OAAO,IAAI,KAAIF,EAAMG,YAActhB,EAAG2gB,SAASU,MAAM,GAAGE,IAAM,IAAM,KACzFn0B,GAAU,aAAcA,GAAU,YAAa,KAAM+zB,GAAQ,GACrE,CAiTeK,CAAwBjuB,EAAIxrB,EAAM4D,EAAKq0B,GAGlDj4B,EAAK05C,cAAev/C,EAAAA,EAAES,QAAWyqB,GAAU,gBAAiB,KAAM,CACpEs0B,iBAAiB35C,EAAK05C,YAAYC,kBAAkB,KACpDC,aAAa55C,EAAK05C,YAAYE,cAAc,KAC5CC,gBAAgB75C,EAAK05C,YAAYG,iBAAiB,OAGjC,MAAfruB,EAAG,UAAoBA,EAAG,SAAS5wB,OAAS,IAAGT,EAAEA,EAAES,QA7WvD,SAA2B4wB,EAAIgP,GAE9B,IADI,IAAgBrQ,EAAhBhwB,EAAI,CAAC,UACDQ,EAAI,EAAGA,GAAK6/B,EAAK5/B,SAAUD,GAC7BwvB,EAAMqQ,EAAK7/B,MACdR,EAAAA,EAAES,QAAWyqB,GAAU,MAAO,KAAMoxB,GAAU97C,EAAGwvB,KAG7C,OADLhwB,EAAAA,EAAES,QAAU,UACPT,EAAE6C,KAAK,GACf,CAqWkE88C,CAAkBtuB,EAAIA,EAAG,WAExFrxB,EAAAkqC,EAAOlqC,EAAES,QAAU,eAClB4wB,EAAA,UAAY,GACE,MAAdA,EAAG,UACG8sB,EAlFV,SAA2B9sB,EAAkBxrB,GACxC,IAAoG24B,EAEzE3rB,EAF3B7S,EAAsB,GAAIoL,EAAsB,GAAIikB,EAAQiB,GAAkBe,EAAG,SAAUrC,EAAK,GAASrjB,EAAK,GAAI00B,EAAyB,GAAIhqB,EAAE,EAAGzF,EAAE,EAAGs2B,EAAO7V,EAAG,SACnKD,EAAQrvB,MAAMY,QAAQ0uB,GACtBuuB,EAAU,CAACx0C,EAAEO,GAA+Bk0C,GAAS,EACzD,IAAIjvC,EAAIye,EAAMltB,EAAES,EAAGgO,GAAKye,EAAM9tB,EAAEqB,IAAKgO,EAAGyvB,EAAKzvB,GAAK+e,GAAW/e,GACzD,IAAAyF,EAAIgZ,EAAMltB,EAAEiJ,EAAGiL,GAAKgZ,EAAM9tB,EAAE6J,IAAKiL,EAAG,CAGnC,IAFJjL,EAAI,GACJO,EAAK+jB,GAAWrZ,GACZzF,EAAIye,EAAMltB,EAAES,EAAGgO,GAAKye,EAAM9tB,EAAEqB,IAAKgO,EAAG,CACjC4tB,EAAA6B,EAAKzvB,GAAKjF,EACZ,IAAAm0C,EAAQ1uB,GAASC,EAAGhb,IAAI,IAAIzF,GAAIygB,EAAGmN,QAC1B,IAAVshB,GAC6D,OAA5D9wB,EAAO4uB,GAAkBkC,EAAOthB,EAAKnN,EAAIxrB,KAA2BuF,EAAAgK,KAAK4Z,EAChF,EACK5jB,EAAE3K,OAAS,GAAMymC,GAAQA,EAAK7wB,MACtBupC,EAAA,CAACx0C,EAAEO,GACVu7B,GAAQA,EAAK7wB,MACfxD,EAAMq0B,EAAK7wB,IACJ6vB,SAAQ0Z,EAAO1Z,OAAS,GACtB2Z,GAAA,EACNhtC,EAAIwzB,IAAcwZ,EAAA1Y,GAAMt0B,EAAIwzB,KACvBxzB,EAAIuzB,MAAKyZ,EAAShtC,EAAIuzB,KAC3ByZ,GAAa,IAAED,EAAOG,GAAKF,EAAQD,EAAOI,aAAe,GACzDntC,EAAI0pC,QAASqD,EAAOpD,aAAe3pC,EAAI0pC,QAEzCv8C,EAAAA,EAAES,QAAWyqB,GAAU,MAAO9f,EAAEvI,KAAK,IAAK+8C,GAE/C,CACC,GAAG1Y,EAAY,KAAA7wB,EAAI6wB,EAAKzmC,SAAU4V,EAC9B6wB,GAAQA,EAAK7wB,KACLupC,EAAA,CAACx0C,EAAEiL,EAAE,IACfxD,EAAMq0B,EAAK7wB,IACJ6vB,SAAQ0Z,EAAO1Z,OAAS,GACtB2Z,GAAA,EACLhtC,EAAIwzB,IAAcwZ,EAAA1Y,GAAMt0B,EAAIwzB,KACvBxzB,EAAIuzB,MAAKyZ,EAAShtC,EAAIuzB,KAC3ByZ,GAAa,IAAED,EAAOG,GAAKF,EAAQD,EAAOI,aAAe,GACzDntC,EAAI0pC,QAASqD,EAAOpD,aAAe3pC,EAAI0pC,OAC3Cv8C,EAAEA,EAAES,QAAWyqB,GAAU,MAAO,GAAI00B,IAG/B,OAAA5/C,EAAE6C,KAAK,GACf,CAwCUo9C,CAAkB5uB,EAAIxrB,GAC3Bs4C,EAAM19C,OAAS,IAAKT,EAAAA,EAAES,QAAW09C,IAElCn+C,EAAES,OAAOypC,EAAK,IAAOlqC,EAAAA,EAAES,QAAW,eAAiBT,EAAEkqC,GAAMlqC,EAAEkqC,GAAMppC,QAAQ,KAAK,MAIhFuwB,EAAG,cAAerxB,EAAAA,EAAES,QA1bxB,SAAiCq5C,GAE5B,IAAA95C,EAAK,CAAC8wB,MAAM,GAKT,OAJY4sB,GAAA7mB,SAAQ,SAASxnB,GAAiB,MAATyqC,EAAGzqC,IAAcyqC,EAAGzqC,KAAMrP,EAAAqP,GAAK,QACzDsuC,GAAA9mB,SAAQ,SAASxnB,GAAiB,MAATyqC,EAAGzqC,IAAeyqC,EAAGzqC,KAAMrP,EAAAqP,GAAK,QAExEyqC,EAAGoG,WAAUlgD,EAAEkgD,SAAWzS,GAAsCqM,EAAGoG,UAAUx3C,SAAS,IAAIF,eACtF0iB,GAAU,kBAAmB,KAAMlrB,EAC3C,CAkbkCmgD,CAAwB9uB,EAAG,cAKpC,MAArBA,EAAG,mBAA0BrxB,EAAES,QAhXnC,SAAiCiC,EAAM2uB,EAAIyM,EAAIr0B,GAC1C,IAAA+0B,EAAyB,iBAAZ97B,EAAK87B,IAAkB97B,EAAK87B,IAAMrO,GAAaztB,EAAK87B,KACjEV,EAAG2gB,WAAU3gB,EAAG2gB,SAAY,CAACxtB,OAAO,KACpC6M,EAAG2gB,SAAS2B,QAAUtiB,EAAA2gB,SAAS2B,MAAQ,IACvC,IAAAlG,EAAyBpc,EAAG2gB,SAAS2B,MACrC/wB,EAAQa,GAAasO,GACtBnP,EAAMltB,EAAEiJ,GAAKikB,EAAM9tB,EAAE6J,IAAKikB,EAAM9tB,EAAE6J,EAAI8kB,GAAamB,EAAG,SAAS9vB,EAAE6J,EAAGozB,EAAMrO,GAAad,IAC1F,IAAA,IAAQ7uB,EAAI,EAAGA,EAAI05C,EAAMz5C,SAAUD,EAAG,CACjC,IAAAkV,EAAOwkC,EAAM15C,GACd,GAAa,yBAAbkV,EAAK2jC,MACL3jC,EAAK2qC,OAAS52C,EAAd,CACHiM,EAAK4qC,IAAM,IAAMxiB,EAAG9M,WAAWvnB,GAAO,KAAO+0B,EAAK,KAD5B,CAExB,CAEC,OADGh+B,GAAK05C,EAAMz5C,UAAc2U,KAAK,CAAEikC,KAAM,wBAAyBgH,MAAO52C,EAAK62C,IAAK,IAAMxiB,EAAG9M,WAAWvnB,GAAO,KAAO+0B,IAC9GtT,GAAU,aAAc,KAAM,CAACsT,OACvC,CAiW6C+hB,CAAwBlvB,EAAG,eAAgBA,EAAIyM,EAAIr0B,IAM3E,MAAjB4nB,EAAG,YAAsBA,EAAG,WAAW5wB,OAAS,IAAGT,EAAEA,EAAES,QAlf3D,SAA6B+/C,GACzB,GAAkB,IAAlBA,EAAO//C,OAAqB,MAAA,GAE/B,IADI,IAAAT,EAAI,sBAAwBwgD,EAAO//C,OAAS,KACxCD,EAAI,EAAGA,GAAKggD,EAAO//C,SAAUD,EAAGR,GAAK,mBAAqBmwB,GAAaqwB,EAAOhgD,IAAM,MAC5F,OAAOR,EAAI,eACZ,CA6esEygD,CAAoBpvB,EAAG,aAMxF,IAAW6Z,EA5ZcwV,EA4ZzBC,GAAW,EAAKpoB,GAAM,EAsDnB,OArDGlH,EAAG,UAAqB5wB,OAAS,IACxCT,EAAAA,EAAES,QAAU,eACP4wB,EAAG,UAAqBwF,SAAQ,SAAStpB,GAC3CA,EAAE,GAAGqrB,SACTsS,EAAO,CAAC1M,IAAMjxB,EAAE,IACY,KAAzBA,EAAE,GAAGqrB,OAAOh4B,OAAO,KACrB23B,EAAMD,GAASF,GAAU,EAAAnO,GAAU1c,EAAE,GAAGqrB,QAAQ93B,QAAQ,OAAQ,IAAKi2B,GAAKE,OACtEiU,EAAA,QAAU,MAAM3S,IAEjBooB,EAAOpzC,EAAE,GAAGqrB,OAAOx5B,QAAQ,OAAQ,MAAQwhD,SAAW32B,GAAU1c,EAAE,GAAGqrB,OAAOv1B,MAAMs9C,EAAK,KACxFpzC,EAAE,GAAGmxB,UAASwM,EAAI2V,QAAU52B,GAAU1c,EAAE,GAAGmxB,UAC9C1+B,EAAEA,EAAES,QAAUyqB,GAAU,YAAY,KAAKggB,GAC5C,IACIlrC,EAAAA,EAAES,QAAU,wBAER4wB,EAAG,UAIW,MAAlBA,EAAG,cAAqBrxB,EAAEA,EAAES,SA/a/Bg8C,GAD6BiE,EAgbkCrvB,EAAG,aA9a3DnG,GAAU,cAAe,KAAMw1B,KAublC76C,IAAQA,EAAKi7C,UAA+B,MAAlBj7C,EAAKi7C,WAAyB9gD,EAAAA,EAAES,QAAUsqB,GAAS,gBAAiBG,GAAU,eAAgB,KAAM,CAAC61B,mBAAmB,EAAGC,MAAMxiB,MAI5J4f,EAAS39C,OAAS,IACd83B,EAAAD,GAASF,GAAU,EAAA,uBAAyB3uB,EAAI,GAAK,OAAQstB,GAAKc,MACtE73B,EAAAA,EAAES,QAAUyqB,GAAU,UAAW,KAAM,CAAC,OAAO,MAAQqN,IACzDlH,EAAG,YAAc+sB,GAGf/sB,EAAG,aAAa5wB,OAAS,IACrB83B,EAAAD,GAASF,GAAU,EAAA,0BAA4B3uB,EAAI,GAAK,OAAQstB,GAAKG,KACzEl3B,EAAAA,EAAES,QAAUyqB,GAAU,gBAAiB,KAAM,CAAC,OAAO,MAAQqN,IAC/DlH,EAAG,WAAakH,GAWdv4B,EAAES,OAAO,IAAOT,EAAAA,EAAES,QAAW,eAAiBT,EAAE,GAAGA,EAAE,GAAGc,QAAQ,KAAK,MACjEd,EAAE6C,KAAK,GACf,CAiEA,SAASo+C,GAAiBpyB,EAAIwC,EAAIhC,EAAOhZ,GACxC,IAAIrW,EAjDL,SAAyBqW,EAAcgZ,EAAOgC,GAC7C,IAAIrxB,EAAIyX,GAAQ,KACZ5E,GAAOwe,EAAG,UAAU,IAAIhb,IAAI,CAAE,EAChCrW,EAAAyR,YAAY,EAAG4E,GAEfrW,EAAAyR,YAAY,EAAG,GAEjB,IAAIyvC,EAAQ,IACTruC,EAAIwzB,IAAK6a,EAAyB,GAAjB/Z,GAAMt0B,EAAIwzB,KACtBxzB,EAAIuzB,MAAa8a,EAAU,GAAVruC,EAAIuzB,KAC3BpmC,EAAAyR,YAAY,EAAGyvC,GAEflhD,EAAAyR,YAAY,EAAG,GAEjB,IAAIK,EAAQ,EACTe,EAAI0pC,QAAOzqC,GAASe,EAAI0pC,OACxB1pC,EAAIqzB,SAAiBp0B,GAAA,KACrBe,EAAIwzB,KAAOxzB,EAAIuzB,OAAct0B,GAAA,IAC9B9R,EAAAyR,YAAY,EAAGK,GAEf9R,EAAAyR,YAAY,EAAG,GAGb,IAAA0vC,EAAW,EAAGC,EAAMphD,EAAEuN,EAC1BvN,EAAEuN,GAAK,EAGP,IADA,IAAI8zC,EAAQ,CAACj2C,EAAEiL,EAAGzT,EAAE,GACZpC,EAAI,EAAGA,EAAI,KAAMA,EACpB,KAAA6uB,EAAMltB,EAAES,EAAMpC,EAAE,GAAM,IAAS6uB,EAAM9tB,EAAEqB,EAAKpC,GAAK,IAAjD,CAEI,IADJ,IAAA8gD,KAAYC,GAAO,EACfj4C,EAAK9I,GAAG,GAAK8I,EAAM9I,EAAE,GAAI,KAAO8I,EACvC+3C,EAAMz+C,EAAI0G,GACCvH,MAAMY,QAAQ0uB,IAAOA,EAAGgwB,EAAMj2C,IAAI,IAAIi2C,EAAMz+C,GAAKyuB,EAAG9B,GAAY8xB,OAC7DC,EAAQ,IAAWA,EAAAh4C,GAAUi4C,EAAAj4C,GAEzCg4C,EAAQ,MACTH,EACAnhD,EAAAyR,YAAY,EAAG6vC,GACfthD,EAAAyR,YAAY,EAAG8vC,GAV0C,CAa5D,IAAIh0C,EAAIvN,EAAEuN,EAKH,OAJPvN,EAAEuN,EAAI6zC,EACJphD,EAAAyR,YAAY,EAAG0vC,GACjBnhD,EAAEuN,EAAIA,EAECvN,EAAES,OAAST,EAAEuN,EAAIvN,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,CAC3C,CAESwhD,CAAgBnrC,EAAGgZ,EAAOgC,IAC9BrxB,EAAES,OAAS,KAAQ4wB,EAAG,UAAU,IAAIhb,KAAiBuY,GAAAC,EAAI,EAAwB7uB,EACtF,CAGA,IAAIyhD,GAAiBrtB,GACjBstB,GAAiBrtB,GA+QrB,IAAIstB,GAAqBvtB,GACrBwtB,GAAqBvtB,GAiFzB,IAAIwtB,GAAgB,CAAC,OAAO,QAAQ,MAAM,SAAS,SAAS,UA4X5D,SAASC,GAAkBjzB,EAAiBG,EAAe3Y,EAAczF,EAAc/K,EAAMwrB,EAAkB0wB,GAC3G,QAAW,IAAX/yB,EAAKrrB,EAAwB,OAAA,EAChC,IAAI6K,EAAK,GACT,OAAOwgB,EAAKnrB,GACX,IAAK,IAAU2K,EAAAwgB,EAAKrrB,EAAI,IAAM,IAAK,MACnC,IAAK,KACJqrB,EAAOtG,GAAIsG,IACNwB,EAAIxB,EAAKwB,GAAK7rB,EAAU,IAC7BqqB,EAAKrrB,EAAI+jB,GAAQS,GAAU6G,EAAKrrB,IAAKqrB,EAAKnrB,EAAI,IAC9C,MAED,IAAK,IAAK,IAAK,IAAK2K,EAAK,GAAGwgB,EAAKrrB,EAAG,MACpC,QAAS6K,EAAKwgB,EAAKrrB,EAEpB,IAAI3D,EAAa,CAACoL,EAAEiL,EAAGzT,EAAEgO,GAKzB,OAHA5Q,EAAEmC,EAAI+6C,GAAer3C,EAAKwpC,QAASrgB,EAAMnpB,GACtCmpB,EAAKzhB,GAAM8jB,EAAA,UAAUjc,KAAK,CAACma,GAAYvvB,GAAIgvB,EAAKzhB,IAChDyhB,EAAKpsB,GAAMyuB,EAAA,aAAajc,KAAK,CAACma,GAAYvvB,GAAIgvB,EAAKpsB,IAC/CosB,EAAKnrB,GACX,IAAK,IAAK,IAAK,MAWP,OAVJgC,EAAKmnC,SACPx+B,EAAK0tC,GAAWr2C,EAAKk4C,QAAU/uB,EAAKrrB,EAAYkC,EAAKm4C,YACrDh+C,EAAE6D,EAAI,IAAK7D,EAAE2D,EAAI6K,EACduzC,EAAwBnzB,GAAAC,EAAI,GA7nBnC,SAA4BG,EAAMgzB,EAAOhiD,GAIjC,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,IAC1B4b,GAAoB2uB,EAAOhiD,GACzBA,EAAAyR,YAAY,EAAGuwC,EAAMr+C,GAChB3D,CACR,CAwnB8DiiD,CAAmBjzB,EAAMhvB,OACjE6uB,EAAI,EAzoB1B,SAA2BG,EAAMgzB,EAAOhiD,GAIhC,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,KAC1B0b,GAAe6uB,EAAOhiD,GACpBA,EAAAyR,YAAY,EAAGuwC,EAAMr+C,GAChB3D,CACR,CAooBoDkiD,CAAkBlzB,EAAMhvB,MAExEA,EAAE6D,EAAI,MACHk+C,EAAwBnzB,GAAAC,EAAI,GAljBnC,SAA0BG,EAAMgzB,EAAOhiD,GAI/B,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,EAAI,EAAIuX,EAAKrrB,EAAElD,SACzC4yB,GAAoB2uB,EAAOhiD,GACRqyB,GAAArD,EAAKrrB,EAAG3D,GACpBA,EAAES,OAAST,EAAEuN,EAAIvN,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,CAC3C,CA6iB4DmiD,CAAiBnzB,EAAMhvB,OAC7D6uB,EAAI,EA9jB1B,SAAyBG,EAAMgzB,EAAOhiD,GAI9B,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,GAAK,EAAIuX,EAAKrrB,EAAElD,SAC1C0yB,GAAe6uB,EAAOhiD,GACHqyB,GAAArD,EAAKrrB,EAAG3D,GACpBA,EAAES,OAAST,EAAEuN,EAAIvN,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,CAC3C,CAyjBkDoiD,CAAgBpzB,EAAMhvB,MAE9D,EACR,IAAK,IAQK,OANNgvB,EAAKrrB,IAAe,EAATqrB,EAAKrrB,IAAUqrB,EAAKrrB,GAAI,KAASqrB,EAAKrrB,EAAI,IACpDo+C,EAAwBnzB,GAAAC,EAAI,GAxlBnC,SAA0BG,EAAMgzB,EAAOhiD,GAI/B,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,IAC1B4b,GAAoB2uB,EAAOhiD,GACZi0B,GAAAjF,EAAKrrB,EAAG3D,GAChBA,CACR,CAmlB4DqiD,CAAiBrzB,EAAMhvB,OAC7D6uB,EAAI,EApmB1B,SAAyBG,EAAMgzB,EAAOhiD,GAI9B,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,KAC1B0b,GAAe6uB,EAAOhiD,GACPi0B,GAAAjF,EAAKrrB,EAAG3D,GAChBA,CACR,CA+lBkDsiD,CAAgBtzB,EAAMhvB,IAEjE+hD,EAAwBnzB,GAAAC,EAAI,GAnnBnC,SAA4BG,EAAMgzB,EAAOhiD,GAIjC,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,KAC1B4b,GAAoB2uB,EAAOhiD,GAChBu0B,GAAAvF,EAAKrrB,EAAG3D,GACZA,CACR,CA8mB8DuiD,CAAmBvzB,EAAMhvB,OACjE6uB,EAAI,EA/nB1B,SAA2BG,EAAMgzB,EAAOhiD,GAIhC,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,KAC1B0b,GAAe6uB,EAAOhiD,GACXu0B,GAAAvF,EAAKrrB,EAAG3D,GACZA,CACR,CA0nBoDwiD,CAAkBxzB,EAAMhvB,KAChE,EACV,IAAK,IAIG,OAHPA,EAAE6D,EAAI,IACHk+C,EAAwBnzB,GAAAC,EAAI,GAnsBlC,SAA4BG,EAAMgzB,EAAOhiD,GAIjC,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,IAC1B4b,GAAoB2uB,EAAOhiD,GAC3BA,EAAEyR,YAAY,EAAGud,EAAKrrB,EAAI,EAAI,GACvB3D,CACR,CA8rB6DyiD,CAAmBzzB,EAAMhvB,OACjE6uB,EAAI,EA/sBzB,SAA2BG,EAAMgzB,EAAOhiD,GAIhC,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,IAC1B0b,GAAe6uB,EAAOhiD,GACtBA,EAAEyR,YAAY,EAAGud,EAAKrrB,EAAI,EAAI,GACvB3D,CACR,CA0sBmD0iD,CAAkB1zB,EAAMhvB,KACjE,EACR,IAAK,IAIG,OAHPA,EAAE6D,EAAI,IACHk+C,EAAwBnzB,GAAAC,EAAI,GAhrBlC,SAA6BG,EAAMgzB,EAAOhiD,GAMlC,OALC,MAALA,IAAeA,EAAAyX,GAAQ,IAC1B4b,GAAoB2uB,EAAOhiD,GACzBA,EAAAyR,YAAY,EAAGud,EAAKrrB,GACpB3D,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACVzR,CACR,CAyqB8D2iD,CAAoB3zB,EAAMhvB,OACnE6uB,EAAI,EA5rBzB,SAA4BG,EAAMgzB,EAAOhiD,GAIjC,OAHC,MAALA,IAAeA,EAAAyX,GAAQ,IAC1B0b,GAAe6uB,EAAOhiD,GACpBA,EAAAyR,YAAY,EAAGud,EAAKrrB,GACf3D,CACR,CAurBoD4iD,CAAmB5zB,EAAMhvB,KACnE,EAIF,OAFJ+hD,EAAwBnzB,GAAAC,EAAI,GAluBhC,SAA6BG,EAAMgzB,EAAOhiD,GAElC,OADC,MAALA,IAAeA,EAAAyX,GAAQ,IACnB4b,GAAoB2uB,EAAOhiD,EACnC,CA+tB4D6iD,CAAoB7zB,EAAMhvB,OACnE6uB,EAAI,EA3uBvB,SAA4BG,EAAMgzB,EAAOhiD,GAEjC,OADC,MAALA,IAAeA,EAAAyX,GAAQ,IACnB0b,GAAe6uB,EAAOhiD,EAC9B,CAwuBkD8iD,CAAmB9zB,EAAMhvB,KACnE,CACR,CA2BA,SAAS+iD,GAAiBl0B,EAAIwC,GA7hB9B,IAAkC3Z,EAAK1X,EA8hBlCqxB,GAAOA,EAAG,aACdzC,GAAaC,EAAI,KA/hBgBnX,EA+hB0C2Z,EAAG,WAAW5wB,OA9hBjF,MAALT,IAAeA,EAAAyX,GAAQ,IACxBzX,EAAAyR,YAAY,EAAGiG,GACV1X,IA6hBPqxB,EAAG,WAAWwF,SAAQ,SAAStwB,GAAKqoB,GAAaC,EAAI,IAA2B+yB,GAAmBr7C,GAAI,IACvGqoB,GAAaC,EAAI,KAClB,CAEA,SAASm0B,GAAen0B,EAAIwC,GACvBA,GAAOA,EAAG,WACdzC,GAAaC,EAAI,KACjBwC,EAAG,SAASwF,SAAQ,SAAStwB,EAAG/F,GAAQ+F,GAAgBqoB,GAAAC,EAAI,GAxe7D,SAA0Bje,EAAcof,EAAKhwB,GACpC,MAALA,IAAeA,EAAAyX,GAAQ,KACtB,IAAAvG,EAAIorC,GAAU1rC,EAAGof,GACnBhwB,EAAAyR,eAAgBb,GAChB5Q,EAAAyR,eAAgBb,GAClB5Q,EAAEyR,YAAY,EAAqB,KAAjBP,EAAEpT,OAAS,KAC3BkC,EAAAyR,YAAY,EAAG,GACjB,IAAIK,EAAQ,EAKL,OAJJke,EAAIkW,SAAiBp0B,GAAA,GACH,iBAAXZ,EAAEpT,QAA4BgU,GAAA,GACrCke,EAAIusB,QAAiBzqC,GAAAke,EAAIusB,OAAS,GACnCv8C,EAAAyR,YAAY,EAAGK,GACV9R,CACR,CA2dwFijD,CAAiBziD,EAAG+F,OAC3GqoB,GAAaC,EAAI,KAClB,CAEA,SAASq0B,GAAgBr0B,EAAIwC,GArb7B,IAA+BmN,EAC1Bx+B,EAqbAqxB,GAAOA,EAAG,UACdzC,GAAaC,EAAI,KACJD,GAAAC,EAAI,KAxba2P,EAwbuClO,GAAkBe,EAAG,UAvbtFrxB,EAAIyX,GAAQ,KACdhG,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACjB4iB,GAAmBmK,EAAKx+B,GACjBA,IAobP4uB,GAAaC,EAAI,KAClB,CAEA,SAASs0B,GAAat0B,EAAIwC,EAAkB+G,GAE3C/G,EAAG,UAAUwF,SAAQ,SAAStpB,GAC7B,GAAIA,EAAE,GAAGqrB,OAAT,CACA,IAAIL,EAAMD,GAASF,GAAM,EAAI7qB,EAAE,GAAGqrB,OAAO93B,QAAQ,OAAQ,IAAKi2B,GAAKE,OACnErI,GAAaC,EAAI,IApiBnB,SAAwBthB,EAAGgrB,GAC1B,IAAIv4B,EAAIyX,GAAQ,GAAG,GAAGlK,EAAE,GAAGqrB,OAAOn4B,QAAU8M,EAAE,GAAGmxB,SAAW,IAAIj+B,SAChE4zB,GAAmB,CAAClyB,EAAE8tB,GAAY1iB,EAAE,IAAKhM,EAAE0uB,GAAY1iB,EAAE,KAAMvN,GACnD4zB,GAAA,MAAQ2E,EAAKv4B,GACzB,IAAIojD,EAAS71C,EAAE,GAAGqrB,OAAOx5B,QAAQ,KAKjC,OAHmBizB,KADC,GAAV+wB,EAAe,GAAK71C,EAAE,GAAGqrB,OAAOv1B,MAAM+/C,EAAO,KAC7B,GAAIpjD,GAC9BqyB,GAAmB9kB,EAAE,GAAGmxB,SAAW,GAAI1+B,GACvCqyB,GAAmB,GAAIryB,GAChBA,EAAEqD,MAAM,EAAGrD,EAAEuN,EACrB,CA0hB0C81C,CAAe91C,EAAGgrB,GAFzC,CAGnB,WACQlH,EAAG,SACX,CAoCA,SAASiyB,GAAez0B,EAAIwC,EAAIotB,GAC/B7vB,GAAaC,EAAI,KAGhBD,GAAaC,EAAI,IAhgBnB,SAA8BwC,EAAIotB,EAAUz+C,GACnC,MAALA,IAAeA,EAAAyX,GAAQ,KAC1B,IAAIrK,EAAI,IAcD,SAbDqxC,GAAU,CAAA,GAAIU,OAAO,IAAI,IAAI,CAAA,GAAIE,MAAUjyC,GAAA,IAC/CpN,EAAAyR,YAAY,EAAGrE,GACfpN,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,KACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACVzR,CACR,CA+egDujD,CAAqBlyB,EAAIotB,IAKvE7vB,GAAaC,EAAI,KAGlBD,GAAaC,EAAI,IAClB,CAOA,SAAS20B,GAAmB30B,EAAIwC,GAnfhC,IAAkCyoB,EAAI95C,EAofjCqxB,EAAG,aAEPzC,GAAaC,EAAI,KAtfgBirB,EAsf0CzoB,EAAG,YArftE,MAALrxB,IAAWA,EAAIyX,GAAQ,KACxBzX,EAAAyR,YAAY,EAAGqoC,EAAGoG,SAAWzS,GAAsCqM,EAAGoG,UAAY,GAClFlgD,EAAAyR,YAAY,EAAG,GACjB,CACC,CAAC,WAAuB,GACxB,CAAC,aAAuB,GACxB,CAAC,eAAwB,GACzB,CAAC,iBAAwB,GACzB,CAAC,cAAwB,GACzB,CAAC,iBAAwB,GACzB,CAAC,cAAwB,GACzB,CAAC,oBAAwB,GACzB,CAAC,iBAAwB,GACzB,CAAC,cAAwB,GACzB,CAAC,qBAAuB,GACxB,CAAC,QAAwB,GACzB,CAAC,cAAwB,GACzB,CAAC,eAAwB,GACzB,CAAC,uBAAuB,IACvBolB,SAAQ,SAASxnB,GAEfA,EAAE,KAAMoC,YAAY,EAAe,MAAZqoC,EAAGzqC,EAAE,KAAgByqC,EAAGzqC,EAAE,IAAU,EAAJ,GAC9CrP,EAAAyR,YAAY,EAAe,MAAZqoC,EAAGzqC,EAAE,KAAeyqC,EAAGzqC,EAAE,IAAM,EAAI,EAChE,IACQrP,GA8dR,CAEA,SAASyjD,GAAah6C,EAAgB5D,EAAMi4B,EAAiB1F,GAC5D,IAAIvJ,EAAKR,KACLlsB,EAAI27B,EAAG9M,WAAWvnB,GAAM4nB,EAAKyM,EAAG7M,OAAO9uB,IAAM,CAAE,EAC/CS,EAAeT,EAAO,IAAK27B,GAAMA,EAAG2gB,WAAU77C,EAAIk7B,EAAG2gB,SAASxtB,OAAOxnB,GAAKi1C,UAAY97C,EAAE,OAASrB,GAAG,CACxG,IAviByBm7C,EAAqB18C,EAuiB1CoL,EAAIklB,GAAkBe,EAAG,SAAW,MACxC,GAAGjmB,EAAE7J,EAAEqB,EAAI,OAAUwI,EAAE7J,EAAE6J,EAAI,QAAS,CAClC,GAAAvF,EAAKwzB,IAAK,MAAM,IAAIzwB,MAAM,UAAYyoB,EAAG,SAAW,MAAQ,uCAC/DjmB,EAAE7J,EAAEqB,EAAIsB,KAAKgI,IAAId,EAAE7J,EAAEqB,EAAG,OACxBwI,EAAE7J,EAAE6J,EAAIlH,KAAKgI,IAAId,EAAE7J,EAAEqB,EAAG,QAC1B,CA4CC,OA3CGyuB,EAAA,UAAY,GAEZA,EAAA,aAAe,GAClBzC,GAAaC,EAAI,MACdiP,EAAGygB,QAAUltB,EAAG,cAAazC,GAAaC,EAAI,IAt4BlD,SAAyBtkB,EAAKnB,EAAMpJ,GAC3B,MAALA,IAAWA,EAAIyX,GAAQ,GAAG,EAAElN,EAAI9J,SACnC,IAAI2M,EAAI,IACLhE,IACCA,EAAK21C,QAAY3xC,IAAA,IACjBhE,EAAKyzC,OAAYzvC,IAAA,MAEnBpN,EAAAyR,YAAY,EAAGrE,GACT,IAAA,IAAA5M,EAAI,EAAGA,EAAI,IAAKA,EAAGR,EAAEyR,YAAY,EAAE,GAK3C,OAJA+iB,GAAe,CAACC,KAAK,GAAIz0B,GACvBA,EAAAyR,gBAAiB,GACjBzR,EAAAyR,gBAAiB,GACnB8hB,GAAmBhpB,EAAKvK,GACjBA,EAAEqD,MAAM,EAAGrD,EAAEuN,EACrB,CAw3B0Em2C,CAAgB9gD,EAAGyuB,EAAG,cAC/FzC,GAAaC,EAAI,IAAuB6yB,GAAet2C,IACxCk4C,GAAAz0B,EAAIwC,EAAIyM,EAAG2gB,UAE1BuE,GAAen0B,EAAIwC,GAtIpB,SAAyBxC,EAAIwC,EAAkB5nB,EAAgB5D,GAC1D,IAA+C24B,EAA/CnP,EAAQiB,GAAkBe,EAAG,SAAW,MAAY1lB,EAAK,GAAI00B,EAAyB,GAC1FzR,GAAaC,EAAI,KACb,IAAAuC,EAAQrvB,MAAMY,QAAQ0uB,GACtBsyB,EAAMt0B,EAAM9tB,EAAE6J,EACfimB,EAAG,WAAUsyB,EAAMz/C,KAAKiI,IAAIkjB,EAAM9tB,EAAE6J,EAAGimB,EAAG,SAAS5wB,OAAS,IAC/D,IAAA,IAAQ4V,EAAIgZ,EAAMltB,EAAEiJ,EAAGiL,GAAKstC,IAAOttC,EAAG,CACrC1K,EAAK+jB,GAAWrZ,GAGC4qC,GAAApyB,EAAIwC,EAAIhC,EAAOhZ,GAChC,IAAI0rC,GAAY,EAChB,GAAG1rC,GAAKgZ,EAAM9tB,EAAE6J,UAAWwF,EAAIye,EAAMltB,EAAES,EAAGgO,GAAKye,EAAM9tB,EAAEqB,IAAKgO,EAAG,CAE3DyF,IAAMgZ,EAAMltB,EAAEiJ,MAAQwF,GAAK+e,GAAW/e,IACnC4tB,EAAA6B,EAAKzvB,GAAKjF,EACZ,IAAAqjB,EAAOoC,GAASC,EAAGhb,IAAI,IAAIzF,GAAKygB,EAAGmN,GAGvCujB,IAFI/yB,GAEQ8yB,GAAkBjzB,EAAIG,EAAM3Y,EAAGzF,EAAG/K,EAAMwrB,EAAI0wB,EAC3D,CACA,CACCnzB,GAAaC,EAAI,IAClB,CAgHiB+0B,CAAA/0B,EAAIwC,EAAI5nB,EAAK5D,GAE7B29C,GAAmB30B,EAAIwC,GAzExB,SAA0BxC,EAAIwC,EAAIyM,EAAIr0B,GAClC,GAAC4nB,EAAG,eAAJ,CACC,IAAA3uB,EAAO2uB,EAAG,eACVmN,EAA0B,iBAAb97B,EAAK87B,IAAmB97B,EAAK87B,IAAMrO,GAAaztB,EAAK87B,KAGlEV,EAAG2gB,WAAU3gB,EAAG2gB,SAAY,CAACxtB,OAAO,KACpC6M,EAAG2gB,SAAS2B,QAAUtiB,EAAA2gB,SAAS2B,MAAQ,IACvC,IAAAlG,EAAyBpc,EAAG2gB,SAAS2B,MACrC/wB,EAAQa,GAAasO,GACtBnP,EAAMltB,EAAEiJ,GAAKikB,EAAM9tB,EAAE6J,IAAKikB,EAAM9tB,EAAE6J,EAAI8kB,GAAamB,EAAG,SAAS9vB,EAAE6J,EAAGozB,EAAMrO,GAAad,IAC1F,IAAA,IAAQ7uB,EAAI,EAAGA,EAAI05C,EAAMz5C,SAAUD,EAAG,CACjC,IAAAkV,EAAOwkC,EAAM15C,GACd,GAAa,yBAAbkV,EAAK2jC,MACL3jC,EAAK2qC,OAAS52C,EAAd,CACHiM,EAAK4qC,IAAM,IAAMxiB,EAAG9M,WAAWvnB,GAAO,KAAO+0B,EAAK,KAD5B,CAExB,CACIh+B,GAAK05C,EAAMz5C,UAAc2U,KAAK,CAAEikC,KAAM,wBAAyBgH,MAAO52C,EAAK62C,IAAK,IAAMxiB,EAAG9M,WAAWvnB,GAAO,KAAO+0B,IAErH5P,GAAaC,EAAI,IAA8BwF,GAAmB/D,GAAkBkO,KAIpF5P,GAAaC,EAAI,IAtBM,CAuBxB,CAoDkBg1B,CAAAh1B,EAAIwC,EAAIyM,EAAIr0B,GAI7Bs5C,GAAiBl0B,EAAIwC,GAIR8xB,GAAAt0B,EAAIwC,EAAI+G,GAElB/G,EAAG,aAA0BzC,GAAAC,EAAI,KArkBX6tB,EAqkBqDrrB,EAAG,YApkBzE,MAALrxB,IAAeA,EAAAyX,GAAQ,KAC1BglC,GAAgBC,GACFmF,GAAAhrB,SAAQ,SAAS3hB,GAAiBqf,GAAAmoB,EAAiBxnC,GAAIlV,MAC9DA,IAwkBH6F,IAAQA,EAAKi7C,UAA+B,MAAlBj7C,EAAKi7C,UAAuCoC,GAAAr0B,EAAIwC,GAtG/E,SAA6BxC,EAAIwC,EAAkB5nB,EAAgB2uB,GAElE,GAAG/G,EAAG,aAAa5wB,OAAS,EAAG,CAC1B,IAAA83B,EAAMD,GAASF,GAAM,EAAI,0BAA4B3uB,EAAI,GAAK,OAAQstB,GAAKG,KAC/EtI,GAAaC,EAAI,IAA+B+E,GAAY,MAAQ2E,IACpElH,EAAG,WAAakH,CAClB,CACA,CAkGqBurB,CAAAj1B,EAAIwC,EAAI5nB,EAAK2uB,GAQjCxJ,GAAaC,EAAI,KACVA,EAAGjM,KACX,CAqJA,IAAImhC,GAAa,CAChB,CAAC,qBAA+B,EAAO,QACvC,CAAC,wBAA+B,EAAO,QACvC,CAAC,cAA+B,EAAO,QACvC,CAAC,sBAA+B,EAAO,QACvC,CAAC,WAA+B,IAChC,CAAC,YAA+B,EAAO,QACvC,CAAC,sBAA+B,EAAQ,OACxC,CAAC,iBAA+B,EAAO,QACvC,CAAC,sBAA+B,EAAO,QACvC,CAAC,qBAA+B,EAAO,QACvC,CAAC,gBAA+B,EAAO,QACvC,CAAC,yBAA+B,EAAO,QACvC,CAAC,0BAA+B,EAAO,QACvC,CAAC,8BAA+B,EAAO,QACvC,CAAC,qBAA+B,EAAO,QACvC,CAAC,cAA+B,OAChC,CAAC,wBAA+B,EAAO,QACvC,CAAC,cAAe,YAgGjB,IAAIC,GAAmC,UAAA5hD,MAAM,IAC7C,SAAS6hD,GAAc50C,EAAc60C,GACjC,GAAA70C,EAAE5O,OAAS,GAAmC,MAAA,IAAImI,MAAM,sCAOpD,OALEo7C,GAAAntB,SAAQ,SAASj0B,GACzB,IAAuB,GAApByM,EAAEjQ,QAAQwD,GACG,MAAA,IAAIgG,MAAM,2CAE5B,KALa,CAOb,CAWA,SAASu7C,GAASrmB,GACd,IAACA,IAAOA,EAAG9M,aAAe8M,EAAG7M,OAAQ,MAAM,IAAIroB,MAAM,oBACxD,IAAIk1B,EAAG9M,WAAWvwB,OAAc,MAAA,IAAImI,MAAM,qBAC1C,IAbuBw7C,EAAG19C,EAAG29C,EAazBpzB,EAAU6M,EAAG2gB,UAAY3gB,EAAG2gB,SAASxtB,QAAW,GAb7BmzB,EAcRtmB,EAAG9M,WAdQtqB,EAcIuqB,EAdDozB,IAcWvmB,EAAGygB,OAbzC6F,EAAAvtB,SAAQ,SAASxnB,EAAE7O,GACpByjD,GAAc50C,GACd,IAAA,IAAQ/F,EAAI,EAAGA,EAAI9I,IAAK8I,EAAG,GAAG+F,GAAK+0C,EAAE96C,GAAI,MAAM,IAAIV,MAAM,yBAA2ByG,GACpF,GAAGg1C,EAAO,CACL,IAAAC,EAAM59C,GAAKA,EAAElG,IAAMkG,EAAElG,GAAGk+C,UAAarvC,EACzC,GAAuB,IAApBi1C,EAAG5jD,WAAW,IAAY4jD,EAAG7jD,OAAS,GAAU,MAAA,IAAImI,MAAM,2BAA6B07C,EAC7F,CACA,IAOS,IAAA,IAAA9jD,EAAI,EAAGA,EAAIs9B,EAAG9M,WAAWvwB,SAAUD,EAAYi9C,GAAA3f,EAAG7M,OAAO6M,EAAG9M,WAAWxwB,IAAKs9B,EAAG9M,WAAWxwB,GAAIA,EAEvG,CAiKA,SAAS+jD,GAAazmB,GACjB,IAAA99B,EAAI,CAAC6pB,IACT7pB,EAAEA,EAAES,QAAUyqB,GAAU,WAAY,KAAM,CACzCoL,MAAShL,GAAW,GAGpB,UAAWD,KAGR,IAAAm5B,EAAe1mB,EAAG2gB,WAAa3gB,EAAG2gB,SAAS2B,OAAO,IAAI3/C,OAAS,EAK/DgkD,EAAsB,CAAC9F,SAAS,gBACjC7gB,EAAG2gB,UAAY3gB,EAAG2gB,SAASiG,UAClBX,GAAAltB,SAAQ,SAASp3B,GAEe,MAAtCq+B,EAAG2gB,SAASiG,QAAQjlD,EAAE,KACtBq+B,EAAG2gB,SAASiG,QAAQjlD,EAAE,KAAgBA,EAAE,KACjCglD,EAAAhlD,EAAE,IAAOq+B,EAAG2gB,SAASiG,QAAQjlD,EAAE,IAC7C,IAEKq+B,EAAG2gB,SAASiG,QAAQhG,WAAuB+F,EAAA9F,SAAW7gB,EAAG2gB,SAASiG,QAAQhG,gBAAiB+F,EAAW/F,WAE1G1+C,EAAEA,EAAES,QAAWyqB,GAAU,aAAc,KAAMu5B,GAI7C,IAAI1zB,EAAS+M,EAAG2gB,UAAY3gB,EAAG2gB,SAASxtB,QAAU,GAC9CzwB,EAAI,EAGL,GAAAuwB,GAAUA,EAAO,IAAQA,EAAO,GAAG4zB,OAAQ,CAE7C,IADE3kD,EAAAA,EAAES,QAAU,cACVD,EAAI,EAAGA,GAAKs9B,EAAG9M,WAAWvwB,QACzBswB,EAAOvwB,IACPuwB,EAAOvwB,GAAGmkD,SAFyBnkD,GAIrCA,GAAKs9B,EAAG9M,WAAWvwB,SAAYD,EAAA,GAClCR,EAAEA,EAAES,QAAU,6BAA+BD,EAAI,gBAAkBA,EAAI,MACrER,EAAAA,EAAES,QAAU,cAChB,CAGC,IADET,EAAAA,EAAES,QAAU,WACVD,EAAI,EAAGA,GAAKs9B,EAAG9M,WAAWvwB,SAAUD,EAAG,CAC1C,IAAIykC,EAAO,CAACvvB,KAAKuU,GAAU6T,EAAG9M,WAAWxwB,GAAG6C,MAAM,EAAE,MAGpD,GAFI4hC,EAAA2f,QAAU,IAAIpkD,EAAE,GAChBykC,EAAA,QAAU,OAAOzkC,EAAE,GACpBuwB,EAAOvwB,UAAWuwB,EAAOvwB,GAAGmkD,QAC9B,KAAK,EAAG1f,EAAI1uB,MAAQ,SAAU,MAC9B,KAAK,EAAG0uB,EAAI1uB,MAAQ,aAErBvW,EAAEA,EAAES,QAAWyqB,GAAU,QAAQ,KAAK+Z,EACxC,CA+BQ,OA9BLjlC,EAAAA,EAAES,QAAU,YAKX+jD,IACAxkD,EAAAA,EAAES,QAAU,iBACXq9B,EAAG2gB,UAAY3gB,EAAG2gB,SAAS2B,SAAU3B,SAAS2B,MAAMvpB,SAAQ,SAASxnB,GACvE,IAAIzL,EAAY,CAAC8R,KAAKrG,EAAEgqC,MACrBhqC,EAAEw1C,UAAWjhD,EAAA2wC,QAAUllC,EAAEw1C,SACd,MAAXx1C,EAAEgxC,QAAiBz8C,EAAAkhD,aAAe,GAAGz1C,EAAEgxC,OACvChxC,EAAEs1C,SAAQ/gD,EAAEsiC,OAAS,KACpB72B,EAAEixC,MACJtgD,EAAAA,EAAES,QAAUyqB,GAAU,cAAejB,GAAU5a,EAAEixC,KAAM18C,GAC5D,IACI5D,EAAAA,EAAES,QAAU,mBAcZT,EAAES,OAAO,IAAMT,EAAAA,EAAES,QAAU,cAAeT,EAAE,GAAGA,EAAE,GAAGc,QAAQ,KAAK,MAC7Dd,EAAE6C,KAAK,GACf,CAyOA,SAASkiD,GAAgBl2B,EAAIiP,GAE5B,GAAIA,EAAG2gB,UAAa3gB,EAAG2gB,SAASxtB,OAAhC,CAGA,IAFI,IAjBsBxnB,EAAKzJ,EAiB3B+wB,EAAS+M,EAAG2gB,SAASxtB,OACrBzwB,EAAI,EAAGwkD,GAAS,EAAI9e,GAAS,EAC3B1lC,EAAIuwB,EAAOtwB,SAAUD,GACtBuwB,EAAOvwB,KAAOuwB,EAAOvwB,GAAGmkD,SAAoB,GAAVK,EAAuBA,EAAAxkD,EACjC,GAApBuwB,EAAOvwB,GAAGmkD,YAAeze,IAAuBA,EAAA1lC,GAEzD,KAAG0lC,EAAS8e,GACZp2B,GAAaC,EAAI,KACjBD,GAAaC,EAAI,KAzBSplB,EAyBmCu7C,EAxBzDhlD,IAAOA,EAAAyX,GAAQ,KACjBzX,EAAAyR,eAAgB,GAChBzR,EAAAyR,eAAgB,KAChBzR,EAAAyR,YAAY,EAAI,OAChBzR,EAAAyR,YAAY,EAAI,OAChBzR,EAAAyR,YAAY,EAAI,KAChBzR,EAAAyR,YAAY,EAAIhI,GAChBzJ,EAAAyR,YAAY,EAAIhI,GAEhBzJ,EAAAyR,YAAY,EADF,KAELzR,EAAES,OAAST,EAAEuN,EAAIvN,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,IAgB1C4uB,GAAaC,EAAI,IAXuB,CAYzC,CAuBA,SAASo2B,GAAannB,EAAIj4B,GACzB,IAAIgpB,EAAKR,KAyBT,OAxBAO,GAAaC,EAAI,KACJD,GAAAC,EAAI,IAjElB,SAA8BnsB,EAAM1C,GAC/BA,IAAOA,EAAAyX,GAAQ,MACX,IAAA,IAAAjX,EAAI,EAAQ,GAALA,IAAUA,EAAGR,EAAEyR,YAAY,EAAG,GAKtC,OAJP4gB,GAAmB,UAAWryB,GACXqyB,GAAAtzB,EAAKoQ,QAASnP,GACdqyB,GAAAtzB,EAAKoQ,QAASnP,GACjCqyB,GAAmB,OAAQryB,GACpBA,EAAES,OAAST,EAAEuN,EAAIvN,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,CAC3C,CAyD+CklD,IAEjCt2B,GAAAC,EAAI,IAxOlB,SAAyBnsB,EAAmB1C,GACvCA,IAAOA,EAAAyX,GAAQ,KACnB,IAAI3F,EAAQ,EAQZ,OAPGpP,GAECA,EAAKyiD,gBAAwBrzC,GAAA,GAE/B9R,EAAAyR,YAAY,EAAGK,GACf9R,EAAAyR,YAAY,EAAG,GACjB8hB,GAAmB7wB,GAAQA,EAAKg8C,UAAY,eAAgB1+C,GACrDA,EAAEqD,MAAM,EAAGrD,EAAEuN,EACrB,CA6N0C63C,CAAgBtnB,EAAG2gB,UAAY3gB,EAAG2gB,SAASiG,SAAW,OAG/FK,GAAgBl2B,EAAIiP,GAjFrB,SAAyBjP,EAAIiP,GAC5BlP,GAAaC,EAAI,KACjB,IAAA,IAAQplB,EAAM,EAAGA,GAAOq0B,EAAG9M,WAAWvwB,SAAUgJ,EAAK,CAGpDmlB,GAAaC,EAAI,KAhMQnsB,EA+LjB,CAAEiiD,OADA7mB,EAAG2gB,UAAY3gB,EAAG2gB,SAASxtB,QAAU6M,EAAG2gB,SAASxtB,OAAOxnB,IAAQq0B,EAAG2gB,SAASxtB,OAAOxnB,GAAKk7C,QAAU,EACrFU,OAAQ57C,EAAI,EAAG67C,SAAU,OAAS77C,EAAI,GAAIiM,KAAMooB,EAAG9M,WAAWvnB,KA/LtDzJ,OAgMYulD,KA/LjCvlD,EAAAyX,GAAQ,MACjBzX,EAAAyR,YAAY,EAAG/O,EAAKiiD,QACpB3kD,EAAAyR,YAAY,EAAG/O,EAAK2iD,QACVzxB,GAAAlxB,EAAK4iD,SAAUtlD,GAC3BqyB,GAAmB3vB,EAAKgT,KAAKrS,MAAM,EAAE,IAAKrD,GACnCA,EAAES,OAAST,EAAEuN,EAAIvN,EAAEqD,MAAM,EAAGrD,EAAEuN,GAAKvN,GA2L3C,CAjMA,IAA2B0C,EAAM1C,EAkMhC4uB,GAAaC,EAAI,IAClB,CA0EC22B,CAAgB32B,EAAIiP,GAepBlP,GAAaC,EAAI,KAEVA,EAAGjM,KACX,CAgEA,SAAS6iC,GAAS/iD,EAAiBgT,EAAiB7P,EAAMi4B,EAAiB1F,GAClE,OAAiB,SAAjB1iB,EAAKrS,OAAM,GAAeogD,GAAevF,IAAcx7C,EAAMmD,EAAMi4B,EAAI1F,EAChF,CAeA,SAASstB,GAAWhjD,EAAqBgT,EAAiB7P,GACzD,OAAyB,SAAjB6P,EAAKrS,OAAM,GAAeixC,GAAqBd,IAAoB9wC,EAC5E,CA46BA,SAASijD,GAAiB7nB,EAAiBj4B,GAC1C,IAAI7F,EAAsB,GAKnB,OAHJ89B,EAAG3E,OAASn5B,EAAAoV,KAtnYhB,SAA6B+jB,EAAOtzB,GACnC,IAAI7F,EAAsB,GAgBnB,OAfP8mB,GAAKmT,IAAiB53B,KAAI,SAASkE,GAClC,IAAA,IAAQ/F,EAAI,EAAGA,EAAI82B,GAAW72B,SAAUD,EAAG,GAAG82B,GAAW92B,GAAG,IAAM+F,EAAG,OAAO+wB,GAAW92B,GACvF,IAAIA,EAAI,EAAGA,EAAI+2B,GAAU92B,SAAUD,EAAG,GAAG+2B,GAAU/2B,GAAG,IAAM+F,EAAG,OAAOgxB,GAAU/2B,GAC1E,MAAA+F,CACR,IAAIswB,SAAQ,SAAS3lB,GACnB,GAAkB,MAAfioB,EAAMjoB,EAAE,IAAX,CACI,IAAA3K,EAAIV,GAAQA,EAAKszB,OAA6B,MAApBtzB,EAAKszB,MAAMjoB,EAAE,IAAcrL,EAAKszB,MAAMjoB,EAAE,IAAMioB,EAAMjoB,EAAE,IAE9E,SADCA,EAAE,KACS3K,EAAA,IAAIM,KAAKN,GAAG6kB,cAActqB,QAAQ,SAAS,MAE9C,iBAALyF,EAAeA,EAAI7G,OAAO6G,IACtB,IAANA,IAAoB,IAANA,EAAeA,EAAIA,EAAI,IAAM,IAC3CA,aAAaM,OAAMN,EAAI,IAAIM,KAAKN,GAAG6kB,cAActqB,QAAQ,SAAS,KACxEd,EAAAoV,KAAK2V,GAASkP,GAAgB/oB,EAAE,KAAOA,EAAE,GAAI3K,GARvB,CAS1B,IACQ2kB,GAAU,qBAAsBlrB,EAAE6C,KAAK,IAAK,CAACyzB,MAAM/K,IAC3D,CAomYqBq6B,CAAoB9nB,EAAG3E,MAAOtzB,IAE/Ci4B,EAAG+nB,WAAa7lD,EAAAoV,KArmYpB,SAA8B+jB,EAAO0sB,GAChC,IAAAC,EAAY,CAAC,aAAa,cAC1B1/C,EAAI,2BACJpG,EAAsB,GA2BnB,OA1BJm5B,GAAYrS,GAAAqS,GAAOtC,SAAQ,SAAS3hB,GAEtC,GAAIsD,OAAOyO,UAAUC,eAAe5jB,KAAK61B,EAAOjkB,GAAhD,CACA,IAAA,IAAQ1U,EAAI,EAAGA,EAAI82B,GAAW72B,SAAUD,EAAG,GAAG0U,GAAKoiB,GAAW92B,GAAG,GAAI,OACrE,IAAIA,EAAI,EAAGA,EAAI+2B,GAAU92B,SAAUD,EAAG,GAAG0U,GAAKqiB,GAAU/2B,GAAG,GAAI,OAC3D,IAAAA,EAAI,EAAGA,EAAIslD,EAAUrlD,SAAUD,EAAM,GAAA0U,GAAK4wC,EAAUtlD,GAAI,OAExD,IAAA+F,EAAI4yB,EAAMjkB,GACVrR,EAAI,SACO,iBAAL0C,GAAqB1C,EAAA,QAAS0C,EAAI7G,OAAO6G,KACrC,IAANA,IAAoB,IAANA,GAAmB1C,EAAA,UAAW0C,EAAIA,EAAI,IAAM,KACzDA,EAAA7G,OAAO6G,GACdvG,EAAAoV,KAAK8V,GAAUhB,GAAahV,GAAI3O,EAAG,CAAC,QAAQ1C,IAVM,CAWtD,IACIgiD,GAAgB/+B,GAAA++B,GAAWhvB,SAAQ,SAAS3hB,GAE9C,GAAIsD,OAAOyO,UAAUC,eAAe5jB,KAAKuiD,EAAW3wC,MACjDikB,IAAS3gB,OAAOyO,UAAUC,eAAe5jB,KAAK61B,EAAOjkB,IAAxD,CACI,IAAA3O,EAAIs/C,EAAU3wC,GACdrR,EAAI,SACO,iBAAL0C,GAAqB1C,EAAA,QAAS0C,EAAI7G,OAAO6G,KACrC,IAANA,IAAoB,IAANA,GAAmB1C,EAAA,UAAW0C,EAAIA,EAAI,IAAM,KAC1DA,aAAaM,MAAYhD,EAAA,cAAe0C,EAAIA,EAAE6kB,eAC7C7kB,EAAA7G,OAAO6G,GACdvG,EAAAoV,KAAK8V,GAAUhB,GAAahV,GAAI3O,EAAG,CAAC,QAAQ1C,IAPc,CAQ9D,IACQ,IAAMuC,EAAI,WAAamlB,GAAW,KAAOvrB,EAAE6C,KAAK,IAAM,KAAOuD,EAAI,GACzE,CAskYyB2/C,CAAqBjoB,EAAG3E,MAAO2E,EAAG+nB,YACnD7lD,EAAE6C,KAAK,GACf,CAoBA,SAASmjD,GAAgB32C,GAAK,OAAO6b,GAAU,aAAc,KAAM,CAAC,UAAW7b,EAAEgqC,KAAM,cAAc,IAAM1S,GAASt3B,EAAEixC,IAAK,CAACl1C,EAAE,EAAExI,EAAE,KAAM,CAmJxI,SAASqjD,GAAmBj3B,EAAMwP,EAAgBnN,EAAIxrB,EAAM4D,EAAgBq0B,EAAIzoB,GAC5E,IAAC2Z,GAAmB,MAAVA,EAAKrrB,GAA4B,MAAVqrB,EAAK5hB,EAAwB,MAAA,GAEjE,IAAI84C,EAAO,CAAE,EAEV,GADAl3B,EAAK5hB,IAAG84C,EAAK,cAAgB,IAAMj8B,GAAU0c,GAAS3X,EAAK5hB,EAAGiI,KAC9D2Z,EAAKoO,GAAKpO,EAAKoO,EAAE/5B,MAAM,EAAGm7B,EAAI/9B,SAAW+9B,EAAK,CAC5C,IAAA5b,EAAMqN,GAAYjB,EAAKoO,EAAE/5B,MAAMm7B,EAAI/9B,OAAS,IAC3CylD,EAAA,iBAAmB,QAAUtjC,EAAIxX,GAAKiK,EAAKjK,EAAI,GAAK,KAAOwX,EAAIxX,EAAIiK,EAAKjK,GAAK,KAAO,KAAOwX,EAAIhgB,GAAKyS,EAAKzS,EAAI,GAAK,KAAOggB,EAAIhgB,EAAIyS,EAAKzS,GAAK,IAClJ,CAOI,GALAosB,EAAKzhB,GAAKyhB,EAAKzhB,EAAEqrB,SACnBstB,EAAK,WAAaj8B,GAAU+E,EAAKzhB,EAAEqrB,QAChC5J,EAAKzhB,EAAEmxB,UAASwnB,EAAK,mBAAqBj8B,GAAU+E,EAAKzhB,EAAEmxB,WAG5DrN,EAAG,WAEL,IADI,IAAA80B,EAAO90B,EAAG,WACN+0B,EAAK,EAAGA,GAAMD,EAAK1lD,SAAU2lD,EACjCD,EAAKC,GAAIjkD,EAAES,GAAKyS,EAAKzS,GAAKujD,EAAKC,GAAIjkD,EAAEiJ,GAAKiK,EAAKjK,IAC/C+6C,EAAKC,GAAI7kD,EAAEqB,EAAIujD,EAAKC,GAAIjkD,EAAES,MAAQ,kBAAoBujD,EAAKC,GAAI7kD,EAAEqB,EAAIujD,EAAKC,GAAIjkD,EAAES,GAChFujD,EAAKC,GAAI7kD,EAAE6J,EAAI+6C,EAAKC,GAAIjkD,EAAEiJ,MAAQ,gBAAkB+6C,EAAKC,GAAI7kD,EAAE6J,EAAI+6C,EAAKC,GAAIjkD,EAAEiJ,IAI/E,IAAAvH,EAAI,GAAIqN,EAAI,GAChB,OAAO8d,EAAKnrB,GACX,IAAK,IAAQ,IAACgC,EAAKisB,WAAmB,MAAA,GAAI,MAC1C,IAAK,IAASjuB,EAAA,SAAcqN,EAAAxR,OAAOsvB,EAAKrrB,GAAI,MAC5C,IAAK,IAASE,EAAA,UAAgBqN,EAAA8d,EAAKrrB,EAAI,IAAM,IAAM,MACnD,IAAK,IAASE,EAAA,QAAaqN,EAAA0f,GAAK5B,EAAKrrB,GAAI,MACzC,IAAK,IAASE,EAAA,WAAYqN,EAAI,IAAIrK,KAAKmoB,EAAKrrB,GAAGynB,cAA4B,MAAV4D,EAAKwB,IAAWxB,EAAKwB,EAAIxB,EAAKwB,GAAK7rB,EAAU,KAAK,MACnH,IAAK,IAASd,EAAA,SAAcqN,IAAW8d,EAAKrrB,GAAG,IA55cjC,IACN7C,QAAQipB,IAAU,SAASzjB,GAAK,OAAOwjB,GAAUxjB,EAAG,IAAIxF,QAAQqpB,IAAa,SAAShoB,GAAY,MAAA,MAASA,EAAEzB,WAAW,GAAGgI,SAAS,IAAKF,cAAgB,GAAI,IA85ctK,IAAIwyC,EAAKkC,GAAer3C,EAAKwpC,QAASrgB,EAAMnpB,GACvCqgD,EAAA,cAAgB,KAAO,GAAGlL,GAC1BkL,EAAA,YAAc7wC,EAAKzS,EAAI,EAC5B,IAAIyjD,EAAgB,MAAVr3B,EAAKrrB,EAAYuN,EAAI,GAC3B3K,EAAc,KAAVyoB,EAAKnrB,EAAW,GAAM,kBAAoBA,EAAI,KAAOwiD,EAAK,UAI3D,OAFHr3B,EAAKpsB,GAAG,IAAInC,OAAS,IAAG8F,GAA2ByoB,EAAKpsB,EA/C5CP,KAAI,SAASO,GAE5B,IACIgB,EAAGsnB,GAAU,WADKtoB,EAAEiB,GAAG,IA92ckC/C,QAAQ,iBAAiB,SA+2cvD,CAACw1B,MAAQ,oCACxC,OAAOpL,GAAU,UAAWtnB,EAAG,CAAC,YAAYhB,EAAEqa,GAChD,IAAIpa,KAAK,KA4CDqoB,GAAU,OAAQ3kB,EAAG2/C,EAC7B,CACA,SAASI,GAAkBjwC,EAAcxD,GACpC,IAAA7S,EAAI,mBAAqBqW,EAAE,GAAK,IAMpC,OALGxD,IACCA,EAAIuzB,MAAQvzB,EAAIwzB,MAASxzB,EAAAwzB,IAAMC,GAAMzzB,EAAIuzB,MACzCvzB,EAAIwzB,MAAUrmC,GAAA,oCAAsC6S,EAAIwzB,IAAM,KAC9DxzB,EAAIqzB,SAAalmC,GAAA,mBAEdA,EAAI,GACZ,CAuCA,SAASumD,GAAc98C,EAAgB5D,EAAMi4B,GAC5C,IAAI99B,EAAsB,GACtBmC,EAAI27B,EAAG9M,WAAWvnB,GAClB4nB,EAAKyM,EAAG7M,OAAO9uB,GAEf0B,EAAewtB,EArOpB,SAA6BA,EAAkBxrB,EAAM4D,EAAgBq0B,GACjE,IAACzM,EAAW,MAAA,GACZ,MAAGyM,GAAI,CAAA,GAAI2gB,UAAU,CAAE,GAAE2B,MAAc,MAAA,GAI1C,IAFI,IAAAlG,EAAuBpc,EAAG2gB,SAAS2B,MACnCj6C,EAAwB,GACpB3F,EAAI,EAAGA,EAAI05C,EAAMz5C,SAAUD,EAAG,CACjC,IAAA6O,EAAI6qC,EAAM15C,GACX6O,EAAEgxC,OAAS52C,IAIX4F,EAAEgqC,KAAK3vC,MAAM,aACZvD,EAAAiP,KAAK4wC,GAAgB32C,IAC3B,CACQ,OAAAlJ,EAAItD,KAAK,GACjB,CAqNyB2jD,CAAoBn1B,EAAIxrB,EAAM4D,EAAKq0B,GAAM,GAU1D,OATJj6B,EAAEpD,OAAS,KAAK2U,KAAK,UAAYvR,EAAI,YAGxCA,EAAIwtB,EA9CL,SAA6BA,EAAkBxrB,GAC9C,IAAIwrB,EAAG,QAAgB,MAAA,GACvB,IAAIhC,EAAkBiB,GAAkBe,EAAG,SACvC80B,EAAwB90B,EAAG,YAAc,GAAI+0B,EAAK,EAClDpmD,EAAsB,GACvBqxB,EAAG,UAAUA,EAAG,SAASwF,SAAQ,SAASxnB,EAAG7O,GAC/C2lC,GAAY92B,GACR,IAAApH,IAAMoH,EAAEvR,MACRoT,EAAIorC,GAAU97C,EAAG6O,GACjB6F,EAAY,CAAC,WAAW1U,EAAE,GAC3ByH,IAAKiN,EAAA,YAAc8xB,GAAS91B,EAAEpT,QAC9BuR,EAAE62B,SAAUhxB,EAAA,aAAa,KAC5BlV,EAAEoV,KAAK8V,GAAU,SAAS,KAAKhW,GACjC,IAES,IADJ,IAAAkc,EAAQrvB,MAAMY,QAAQ0uB,GAClBhb,EAAIgZ,EAAMltB,EAAEiJ,EAAGiL,GAAKgZ,EAAM9tB,EAAE6J,IAAKiL,EAAG,CAEnC,IADJ,IAAAxD,EAAM,CAACyzC,GAAkBjwC,GAAIgb,EAAG,UAAU,IAAIhb,KAC1CzF,EAAIye,EAAMltB,EAAES,EAAGgO,GAAKye,EAAM9tB,EAAEqB,IAAKgO,EAAG,CAC3C,IAAI61C,GAAO,EACX,IAAIL,EAAK,EAAGA,GAAMD,EAAK1lD,SAAU2lD,EAChC,KAAGD,EAAKC,GAAIjkD,EAAES,EAAIgO,GACfu1C,EAAKC,GAAIjkD,EAAEiJ,EAAIiL,GACf8vC,EAAKC,GAAI7kD,EAAEqB,EAAIgO,GACfu1C,EAAKC,GAAI7kD,EAAE6J,EAAIiL,GAAlB,CACG8vC,EAAKC,GAAIjkD,EAAES,GAAKgO,GAAKu1C,EAAKC,GAAIjkD,EAAEiJ,GAAKiL,IAAUowC,GAAA,GAClD,KAFqB,CAItB,IAAGA,EAAH,CACA,IAAIpxC,EAAO,CAACjK,EAAEiL,EAAEzT,EAAEgO,GACd4tB,EAAMjP,GAAYla,GAAO2Z,EAAOoC,GAASC,EAAGhb,IAAI,IAAIzF,GAAKygB,EAAGmN,GAC5D3rB,EAAAuC,KAAK6wC,GAAmBj3B,EAAMwP,EAAKnN,EAAIxrB,EAAM4D,EAAKq0B,EAAIzoB,GAHjD,CAIZ,CACExC,EAAIuC,KAAK,UACNvC,EAAIpS,OAAS,GAAGT,EAAEoV,KAAKvC,EAAIhQ,KAAK,IACrC,CACQ,OAAA7C,EAAE6C,KAAK,GACf,CAUU6jD,CAAoBr1B,EAAIxrB,GAAiB,GAC/ChC,EAAEpD,OAAS,KAAK2U,KAAK,UAAYvR,EAAI,YAGxC7D,EAAEoV,KA3NH,SAA8Bic,EAAkBxrB,EAAM4D,EAAgBq0B,GAClE,IAACzM,EAAW,MAAA,GACf,IAAIrxB,EAAsB,GA0CvB,GA1BAqxB,EAAG,cACLrxB,EAAEoV,KAAK,eACJic,EAAG,YAAYjd,QAAQpU,EAAEoV,KAAK8V,GAAU,SAAU,KAAM,CAAC,WAAWmG,EAAG,YAAYjd,UACnFid,EAAG,YAAY4rB,QAAQj9C,EAAEoV,KAAK8V,GAAU,SAAU,KAAM,CAAC,WAAWmG,EAAG,YAAY4rB,UACpFj9C,EAAAoV,KAAK8V,GAAU,cAAe,KAAM,CACrC,WAAYmG,EAAG,YAAY2rB,QAAU,OACrC,SAAU3rB,EAAG,YAAYwrB,MAAQ,MACjC,UAAWxrB,EAAG,YAAYyrB,OAAS,MACnC,QAASzrB,EAAG,YAAY0rB,KAAO,UAEhC/8C,EAAEoV,KAAK,iBAgBL0oB,GAAMA,EAAG2gB,UAAY3gB,EAAG2gB,SAASxtB,QAAU6M,EAAG2gB,SAASxtB,OAAOxnB,GAE7D,GAAAq0B,EAAG2gB,SAASxtB,OAAOxnB,GAAKk7C,OAAQ3kD,EAAEoV,KAAK8V,GAAU,UAA8C,GAAlC4S,EAAG2gB,SAASxtB,OAAOxnB,GAAKk7C,OAAc,cAAgB,kBAAoB,CAAA,QACrI,CAEJ,IAAA,IAAQnkD,EAAI,EAAGA,EAAIiJ,KAAaq0B,EAAG2gB,SAASxtB,OAAOzwB,IAAOs9B,EAAG2gB,SAASxtB,OAAOzwB,GAAGmkD,UAAtDnkD,GACvBA,GAAKiJ,GAAOzJ,EAAAoV,KAAK,cACvB,CAqDI,UAhDI0oB,GAAI,CAAA,GAAI2gB,UAAU,CAAA,GAAIU,OAAO,IAAI,IAAI,CAAE,GAAEE,KAAKr/C,EAAEoV,KAAK,yBA2BzDic,EAAG,cACLrxB,EAAEoV,KAAK2V,GAAS,kBAAmB,SAChCsG,EAAG,YAAYs1B,WAAWvxC,KAAK2V,GAAS,iBAAkB,SAC1DsG,EAAG,YAAYu1B,aAAaxxC,KAAK2V,GAAS,mBAAoB,SAC1B,MAApCsG,EAAG,YAAYw1B,mBAA8Bx1B,EAAG,YAAYw1B,kBACjB,MAAtCx1B,EAAG,YAAYy1B,qBAAgCz1B,EAAG,YAAYy1B,qBAAuB9mD,EAAAoV,KAAK2V,GAAS,kBAAmB,kBAD1C/qB,EAAAoV,KAAK2V,GAAS,kBAAmB,gBAEtH,CACC,CAAE,cAAe,oBACjB,CAAE,gBAAiB,iBACnB,CAAE,aAAc,iBAChB,CAAE,gBAAiB,mBACnB,CAAE,aAAc,mBAChB,CAAE,mBAAoB,yBACtB,CAAE,gBAAiB,mBACnB,CAAE,aAAc,mBAChB,CAAE,OAAQ,aACV,CAAE,aAAc,eAChB,CAAE,cAAe,wBAChB8L,SAAQ,SAASp3B,GAAQ4xB,EAAG,YAAY5xB,EAAE,KAAKO,EAAEoV,KAAK,IAAI3V,EAAE,GAAG,UAGlD,GAAZO,EAAES,OAAoB,GAClByqB,GAAU,mBAAoBlrB,EAAE6C,KAAK,IAAK,CAACyzB,MAAM/K,IACzD,CAiHQw7B,CAAqB11B,EAAIxrB,EAAM4D,EAAKq0B,IAEpC99B,EAAE6C,KAAK,GACf,CACA,SAASmkD,GAAWlpB,EAAIj4B,GACnBA,IAAMA,EAAO,CAAE,GACfi4B,EAAGmR,MAAQnR,EAAAmR,IAAMvmB,GAAI/jB,IACtBm5B,EAAGmR,WACOngC,GAAegvB,EAAGmR,KAEzBppC,EAAAs3C,OAAS31B,GAAUsW,EAAGmR,KAAMppC,EAAKs3C,OAAOrf,EAAGmR,IAAI,QAAU,EAC9DppC,EAAKu3C,IAAMtf,EAAGmR,IACdppC,EAAKwpC,QAAU,GACA6N,GAAAr3C,EAAKwpC,QAAS,CAAE,EAAE,CAAC8N,OAAO,CAAC8J,QAAU,MAErD,IAAIrjD,EAAsB,GAC1BA,EAAEwR,KAAKuwC,GAAiB7nB,EAAIj4B,IAC1BjC,EAAAwR,KA3RK,IA4RPxR,EAAEwR,KAAK,IACPxR,EAAEwR,KAAK,IACP,IAAA,IAAQ5U,EAAI,EAAGA,EAAIs9B,EAAG9M,WAAWvwB,SAAUD,EAC1CoD,EAAEwR,KAAK8V,GAAU,YAAaq7B,GAAc/lD,EAAGqF,EAAMi4B,GAAK,CAAC,UAAU7T,GAAU6T,EAAG9M,WAAWxwB,OAG9F,OAFAoD,EAAE,GA7RH,SAAwBk6B,EAAIj4B,GAEvB,IAAAqwB,EAA2B,CAAC,mEAQhC,OAPArwB,EAAKwpC,QAAQxY,SAAQ,SAASqwB,EAAI7a,GACjC,IAAI90B,EAA4B,GAChCA,EAAQnC,KAAK8V,GAAU,eAAgB,KAAM,CAAC,YAAajB,GAAUtlB,EAAUuiD,EAAGx2B,cAE9E,IAAA1wB,EAAA,CAAY,QAAS,KAAO,GAAGqsC,IAC5BnW,EAAA9gB,KAAK8V,GAAU,QAAS3T,EAAQ1U,KAAK,IAAK7C,GACnD,IACQkrB,GAAU,SAAUgL,EAAOrzB,KAAK,IACxC,CAkRQskD,CAAerpB,EAAIj4B,GACxBjC,EAAA,GAjRH,SAA0Bk6B,GACtB,MAAGA,GAAI,CAAA,GAAI2gB,UAAU,CAAE,GAAE2B,MAAc,MAAA,GAI1C,IAFI,IAAAlG,EAAuBpc,EAAG2gB,SAAS2B,MACnCj6C,EAAwB,GACpB3F,EAAI,EAAGA,EAAI05C,EAAMz5C,SAAUD,EAAG,CACjC,IAAA6O,EAAI6qC,EAAM15C,GACA,MAAX6O,EAAEgxC,QACFhxC,EAAEgqC,KAAK3vC,MAAM,aACZvD,EAAAiP,KAAK4wC,GAAgB32C,IAC3B,CACC,OAAO6b,GAAU,QAAS/kB,EAAItD,KAAK,IACpC,CAqQQukD,CAAiBtpB,GACjBjU,GAAaqB,GAAU,WAAYtnB,EAAEf,KAAK,IAAK,CACrDyzB,MAAc/K,GACd,UAAcA,GACd,UAAcA,GACd,WAAcA,GACd,WAAcA,GACd,aAAcA,IAEhB,CAkmBA,IAAI87B,GACC,mCADDA,GAEE,mCAFFA,GAGE,mCA+FN,SAASC,GAAaxpB,EAAiBj4B,GAClC,IAAA7F,EAAI6F,GAAQ,CAAE,EACdgS,EAAM/G,GAAIwS,MAAMY,QAAQ,CAACvR,KAAK,MAC9B40C,EAAS,YACN,OAAAvnD,EAAE22B,UAAY,OACpB,IAAK,MAAO32B,EAAE22B,SAAW,QAEzB,IAAK,MAAW32B,EAAE22B,WAAU32B,EAAE22B,SAAW,OAEzC,IAAK,QAAkB4wB,EAAA,YAAavnD,EAAEmvB,KAAO,EAAG,MAChD,IAAK,QAAkBo4B,EAAA,QAASvnD,EAAEmvB,KAAO,EAAG,MAC5C,QAAS,MAAM,IAAIvmB,MAAM,gBAAkB5I,EAAE22B,SAAW,gBAMlD,OAJP7lB,GAAIwS,MAAM1B,QAAQ/J,EAAK0vC,EAAQC,GAAe1pB,EAAI99B,IACrC,GAAVA,EAAEmvB,OAAc2O,EAAG3E,OAAS2E,EAAG+nB,YAvFnC,SAAyB/nB,EAAiBjmB,GACzC,IACW4vC,EADPC,EAAY,GAAIC,EAAW,GAAIC,EAAW,GAC1CpnD,EAAI,EACJqnD,EAAyC1gC,GAAU6N,GAAkB,KACrE8yB,EAAsC3gC,GAAU8N,GAAc,KAClE,GAAG6I,EAAG3E,MAGL,IAFOsuB,EAAA3gC,GAAKgX,EAAG3E,OAEX34B,EAAI,EAAGA,EAAIinD,EAAKhnD,SAAUD,GAAIgY,OAAOyO,UAAUC,eAAe5jB,KAAKukD,EAAcJ,EAAKjnD,IAAMknD,EAAYlvC,OAAOyO,UAAUC,eAAe5jB,KAAKwkD,EAAWL,EAAKjnD,IAAMmnD,EAAWC,GAAUxyC,KAAK,CAACqyC,EAAKjnD,GAAIs9B,EAAG3E,MAAMsuB,EAAKjnD,MAE1N,GAAGs9B,EAAG+nB,UAGD,IAFG4B,EAAA3gC,GAAKgX,EAAG+nB,WAEXrlD,EAAI,EAAGA,EAAIinD,EAAKhnD,SAAUD,EAAOgY,OAAOyO,UAAUC,eAAe5jB,KAAMw6B,EAAG3E,OAAO,GAAKsuB,EAAKjnD,MAAMgY,OAAOyO,UAAUC,eAAe5jB,KAAKukD,EAAcJ,EAAKjnD,IAAMknD,EAAYlvC,OAAOyO,UAAUC,eAAe5jB,KAAKwkD,EAAWL,EAAKjnD,IAAMmnD,EAAWC,GAAUxyC,KAAK,CAACqyC,EAAKjnD,GAAIs9B,EAAG+nB,UAAU4B,EAAKjnD,MAEjS,IAAIunD,EAAY,GAChB,IAAIvnD,EAAI,EAAGA,EAAIonD,EAASnnD,SAAUD,EAC9B46B,GAAUh8B,QAAQwoD,EAASpnD,GAAG,KAAY,GAAA+4B,GAAiBn6B,QAAQwoD,EAASpnD,GAAG,KAAU,GACvE,MAAlBonD,EAASpnD,GAAG,IACLunD,EAAA3yC,KAAKwyC,EAASpnD,IAEtBmnD,EAASlnD,QAAYqQ,GAAAwS,MAAM1B,QAAQ/J,EAAK,uBAA6BokB,GAAwB0rB,EAAUN,GAAYS,EAAW7yB,MAC9HyyB,EAAUjnD,QAAUsnD,EAAUtnD,YAAY6iB,MAAM1B,QAAQ/J,EAAK,+BAAqCokB,GAAwByrB,EAAWL,GAAaQ,EAAc7yB,GAAkB+yB,EAAUtnD,OAASsnD,EAAY,KAAMV,IAC3N,CAgE+DW,CAAAlqB,EAAIjmB,GAErD,GAAV7X,EAAEmvB,MAAa2O,EAAGygB,QA38NtB,SAAsB1mC,EAAKowC,GACzBA,EAAI/0C,UAAU2jB,SAAQ,SAAS3lB,EAAG1Q,GAChC,GAAS,GAALA,EAAJ,CAEA,IAAI0nD,EAAUh3C,EAAEpQ,QAAQ,aAAc,sBACZ,MAAtBonD,EAAQ7kD,OAAM,IACZyN,GAAAwS,MAAM1B,QAAQ/J,EAAKqwC,EAASD,EAAIh1C,UAAUzS,GAAGsW,QAHjD,CAIN,GACA,CAm8N2CqxC,CAAAtwC,EAAK/G,GAAI8S,KAAKka,EAAGygB,OAAQ,CAACz1C,KAA0B,iBAAbg1B,EAAGygB,OAAqB,SAAW,YAC7G1mC,CACR,CAEA,IAAIiX,GAAiB,CACb,EAAe,CAAuB1hB,EAt1H9C,SAAyB1K,EAAMjC,GAC9B,IAAI+vB,EAAK,CAAA,EACLve,EAAMvP,EAAK6K,EAAI9M,EACjB+vB,EAAAplB,EAAI1I,EAAKqP,WAAW,GACtBrP,EAAK6K,GAAK,EACN,IAAA2zC,EAAQx+C,EAAKqP,WAAW,GAC5BrP,EAAK6K,GAAK,EACN,IAAAuE,EAAQpP,EAAKqP,WAAW,GAKrB,OAJPrP,EAAK6K,EAAI0E,EACE,EAARH,IAAgB0e,EAAA+rB,MAAgB,EAARzqC,GAChB,GAARA,IAAc0e,EAAE0V,QAAS,GACjB,GAARp0B,IAAgB0e,EAAA4V,IAAM8a,EAAQ,IAC1B1wB,CACR,GA00HQ,EAAe,CAA0BpjB,EA/uHjD,SAA4B1K,GAE3B,MAAO,CADIuwB,GAAevwB,GAE3B,GA6uHQ,EAAe,CAAuB0K,EA3nH9C,SAAyB1K,GAGjB,MAAA,CAFIuwB,GAAevwB,GACdmxB,GAAenxB,GACN,IACtB,GAwnHQ,EAAe,CAA0B0K,EAvsHjD,SAA4B1K,GAGpB,MAAA,CAFIuwB,GAAevwB,GACbA,EAAKqP,WAAW,GACP,IACvB,GAosHQ,EAAe,CAAyB3E,EAhuHhD,SAA2B1K,GAGnB,MAAA,CAFIuwB,GAAevwB,GACdA,EAAKqP,WAAW,GACP,IACtB,GA6tHQ,EAAe,CAAyB3E,EAtpHhD,SAA2B1K,GAGnB,MAAA,CAFIuwB,GAAevwB,GACd4xB,GAAW5xB,GACF,IACtB,GAmpHQ,EAAe,CAAuB0K,EAhmH9C,SAAyB1K,GAGjB,MAAA,CAFIuwB,GAAevwB,GACdyvB,GAAmBzvB,GACV,MACtB,GA6lHQ,EAAe,CAAyB0K,EAhrHhD,SAA2B1K,GAGnB,MAAA,CAFIuwB,GAAevwB,GACfA,EAAKqP,WAAW,GACP,IACrB,GA6qHQ,EAAe,CAA2B3E,EA1hHlD,SAA6B1K,EAAMjC,EAAQoF,GACtC,IAAA+c,EAAMlgB,EAAK6K,EAAI9M,EACfuuB,EAAOiE,GAAevwB,GACrBssB,EAAA5jB,EAAIvF,EAAK,QACV,IACA7F,EAAI,CAACgvB,EADGmD,GAAmBzvB,GACT,OACtB,GAAGmD,EAAKuiD,YAAa,CACpB1lD,EAAK6K,GAAK,EACV,IAAIs4B,EAAUgW,GAA4Bn5C,EAAMkgB,EAAMlgB,EAAK6K,EAAG1H,GAC5D7F,EAAA,GAAK05C,GAAkB7T,EAAS,EAAe7W,EAAMnpB,EAAKqzC,SAAUrzC,EACxE,QACW0H,EAAIqV,EACP,OAAA5iB,CACR,GA8gHQ,EAAe,CAAwBoN,EA3iH/C,SAA0B1K,EAAMjC,EAAQoF,GACnC,IAAA+c,EAAMlgB,EAAK6K,EAAI9M,EACfuuB,EAAOiE,GAAevwB,GACrBssB,EAAA5jB,EAAIvF,EAAK,QACV,IACA7F,EAAI,CAACgvB,EADGsF,GAAW5xB,GACD,KACtB,GAAGmD,EAAKuiD,YAAa,CACpB1lD,EAAK6K,GAAK,EACV,IAAIs4B,EAAUgW,GAA4Bn5C,EAAMkgB,EAAMlgB,EAAK6K,EAAG1H,GAC5D7F,EAAA,GAAK05C,GAAkB7T,EAAS,EAAe7W,EAAMnpB,EAAKqzC,SAAUrzC,EACxE,QACW0H,EAAIqV,EACP,OAAA5iB,CACR,GA+hHQ,GAAe,CAAyBoN,EA5kHhD,SAA2B1K,EAAMjC,EAAQoF,GACpC,IAAA+c,EAAMlgB,EAAK6K,EAAI9M,EACfuuB,EAAOiE,GAAevwB,GACrBssB,EAAA5jB,EAAIvF,EAAK,QACV,IACA7F,EAAI,CAACgvB,EADGtsB,EAAKqP,WAAW,GACN,KACtB,GAAGlM,EAAKuiD,YAAa,CACpB1lD,EAAK6K,GAAK,EACV,IAAIs4B,EAAUgW,GAA4Bn5C,EAAMkgB,EAAMlgB,EAAK6K,EAAG1H,GAC5D7F,EAAA,GAAK05C,GAAkB7T,EAAS,EAAe7W,EAAMnpB,EAAKqzC,SAAUrzC,EACxE,QACW0H,EAAIqV,EACP,OAAA5iB,CACR,GAgkHQ,GAAe,CAA0BoN,EA7jHjD,SAA4B1K,EAAMjC,EAAQoF,GACrC,IAAA+c,EAAMlgB,EAAK6K,EAAI9M,EACfuuB,EAAOiE,GAAevwB,GACrBssB,EAAA5jB,EAAIvF,EAAK,QACV,IACA7F,EAAI,CAACgvB,EADGtsB,EAAKqP,WAAW,GACN,KACtB,GAAGlM,EAAKuiD,YAAa,CACpB1lD,EAAK6K,GAAK,EACV,IAAIs4B,EAAUgW,GAA4Bn5C,EAAMkgB,EAAMlgB,EAAK6K,EAAG1H,GAC5D7F,EAAA,GAAK05C,GAAkB7T,EAAS,EAAe7W,EAAMnpB,EAAKqzC,SAAUrzC,EACxE,QACW0H,EAAIqV,EACP,OAAA5iB,CACR,GAijHQ,GAAe,CAA2BoN,EAlvHlD,SAA6B1K,GAE5B,MAAO,CADI0wB,GAAoB1wB,GAEhC,GAgvHQ,GAAe,CAAwB0K,EA3nH/C,SAA0B1K,GAGlB,MAAA,CAFI0wB,GAAoB1wB,GACnBmxB,GAAenxB,GACN,IACtB,GAwnHQ,GAAe,CAA2B0K,EAvsHlD,SAA6B1K,GAGrB,MAAA,CAFI0wB,GAAoB1wB,GAClBA,EAAKqP,WAAW,GACP,IACvB,GAosHQ,GAAe,CAA0B3E,EAhuHjD,SAA4B1K,GAGpB,MAAA,CAFI0wB,GAAoB1wB,GACnBA,EAAKqP,WAAW,GACP,IACtB,GA6tHQ,GAAe,CAA0B3E,EAtpHjD,SAA4B1K,GAGpB,MAAA,CAFI0wB,GAAoB1wB,GACnB4xB,GAAW5xB,GACF,IACtB,GAmpHQ,GAAe,CAAwB0K,EAhmH/C,SAA0B1K,GAGlB,MAAA,CAFI0wB,GAAoB1wB,GACnByvB,GAAmBzvB,GACV,MACtB,GA6lHQ,GAAe,CAA0B0K,EAhrHjD,SAA4B1K,GAGpB,MAAA,CAFI0wB,GAAoB1wB,GACpBA,EAAKqP,WAAW,GACP,IACrB,GA6qHQ,GAAe,CAAwB3E,EAAEslB,IACzC,GAAe,CAA4B,EAC3C,GAAe,CAA2B,EAC1C,GAAe,CAA4B,EAC3C,GAAe,CAA0B,EACzC,GAAe,CAA2B,EAC1C,GAAe,CAA6B,EAC5C,GAAe,CAA0B,EACzC,GAAe,CAA6B,EAC5C,GAAe,CAA4B,EAC3C,GAAe,CAA6B,EAC5C,GAAe,CAA2B,EAC1C,GAAe,CAA4B,EAC3C,GAAe,CAA8B,EAC7C,GAAe,CAA0B,EACzC,GAAe,CAA4B,EAC3C,GAAe,CAAyBtsB,EAAE,GAC1C,GAAe,CAAuBA,GAAE,GACxC,GAAe,CAAwBA,EAAE,GACzC,GAAe,CAAsBA,GAAE,GACvC,GAAe,CAAqBgH,EA7xE5C,SAAuB1K,EAAMjC,EAAQoF,GAChC,IAAA+c,EAAMlgB,EAAK6K,EAAI9M,EACnBiC,EAAK6K,GAAK,EACV7K,EAAK6K,GAAK,EACN,IAAA+sC,EAAO53C,EAAKqP,WAAW,GACvB2D,EAAOge,GAAuBhxB,GAC9BmjC,EAAUiW,GAA4Bp5C,EAAM,EAAGmD,GAC/C0uC,EAAU/gB,GAA2B9wB,GAOzCA,EAAK6K,EAAIqV,EACT,IAAIzc,EAAO,CAACkzC,KAAK3jC,EAAM2yC,IAAIxiB,GAGpB,OAFJyU,EAAO,YAAWn0C,EAAIk6C,MAAQ/F,GAC9B/F,MAAasQ,QAAUtQ,GACnBpuC,CACR,GA2wEQ,GAAe,CAA8B,EAC7C,GAAe,CAA2B,EAC1C,GAAe,CAAqBiH,EA55Q5C,SAAuB1K,EAAMjC,EAAmBoF,GAC/C,IAAIM,EAAO,CAAA,EAEXA,EAAI6L,GAAKtP,EAAKqP,WAAW,GAAK,GAE1B,IAAA29B,EAl4LL,SAAyBhtC,GACpB,IAAAkB,EAAIlB,EAAKqP,WAAW,GAYjB,OAXFrP,EAAA6K,IACK,CACT+6C,MAAW,EAAJ1kD,EACP2kD,QAAa,EAAJ3kD,EACT4kD,WAAgB,EAAJ5kD,EACZ6kD,WAAgB,EAAJ7kD,EACZ8kD,SAAc,GAAJ9kD,EACV+kD,QAAa,GAAJ/kD,EACTglD,UAAe,GAAJhlD,EACXilD,QAAa,IAAJjlD,EAGX,CAo3LaklD,CAAgBpmD,GAWrB,OAVJgtC,EAAM6Y,UAASpiD,EAAIwpC,OAAS,GAC5BD,EAAMkZ,YAAWziD,EAAI4pC,SAAW,GAChCL,EAAMmZ,UAAS1iD,EAAI6pC,OAAS,GAC5BN,EAAMiZ,UAASxiD,EAAI2pC,OAAS,GAC5BJ,EAAMgZ,WAAUviD,EAAI0pC,QAAU,GAC9BH,EAAM+Y,aAAYtiD,EAAIypC,OAAS,GAGvB,MADDltC,EAAKqP,WAAW,KACP5L,EAAI+pC,KAAO,GAEvBxtC,EAAKqP,WAAW,IAEtB,KAAK,EAAG5L,EAAIiqC,UAAY,cAAe,MACvC,KAAK,EAAGjqC,EAAIiqC,UAAY,YAGrB,IAAAC,EAAY3tC,EAAKqP,WAAW,GAChB,GAAbs+B,IAAgBlqC,EAAIkqC,UAAYA,GAE/B,IAAAC,EAAS5tC,EAAKqP,WAAW,GAC1Bu+B,EAAS,IAAGnqC,EAAImqC,OAASA,GAExB,IAAAyY,EAAWrmD,EAAKqP,WAAW,GAMxB,OALJg3C,EAAW,IAAG5iD,EAAIoqC,QAAUwY,GAE1BrmD,EAAA6K,IACDpH,EAAAiQ,MA99LL,SAAwB1T,GACvB,IAAIyD,EAAM,CAAE,EAIR6iD,EAHItmD,EAAKqP,WAAW,KAGD,EAEnB2iB,EAAQhyB,EAAKqP,WAAW,GACxB6iB,EAAMlyB,EAAKqP,WAAW,EAAG,KACzBk3C,EAAKvmD,EAAKqP,WAAW,GACrBm3C,EAAKxmD,EAAKqP,WAAW,GACrBo3C,EAAKzmD,EAAKqP,WAAW,GAGzB,OAFKrP,EAAA6K,IAEGy7C,GACP,KAAK,EAAG7iD,EAAIsuB,KAAO,EAAG,MACtB,KAAK,EACJtuB,EAAIuuB,MAAQA,EACR,IAAA00B,EAAMj0B,GAAOT,GAEb00B,IAAKjjD,EAAI2uB,IAAMyZ,GAAQ6a,IAC3B,MACD,KAAK,EAEJjjD,EAAI2uB,IAAMyZ,GAAQ,CAAC0a,EAAIC,EAAIC,IAC3B,MACD,KAAK,EAAGhjD,EAAIwuB,MAAQD,EAId,OAFI,GAAPE,IAAczuB,EAAA0uB,KAAOD,EAAM,EAAIA,EAAM,MAAQA,EAAM,OAEhDzuB,CACR,CA+7LakjD,CAAe3mD,GAEpBA,EAAKqP,WAAW,IAEtB,KAAK,EAAG5L,EAAImjD,OAAS,QAAS,MAC9B,KAAK,EAAGnjD,EAAImjD,OAAS,QAKf,OAFHnjD,EAAAuP,KAAOyc,GAAmBzvB,GAEvByD,CACR,GAk3QQ,GAAe,CAAoBiH,EA56Q3C,SAAsB1K,EAAMjC,GAGpB,MAAA,CAFQiC,EAAKqP,WAAW,GACfogB,GAAmBzvB,GAEpC,GAy6QQ,GAAe,CAAqB0K,EAAEsjC,IACtC,GAAe,CAAuBtjC,EAAE4jC,IACxC,GAAe,CAAmB5jC,EAtyQ1C,SAAqB1K,EAAMjC,GACtB,IAAAwR,EAAMvP,EAAK6K,EAAI9M,EACf8oD,EAAa7mD,EAAKqP,WAAW,GAC7By3C,EAAO9mD,EAAKqP,WAAW,GAE3B,OADArP,EAAK6K,EAAI0E,EACF,CAACsrB,KAAKgsB,EAAY74B,SAAS84B,EACnC,GAiyQQ,GAAe,CAAsB,EACrC,GAAe,CAAyBp8C,EAzidhD,SAAuB1K,GACf,OAAAA,EAAKqP,WAAW,EAAG,IAC3B,GAwidQ,GAAe,CAA0B,EACzC,GAAe,CAAmB3E,EA3qP1C,SAAsB1K,GAGpB,IAFA,IAAIyD,EAAM,GACNuR,EAAMhV,EAAKqP,WAAW,GACnB2F,KAAQ,GACTvR,EAAAiP,KAAK,CAAC1S,EAAKqP,WAAW,GAAIrP,EAAKqP,WAAW,KACzC,OAAA5L,CACT,GAsqPQ,GAAe,CAAyBC,EAAE,GAC1C,GAAe,CAAuBA,GAAE,GACxC,GAAe,CAAyBA,EAAE,GAC1C,GAAe,CAAuBA,GAAE,GACxC,GAAe,CAA8BA,EAAE,GAC/C,GAAe,CAA4BA,GAAE,GAC7C,GAAe,CAA2B,EAC1C,GAAe,CAAoB,EACnC,GAAe,CAAwBgH,EA1kX/C,SAAuBwE,EAAMnR,EAAQoF,GACpC,IAAIA,EAAK4jD,WAAmB,OAAAr7B,GAAUxc,EAAMnR,GAC5C,IAAIwH,EAAIpC,GAAQA,EAAKspB,MAAQ,GAAK,EAAI,EAClCu6B,EAAW93C,EAAKG,WAAW9J,GAC3B0hD,EAAU/3C,EAAKG,WAAW9J,GAC1B2hD,EAAQh4C,EAAKG,WAAW9J,GACxBs1B,EAAO3rB,EAAKG,WAAW9J,GACvB6J,EAAQF,EAAKG,WAAW,GACpB,GAAL9J,IAAQ2J,EAAKrE,GAAK,GACjB,IAAAvN,EAAK,CAACmC,EAAEunD,EAAUnoD,EAAEooD,EAAS1hD,EAAE2hD,EAAOrsB,OAAWzrB,SAE9C,OADJjM,EAAKspB,MAAQ,IAAMtpB,EAAKspB,QAAMnvB,EAAEu8C,MAASzqC,GAAS,EAAK,GACnD9R,CACR,GA+jXQ,GAAe,CAA4BoN,EA7pHnD,SAA8B1K,GAGtB,MAAA,CAFIuwB,GAAevwB,GACdgwB,GAAchwB,GACL,KACtB,GA0pHQ,GAAe,CAA+B0K,EA3+OtD,SAAiC1K,GAChC,IAAIyD,EAAM,CAAE,EACRA,EAAA3F,EAAIkC,EAAKqP,WAAW,GACxB,IAAIid,EAAO,CAAE,EACRA,EAAA5jB,EAAI1I,EAAKqP,WAAW,GACpBid,EAAApsB,EAAIF,EAAKqP,WAAW,GACrB5L,EAAAiF,EAAImkB,GAAYP,GAChB,IAAAld,EAAQpP,EAAKqP,WAAW,GAGrB,OAFI,EAARD,IAAa3L,EAAIoH,EAAI,KACb,EAARuE,IAAa3L,EAAI8W,EAAI,KACjB9W,CACR,GAi+OQ,GAAe,CAAqBiH,EAl6G5C,WACA,GAk6GQ,GAAe,CAA2B,EAC1C,GAAe,CAA2B,EAC1C,GAAe,CAA4B,EAC3C,GAAe,CAA2B,EAC1C,GAAe,CAA4B,EAC3C,GAAe,CAA2B,EAC1C,IAAe,CAA4B,EAC3C,IAAe,CAA2BhH,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,EAAGgH,EAAEghB,GAAWld,EAAE,GAC7D,IAAe,CAAwB9K,GAAE,GACzC,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA4BA,EAAE,EAAGgH,EAh/GxD,SAA8B1K,GACzB,IAAA0K,EAAI1K,EAAKqP,WAAW,GAEjB,OADPrP,EAAK6K,GAAK,GACH,CAAE8xC,IAAS,GAAJjyC,EACf,GA6+GQ,IAAe,CAA0BhH,GAAE,GAC3C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAuBgH,EAj2H9C,SAAyB1K,EAAMjC,GAC9B,IAAI+vB,EAAI,CAAE,EACNpjB,EAAI1K,EAAKA,EAAK6K,GAMX,QANiB7K,EAAK6K,EAC3BijB,EAAAuuB,QAAc,GAAJ3xC,GACVojB,EAAAqsB,OAAc,IAAJzvC,GAEZ1K,EAAK6K,GAAK,GACRijB,EAAA9a,KAAO4d,GAAmB5wB,GACrB8tB,CACR,GAy1HQ,IAAe,CAAsBpjB,EAAEq0C,GAAgBvwC,EAAE,IACzD,IAAe,CAAqB9D,EAzjH5C,WACA,GAyjHQ,IAAe,CAAoB,EACnC,IAAe,CAAuBA,EA/3E9C,SAAyB1K,EAAMjC,GAC9B,IAAIT,EAAiB,CAAA,EACjB8R,EAAQpP,EAAKqP,WAAW,GAC1B/R,EAAA6pD,oBAAsBnnD,EAAKqP,WAAW,GACxC,IAAI+3C,EAAWrpD,EAAS,EAAK0xB,GAAmBzvB,GAAQ,GAiBjD,OAhBJonD,EAAQrpD,OAAS,IAAGT,EAAE0+C,SAAWoL,GAClC9pD,EAAA+pD,wBAAkC,MAARj4C,GAC1B9R,EAAAgqD,cAAwB,GAARl4C,GAChB9R,EAAAiqD,sBAAgC,KAARn4C,GACxB9R,EAAA4G,YAAsB,EAARkL,GACd9R,EAAAmlD,iBAA2B,EAARrzC,GACnB9R,EAAAkqD,sBAAgC,KAARp4C,GACxB9R,EAAAmqD,qBAA+B,GAARr4C,GACvB9R,EAAAoqD,gBAA0B,KAARt4C,GAClB9R,EAAAqqD,yBAAmC,OAARv4C,GAC3B9R,EAAAsqD,0BAAoC,IAARx4C,GAC5B9R,EAAAuqD,8BAAwC,EAARz4C,GAChC9R,EAAAwqD,qBAA+B,GAAR14C,GACvB9R,EAAAyqD,YAAc,CAAC,MAAO,eAAgB,QAAS34C,GAAS,GAAM,GAC9D9R,EAAA0qD,wBAAkC,MAAR54C,GAC1B9R,EAAA2qD,YAAc,CAAC,UAAW,QAAS,UAAW74C,GAAS,EAAK,GACvD9R,CACR,GA02EQ,IAAe,CAA0B,EACzC,IAAe,CAA4B,EAC3C,IAAe,CAAyBoN,EAp5EhD,SAA2B1K,EAAMjC,GAChC,IAAI+vB,EAAI,CAAE,EAKH,OAJLA,EAAAm0B,OAASjiD,EAAKqP,WAAW,GACzBye,EAAA60B,OAAS3iD,EAAKqP,WAAW,GACzBye,EAAA80B,SAAW3xB,GAAYjxB,GACvB8tB,EAAA9a,KAAOyc,GAAmBzvB,GACrB8tB,CACR,GA84EQ,IAAe,CAAyB,EACxC,IAAe,CAAyB,EACxC,IAAe,CAAyBpqB,EAAE,EAAGgH,EA/7SrD,SAA2B1K,GACnB,MAAA,CAACA,EAAKqP,WAAW,GAAIrP,EAAKqP,WAAW,GAC7C,GA87SQ,IAAe,CAAuB3L,GAAE,GACxC,IAAe,CAA6BA,EAAE,EAAGgH,EAAEgnB,IACnD,IAAe,CAA2BhuB,GAAE,GAC5C,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAuB,EACtC,IAAe,CAA4B,EAC3C,IAAe,CAA2B,EAC1C,IAAe,CAA4B,EAC3C,IAAe,CAA8B,EAC7C,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA6B,EAC5C,IAAe,CAAqC,EACpD,IAAe,CAA0BgH,EAAEu0C,IAC3C,IAAe,CAAgCv7C,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAuCA,EAAE,GACxD,IAAe,CAAqCA,GAAE,GACtD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAqCA,EAAE,GACtD,IAAe,CAAmCA,GAAE,GACpD,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAAqCA,EAAE,GACtD,IAAe,CAAmCA,GAAE,GACpD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAqCA,EAAE,GACtD,IAAe,CAAmCA,GAAE,GACpD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAAyBA,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,CAA6B,EAC5C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAAwBgH,EAz5P/C,SAA0B1K,EAAMjC,GACvB,MAAA,CACLqR,MAAOpP,EAAKqP,WAAW,GACvB5C,QAASzM,EAAKqP,WAAW,GACzB2D,KAAMyc,GAAmBzvB,GAE7B,GAo5PQ,IAAe,CAA6B0D,GAAE,GAC9C,IAAe,CAA2BgH,EAv3PlD,SAA6B1K,GAEpB,OADPA,EAAK6K,GAAK,EACmB,GAAtB7K,EAAKqP,WAAW,EACzB,EAo3PyE3L,EAAE,GACnE,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA2B,EAC1C,IAAe,CAA2B,EAC1C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA2BgH,EAAEumB,IAC5C,IAAe,CAAwB,EACvC,IAAe,CAAwB,EACvC,IAAe,CAAwB,EACvC,IAAe,CAA6BvtB,EAAE,GAC9C,IAAe,CAAgC,EAC/C,IAAe,CAA4BgH,EAnjYnD,SAA2BwE,EAAMnR,EAAQoF,GACxC,GAAGA,EAAKspB,KAAO,SAOhB,SAAgCvd,EAAMnR,EAAQoF,GACtB,GAApB+L,EAAKA,EAAKrE,EAAI,IAAYqE,EAAKA,EAAKrE,KACvC,IAAIvN,EAAI08B,GAA2B9qB,EAAMnR,EAAQoF,GAC1C,OAAmB,GAAnB7F,EAAEU,WAAW,GAAaV,EAAEqD,MAAM,GAAKrD,CAC/C,CAX0B4qD,CAAuBh5C,EAAMnR,EAAQoF,GAE9D,IADA,IAAI7F,EAAI,GAAIu7C,EAAS3pC,EAAKrE,EAAI9M,EAAQmB,EAAMgQ,EAAKG,WAAWlM,EAAKspB,KAAO,EAAI,EAAI,GAChE,GAAVvtB,KAAe5B,EAAAoV,KAAKooB,GAAU5rB,EAAM/L,EAAKspB,KAAmBtpB,IAE/D,GAAA+L,EAAKrE,GAAKguC,EAAc,MAAA,IAAI3yC,MAAM,oBAAsBgJ,EAAKrE,EAAI,OAASguC,GACtE,OAAAv7C,CACR,GA6iYQ,IAAe,CAAiC,EAChD,IAAe,CAA+B,EAC9C,IAAe,CAA6B,EAC5C,IAAe,CAAgC,EAC/C,IAAe,CAA+B,EAC9C,IAAe,CAA+B,EAC9C,IAAe,CAAgC,EAC/C,IAAe,CAAiC,EAChD,IAAe,CAA2BoG,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAAoB,EACnC,IAAe,CAA6B,EAC5C,IAAe,CAAqB,EACpC,IAAe,CAAqB,EACpC,IAAe,CAAoB,EACnC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAoB,EACnC,IAAe,CAAoB,EACnC,IAAe,CAAyB,EACxC,IAAe,CAA4B,EAC3C,IAAe,CAAuB,EACtC,IAAe,CAA0B,EACzC,IAAe,CAA0B,EACzC,IAAe,CAA6B,EAC5C,IAAe,CAAyB,EACxC,IAAe,CAA2B,EAC1C,IAAe,CAA2B,EAC1C,IAAe,CAA2B,EAC1C,IAAe,CAA0B,EACzC,IAAe,CAAuB,EACtC,IAAe,CAA2B,EAC1C,IAAe,CAAwB,EACvC,IAAe,CAAyB,EACxC,IAAe,CAA4B,EAC3C,IAAe,CAA0B,EACzC,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAwBgH,EAr0H/C,SAA0B1K,EAAMjC,EAAQoF,GACnC,IAAA+c,EAAMlgB,EAAK6K,EAAI9M,EACfoqD,EAAM12B,GAAUzxB,GAChBooD,EAAcpoD,EAAKqP,WAAW,GAC9B/R,EAAI,CAAC6qD,GACT,GADe7qD,EAAE,GAAK8qD,EACnBjlD,EAAKuiD,YAAa,CACpB,IAAIviB,EAAU+V,GAA6Bl5C,EAAMkgB,EAAMlgB,EAAK6K,EAAG1H,GAC/D7F,EAAE,GAAK6lC,CACT,QAAat4B,EAAIqV,EACT,OAAA5iB,CACR,GA4zHQ,IAAe,CAAwBoN,EAzzH/C,SAA0B1K,EAAMjC,EAAQoF,GACnC,IAAA+c,EAAMlgB,EAAK6K,EAAI9M,EAEfT,EAAI,CADEo0B,GAAmB1xB,IAE7B,GAAGmD,EAAKuiD,YAAa,CACpB,IAAIviB,EAAUkW,GAA8Br5C,EAAMkgB,EAAMlgB,EAAK6K,EAAG1H,GAChE7F,EAAE,GAAK6lC,EACPnjC,EAAK6K,EAAIqV,CACX,QAAarV,EAAIqV,EACT,OAAA5iB,CACR,GAgzHQ,IAAe,CAAsB,EACrC,IAAe,CAAoCoG,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAAyBA,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA2CA,EAAE,GAC5D,IAAe,CAAyCA,GAAE,GAC1D,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAqB,EACpC,IAAe,CAAgC,EAC/C,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAA6B,EAC5C,IAAe,CAAwBgH,EA30H/C,SAA0B1K,GACzB,IAAIg6C,EAAW,CAAA,EAER,OADOmF,GAAAhrB,SAAQ,SAAS3hB,GAAawnC,EAAAxnC,GAAKof,GAAW5xB,MACrDg6C,CACR,GAw0HQ,IAAe,CAA6B,EAC5C,IAAe,CAA0B,EACzC,IAAe,CAAkCt2C,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAA0BgH,EAnrIjD,WACA,GAmrIQ,IAAe,CAAyBhH,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAAwBA,EAAE,GACzC,IAAe,CAAsBA,GAAE,GACvC,IAAe,CAAyBA,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,CAAsBgH,EAt6H7C,SAAwB1K,EAAMjC,GACzB,IAAAmiB,EAAMlgB,EAAK6K,EAAI9M,EACfoqD,EAAMz2B,GAAmB1xB,GACzBqoD,EAAQv3B,GAA2B9wB,GACnC2qB,EAAM8E,GAAmBzvB,GACzBm+C,EAAU1uB,GAAmBzvB,GAC7BsoD,EAAU74B,GAAmBzvB,GACjCA,EAAK6K,EAAIqV,EACT,IAAI5iB,EAAK,CAAC6qD,MAASE,QAAa19B,MAAS29B,WAElC,OADJnK,MAAWniB,QAAUmiB,GACjB7gD,CACR,GA45HQ,IAAe,CAA0BoG,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAAqB,EACpC,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAyBA,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,CAAoB,EACnC,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAAoB,EACnC,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAkC,EACjD,IAAe,CAAiC,EAChD,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA4B,EAC3C,IAAe,CAAuB,EACtC,IAAe,CAAuB,EACtC,IAAe,CAAuB,EACtC,IAAe,CAAuB,EACtC,IAAe,CAAwB,EACvC,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+B,EAC9C,IAAe,CAAgC,EAC/C,IAAe,CAAgC,EAC/C,IAAe,CAA6B,EAC5C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA4B,EAC3C,IAAe,CAAwB,EACvC,IAAe,CAAwBgH,EAAEumB,IACzC,IAAe,CAA8B,EAC7C,IAAe,CAAgC,EAC/C,IAAe,CAAuB,EACtC,IAAe,CAAiCvtB,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAsB,EACrC,IAAe,CAAsB,EACrC,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAyB,EACxC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA6B,EAC5C,IAAe,CAAkC,EACjD,IAAe,CAAgC,EAC/C,IAAe,CAA2B,EAC1C,IAAe,CAA2B,EAC1C,IAAe,CAA0B,EACzC,IAAe,CAA2B,EAC1C,IAAe,CAA4B,EAC3C,IAAe,CAA4B,EAC3C,IAAe,CAA4B,EAC3C,IAAe,CAA2B,EAC1C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAqC,EACpD,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA6B,EAC5C,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAA0B,EACzC,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA4B,EAC3C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAAwB,EACvC,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAA8BgH,EAAEinC,IAC/C,IAAe,CAAiCjuC,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAA6BA,EAAE,EAAGgH,EAtmPzD,SAA+B1K,GAC9B,IAAIyD,EAAM,CAAE,EACRA,EAAAstC,QAAU/wC,EAAKqP,WAAW,GAC1B,IAAA84C,EAAMz2B,GAAmB1xB,GAItB,OAHPyD,EAAI0kD,IAAMA,EAAI1oD,EACVgE,EAAAq4B,IAAMjP,GAAYs7B,EAAI1oD,GAC1BO,EAAK6K,GAAK,GACHpH,CACR,GA+lPQ,IAAe,CAA2BC,GAAE,GAC5C,IAAe,CAA4BgH,EAAEylB,IAC7C,IAAe,CAAgCzsB,EAAE,GACjD,IAAe,CAA0B,EACzC,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAqCA,EAAE,GACtD,IAAe,CAAwB,EACvC,IAAe,CAAmCA,GAAE,GACpD,IAAe,CAA2CA,EAAE,GAC5D,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAA6B,EAC5C,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAAuBgH,EAh0G9C,SAAyB1K,EAAMjC,GAG9B,OAFAiC,EAAK6K,GAAK,GAEH,CAAEmI,KADEyc,GAAmBzvB,GAE/B,GA6zGQ,IAAe,CAA4B,EAC3C,IAAe,CAAiC0D,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAA6B,EAC5C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAAyB,EACxC,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8B,EAC7C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAAwB,EACvC,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAyB,EACxC,IAAe,CAA4B,EAC3C,IAAe,CAA6B,EAC5C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA2B,EAC1C,IAAe,CAA+B,EAC9C,IAAe,CAAkC,EACjD,IAAe,CAAmC,EAClD,IAAe,CAAgC,EAC/C,IAAe,CAAmC,EAClD,IAAe,CAAyB,EACxC,KAAe,CAA0B,EACzC,KAAe,CAA2B,EAC1C,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAAqC,EACpD,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,GAAE,GAClD,KAAe,CAAkC,EACjD,KAAe,CAAwB,EACvC,KAAe,CAAuB,EACtC,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,GAAE,GACjD,KAAe,CAAuB,EACtC,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAA0B,EACzC,KAAe,CAAuB,EACtC,KAAe,CAA8B,EAC7C,KAAe,CAA6CA,EAAE,GAC9D,KAAe,CAA2CA,GAAE,GAC5D,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAAuB,EACtC,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAAuBgH,EAx9H9C,WACA,GAw9HQ,KAAe,CAA6BhH,EAAE,GAC9C,KAAe,CAAwB,EACvC,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAAuB,EACtC,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAA2BA,EAAE,GAC5C,KAAe,CAAyBA,GAAE,GAC1C,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,GAAE,GAClD,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAA4BA,EAAE,GAC7C,KAAe,CAA0BA,GAAE,GAC3C,KAAe,CAAuC,EACtD,KAAe,CAAyCA,EAAE,GAC1D,KAAe,CAAuCA,GAAE,GACxD,KAAe,CAA2CA,EAAE,GAC5D,KAAe,CAAyCA,GAAE,GAC1D,KAAe,CAA0CA,EAAE,GAC3D,KAAe,CAAwCA,GAAE,GACzD,KAAe,CAAyCA,EAAE,GAC1D,KAAe,CAAuCA,GAAE,GACxD,KAAe,CAAwCA,EAAE,GACzD,KAAe,CAAsCA,GAAE,GACvD,KAAe,CAAoC,EACnD,KAAe,CAA2CA,EAAE,GAC5D,KAAe,CAAqC,EACpD,KAAe,CAAyCA,GAAE,GAC1D,KAAe,CAAuCA,EAAE,GACxD,KAAe,CAAqCA,GAAE,GACtD,KAAe,CAAsC,EACrD,KAAe,CAAkC,EACjD,KAAe,CAAqC,EACpD,KAAe,CAA+B,EAC9C,KAAe,CAAuB,EACtC,KAAe,CAAuB,EACtC,KAAe,CAA+CA,EAAE,GAChE,KAAe,CAA6CA,GAAE,GAC9D,KAAe,CAA6BA,EAAE,GAC9C,KAAe,CAA2BA,GAAE,GAC5C,KAAe,CAAyB,EACxC,KAAe,CAA4BA,EAAE,GAC7C,KAAe,CAA0BA,GAAE,GAC3C,KAAe,CAA6BA,EAAE,GAC9C,KAAe,CAA2BA,GAAE,GAC5C,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAA6B,EAC5C,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAmC,EAClD,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAA8CA,EAAE,GAC/D,KAAe,CAA4CA,GAAE,GAC7D,KAAe,CAA4CA,EAAE,GAC7D,KAAe,CAA0CA,GAAE,GAC3D,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,GAAE,GAClD,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAA2B,EAC1C,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,GAAE,GACjD,KAAe,CAAyCA,EAAE,GAC1D,KAAe,CAAuCA,GAAE,GACxD,KAAe,CAA0B,EACzC,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,GAAE,GACjD,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAA2BA,GAAE,GAC5C,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,GAAE,GACjD,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAA6BA,EAAE,GAC9C,KAAe,CAA2BA,GAAE,GAC5C,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAAsB,EACrC,KAAe,CAA4BA,EAAE,GAC7C,KAAe,CAA0BA,GAAE,GAC3C,KAAe,CAAyB,EACxC,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAA+B,EAC9C,KAAe,CAA6B,EAC5C,KAAe,CAAyC,EACxD,KAAe,CAA4CA,EAAE,GAC7D,KAAe,CAA0CA,GAAE,GAC3D,KAAe,CAAsC,EACrD,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAA8B,EAC7C,KAAe,CAA2C,EAC1D,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAA2BA,EAAE,GAC5C,KAAe,CAAyBA,GAAE,GAC1C,KAAe,CAA6B,EAC5C,KAAe,CAAsB,EACrC,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,GAAE,GAClD,KAAe,CAA6B,EAC5C,KAAe,CAA0B,EACzC,KAAe,CAA0CA,EAAE,GAC3D,KAAe,CAAwCA,GAAE,GACzD,KAAe,CAAoC,EACnD,KAAe,CAAmC,EAClD,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAA2B,EAC1C,KAAe,CAAgDA,EAAE,GACjE,KAAe,CAA8CA,GAAE,GAC/D,KAAe,CAA0C,EACzD,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAA6B,EAC5C,KAAe,CAAuB,EACtC,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,GAAE,GAClD,KAAe,CAAqC,EACpD,KAAe,CAA6CA,EAAE,GAC9D,KAAe,CAA2CA,GAAE,GAC5D,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAA2CA,EAAE,GAC5D,KAAe,CAAyCA,GAAE,GAC1D,KAAe,CAAsB,EACrC,KAAe,CAA4BA,EAAE,GAC7C,KAAe,CAA0BA,GAAE,GAC3C,KAAe,CAA+C,EAC9D,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAA+B,EAC9C,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,GAAE,GACjD,KAAe,CAAyB,EACxC,KAAe,CAA0B,EACzC,KAAe,CAA4B,EAC3C,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAA0B,EACzC,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAA2B,EAC1C,KAAe,CAAwCA,EAAE,GACzD,KAAe,CAAsCA,GAAE,GACvD,KAAe,CAAkC,EACjD,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAoC,EACnD,KAAe,CAAoC,EACnD,KAAe,CAAuB,EACtC,KAAe,CAAwCA,EAAE,GACzD,KAAe,CAAsCA,GAAE,GACvD,KAAe,CAAuCA,EAAE,GACxD,KAAe,CAAqCA,GAAE,GACtD,KAAe,CAAyC,EACxD,KAAe,CAAoB,EACnC,KAAe,CAA4B,EAC3C,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAA2B,EAC1C,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAAuCA,EAAE,GACxD,KAAe,CAAqCA,GAAE,GACtD,KAAe,CAAiC,EAChD,KAAe,CAAgC,EAC/C,KAAe,CAAkC,EACjD,KAAe,CAAuCA,EAAE,GACxD,KAAe,CAAqCA,GAAE,GACtD,KAAe,CAAwC,EACvD,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,GAAE,GACjD,KAAe,CAA4B,EAC3C,KAAe,CAAgC,EAC/C,MAAe,CAAEiJ,EAAE,KAkd3B,SAASk9B,GAAe1d,EAAiB/lB,EAAiByO,EAAS9W,GAClE,IAAIoD,EAAeiF,EAChB,IAAAnI,MAAMkD,GAAN,CACH,IAAIjC,EAAMnB,IAAW8W,GAAS,IAAI9W,QAAU,EACxCT,EAAI6uB,EAAGH,KAAK,GACd1uB,EAAAyR,YAAY,EAAG5N,GACf7D,EAAAyR,YAAY,EAAG7P,GACOA,EAAM,GAAKkrB,GAAOvV,IAAUsX,EAAGzZ,KAAKmC,EAL/C,CAMd,CAyBA,SAAS0zC,GAAgB9kD,EAAKiF,EAAcxI,GAMpC,OALHuD,IAAWA,EAAAsR,GAAQ,IACnBtR,EAAAsL,YAAY,EAAGrG,GACfjF,EAAAsL,YAAY,EAAG7O,GACfuD,EAAAsL,YAAY,EAAG,GACftL,EAAAsL,YAAY,EAAG,GACZtL,CACR,CAkBA,SAAS+kD,GAAoBr8B,EAAiBG,EAAe3Y,EAAczF,GAC1E,GAAa,MAAVoe,EAAKrrB,EAAW,OAAOqrB,EAAKnrB,GAC9B,IAAK,IAAK,IAAK,IACV,IAAAF,EAAc,KAAVqrB,EAAKnrB,EAAW6jB,GAAQS,GAAU6G,EAAKrrB,IAAMqrB,EAAKrrB,EAK1D,YAJIA,IAAQ,EAAFA,IAAUA,GAAK,GAAOA,EAAI,MACnC4oC,GAAe1d,EAAI,GAjxZCzjB,EAixZsBiL,EAjxZRzT,EAixZWgO,EAjxZG5H,EAixZArF,EAhxZ/CwC,EAAMsR,GAAQ,GACFwzC,GAAA9kD,EAAKiF,EAAGxI,GACpBuD,EAAAsL,YAAY,EAAGzI,GACZ7C,IA+wZJomC,GAAe1d,EAAI,EAlyZvB,SAAwBzjB,EAAcxI,EAAcoG,GAC/C,IAAA7C,EAAMsR,GAAQ,IAGX,OAFSwzC,GAAA9kD,EAAKiF,EAAGxI,GACpBuD,EAAAsL,YAAY,EAAGzI,EAAK,KACjB7C,CACR,CA6xZ+BglD,CAAe90C,EAAEzF,EAAGjN,KAEjD,IAAK,IAAK,IAAK,IAAwE,YAApD4oC,GAAA1d,EAAI,EAzBzC,SAAyBzjB,EAAcxI,EAAcoG,EAAKnF,GACrD,IAAAsC,EAAMsR,GAAQ,GAGX,OAFSwzC,GAAA9kD,EAAKiF,EAAGxI,GACd65B,GAAAzzB,EAAKnF,GAAK,IAAKsC,GAClBA,CACR,CAoBiDilD,CAAgB/0C,EAAGzF,EAAGoe,EAAKrrB,EAAGqrB,EAAKnrB,IAElF,IAAK,IAAK,IAAK,MAEd,YADA0oC,GAAe1d,EAAI,EApBtB,SAA0BzjB,EAAcxI,EAAcoG,GACrD,IAAI7C,EAAMsR,GAAQ,EAAI,EAAEzO,EAAIvI,QAIrB,OAHSwqD,GAAA9kD,EAAKiF,EAAGxI,GACpBuD,EAAAsL,YAAY,EAAGzI,EAAIvI,QACvB0F,EAAIsL,YAAYzI,EAAIvI,OAAQuI,EAAK,QAC1B7C,EAAIoH,EAAIpH,EAAI1F,OAAS0F,EAAI9C,MAAM,EAAG8C,EAAIoH,GAAKpH,CACnD,CAc8BklD,CAAiBh1C,EAAGzF,GAAIoe,EAAKrrB,GAAG,IAAIN,MAAM,EAAE,OAxxZ1E,IAAwB+H,EAAcxI,EAAcoG,EAC/C7C,EA0xZJomC,GAAe1d,EAAI,EAAQo8B,GAAgB,KAAM50C,EAAGzF,GACrD,CAyBA,SAAS06C,GAAgBxtB,EAAiBj4B,GAKzC,IAJI,IAAA7F,EAAI6F,GAAQ,CAAE,EAEdgpB,EAAKR,KACL5kB,EAAM,EACFjJ,EAAE,EAAEA,EAAEs9B,EAAG9M,WAAWvwB,SAASD,EAAMs9B,EAAG9M,WAAWxwB,IAAMR,EAAE8wB,QAAWrnB,EAAAjJ,GAC5E,GAAU,GAAPiJ,GAAczJ,EAAE8wB,OAASgN,EAAG9M,WAAW,IAAMhxB,EAAE8wB,MAAO,MAAM,IAAIloB,MAAM,oBAAsB5I,EAAE8wB,OAMjG,OALAyb,GAAe1d,EAAe,GAAV7uB,EAAEmvB,KAAY,KAAoB,GAAVnvB,EAAEmvB,KAAY,IAAS,EAAU0O,GAAUC,EAAI,GAAM99B,IA9BlG,SAAwB6uB,EAAiBwC,EAAkB5nB,EAAgB5D,GACtE,IAC+C24B,EAD/CpN,EAAQrvB,MAAMY,QAAQ0uB,GACtBhC,EAAQiB,GAAkBe,EAAG,SAAW,MAAuB1lB,EAAK,GAAI00B,EAAyB,GACrG,GAAGhR,EAAM9tB,EAAEqB,EAAI,KAAQysB,EAAM9tB,EAAE6J,EAAI,MAAQ,CACvC,GAAAvF,EAAKwzB,IAAK,MAAM,IAAIzwB,MAAM,UAAYyoB,EAAG,SAAW,MAAQ,oCAC/DhC,EAAM9tB,EAAEqB,EAAIsB,KAAKgI,IAAImjB,EAAM9tB,EAAEqB,EAAG,KAChCysB,EAAM9tB,EAAE6J,EAAIlH,KAAKgI,IAAImjB,EAAM9tB,EAAEqB,EAAG,OAChC47B,EAAMrO,GAAad,EACrB,CACS,IAAA,IAAAhZ,EAAIgZ,EAAMltB,EAAEiJ,EAAGiL,GAAKgZ,EAAM9tB,EAAE6J,IAAKiL,EAAG,CAC3C1K,EAAK+jB,GAAWrZ,GACR,IAAA,IAAAzF,EAAIye,EAAMltB,EAAES,EAAGgO,GAAKye,EAAM9tB,EAAEqB,IAAKgO,EAAG,CACxCyF,IAAMgZ,EAAMltB,EAAEiJ,MAAQwF,GAAK+e,GAAW/e,IACnC4tB,EAAA6B,EAAKzvB,GAAKjF,EACZ,IAAAqjB,EAAOoC,GAASC,EAAGhb,IAAI,IAAIzF,GAAKygB,EAAGmN,GACnCxP,GAEgBk8B,GAAAr8B,EAAIG,EAAM3Y,EAAGzF,EACpC,CACA,CACA,CAYgB26C,CAAA18B,EAAIiP,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOA,EAAKzJ,GAEvDusC,GAAe1d,EAAI,IACZA,EAAGjM,KACX,CAEA,SAAS4oC,GAAkB38B,EAAInsB,EAAMmD,GACrB0mC,GAAA1d,EAAI,GAr+apB,SAAoBnsB,EAAMmD,GACrB,IAAA6P,EAAOhT,EAAKgT,MAAQ,QACpBwoB,EAAMr4B,GAAsB,GAAbA,EAAKspB,KACpBnvB,EAAIyX,GADkCymB,EAAM,GAAKxoB,EAAKjV,OAAW,GAAK,EAAIiV,EAAKjV,QAU5E,OARPT,EAAEyR,YAAY,EAAqB,GAAjB/O,EAAKsP,IACrBhS,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,KACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAGiE,EAAKjV,QAClBy9B,GAAMl+B,EAAAyR,YAAY,EAAG,GACvBzR,EAAAyR,aAAaysB,EAAK,EAAI,GAAKxoB,EAAKjV,OAAQiV,EAAOwoB,EAAK,OAAS,WACxDl+B,CACR,CAw9auCyrD,CAAW,CAChDz5C,GAAG,GAEH0D,KAAM,SAGJ7P,GACJ,CA2CA,SAAS6lD,GAAoB78B,EAAIwR,GAChC,GAAIA,EAAJ,CACA,IAAI3oB,EAAM,EACL2oB,EAAAxJ,SAAQ,SAAS7G,EAAKvmB,KACrBiO,GAAO,KAAOsY,GACHuc,GAAA1d,EAAI,IAt9ZtB,SAAuBmB,EAAKvmB,GACvB,IAAAzJ,EAAIyX,GAAQ,IACdzX,EAAAyR,YAAY,EAAGhI,GACfzJ,EAAAyR,YAAY,EAAGhI,GACjBzJ,EAAEyR,YAAY,EAAe,IAAZue,EAAIlyB,OACnBkC,EAAAyR,YAAY,EAAG,GACjB,IAAIrE,EAAI,EAMD,OALJ4iB,EAAIkW,SAAa94B,GAAA,GAClBpN,EAAAyR,YAAY,EAAGrE,GACjBA,EAAI4iB,EAAIusB,OAAS,EACfv8C,EAAAyR,YAAY,EAAGrE,GACfpN,EAAAyR,YAAY,EAAG,GACVzR,CACR,CAy8Z4C2rD,CAAcrP,GAAU7yC,EAAKumB,GAAMvmB,GAE/E,GANW,CAOX,CAEA,SAASmiD,GAAoB/8B,EAAiBG,EAAe3Y,EAAczF,EAAc/K,GACxF,IAAIm1C,EAAK,GAAKkC,GAAer3C,EAAKwpC,QAASrgB,EAAMnpB,GACjD,GAAa,MAAVmpB,EAAKrrB,GAAcqrB,EAAKosB,GAIxB,GAAApsB,EAAKosB,GAAI7O,GAAe1d,EAAI,EAAsBksB,GAAc/rB,EAAM3Y,EAAGzF,EAAG/K,EAAMm1C,SAChF,OAAOhsB,EAAKnrB,GAChB,IAAK,IAAK,IAAK,IAGd0oC,GAAe1d,EAAI,IAp0atB,SAAsBxY,EAAczF,EAAcjN,EAAGq3C,GAChD,IAAAh7C,EAAIyX,GAAQ,IAGT,OAFO6lB,GAAAjnB,EAAGzF,EAAGoqC,EAAIh7C,GACxBu0B,GAAW5wB,EAAG3D,GACPA,CACR,CA+za2C6rD,CAAax1C,EAAGzF,EAFtC,KAAVoe,EAAKnrB,EAAW6jB,GAAQS,GAAU6G,EAAKrrB,IAAMqrB,EAAKrrB,EAEIq3C,IAC9D,MACD,IAAK,IAAK,IAAK,IACCzO,GAAA1d,EAAI,IAt1atB,SAAuBxY,EAAczF,EAAcjN,EAAGq3C,EAAen1C,EAAMhC,GACtE,IAAA7D,EAAIyX,GAAQ,GAGT,OAFO6lB,GAAAjnB,EAAGzF,EAAGoqC,EAAIh7C,GACdy8B,GAAA94B,EAAGE,EAAG7D,GACTA,CACR,CAi1a4C8rD,CAAcz1C,EAAGzF,EAAGoe,EAAKrrB,EAAGq3C,EAAIn1C,EAAMmpB,EAAKnrB,IACpF,MAED,IAAK,IAAK,IAAK,MACd,GAAGgC,EAAKmnC,QAEPT,GAAe1d,EAAI,IAhibvB,SAAwBxY,EAAczF,EAAcjN,EAAcq3C,GAC7D,IAAAh7C,EAAIyX,GAAQ,IAGT,OAFO6lB,GAAAjnB,EAAGzF,EAAGoqC,EAAIh7C,GACtBA,EAAAyR,YAAY,EAAG9N,GACV3D,CACR,CA2hb8C+rD,CAAe11C,EAAGzF,EADjDsrC,GAAWr2C,EAAKk4C,QAAS/uB,EAAKrrB,EAAGkC,EAAKm4C,YACoBhD,SAChDzO,GAAA1d,EAAI,IAhhb7B,SAAqBxY,EAAczF,EAAcjN,EAAcq3C,EAAen1C,GAC7E,IAAImmD,GAAMnmD,GAAqB,GAAbA,EAAKspB,KACnBnvB,EAAIyX,IAAkBu0C,EAAV,GAAiB,EAAIA,GAAMroD,EAAElD,QAKtC,OAJO68B,GAAAjnB,EAAGzF,EAAGoqC,EAAIh7C,GACtBA,EAAAyR,YAAY,EAAG9N,EAAElD,QAChBurD,GAAIhsD,EAAEyR,YAAY,EAAG,GACtBzR,EAAAyR,aAAa,EAAIu6C,GAAMroD,EAAElD,OAAQkD,EAAGqoD,EAAK,UAAY,QAChDhsD,CACR,CAwgbiDisD,CAAY51C,EAAGzF,GAAIoe,EAAKrrB,GAAG,IAAIN,MAAM,EAAE,KAAM23C,EAAIn1C,IAC/F,MACD,QACC0mC,GAAe1d,EAAI,IAAoByO,GAAcjnB,EAAGzF,EAAGoqC,SArB5DzO,GAAe1d,EAAI,IAAoByO,GAAcjnB,EAAGzF,EAAGoqC,GAuB7D,CAGA,SAASkR,GAAeziD,EAAgB5D,EAAMi4B,GAC7C,IAMIU,EA53aAx+B,EAs3aA6uB,EAAKR,KACLlsB,EAAI27B,EAAG9M,WAAWvnB,GAAM4nB,EAAKyM,EAAG7M,OAAO9uB,IAAM,CAAE,EAC/CgqD,GAAsBruB,GAAI,CAAA,GAAI2gB,UAAU,CAAA,EACxC2N,GAAwBD,EAAIl7B,QAAQ,IAAIxnB,IAAM,GAC9C2nB,EAAQrvB,MAAMY,QAAQ0uB,GACtB26B,EAAkB,GAAbnmD,EAAKspB,KACMxjB,EAAK,GAAI00B,EAAyB,GAClDhR,EAAQiB,GAAkBe,EAAG,SAAW,MACxCg7B,EAAWL,EAAK,MAAQ,MAC5B,GAAG38B,EAAM9tB,EAAEqB,EAAI,KAAQysB,EAAM9tB,EAAE6J,GAAKihD,EAAU,CAC1C,GAAAxmD,EAAKwzB,IAAK,MAAM,IAAIzwB,MAAM,UAAYyoB,EAAG,SAAW,MAAQ,oCAC/DhC,EAAM9tB,EAAEqB,EAAIsB,KAAKgI,IAAImjB,EAAM9tB,EAAEqB,EAAG,KAC1BysB,EAAA9tB,EAAE6J,EAAIlH,KAAKgI,IAAImjB,EAAM9tB,EAAEqB,EAAGypD,EAAS,EAC3C,CAEC9f,GAAe1d,EAAI,KAAQgP,GAAUC,EAAI,GAAMj4B,IAE/C0mC,GAAe1d,EAAI,GAAuB2N,GAAY,IACtD+P,GAAe1d,EAAI,GAAwB2N,GAAY,MACvD+P,GAAe1d,EAAI,GAA0ByN,IAAU,IACvDiQ,GAAe1d,EAAI,GAAuByN,IAAU,IACpDiQ,GAAe1d,EAAI,GAAwB0F,GAAW,OACtDgY,GAAe1d,EAAI,GAA6ByN,IAAU,IAC1DiQ,GAAe1d,EAAI,GAA0ByN,IAAU,IACvDiQ,GAAe1d,EAAI,GAAwByN,IAAU,IACrDiQ,GAAe1d,EAAI,IAAsB2N,GAAY,IACtC+P,GAAA1d,EAAI,MAh5af7uB,EAAIyX,GAAQ,IACdhG,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAA2B,GACvCzR,EAAAyR,YAAY,EAA2B,GAClCzR,IAg5aPusC,GAAe1d,EAAI,IAAsByN,IAAU,IACnDiQ,GAAe1d,EAAI,IAAsByN,IAAU,IAEhD0vB,GAAIN,GAAoB78B,EAAIwC,EAAG,UAElCkb,GAAe1d,EAAI,IArhbpB,SAA0BQ,EAAOxpB,GAChC,IAAIoC,EAAiB,GAAbpC,EAAKspB,MAActpB,EAAKspB,KAAW,EAAJ,EACnCnvB,EAAIyX,GAAQ,EAAExP,EAAI,GAMf,OALPjI,EAAEyR,YAAYxJ,EAAGonB,EAAMltB,EAAEiJ,GACzBpL,EAAEyR,YAAYxJ,EAAGonB,EAAM9tB,EAAE6J,EAAI,GAC7BpL,EAAEyR,YAAY,EAAG4d,EAAMltB,EAAES,GACzB5C,EAAEyR,YAAY,EAAG4d,EAAM9tB,EAAEqB,EAAI,GAC3B5C,EAAAyR,YAAY,EAAG,GACVzR,CACR,CA4gb2BssD,CAAiBj9B,EAAOxpB,IAG/CmmD,IAAI36B,EAAG,UAAY,IACd,IAAA,IAAAhb,EAAIgZ,EAAMltB,EAAEiJ,EAAGiL,GAAKgZ,EAAM9tB,EAAE6J,IAAKiL,EAAG,CAC3C1K,EAAK+jB,GAAWrZ,GACR,IAAA,IAAAzF,EAAIye,EAAMltB,EAAES,EAAGgO,GAAKye,EAAM9tB,EAAEqB,IAAKgO,EAAG,CACxCyF,IAAMgZ,EAAMltB,EAAEiJ,MAAQwF,GAAK+e,GAAW/e,IACnC4tB,EAAA6B,EAAKzvB,GAAKjF,EACZ,IAAAqjB,EAAOoC,GAASC,EAAGhb,IAAI,IAAIzF,GAAKygB,EAAGmN,GACnCxP,IAEJ48B,GAAoB/8B,EAAIG,EAAM3Y,EAAGzF,EAAG/K,GACjCmmD,GAAMh9B,EAAKzhB,GAAM8jB,EAAA,UAAUjc,KAAK,CAACopB,EAAKxP,EAAKzhB,IACjD,CACA,CACC,IAAIixC,EAAmB4N,EAAO1N,UAAY0N,EAAO12C,MAAQvT,EAazD,OAXG6pD,GAAmBzf,GAAA1d,EAAI,IAjpb3B,SAAuBrsB,GACtB,IAAIxC,EAAIyX,GAAQ,IAAKrK,EAAI,KAOlB,OANJ5K,GAAQA,EAAK68C,MAAUjyC,GAAA,IACxBpN,EAAAyR,YAAY,EAAGrE,GACfpN,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,IACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACVzR,CACR,CAwobiDusD,EAAeJ,EAAIhN,OAAO,IAAI,KAE3E6M,IAAO36B,EAAG,YAAY,IAAI5wB,QAAuB8rC,GAAA1d,EAAI,IAzuazD,SAA0B2xB,GACzB,IAAIxgD,EAAIyX,GAAQ,EAAoB,EAAhB+oC,EAAO//C,QACzBT,EAAAyR,YAAY,EAAG+uC,EAAO//C,QAChB,IAAA,IAAAD,EAAI,EAAGA,EAAIggD,EAAO//C,SAAUD,EAAeo9B,GAAA4iB,EAAOhgD,GAAIR,GACvD,OAAAA,CACR,CAouakFwsD,CAAiBn7B,EAAG,aAElG26B,GA1GJ,SAA+Bn9B,EAAiBwC,GACvC,IAAA,IAAAhb,EAAE,EAAGA,EAAEgb,EAAG,UAAU5wB,SAAU4V,EAAG,CACxC,IAAIo2C,EAAKp7B,EAAG,UAAUhb,GACtBk2B,GAAe1d,EAAI,IAAoByP,GAAYmuB,IAChDA,EAAG,GAAG/tB,YAAwB7P,EAAI,KAA2B4P,GAAmBguB,GACrF,QACQp7B,EAAG,SACX,CAmG8Bq7B,CAAA79B,EAAIwC,GAEjCkb,GAAe1d,EAAI,IAAuBkO,GAAsByhB,IAE7DwN,GArIJ,SAAoBn9B,EAAIwC,GAEnB,IAAArxB,EAAIyX,GAAQ,IACdzX,EAAAyR,YAAY,EAAG,MAAUzR,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GAC7DzR,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GAC5C86B,GAAA1d,EAAI,KAAsB7uB,IAEzCA,EAAIyX,GAAQ,KACVhG,YAAY,EAAG,MAAUzR,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GAC7DzR,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GACzDzR,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GAAMzR,EAAAyR,YAAY,EAAG,GAC3DmsB,GAAYtN,GAAkBe,EAAG,SAAS,MAAOrxB,GAC/CA,EAAAyR,YAAY,EAAG,GACF86B,GAAA1d,EAAI,KAAmB7uB,EACvC,CAuHmB2sD,CAAA99B,EAAIwC,GAEtBkb,GAAe1d,EAAI,IACZA,EAAGjM,KACX,CAGA,SAASgqC,GAAmB9uB,EAAiB/6B,EAAM8C,GAClD,IAnrbI7F,EAmrbAyF,EAAI4oB,KACJ89B,GAAsBruB,GAAI,CAAA,GAAI2gB,UAAU,CAAA,EACxCoO,EAA+BV,EAAIl7B,QAAQ,GAC3C67B,EAA0BX,EAAIzH,SAAS,CAA+B,EACtEsH,EAAkB,GAAbnmD,EAAKspB,KAAW+O,EAAkB,GAAbr4B,EAAKspB,MACnCod,GAAe9mC,EAAG,KAAQo4B,GAAUC,EAAI,EAAMj4B,IAC1B,OAAjBA,EAAK8wB,UAAmB4V,GAAe9mC,EAAG,KAC7C8mC,GAAe9mC,EAAG,IAA2BumD,EAAKxvB,GAAY,MAAU,MACxE+P,GAAe9mC,EAAG,IAjxcnB,SAAqB4J,EAAGrP,GAASA,IAAKA,EAAAyX,GAAQpI,IAAY,IAAA,IAAA/F,EAAE,EAAGA,EAAE+F,IAAK/F,EAAGtJ,EAAEyR,YAAY,EAAG,GAAW,OAAAzR,CAAE,CAixclE+sD,CAAY,IAC7C7uB,GAAIqO,GAAe9mC,EAAG,KACtBy4B,GAAIqO,GAAe9mC,EAAG,KACzB8mC,GAAe9mC,EAAG,KAClB8mC,GAAe9mC,EAAG,GAv0bnB,SAA2BtD,EAAc0D,GACxC,IAAImmD,GAAMnmD,GAAqB,GAAbA,EAAKspB,KACnBnvB,EAAIyX,GAAQu0C,EAAK,IAAM,IAKrB,IAJNhsD,EAAEyR,YAAyB,GAAb5L,EAAKspB,KAAY,EAAI,EAAG,GACnC68B,GAAIhsD,EAAEyR,YAAY,EAAG,GACtBzR,EAAAyR,YAAY,EAAG,WACjBzR,EAAEyR,YAAY,EAAI,SAAcu6C,EAAK,EAAI,YACnChsD,EAAEuN,EAAIvN,EAAES,UAAUgR,YAAY,EAAIu6C,EAAK,EAAI,IAC1C,OAAAhsD,CACR,CA8zb6CgtD,CAAkB,EAAWnnD,IAEzE0mC,GAAe9mC,EAAG,GAAuB+2B,GAAYwvB,EAAK,KAAS,OAEhEA,GAAmBzf,GAAA9mC,EAAG,IAAkB+2B,GAAY,IACpDwvB,GAAIzf,GAAe9mC,EAAG,KACzB8mC,GAAe9mC,EAAG,IA5ianB,SAAuB4J,GAEd,IADJ,IAAAlJ,EAAMsR,GAAQ,EAAIpI,GACd7O,EAAI,EAAGA,EAAI6O,IAAK7O,EAAO2F,EAAAsL,YAAY,EAAGjR,EAAE,GACzC,OAAA2F,CACR,CAwiayC8mD,CAAcnvB,EAAG9M,WAAWvwB,SACjEurD,GAAMluB,EAAGygB,QAAQhS,GAAe9mC,EAAG,KAEnCumD,GAAMluB,EAAGygB,SAEXhS,GAAe9mC,EAAG,IAAuBs3B,GADlB+vB,EAAIpO,UAAY,iBAGxCnS,GAAe9mC,EAAG,IAAkC+2B,GAAY,KAIhE+P,GAAe9mC,EAAG,GAAyB62B,IAAU,IACrDiQ,GAAe9mC,EAAG,GAAsB62B,IAAU,IAClDiQ,GAAe9mC,EAAG,GAAuB+2B,GAAY,IAClDwvB,GAAmBzf,GAAA9mC,EAAG,IAAuB62B,IAAU,IACvD0vB,GAAmBzf,GAAA9mC,EAAG,IAA2B+2B,GAAY,IACjD+P,GAAA9mC,EAAG,KArtbdzF,EAAIyX,GAAQ,KACdhG,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,OACfzR,EAAAyR,YAAY,EAAG,OACfzR,EAAAyR,YAAY,EAAG,IACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,KACVzR,IA4sbPusC,GAAe9mC,EAAG,GAAqB62B,IAAU,IACjDiQ,GAAe9mC,EAAG,IAAsB+2B,GAAY,IACpD+P,GAAe9mC,EAAG,GAAuB62B,GAAwB,QAlrIlE,SAAkBwB,GAEd,OAACA,EAAG2gB,UACH3gB,EAAG2gB,SAASiG,SApoZjB,SAAsBxpB,GACrB,OAAOA,GACN,KAAK,EAAG,KAAK,EAAM,IAAK,IAAK,IAAK,OAAQ,IAAK,OAAe,OAAA,EAE9D,QAAgB,OAAA,EAElB,CA+nZQgyB,CAAapvB,EAAG2gB,SAASiG,QAAQ99C,UAAY,OAF5B,OAGzB,CA6qIoDumD,CAASrvB,KAC5DyO,GAAe9mC,EAAG,GAA4B62B,IAAU,IACrD0vB,GAAmBzf,GAAA9mC,EAAG,IAAyB62B,IAAU,IAC5DiQ,GAAe9mC,EAAG,IAAuB+2B,GAAY,IAEnCgvB,GAAA/lD,EAAGq4B,EAAIj4B,GA/L1B,SAA0BgpB,EAAIqgB,EAAkBrpC,GAC3CqpC,GACH,CAAA,CAAC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,IAAI,CAAO,GAAgB,MAAMrY,SAAQ,SAASzrB,GAE5D,IAAA,IAAA5K,EAAI4K,EAAE,GAAI5K,GAAK4K,EAAE,KAAM5K,EAAe,MAAT0uC,EAAG1uC,IAA2B+rC,GAAA1d,EAAI,KAAqBoP,GAAaz9B,EAAG0uC,EAAG1uC,GAAIqF,GACrH,GACA,CA0LkBunD,CAAA3nD,EAAGq4B,EAAGmR,IAAKppC,GAxK7B,SAA6BgpB,EAAIhpB,GAChC,IAAA,IAAQrF,EAAI,EAAGA,EAAI,KAAMA,KAAkBquB,EAAI,IAAiBsP,GAAS,CAACzN,SAAS,EAAG2N,OAAM,GAAO,EAAGx4B,IACjGA,EAAAwpC,QAAQxY,SAAQ,SAASj0B,GAC7B2pC,GAAe1d,EAAI,IAAiBsP,GAASv7B,EAAG,EAAGiD,GACrD,GACA,CAoKCwnD,CAAoB5nD,EAAGI,GAEpBmmD,GAAmBzf,GAAA9mC,EAAG,IAAuB62B,IAAU,IACtD,IAAArf,EAAIxX,EAAEmd,MAENhS,EAAIyd,KAEL29B,GAAIzf,GAAe37B,EAAG,IAhqa1B,SAAuB5Q,GAIf,OAHHA,IAAOA,EAAAyX,GAAQ,IACjBzX,EAAAyR,YAAY,EAAG,GACfzR,EAAAyR,YAAY,EAAG,GACVzR,CACR,CA2pakCstD,IAI9BtB,GAAMnmD,EAAKk4C,SA/Tf,SAA6BlvB,EAAiB/lB,EAAiByO,GAC9D,IAAI3V,GAAiB2V,GAAS,IAAI9W,QAAU,EAC5C,GAAGmB,GAAO,KAAM,OAAO2qC,GAAe1d,EAAI/lB,EAAMyO,EAAS3V,GACzD,IAAIiC,EAAIiF,EACL,IAAAnI,MAAMkD,GAAN,CAGH,IAFA,IAAI0pD,EAAQh2C,EAAQg2C,OAAS,GAAIrjB,EAAO,EACpC1pC,EAAI,EAAGyH,EAAI,EACTA,GAAKslD,EAAMrjB,IAAS,OAAS,MAAajiC,GAAAslD,EAAMrjB,IAAS,KAAOA,IAClE,IAAAlqC,EAAI6uB,EAAGH,KAAK,GAKhB,IAJE1uB,EAAAyR,YAAY,EAAG5N,GACf7D,EAAAyR,YAAY,EAAGxJ,GACjB4mB,EAAGzZ,KAAKmC,EAAQlU,MAAM7C,EAAGA,EAAIyH,IACxBzH,GAAAyH,EACCzH,EAAIoB,GAAK,CAId,KAHI5B,EAAA6uB,EAAGH,KAAK,IACVjd,YAAY,EAAG,IACbxJ,EAAA,EACEA,GAAKslD,EAAMrjB,IAAS,OAAS,MAAajiC,GAAAslD,EAAMrjB,IAAS,KAAOA,IACpElqC,EAAAyR,YAAY,EAAGxJ,GACjB4mB,EAAGzZ,KAAKmC,EAAQlU,MAAM7C,EAAGA,EAAEyH,IAASzH,GAAAyH,CACtC,CAhBc,CAiBd,CA0SwBulD,CAAoB58C,EAAG,IAzzb/C,SAAmBm8B,GACd,IAAA34B,EAASqD,GAAQ,GACdrD,EAAA3C,YAAY,EAAGs7B,EAAIG,OACnB94B,EAAA3C,YAAY,EAAGs7B,EAAIK,QAE1B,IADA,IAAIxX,EAAO,GACHtsB,EAAI,EAAGA,EAAIyjC,EAAItsC,SAAU6I,EAAGssB,EAAKtsB,GAAKszB,GAAkCmQ,EAAIzjC,IACpF,IAAItJ,EAAI8C,EAAQ,CAACsR,GAAQpR,OAAO4yB,IAEzB,OADc51B,EAAAutD,MAAQ,CAACn5C,EAAO3T,QAAQuC,OAAO4yB,EAAKvzB,KAAI,SAASkI,GAAO,OAAOA,EAAI9J,MAAS,KAC1FT,CACR,CAgzbuDytD,CAAU5nD,EAAKk4C,UAGrExR,GAAe37B,EAAG,IACd,IAAAhO,EAAIgO,EAAEgS,MAEN1d,EAAImpB,KACJq/B,EAAO,EAAGpkD,EAAI,EAClB,IAAIA,EAAI,EAAGA,EAAIw0B,EAAG9M,WAAWvwB,SAAU6I,EAAGokD,IAAS1B,EAAK,GAAK,KAAOA,EAAK,EAAI,GAAKluB,EAAG9M,WAAW1nB,GAAG7I,OACnG,IAAI+V,EAAQyG,EAAExc,OAASitD,EAAO9qD,EAAEnC,OAChC,IAAI6I,EAAI,EAAGA,EAAIw0B,EAAG9M,WAAWvwB,SAAU6I,EAAG,CAEzCijC,GAAernC,EAAG,IAA0B64B,GAAkB,CAAC5P,IAAI3X,EAAOwnB,IADhD6uB,EAAQvjD,IAAO,CAAA,GAC2Cq7C,QAAQ,EAAG72C,GAAG,EAAG4H,KAAKooB,EAAG9M,WAAW1nB,IAAKzD,IACpH2Q,GAAAzT,EAAKuG,GAAG7I,MACnB,CAEK,IAAA0b,EAAIjX,EAAE0d,MACP,GAAA8qC,GAAQvxC,EAAE1b,OAAc,MAAA,IAAImI,MAAM,OAAS8kD,EAAO,OAASvxC,EAAE1b,QAEhE,IAAI0F,EAAM,GAIV,OAHG8W,EAAExc,QAAY0F,EAAAiP,KAAK6H,GACnBd,EAAE1b,QAAY0F,EAAAiP,KAAK+G,GACnBvZ,EAAEnC,QAAY0F,EAAAiP,KAAKxS,GACfE,EAAQqD,EAChB,CA8BA,SAASqhD,GAAe1pB,EAAiBj4B,GACxC,IAAA,IAAQrF,EAAI,EAAGA,GAAKs9B,EAAG9M,WAAWvwB,SAAUD,EAAG,CAC9C,IAAI6wB,EAAKyM,EAAG7M,OAAO6M,EAAG9M,WAAWxwB,IACjC,GAAI6wB,GAAOA,EAAG,QACFnB,GAAamB,EAAG,SACnB9vB,EAAEqB,EAAI,KACM,oBAAX+qD,SAA0BA,QAAQC,KAE9C,CAEK,IAAA5tD,EAAI6F,GAAQ,CAAE,EACX,OAAA7F,EAAEmvB,MAAQ,GAChB,KAAK,EAAG,KAAK,EAAU,OAvCzB,SAAyB2O,EAAiBj4B,GACrC,IAAA7F,EAAI6F,GAAQ,CAAE,EACd9C,EAAO,GAER+6B,IAAOA,EAAGmR,MACTnR,EAAAmR,IAAMvmB,GAAI/jB,IAEXm5B,GAAMA,EAAGmR,WACCngC,GAAegvB,EAAGmR,KAE5BjvC,EAAAm9C,OAAS31B,GAAUsW,EAAGmR,KAAMjvC,EAAEm9C,OAAOrf,EAAGmR,IAAI,QAAU,EACxDjvC,EAAEo9C,IAAMtf,EAAGmR,KAGVjvC,EAAA+9C,QAAkB,GAAqB/9C,EAAE+9C,QAAQ7Q,MAAQ,EAAGltC,EAAE+9C,QAAQ3Q,OAAS,EACjFygB,GAAe7tD,GAEfA,EAAEqvC,QAAU,GACG6N,GAAAl9C,EAAEqvC,QAAS,CAAE,EAAE,CAAC8N,OAAO,CAAC8J,QAAU,KAE7CnpB,EAAG3E,QAAO2E,EAAG3E,MAAQ,CAAE,GAE3B,IAAA,IAAQ34B,EAAI,EAAGA,EAAIs9B,EAAG9M,WAAWvwB,SAAUD,EAAGuC,EAAKA,EAAKtC,QAAUyrD,GAAe1rD,EAAGR,EAAG89B,GAEvF,OADA/6B,EAAKg5B,QAAQ6wB,GAAmB9uB,EAAI/6B,EAAM/C,IACnC8C,EAAQC,EAChB,CAcyB+qD,CAAgBhwB,EAAIj4B,GAC3C,KAAK,EAAG,KAAK,EAAG,KAAK,EAAU,OAAAylD,GAAgBxtB,EAAIj4B,GAEpD,MAAM,IAAI+C,MAAM,gBAAkB5I,EAAE22B,SAAW,YAChD,CA4DA,SAASo3B,GAAc18B,EAAkBjmB,EAAaiL,EAAcrW,GAG3D,IAFR,IAAIyG,EAAsB4qB,EAAG,YAAa,GACtC/D,EAAuB,GACnB1c,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAAG,CAEnC,IADI,IAAAi2B,EAAK,EAAGmnB,EAAK,EACT1kD,EAAI,EAAGA,EAAI7C,EAAEhG,SAAU6I,EAC3B,KAAA7C,EAAE6C,GAAGnH,EAAEiJ,EAAIiL,GAAK5P,EAAE6C,GAAGnH,EAAES,EAAIgO,GAC3BnK,EAAE6C,GAAG/H,EAAE6J,EAAIiL,GAAK5P,EAAE6C,GAAG/H,EAAEqB,EAAIgO,GAA3B,CACA,GAAAnK,EAAE6C,GAAGnH,EAAEiJ,EAAIiL,GAAK5P,EAAE6C,GAAGnH,EAAES,EAAIgO,EAAG,CAAOi2B,GAAA,EAAI,KAAM,CAC7CA,EAAApgC,EAAE6C,GAAG/H,EAAE6J,EAAI3E,EAAE6C,GAAGnH,EAAEiJ,EAAI,EAAQ4iD,EAAAvnD,EAAE6C,GAAG/H,EAAEqB,EAAI6D,EAAE6C,GAAGnH,EAAES,EAAI,EAAG,KAF3B,CAIlC,KAAGikC,EAAK,GAAR,CACA,IAAIO,EAAQ7X,GAAY,CAACnkB,EAAEiL,EAAEzT,EAAEgO,IAC3Boe,EAAOhvB,EAAEoxB,OAASC,EAAGhb,IAAI,IAAIzF,GAAKygB,EAAG+V,GAErCn/B,EAAK+mB,GAAkB,MAAVA,EAAKrrB,IAAeqrB,EAAKzS,KAAgByS,EAAK/mB,IAAM0oB,GAAY3B,GAAOA,EAAK/mB,IAAM,IAv+hBrF,IACNnH,QAAQipB,IAAU,SAASzjB,GAAK,OAAOwjB,GAAUxjB,EAAG,IAAIxF,QAAQ,MAAO,SAASA,QAAQqpB,IAAa,SAAShoB,GAAY,MAAA,OAAS,MAAMA,EAAEzB,WAAW,GAAGgI,SAAS,KAAKrF,OAAM,GAAM,SAs+hBhF,GACvGy2C,EAAM,CAAA,EACPjT,EAAK,IAAGiT,EAAGmU,QAAUpnB,GACrBmnB,EAAK,IAAGlU,EAAGoU,QAAUF,GACrBhuD,EAAEmuD,SAAclmD,EAAA,gCAAkCA,EAAI,UACjD+mB,IACP8qB,EAAG,UAAY9qB,GAAQA,EAAKnrB,GAAK,IACpB,MAAVmrB,EAAKrrB,IAAcm2C,EAAA,UAAY9qB,EAAKrrB,GAC1B,MAAVqrB,EAAKwB,IAAcspB,EAAA,UAAY9qB,EAAKwB,GACpCxB,EAAKzhB,GAAyC,MAAnCyhB,EAAKzhB,EAAEqrB,QAAU,KAAKh4B,OAAO,OAAe,YAAcouB,EAAKzhB,EAAEqrB,OAAQ,KAAO3wB,EAAI,SAEnG6xC,EAAGzN,IAAMrsC,EAAEqsC,IAAM,OAAS,IAAMjF,EAChC9Z,EAAGlY,KAAK8V,GAAU,KAAMjjB,EAAG6xC,GAhBhB,CAiBb,CAEC,MADe,OACGxsB,EAAGzqB,KAAK,IAAM,OACjC,CAmBA,SAASurD,GAAc/8B,EAAkBxrB,GACpC,IAAA7F,EAAI6F,GAAQ,CAAE,EACduO,EAAqB,MAAZpU,EAAEoU,OAAiBpU,EAAEoU,OAnBlB,sFAoBZ6oC,EAAqB,MAAZj9C,EAAEi9C,OAAiBj9C,EAAEi9C,OAnBpB,iBAoBV92C,EAAwB,CAACiO,GACzBhJ,EAAI8kB,GAAamB,EAAG,SACtBrxB,EAAAoxB,MAAQrvB,MAAMY,QAAQ0uB,GACxBlrB,EAAIiP,KAZL,SAA4Bic,EAAkBhb,EAAarW,GAE1D,MAD4B,GACjB6C,KAAK,IAAM,UAAY7C,GAAKA,EAAEqsC,GAAK,QAAUrsC,EAAEqsC,GAAK,IAAM,IAAM,GAC5E,CASUgiB,CAAmBh9B,EAAIjmB,EAAGpL,IACnC,IAAA,IAAQqW,EAAIjL,EAAEjJ,EAAEiJ,EAAGiL,GAAKjL,EAAE7J,EAAE6J,IAAKiL,IAAOjB,KAAK24C,GAAc18B,EAAIjmB,EAAGiL,EAAGrW,IAE9D,OADHmG,EAAAiP,KAAK,WAAa6nC,GACf92C,EAAItD,KAAK,GACjB,CAEA,SAASyrD,GAAcj9B,EAAkBzjB,EAAuBoL,GAC3D,IAAAnT,EAAOmT,GAAS,CAAE,EAElBu1C,EAAO,EAAGC,EAAO,EAClB,GAAe,MAAf3oD,EAAK2rB,OACP,GAAyB,iBAAf3rB,EAAK2rB,SAA2B3rB,EAAK2rB,WAC1C,CACA,IAAAC,EAAgD,iBAAf5rB,EAAK2rB,OAAqBvB,GAAYpqB,EAAK2rB,QAAU3rB,EAAK2rB,OAC/F+8B,EAAO98B,EAAQrmB,EAAGojD,EAAO/8B,EAAQ7uB,CACpC,CAGK,IAAAskC,EAA+Ct5B,EAAM6gD,qBAAqB,MAC1E9uB,EAAYz7B,KAAKgI,IAAIrG,EAAK85B,WAAW,IAAUuH,EAAKzmC,QACpD4uB,EAAkB,CAACltB,EAAE,CAACiJ,EAAE,EAAExI,EAAE,GAAGrB,EAAE,CAAC6J,EAAEmjD,EAAK3rD,EAAE4rD,IAC5C,GAAAn9B,EAAG,QAAS,CACd,IAAIK,EAAmBxB,GAAamB,EAAG,SACjChC,EAAAltB,EAAEiJ,EAAIlH,KAAKgI,IAAImjB,EAAMltB,EAAEiJ,EAAGsmB,EAAOvvB,EAAEiJ,GACnCikB,EAAAltB,EAAES,EAAIsB,KAAKgI,IAAImjB,EAAMltB,EAAES,EAAG8uB,EAAOvvB,EAAES,GACnCysB,EAAA9tB,EAAE6J,EAAIlH,KAAKiI,IAAIkjB,EAAM9tB,EAAE6J,EAAGsmB,EAAOnwB,EAAE6J,GACnCikB,EAAA9tB,EAAEqB,EAAIsB,KAAKiI,IAAIkjB,EAAM9tB,EAAEqB,EAAG8uB,EAAOnwB,EAAEqB,OACtC2rD,IAAkBl/B,EAAA9tB,EAAE6J,EAAImjD,EAAO78B,EAAOnwB,EAAE6J,EAAI,EACjD,CACK,IAAAo1C,EAA0B,GAAIkO,EAAO,EACrCxpB,EAA6B7T,EAAG,WAAaA,EAAG,SAAW,IAC3DC,EAAK,EAAGjb,EAAI,EAAGkb,EAAK,EAAG3gB,EAAI,EAAGi2B,EAAK,EAAGmnB,EAAK,EAE/C,IADI38B,EAAG,WAAaA,EAAA,SAAW,IACzBC,EAAK4V,EAAKzmC,QAAU4V,EAAIspB,IAAarO,EAAI,CAC1C,IAAAze,EAA8Bq0B,EAAK5V,GACnC,GAAAq9B,GAAsB97C,GAAM,CAC/B,GAAIhN,EAAKmlD,QAAS,SAClB9lB,EAAQ7uB,GAAK,CAAC6vB,QAAQ,EACzB,CACE,IAAI0oB,EAAiD/7C,EAAIg8C,SACzD,IAAIt9B,EAAK3gB,EAAI,EAAG2gB,EAAKq9B,EAAKnuD,SAAU8wB,EAAI,CACnC,IAAAzY,EAA+B81C,EAAKr9B,GACxC,IAAI1rB,EAAKmlD,UAAW2D,GAAsB71C,GAA1C,CACA,IAAInV,EAAgBmV,EAAIg2C,aAAa,UAAYh2C,EAAIi2C,aAAa,UAAYj2C,EAAIg2C,aAAa,KAAOh2C,EAAIi2C,aAAa,KAAOpkC,GAAW7R,EAAIk2C,WACzIx+B,EAAgB1X,EAAIi2C,aAAa,WAAaj2C,EAAIi2C,aAAa,KACnE,IAAIL,EAAO,EAAGA,EAAOlO,EAAO//C,SAAUiuD,EAAM,CACvC,IAAAnoD,EAAci6C,EAAOkO,GACtBnoD,EAAEpE,EAAES,GAAKgO,EAAI49C,GAAQjoD,EAAEpE,EAAEiJ,EAAIiL,EAAIk4C,GAAQl4C,EAAIk4C,GAAQhoD,EAAEhF,EAAE6J,IAASwF,EAAArK,EAAEhF,EAAEqB,EAAE,EAAI4rD,EAAaE,GAAA,EAChG,CAEGV,GAAMl1C,EAAIi2C,aAAa,YAAc,IAC/BloB,GAAO/tB,EAAIi2C,aAAa,YAAc,GAAK,GAAKf,EAAG,MAAU54C,KAAK,CAACjT,EAAE,CAACiJ,EAAEiL,EAAIk4C,EAAK3rD,EAAEgO,EAAI49C,GAAMjtD,EAAE,CAAC6J,EAAEiL,EAAIk4C,GAAQ1nB,GAAI,GAAK,EAAGjkC,EAAEgO,EAAI49C,GAAQR,GAAI,GAAK,KACvJ,IAAIhuD,EAAa,CAAC6D,EAAE,IAAKF,KACrBsrD,EAAgBn2C,EAAIi2C,aAAa,WAAaj2C,EAAIi2C,aAAa,MAAQ,GACnE,MAALprD,IACa,GAAZA,EAAElD,OAAaT,EAAE6D,EAAIorD,GAAM,IACtBppD,EAAKwR,KAA0B,GAAnB1T,EAAEuf,OAAOziB,QAAqB,KAANwuD,IAC9B,SAANtrD,EAAc3D,EAAI,CAAC6D,EAAE,IAAKF,GAAE,GACtB,UAANA,EAAe3D,EAAI,CAAC6D,EAAE,IAAKF,GAAE,GAC5BhD,MAAMkoB,GAASllB,IACfhD,MAAMwoB,GAAUxlB,GAAGoD,aAC3B/G,EAAK,CAAC6D,EAAE,IAAKF,EAAEwkB,GAAUxkB,IACrBkC,EAAKksB,YAAgB/xB,EAAA,CAAC6D,EAAE,IAAKF,EAAE+jB,GAAQ1nB,EAAE2D,KAC7C3D,EAAEwwB,EAAI3qB,EAAK8H,QAAUhJ,EAAU,KAJC3E,EAAA,CAAC6D,EAAE,IAAKF,EAAEklB,GAASllB,WAO1C,IAAR3D,EAAEwwB,GAAwB,MAALA,MAAaA,EAAIA,GAGzC,IAAIjjB,EAAI,GAAI2hD,EAAQp2C,EAAI21C,qBAAqB,KAC7C,GAAGS,GAASA,EAAMzuD,OAAQ,IAAA,IAAQ0uD,EAAQ,EAAGA,EAAQD,EAAMzuD,UAAoByuD,EAAMC,GAAOL,aAAa,SAC/C,MAAzDvhD,EAAI2hD,EAAMC,GAAOJ,aAAa,SAAcnuD,OAAO,MADiBuuD,GAGlE5hD,GAAoB,KAAfA,EAAE3M,OAAO,KAAaZ,EAAAuN,EAAK,CAAEqrB,OAAQrrB,IAC1C1H,EAAKurB,OAAaC,EAAGhb,EAAIk4C,KAAUl9B,EAAAhb,EAAIk4C,GAAQ,IAAIl9B,EAAGhb,EAAIk4C,GAAM39C,EAAI49C,GAAQxuD,GAC1EqxB,EAAG9B,GAAY,CAAC3sB,EAAEgO,EAAI49C,EAAMpjD,EAAEiL,EAAIk4C,KAAUvuD,EAC9CqvB,EAAM9tB,EAAEqB,EAAIgO,EAAI49C,IAAYn/B,EAAA9tB,EAAEqB,EAAIgO,EAAI49C,GACpC59C,GAAAo9C,CAnC2C,CAoCnD,GACI33C,CACJ,CAKQ,OAJJmqC,EAAO//C,SAAQ4wB,EAAG,YAAcA,EAAG,YAAc,IAAIruB,OAAOw9C,IACzDnxB,EAAA9tB,EAAE6J,EAAIlH,KAAKiI,IAAIkjB,EAAM9tB,EAAE6J,EAAGiL,EAAI,EAAIk4C,GACrCl9B,EAAA,QAAUlB,GAAad,GACvBhZ,GAAKspB,IAActO,EAAA,YAAclB,IAAcd,EAAM9tB,EAAE6J,EAAI87B,EAAKzmC,OAAO6wB,EAAGjb,EAAE,EAAIk4C,EAAKl/B,KACjFgC,CACR,CAEA,SAAS+9B,GAAgBxhD,EAAuBoL,GAGxC,OAAAs1C,IAFIt1C,GAAS,CAAE,GACMoY,MAAS,GAAe,CAAA,EAC3BxjB,EAAOoL,EACjC,CAMA,SAAS21C,GAAsBU,GAC9B,IAAIrE,EAAqB,GACrBsE,EAOL,SAAyCD,GAExC,OAAGA,EAAQE,cAAcC,aAA6E,mBAAvDH,EAAQE,cAAcC,YAAYC,iBAAwCJ,EAAQE,cAAcC,YAAYC,iBAE5H,mBAArBA,iBAAwCA,iBAC3C,IACR,CAbwCC,CAAgCL,GAGvE,OAFGC,IAA8BtE,EAAAsE,EAAmBD,GAASM,iBAAiB,YAC1E3E,IAASA,EAAUqE,EAAQhxB,OAASgxB,EAAQhxB,MAAM2sB,SACnC,SAAZA,CACR,CAmkBA,IAAI4E,GAA8E,WACjF,IAAIC,EAAgB,CACnB,yBACC,oEACC,kBACA,6CACA,kBACA,6CACD,uBACD,2BACChtD,KAAK,IAEH0U,EAAU,2BAA6B0T,GAAW,CACrD,eAAkB,mDAClB,cAAkB,kDAClB,cAAkB,kDAClB,aAAkB,iDAClB,aAAkB,oDAClB,WAAkB,8DAClB,cAAkB,+BAClB,WAAkB,mCAClB,eAAkB,sDAClB,YAAkB,2DAClB,WAAkB,+CAClB,iBAAkB,QACd,IAAM4kC,EAAgB,4BAE3B,OAAO,WACN,OAAOhmC,GAAatS,CACpB,CACF,CA9BkF,GA+B9Eu4C,GAA+E,WAE9E,IAQAC,EAAgB,mCAEhBtK,EAAW,SAASp0B,EAAIyM,EAAiBt9B,GAE5C,IAAIR,EAAsB,GACxBA,EAAAoV,KAAK,kCAAoC6U,GAAU6T,EAAG9M,WAAWxwB,IAAM,+BACrE,IAAA6V,EAAE,EAAEzF,EAAE,EAAGye,EAAQa,GAAamB,EAAG,SAAS,MAC1C80B,EAAwB90B,EAAG,YAAc,GAAI+0B,EAAK,EAClDh1B,EAAQrvB,MAAMY,QAAQ0uB,GACvB,GAAAA,EAAG,SACD,IAAAzgB,EAAI,EAAGA,GAAKye,EAAM9tB,EAAEqB,IAAKgO,EAAK5Q,EAAAoV,KAAK,+BAAiCic,EAAG,SAASzgB,GAAK,wBAA0BygB,EAAG,SAASzgB,GAAGo/C,IAAM,IAAM,IAAM,4BAErJ,IAAIxpD,EAAI,GAAIypD,EAAO5+B,EAAG,UAAU,GAChC,IAAIhb,EAAI,EAAGA,EAAIgZ,EAAMltB,EAAEiJ,IAAKiL,EACvB7P,EAAAypD,EAAK55C,GAAK,wBAA0B45C,EAAK55C,GAAG25C,IAAM,IAAM,GAC1DhwD,EAAAoV,KAAK,2BAA6B5O,EAAI,yBAEzC,KAAM6P,GAAKgZ,EAAM9tB,EAAE6J,IAAKiL,EAAG,CAGtB,IAFA7P,EAAAypD,EAAK55C,GAAK,wBAA0B45C,EAAK55C,GAAG25C,IAAM,IAAM,GAC1DhwD,EAAAoV,KAAK,2BAA6B5O,EAAI,OACpCoK,EAAE,EAAGA,EAAIye,EAAMltB,EAAES,IAAKgO,EAAK5Q,EAAAoV,KAAK26C,GACpC,KAAMn/C,GAAKye,EAAM9tB,EAAEqB,IAAKgO,EAAG,CAC1B,IAAI61C,GAAO,EAAO/vC,EAAK,CAAE,EAAEw5C,EAAQ,GACnC,IAAI9J,EAAK,EAAGA,GAAMD,EAAK1lD,SAAU2lD,EAChC,KAAGD,EAAKC,GAAIjkD,EAAES,EAAIgO,GACfu1C,EAAKC,GAAIjkD,EAAEiJ,EAAIiL,GACf8vC,EAAKC,GAAI7kD,EAAEqB,EAAIgO,GACfu1C,EAAKC,GAAI7kD,EAAE6J,EAAIiL,GAAlB,CACG8vC,EAAKC,GAAIjkD,EAAES,GAAKgO,GAAKu1C,EAAKC,GAAIjkD,EAAEiJ,GAAKiL,IAAUowC,GAAA,GAC/C/vC,EAAA,gCAAmCyvC,EAAKC,GAAI7kD,EAAEqB,EAAIujD,EAAKC,GAAIjkD,EAAES,EAAI,EACjE8T,EAAA,6BAAmCyvC,EAAKC,GAAI7kD,EAAE6J,EAAI+6C,EAAKC,GAAIjkD,EAAEiJ,EAAI,EACpE,KAJqB,CAMtB,GAAGq7C,EAAQzmD,EAAEoV,KAhCO,+CAgCpB,CACA,IAAIopB,EAAMjP,GAAY,CAACnkB,EAAEiL,EAAGzT,EAAEgO,IAAKoe,EAAOoC,GAASC,EAAGhb,IAAI,IAAIzF,GAAIygB,EAAGmN,GAClE,GAAAxP,GAAQA,EAAK5hB,IACfsJ,EAAG,iBAAmBuT,IA5pOlB,OA4pO+C+E,EAAK5hB,EA5pOzCtM,QAAQi0C,GAAW,iBAAiBj0C,QAAQ,SAAS,MAE/DA,QAAQ,KAAM,KAAKA,QAAQ,KAAK,MA2pOlCkuB,EAAKoO,GACJpO,EAAKoO,EAAE/5B,MAAM,EAAGm7B,EAAI/9B,SAAW+9B,GAAK,CAClC,IAAA2xB,EAAQjgC,GAAalB,EAAKoO,GAC9B1mB,EAAG,uCAA0Cy5C,EAAM5uD,EAAEqB,EAAIutD,EAAMhuD,EAAES,EAAI,EACrE8T,EAAG,oCAA0Cy5C,EAAM5uD,EAAE6J,EAAI+kD,EAAMhuD,EAAEiJ,EAAI,CAC5E,CAGI,GAAI4jB,EAAJ,CACA,OAAOA,EAAKnrB,GACX,IAAK,IACKqsD,EAAAlhC,EAAKrrB,EAAI,OAAS,QAC3B+S,EAAG,qBAAuB,UAC1BA,EAAG,wBAA2BsY,EAAKrrB,EAAI,OAAS,QAChD,MACD,IAAK,IACJusD,EAASlhC,EAAK/mB,GAAGvI,OAAOsvB,EAAKrrB,GAAG,GAChC+S,EAAG,qBAAuB,QACvBA,EAAA,gBAAmBsY,EAAKrrB,GAAG,EAC9B,MACD,IAAK,IAAK,IAAK,MACdusD,EAAkB,MAAVlhC,EAAKrrB,EAAY,GAAKqrB,EAAKrrB,EACnC+S,EAAG,qBAAuB,SAC1B,MACD,IAAK,IACJw5C,EAASlhC,EAAK/mB,GAAIkgB,GAAU6G,EAAKrrB,GAAGynB,cACpC1U,EAAG,qBAAuB,OAC1BA,EAAG,qBAAwByR,GAAU6G,EAAKrrB,GAAGynB,cAC7C1U,EAAG,oBAAsB,MACzB,MAED,QAAS1W,EAAEoV,KAAK26C,GAAgB,SAE7B,IAAAK,EA7ECnmC,GA6EqBimC,GA5E1BpvD,QAAQ,QAAQ,SAASgJ,GAAW,MAAA,mBAAmBA,EAAGrJ,OAAO,KAAM,IACvEK,QAAQ,MAAO,eACfA,QAAQ,MAAO,qBACfA,QAAQ,KAAM,aAAaA,QAAQ,KAAM,aA0EzC,GAAGkuB,EAAKzhB,GAAKyhB,EAAKzhB,EAAEqrB,OAAQ,CACvB,IAAAy3B,EAAOrhC,EAAKzhB,EAAEqrB,OAGG,MAFdy3B,EAAkB,KAAlBA,EAAKzvD,OAAO,GAAY,IAAoByvD,EAAKhtD,MAAM,GArrOzDvC,QAAQ,KAAK,KAqrOkDuvD,GAE5DzvD,OAAO,IAAcyvD,EAAK3mD,MAAM,WAAU2mD,EAAO,MAAQA,GACxDD,EAAAllC,GAAU,SAAUklC,EAAQ,CAAC,aAAcC,EAAKvvD,QAAQ,KAAM,UAC5E,CACId,EAAEoV,KAAK,aAAe8V,GAAU,mBAAoBA,GAAU,SAAUklC,EAAQ,CAAE,GAAG15C,GAAM,KAjC/C,MAAhC1W,EAAEoV,KAAK26C,EAZ2B,CA8ClD,CACG/vD,EAAEoV,KAAK,+BACV,CAES,OADPpV,EAAEoV,KAAK,0BACApV,EAAE6C,KAAK,GACd,EA6DM,OAAA,SAAai7B,EAAIj4B,GACnB,IAAA7F,EAAI,CAAC6pB,IAELq8B,EAAOj7B,GAAW,CACrB,eAAsB,mDACtB,cAAsB,kDACtB,cAAsB,kDACtB,aAAsB,iDACtB,aAAsB,oDACtB,WAAsB,8DACtB,cAAsB,+BACtB,WAAsB,mCACtB,aAAsB,iDACtB,eAAsB,sDACtB,qBAAsB,yDACtB,YAAsB,2DACtB,cAAsB,kDACtB,aAAsB,iDACtB,aAAsB,qCACtB,aAAsB,iDACtB,eAAsB,mDACtB,YAAsB,oCACtB,aAAsB,oCACtB,aAAsB,kCACtB,YAAsB,oCACtB,eAAsB,gCACtB,YAAsB,mCACtB,YAAsB,4CACtB,cAAsB,8CACtB,YAAsB,oCACtB,WAAsB,+CACtB,cAAsB,+BACtB,cAAsB,sCACtB,iBAAsB,mCACtB,gBAAsB,kCACtB,gBAAsB,uEACtB,cAAsB,uEACtB,cAAsB,mEACtB,cAAsB,qEACtB,cAAsB,kCACtB,iBAAsB,QAGnBqlC,EAAOrlC,GAAW,CACrB,eAAmB,mDACnB,kBAAmB,mDAGA,QAAjBplB,EAAK8wB,UACP32B,EAAEoV,KAAK,mBAAqB8wC,EAAOoK,EAAO,OAC1CtwD,EAAEoV,KAAK4jB,KAAiBl4B,QAAQ,wBAAyB,iBAEnDd,EAAEoV,KAAK,2BAA6B8wC,EAAQ,OA/GnB,SAASlmD,EAAqB89B,GAC9D99B,EAAEoV,KAAK,gCAEPpV,EAAEoV,KAAK,0EACPpV,EAAEoV,KAAK,4CACPpV,EAAEoV,KAAK,qCACPpV,EAAEoV,KAAK,0CACPpV,EAAEoV,KAAK,qCACPpV,EAAEoV,KAAK,uBACPpV,EAAEoV,KAAK,4BAGP,IAAIm7C,EAAO,EACRzyB,EAAA9M,WAAW3uB,KAAI,SAASgN,GAAY,OAAAyuB,EAAG7M,OAAO5hB,EAAG,IAAIwnB,SAAQ,SAASxF,GACxE,GAAIA,GACDA,EAAG,SACL,IAAA,IAAQzgB,EAAI,EAAGA,EAAIygB,EAAG,SAAS5wB,SAAUmQ,EAAM,GAAAygB,EAAG,SAASzgB,GAAI,CAC9D,IAAI4/C,EAASn/B,EAAG,SAASzgB,GACtB,GAAgB,MAAhB4/C,EAAO1yD,OAA+B,MAAd0yD,EAAOzpB,KAA6B,MAAdypB,EAAO3wB,IAAa,SACrEsG,GAAYqqB,GACZA,EAAOR,IAAMO,EACb,IAAItoD,EAAIopB,EAAG,SAASzgB,GAAGm2B,IAAM,KAC3B/mC,EAAAoV,KAAK,gCAAkCm7C,EAAO,oCAC9CvwD,EAAAoV,KAAK,gFAAkFnN,EAAI,SAC7FjI,EAAEoV,KAAK,wBACLm7C,CACP,CAEA,IAGE,IAAI7mC,EAAO,EACRoU,EAAA9M,WAAW3uB,KAAI,SAASgN,GAAY,OAAAyuB,EAAG7M,OAAO5hB,EAAG,IAAIwnB,SAAQ,SAASxF,GACxE,GAAIA,GACDA,EAAG,SACL,IAAA,IAAQhb,EAAI,EAAGA,EAAIgb,EAAG,SAAS5wB,SAAU4V,EAAM,GAAAgb,EAAG,SAAShb,GAAI,CAC9Dgb,EAAG,SAAShb,GAAG25C,IAAMtmC,EACrB,IAAInN,EAAI8U,EAAG,SAAShb,GAAGgwB,IAAM,KAC3BrmC,EAAAoV,KAAK,gCAAkCsU,EAAO,iCAC9C1pB,EAAAoV,KAAK,2EAA6EmH,EAAI,SACxFvc,EAAEoV,KAAK,wBACLsU,CACP,CAEA,IAGE1pB,EAAEoV,KAAK,wFACPpV,EAAEoV,KAAK,kFACPpV,EAAEoV,KAAK,sBAGPpV,EAAEoV,KAAK,+HAIPpV,EAAEoV,KAAK,gCACP,CAwDAq7C,CAA2BzwD,EAAG89B,GAC9B99B,EAAEoV,KAAK,qBACPpV,EAAEoV,KAAK,8BACC,IAAA,IAAA5U,EAAI,EAAGA,GAAKs9B,EAAG9M,WAAWvwB,SAAUD,EAAKR,EAAAoV,KAAKqwC,EAAS3nB,EAAG7M,OAAO6M,EAAG9M,WAAWxwB,IAAKs9B,EAAIt9B,IAKzF,OAJPR,EAAEoV,KAAK,+BACPpV,EAAEoV,KAAK,sBACa,QAAjBvP,EAAK8wB,SAAoB32B,EAAEoV,KAAK,sBAC9BpV,EAAEoV,KAAK,8BACLpV,EAAE6C,KAAK,GACd,CACF,CA3NmF,GA6NnF,SAAS6tD,GAAU5yB,EAAYj4B,GAC9B,GAAoB,QAAjBA,EAAK8wB,SAA2B,OAAAm5B,GAAkBhyB,EAAIj4B,GAEzD,IAAI0jB,EAAMK,KACNxc,EAAI,GAEJujD,EAAqC,GACrCC,EAAkC,GAiC/B,OA7BMtnC,GAAAC,EADTnc,EAAA,WACiB,kDAIrBkc,GAAaC,EADTnc,EAAA,cACiB0iD,GAAkBhyB,EAAIj4B,IAC3C8qD,EAASv7C,KAAK,CAAChI,EAAG,aAClBwjD,EAAIx7C,KAAK,CAAChI,EAAG,gBAIbkc,GAAaC,EADTnc,EAAA,aACiBwiD,GAAiB9xB,EAAIj4B,IAC1C8qD,EAASv7C,KAAK,CAAChI,EAAG,aAClBwjD,EAAIx7C,KAAK,CAAChI,EAAG,eAIAkc,GAAAC,EADTnc,EAAA,WACiByc,GAAamP,MAClC23B,EAASv7C,KAAK,CAAChI,EAAG,aAClBwjD,EAAIx7C,KAAK,CAAChI,EAAG,iBAIbkc,GAAaC,EADTnc,EAAA,eAhrgBL,SAAmBwjD,GACd,IARkBhlD,EAAiB4G,EAQnCxS,EAAI,CAAC6pB,IACT7pB,EAAEoV,KAAK,uEACP,IAAA,IAAQ5U,EAAI,EAAGA,GAAKowD,EAAInwD,SAAUD,EACjCR,EAAEoV,KAAK0jB,GAAe83B,EAAIpwD,GAAG,GAAIowD,EAAIpwD,GAAG,KACtCR,EAAAoV,MAZmBxJ,EAYA,GAZiB4G,EAYdo+C,EAAIpwD,GAAG,GAXzB,CACN,iCAAmCoL,EAAO,OAC1C,iGAAmG4G,EAAO,QAC1G,0BACC3P,KAAK,MAWA,OAFP7C,EAAEoV,KAAK0jB,GAAe,GAAG,WAAY,QACrC94B,EAAEoV,KAAK,cACApV,EAAE6C,KAAK,GACf,CAuqgBsBguD,CAAUD,IAC/BD,EAASv7C,KAAK,CAAChI,EAAG,wBAIlBkc,GAAaC,EADTnc,EAAA,wBA7sgBL,SAAwBujD,GACnB,IAAA3wD,EAAI,CAAC6pB,IACT7pB,EAAEoV,KAAK,oHACPpV,EAAEoV,KAAK,iJACC,IAAA,IAAA5U,EAAI,EAAGA,EAAImwD,EAASlwD,SAAUD,IAAK4U,KAAK,8CAAgDu7C,EAASnwD,GAAG,GAAK,0BAA4BmwD,EAASnwD,GAAG,GAAK,SAEvJ,OADPR,EAAEoV,KAAK,wBACApV,EAAE6C,KAAK,GACf,CAusgBsBiuD,CAAeH,IAE7BpnC,CACR;6DAGA,SAASwnC,GAAeC,GACtB,OAAO,IAAIC,SAASD,EAAME,OAAQF,EAAMG,WAAYH,EAAMI,WAC5D,CAIA,SAASC,GAAM9mD,GACb,MAA6B,oBAAf0a,aAA6B,IAAIA,aAAcC,OAAO3a,GAAOrI,EAAIijB,GAAU5a,GAC3F,CAWA,SAAS+mD,GAASC,GAChB,IAAI3vD,EAAM2vD,EAAIC,QAAO,SAASC,EAAKhyD,GACjC,OAAOgyD,EAAMhyD,EAAEgB,MAChB,GAAE,GACC0F,EAAM,IAAIrE,WAAWF,GACrB8c,EAAM,EAKH,OAJH6yC,EAAA16B,SAAQ,SAAS66B,GACfvrD,EAAAhD,IAAIuuD,EAAIhzC,GACZA,GAAOgzC,EAAGjxD,MACd,IACS0F,CACT,CAsBA,SAASwrD,GAAenwD,EAAKowD,GAC3B,IAAIrkD,EAAIqkD,EAAMA,EAAI,GAAK,EACnBlyC,EAAe,IAATle,EAAI+L,GACdskD,EACM,GAAArwD,EAAI+L,MAAQ,IAAK,CAEf,GADImS,IAAS,IAATle,EAAI+L,KAAa,EACrB/L,EAAI+L,KAAO,IACP,MAAAskD,EAEJ,GADInyC,IAAS,IAATle,EAAI+L,KAAa,GACrB/L,EAAI+L,KAAO,IACP,MAAAskD,EAEJ,GADInyC,IAAS,IAATle,EAAI+L,KAAa,GACrB/L,EAAI+L,KAAO,IACP,MAAAskD,EAGJ,GAFJnyC,IAAiB,IAATle,EAAI+L,IAAYrJ,KAAKC,IAAI,EAAG,MAClCoJ,EACE/L,EAAI+L,KAAO,IACP,MAAAskD,EAGJ,GAFJnyC,IAAiB,IAATle,EAAI+L,IAAYrJ,KAAKC,IAAI,EAAG,MAClCoJ,EACE/L,EAAI+L,KAAO,IACP,MAAAskD,EAGJ,GAFJnyC,IAAiB,IAATle,EAAI+L,IAAYrJ,KAAKC,IAAI,EAAG,MAClCoJ,EACE/L,EAAI+L,KAAO,IACP,MAAAskD,CACd,CAGS,OAFHD,IACFA,EAAI,GAAKrkD,GACJmS,CACT,CACA,SAASoyC,GAAenuD,GAClB,IAAA+b,EAAM,IAAI5d,WAAW,GACrB4d,EAAA,GAAS,IAAJ/b,EACT,IAAIkN,EAAI,EACRmB,EACE,GAAIrO,EAAI,IAAK,CAIX,GAHI+b,EAAA7O,EAAI,IAAM,IACV6O,EAAA7O,GAAKlN,GAAK,EAAI,MAChBkN,EACElN,GAAK,MACD,MAAAqO,EAIR,GAHI0N,EAAA7O,EAAI,IAAM,IACV6O,EAAA7O,GAAKlN,GAAK,GAAK,MACjBkN,EACElN,GAAK,QACD,MAAAqO,EAIR,GAHI0N,EAAA7O,EAAI,IAAM,IACV6O,EAAA7O,GAAKlN,GAAK,GAAK,MACjBkN,EACElN,GAAK,UACD,MAAAqO,EAIR,GAHI0N,EAAA7O,EAAI,IAAM,IACd6O,EAAI7O,GAAKlN,EAAI,MAAQ,GAAK,MACxBkN,EACElN,GAAK,YACD,MAAAqO,EAIR,GAHI0N,EAAA7O,EAAI,IAAM,IACd6O,EAAI7O,GAAKlN,EAAI,QAAU,GAAK,MAC1BkN,EACElN,GAAK,cACD,MAAAqO,EACJ0N,EAAA7O,EAAI,IAAM,IACd6O,EAAI7O,GAAKlN,EAAI,WAAa,GAAK,MAC7BkN,CACR,CACS,OAAA6O,EAAIrc,MAAM,EAAGwN,EACtB,CACA,SAASkhD,GAAcvwD,GACrB,IAAI+L,EAAI,EAAGykD,EAAe,IAATxwD,EAAI+L,GACrBskD,EACM,GAAArwD,EAAI+L,MAAQ,IAAK,CAEf,GADIykD,IAAS,IAATxwD,EAAI+L,KAAa,EACrB/L,EAAI+L,KAAO,IACP,MAAAskD,EAEJ,GADIG,IAAS,IAATxwD,EAAI+L,KAAa,GACrB/L,EAAI+L,KAAO,IACP,MAAAskD,EAEJ,GADIG,IAAS,IAATxwD,EAAI+L,KAAa,GACrB/L,EAAI+L,KAAO,IACP,MAAAskD,EACAG,IAAS,IAATxwD,EAAI+L,KAAa,EAC/B,CACS,OAAAykD,CACT,CACA,SAASC,GAAczwD,GAErB,IADA,IAAI2E,EAAM,GAAIyrD,EAAM,CAAC,GACdA,EAAI,GAAKpwD,EAAIf,QAAQ,CACtB,IAKA+oB,EALA9K,EAAMkzC,EAAI,GACVM,EAAMP,GAAenwD,EAAKowD,GAC1B9oD,EAAa,EAANopD,EAEPtwD,EAAM,EAEV,GAAW,IAHLswD,EAAAhuD,KAAKwB,MAAMwsD,EAAM,IAIrB,MACF,OAAQppD,GACN,KAAK,EAGD,IADI,IAAAyE,EAAIqkD,EAAI,GACLpwD,EAAIowD,EAAI,OAAS,MAExBpoC,EAAMhoB,EAAI6B,MAAMkK,EAAGqkD,EAAI,IAEzB,MACF,KAAK,EACGhwD,EAAA,EACA4nB,EAAAhoB,EAAI6B,MAAMuuD,EAAI,GAAIA,EAAI,GAAKhwD,GACjCgwD,EAAI,IAAMhwD,EACV,MACF,KAAK,EACGA,EAAA,EACA4nB,EAAAhoB,EAAI6B,MAAMuuD,EAAI,GAAIA,EAAI,GAAKhwD,GACjCgwD,EAAI,IAAMhwD,EACV,MACF,KAAK,EACGA,EAAA+vD,GAAenwD,EAAKowD,GACpBpoC,EAAAhoB,EAAI6B,MAAMuuD,EAAI,GAAIA,EAAI,GAAKhwD,GACjCgwD,EAAI,IAAMhwD,EACV,MAGF,QACE,MAAM,IAAIgH,MAAM,WAAW5F,OAAO8F,EAAM,eAAe9F,OAAOkvD,EAAK,eAAelvD,OAAO0b,IAE7F,IAAI/a,EAAI,CAAEjB,KAAM8mB,EAAK1gB,QACL,MAAZ3C,EAAI+rD,GACF/rD,EAAA+rD,GAAO,CAACvuD,GAERwC,EAAA+rD,GAAK98C,KAAKzR,EACpB,CACS,OAAAwC,CACT,CACA,SAASgsD,GAAcC,GACrB,IAAIjsD,EAAM,GAWV,OAVMisD,EAAAv7B,SAAQ,SAAS4I,EAAOh2B,GACtBg2B,EAAA5I,SAAQ,SAASw7B,GAChBA,EAAK3vD,OAEVyD,EAAIiP,KAAK08C,GAAqB,EAANroD,EAAU4oD,EAAKvpD,OACtB,GAAbupD,EAAKvpD,MACP3C,EAAIiP,KAAK08C,GAAeO,EAAK3vD,KAAKjC,SAChC0F,EAAAiP,KAAKi9C,EAAK3vD,MACpB,GACA,IACS4uD,GAASnrD,EAClB,CAMA,SAASmsD,GAAe9wD,GAGtB,IAFI,IAAA+wD,EACApsD,EAAM,GAAIyrD,EAAM,CAAC,GACdA,EAAI,GAAKpwD,EAAIf,QAAQ,CACtB,IAAAmB,EAAM+vD,GAAenwD,EAAKowD,GAC1BY,EAAKP,GAAczwD,EAAI6B,MAAMuuD,EAAI,GAAIA,EAAI,GAAKhwD,IAClDgwD,EAAI,IAAMhwD,EACV,IAAI4nB,EAAM,CACR6iB,GAAI0lB,GAAcS,EAAG,GAAG,GAAG9vD,MAC3B+vD,SAAU,IAEZD,EAAG,GAAG37B,SAAQ,SAAS1a,GACjB,IAAAiqC,EAAK6L,GAAc91C,EAAEzZ,MACrBgwD,EAAKX,GAAc3L,EAAG,GAAG,GAAG1jD,MAChC8mB,EAAIipC,SAASr9C,KAAK,CAChB4yB,KAAMoe,EACN1jD,KAAMlB,EAAI6B,MAAMuuD,EAAI,GAAIA,EAAI,GAAKc,KAEnCd,EAAI,IAAMc,CAChB,KACwB,OAAfH,EAAKC,EAAG,SAAc,EAASD,EAAG,MACjC/oC,EAAAmpC,MAAQZ,GAAcS,EAAG,GAAG,GAAG9vD,QAAU,EAAI,GACnDyD,EAAIiP,KAAKoU,EACb,CACS,OAAArjB,CACT,CACA,SAASysD,GAAeC,GACtB,IAAI9vD,EAAO,GAoBX,OAnBI8vD,EAAAh8B,SAAQ,SAASi8B,GACnB,IAAIN,EAAK,GACNA,EAAA,GAAK,CAAC,CAAE9vD,KAAMovD,GAAegB,EAAGzmB,IAAKvjC,KAAM,IAC3C0pD,EAAA,GAAK,GACQ,MAAZM,EAAGH,QACLH,EAAG,GAAK,CAAC,CAAE9vD,KAAMovD,MAAkBgB,EAAGH,OAAQ7pD,KAAM,KACtD,IAAIiqD,EAAS,GACVD,EAAAL,SAAS57B,SAAQ,SAASuvB,GACpB2M,EAAA39C,KAAKgxC,EAAG1jD,MACf0jD,EAAGpe,KAAK,GAAK,CAAC,CAAEl/B,KAAM,EAAGpG,KAAMovD,GAAe1L,EAAG1jD,KAAKjC,UACnD+xD,EAAA,GAAGp9C,KAAK,CAAE1S,KAAMyvD,GAAc/L,EAAGpe,MAAOl/B,KAAM,GACvD,IACQ,IAAAkqD,EAAYb,GAAcK,GAC9BzvD,EAAKqS,KAAK08C,GAAekB,EAAUvyD,SACnCsC,EAAKqS,KAAK49C,GACHD,EAAAl8B,SAAQ,SAASo8B,GACf,OAAAlwD,EAAKqS,KAAK69C,EACvB,GACA,IACS3B,GAASvuD,EAClB,CACA,SAASmwD,GAAmBpqD,EAAMtH,GAChC,GAAY,GAARsH,EACF,MAAM,IAAIF,MAAM,gCAAgC5F,OAAO8F,IAIzD,IAHI,IAAA8oD,EAAM,CAAC,GACPlyC,EAAMiyC,GAAenwD,EAAKowD,GAC1BuB,EAAS,GACNvB,EAAI,GAAKpwD,EAAIf,QAAQ,CAC1B,IAAIs4B,EAAoB,EAAdv3B,EAAIowD,EAAI,IAClB,GAAW,GAAP74B,EAAJ,CAqBM,IAAAphB,EAAS,EAAGlX,EAAS,EAgBzB,GAfW,GAAPs4B,GACFt4B,EAAkC,GAAxBe,EAAIowD,EAAI,KAAO,EAAI,GAC7Bj6C,GAA0B,IAAhBnW,EAAIowD,EAAI,QAAgB,EACxBj6C,GAAAnW,EAAIowD,EAAI,QAElBnxD,EAAgC,GAAtBe,EAAIowD,EAAI,OAAS,GAChB,GAAP74B,GACOphB,EAAAnW,EAAIowD,EAAI,IAAMpwD,EAAIowD,EAAI,GAAK,IAAM,EAC1CA,EAAI,IAAM,IAEAj6C,GAAAnW,EAAIowD,EAAI,IAAMpwD,EAAIowD,EAAI,GAAK,IAAM,EAAIpwD,EAAIowD,EAAI,GAAK,IAAM,GAAKpwD,EAAIowD,EAAI,GAAK,IAAM,MAAQ,EAClGA,EAAI,IAAM,IAGLuB,EAAA,CAAC7B,GAAS6B,IACL,GAAVx7C,EACI,MAAA,IAAI/O,MAAM,oBACd,GAAA+O,EAASw7C,EAAO,GAAG1yD,OACf,MAAA,IAAImI,MAAM,gCAClB,GAAInI,GAAUkX,EAGZ,IAFAw7C,EAAO/9C,KAAK+9C,EAAO,GAAG9vD,OAAOsU,IACnBlX,GAAAkX,EACHlX,GAAU0yD,EAAOA,EAAO1yD,OAAS,GAAGA,QACzC0yD,EAAO/9C,KAAK+9C,EAAOA,EAAO1yD,OAAS,IACnCA,GAAU0yD,EAAOA,EAAO1yD,OAAS,GAAGA,OAGjC0yD,EAAA/9C,KAAK+9C,EAAO,GAAG9vD,OAAOsU,GAASA,EAASlX,GACrD,KAlDI,CACE,IAAImB,EAAMJ,EAAIowD,EAAI,OAAS,EAC3B,GAAIhwD,EAAM,KACNA,MACC,CACH,IAAIgB,EAAIhB,EAAM,GACRA,EAAAJ,EAAIowD,EAAI,IACVhvD,EAAI,IACNhB,GAAOJ,EAAIowD,EAAI,GAAK,IAAM,GACxBhvD,EAAI,IACNhB,GAAOJ,EAAIowD,EAAI,GAAK,IAAM,IACxBhvD,EAAI,IACNhB,GAAOJ,EAAIowD,EAAI,GAAK,IAAM,IACnBhwD,KAAA,EACTA,IACAgwD,EAAI,IAAMhvD,CAClB,CACauwD,EAAA/9C,KAAK5T,EAAI6B,MAAMuuD,EAAI,GAAIA,EAAI,GAAKhwD,IACvCgwD,EAAI,IAAMhwD,CAgChB,CACA,CACM,IAAA5B,EAAIsxD,GAAS6B,GACjB,GAAInzD,EAAES,QAAUif,EACR,MAAA,IAAI9W,MAAM,sBAAsB5F,OAAOhD,EAAES,OAAQ,QAAQuC,OAAO0c,IACjE,OAAA1f,CACT,CACA,SAASozD,GAAoB5xD,GAGpB,IAFP,IAAI2E,EAAM,GACNoH,EAAI,EACDA,EAAI/L,EAAIf,QAAQ,CACjB,IAAAoD,EAAIrC,EAAI+L,KACR3L,EAAMJ,EAAI+L,GAAK/L,EAAI+L,EAAI,IAAM,EAAI/L,EAAI+L,EAAI,IAAM,GAC9CA,GAAA,EACDpH,EAAAiP,KAAK89C,GAAmBrvD,EAAGrC,EAAI6B,MAAMkK,EAAGA,EAAI3L,KAC3C2L,GAAA3L,CACT,CACE,GAAI2L,IAAM/L,EAAIf,OACN,MAAA,IAAImI,MAAM,sCAClB,OAAO0oD,GAASnrD,EAClB,CACA,SAASktD,GAAkB7xD,GAGlB,IAFP,IAAI2E,EAAM,GACNoH,EAAI,EACDA,EAAI/L,EAAIf,QAAQ,CACrB,IAAImC,EAAIsB,KAAKgI,IAAI1K,EAAIf,OAAS8M,EAAG,WAC7B+lD,EAAQ,IAAIxxD,WAAW,GAC3BqE,EAAIiP,KAAKk+C,GACL,IAAA5zC,EAAMoyC,GAAelvD,GACrBiO,EAAI6O,EAAIjf,OACZ0F,EAAIiP,KAAKsK,GACL9c,GAAK,IACPiO,IACI1K,EAAAiP,KAAK,IAAItT,WAAW,CAACc,EAAI,GAAK,MACzBA,GAAK,KACTiO,GAAA,EACD1K,EAAAiP,KAAK,IAAItT,WAAW,CAAC,IAAKc,EAAI,EAAI,QAC7BA,GAAK,OACTiO,GAAA,EACL1K,EAAIiP,KAAK,IAAItT,WAAW,CAAC,IAAKc,EAAI,EAAI,IAAKA,EAAI,GAAK,EAAI,QAC/CA,GAAK,UACTiO,GAAA,EACL1K,EAAIiP,KAAK,IAAItT,WAAW,CAAC,IAAKc,EAAI,EAAI,IAAKA,EAAI,GAAK,EAAI,IAAKA,EAAI,GAAK,GAAK,QAClEA,GAAK,aACTiO,GAAA,EACD1K,EAAAiP,KAAK,IAAItT,WAAW,CAAC,IAAKc,EAAI,EAAI,IAAKA,EAAI,GAAK,EAAI,IAAKA,EAAI,GAAK,GAAK,IAAKA,EAAI,IAAM,GAAK,QAEjGuD,EAAIiP,KAAK5T,EAAI6B,MAAMkK,EAAGA,EAAI3K,IACrBiO,GAAAjO,EACL0wD,EAAM,GAAK,EACLA,EAAA,GAAS,IAAJziD,EACLyiD,EAAA,GAAKziD,GAAK,EAAI,IACdyiD,EAAA,GAAKziD,GAAK,GAAK,IAChBtD,GAAA3K,CACT,CACE,OAAO0uD,GAASnrD,EAClB,CA6HA,SAASotD,GAAkBvkC,EAAM+d,GAC3B,IAAA5mC,EAAM,IAAIrE,WAAW,IAAK0xD,EAAKzC,GAAe5qD,GAAMoH,EAAI,GAAIuE,EAAQ,EAExE,OADA3L,EAAI,GAAK,EACD6oB,EAAKnrB,GACX,IAAK,IACHsC,EAAI,GAAK,EAtcf,SAA2B3E,EAAKmW,EAAQujB,GACtC,IAAIu4B,EAAMvvD,KAAKwB,MAAe,GAATw1B,EAAa,EAAIh3B,KAAK6D,OAAS7D,KAAK4D,IAAI5D,KAAKyC,IAAIu0B,KAAW,KAAO,GACpFw4B,EAAWx4B,EAAQh3B,KAAKC,IAAI,GAAIsvD,EAAM,MACtCjyD,EAAAmW,EAAS,KAAO87C,GAAO,EAC3BjyD,EAAImW,EAAS,MAAc,IAAN87C,IAAc,EACnC,IAAA,IAASjzD,EAAI,EAAGkzD,GAAY,IAAKlzD,EAAGkzD,GAAY,IAC1ClyD,EAAAmW,EAASnX,GAAgB,IAAXkzD,EACpBlyD,EAAImW,EAAS,KAAOujB,GAAS,EAAI,EAAI,GACvC,CA+bwBy4B,CAAAxtD,EAAKoH,EAAGyhB,EAAKrrB,GACtBmO,GAAA,EACJvE,GAAA,GACL,MACF,IAAK,IACHpH,EAAI,GAAK,EACTqtD,EAAGI,WAAWrmD,EAAGyhB,EAAKrrB,EAAI,EAAI,GAAG,GACxBmO,GAAA,EACJvE,GAAA,EACL,MACF,IAAK,IACH,IAA2B,GAAvBw/B,EAAI3tC,QAAQ4vB,EAAKrrB,GACnB,MAAM,IAAIiF,MAAM,SAAS5F,OAAOgsB,EAAKrrB,EAAG,uBAC1CwC,EAAI,GAAK,EACTqtD,EAAGK,UAAUtmD,EAAGw/B,EAAI3tC,QAAQ4vB,EAAKrrB,IAAI,GAC5BmO,GAAA,EACJvE,GAAA,EACL,MACF,QACE,KAAM,yBAA2ByhB,EAAKnrB,EAGnC,OADJ2vD,EAAAK,UAAU,EAAG/hD,GAAO,GAChB3L,EAAI9C,MAAM,EAAGkK,EACtB,CACA,SAASumD,GAAkB9kC,EAAM+d,GAC3B,IAAA5mC,EAAM,IAAIrE,WAAW,IAAK0xD,EAAKzC,GAAe5qD,GAAMoH,EAAI,GAAIuE,EAAQ,EAExE,OADA3L,EAAI,GAAK,EACD6oB,EAAKnrB,GACX,IAAK,IACHsC,EAAI,GAAK,EACTqtD,EAAGI,WAAWrmD,EAAGyhB,EAAKrrB,GAAG,GAChBmO,GAAA,GACJvE,GAAA,EACL,MACF,IAAK,IACHpH,EAAI,GAAK,EACTqtD,EAAGI,WAAWrmD,EAAGyhB,EAAKrrB,EAAI,EAAI,GAAG,GACxBmO,GAAA,GACJvE,GAAA,EACL,MACF,IAAK,IACH,IAA2B,GAAvBw/B,EAAI3tC,QAAQ4vB,EAAKrrB,GACnB,MAAM,IAAIiF,MAAM,SAAS5F,OAAOgsB,EAAKrrB,EAAG,uBAC1CwC,EAAI,GAAK,EACTqtD,EAAGK,UAAUtmD,EAAGw/B,EAAI3tC,QAAQ4vB,EAAKrrB,IAAI,GAC5BmO,GAAA,GACJvE,GAAA,EACL,MACF,QACE,KAAM,yBAA2ByhB,EAAKnrB,EAGnC,OADJ2vD,EAAAK,UAAU,EAAG/hD,GAAO,GAChB3L,EAAI9C,MAAM,EAAGkK,EACtB,CAcA,SAASwmD,GAAoBvyD,GAE3B,OAAOmwD,GADEM,GAAczwD,GACE,GAAG,GAAGkB,KACjC,CAuNA,SAASsxD,GAAeC,EAAKvxD,EAAM+0B,GAC7B,IAAA86B,EAAI2B,EAAIC,EAAIC,EAChB,KAAuB,OAAhB7B,EAAK0B,EAAI,SAAc,EAAS1B,EAAG,OAA0B,OAAhB2B,EAAKD,EAAI,SAAc,EAASC,EAAG,IAC/E,KAAA,4CAEJ,IADiE,OAAhDE,EAAsB,OAAhBD,EAAKF,EAAI,SAAc,EAASE,EAAG,SAAc,EAASC,EAAG1xD,OAASqvD,GAAckC,EAAI,GAAG,GAAGvxD,MAAQ,IAAK,EAE9H,KAAA,sCAIR,IAHA,IAAIgV,EAAM,EACN87C,EAAKzC,GAAekD,EAAI,GAAG,GAAGvxD,MAAO2xD,EAAc,EAAGC,EAAe,GACrEC,EAAMxD,GAAekD,EAAI,GAAG,GAAGvxD,MAAO8xD,EAAe,EAAGC,EAAgB,GACnE7jD,EAAI,EAAGA,EAAIlO,EAAKjC,SAAUmQ,EAC7B,GAAW,MAAXlO,EAAKkO,GAAL,CAOJ,IAAI8jD,EAASC,EACL,OAHRnB,EAAGoB,UAAc,EAAJhkD,EAAOyjD,GAAa,GACjCE,EAAIK,UAAc,EAAJhkD,EAAO4jD,GAAc,UAEpB9xD,EAAKkO,IAClB,IAAK,SACO8jD,EAAAnB,GAAkB,CAAE1vD,EAAG,IAAKF,EAAGjB,EAAKkO,IAAM6mB,GACzCk9B,EAAAb,GAAkB,CAAEjwD,EAAG,IAAKF,EAAGjB,EAAKkO,IAAM6mB,GACrD,MACF,IAAK,SACOi9B,EAAAnB,GAAkB,CAAE1vD,EAAG,IAAKF,EAAGjB,EAAKkO,IAAM6mB,GACzCk9B,EAAAb,GAAkB,CAAEjwD,EAAG,IAAKF,EAAGjB,EAAKkO,IAAM6mB,GACrD,MACF,IAAK,UACOi9B,EAAAnB,GAAkB,CAAE1vD,EAAG,IAAKF,EAAGjB,EAAKkO,IAAM6mB,GACzCk9B,EAAAb,GAAkB,CAAEjwD,EAAG,IAAKF,EAAGjB,EAAKkO,IAAM6mB,GACrD,MACF,QACE,MAAM,IAAI7uB,MAAM,qBAAuBlG,EAAKkO,IAEhD0jD,EAAal/C,KAAKs/C,GAClBL,GAAeK,EAAQj0D,OACvBg0D,EAAcr/C,KAAKu/C,GACnBH,GAAgBG,EAASl0D,SACvBiX,CAxBN,MAHM87C,EAAGoB,UAAc,EAAJhkD,EAAO,OAAO,GACvB2jD,EAAAK,UAAc,EAAJhkD,EAAO,OA6BlB,IADPqjD,EAAI,GAAG,GAAGvxD,KAAOovD,GAAep6C,GACzB9G,EAAIqjD,EAAI,GAAG,GAAGvxD,KAAKjC,OAAS,IAAKmQ,EACtC4iD,EAAGoB,UAAc,EAAJhkD,EAAO,OAAO,GAC3B2jD,EAAIK,UAAc,EAAJhkD,EAAO,OAAO,GAIvB,OAFPqjD,EAAI,GAAG,GAAGvxD,KAAO4uD,GAASgD,GAC1BL,EAAI,GAAG,GAAGvxD,KAAO4uD,GAASmD,GACnB/8C,CACT,CA8SA,SAASm2C,GAAehoD,GAjCxB,IAAuBgvD,KAkCT,CACb,CAAC,aAAa,GAEd,CAAC,WAAW,GAEZ,CAAC,WAAY,QAEb,CAAC,eAAe,GAEhB,CAAC,OAAO,IA1CD,SAAkBhvD,GACxB,IAAA,IAAQrF,EAAI,EAAGA,GAAKq0D,EAASp0D,SAAUD,EAAG,CACrC,IAAAoD,EAAIixD,EAASr0D,QACC,IAAfqF,EAAKjC,EAAE,MAAwBiC,EAAAjC,EAAE,IAAMA,EAAE,IAChC,MAATA,EAAE,OAAiBA,EAAE,IAAMklB,OAAOjjB,EAAKjC,EAAE,KAC/C,CACE,GAqCCiC,EACH,CAoSA,SAASgU,GAAUikB,EAAiBj4B,GACnC,MAAoB,OAAjBA,EAAK8wB,SAA0B+5B,GAAU5yB,EAAIj4B,GAC5B,WAAjBA,EAAK8wB,SA/lBT,SAA2BmH,EAAIj4B,GACzB,IAACA,IAASA,EAAKivD,QACX,MAAA,IAAIlsD,MAAM,oDAClB,IAAIyoB,EAAKyM,EAAG7M,OAAO6M,EAAG9M,WAAW,IAC7B8M,EAAG9M,WAAWvwB,OAElB,IAAI4uB,EAAQa,GAAamB,EAAG,SAC5BhC,EAAMltB,EAAEiJ,EAAIikB,EAAMltB,EAAES,EAAI,EAEpBysB,EAAM9tB,EAAEqB,EAAI,IAEdysB,EAAM9tB,EAAEqB,EAAI,GAEVysB,EAAM9tB,EAAE6J,EAAI,KAEdikB,EAAM9tB,EAAE6J,EAAI,IAId,IAAI1I,EAAOy9B,GAAc9O,EAAI,CAAEhC,QAAcjb,OAAQ,IACjDqjB,EAAM,CAAC,aACN/0B,EAAAm0B,SAAQ,SAAShkB,GACb,OAAAA,EAAIgkB,SAAQ,SAAS7H,GACP,iBAARA,GACTyI,EAAIriB,KAAK4Z,EACjB,GACA,IACE,IAAI+lC,EAAa,CAAE,EACfC,EAAU,GACVn9C,EAAM/G,GAAI8S,KAAK/d,EAAKivD,QAAS,CAAEhsD,KAAM,WACzC+O,EAAI5E,UAAU5Q,KAAI,SAAS8W,EAAI1P,GAC7B,MAAO,CAAC0P,EAAItB,EAAI3E,UAAUzJ,GAC9B,IAAKotB,SAAQ,SAAShkB,GAClB,IAAIsG,EAAKtG,EAAI,GAAIqG,EAAKrG,EAAI,GACX,GAAXsG,EAAGrQ,MAEFqQ,EAAGzD,KAAKhM,MAAM,UAIV4oD,GADEc,GADOj6C,EAAGrC,UAGlB+f,SAAQ,SAASo+B,GACVD,EAAA5/C,KAAK6/C,EAAQ5oB,IACV0oB,EAAAE,EAAQ5oB,IAAM,CAAE6oB,KAAM,GAAItU,SAAU1nC,EAAIpQ,KAAMipD,GAAckD,EAAQxC,SAAS,GAAGzqB,KAAK,GAAG,GAAGtlC,MAC5G,GACA,IACUsyD,EAAAr8C,MAAK,SAASw8C,EAAIC,GACxB,OAAOD,EAAKC,CAChB,IACE,IAAIC,EAAiBL,EAAQM,QAAO,SAASH,GAC3C,OAAOA,EAAK,CAChB,IAAK9yD,KAAI,SAAS8yD,GACd,MAAO,CAACA,EAAIrD,GAAeqD,GAC/B,IACEt9C,EAAI5E,UAAU5Q,KAAI,SAAS8W,EAAI1P,GAC7B,MAAO,CAAC0P,EAAItB,EAAI3E,UAAUzJ,GAC9B,IAAKotB,SAAQ,SAAShkB,GACd,IAAAsG,EAAKtG,EAAI,GAASA,EAAI,GACrBsG,EAAGzD,KAAKhM,MAAM,UAEV4oD,GAAec,GAAoBj6C,EAAGrC,UAC5C+f,SAAQ,SAASi8B,GACfA,EAAAL,SAAS57B,SAAQ,SAAStwB,GACZ8uD,EAAAx+B,SAAQ,SAAS0+B,GAC1BzC,EAAGL,SAAS+C,MAAK,SAASC,GAC5B,OAA8C,OAAvC1D,GAAc0D,EAAKztB,KAAK,GAAG,GAAGtlC,OAz3BjD,SAAoB0jB,EAAMsvC,GACxBtsB,EACW,IAAA,IAAAv4B,EAAI,EAAGA,GAAKuV,EAAK3lB,OAASi1D,EAAOj1D,SAAUoQ,EAAG,CACrD,IAAA,IAASvH,EAAI,EAAGA,EAAIosD,EAAOj1D,SAAU6I,EACnC,GAAI8c,EAAKvV,EAAIvH,IAAMosD,EAAOpsD,GACf,SAAA8/B,EACN,OAAA,CACb,CACS,OAAA,CACT,CAg3BmEusB,CAAWF,EAAK/yD,KAAM6yD,EAAI,GAC7F,KACYR,EAAWQ,EAAI,IAAIL,KAAK9/C,KAAK09C,EAAGzmB,GAE5C,GACA,GACA,GACA,IAUE,IAHA,IAEIupB,EAFAt+C,EAAQxG,GAAIkH,KAAKH,EAAKk9C,EAAW,GAAGnU,UACpCnhD,EAAI6yD,GAAec,GAAoB97C,EAAMR,UAExC++C,EAAK,EAAGA,EAAKp2D,EAAEgB,SAAUo1D,EAAI,CAChC,IAAAC,EAASr2D,EAAEo2D,GACE,GAAbC,EAAOzpB,KACCupB,EAAAE,EAChB,CACE,IAAIC,EAAehC,GAAoB9B,GAAc2D,EAAQnD,SAAS,GAAG/vD,MAAM,GAAG,GAAGA,MAGrF,IADAjD,EAAI6yD,GAAec,IADnB97C,EAAQxG,GAAIkH,KAAKH,EAAKk9C,EAAWgB,GAAcnV,WACF9pC,UACxC++C,EAAK,EAAGA,EAAKp2D,EAAEgB,SAAUo1D,GAC5BC,EAASr2D,EAAEo2D,IACAxpB,IAAM0pB,IACLH,EAAAE,GAKd,IAHAC,EAAehC,GAAoB9B,GAAc2D,EAAQnD,SAAS,GAAG/vD,MAAM,GAAG,GAAGA,MAEjFjD,EAAI6yD,GAAec,IADnB97C,EAAQxG,GAAIkH,KAAKH,EAAKk9C,EAAWgB,GAAcnV,WACF9pC,UACxC++C,EAAK,EAAGA,EAAKp2D,EAAEgB,SAAUo1D,GAC5BC,EAASr2D,EAAEo2D,IACAxpB,IAAM0pB,IACLH,EAAAE,GAKd,IAHAC,EAAehC,GAAoB9B,GAAc2D,EAAQnD,SAAS,GAAG/vD,MAAM,GAAG,GAAGA,MAEjFjD,EAAI6yD,GAAec,IADnB97C,EAAQxG,GAAIkH,KAAKH,EAAKk9C,EAAWgB,GAAcnV,WACF9pC,UACxC++C,EAAK,EAAGA,EAAKp2D,EAAEgB,SAAUo1D,GAC5BC,EAASr2D,EAAEo2D,IACAxpB,IAAM0pB,IACLH,EAAAE,GAEd,IAAIE,EAAK/D,GAAc2D,EAAQnD,SAAS,GAAG/vD,MAEtCszD,EAAA,GAAG,GAAGtzD,KAAOovD,GAAeziC,EAAM9tB,EAAE6J,EAAI,GACxC4qD,EAAA,GAAG,GAAGtzD,KAAOovD,GAAeziC,EAAM9tB,EAAEqB,EAAI,GAKzC,IAJF,IAAIqzD,EAAYlC,GAAoBiC,EAAG,IAAI,GAAGtzD,MAC1CwzD,EAAYplD,GAAIkH,KAAKH,EAAKk9C,EAAWkB,GAAWrV,UAChDuV,EAAK7D,GAAec,GAAoB8C,EAAUp/C,UAE3CxN,EAAI,EAAGA,EAAI6sD,EAAG11D,QACjB01D,EAAG7sD,GAAG+iC,IAAM4pB,IADe3sD,GAI7B,GAAA6sD,EAAG7sD,GAAG+iC,IAAM4pB,EACR,KAAA,6BACJ,IAAAG,EAASnE,GAAckE,EAAG7sD,GAAGmpD,SAAS,GAAG/vD,MACtC0zD,EAAA,GAAK,GACZA,EAAO,GAAK,GAAIA,EAAO,GAAK,GAC5B,IAAA,IAASxlD,EAAI,EAAGA,GAAKye,EAAM9tB,EAAEqB,IAAKgO,EAAG,CACnC,IAAIylD,EAAO,GACXA,EAAK,GAAKA,EAAK,GAAK,CAAC,CAAEvtD,KAAM,EAAGpG,KAAMovD,GAAelhD,EAAI,UAClDwlD,EAAA,GAAGhhD,KAAK,CAAEtM,KAAM,EAAGpG,KAAMyvD,GAAckE,KACvCD,EAAA,GAAGhhD,KAAK,CAAEtM,KAAM,EAAGpG,KAAMovD,GAAelhD,KACxCwlD,EAAA,GAAGhhD,KAAK,CAAEtM,KAAM,EAAGpG,KAAMovD,GAAelhD,IACvD,CACawlD,EAAA,GAAK,GACZA,EAAO,GAAK,GAAIA,EAAO,GAAK,GAC5B,IAAA,IAAS//C,EAAI,EAAGA,GAAKgZ,EAAM9tB,EAAE6J,IAAKiL,GAChCggD,EAAO,IACF,GAAKA,EAAK,GAAK,CAAC,CAAEvtD,KAAM,EAAGpG,KAAMovD,GAAez7C,EAAI,UAClD+/C,EAAA,GAAGhhD,KAAK,CAAEtM,KAAM,EAAGpG,KAAMyvD,GAAckE,KACvCD,EAAA,GAAGhhD,KAAK,CAAEtM,KAAM,EAAGpG,KAAMovD,GAAez7C,KACxC+/C,EAAA,GAAGhhD,KAAK,CAAEtM,KAAM,EAAGpG,KAAMovD,GAAez7C,KAEjD8/C,EAAG7sD,GAAGmpD,SAAS,GAAG/vD,KAAOyvD,GAAciE,GAEzCF,EAAUp/C,QAAUu8C,GAAkBT,GAAeuD,IAC3CD,EAAAz/C,KAAOy/C,EAAUp/C,QAAQrW,cAC5Bu1D,EAAG,IACV,IAAIM,EAAQrE,GAAc+D,EAAG,GAAG,GAAGtzD,MAE3B4zD,EAAA,GAAG,GAAG5zD,KAAOovD,GAAeziC,EAAM9tB,EAAE6J,EAAI,GAC9C,IACImrD,EAAiBxC,GADH9B,GAAcqE,EAAM,GAAG,GAAG5zD,MACS,GAAG,GAAGA,MAIrD,IAFNyzD,EAAK7D,GAAec,IADpB8C,EAAYplD,GAAIkH,KAAKH,EAAKk9C,EAAWwB,GAAgB3V,WACH9pC,WAEzC,GAAGu1B,IAAMkqB,EACR,KAAA,0BACJ,IAAAC,EAAcvE,GAAckE,EAAG,GAAG1D,SAAS,GAAG/vD,MAClD,IAAK2T,EAAI,EAAGA,EAAI3T,EAAKjC,SAAU4V,EAAG,CAChC,IAAIogD,EAAUxE,GAAcuE,EAAY,GAAG,GAAG9zD,MAC9C+zD,EAAQ,GAAG,GAAG/zD,KAAOovD,GAAez7C,GAC5BogD,EAAA,GAAG,GAAG/zD,KAAOovD,GAAepvD,EAAK2T,GAAG5V,QAC5C+1D,EAAY,GAAGngD,GAAK,CAAEvN,KAAM0tD,EAAY,GAAG,GAAG1tD,KAAMpG,KAAMyvD,GAAcsE,GAClF,CACQN,EAAG,GAAG1D,SAAS,GAAG/vD,KAAOyvD,GAAcqE,GAEzCN,EAAUp/C,QAAUu8C,GAAkBT,GAAeuD,IAC3CD,EAAAz/C,KAAOy/C,EAAUp/C,QAAQrW,OACnC,IAAIi2D,EAAiB3C,GAAoBuC,EAAM,GAAG,GAAG5zD,MAI/C,IAFNyzD,EAAK7D,GAAec,IADpB8C,EAAYplD,GAAIkH,KAAKH,EAAKk9C,EAAW2B,GAAgB9V,WACH9pC,WAEzC,GAAGu1B,IAAMqqB,EACR,KAAA,0BAER,IADAF,EAAcvE,GAAckE,EAAG,GAAG1D,SAAS,GAAG/vD,MACzCkO,EAAI,EAAGA,GAAKye,EAAM9tB,EAAEqB,IAAKgO,GAC5B6lD,EAAUxE,GAAcuE,EAAY,GAAG,GAAG9zD,OAClC,GAAG,GAAGA,KAAOovD,GAAelhD,GAC5B6lD,EAAA,GAAG,GAAG/zD,KAAOovD,GAAeziC,EAAM9tB,EAAE6J,EAAI,GAChDorD,EAAY,GAAG5lD,GAAK,CAAE9H,KAAM0tD,EAAY,GAAG,GAAG1tD,KAAMpG,KAAMyvD,GAAcsE,IAE1EN,EAAG,GAAG1D,SAAS,GAAG/vD,KAAOyvD,GAAcqE,GAEzCN,EAAUp/C,QAAUu8C,GAAkBT,GAAeuD,IAC3CD,EAAAz/C,KAAOy/C,EAAUp/C,QAAQrW,OACnC,IAAIk2D,EAAS5C,GAAoBuC,EAAM,GAAG,GAAG5zD,OAC7C,WAIE,IAHA,IAEIk0D,EAFAC,EAAS/lD,GAAIkH,KAAKH,EAAKk9C,EAAW4B,GAAQ/V,UAC1CkW,EAAKxE,GAAec,GAAoByD,EAAO//C,UAE1CigD,EAAM,EAAGA,EAAMD,EAAGr2D,SAAUs2D,EAAK,CACpC,IAAA9B,EAAU6B,EAAGC,GACb9B,EAAQ5oB,IAAMsqB,IACNC,EAAA3B,EACtB,CACQ,IAAI+B,EAAU/E,GAAc2E,EAAQnE,SAAS,GAAG/vD,MAEtCs0D,EAAA,GAAK,GACb,IAAIC,EAAS,GACTx/B,EAAAZ,SAAQ,SAAStsB,EAAK/J,GACjBy2D,EAAA,GAAK,CAAC,CAAEnuD,KAAM,EAAGpG,KAAMovD,GAAetxD,KACtCy2D,EAAA,GAAK,CAAC,CAAEnuD,KAAM,EAAGpG,KAAMovD,GAAe,KACtCmF,EAAA,GAAK,CAAC,CAAEnuD,KAAM,EAAGpG,KAAM2uD,GAAM9mD,KAC5BysD,EAAA,GAAG5hD,KAAK,CAAEtM,KAAM,EAAGpG,KAAMyvD,GAAc8E,IAC3D,IAEQL,EAAQnE,SAAS,GAAG/vD,KAAOyvD,GAAc6E,GACrC,IACAE,EAAQ7D,GADHT,GAAekE,IAExBD,EAAO//C,QAAUogD,EACVL,EAAApgD,KAAOogD,EAAO//C,QAAQrW,MAC3B,CAzBJ,GA0BA,IAAI02D,EAAOlF,GAAcqE,EAAM,GAAG,GAAG5zD,MAE/BmB,EAAIszD,EAAK,GAAG,UACTA,EAAK,GACR,IAAAC,EAAKnF,GAAcpuD,EAAEnB,MAEnB20D,EAAUtD,GAAoBqD,EAAG,GAAG,GAAG10D,OAC3C,WAIE,IAHA,IAEI40D,EAFAC,EAASzmD,GAAIkH,KAAKH,EAAKk9C,EAAWsC,GAASzW,UAC3C4W,EAAKlF,GAAec,GAAoBmE,EAAOzgD,UAE1CigD,EAAM,EAAGA,EAAMS,EAAG/2D,SAAUs2D,EAAK,CACpC,IAAA9B,EAAUuC,EAAGT,GACb9B,EAAQ5oB,IAAMgrB,IACLC,EAAArC,EAC3B,CACY,IAAIwC,EAAWxF,GAAcqF,EAAS7E,SAAS,GAAG/vD,aAEzC+0D,EAAS,UACTN,EAAK,GACR,IAAAO,EAAU,IAAI51D,WAAW21D,EAAS,GAAG,GAAG/0D,MACnC+0D,EAAA,GAAK,GAEd,IADA,IAAI//C,EAAM,EACDigD,EAAK,EAAGA,GAAMtoC,EAAM9tB,EAAE6J,IAAKusD,EAAI,CAClC,IAAAC,EAAU3F,GAAcyF,GAC5BhgD,GAAOs8C,GAAe4D,EAASl1D,EAAKi1D,GAAKlgC,GACzCmgC,EAAQ,GAAG,GAAGl1D,KAAOovD,GAAe6F,GAC3BF,EAAA,GAAGriD,KAAK,CAAE1S,KAAMyvD,GAAcyF,GAAU9uD,KAAM,GACvE,CACc2uD,EAAS,GAAK,CAAC,CAAE3uD,KAAM,EAAGpG,KAAMovD,GAAeziC,EAAM9tB,EAAEqB,EAAI,KAC3D60D,EAAS,GAAK,CAAC,CAAE3uD,KAAM,EAAGpG,KAAMovD,GAAeziC,EAAM9tB,EAAE6J,EAAI,KAClDqsD,EAAA,GAAK,CAAC,CAAE3uD,KAAM,EAAGpG,KAAMovD,GAAep6C,KAC/C+/C,EAAS,GAAK,CAAC,CAAE3uD,KAAM,EAAGpG,KAAMovD,GAAeziC,EAAM9tB,EAAE6J,EAAI,KAE7DksD,EAAS7E,SAAS,GAAG/vD,KAAOyvD,GAAcsF,GACtC,IACAP,EAAQ7D,GADHT,GAAe4E,IAExBD,EAAOzgD,QAAUogD,EACVK,EAAA9gD,KAAO8gD,EAAOzgD,QAAQrW,MAC3B,CAhCJ,GAkCAoD,EAAAnB,KAAOyvD,GAAciF,GAEzBd,EAAM,GAAG,GAAG5zD,KAAOyvD,GAAcgF,GAEnCnB,EAAG,GAAG,GAAGtzD,KAAOyvD,GAAcmE,GAEhCV,EAAQnD,SAAS,GAAG/vD,KAAOyvD,GAAc6D,GACrC,IACA6B,EAAOxE,GADHT,GAAenzD,IAIhB,OAFP6X,EAAMR,QAAU+gD,EACVvgD,EAAAb,KAAOa,EAAMR,QAAQrW,OACpBoX,CACT,CAoVuCigD,CAAkBh6B,EAAIj4B,GACxC,QAAjBA,EAAK8wB,SAQT,SAAyBmH,EAAiBj4B,GAC9B2sC,GAAA,KACR1U,IAAOA,EAAGmR,MACTnR,EAAAmR,IAAMvmB,GAAI/jB,IAEXm5B,GAAMA,EAAGmR,WACCngC,GAAegvB,EAAGmR,KAEzBppC,EAAAs3C,OAAS31B,GAAUsW,EAAGmR,KAAMppC,EAAKs3C,OAAOrf,EAAGmR,IAAI,QAAU,EAC9DppC,EAAKu3C,IAAMtf,EAAGmR,KAEfppC,EAAKuyB,KAAO,CAAA,EAAIvyB,EAAKkyD,OAAS,CAAE,EAC3BlyD,EAAAk4C,QAAkB,GAAqBl4C,EAAKk4C,QAAQ7Q,MAAQ,EAAGrnC,EAAKk4C,QAAQ3Q,OAAS,EACvF4O,GAAiBn2C,EAAKm4C,WAAa,IAAI/B,KACnCp2C,EAAKm4C,WAAa,CAAE,EAAOn4C,EAAAm4C,WAAWga,IAAM,UAAWnyD,EAAKm4C,WAAWga,KAC9E,IAAIC,EAAyB,QAAjBpyD,EAAK8wB,SAAqB,MAAQ,MAC1CuhC,EAASxjB,GAAQt1C,QAAQyG,EAAK8wB,WAAY,EAC1CjgB,EA92jBI,CACP4e,UAAU,GAAIvE,OAAO,GAAI+E,OAAO,GAAIC,QAAQ,GAAIC,OAAO,GACvDoC,KAAK,GAAIxC,KAAK,GAAIC,SAAS,GAAIsiC,iBAAiB,GAAIC,MAAM,GAC1DC,UAAU,GAAIC,SAAS,GAAIC,UAAU,GAAIC,OAAO,GAAItiC,OAAO,GAC3DuiC,WAAW,GAAIxQ,IAAK,GAAIyQ,SAAU,GAAIziC,SAAU,GAAI6d,OAAO,GAC3D6kB,KAAK,GAAIriC,MAAO,IA02jBFu3B,GAAAhoD,EAAOA,GAAQ,IAC9B,IAAI0jB,EAAMK,KACNxc,EAAI,GAAImrB,EAAM,EAElB1yB,EAAKwpC,QAAU,GACA6N,GAAAr3C,EAAKwpC,QAAS,CAAE,EAAE,CAAC8N,OAAO,CAAC8J,QAAU,KAEhDnpB,EAAG3E,QAAO2E,EAAG3E,MAAQ,CAAE,GAS3B,GANA7P,GAAaC,EADTnc,EAAA,oBACiB8rB,GAAiB4E,EAAG3E,MAAOtzB,IAC7C6Q,EAAA2hD,UAAUjjD,KAAKhI,GAClBkrB,GAASzyB,EAAKuyB,KAAM,EAAGhrB,EAAG2pB,GAAKO,YAG3BlqB,EAAA,mBACD0wB,EAAG3E,OAAS2E,EAAG3E,MAAMnI,iBAChB,GAAC8M,EAAG2gB,UAAa3gB,EAAG2gB,SAASxtB,OAChC,CAEJ,IADA,IAAI2nC,EAAM,GACFC,EAAK,EAAGA,EAAK/6B,EAAG9M,WAAWvwB,SAAUo4D,EACF,IAAtC/6B,EAAG2gB,SAASxtB,OAAO4nC,IAAK,CAAE,GAAElU,QAAiBiU,EAAAxjD,KAAK0oB,EAAG9M,WAAW6nC,IACrE/6B,EAAG3E,MAAMnI,WAAa4nC,CACxB,MAN8C96B,EAAG3E,MAAMnI,WAAa8M,EAAG9M,WAOtE8M,EAAG3E,MAAMQ,WAAamE,EAAG3E,MAAMnI,WAAWvwB,OAC1C6oB,GAAaC,EAAKnc,EAAGosB,GAAgBsE,EAAG3E,QACrCziB,EAAA4hD,SAASljD,KAAKhI,GACjBkrB,GAASzyB,EAAKuyB,KAAM,EAAGhrB,EAAG2pB,GAAKQ,WAE5BuG,EAAG+nB,YAAc/nB,EAAG3E,OAASrS,GAAKgX,EAAG+nB,WAAW,CAAA,GAAIplD,OAAS,IAE/D6oB,GAAaC,EADTnc,EAAA,sBACiBysB,GAAiBiE,EAAG+nB,YACtCnvC,EAAA6hD,UAAUnjD,KAAKhI,GAClBkrB,GAASzyB,EAAKuyB,KAAM,EAAGhrB,EAAG2pB,GAAKS,aAGhC,IAAIe,EAAI,EAAEA,GAAOuF,EAAG9M,WAAWvwB,SAAU83B,EAAK,CAC7C,IAAIugC,EAAS,CAAC,MAAM,IAChBznC,EAAKyM,EAAG7M,OAAO6M,EAAG9M,WAAWuH,EAAI,KACxBlH,GAAM,CAAA,GAAI,SAWvB,GALc/H,GAAAC,EADTnc,EAAA,sBAAwBmrB,EAAM,IAAM0/B,EACnBxS,GAASltB,EAAI,EAAGnrB,EAAGvH,EAAMi4B,EAAIg7B,IAC/CpiD,EAAAqa,OAAO3b,KAAKhI,GACNkrB,GAAAzyB,EAAKkyD,QAAQ,EAAI,mBAAqBx/B,EAAM,IAAM0/B,EAAOlhC,GAAKa,GAAG,IAGxEvG,EAAI,CACF,IAAAwE,EAAWxE,EAAG,aACd0nC,GAAW,EACXC,EAAK,GACNnjC,GAAYA,EAASp1B,OAAS,IAEhC6oB,GAAaC,EADRyvC,EAAA,cAAgBzgC,EAAM,IAAM0/B,EACXvS,GAAW7vB,EAAUmjC,IACxCtiD,EAAAmf,SAASzgB,KAAK4jD,GACjB1gC,GAASwgC,GAAY,EAAA,cAAgBvgC,EAAM,IAAM0/B,EAAOlhC,GAAKM,MAClD0hC,GAAA,GAET1nC,EAAG,YACF0nC,GAAuBzvC,GAAAC,EAAK,yBAA4BgP,EAAO,OAAQka,GAAmBla,EAAKlH,EAAG,sBAE/FA,EAAG,oBACHA,EAAG,UACb,CAEKynC,EAAO,OAAOG,MAAM3vC,GAAaC,EAAK2O,GAAc9qB,GAAI+qB,GAAW2gC,GACxE,CAEoB,MAAhBjzD,EAAKk4C,SAAmBl4C,EAAKk4C,QAAQt9C,OAAS,IAEhD6oB,GAAaC,EADbnc,EAAI,oBAAsB6qD,EArsM5B,SAAmBv1D,EAAcgT,EAAiB7P,GACzC,OAAiB,SAAjB6P,EAAKrS,OAAQ,GAAakqC,GAAgBT,IAAepqC,EAAMmD,EACxE,CAosMuBqzD,CAAUrzD,EAAKk4C,QAAS3wC,EAAGvH,IAC7C6Q,EAAAkf,KAAKxgB,KAAKhI,GACbkrB,GAASzyB,EAAKkyD,QAAQ,EAAI,iBAAmBE,EAAOlhC,GAAKU,MAI1DnO,GAAaC,EADbnc,EAAI,eAAiB6qD,EA5tMtB,SAAkBn6B,EAAIpoB,GACrB,OAAyB,SAAjBA,EAAKrS,OAAM,GAAe4hD,GAAeV,IAAczmB,EAChE,CA2tMsBq7B,CAASr7B,EAAI1wB,IAC/BsJ,EAAA4e,UAAUlgB,KAAKhI,GAClBkrB,GAASzyB,EAAKuyB,KAAM,EAAGhrB,EAAG2pB,GAAKC,IAK/B1N,GAAaC,EADTnc,EAAA,sBACiB2kC,GAAYjU,EAAGkU,OAAQnsC,IACzC6Q,EAAA8hD,OAAOpjD,KAAKhI,GACfkrB,GAASzyB,EAAKkyD,QAAY,EAAA,mBAAoBhhC,GAAKY,OAKnDrO,GAAaC,EADbnc,EAAI,aAAe6qD,EA7tMpB,SAAmBv1D,EAAMgT,EAAiB7P,GACjC,OAAiB,SAAjB6P,EAAKrS,OAAQ,GAAamuC,GAAgBxC,IAAetsC,EAAMmD,EACxE,CA4tMsBuzD,CAAUt7B,EAAI1wB,EAAGvH,IACnC6Q,EAAAwf,OAAO9gB,KAAKhI,GACfkrB,GAASzyB,EAAKkyD,QAAQ,EAAI,UAAYE,EAAOlhC,GAAKW,KAE/CoG,EAAGygB,QAAU2Z,IAEF5uC,GAAAC,EADTnc,EAAA,oBACiB0wB,EAAGygB,QACrB7nC,EAAAuxC,IAAI7yC,KAAKhI,GACZkrB,GAASzyB,EAAKkyD,QAAY,EAAA,iBAAkBhhC,GAAKkB,MAa3C,OATP3O,GAAaC,EADbnc,EAAI,eAAiB6qD,EAxtMtB,SAAsBviD,GACrB,OAAyB,SAAjBA,EAAKrS,OAAM,GAAe6uC,GAAmBK,KACtD,CAutMsB8mB,CAAajsD,IAC/BsJ,EAAAuf,SAAS7gB,KAAKhI,GACjBkrB,GAASzyB,EAAKkyD,QAAQ,EAAI,YAAcE,EAAOlhC,GAAKe,QAEpDxO,GAAaC,EAAK,sBAAuB4M,GAASzf,EAAI7Q,IACtDyjB,GAAaC,EAAK,cAAe4O,GAAWtyB,EAAKuyB,OACjD9O,GAAaC,EAAK,qBAAuB0uC,EAAQ,QAAS9/B,GAAWtyB,EAAKkyD,gBAEnElyD,EAAKs3C,cAAet3C,EAAKu3C,IACzB7zB,CACR,CA7IoC+vC,CAAgBx7B,EAAIj4B,GA+IxD,SAAwBi4B,EAAiBj4B,GAC7B2sC,GAAA,KACR1U,IAAOA,EAAGmR,MACTnR,EAAAmR,IAAMvmB,GAAI/jB,IAEXm5B,GAAMA,EAAGmR,WACCngC,GAAegvB,EAAGmR,KAEzBppC,EAAAs3C,OAAS31B,GAAUsW,EAAGmR,KAAMppC,EAAKs3C,OAAOrf,EAAGmR,IAAI,QAAU,EAC9DppC,EAAKu3C,IAAMtf,EAAGmR,KAEfppC,EAAKuyB,KAAO,CAAA,EAAIvyB,EAAKkyD,OAAS,CAAE,EAC3BlyD,EAAAk4C,QAAkB,GAAqBl4C,EAAKk4C,QAAQ7Q,MAAQ,EAAGrnC,EAAKk4C,QAAQ3Q,OAAS,EACvF4O,GAAiBn2C,EAAKm4C,WAAa,IAAI/B,KACnCp2C,EAAKm4C,WAAa,CAAE,EAAOn4C,EAAAm4C,WAAWga,IAAM,UAAWnyD,EAAKm4C,WAAWga,KAC9E,IAAIC,EAAQ,MACRC,EAASxjB,GAAQt1C,QAAQyG,EAAK8wB,WAAY,EAC1CjgB,EAr/jBI,CACP4e,UAAU,GAAIvE,OAAO,GAAI+E,OAAO,GAAIC,QAAQ,GAAIC,OAAO,GACvDoC,KAAK,GAAIxC,KAAK,GAAIC,SAAS,GAAIsiC,iBAAiB,GAAIC,MAAM,GAC1DC,UAAU,GAAIC,SAAS,GAAIC,UAAU,GAAIC,OAAO,GAAItiC,OAAO,GAC3DuiC,WAAW,GAAIxQ,IAAK,GAAIyQ,SAAU,GAAIziC,SAAU,GAAI6d,OAAO,GAC3D6kB,KAAK,GAAIriC,MAAO,IAi/jBFu3B,GAAAhoD,EAAOA,GAAQ,IAC9B,IAAI0jB,EAAMK,KACNxc,EAAI,GAAImrB,EAAM,EAElB1yB,EAAKwpC,QAAU,GACA6N,GAAAr3C,EAAKwpC,QAAS,CAAE,EAAE,CAAC8N,OAAO,CAAC8J,QAAU,KAEhDnpB,EAAG3E,QAAO2E,EAAG3E,MAAQ,CAAE,GAS3B,GANA7P,GAAaC,EADTnc,EAAA,oBACiB8rB,GAAiB4E,EAAG3E,MAAOtzB,IAC7C6Q,EAAA2hD,UAAUjjD,KAAKhI,GAClBkrB,GAASzyB,EAAKuyB,KAAM,EAAGhrB,EAAG2pB,GAAKO,YAG3BlqB,EAAA,mBACD0wB,EAAG3E,OAAS2E,EAAG3E,MAAMnI,iBAChB,GAAC8M,EAAG2gB,UAAa3gB,EAAG2gB,SAASxtB,OAChC,CAEJ,IADA,IAAI2nC,EAAM,GACFC,EAAK,EAAGA,EAAK/6B,EAAG9M,WAAWvwB,SAAUo4D,EACF,IAAtC/6B,EAAG2gB,SAASxtB,OAAO4nC,IAAK,CAAE,GAAElU,QAAiBiU,EAAAxjD,KAAK0oB,EAAG9M,WAAW6nC,IACrE/6B,EAAG3E,MAAMnI,WAAa4nC,CACxB,MAN8C96B,EAAG3E,MAAMnI,WAAa8M,EAAG9M,WAOtE8M,EAAG3E,MAAMQ,WAAamE,EAAG3E,MAAMnI,WAAWvwB,OAC1C6oB,GAAaC,EAAKnc,EAAGosB,GAAgBsE,EAAG3E,QACrCziB,EAAA4hD,SAASljD,KAAKhI,GACjBkrB,GAASzyB,EAAKuyB,KAAM,EAAGhrB,EAAG2pB,GAAKQ,WAE5BuG,EAAG+nB,YAAc/nB,EAAG3E,OAASrS,GAAKgX,EAAG+nB,WAAW,CAAA,GAAIplD,OAAS,IAE/D6oB,GAAaC,EADTnc,EAAA,sBACiBysB,GAAiBiE,EAAG+nB,YACtCnvC,EAAA6hD,UAAUnjD,KAAKhI,GAClBkrB,GAASzyB,EAAKuyB,KAAM,EAAGhrB,EAAG2pB,GAAKS,aAG5B,IAAAsc,EAAS,CAAC,WAGd,IAFAjuC,EAAKquC,KAAO,EAER3b,EAAI,EAAEA,GAAOuF,EAAG9M,WAAWvwB,SAAU83B,EAAK,CAC7C,IAAIugC,EAAS,CAAC,MAAM,IAChBznC,EAAKyM,EAAG7M,OAAO6M,EAAG9M,WAAWuH,EAAI,KACxBlH,GAAM,CAAA,GAAI,SAWvB,GALc/H,GAAAC,EADTnc,EAAA,sBAAwBmrB,EAAM,IAAM0/B,EACnB/Z,GAAa3lB,EAAI,EAAG1yB,EAAMi4B,EAAIg7B,IAChDpiD,EAAAqa,OAAO3b,KAAKhI,GACNkrB,GAAAzyB,EAAKkyD,QAAQ,EAAI,mBAAqBx/B,EAAM,IAAM0/B,EAAOlhC,GAAKa,GAAG,IAGxEvG,EAAI,CACF,IAAAwE,EAAWxE,EAAG,aACd0nC,GAAW,EACXC,EAAK,GACN,GAAAnjC,GAAYA,EAASp1B,OAAS,EAAG,CACnC,IAAI84D,GAAS,EACJ1jC,EAAAgB,SAAQ,SAASkd,GACzBA,EAAK,GAAGld,SAAQ,SAASj0B,GAAe,GAAPA,EAAEwD,IAAoBmzD,GAAA,EAAK,GACjE,IACOA,IAEFjwC,GAAaC,EADRyvC,EAAA,sCAAwCzgC,EAAM,IAAM0/B,EACnCpkB,GAAgBhe,EAAUie,EAAQjuC,IACrD6Q,EAAAyhD,iBAAiB/iD,KAAK4jD,GACzB1gC,GAASwgC,GAAY,EAAA,sCAAwCvgC,EAAM,IAAM0/B,EAAOlhC,GAAKgB,QAItFzO,GAAaC,EADRyvC,EAAA,cAAgBzgC,EAAM,IAAM0/B,EACXzkB,GAAmB3d,IACtCnf,EAAAmf,SAASzgB,KAAK4jD,GACjB1gC,GAASwgC,GAAY,EAAA,cAAgBvgC,EAAM,IAAM0/B,EAAOlhC,GAAKM,MAClD0hC,GAAA,CACf,CACM1nC,EAAG,YACF0nC,GAAuBzvC,GAAAC,EAAK,yBAA4BgP,EAAO,OAAQka,GAAmBla,EAAKlH,EAAG,sBAE/FA,EAAG,oBACHA,EAAG,UACb,CAEKynC,EAAO,OAAOG,MAAM3vC,GAAaC,EAAK2O,GAAc9qB,GAAI+qB,GAAW2gC,GACxE,CAEoB,MAAhBjzD,EAAKk4C,SAAmBl4C,EAAKk4C,QAAQt9C,OAAS,IAEhD6oB,GAAaC,EADbnc,EAAI,oBAAsB6qD,EACLnrB,GAAcjnC,EAAKk4C,QAASl4C,IAC9C6Q,EAAAkf,KAAKxgB,KAAKhI,GACbkrB,GAASzyB,EAAKkyD,QAAQ,EAAI,iBAAmBE,EAAOlhC,GAAKU,MAI1DnO,GAAaC,EADbnc,EAAI,eAAiB6qD,EACA1T,GAAazmB,IAC/BpnB,EAAA4e,UAAUlgB,KAAKhI,GAClBkrB,GAASzyB,EAAKuyB,KAAM,EAAGhrB,EAAG2pB,GAAKC,IAK/B1N,GAAaC,EADTnc,EAAA,sBACiB2kC,GAAYjU,EAAGkU,OAAQnsC,IACzC6Q,EAAA8hD,OAAOpjD,KAAKhI,GACfkrB,GAASzyB,EAAKkyD,QAAY,EAAA,mBAAoBhhC,GAAKY,OAKnDrO,GAAaC,EADbnc,EAAI,aAAe6qD,EACEjpB,GAAclR,EAAIj4B,IACpC6Q,EAAAwf,OAAO9gB,KAAKhI,GACfkrB,GAASzyB,EAAKkyD,QAAQ,EAAI,UAAYE,EAAOlhC,GAAKW,KAE/CoG,EAAGygB,QAAU2Z,IAEF5uC,GAAAC,EADTnc,EAAA,oBACiB0wB,EAAGygB,QACrB7nC,EAAAuxC,IAAI7yC,KAAKhI,GACZkrB,GAASzyB,EAAKkyD,QAAY,EAAA,iBAAkBhhC,GAAKkB,MAIrC3O,GAAAC,EADbnc,EAAI,eAAiB6qD,EACA1lB,MAClB77B,EAAAuf,SAAS7gB,KAAKhI,GACjBkrB,GAASzyB,EAAKkyD,QAAQ,EAAI,YAAcE,EAAOlhC,GAAKe,QAEjDgc,EAAOrzC,OAAS,IAElB6oB,GAAaC,EADTnc,EAAA,wBA1gXN,SAA0B0mC,GACzB,IAAI9zC,EAAI,CAAC6pB,GAAYqB,GAAU,aAAc,KAAM,CAClDoL,MAASjL,GACT,UAAWC,GAAW,KACpBxqB,QAAQ,QAAS,MAUb,OATAgzC,EAAAjd,SAAQ,SAAS2iC,EAAQ/vD,GAC7BzJ,EAAAoV,KAAK8V,GAAU,SAAU,KAAM,CAChCuuC,YAAaD,EACbntB,GAAI,6BAA+B,eAAiB5iC,GAAKpG,WAAa,IACtEq2D,OAAQF,EACRG,WAAY,SAEf,IACC35D,EAAEoV,KAAK,iBACApV,EAAE6C,KAAK,GACf,CA4/WuB+2D,CAAiB9lB,IACnCp9B,EAAAo9B,OAAO1+B,KAAKhI,GACfkrB,GAASzyB,EAAKkyD,QAAY,EAAA,qBAAsBhhC,GAAKiB,SAQ/C,OALP1O,GAAaC,EAAK,sBAAuB4M,GAASzf,EAAI7Q,IACtDyjB,GAAaC,EAAK,cAAe4O,GAAWtyB,EAAKuyB,OACjD9O,GAAaC,EAAK,qBAAuB0uC,EAAQ,QAAS9/B,GAAWtyB,EAAKkyD,gBAEnElyD,EAAKs3C,cAAet3C,EAAKu3C,IACzB7zB,CACR,CAxSQswC,CAAe/7B,EAAIj4B,EAC3B,CA+ZA,SAASi0D,GAAcjiD,EAAsB7X,GAC5C,OAAOA,EAAE8I,MACR,IAAK,SAAU,IAAK,SAAU,MAC9B,IAAK,SAAU,IAAK,QAAS9I,EAAE8I,KAAO,GAAI,MAC1C,IAAK,OAAQ,OAAOic,GAAS/kB,EAAEwS,KAAM1B,GAAIiT,MAAMlM,EAAK,CAAC/O,KAAK/H,EAAU,SAAW,MAC/E,IAAK,SAAU,MAAM,IAAI6H,MAAM,qCAAuC5I,EAAE22B,SAAW,WACnF,QAAS,MAAM,IAAI/tB,MAAM,qBAAuB5I,EAAE8I,MAE5C,OAAAgI,GAAIiT,MAAMlM,EAAK7X,EACvB,CAGA,SAAS+5D,GAAej8B,EAAiBj4B,GACxC,IAAI7F,EAAI0oB,GAAI7iB,GAAM,IAEX,OAOR,SAA8B2qB,EAAWxwB,GACxC,IAAIg6D,EAAQ,CAAE,EACVC,EAAQl5D,EAAU,aAAsC,oBAAfe,WAA6B,QAAU,SACjF9B,EAAEga,cAAaggD,EAAMhgD,YAAc,WACnC,GAAAha,EAAEkgD,SAAU8Z,EAAMlxD,KAAOmxD,OACvB,OAAOj6D,EAAE8I,MACb,IAAK,SAAUkxD,EAAMlxD,KAAO,SAAU,MACtC,IAAK,SAAUkxD,EAAMlxD,KAAO,SAAU,MACtC,IAAK,SAAU,MAAM,IAAIF,MAAM,qCAAuC5I,EAAE22B,SAAW,WACnF,IAAK,SACL,IAAK,OAAQqjC,EAAMlxD,KAAOmxD,EAAO,MACjC,QAAS,MAAM,IAAIrxD,MAAM,qBAAuB5I,EAAE8I,MAE/C,IAAA3C,EAAMqqB,EAAEtd,UAAYpC,GAAIiT,MAAMyM,EAAG,CAACvX,SAAS,MAAOnQ,KAAa,CAACoxD,WAAc,SAAUC,OAAU,UAAsBH,EAAMlxD,OAASkxD,EAAMlxD,KAAMkR,cAAeha,EAAEga,cAAgBwW,EAAE4pC,SAASJ,GAChM,GAAgB,oBAATh1C,MACQ,iBAAP7e,EAAiB,CAC1B,GAAa,UAAVnG,EAAE8I,MAA8B,UAAV9I,EAAE8I,KAAyB,OAAA3C,EACpDA,EAAM,IAAIrE,WAAWQ,EAAK6D,GAC7B,CAGC,OAAGnG,EAAEkgD,UAAqC,oBAAlBma,cAAsCP,GAAcO,cAAcl0D,EAAKnG,EAAEkgD,UAAWlgD,GAE9F,SAAXA,EAAE8I,KAAwBic,GAAS/kB,EAAEwS,KAAMrM,GAC7B,UAAVnG,EAAE8I,KAAmB4hB,GAAgBvkB,GAAmBA,CAChE,CAhCQm0D,CADCzgD,GAAUikB,EAAI99B,GACSA,EAChC,CAuCA,SAASu6D,GAAkBp0D,EAAgBN,EAAoB20D,GAC1DA,IAAWA,EAAA,IACf,IAAIx6D,EAAIw6D,EAAMr0D,EACd,OAAON,EAAKiD,MACX,IAAK,SAAiB,OAAAhJ,EAAcqlB,GAAUnlB,IAC9C,IAAK,SAAU,OAAOmlB,GAAUnlB,GAChC,IAAK,SAAiB,OAAAmG,EACtB,IAAK,OAAQ,OAAO4e,GAASlf,EAAK2M,KAAMxS,EAAG,QAC3C,IAAK,SACJ,OAAGe,EAAgBK,EAAYpB,EAAG,QACH,oBAAhBilB,aAAoC,IAAIA,aAAcC,OAAOllB,GAChEu6D,GAAkBv6D,EAAG,CAAC8I,KAAK,WAAW1G,MAAM,IAAIC,KAAI,SAASO,GAAY,OAAAA,EAAElC,WAAW,MAGpG,MAAM,IAAIkI,MAAM,qBAAuB/C,EAAKiD,KAC7C,CAiBA,SAAS2xD,GAAkBt0D,EAAKN,GAC/B,OAAOA,EAAKiD,MACX,IAAK,SACL,IAAK,SACL,IAAK,SAGJ,IAFA,IAAI4H,EAAO,GAEHlQ,EAAI,EAAGA,EAAI2F,EAAI1F,SAAUD,EAAGkQ,GAAQhR,OAAOC,aAAawG,EAAI3F,IAC7D,MAAa,UAAbqF,EAAKiD,KAAmBhJ,EAAc4Q,GAAqB,UAAb7K,EAAKiD,KAAmB4hB,GAASha,GAAQA,EAC/F,IAAK,OAAe,OAAAqU,GAASlf,EAAK2M,KAAMrM,GACxC,IAAK,SAAiB,OAAAA,EACtB,QAAS,MAAM,IAAIyC,MAAM,qBAAuB/C,EAAKiD,MAEvD,CAWA,SAAS4xD,GAAU58B,EAAiBj4B,GACzBvG,IACV6kD,GAASrmB,GACT,IAAI99B,EAAI0oB,GAAI7iB,GAAM,IAEf,GADA7F,EAAEypD,aAAczpD,EAAEmpC,QAAS,EAAMnpC,EAAE8xB,YAAa,GACtC,SAAV9xB,EAAE8I,KAAiB,CAAE9I,EAAE8I,KAAO,SAAc,IAAA3C,EAAkBu0D,GAAU58B,EAAI99B,GAA+B,OAAlBA,EAAE8I,KAAO,QAAgBxG,EAAK6D,EAAK,CAC/H,IAAIsD,EAAM,EACV,GAAGzJ,EAAE8wB,UACiB,iBAAX9wB,EAAE8wB,MAAyB9wB,EAAE8wB,MAC5BgN,EAAG9M,WAAW5xB,QAAQY,EAAE8wB,QAC/BgN,EAAG9M,WAAWvnB,IAAY,MAAA,IAAIb,MAAM,oBAAsB5I,EAAE8wB,MAAQ,aAAgB9wB,EAAE8wB,OAEpF,OAAA9wB,EAAE22B,UAAY,QACpB,IAAK,MACL,IAAK,OAAQ,OAAO4jC,GAAkBvT,GAAWlpB,EAAI99B,GAAIA,GACzD,IAAK,MACL,IAAK,OAAQ,OAAOu6D,GAAkBr5B,GAAKjB,WAAWnC,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,GACzF,IAAK,MACL,IAAK,OAAe,OAAAu6D,GAAkBnM,GAActwB,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,GACvF,IAAK,MAAc,OA1DrB,SAAyBmG,EAAgBN,GACxC,OAAOA,EAAKiD,MACX,IAAK,SAAU,OAAOhJ,EAAcqG,GACpC,IAAK,SACL,IAAK,SAAiB,OAAAA,EACtB,IAAK,OAAQ,OAAO4e,GAASlf,EAAK2M,KAAMrM,EAAK,UAC7C,IAAK,SACJ,OAAGpF,EAAgBK,EAAY+E,EAAK,UACxBA,EAAI/D,MAAM,IAAIC,KAAI,SAASO,GAAY,OAAAA,EAAElC,WAAW,EAAG,IAGrE,MAAM,IAAIkI,MAAM,qBAAuB/C,EAAKiD,KAC7C,CA8CqB6xD,CAAgBC,GAAa98B,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,GACnF,IAAK,MAAO,OAAOu6D,GAAkBM,GAAa/8B,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,EAAG,UACxF,IAAK,MAAO,OAAOu6D,GAAkBlzB,GAAIpH,WAAWnC,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,GACvF,IAAK,MAAO,OAAOy6D,GAAkB97B,GAAIsB,WAAWnC,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,GACvF,IAAK,MAAO,OAAOu6D,GAAkBryB,GAAIjI,WAAWnC,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,GACvF,IAAK,MAAO,OAAOu6D,GAAkBxsB,GAAI9N,WAAWnC,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,GACvF,IAAK,MAAO,OAAOu6D,GAAkB3yB,GAAI3H,WAAWnC,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,GACvF,IAAK,OAAQ,OAAOu6D,GAAkB7J,GAAU5yB,EAAI99B,GAAIA,GACxD,IAAK,MAAO,OAAOy6D,GAAkB9wB,GAAI2C,aAAaxO,EAAG7M,OAAO6M,EAAG9M,WAAWvnB,IAAOzJ,GAAIA,GACzF,IAAK,MAAO,OAAOy6D,GAAkB9wB,GAAI+C,YAAY5O,EAAI99B,GAAIA,GAC7D,IAAK,QAAaA,EAAEmvB,OAAMnvB,EAAEmvB,KAAO,GACnC,IAAK,QAAanvB,EAAEmvB,OAAMnvB,EAAEmvB,KAAO,GACnC,IAAK,QAAiC,OAApBnvB,EAAEmvB,OAAMnvB,EAAEmvB,KAAO,GAAUsrC,GAAkBjT,GAAe1pB,EAAI99B,GAAIA,GACtF,IAAK,QAAaA,EAAEmvB,OAAMnvB,EAAEmvB,KAAO,GACnC,IAAK,QACL,IAAK,MACL,IAAK,MAAsC,OAA3BnvB,EAAEmvB,OAAMnvB,EAAEmvB,KAAO,GAjGnC,SAAwB2O,EAAiBj4B,GACpC,IAAA7F,EAAI6F,GAAM,CAAE,EAET,OAAAi0D,GADoBxS,GAAaxpB,EAAI99B,GAClBA,EAC3B,CA6F6C86D,CAAeh9B,EAAI99B,GAC9D,IAAK,OACL,IAAK,OACL,IAAK,OACL,IAAK,OACL,IAAK,UACL,IAAK,MAAc,OAAA+5D,GAAej8B,EAAI99B,GACtC,QAAS,MAAM,IAAI4I,MAAO,0BAA4B5I,EAAE22B,SAAW,KAErE,CA6CA,SAASokC,GAAcjqC,EAAqB1lB,EAAaiL,EAAcgqB,EAAwBjsB,EAAmBsnB,EAAoBtK,EAAmBpxB,GACpJ,IAAA2L,EAAK+jB,GAAWrZ,GAChB2kD,EAASh7D,EAAEg7D,OAAQ3jD,EAAMrX,EAAEqX,MAAQmB,OAAOyO,UAAUC,eAAe5jB,KAAKtD,EAAG,OAC3Ei7D,GAAU,EACVpoD,EAA0B,IAAXuB,EAAgB,GAAK,CAAE,EAC1C,GAAc,IAAXA,EACC,GAAAoE,OAAO0iD,eAAoB,IAAS1iD,OAAA0iD,eAAeroD,EAAK,aAAc,CAACqoB,MAAM7kB,EAAG8kD,YAAW,GAAU,OAAO55D,GAAKsR,EAAIuoD,WAAa/kD,CAAE,QAC9H+kD,WAAa/kD,EAEvB,IAAI+a,GAASN,EAAMza,GAAa,IAAA,IAAAzF,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAAG,CACvD,IAAA5H,EAAMooB,EAAQN,EAAMza,GAAGzF,GAAKkgB,EAAMuP,EAAKzvB,GAAKjF,GAChD,QAAW,IAAR3C,QAA+B,IAAVA,EAAInF,EAA5B,CAKA,IAAIF,EAAIqF,EAAIrF,EACZ,OAAOqF,EAAInF,GACV,IAAK,IAAK,GAAQ,MAALF,EAAW,MAAO,SAC/B,IAAK,IAAUA,EAAK,GAALA,EAAS,UAAO,EAAS,MACxC,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,MACxC,QAAS,MAAM,IAAIiF,MAAM,qBAAuBI,EAAInF,GAElD,GAAU,MAAV63B,EAAI9qB,GAAY,CAClB,GAAQ,MAALjN,EACC,GAAS,KAATqF,EAAInF,GAAkB,OAANF,EAAgBkP,EAAA6oB,EAAI9qB,IAAM,UAAA,QAC1B,IAAXoqD,EAAsBnoD,EAAI6oB,EAAI9qB,IAAMoqD,MAAA,KACpC3jD,GAAa,OAAN1T,EACV,WAD0B+3B,EAAI9qB,IAAM,IACpC,MAELiC,EAAI6oB,EAAI9qB,IAAMyG,IAAkB,MAAVrO,EAAInF,GAAwB,MAAVmF,EAAInF,IAA8B,IAAjB7D,EAAEq7D,YAAyB13D,EAAIgtB,GAAY3nB,EAAIrF,EAAE3D,GAEnG,MAAL2D,IAAqBs3D,GAAA,EAC3B,CAlBA,KAJE,CACC,QAAc,IAAXD,EAAsB,SACZ,MAAVt/B,EAAI9qB,KAAkBiC,EAAA6oB,EAAI9qB,IAAMoqD,EAEtC,CAmBA,CACQ,MAAA,CAAEnoD,MAAUooD,UACpB,CAGA,SAAS96B,GAAcrP,EAAqBjrB,GAC3C,GAAY,MAATirB,GAAkC,MAAjBA,EAAM,cAAwB,GAClD,IAAI9nB,EAAM,CAACnF,EAAE,IAAIF,EAAE,GAAIyQ,EAAS,EAAGuD,EAAS,EAAG+jB,EAAqB,GAAI/3B,EAAE,EAAG6K,EAAG,GAC5EpD,EAAI,CAACjJ,EAAE,CAACiJ,EAAE,EAAExI,EAAE,GAAGrB,EAAE,CAAC6J,EAAE,EAAExI,EAAE,IAC1B5C,EAAI6F,GAAQ,CAAE,EACdwpB,EAAmB,MAAXrvB,EAAEqvB,MAAgBrvB,EAAEqvB,MAAQyB,EAAM,QAK9C,OAJgB,IAAb9wB,EAAEoU,OAAuBA,EAAA,EACP,MAAbpU,EAAEoU,OAAyBA,EAAA,EAC3BrS,MAAMY,QAAQ3C,EAAEoU,QAAkBA,EAAA,EACtB,MAAZpU,EAAEoU,SAAyBA,EAAA,UACrBib,GACb,IAAK,SAAUjkB,EAAIklB,GAAkBjB,GAAQ,MAC7C,IAAK,UAAcjkB,EAAAklB,GAAkBQ,EAAM,UAAY3uB,EAAEiJ,EAAIikB,EAAO,MACpE,QAAajkB,EAAAikB,EAEXjb,EAAS,IAAYuD,EAAA,GACxB,IAAIhM,EAAK+jB,GAAWtkB,EAAEjJ,EAAEiJ,GACpBi1B,EAAyB,GACzBl6B,EAAqB,GACrBm1D,EAAO,EAAGC,EAAU,EACpBnqC,EAAQrvB,MAAMY,QAAQmuB,GACtBza,EAAIjL,EAAEjJ,EAAEiJ,EAAGwF,EAAI,EACf4qD,EAAa,CAAE,EAChBpqC,IAAUN,EAAMza,KAAUya,EAAAza,GAAK,IAClC,IAAI8uB,EAA6BnlC,EAAEy7D,YAAc3qC,EAAM,UAAY,GAC/DoU,EAA6BllC,EAAEy7D,YAAc3qC,EAAM,UAAY,GAC/D,IAAAlgB,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAC5B,KAAKu0B,EAAQv0B,IAAI,CAAA,GAAIs1B,OAGrB,OAFK7F,EAAAzvB,GAAK+e,GAAW/e,GACf5H,EAAAooB,EAAQN,EAAMza,GAAGzF,GAAKkgB,EAAMuP,EAAKzvB,GAAKjF,GACrCyI,GACN,KAAK,EAAGsnB,EAAI9qB,GAAKA,EAAIxF,EAAEjJ,EAAES,EAAG,MAC5B,KAAK,EAAO84B,EAAA9qB,GAAKyvB,EAAKzvB,GAAI,MAC1B,KAAK,EAAG8qB,EAAI9qB,GAAK5Q,EAAEoU,OAAOxD,EAAIxF,EAAEjJ,EAAES,GAAI,MACtC,QAIC,GAHU,MAAPoG,IAAaA,EAAM,CAACf,EAAG,UAAWpE,EAAG,MACxC2K,EAAK7K,EAAIgtB,GAAY3nB,EAAK,KAAMhJ,GACtBu7D,EAAAC,EAAW73D,IAAM,EAEtB,CACD,GAAE6K,EAAK7K,EAAI,IAAO43D,UAAoBC,EAAWhtD,IAAMgtD,EAAW73D,GAAK43D,EAC1EC,EAAWhtD,GAAM,CACtB,MAJ4BgtD,EAAA73D,GAAK,EAK7B+3B,EAAI9qB,GAAKpC,EAGP,IAAA6H,EAAIjL,EAAEjJ,EAAEiJ,EAAIuM,EAAQtB,GAAKjL,EAAE7J,EAAE6J,IAAKiL,EACtC,KAAK6uB,EAAQ7uB,IAAI,CAAA,GAAI6vB,OAArB,CACI,IAAArzB,EAAMkoD,GAAcjqC,EAAO1lB,EAAGiL,EAAGgqB,EAAMjsB,EAAQsnB,EAAKtK,EAAOpxB,KAC3C,IAAhB6S,EAAIooD,UAAkC,IAAX7mD,GAA+B,IAAhBpU,EAAE07D,UAAwB17D,EAAE07D,cAAgBv1D,EAAAm1D,KAAUzoD,EAAIA,IAF3E,CAKvB,OADP1M,EAAI1F,OAAS66D,EACNn1D,CACR,CAEA,IAAIw1D,GAAO,KACX,SAASC,GAAa9qC,EAAqB1lB,EAAaiL,EAAcgqB,EAAwBtvB,EAAe8qD,EAAepzB,EAAezoC,GAGlI,IAFR,IAAIi7D,GAAU,EACVpoD,EAAwB,GAAIipD,EAAM,GAAInwD,EAAK+jB,GAAWrZ,GAClDzF,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAC5B,GAACyvB,EAAKzvB,GAAN,CACJ,IAAI5H,EAAMhJ,EAAEoxB,OAASN,EAAMza,IAAI,IAAIzF,GAAIkgB,EAAMuP,EAAKzvB,GAAKjF,GACpD,GAAO,MAAP3C,EAAmB8yD,EAAA,QACd,GAAS,MAAT9yD,EAAIrF,EAAW,CACZs3D,GAAA,EACJa,EAAA,IAAI97D,EAAEq7D,YAAuB,KAATryD,EAAInF,EAAWmF,EAAIrF,EAAIgtB,GAAY3nB,EAAK,KAAMhJ,IAChE,IAAA,IAAAQ,EAAI,EAAGgK,EAAK,EAAGhK,IAAMs7D,EAAIr7D,SAAUD,EAAG,IAAIgK,EAAKsxD,EAAIp7D,WAAWF,MAAQuQ,GAAMvG,IAAOqxD,GAAa,KAAPrxD,GAAaxK,EAAE+7D,YAAa,CAACD,EAAM,IAAOA,EAAIh7D,QAAQ66D,GAAM,MAAQ,IAAM,KAAM,CACvK,MAAPG,IAAmBA,EAAA,OACzB,MAAqB,MAAT9yD,EAAIoE,GAAcpE,EAAIo0B,EAGnB0+B,EAAA,IAFFb,GAAA,GACVa,EAAM,IAAM9yD,EAAIoE,GAAUhO,QAAQ,MAAQ,IAAS08D,EAAA,IAAMA,EAAIh7D,QAAQ66D,GAAM,MAAQ,MAGpF9oD,EAAIuC,KAAK0mD,EAbK,CAef,OAAmB,IAAhB97D,EAAE07D,WAAuBT,EAAgB,KACrCpoD,EAAIhQ,KAAK4lC,EACjB,CAEA,SAASoyB,GAAa/pC,EAAqBjrB,GAC1C,IAAIM,EAAwB,GACxBnG,EAAY,MAAR6F,EAAe,CAAE,EAAGA,EAC5B,GAAY,MAATirB,GAAkC,MAAjBA,EAAM,QAAwB,MAAA,GAClD,IAAI1lB,EAAIklB,GAAkBQ,EAAM,SAC5B2X,OAAc,IAATzoC,EAAEyoC,GAAmBzoC,EAAEyoC,GAAK,IAAK13B,EAAK03B,EAAG/nC,WAAW,GACzDmmC,OAAc,IAAT7mC,EAAE6mC,GAAmB7mC,EAAE6mC,GAAK,KAAMg1B,EAAKh1B,EAAGnmC,WAAW,GAC1Ds7D,EAAW,IAAInxC,QAAY,KAAJ4d,EAAU,MAAQA,GAAI,MAC7C51B,EAAM,GAAIwtB,EAAyB,GACrCrgC,EAAAoxB,MAAQrvB,MAAMY,QAAQmuB,GAGhB,IAFR,IAAIqU,EAA6BnlC,EAAEy7D,YAAc3qC,EAAM,UAAY,GAC/DoU,EAA6BllC,EAAEy7D,YAAc3qC,EAAM,UAAY,GAC3DlgB,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,GAAUu0B,EAAQv0B,IAAI,IAAIs1B,SAAc7F,EAAAzvB,GAAK+e,GAAW/e,IAEjF,IADR,IAAI3I,EAAI,EACAoO,EAAIjL,EAAEjJ,EAAEiJ,EAAGiL,GAAKjL,EAAE7J,EAAE6J,IAAKiL,GAC3B6uB,EAAQ7uB,IAAI,CAAA,GAAI6vB,QAEX,OADJrzB,EAAA+oD,GAAa9qC,EAAO1lB,EAAGiL,EAAGgqB,EAAMtvB,EAAI8qD,EAAIpzB,EAAIzoC,MAE/CA,EAAEi8D,QAAOppD,EAAMA,EAAI/R,QAAQk7D,EAAS,MACpCnpD,IAAwB,IAAhB7S,EAAE07D,cAA0BtmD,MAAMnN,IAAM4+B,EAAK,IAAMh0B,IAGxD,cADA7S,EAAEoxB,MACFjrB,EAAItD,KAAK,GACjB,CAEA,SAAS+3D,GAAa9pC,EAAqBjrB,GAGyB,OAF/DA,IAAMA,EAAO,CAAA,GAAIA,EAAK4iC,GAAK,KAAM5iC,EAAKghC,GAAK,KACvCg0B,GAAa/pC,EAAOjrB,EAI7B,CAoCA,SAASq2D,GAAe/qC,EAAoBgrC,EAAmBt2D,GAC1D,IAWAmpB,EAXAhvB,EAAI6F,GAAQ,CAAE,EACd8R,IAAW3X,EAAEo8D,WACb/qC,EAAmBF,GAAQ,GAC3BG,EAAK,EAAGC,EAAK,EACd,GAAAF,GAAkB,MAAZrxB,EAAEwxB,OACV,GAAsB,iBAAZxxB,EAAEwxB,SAAyBxxB,EAAEwxB,WAClC,CACA,IAAAC,EAA6C,iBAAZzxB,EAAEwxB,OAAqBvB,GAAYjwB,EAAEwxB,QAAUxxB,EAAEwxB,OACtFF,EAAKG,EAAQrmB,EAAGmmB,EAAKE,EAAQ7uB,CAChC,CAGC,IAAIysB,EAAmB,CAACltB,EAAG,CAACS,EAAE,EAAGwI,EAAE,GAAI7J,EAAG,CAACqB,EAAE2uB,EAAInmB,EAAEkmB,EAAK6qC,EAAG17D,OAAS,EAAIkX,IACrE,GAAA0Z,EAAG,QAAS,CACd,IAAIK,EAASpB,GAAkBe,EAAG,SAC5BhC,EAAA9tB,EAAEqB,EAAIsB,KAAKiI,IAAIkjB,EAAM9tB,EAAEqB,EAAG8uB,EAAOnwB,EAAEqB,GACnCysB,EAAA9tB,EAAE6J,EAAIlH,KAAKiI,IAAIkjB,EAAM9tB,EAAE6J,EAAGsmB,EAAOnwB,EAAE6J,IAC5B,GAAVkmB,IAAiBA,EAAAI,EAAOnwB,EAAE6J,EAAI,EAAGikB,EAAM9tB,EAAE6J,EAAIkmB,EAAK6qC,EAAG17D,OAAS,EAAIkX,EACvE,MACe,GAAV2Z,IAAiBA,EAAA,EAAGjC,EAAM9tB,EAAE6J,EAAI+wD,EAAG17D,OAAS,EAAIkX,GAEpD,IAAI+jB,EAAwB17B,EAAEoU,QAAU,GAAIxD,EAAI,EAE7CurD,EAAAtlC,SAAQ,SAAUwlC,EAAIhmD,GACxByQ,GAAKu1C,GAAIxlC,SAAQ,SAAS3hB,QACrBtE,EAAE8qB,EAAIt8B,QAAQ8V,MAAewmB,EAAA9qB,EAAE8qB,EAAIj7B,QAAUyU,GAC7C,IAAAvR,EAAI04D,EAAGnnD,GACPrR,EAAI,IACJ2sB,EAAI,GACJgO,EAAMjP,GAAY,CAAC3sB,EAAE2uB,EAAK3gB,EAAExF,EAAEkmB,EAAKjb,EAAIsB,IACpCqX,EAAAstC,GAAiBjrC,EAAImN,IACzB76B,GAAkB,iBAANA,GAAoBA,aAAakD,MAGhC,iBAALlD,EAAmBE,EAAA,IACT,kBAALF,EAAoBE,EAAA,IACf,iBAALF,EAAmBE,EAAA,IAC1BF,aAAakD,MAChBhD,EAAA,IACA7D,EAAE+xB,YAAiBluB,EAAA,IAAKF,EAAI+jB,GAAQ/jB,IACnC6sB,EAAAxwB,EAAE2N,QAAUhJ,EAAU,KAEd,OAANhB,GAAc3D,EAAE6xB,YAAiBhuB,EAAA,IAASF,EAAA,GAC9CqrB,GAEHA,EAAKnrB,EAAIA,EAAGmrB,EAAKrrB,EAAIA,SACdqrB,EAAK/mB,SAAU+mB,EAAK3Y,EACxBma,MAAQA,EAAIA,IAJHa,EAAAmN,GAAOxP,EAAQ,CAACnrB,IAAKF,KAM/B6sB,MAAQA,EAAIA,IAjBfa,EAAGmN,GAAO76B,CAmBd,GACA,IACO0rB,EAAA9tB,EAAEqB,EAAIsB,KAAKiI,IAAIkjB,EAAM9tB,EAAEqB,EAAG2uB,EAAKmK,EAAIj7B,OAAS,GAC9C,IAAAkxB,EAAMjC,GAAW4B,GAClB,GAAA3Z,MAAY/G,EAAI,EAAGA,EAAI8qB,EAAIj7B,SAAUmQ,EAAMygB,EAAA1B,GAAW/e,EAAI2gB,GAAMI,GAAO,CAAC9tB,EAAE,IAAKF,EAAE+3B,EAAI9qB,IAEjF,OADJygB,EAAA,QAAUlB,GAAad,GACnBgC,CACR,CAIA,SAASirC,GAAiBjrC,EAAkBhb,EAAGzF,GAE3C,GAAY,iBAALyF,EAAe,CAErB,GAAAtU,MAAMY,QAAQ0uB,GAAK,CACjB,IAAAkrC,EAAKtsC,GAAY5Z,GAErB,OADIgb,EAAGkrC,EAAGnxD,KAAOimB,EAAAkrC,EAAGnxD,GAAK,IAClBimB,EAAGkrC,EAAGnxD,GAAGmxD,EAAG35D,KAAOyuB,EAAGkrC,EAAGnxD,GAAGmxD,EAAG35D,GAAK,CAACiB,EAAE,KACjD,CACS,OAAAwtB,EAAGhb,KAAOgb,EAAGhb,GAAK,CAACxS,EAAE,KAC9B,CAEI,OAA6By4D,GAAiBjrC,EAAI9B,GAAtC,iBAALlZ,EAAuDA,EAEzB,CAACjL,EAAEiL,EAAEzT,EAAEgO,GAAG,IACnD,CA8DA,SAAS4rD,GAAmBxtC,EAAeusB,EAAmBsF,GAOtD,OANHtF,GAGEvsB,EAAAzhB,EAAK,CAAEqrB,OAAQ2iB,GACjBsF,IAAc7xB,EAAAzhB,EAAEmxB,QAAUmiB,WAHtB7xB,EAAKzhB,EAKNyhB,CACR,CA0BA,IAAI1L,GAAgB,CACnBqM,cACAD,cACAH,eACAY,gBACAL,cACAF,cACA6sC,WAjxnBD,SAAoBpjD,GAAqC,OAAOA,EAAKvY,QAAQ,sBAAsB,SAASsB,MAAM,IAAK,EAkxnBtH6tB,eACAC,gBACAS,eACAO,iBACAgrC,kBACA5N,iBACAr8B,gBACAyqC,cAjID,SAAuBP,EAAmBt2D,GAA6B,OAAAq2D,GAAe,KAAMC,EAAIt2D,EAAM,EAkIrG82D,eAAgBvN,GAChBwN,cAvvGD,SAAuBhvD,EAAuB/H,GAC7C,OAAOgrB,GAAkBu+B,GAAgBxhD,EAAO/H,GAAOA,EACxD,EAsvGCg1D,gBACAD,gBACAz6B,iBACAiuB,iBACAyO,kBAtOD,SAA2B/rC,GACtB,IAAQrxB,EAAR6G,EAAI,GAAO0C,EAAI,GACnB,GAAY,MAAT8nB,GAAkC,MAAjBA,EAAM,cAAwB,GAC9C,IAA4ElgB,EAA5ExF,EAAIklB,GAAkBQ,EAAM,SAAUnlB,EAAK,GAAI00B,EAAyB,GACxEy8B,EAAyB,GACzB1rC,EAAQrvB,MAAMY,QAAQmuB,GAC1B,IAAIlgB,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAAGyvB,EAAKzvB,GAAK+e,GAAW/e,GAC7C,IAAA,IAAAyF,EAAIjL,EAAEjJ,EAAEiJ,EAAGiL,GAAKjL,EAAE7J,EAAE6J,IAAKiL,EAE5B,IADJ1K,EAAK+jB,GAAWrZ,GACZzF,EAAIxF,EAAEjJ,EAAES,EAAGgO,GAAKxF,EAAE7J,EAAEqB,IAAKgO,EAI5B,GAHItK,EAAA+5B,EAAKzvB,GAAKjF,EAER3C,EAAA,QACG,KAFLvJ,EAAA2xB,GAASN,EAAMza,IAAI,IAAIzF,GAAKkgB,EAAMxqB,IAEtC,CACQ,GAAO,MAAP7G,EAAE29B,EAAW,CAEjB,GADH92B,EAAI7G,EAAE29B,GACF39B,EAAE2N,EAAG,SACTpE,EAAMvJ,EAAE2N,GACiB,GAAtB9G,EAAElH,QAAQ,OAAYkH,EAAIA,EAAI,IAAMA,EAC3C,CACG,GAAU,MAAP7G,EAAE2N,EAAWpE,EAAMvJ,EAAE2N,MAChB,IAAO,KAAP3N,EAAEoE,EAAU,SACZ,GAAO,KAAPpE,EAAEoE,GAAmB,MAAPpE,EAAEkE,EAAWqF,EAAM,GAAKvJ,EAAEkE,OAAA,GACjC,KAAPlE,EAAEoE,EAAgBmF,EAAAvJ,EAAEkE,EAAI,OAAS,aAAA,QACzB,IAARlE,EAAEwI,EAAiBe,EAAM,IAAMvJ,EAAEwI,MACjC,SAAQ,IAARxI,EAAEkE,EAAiB,SACPqF,EAAL,KAAPvJ,EAAEoE,EAAgB,IAAMpE,EAAEkE,EACvB,GAAGlE,EAAEkE,CAAA,EAChBm5D,EAAKA,EAAKr8D,QAAU6F,EAAI,IAAM0C,CATjC,CAYQ,OAAA8zD,CACR,EAuMCC,0BAA2B58B,GAC3B68B,eAAgBV,GAChBW,SA1GD,WACC,MAAO,CAAEjsC,WAAY,GAAIC,OAAQ,CAAA,EAClC,EAyGCisC,kBAtGD,SAA2Bp/B,EAAiBzM,EAAkB3b,EAAkBynD,GAC/E,IAAI38D,EAAI,EACR,IAAIkV,EAAM,KAAMlV,GAAK,QAAmF,GAAjDs9B,EAAG9M,WAAW5xB,QAAQsW,EAAO,QAAUlV,KAA/DA,EAAGkV,OAAO,GACtC,IAACA,GAAQooB,EAAG9M,WAAWvwB,QAAU,MAAQ,MAAM,IAAImI,MAAM,uBAC5D,GAAGu0D,GAAQr/B,EAAG9M,WAAW5xB,QAAQsW,IAAS,EAAG,CACxC,IAAAnP,EAAImP,EAAKhM,MAAM,gBACnBlJ,EAAI+F,IAAMA,EAAE,IAAM,EAClB,IAAIoM,EAAOpM,GAAKA,EAAE,IAAMmP,EACxB,MAAMlV,EAAGA,GAAK,QAA8D,GAA9Cs9B,EAAG9M,WAAW5xB,QAAQsW,EAAO/C,EAAOnS,KAA1CA,GAC1B,CAEI,GADHyjD,GAAcvuC,GACXooB,EAAG9M,WAAW5xB,QAAQsW,IAAS,EAAG,MAAM,IAAI9M,MAAM,wBAA0B8M,EAAO,qBAI/E,OAFJooB,EAAA9M,WAAW5b,KAAKM,GAChBooB,EAAA7M,OAAOvb,GAAQ2b,EACX3b,CACR,EAuFC0nD,0BApFD,SAAmCt/B,EAAiBu/B,EAAsBC,GACrEx/B,EAAG2gB,WAAU3gB,EAAG2gB,SAAW,CAAE,GAC7B3gB,EAAG2gB,SAASxtB,SAAW6M,EAAA2gB,SAASxtB,OAAS,IAEzC,IAAAxnB,EAxCL,SAAsBq0B,EAAiBu/B,GACnC,GAAa,iBAANA,EAAgB,CACzB,GAAGA,GAAM,GAAKv/B,EAAG9M,WAAWvwB,OAAS48D,EAAW,OAAAA,EAC1C,MAAA,IAAIz0D,MAAM,uBAAyBy0D,EAC3C,CAAA,GAAwB,iBAANA,EAAgB,CAChC,IAAI5zD,EAAMq0B,EAAG9M,WAAW5xB,QAAQi+D,GAC7B,GAAA5zD,KAAiB,OAAAA,EACpB,MAAM,IAAIb,MAAM,2BAA6By0D,EAAK,IAClD,CAAY,MAAA,IAAIz0D,MAAM,sBAAwBy0D,EAAK,IACrD,CA+BWE,CAAaz/B,EAAIu/B,GAI3B,OAFIv/B,EAAG2gB,SAASxtB,OAAOxnB,KAAMq0B,EAAG2gB,SAASxtB,OAAOxnB,GAAO,CAAE,GAElD6zD,GACN,KAAK,EAAG,KAAK,EAAG,KAAK,EAAG,MACxB,QAAe,MAAA,IAAI10D,MAAM,gCAAkC00D,GAG5Dx/B,EAAG2gB,SAASxtB,OAAOxnB,GAAKk7C,OAAS2Y,CAClC,EAuECE,uBApED,SAAgCxuC,EAAejmB,GAEvC,OADPimB,EAAKwB,EAAIznB,EACFimB,CACR,EAkECwtC,sBACAiB,uBAvDD,SAAgCzuC,EAAeK,EAAkBwxB,GAAuB,OAAO2b,GAAmBxtC,EAAM,IAAMK,EAAOwxB,EAAS,EAwD7I6c,iBArDD,SAA0B1uC,EAAevM,EAAiBk7C,GACrD3uC,EAAKpsB,IAAGosB,EAAKpsB,EAAI,IAChBosB,EAAApsB,EAAEwS,KAAK,CAACvR,EAAE4e,EAAMxF,EAAE0gD,GAAQ,WAChC,EAmDCC,wBAhDD,SAAiCvsC,EAAkBhC,EAAOwW,EAAoBg4B,GAGrE,IAFR,IAAIC,EAAsB,iBAATzuC,EAAoBA,EAAQiB,GAAkBjB,GAC3D0uC,EAAyB,iBAAT1uC,EAAoBA,EAAQc,GAAad,GACrDhZ,EAAIynD,EAAI37D,EAAEiJ,EAAGiL,GAAKynD,EAAIv8D,EAAE6J,IAAKiL,UAAWzF,EAAIktD,EAAI37D,EAAES,EAAGgO,GAAKktD,EAAIv8D,EAAEqB,IAAKgO,EAAG,CAC/E,IAAIoe,EAAOstC,GAAiBjrC,EAAIhb,EAAGzF,GACnCoe,EAAKnrB,EAAI,IACTmrB,EAAKoO,EAAI2gC,SACF/uC,EAAKrrB,EACT0S,GAAKynD,EAAI37D,EAAEiJ,GAAKwF,GAAKktD,EAAI37D,EAAES,IAC7BosB,EAAK5hB,EAAIy4B,EACNg4B,MAAc94D,GAAI,GAExB,CACQ,OAAAssB,CACR,EAmCCtW,OAAQ,CACPijD,cAAe,EACfC,aAAc,EACdC,kBAAmB,IC78uBd,MAAMC,GAAgB,EAAG/pD,SAAQgqD,YAAWC,eAElD,MAMMC,EAAY,CANFlqD,EAAO/R,KAAI2tB,GAAOA,EAAIuuC,WAEzBH,EAAU/7D,KAAWwQ,GAC1BuB,EAAO/R,KAAI2tB,GAAOnd,EAAImd,EAAI4L,WAK5BvK,EAAKmtC,GAAWvsC,aAAaqsC,GAC7BxgC,EAAK0gC,GAAWvB,WACX35C,GAAA45C,kBAAkBp/B,EAAIzM,EAAI,UDyhuBtC,SAAuByM,EAAiB3sB,GACvC,IAAInR,EAAU,CAAIA,KAAS,QAC3BA,EAAEwS,KAAOrB,EAhBV,SAA2BnR,GAC1B,IAAGA,EAAE22B,SAAL,CACA,IAOInU,EAAMxiB,EAAEwS,KAAKnP,MAAMrD,EAAEwS,KAAK5F,YAAY,MAAMqB,cAC7CuU,EAAI9Y,MAAM,kBAAiBitB,SAAWnU,EAAInf,MAAM,IACnDrD,EAAE22B,SATQ,CACT8nC,IAAO,QACP18C,IAAO,OACP28C,IAAO,OACPC,WAAc,MACdC,QAAW,OAIK5+D,EAAE22B,WAAa32B,EAAE22B,QAVnB,CAWhB,CAKCkoC,CAAkB7+D,GACX06D,GAAU58B,EAAI99B,EACtB,CC3huBgBgkB,CAAA8Z,EAAI,GAAGugC,SAAe,ECpaL,SAAAS,GAAA38D,GAAA,MAAA,mBAAAA,GAAA48D,oBAAAvmD,OAAAyO,UAAAve,SAAApF,KAAAnB,KAAA48D,EAAAA,QAAA58D,EAAA,qQACjC,MAAMm8C,EAAQ0gB,EACRC,EAAQC,EAAAA,WACRC,EAAQC,EAAAA,WACRC,EAAW7gC,EAAAA,MACX8gC,EAAe9gC,EAAAA,MACf+gC,EAAU/gC,EAAGA,IAAgB,IAE7BghC,EAAchhC,EAAGA,KAAC,GAClBihC,EAAiBjhC,EAAGA,IAAoC,IACxDkhC,EAAOC,EAKbC,EAAAA,WAAU,KACTC,EAAAA,UAAS,KACGC,GAAA,GACX,IAEFC,SACC,IAAMzhB,EAAMihB,UACZ,KACYS,GAAA,IAGbC,EAAAA,eAAc1hE,gBACPyhE,GAAW,IAElB,MAAMA,EAAYzhE,UACT28B,EAAAA,MAAiC,mBAAlBojB,EAAMihB,cAA+BjhB,EAAMihB,UAAYjhB,EAAMihB,QAC5ErkC,EAAAA,MAAMrE,SAA8B7G,YACtCA,EAAIkwC,aACL,CAAC,SAAU,YAAYC,SAASnwC,EAAIkwC,cAAelwC,OAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAKowC,aAALpwC,EAAAA,EAAaqwC,cACnEA,EAAYrwC,EAAIowC,SAEbpwC,EAAIswC,WAAYtwC,OAAAA,EAAIuwC,EAAAA,gBAAO9/D,WAC9B++D,EAAYtkC,OAAQ,GACrB,IAEGskC,EAAYtkC,OACLslC,GACX,EAGKH,EAAc9hE,MAAO6hE,KACtBA,MAAAA,OAAAA,EAAAA,EAAQ3tD,UAAsC,KAA3B2tD,MAAAA,OAAAA,EAAAA,EAAQ3tD,QAAQhS,UAAgB2/D,MAAAA,OAAAA,EAAAA,EAAQC,cAA8C,mBAAhBA,MAARD,OAAQC,EAAAA,EAAAA,eACrF5tD,EAAAA,cAAwB4tD,MAARD,OAAQC,EAAAA,EAAAA,eAChC,EAEKP,EAAYA,aACb,IAACxhB,EAAM3lC,KAAM,OACjB,MAAM8nD,EAAUpB,OAAAA,EAAAA,OAASnkC,EAAAA,EAAAA,YAAOwlC,EAAAA,EAAAA,cAAKC,cAAc,yBAC3CC,EAAAC,SAACpoD,OAAOgoD,EAAS,CACxBK,UAAW,IAEXnoD,MAAM,EACNooD,OAAQziB,EAAM0iB,WAAa,IAAI1iB,EAAM0iB,aAAe,KACpDC,MAAOA,EAAGC,WAAUC,eACdzB,EAAA,WAAYwB,EAAUC,EAAQ,GAEpC,EAmDIC,EAAaA,CAACxlC,EAAWlH,EAAe2sC,IAC7CC,EAAAC,YAAAC,mBAAA,gBAAA,CAAA5lC,KACqB,aAAelH,EAAQ,IAAMkH,EAAI2kC,MAASd,EAAevkC,MAAMU,IAAKkjC,GACtFuC,GAAAA,EAAS,CAAAI,QAAAA,IAAA,CAATJ,KAKEb,EAAWA,KAChB,MAAMD,EAA2C,CAAE,EAC/C,IAACf,EAAYtkC,MAAO,OACxB,MAAMwmC,EAAoCrP,IACrC,IAACA,EAAKz2B,KAAM,OACV+lC,MAAAA,SAAWtP,WAAM6N,aAAc,CAAC,SAAU,YAAYC,SAAS9N,MAAAA,OAAAA,EAAAA,EAAM6N,YACrE0B,EAAc,CAAEtB,UAAU,EAAMz5C,QAAS,GAAGwrC,EAAKkM,OAAS,YAAasD,QAASF,EAAW,SAAW,QACxGtP,EAAKiO,WACRC,EAAMlO,EAAKz2B,MAAQ,CAACgmC,IAEjBvP,EAAKkO,OAASlO,EAAKkO,MAAM9/D,OAAS,IACrC8/D,EAAMlO,EAAKz2B,MAAQ,IAAK2kC,EAAY3kC,MAANy2B,OAAMz2B,EAAAA,EAAAA,OAAS,MAAQy2B,EAAKkO,OAC3D,EAEDhB,EAAQrkC,MACNo6B,QAAgBtmC,KAAAA,MAAAA,OAAAA,EAAAA,EAAMkxC,cAAclxC,MAAAA,OAAAA,EAAAA,EAAM8yC,YAAY9yC,MAAAA,OAAAA,EAAAA,EAAMsxC,YAAYtxC,MAAAA,OAAAA,EAAAA,EAAMuxC,UAC9E1pC,SAAuBkrC,UACvBA,OAAKlT,EAAAA,EAAAA,aAAUh4B,QAAQ6qC,GACvBA,EAAWK,EAAI,IAEjBtC,EAAevkC,MAAQqlC,CAAAA,EASlBuB,EAAUxjB,IAAwB0jB,IAAAA,EACjC,MAAAC,OAAEA,EAAAA,UAAQ7D,EAAAA,SAAW8D,GAAa5jB,EAIlC6jB,EAAgB5C,GACdA,EACLjK,QAAetmC,IAACA,EAAKjxB,MAAQixB,EAAKjxB,KAAKixB,KACvC3sB,KAA2B2sB,IACrB,MAAA6/B,SAAEA,KAAauT,GAAapzC,EAClC,OAAAsyC,cAAAE,EAAAA,iBAAA,mBACsBY,EAAQ,CAE3BX,QAAyBY,IAExB,GAAyB,mBAArBrzC,WAAMkxC,YAAiCoC,OAAAA,EAActzC,EAAMqzC,GAE/D,IAAUnC,MAANlxC,OAAMkxC,EAAAA,EAAAA,aAAmC,aAAfA,MAANlxC,OAAMkxC,EAAAA,EAAAA,YACtBqC,MAvGSA,EAACC,GAAuBC,SAAQ5vD,UAAe6vD,IAAAA,EACjE,MAAAxC,WAAEA,EAAAA,MAAYyC,EAAQ,CAAE,EAAA/mC,KAAEA,EAAAA,MAAM2iC,EAAAA,OAAO6B,EAAS,CAAE,EAAAE,SAAEA,EAAAA,MAAUC,GAAUiC,EAC9E,IAAK5mC,IAASskC,EAAmB,OAAA,KACjC,MAAM0C,EAAYC,EAAAA,iBAAiB,MAAQ3C,IACrCztD,QAAEA,EAAU,MAAOqwD,GAAe1C,EAiBxC,GAAmB,aAAfF,EACH,OAAAoB,cAAAE,EAAAA,iBAAA,eAAAuB,EAAAA,WAAA,CAAAC,WAA6BnwD,EAAI+oB,GAAK,sBAAAqnC,GAATpwD,EAAI+oB,GAAKqnC,EAAAC,YAAe,MAAM3E,IAAO9rD,QAAWA,GAAakwD,EAAWG,GAAU,MAGhH,MAAMnB,EAAW,CAAC,SAAU,YAAYxB,SAASD,GAE3CiD,EAAa7C,IAAmB7/D,MAAP8/D,OAAO9/D,EAAAA,EAAAA,QAChCuiE,EAAanwD,EAAI+oB,GAKjBylC,EAASC,EAAAA,YAAAsB,EAAAG,aAAA,CAAAC,WAEDA,EAAU,sBANeh6D,IAEtC6J,EAAI+oB,GAAyB,YAAjBwkC,MAAAA,OAAAA,EAAAA,EAAQt3D,MAAoBggB,OAAO9f,GAAOA,CAAAA,EAKhBk6D,YACxB,IAAIvB,EAAW,KAAO,OAAOpD,KACtCoE,EACAG,GAAUhE,GAAA4D,EAhCVjwD,GAA8B,IAAnBA,EAAQhS,OACL,WAAfy/D,EACIztD,EAAQpQ,KAAci/D,GAAAA,EAAAA,YAAAE,EAAAA,iBAAA,aAAA,CAAAjD,MAAuBlM,EAAKkM,MAAKrjC,MAASm3B,EAAKn3B,MAAK7T,IAAOgrC,EAAKn3B,OAAK,QAEhF,gBAAfglC,EACIztD,EAAQpQ,KAAci/D,GAAAA,EAAAA,YAAAE,EAAAA,iBAAA,YAAA,CAAAjD,MACXlM,EAAKn3B,MAAK7T,IAAOgrC,EAAKn3B,OAAK,CAAAumC,QAAAA,IAC1CpP,CAAAA,EAAKkM,WAIF,KAXsC,MAkCrBmE,EAAA,CAAAjB,QAAAA,IAAA,CAAAiB,KAGrB,OAACS,EAEE/B,EAAWxlC,EAAM6mC,EAAQpB,GAFRA,CAEiB,EAyD1BkB,CAAiBvzC,EAAMqzC,GAG/B,SAAIrzC,WAAM8yC,OAAQ,CACjB,MAAMsB,EAAep0C,EAAK8yC,OAAOO,EAAMxvD,IAAKwvD,EAAMI,OAAQzzC,GAEpDq0C,EAAkBr0C,EAAKsxC,UAAYtxC,EAAKuxC,MAExC+C,EAAa,CAAC,SAAU,UAAUnD,sBAAgBiD,WAAct6D,OAEtE,OAAIu6D,GAAmBC,EACflC,EAAWpyC,EAAK4M,KAAMymC,EAAMI,OAAQW,GAErCA,CACR,CAEA,OAAIvU,IAAsBpuD,MAAVouD,OAAUpuD,EAAAA,EAAAA,QAAS,EAAU0hE,EAAatT,IAE7C0U,MAANv0C,OAAMu0C,EAAAA,EAAAA,WAjCAC,EAACx0C,EAAmBqzC,WAAerzC,OAAAA,EAAKu0C,WAAYtE,OAAAA,EAAAA,EAAMjwC,EAAKu0C,gBAAYlB,EAAAA,EAAAA,KAAAA,EAAAA,GAAAA,EAiC/DmB,CAAYx0C,EAAMqzC,EAAK,EAEjDjuD,OAAwBiuD,YAEvB,aAAIrzC,WAAMsxC,UACTgB,EAAAA,YAAA,OAAA,CAAAmC,MAAA,2BAAA,CAAAnC,EAAAC,YAAA,OAAA,CAAAkC,MAAA,gBAAAC,CAAAA,EAAAA,yBAGGrB,OAAAA,EAAOG,MAAAA,OAAAA,EAAAA,EAAAA,aAAQjE,EAAAA,EAAAA,QAAS,MAKlBoF,MAAN30C,OAAM20C,EAAAA,EAAAA,cAAqB30C,MAAAA,OAAAA,EAAAA,EAAM20C,aAAatB,EAAMxvD,YAEpDmc,WAAM40C,gBAAuB3E,OAAAA,EAAMjwC,EAAAA,MAAAA,OAAAA,EAAAA,EAAM40C,sBAAkBvB,EAAAA,EAAAA,KAAAA,EAAAA,QAA/D,CAA+DA,GAChE,IAOAC,EAAgBA,CAACtzC,EAAmBqzC,aACzCf,OAAAA,EAAAA,YAAA,MAAA,CAAAmC,MACa,2DAA0Dz0C,OAAAA,EAAAA,EAAKoxC,aAALpxC,EAAAA,EAAa60C,YAAa,MAC9F70C,CAAAA,OAAAA,EAAAA,EAAK80C,cAAL90C,EAAAA,EACEsmC,QAAayO,IAACA,EAAGhmE,MAAQgmE,EAAGhmE,KAAKskE,EAAMxvD,OACxCxQ,KAAU0hE,IACNA,MAAAA,OAAAA,EAAAA,EAAIjC,QAAeiC,EAAGjC,OAAOO,EAAMxvD,IAAKwvD,EAAMI,QAClDnB,EAAAA,YAAA,OAAA,CAAA0C,QAEWC,EAAaA,eAAC,MAClBD,MAAAA,OAAAA,EAAAA,EAAAA,WAAeA,MAAJD,GAAIC,EAAAA,QAAQ3B,EAAMxvD,MACjC6sD,EAAK,iBAAkBqE,EAAG18C,IAAKg7C,EAAMxvD,IAAKwvD,EAAMI,OAAM,GACpD,CAAC,SAAQgB,MACL,mCAAsCI,MAAJE,OAAIF,EAAAA,EAAAA,YAAa,MAEzDE,CAAAA,EAAGxF,WAGL,EA8BF,GAACgB,EAAQrkC,MACb,OAAAomC,EAAAC,YAAA2C,WAEG1E,KAAAA,CAAAA,EAAYtkC,MAAKomC,EAAAC,YAAAC,mBAAA,WAAA,CAAA2C,MACD7lB,EAAK9f,IAAO8gC,GAAYR,GAAAkD,EACtCoC,KAAapC,EAAA,CAAAP,QAAAA,IAAA,CAAAO,KAGfoC,IAjCgBC,MACd,IAACnC,EAAiB,OAAA,KAOtBZ,OAAAA,EAAAA,YAAA,MAAA,CAAAmC,MAAA,mBAAAnC,CAAAA,EAAAC,YAAAC,mBAAA,iBAAA,CAAA8C,YAGwBpC,EAASqC,UAAS,uBAAlBrC,GAAAA,EAASqC,UAAStB,EAAAuB,SACrBtC,EAASsC,SAAQ,oBAAjBtC,GAAAA,EAASsC,SAAQvB,EAAAwB,OAC5B,EAAKC,UACF,EAAK,aACH,CAAC,GAAI,GAAI,GAAI,KAAIC,QACrBzC,MAAAA,OAAAA,EAAAA,EAAUyC,QAASzC,MAAAA,OAAAA,EAAAA,EAAUyC,OAAS,gCAA+BC,YACjE,EAAKC,MACV3C,EAAS2C,MAAKC,aAhBgBvjE,IAClCm+D,EAAA,cAAe,WAAYn+D,EAAC,EAgBDwjE,gBAdUxjE,IACrCm+D,EAAA,cAAe,YAAan+D,EAAC,GAcI,OAAA,EAerC8iE,KAIH,SAASD,IAAcY,IAAAA,EACtB,OAAA1D,cAAAE,EAAAA,iBAAA,YAAAuB,EAAAA,WAAA,CAAAvkC,IACgB6gC,GAAcF,EAAK,CAAA,UAAW8C,EAAMv/D,KAAQ07D,IAASU,GAAAkG,EAClE7C,EAAa5C,EAAQrkC,QAAM8pC,EAAA,CAAAvD,QAAAA,IAAA,CAAAuD,IAG/B,UAYYvmE,EAAA,CACZ4gE,WACA4F,kBAZgD5G,IAChD,MAAMjqD,EAASmrD,EAAQrkC,MAAMo6B,QAAOtmC,GAAQA,EAAK4M,OAC3CwiC,EAAY9f,EAAM8f,UACVD,GAAA,CAAE/pD,SAAQgqD,YAAWC,SAAUA,GAAYx3D,KAAKyR,OAAO,EAUrE4sD,cAPqB3mE,MAAO4mE,IACvB5F,EAAQrkC,QACbqkC,EAAQrkC,MAA8B,mBAAfiqC,QAAkCA,IAAeA,EAAAA,EAMxEC,kBApJyB7mE,SACpBihE,EAAYtkC,MACZokC,EAAapkC,YACLokC,EAAapkC,MAAMmqC,UAAS,IAAMC,QAAQC,YADvBD,QAAQC,SAAQ,GADjBD,QAAQC,SAAQ,8EC5K1CC,GAAa,CACjBlvC,MAAO,6BACPmvC,QAAS,iBAWX,MAAeC,GAAA,CAAE5D,OARV,SAAgB6D,EAAMC,GAC3B,OAAQC,EAAUC,YAAIC,EAAmBC,mBAAC,MAAOR,GAAYI,EAAO,KAAOA,EAAO,GAAK,CACrFK,EAAAA,mBAAoB,OAAQ,CAC1BniE,KAAM,eACNF,EAAG,m6BACF,MAAQ,KAEf,GCAoD,SAAAk7D,GAAA38D,GAAA,MAAA,mBAAAA,GAAA48D,oBAAAvmD,OAAAyO,UAAAve,SAAApF,KAAAnB,KAAA48D,EAAAA,QAAA58D,EAAA,8OACpD,MAAM+jE,EAAW1nC,EAAGA,IAAyB,IACvC2nC,EAAY3nC,EAAGA,IAAoC,IACnD4nC,EAAa5nC,EAAGA,IAAa,IAG7B6nC,EAAW9nE,gBACV,MAAA+nE,SAAEA,EAAAA,WAAUC,GAAejoB,EAG7B,GADJ8nB,EAAWlrC,MAA4B,mBAAborC,QAAgCA,IAAaA,GAClEvkE,MAAMY,QAAQyjE,EAAWlrC,QAAsC,IAA5BkrC,EAAWlrC,MAAMz6B,OAExD,OAGD,MAAM+lE,EAAmC,CAAE,EAErCC,EAA8BpU,IAbTvpD,MActBupD,EAAKz2B,QAAUy2B,EAAKz2B,QAAQ4qC,KACnBnU,EAAAA,EAAKz2B,MAAQ,OAEGskC,MAAN7N,OAAM6N,EAAAA,EAAAA,aAjB4B,CAAC,SAAU,YAAYC,SAASr3D,IAkBxFu3D,EAAYhO,GAETtwD,MAAMY,QAAQ0vD,EAAKxD,WACjBA,EAAAA,SAASh4B,QAAQ4vC,GAGvBC,EAAkBrU,EAAI,EAIvB,GAFA+T,EAAWlrC,MAAMrE,SAAgB4vC,GAAAA,EAAapU,KAE1CkU,GAAc/tD,OAAOsO,KAAKy/C,GAAY9lE,OAAS,EAClD,GAAIkmE,IACQtU,IAAAA,MAAAA,KAAQ+T,EAAWlrC,MAAO,CAChC,IAACm3B,EAAKz2B,KAAM,UACMy2B,OAAAA,IAAK+N,aAAL/N,EAAAA,EAAagO,cAAkD,mBAA5BhO,EAAK+N,OAAOC,kBAEpBuG,IAA1BL,EAAWlU,EAAKz2B,QACtCsqC,EAAShrC,MAAMm3B,EAAKz2B,MAAQ2qC,EAAWlU,EAAKz2B,MAE9C,MAGAsqC,EAAShrC,MAAQqrC,OAIlBL,EAAShrC,MAAQsrC,CAClB,EAGKE,EAAmCrU,YACxC,KAAKA,OAAAA,EAAK+N,EAAAA,aAAQyG,EAAAA,EAAAA,qBAAexU,WAAMyU,gBAAgB,OACjDD,MAAAA,EAAcxU,EAAK+N,OAAOyG,YAC1BE,EAAiB1U,OAAAA,EAAKsQ,EAAAA,YAAOqE,EAAAA,EAAAA,SAgBnC3U,EAAKsQ,MAAQ,IACTtQ,EAAKsQ,MACRqE,SAjBmBzoE,MAAOgD,UAG1B,MAAM0lE,EAAuBb,EAAWlrC,MAAMljB,MAAoB+pD,IAAAA,MAAAA,OAAAA,EAAAA,EAAMnmC,QAASirC,IAE7E,IAACI,KAAeA,OAAAA,QAAAA,WAAY7G,aAAZ6G,EAAAA,EAAoB5G,aAAa,OACrD,MAAM5tD,QAAgBw0D,EAAW7G,OAAOC,YAAY9+D,GAEpD0lE,EAAW7G,OAAO3tD,QAAUA,EAEE,mBAAnBs0D,GACVA,EAAexlE,EAChB,GAQD8wD,EAAKyU,gBAAiB,CAAA,EAGjBH,EAAiBA,IACfP,EAAWlrC,MAAMs6B,MAASnD,UAAIA,OAAAA,OAAAA,EAAAA,EAAK+N,aAAQC,EAAAA,EAAAA,cAAkD,mBAA5BhO,EAAK+N,OAAOC,WAAgB,IAG/FA,EAAc9hE,OAAS6hE,SAAQxkC,iBAEhC,IAACwkC,GAAUA,EAAO8G,mBAAoB,OACpC,MAAE7G,YAAAA,EAAAA,QAAa5tD,GAAY2tD,EACjC,IAAK3tD,GAAkC,mBAAhB4tD,EAA4B,OAC7C,MAAAkG,WAAEA,GAAejoB,EAEjB6oB,EAAaf,OAAAA,EAAAA,EAAWlrC,MAAMljB,gBAAoBq6C,OAAAA,OAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAM+N,aAAN/N,EAAAA,EAAcwU,eAAgBjrC,CAAAA,UAAOA,EAAAA,EAAAA,KACvFwrC,EAAcD,EAAaZ,MAAAA,OAAAA,EAAAA,EAAaY,QAAcP,EACxD,IACIn0D,EAAAA,cAAgB4tD,EAAY+G,GAE/BxrC,UAAQ2qC,WAAa3qC,MACxBsqC,EAAShrC,MAAMU,GAAQ2qC,EAAW3qC,GAEnC,OAAQp9B,GAET,GAGKygE,EAAQC,EAAAA,WACRC,EAAQC,EAAAA,WACR9gB,EAAQ0gB,EAUde,EAAAA,OACC,IAAMzhB,EAAMgoB,WACAA,IACPA,EAAS7lE,OAAS,IAEX4lE,IACA7F,IACX,IAIFT,EAAAA,OACC,IAAMzhB,EAAMioB,aACEA,IACTA,GAEOF,GACX,IAKF,MAAM7F,EAAWA,WAChB,MAAMD,EAA2C,CAAE,EACnD,KAAK6F,OAAAA,EAAAA,EAAWlrC,YAAXkrC,EAAAA,EAAkB3lE,QAAQ,OAC/B,MAAMihE,EAAiCrP,IAClC,IAACA,EAAKz2B,KAAM,OACV+lC,MAAAA,SAAWtP,WAAM6N,aAAc,CAAC,SAAU,YAAYC,SAAS9N,MAAAA,OAAAA,EAAAA,EAAM6N,YACrE0B,EAAc,CAAEtB,UAAU,EAAMz5C,QAAS,GAAGwrC,EAAKkM,OAAS,YAAasD,QAASF,EAAW,SAAW,QACxGtP,EAAKiO,WACRC,EAAMlO,EAAKz2B,MAAQ,CAACgmC,IAEjBvP,EAAKkO,OAASlO,EAAKkO,MAAM9/D,OAAS,IACrC8/D,EAAMlO,EAAKz2B,MAAQ,IAAK2kC,EAAY3kC,MAANy2B,OAAMz2B,EAAAA,EAAAA,OAAS,MAAQy2B,EAAKkO,OAC3D,EAEUrlC,EAAAA,MAAMrE,SAAuBkrC,UACvCA,OAAAA,EAAAA,EAAKlT,WAALkT,EAAelrC,QAAQ6qC,GACvBA,EAAWK,EAAI,IAEhBoE,EAAUjrC,MAAQqlC,CAAAA,EAInBN,EAAAA,eAAc1hE,UACT+/C,EAAMgoB,iBACHD,IACI7F,IACX,IAED6G,EAAAA,aAAY,SAGNC,MAAAA,EAAU9oC,EAAAA,MACV+oC,EAAeA,KACd,MAAAC,UAAEA,GAAclpB,GAChBzrC,IAAEA,EAAAA,IAAK40D,KAAQppC,GAAUmpC,EACxB,MAAA,CACN,wBAAyB,UAAU30D,UACnC,WAAY40D,KACTppC,EACH,EAGIqpC,EAA2CC,IAC5C,IAACA,EAAY,MAAO,CAAE,EACpB,MAAA90D,IAAEA,EAAAA,IAAK40D,KAAQppC,GAAUspC,EACxB,MAAA,CACN,wBAAyB,UAAU90D,UACnC,WAAY40D,KACTppC,EACH,EAGIyjC,EAAUxjB,UAAuBokB,IAAAA,EAChC,MAAA8E,UAAEA,EAAAA,WAAWI,GAAetpB,EAClC,KAAK8nB,OAAAA,EAAAA,EAAWlrC,YAAXkrC,EAAAA,EAAkB3lE,QAAQ,OA0F/B,OAAA6gE,EAAAC,YAAA2C,EAAA2D,SAAA,KAAA,CAAAvG,EAAAC,YAAAC,8BAAAuB,aAAA,CAAA,mBAAA,EAAAoB,MAIU+B,EAAShrC,MAAKqlC,MACd4F,EAAUjrC,MAAKuoC,MAAA,OAAAjlC,IAEjB8oC,EAAO,2BACa,GACrBnI,EAAK,CAAA9gC,MACF,IAAKkpC,OAAgBzI,GAAA4D,EApEP4D,CAAoBA,IAC3C,MAAMlF,EAAiCW,IAChC,MAAA8B,UAAEA,KAAciE,GAAc/F,EACpC,OAAAT,cAAAE,EAAAA,iBAAA,gBAAAuB,EAAAA,WAAA,CAAAU,MAES,GAAkB,aAAfmE,EAA4B,iBAAmB,OAAiBG,MAAXP,OAAWO,EAAAA,EAAAA,oBAAqB,MAAMlE,GAAa,MAChH9B,EAAKxD,MAA0B,GAAlB,mBAEXuJ,EAAS,CAAAlsC,KACPmmC,EAAKnmC,KAAIosC,WACQA,MAAXR,OAAWQ,EAAAA,EAAAA,WAAU3gD,IAC5B06C,EAAKnmC,OAAI,CAGb6lC,QAASA,KACEK,MAANC,OAAMD,EAAAA,EAAAA,QAAeC,MAAAA,OAAAA,EAAAA,EAAMD,OAAOoE,EAAShrC,OAC3C6mC,EAAK7B,WA/CUqC,GAAGrC,aAAYyC,QAAO/mC,OAAM2iC,QAAO6B,aAC3D,IAAKxkC,EAAM,OAEX,MAAMgnC,EAAYC,EAAAA,iBAAiB,MAAQ3C,GACrC+H,EAAuBA,IACT,WAAf/H,IAAmCztD,MAAR2tD,OAAQ3tD,EAAAA,EAAAA,SACvBA,MAAR2tD,OAAQ3tD,EAAAA,EAAAA,QAAQpQ,KAAKgwD,GAASiP,EAAAA,YAAAE,EAAAqB,iBAAA,aAAA,CAAAtE,MAAuBlM,EAAKkM,MAAKrjC,MAASm3B,EAAKn3B,OAAK,QACvE,gBAAfglC,IAAwCztD,MAAR2tD,OAAQ3tD,EAAAA,EAAAA,SAC5BA,MAAR2tD,OAAQ3tD,EAAAA,EAAAA,QAAQpQ,KAAKgwD,GAASiP,EAAAA,YAAAE,EAAAqB,iBAAA,YAAA,CAAAtE,MAAsBlM,EAAKkM,MAAKrjC,MAASm3B,EAAKn3B,OAAK,QAClF,MAEFzoB,QAAEA,KAAYy1D,GAAS9H,GAAU,CAAE,EACzC,GAAmB,aAAfF,EACHoB,OAAAA,cAAAE,EAAAA,iBAAAuB,eAAAA,EAAAA,WAEMJ,EACAuF,EAAI,CAAAz1D,QACCA,EAAOuwD,WACPkD,EAAShrC,MAAMU,GAAK,sBAAAqnC,GAApBiD,EAAShrC,MAAMU,GAAKqnC,EAAAC,YAChB,MAAM3E,MAAO,MAG7B,IAAIoD,EAAWzB,GAAc,CAAC,SAAU,YAAYC,SAASD,GAC7D,OAAAoB,cAAAsB,EAAAG,EAAAoF,WACgBxF,EAAK,CAAAO,YAAe,IAAIvB,EAAW,KAAO,OAAOpD,KAAa2J,EAAI,CAAAlF,WAAWkD,EAAShrC,MAAMU,GAAK,sBAAAqnC,GAApBiD,EAAShrC,MAAMU,GAAKqnC,IAAAnE,GAC9GmJ,GAAAA,EAAoB,CAAAxG,QAAAA,IAAA,CAApBwG,IAAoB,EAsBU1F,CAAiBR,IACtCA,MAAAA,OAAAA,EAAAA,EAAMwB,WAlBIxB,CAAmBA,UAAKwB,OAAAA,EAAAA,WAAYtE,OAAAA,EAAAA,EAAM8C,EAAKwB,gBAAXtE,EAAAA,EAAAA,OAAuBiH,EAAShrC,OAAAA,EAkB5DktC,CAAcrG,GAExCxD,MAAOA,WACDA,OAAAA,EAAAA,MAAK+C,EAAAA,YAAA,MAAA,CAAAmC,MACG,2BAA2B1B,EAAKsG,gBAAkB,MAAI,CAChEtG,EAAKxD,MACLwD,EAAKuG,WAAUhH,EAAAA,YAAAE,EAAAqB,iBACCd,cAAAA,OAAAA,EAAAA,EAAKuG,iBAALvG,EAAAA,EAAiBwG,YAAW,CAAA9G,QAAAA,aAAAH,MAAAA,CAAAA,EAAAA,YAAAE,EAAAqB,iBAAA,WAAA,CAAApsD,MAC5BsrD,OAAAA,EAAAA,EAAKuG,iBAALvG,EAAAA,EAAiBtrD,OAAQ,GAAEL,MAAS2rD,OAAAA,EAAKuG,EAAAA,iBAAYlyD,EAAAA,EAAAA,OAAK,CAAAqrD,QAAAA,IAAAH,CAAAA,EAAAA,YAAAoE,GAAA,KAAA,SAAA,IAK1E,KAGC,IAAA,GAAG,EAMZ,OAAOY,EACLhR,QAAeyM,IAACA,EAAKhkE,MAAQgkE,EAAKhkE,KAAKmoE,EAAShrC,SAChD74B,KAAwB0/D,GACpBA,EAAKlT,UAAYkT,EAAKlT,SAASpuD,OAAS,EAC3C6gE,EAAAA,YAAA,MAAA,CAAAmC,MACa,iBAAiB1B,EAAKyG,oBAAsB,KAAInqC,MAAS,IAAWoqC,MAAN1G,OAAM0G,EAAAA,EAAAA,iBAAgB,CAAAnH,EAAAC,YAAA,MAAA,CAAAkC,MACnF1B,EAAK2G,qBAAuB,GAAErqC,MAAS,IAAWsqC,MAAN5G,OAAM4G,EAAAA,EAAAA,kBAAiB,CAC7E5G,EAAK6G,YAAStH,EAAAA,YAAA,MAAA,CAAAmC,MAEJ,QAAQ1B,EAAK8G,gBAAkB,KAAIxqC,MAAS,IAAKqpC,GAAoBC,MAAN5F,OAAM4F,EAAAA,EAAAA,aAAc,CAAE,KAAG,CAClG5F,EAAKlT,SAASyG,QAAOyM,IAASA,EAAKhkE,MAAQgkE,EAAKhkE,KAAKmoE,EAAShrC,SAAQ74B,KAAI0/D,GAAQX,EAAWW,SAK1FX,EAAWW,IAEnB,EAcC+G,CAAe1C,EAAWlrC,QAAMwnC,EAAA,CAAAjB,QAAAA,IAAA,CAAAiB,MAAA,SAUxBjkE,EAAA,CACZynE,WACA6C,aANoBxqE,SACf+oE,EAAQpsC,YACAosC,EAAQpsC,MAAMmqC,UAAS,IAAMC,QAAQC,YADvBD,QAAQC,SAAQ,GAM3C+B,4ICpTD,IAAI0B,GAAoCC,GAuCjC,MAAMC,GAAmB,KAClBC,aAAAC,QAAQJ,GAAYC,IAC1BI,OAAAzoB,SAAS0oB,QAAO,EAAI,EAGfC,GAAwB,KA5CeC,UA8CzCC,UACV/jD,SAASU,KAAKG,YAAYb,SAASi7C,cAAc,YACpCwI,aAAAC,QAAQJ,GAAYC,GAAU,uZCjD5C,MAAM3qB,EAAQ0gB,iqCCQT0K,GAAU,CACdprB,MAAO,CACNloC,MAAO,CACNtN,KAAMpJ,OACN+hE,QAAS,WAEVhrD,KAAM,CACL3N,KAAMpJ,OACN+hE,QAAS,wFAhBXsE,EAEIC,mBAAA,IAAA,CAFDvC,MAAM,UAAWplC,MAXrBsrC,EAAAC,eAAA,CAAA,CAAA,UAW0CC,EAAKzzD,MAAA,YAAeyzD,EAAIpzD,KAAA,UAChEqzD,EAAQC,WAAApE,EAAAqE,OAAA,UAAA,CAAA,OAAA,GAAA,mRCIJ7K,MAAAA,EAAQC,EAAAA,WACRH,EAAQC,EAAAA,WACR+K,EAAWzrC,EAAGA,IAAmB,IACjC8f,EAAQ0gB,EACd,IAAIkL,EAAmC,GACjCC,MAAAA,EAAa3rC,EAAGA,IAAC,IACjB4rC,EAAS5rC,EAAAA,MACTkhC,EAAOC,EAIP0K,EAAa9rE,MAAOiU,IACzB,SAAI8rC,WAAOgsB,aACV,aAAOhsB,WAAOgsB,aAAa93D,GAEtB+3D,MAAAA,EAAW,IAAIC,SACZC,EAAAA,OAAO,OAAQj4D,GAClB,MAAA9P,KAAEA,UAAuBgoE,MAAPpsB,OAAOosB,EAAAA,EAAAA,yBAAoBpsB,WAAOosB,kBAAkBH,GAAYI,oBAAyBJ,IACjHJ,EAAWjvC,MAAQx4B,EAAKkoE,QACnBlL,EAAA,oBAAqByK,EAAWjvC,MAAK,EAErC2vC,EAAoCtsE,MAAMsX,IAC/Cu0D,EAAOlvC,MAAO4vC,aACRt4D,MAAAA,EAAOqD,EAAM,GACdk1D,EAAAA,IAAMC,cACJ9vC,EAAAA,MAAO+vC,YAAYz4D,EAAI,EAEzBw0D,EAAWzoE,MAAOiU,EAAsB04D,WAC5BA,EAAAA,GACNC,MAAPhM,OAAOgM,EAAAA,EAAAA,QAA0B,KAAVA,MAAPhM,OAAOgM,EAAAA,EAAAA,aACpBd,EAAWH,OAAAA,EAAAA,EAAe,aAAI7yD,WAE9BgzD,EAAWH,EAClB,EAIYzrE,EAAA,CAAE2rE,SAAQgB,YADHA,IAAMlB,IAEpBpI,MAAAA,EAAUxjB,GAIfgjB,EAAAC,YAAA2C,EAAA2D,SAAA,KAAA,CAAAvG,EAAAC,YAAAC,gCAAAuB,aAAA,CAAAvkC,IAGQ4rC,EAAM3G,MAAA,gBAAA,eAEG4G,EAAU,YACbJ,EAAS/uC,OAChBikC,EAAK,CAAA,YACE0L,EAAQ,YACR7D,EAAQ,eACN,IAAK,CAGjBnF,QAASA,KACDvjB,MAAAA,OAAAA,EAAAA,EAAO+sB,eACX/sB,MAAAA,SAAAA,EAAO+sB,cAAclB,EAAWjvC,OAChC+jC,EAAe,QACfA,EAAe,UAnBtBqC,cAAAE,EAAAA,iBAAA,aAAA,KAAA,CAAAC,QAAAA,IAAA,CAAmBnjB,EAAMgtB,aAAe,UAsBrCC,IAAKA,IACJjK,EAAAA,YAAA,MAAA,CAAAmC,MAAA,kBAAoCnlB,CAAAA,MAAAA,OAAAA,EAAAA,EAAOktB,+IClElC9B,GAAA,CACdh0D,KAAM,YACN4oC,MAAO,CACNmtB,SAAU,CACT3iE,KAAM4iE,QACNjK,SAAS,GAEVkK,UAAW,CACV7iE,KAAM4iE,QACNjK,SAAS,GAEVmK,YAAa,CACZ9iE,KAAM4iE,QACNjK,SAAS,IAGX/+D,KAAO,KACC,CACNmpE,aAAc,CACbC,UAAW,CACVhuE,MAAO,QACP+hD,OAAQ,WAKZ,aAAMksB,GACD,IACG,MAAArpE,QAAaspE,kBACnBz+C,KAAKs+C,aAAe,IAChBt+C,KAAKs+C,gBACLnpE,SAEInB,GAAG,CAGb,EACA0qE,QAAS,CACR,cAAAC,UACwC,KAAnC,OAAA3Z,EAAKhlC,KAAAs+C,mBAAc,EAAAtZ,EAAAqZ,cACvBO,cAAgB,0DAQZ,SA7DPxG,IA6DQkE,EAAsCuC,EAAAC,EAAAC,sBAE3CzG,EAAKC,YAAAC,EAAAC,mBAAA,MAAA,CAAAvC,MAAA8I,EAAAA,eAAA,CAAA,uCAAA,CAAA,kBAAA,KAAA,OAAAha,EAAA8Z,EAAAR,mBAAA,EAAAtZ,EAAAqZ,wBAGChG,EAAQ,KAAIA,SAAYz5B,IAAMmgC,EAAAJ,gBAAAI,EAAAJ,kBAAA//B,KAAA,GAlEvCs/B,WAmEW,OAAAvX,EAAAmY,EAAAR,mBAAA,EAAA3X,EAAAsY,OAAA3G,cAAAE,EAAAC,mBAAA,MAAA,CACR3+C,IAAK,EACLgX,MAAAsrC,EAAAC,eAAQyC,EAAYR,aAAKC,WAAArI,MAAA,qBArE5BzU,UAAAqd,EAAAR,aAAAW,MAyES,KAAA,GAAShH,KAFhBiH,EAAAC,mBAAA,IAAA,GAAA7C,EAvEF8B,YAwEW,OAAAxX,EAAAkY,EAAAR,mBAAA,EAAA1X,EAAAn2D,QAAA6nE,cAAAE,EAAAC,mBAAA,MAAA,CAER3+C,IAAK,EAAAgX,MAAAsrC,EAAAC,eAEFyC,eAAcM,YA5EpBlJ,MAAA,gDAAAmJ,EAAAC,gBAAA,OAAAzY,EAAAiY,EAAAR,mBAAA,EAAAzX,EAAAp2D,OAAA,IAAAyuE,qBAAA,IAAA,2CCcO,MAAMK,GACZ,WAAAC,CAAYzuB,EAAuB0uB,EAAgB,qBAC7Cz/C,KAAAu0C,OAAOxjB,EAAO0uB,EAAK,CAEzB,cAAIC,GACI99D,OAAAA,EAAAA,QAAQ,EAAC,CAEjB,MAAA2yD,CAAOxjB,EAAuB0uB,GACzB,GAAoB,MAApBz/C,KAAK0/C,WAEF,CAEN,OAAO,IADKC,QAAQ,OACb,CAAQ,CAAEpL,OAAQvlD,GAAKA,EAAE4wD,GAAW,CAAE7uB,YAAY8uB,OAAO,IAAIJ,IAAO,CAH3EK,EAAAA,UAAUF,GAAW7uB,GAAOgvB,MAAM,IAAIN,IAIvC","x_google_ignoreList":[2]}
1
+ {"version":3,"file":"index.cjs6.js","sources":["../packages/components/YxDialog/index.vue","../packages/components/YxDrawer/index.vue","../packages/components/YxTable/index.vue","../packages/utils/excel/index.ts","../packages/components/YxForm/icon/question.svg?component","../packages/components/YxForm/index.vue","../packages/utils/common/update.ts","../packages/components/Update/index.vue","../packages/components/YxIcon/index.vue","../packages/components/YxUpload/index.vue","../packages/components/LogoTitle/index.vue","../packages/components/LogoTitle/index.ts"],"sourcesContent":["<!--\n * @Author: WangXin\n * @Date: 2024-01-17 18:18:08\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-15 16:06:10\n * @FilePath: /yxuse/packages/components/YxDialog/index.vue\n * @Description: \n * \n * Copyright (c) 2024 by YuXing, All Rights Reserved. \n-->\n\n<script setup lang=\"ts\" name=\"YxDialog\">\nimport { reactive } from \"vue\";\nimport type { DialogOptions } from \"./type\";\nconst dialogOptions = reactive({\n\twidth: \"40%\",\n\tshow: false,\n\ttitle: \"\",\n\tloading: false,\n\tshowFooter: true,\n\tautoClose: true\n});\nconst close = () => {\n\tconsole.log(\"关闭\");\n\tdialogMap[\"cancel\"] && dialogMap[\"cancel\"]();\n\tdialogOptions.show = false;\n};\nconst dialogMap: Record<string, Function> = {};\nconst submit = async () => {\n\t//执行提交之前的回调\n\tif (dialogMap[\"beforeSubmit\"] && !(await dialogMap[\"beforeSubmit\"]())) return;\n\tdialogOptions.loading = true;\n\ttry {\n\t\tdialogMap[\"submit\"] && (await dialogMap[\"submit\"]());\n\t\tdialogOptions.loading = false;\n\t\tif (dialogOptions.autoClose) close();\n\t} catch (err) {\n\t\tdialogOptions.loading = false;\n\t}\n};\nconst show = async ({ width, title, submit, cancel, showFooter, autoClose, beforeOpen, beforeSubmit }: DialogOptions) => {\n\tif (width) dialogOptions.width = width;\n\tif (title) dialogOptions.title = title;\n\tif (showFooter !== undefined) dialogOptions.showFooter = showFooter;\n\tif (autoClose !== undefined) dialogOptions.autoClose = autoClose;\n\tif (submit) dialogMap[\"submit\"] = submit;\n\tif (cancel) dialogMap[\"cancel\"] = cancel;\n\tif (beforeSubmit) dialogMap[\"beforeSubmit\"] = beforeSubmit;\n\tif (beforeOpen) {\n\t\tawait beforeOpen();\n\t}\n\tdialogOptions.show = true;\n};\n\ndefineExpose({\n\tshow,\n\tclose\n});\n</script>\n\n<template>\n\t<el-dialog\n\t\t:close-on-click-modal=\"false\"\n\t\tattrs\n\t\t:width=\"dialogOptions.width\"\n\t\tv-model=\"dialogOptions.show\"\n\t\t:title=\"dialogOptions.title\"\n\t\tdestroy-on-close\n\t\t:before-close=\"close\"\n\t>\n\t\t<slot />\n\t\t<template #footer v-if=\"dialogOptions.showFooter\">\n\t\t\t<span class=\"dialog-footer flex justify-end\">\n\t\t\t\t<el-button plain @click=\"dialogOptions.show = false\">取消</el-button>\n\t\t\t\t<el-button :loading=\"dialogOptions.loading\" @click=\"submit\">确认</el-button>\n\t\t\t</span>\n\t\t</template>\n\t</el-dialog>\n</template>\n\n<style scoped lang=\"scss\"></style>\n","<!--\n * @Author: WangXin\n * @Date: 2024-01-17 18:18:08\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-15 16:05:44\n * @FilePath: /yxuse/packages/components/YxDrawer/index.vue\n * @Description: \n * \n * Copyright (c) 2024 by YuXing, All Rights Reserved. \n-->\n\n<script setup lang=\"ts\" name=\"YxDrawer\">\nimport { reactive } from \"vue\";\nimport type { DrawerOptions } from \"./type\";\nconst drawerOptions = reactive({\n\twidth: \"40%\",\n\tshow: false,\n\ttitle: \"\",\n\tloading: false,\n\tshowFooter: true,\n\tautoClose: true\n});\nconst close = () => {\n\tdrawerMap[\"cancel\"] && drawerMap[\"cancel\"]();\n\tdrawerOptions.show = false;\n\tconsole.log(\"关闭\");\n};\nconst drawerMap: Record<string, Function> = {};\nconst submit = async () => {\n\t//执行提交之前的回调\n\tif (drawerMap[\"beforeSubmit\"] && !(await drawerMap[\"beforeSubmit\"]())) return;\n\tdrawerOptions.loading = true;\n\ttry {\n\t\tdrawerMap[\"submit\"] && (await drawerMap[\"submit\"]());\n\t\tdrawerOptions.loading = false;\n\t\tif (drawerOptions.autoClose) close();\n\t} catch (err) {\n\t\tdrawerOptions.loading = false;\n\t}\n};\nconst show = async ({ width, title, submit, cancel, showFooter, autoClose, beforeOpen, beforeSubmit }: DrawerOptions) => {\n\tif (width) drawerOptions.width = width;\n\tif (title) drawerOptions.title = title;\n\tif (showFooter !== undefined) drawerOptions.showFooter = showFooter;\n\tif (autoClose !== undefined) drawerOptions.autoClose = autoClose;\n\tif (submit) drawerMap[\"submit\"] = submit;\n\tif (cancel) drawerMap[\"cancel\"] = cancel;\n\tif (beforeSubmit) drawerMap[\"beforeSubmit\"] = beforeSubmit;\n\tif (beforeOpen) {\n\t\tawait beforeOpen();\n\t}\n\tdrawerOptions.show = true;\n};\ndefineExpose({\n\tshow,\n\tclose\n});\n</script>\n<template>\n\t<el-drawer\n\t\t:close-on-click-modal=\"false\"\n\t\tattrs\n\t\t:size=\"drawerOptions.width\"\n\t\tv-model=\"drawerOptions.show\"\n\t\t:title=\"drawerOptions.title\"\n\t\tdestroy-on-close\n\t\t@close=\"close\"\n\t>\n\t\t<slot />\n\t\t<template #footer v-if=\"drawerOptions.showFooter\">\n\t\t\t<span class=\"dialog-footer flex justify-end\">\n\t\t\t\t<el-button plain @click=\"drawerOptions.show = false\">取消</el-button>\n\t\t\t\t<el-button :loading=\"drawerOptions.loading\" @click=\"submit\">确认</el-button>\n\t\t\t</span>\n\t\t</template>\n\t</el-drawer>\n</template>\n\n<style scoped lang=\"scss\"></style>\n","<!--\n * @Author: WangXin\n * @Date: 2024-01-04 16:35:08\n * @LastEditors: WangXin\n * @LastEditTime: 2025-06-03 14:42:33\n * @FilePath: /yxuse/packages/components/YxTable/index.vue\n * @Description: \n * \n * Copyright (c) 2024 by YuXing, All Rights Reserved. \n-->\n<script setup lang=\"tsx\">\nimport {\n\tref,\n\tonMounted,\n\tonBeforeMount,\n\tnextTick,\n\tuseSlots,\n\tuseAttrs,\n\twithModifiers,\n\twatch,\n\tresolveComponent,\n\tdefineOptions\n} from \"vue\";\nimport type { FormItemRule } from \"element-plus\";\nimport type { TableColumn, YxTableProps, ColumnsConfig } from \"./type.ts\";\nimport { exportToExcel } from \"@packages/utils/excel\";\nimport Sortable from \"sortablejs\";\nconst props = defineProps<YxTableProps>();\nconst slots = useSlots();\nconst attrs = useAttrs();\nconst tableRef = ref();\nconst tableFormRef = ref();\nconst columns = ref<TableColumn[]>([]);\n/**是否为编辑表单,且需要进行表格校验 */\nconst isFormTable = ref(false);\nconst formTableRules = ref<{ [key: string]: FormItemRule[] }>({});\nconst emit = defineEmits<{\n\t(e: \"operate-handle\", type: string, data: object, index: number): void;\n\t(e: \"sort-end\", oldIndex: number, newIndex: number): void;\n\t(e: \"update-page\", type: string, value: number): void;\n}>();\nonMounted(() => {\n\tnextTick(() => {\n\t\tstartSort();\n\t});\n});\nwatch(\n\t() => props.columns,\n\t() => {\n\t\tinitTable();\n\t}\n);\nonBeforeMount(async () => {\n\tawait initTable();\n});\nconst initTable = async () => {\n\tcolumns.value = typeof props.columns === \"function\" ? await props.columns() : props.columns;\n\tcolumns.value.forEach((col: TableColumn) => {\n\t\tif (col.required || col.rules?.length) {\n\t\t\tisFormTable.value = true;\n\t\t}\n\t\tif (col?.renderType && [\"select\", \"cascader\"].includes(col?.renderType) && col?.config?.loadOptions) {\n\t\t\tloadOptions(col.config);\n\t\t}\n\t});\n\tif (isFormTable.value) {\n\t\tgetRules();\n\t}\n};\n/**远程加载下拉数据 */\nconst loadOptions = async (config: any) => {\n\tif (config?.options && config?.options.length === 0 && config?.loadOptions && typeof config?.loadOptions === \"function\") {\n\t\tconfig.options = await config?.loadOptions();\n\t}\n};\nconst startSort = () => {\n\tif (!props.sort) return;\n\tconst sortDom = tableRef.value?.$el?.querySelector(\".el-table__body tbody\");\n\tSortable.create(sortDom, {\n\t\tanimation: 200,\n\t\t// group: \"el-table__row table-row\",\n\t\tsort: true,\n\t\thandle: props.sortHandle ? `.${props.sortHandle}` : null,\n\t\tonEnd: ({ oldIndex, newIndex }: { oldIndex: number; newIndex: number }) => {\n\t\t\temit(\"sort-end\", oldIndex, newIndex);\n\t\t}\n\t});\n};\n/***渲染动态组件 */\nconst dynamicComponent = (column: TableColumn, { $index, row }: any) => {\n\tconst { renderType, event = {}, prop, label, config = {}, required, rules } = column;\n\tif (!prop || !renderType) return null;\n\tconst Component = resolveComponent(\"el-\" + renderType) as any;\n\tconst { options = [], ...restConfig } = config;\n\t// 渲染子组件(如 select 的 options)\n\tconst renderChildComponent = () => {\n\t\tif (!options || options.length === 0) return null;\n\t\tif (renderType === \"select\") {\n\t\t\treturn options.map((item: any) => <el-option label={item.label} value={item.value} key={item.value} />);\n\t\t}\n\t\tif (renderType === \"radio-group\") {\n\t\t\treturn options.map((item: any) => (\n\t\t\t\t<el-radio label={item.value} key={item.value}>\n\t\t\t\t\t{item.label}\n\t\t\t\t</el-radio>\n\t\t\t));\n\t\t}\n\t\treturn null;\n\t};\n\t// 单独处理 cascader\n\tif (renderType === \"cascader\") {\n\t\treturn <el-cascader v-model={row[prop]} placeholder={`请选择${label}`} options={options} {...event} {...restConfig} />;\n\t}\n\t// 通用组件渲染\n\tconst isSelect = [\"select\", \"cascader\"].includes(renderType);\n\t//是否为编辑表格必填项\n\tconst isFormCell = required || rules?.length;\n\tconst modelValue = row[prop];\n\tconst updateModelValue = (val: any) => {\n\t\t//处理配置是数值类型\n\t\trow[prop] = config?.type === \"number\" ? Number(val) : val;\n\t};\n\tconst component = (\n\t\t<Component\n\t\t\tmodelValue={modelValue}\n\t\t\tonUpdate:modelValue={updateModelValue}\n\t\t\tplaceholder={`请${isSelect ? \"选择\" : \"输入\"}${label}`}\n\t\t\t{...event}\n\t\t\t{...restConfig}\n\t\t>\n\t\t\t{renderChildComponent()}\n\t\t</Component>\n\t);\n\tif (!isFormCell) return component;\n\t//编辑表格\n\treturn renderForm(prop, $index, component);\n};\nconst renderForm = (prop: any, index: number, component: any) => {\n\treturn (\n\t\t<el-form-item prop={\"tableData.\" + index + \".\" + prop} rules={formTableRules.value[prop]}>\n\t\t\t{component}\n\t\t</el-form-item>\n\t);\n};\n/**初始化规则 */\nconst getRules = () => {\n\tconst rules: { [key: string]: FormItemRule[] } = {};\n\tif (!isFormTable.value) return;\n\tconst handleRule = (item: TableColumn) => {\n\t\tif (!item.prop) return;\n\t\tconst isSelect = item?.renderType && [\"select\", \"cascader\"].includes(item?.renderType);\n\t\tconst defaultRule = { required: true, message: `${item.label ?? \"该字段\"}不能为空`, trigger: isSelect ? \"change\" : \"blur\" };\n\t\tif (item.required) {\n\t\t\trules[item.prop] = [defaultRule];\n\t\t}\n\t\tif (item.rules && item.rules.length > 0) {\n\t\t\trules[item.prop] = [...(rules[item?.prop] || []), ...item.rules];\n\t\t}\n\t};\n\tcolumns.value\n\t\t.filter(cell => (cell?.renderType || cell?.render) && (cell?.required || cell?.rules))\n\t\t.forEach((form: any) => {\n\t\t\tform.children?.forEach(handleRule); // 处理子项\n\t\t\thandleRule(form); // 处理自身\n\t\t});\n\tformTableRules.value = rules;\n\tconsole.log(\"rules\", formTableRules.value);\n};\n/**编辑表格校验 */\nconst tableFormValidate = async (): Promise<boolean> => {\n\tif (!isFormTable.value) return Promise.resolve(true);\n\tif (!tableFormRef.value) return Promise.resolve(false);\n\treturn await tableFormRef.value.validate(() => Promise.resolve());\n};\nconst render = (props: YxTableProps) => {\n\tconst { rowKey, tableData, pageInfo } = props;\n\t//动态插槽\n\tconst columnSlots = (cell: TableColumn, scope: any) => cell.slotName && slots[cell.slotName]?.(scope);\n\t//处理列;\n\tconst renderColumn = (columns: TableColumn[]) => {\n\t\treturn columns\n\t\t\t.filter(cell => !cell.show || cell.show(cell))\n\t\t\t.map((cell: TableColumn) => {\n\t\t\t\tconst { children, ...cellConf } = cell;\n\t\t\t\treturn (\n\t\t\t\t\t<el-table-column {...cellConf}>\n\t\t\t\t\t\t{{\n\t\t\t\t\t\t\tdefault: (scope: any) => {\n\t\t\t\t\t\t\t\t//先处理操作栏\n\t\t\t\t\t\t\t\tif (cell?.renderType === \"operate\") return renderOperate(cell, scope);\n\t\t\t\t\t\t\t\t//处理动态渲染的组件,绑定动态row\n\t\t\t\t\t\t\t\tif (cell?.renderType && cell?.renderType !== \"operate\") {\n\t\t\t\t\t\t\t\t\treturn dynamicComponent(cell, scope);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t//处理自定义渲染函数,判断是否为表单组件\n\t\t\t\t\t\t\t\tif (cell?.render) {\n\t\t\t\t\t\t\t\t\tconst renderResult = cell.render(scope.row, scope.$index, cell);\n\t\t\t\t\t\t\t\t\t//是否为编辑表单\n\t\t\t\t\t\t\t\t\tconst needsValidation = cell.required || cell.rules;\n\t\t\t\t\t\t\t\t\t//是否为组件节点\n\t\t\t\t\t\t\t\t\tconst isFragment = [\"symbol\", \"object\"].includes(typeof renderResult?.type);\n\t\t\t\t\t\t\t\t\t// 如果为表单节点且需要校验,进行form-item包裹\n\t\t\t\t\t\t\t\t\tif (needsValidation && isFragment) {\n\t\t\t\t\t\t\t\t\t\treturn renderForm(cell.prop, scope.$index, renderResult);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\treturn renderResult;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t//处理多级表头\n\t\t\t\t\t\t\t\tif (children && children?.length > 0) return renderColumn(children);\n\t\t\t\t\t\t\t\t//处理自定义插槽\n\t\t\t\t\t\t\t\treturn cell?.slotName && columnSlots(cell, scope);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\theader: (scope: any) => {\n\t\t\t\t\t\t\t\t//添加必填标识\n\t\t\t\t\t\t\t\tif (cell?.required) {\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<span class=\"flex items-center gap-5\">\n\t\t\t\t\t\t\t\t\t\t\t<span class=\"text-[var(--color-error-100)]\">* </span>\n\t\t\t\t\t\t\t\t\t\t\t{scope?.column?.label ?? \"\"}\n\t\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t//处理自定义渲染函数\n\t\t\t\t\t\t\t\tif (cell?.headerRender) return cell?.headerRender(scope.row);\n\t\t\t\t\t\t\t\t//处理表头自定义插槽\n\t\t\t\t\t\t\t\tif (cell?.headerSlotName) return slots[cell?.headerSlotName]?.(scope);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}}\n\t\t\t\t\t</el-table-column>\n\t\t\t\t);\n\t\t\t});\n\t};\n\t//操作栏;\n\t// const renderOperate = (cell: TableColumn, scope: any) => {\n\t// \treturn (\n\t// \t\t<div class={`flex justify-center items-center cursor-pointer gap-10 ${cell.config?.className ?? \"\"}`}>\n\t// \t\t\t{cell.operate\n\t// \t\t\t\t?.filter(op => !op.show || op.show(scope.row))\n\t// \t\t\t\t.map(op => {\n\t// \t\t\t\t\tif (op?.render) return op.render(scope.row, scope.$index);\n\t// \t\t\t\t\treturn (\n\t// \t\t\t\t\t\t<span\n\t// \t\t\t\t\t\t\tonClick={withModifiers(() => {\n\t// \t\t\t\t\t\t\t\top?.onClick && op?.onClick(scope.row);\n\t// \t\t\t\t\t\t\t\temit(\"operate-handle\", op.key, scope.row, scope.$index);\n\t// \t\t\t\t\t\t\t}, [\"stop\"])}\n\t// \t\t\t\t\t\t\tclass={`table-handle whitespace-nowrap ${op?.className ?? \"\"}`}\n\t// \t\t\t\t\t\t>\n\t// \t\t\t\t\t\t\t{op.label}\n\t// \t\t\t\t\t\t</span>\n\t// \t\t\t\t\t);\n\t// \t\t\t\t})}\n\t// \t\t</div>\n\t// \t);\n\t// };\n\tconst renderOperate = (cell: TableColumn, scope: any) => {\n\t\treturn (\n\t\t\t<div class={`flex justify-center items-center cursor-pointer gap-10 ${cell.config?.className ?? \"\"}`}>\n\t\t\t\t{cell.operate\n\t\t\t\t\t?.filter(op => !op.show || op.show(scope.row))\n\t\t\t\t\t.map(op => {\n\t\t\t\t\t\tif (op?.render) return op.render(scope.row, scope.$index);\n\t\t\t\t\t\tconst disabled = typeof op?.disabled === \"function\" ? op.disabled(scope.row, scope.$index) : op?.disabled ?? false;\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\tonClick={withModifiers(() => {\n\t\t\t\t\t\t\t\t\tif (!disabled) {\n\t\t\t\t\t\t\t\t\t\top?.onClick && op?.onClick(scope.row);\n\t\t\t\t\t\t\t\t\t\temit(\"operate-handle\", op.key, scope.row, scope.$index);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}, [\"stop\"])}\n\t\t\t\t\t\t\t\tclass={`table-handle whitespace-nowrap ${op?.className ?? \"\"} ${disabled ? \"table-handle-disabled\" : \"\"}`}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{op.label}\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t);\n\t\t\t\t\t})}\n\t\t\t</div>\n\t\t);\n\t};\n\t//分页\n\tconst pagination = () => {\n\t\tif (!pageInfo) return null;\n\t\tconst handleSizeChange = (e: number) => {\n\t\t\temit(\"update-page\", \"pageSize\", e);\n\t\t};\n\t\tconst handleCurrentChange = (e: number) => {\n\t\t\temit(\"update-page\", \"pageIndex\", e);\n\t\t};\n\t\treturn (\n\t\t\t<div class=\"pagination-wrap\">\n\t\t\t\t<el-pagination\n\t\t\t\t\tv-model:currentPage={pageInfo.pageIndex}\n\t\t\t\t\tv-model:pageSize={pageInfo.pageSize}\n\t\t\t\t\tsmall={false}\n\t\t\t\t\tdisabled={false}\n\t\t\t\t\tpage-sizes={[10, 20, 50, 100]}\n\t\t\t\t\tlayout={pageInfo?.layout ? pageInfo?.layout : \"total,sizes,prev, pager, next\"}\n\t\t\t\t\tbackground={false}\n\t\t\t\t\ttotal={pageInfo.total}\n\t\t\t\t\tonSizeChange={handleSizeChange}\n\t\t\t\t\tonCurrentChange={handleCurrentChange}\n\t\t\t\t/>\n\t\t\t</div>\n\t\t);\n\t};\n\tif (!columns.value) return;\n\treturn (\n\t\t<>\n\t\t\t{isFormTable.value ? (\n\t\t\t\t<el-form model={props} ref={tableFormRef}>\n\t\t\t\t\t{renderTable()}\n\t\t\t\t</el-form>\n\t\t\t) : (\n\t\t\t\trenderTable()\n\t\t\t)}\n\t\t\t{pagination()}\n\t\t</>\n\t);\n\t/**渲染表格 */\n\tfunction renderTable() {\n\t\treturn (\n\t\t\t<el-table ref={tableRef} {...attrs} row-key={rowKey} data={tableData}>\n\t\t\t\t{renderColumn(columns.value)}\n\t\t\t</el-table>\n\t\t);\n\t}\n};\nconst exportDataToExcel = (fileName?: string) => {\n\tconst header = columns.value.filter(cell => cell.prop);\n\tconst tableData = props.tableData;\n\texportToExcel({ header, tableData, fileName: fileName || Date.now() });\n};\n/** 更新列 */\nconst updateColumns = async (newColumns: ColumnsConfig) => {\n\tif (!columns.value) return;\n\tcolumns.value = typeof newColumns === \"function\" ? await newColumns() : newColumns;\n};\ndefineExpose({\n\ttableRef,\n\texportDataToExcel,\n\tupdateColumns,\n\ttableFormValidate\n});\ndefineOptions({\n\tname: \"YxTable\",\n\tinheritAttrs: false\n});\n</script>\n\n<template>\n\t<component :is=\"render(props)\" />\n</template>\n\n<style scoped lang=\"scss\"></style>\n","import * as XLSX from \"xlsx\";\nimport { saveAs } from \"file-saver\";\nimport XLSXStyle from \"xlsx-js-style\";\n\nfunction generateArray(table) {\n\tlet out = [];\n\tlet rows = table.querySelectorAll(\"tr\");\n\tlet ranges = [];\n\tfor (var R = 0; R < rows.length; ++R) {\n\t\tvar outRow = [];\n\t\tlet row = rows[R];\n\t\tlet columns = row.querySelectorAll(\"td\");\n\t\tfor (let C = 0; C < columns.length; ++C) {\n\t\t\tlet cell = columns[C];\n\t\t\tlet colspan = cell.getAttribute(\"colspan\");\n\t\t\tlet rowspan = cell.getAttribute(\"rowspan\");\n\t\t\tlet cellValue = cell.innerText;\n\t\t\tif (cellValue !== \"\" && cellValue == +cellValue) cellValue = +cellValue;\n\n\t\t\t//Skip ranges\n\t\t\tranges.forEach(function (range) {\n\t\t\t\tif (R >= range.s.r && R <= range.e.r && outRow.length >= range.s.c && outRow.length <= range.e.c) {\n\t\t\t\t\tfor (let i = 0; i <= range.e.c - range.s.c; ++i) outRow.push(null);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t//Handle Row Span\n\t\t\tif (rowspan || colspan) {\n\t\t\t\trowspan = rowspan || 1;\n\t\t\t\tcolspan = colspan || 1;\n\t\t\t\tranges.push({\n\t\t\t\t\ts: {\n\t\t\t\t\t\tr: R,\n\t\t\t\t\t\tc: outRow.length\n\t\t\t\t\t},\n\t\t\t\t\te: {\n\t\t\t\t\t\tr: R + rowspan - 1,\n\t\t\t\t\t\tc: outRow.length + colspan - 1\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\n\t\t\t//Handle Value\n\t\t\toutRow.push(cellValue !== \"\" ? cellValue : null);\n\n\t\t\t//Handle Colspan\n\t\t\tif (colspan) for (let k = 0; k < colspan - 1; ++k) outRow.push(null);\n\t\t}\n\t\tout.push(outRow);\n\t}\n\treturn [out, ranges];\n}\n\nfunction datenum(v, date1904) {\n\tif (date1904) v += 1462;\n\tlet epoch = Date.parse(v);\n\treturn (epoch - new Date(Date.UTC(1899, 11, 30))) / (24 * 60 * 60 * 1000);\n}\n\nfunction sheet_from_array_of_arrays(data, opts) {\n\tlet ws = {};\n\tlet range = {\n\t\ts: {\n\t\t\tc: 10000000,\n\t\t\tr: 10000000\n\t\t},\n\t\te: {\n\t\t\tc: 0,\n\t\t\tr: 0\n\t\t}\n\t};\n\tfor (let R = 0; R != data.length; ++R) {\n\t\tfor (let C = 0; C != data[R].length; ++C) {\n\t\t\tif (range.s.r > R) range.s.r = R;\n\t\t\tif (range.s.c > C) range.s.c = C;\n\t\t\tif (range.e.r < R) range.e.r = R;\n\t\t\tif (range.e.c < C) range.e.c = C;\n\t\t\tlet cell = {\n\t\t\t\tv: data[R][C]\n\t\t\t};\n\t\t\tif (cell.v == null) continue;\n\t\t\tlet cell_ref = XLSX.utils.encode_cell({\n\t\t\t\tc: C,\n\t\t\t\tr: R\n\t\t\t});\n\n\t\t\tif (typeof cell.v === \"number\") cell.t = \"n\";\n\t\t\telse if (typeof cell.v === \"boolean\") cell.t = \"b\";\n\t\t\telse if (cell.v instanceof Date) {\n\t\t\t\tcell.t = \"n\";\n\t\t\t\tcell.z = XLSX.SSF._table[14];\n\t\t\t\tcell.v = datenum(cell.v);\n\t\t\t} else cell.t = \"s\";\n\n\t\t\tws[cell_ref] = cell;\n\t\t}\n\t}\n\tif (range.s.c < 10000000) ws[\"!ref\"] = XLSX.utils.encode_range(range);\n\treturn ws;\n}\n\nfunction Workbook() {\n\tif (!(this instanceof Workbook)) return new Workbook();\n\tthis.SheetNames = [];\n\tthis.Sheets = {};\n}\n\nfunction s2ab(s) {\n\tlet buf = new ArrayBuffer(s.length);\n\tlet view = new Uint8Array(buf);\n\tfor (let i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xff;\n\treturn buf;\n}\n\nexport function export_table_to_excel(id) {\n\tlet theTable = document.getElementById(id);\n\tlet oo = generateArray(theTable);\n\tlet ranges = oo[1];\n\n\t/* original data */\n\tlet data = oo[0];\n\tlet ws_name = \"SheetJS\";\n\n\tlet wb = new Workbook(),\n\t\tws = sheet_from_array_of_arrays(data);\n\n\t/* add ranges to worksheet */\n\t// ws['!cols'] = ['apple', 'banan'];\n\tws[\"!merges\"] = ranges;\n\n\t/* add worksheet to workbook */\n\twb.SheetNames.push(ws_name);\n\twb.Sheets[ws_name] = ws;\n\n\tlet wbout = XLSX.write(wb, {\n\t\tbookType: \"xlsx\",\n\t\tbookSST: false,\n\t\ttype: \"binary\"\n\t});\n\n\tsaveAs(\n\t\tnew Blob([s2ab(wbout)], {\n\t\t\ttype: \"application/octet-stream\"\n\t\t}),\n\t\t\"test.xlsx\"\n\t);\n}\n\nexport function export_json_to_excel({\n\tmultiHeader = [],\n\theader,\n\tdata,\n\tfilename,\n\tmerges = [],\n\tautoWidth = true,\n\texcelWidth = true,\n\tbookType = \"xlsx\"\n} = {}) {\n\t/* original data */\n\t// console.log( multiHeader,header,data,filename)\n\tfilename = filename || \"excel-list\";\n\tdata = [...data];\n\tdata.unshift(header);\n\n\tfor (let i = multiHeader.length - 1; i > -1; i--) {\n\t\tdata.unshift(multiHeader[i]);\n\t}\n\n\tlet ws_name = \"SheetJS\";\n\tlet wb = new Workbook(),\n\t\tws = sheet_from_array_of_arrays(data);\n\n\tif (merges.length > 0) {\n\t\tif (!ws[\"!merges\"]) ws[\"!merges\"] = [];\n\t\tmerges.forEach(item => {\n\t\t\tws[\"!merges\"].push(XLSX.utils.decode_range(item));\n\t\t});\n\t}\n\n\tif (autoWidth) ws[\"!cols\"] = getColWidth(data);\n\tif (excelWidth) setColMaxW(data, ws);\n\n\t/* add worksheet to workbook */\n\twb.SheetNames.push(ws_name);\n\twb.Sheets[ws_name] = ws;\n\n\tlet wbout = XLSX.write(wb, {\n\t\tbookType: bookType,\n\t\tbookSST: false,\n\t\ttype: \"binary\"\n\t});\n\tsaveAs(\n\t\tnew Blob([s2ab(wbout)], {\n\t\t\ttype: \"application/octet-stream\"\n\t\t}),\n\t\t`${filename}.${bookType}`\n\t);\n}\n\n// export function readFile(file) {\n// return new Promise((resolve) => {\n// let reader = new FileReader();\n// reader.readAsBinaryString(file);\n// reader.onload = (ev) => {\n// let dataBinary = ev.target.result;\n// let workBook = XLSX.read(dataBinary, { type: \"binary\", cellDates: true });\n// let workSheet = workBook.Sheets[workBook.SheetNames[0]];\n// const data = XLSX.utils.sheet_to_json(workSheet, {defval:\"\"});\n// resolve(data);\n// };\n// });\n// }\n\nexport function readFile(file) {\n\treturn new Promise(resolve => {\n\t\tlet reader = new FileReader();\n\t\treader.readAsBinaryString(file);\n\t\treader.onload = ev => {\n\t\t\tresolve(ev.target.result);\n\t\t};\n\t});\n}\n\n// 读取excel,返回一维数组,第一行格式:{列名:值,列名:值}\nexport async function readExcel(file) {\n\tlet dataBinary = await readFile(file);\n\tlet workBook = XLSX.read(dataBinary, { type: \"binary\", cellDates: true });\n\tlet workSheet = workBook.Sheets[workBook.SheetNames[0]];\n\tconst data = XLSX.utils.sheet_to_json(workSheet, { defval: \"\" });\n\treturn data;\n}\n\n// 读取excel,返回二维数组,第一行表头,后面行是数据\nexport async function readExcelToArray(file) {\n\tlet dataBinary = await readFile(file);\n\tlet workBook = XLSX.read(dataBinary, { type: \"binary\", cellDates: true });\n\tlet workSheet = workBook.Sheets[workBook.SheetNames[0]];\n\tconst data = XLSX.utils.sheet_to_json(workSheet, { defval: \"\", header: 1 });\n\treturn data;\n}\n\nexport async function saveFile(content, fileName) {\n\tlet file = new Blob([content]);\n\tsaveAs(file, fileName);\n}\n\n// 判断列宽\nfunction getColWidth(list) {\n\t/*设置worksheet每列的最大宽度*/\n\tconst colWidth = list.map(row =>\n\t\trow.map(val => {\n\t\t\t/*先判断是否为null/undefined*/\n\t\t\tif (val == null) {\n\t\t\t\treturn {\n\t\t\t\t\twch: 10\n\t\t\t\t};\n\t\t\t} else if (val.toString().charCodeAt(0) > 255) {\n\t\t\t\t/*再判断是否为中文*/\n\t\t\t\treturn {\n\t\t\t\t\twch: val.toString().length * 2\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\treturn {\n\t\t\t\t\twch: val.toString().length\n\t\t\t\t};\n\t\t\t}\n\t\t})\n\t);\n\t/*以第一行为初始值*/\n\tlet result = colWidth[0];\n\tfor (let i = 1; i < colWidth.length; i++) {\n\t\tfor (let j = 0; j < colWidth[i].length; j++) {\n\t\t\tif (result[j][\"wch\"] < colWidth[i][j][\"wch\"]) {\n\t\t\t\tresult[j][\"wch\"] = colWidth[i][j][\"wch\"];\n\t\t\t}\n\t\t}\n\t}\n\treturn result;\n}\n\n// 设置最大列宽\nfunction setColMaxW(list, ws) {\n\t/*设置worksheet每列的最大宽度*/\n\tconst colWidth = list.map(row =>\n\t\trow.map(val => {\n\t\t\t/*先判断是否为null/undefined*/\n\t\t\t// console.log(val)\n\t\t\tif (val == null) {\n\t\t\t\treturn {\n\t\t\t\t\twch: 10\n\t\t\t\t};\n\t\t\t} else if (val.toString().charCodeAt(0) > 255) {\n\t\t\t\t/*再判断是否为中文*/\n\t\t\t\treturn {\n\t\t\t\t\twch: 20\n\t\t\t\t};\n\t\t\t} else if (val.toString().indexOf(\"<operation\") !== -1) {\n\t\t\t\t/* 判断是否为报文数据*/\n\t\t\t\treturn {\n\t\t\t\t\twch: 30\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\treturn {\n\t\t\t\t\twch: val.toString().length\n\t\t\t\t};\n\t\t\t}\n\t\t})\n\t);\n\t// console.log(colWidth)\n\t/*以第一行为初始值*/\n\tlet result = colWidth[0];\n\tfor (let i = 1; i < colWidth.length; i++) {\n\t\tfor (let j = 0; j < colWidth[i].length; j++) {\n\t\t\tif (result[j][\"wch\"] < colWidth[i][j][\"wch\"]) {\n\t\t\t\tresult[j][\"wch\"] = colWidth[i][j][\"wch\"];\n\t\t\t}\n\t\t}\n\t}\n\t// console.log(result)\n\tresult[0].wch = 20;\n\tresult[4] ? (result[4].wch = 10) : \"\";\n\tws[\"!cols\"] = result;\n}\n\n// 导出excel,且可带单元格注释及样式\nconst englishLetter = [\n\t\"A\",\n\t\"B\",\n\t\"C\",\n\t\"D\",\n\t\"E\",\n\t\"F\",\n\t\"G\",\n\t\"H\",\n\t\"I\",\n\t\"J\",\n\t\"K\",\n\t\"L\",\n\t\"M\",\n\t\"N\",\n\t\"O\",\n\t\"P\",\n\t\"Q\",\n\t\"R\",\n\t\"S\",\n\t\"T\",\n\t\"U\",\n\t\"V\",\n\t\"W\",\n\t\"X\",\n\t\"Y\",\n\t\"X\"\n];\nexport function export_excel_style({ header, data, filename, merges = [], autoWidth = true, excelWidth = true } = {}) {\n\t// 创建一个工作簿\n\tconst workBook = XLSX.utils.book_new();\n\tdata = [...data];\n\tdata.unshift(header.map(item => item.label));\n\t// 创建工作表 worksheet\n\tconst workSheet = sheet_from_array_of_arrays(data);\n\tif (merges.length > 0) {\n\t\tif (!workSheet[\"!merges\"]) workSheet[\"!merges\"] = [];\n\t\tmerges.forEach(item => {\n\t\t\tworkSheet[\"!merges\"].push(XLSX.utils.decode_range(item));\n\t\t});\n\t}\n\tif (autoWidth) workSheet[\"!cols\"] = getColWidth(data);\n\tif (excelWidth) setColMaxW(data, workSheet);\n\theader.forEach((head, index) => {\n\t\tlet cell = workSheet[`${englishLetter[index]}1`];\n\t\t// cell.s = { font:{ bold: true } };\n\t\tif (cell && head.note) {\n\t\t\tif (!cell.c) cell.c = [];\n\t\t\tcell.c.hidden = true;\n\t\t\tcell.c.push({ a: head.label, t: head.note });\n\t\t}\n\t});\n\t// 将工作表放入工作簿中\n\tXLSX.utils.book_append_sheet(workBook, workSheet, \"Sheet1\");\n\t// 生成数据保存\n\tXLSXStyle.writeFile(workBook, `${filename}.xlsx`, { bookType: \"xlsx\" });\n}\n\n// 验证文件格式\nexport function checkFileType(file, fileType) {\n\tlet index = file.name.lastIndexOf(\".\");\n\tlet ext = file.name.substr(index);\n\tlet extList = fileType instanceof Array ? fileType : [fileType];\n\tif (fileType === \"Excel\") {\n\t\textList = [\".xls\", \".xlsx\", \".csv\"];\n\t}\n\tif (!extList.includes(ext)) {\n\t\treturn `请上传${extList.join(\"或\") || \"指定格式\"}文件!`;\n\t}\n\treturn \"\";\n}\n\n// 解析文件并判断文件类型\nexport async function parseFile(file, config) {\n\tlet typeErrorMsg = checkFileType(file, config.fileType);\n\tif (typeErrorMsg) return { code: 0, message: typeErrorMsg };\n\tif (config.fileType === \"Excel\") {\n\t\tlet data = await readExcelToArray(file);\n\t\treturn { code: 200, data };\n\t}\n\tlet dataBinary = await readFile(file);\n\treturn { code: 200, data: dataBinary };\n}\n\n// 导出多Sheet Excel\nexport async function exportMultiSheetExcel(fileName, list) {\n\tconst wb = XLSX.utils.book_new();\n\n\t// 使用 Promise 包装异步操作\n\tconst generateSheetAsync = async section => {\n\t\treturn new Promise(resolve => {\n\t\t\tsetTimeout(() => {\n\t\t\t\tconst ws = XLSX.utils.json_to_sheet(section.data);\n\t\t\t\tXLSX.utils.book_append_sheet(wb, ws, section.sheetName.replace(/[\\\\/:*?\\[\\]]/g, \"-\"));\n\t\t\t\tresolve(true);\n\t\t\t}, 0);\n\t\t});\n\t};\n\n\t// 使用 for...of 循环和 await 处理异步操作\n\tfor (const section of list) {\n\t\tawait generateSheetAsync(section);\n\t}\n\n\tconst excelBuffer = XLSX.write(wb, { bookType: \"xlsx\", type: \"array\" });\n\tconst data = new Blob([excelBuffer], { type: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\" });\n\tsaveAs(data, fileName);\n}\n\nexport const exportToExcel = ({ header, tableData, fileName }: any) => {\n\t// 1. 获取表头(columns)并处理为 Excel 中的第一行\n\tconst tHeader = header.map(col => col.label); // 获取每一列的 label 作为表头\n\t// 2. 获取表格数据(data)\n\tconst data = tableData.map(row => {\n\t\treturn header.map(col => row[col.prop]); // 按照表头的顺序排列每行数据\n\t});\n\t// 3. 将表头和数据合并\n\tconst finalData = [tHeader, ...data]; // 把表头和数据组合成一个数组\n\t// 4. 创建工作表(sheet)\n\tconst ws = XLSX.utils.aoa_to_sheet(finalData); // 使用 aoa_to_sheet 转换为工作表\n\tconst wb = XLSX.utils.book_new(); // 创建工作簿\n\tXLSX.utils.book_append_sheet(wb, ws, \"Sheet1\"); // 添加工作表\n\n\t// 5. 导出 Excel 文件\n\tXLSX.writeFile(wb, `${fileName}.xlsx`); // 下载 Excel 文件\n};\n","import { createElementVNode as _createElementVNode, openBlock as _openBlock, createElementBlock as _createElementBlock } from \"vue\"\n\nconst _hoisted_1 = {\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 1024 1024\"\n}\n\nexport function render(_ctx, _cache) {\n return (_openBlock(), _createElementBlock(\"svg\", _hoisted_1, _cache[0] || (_cache[0] = [\n _createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896m23.744 191.488c-52.096 0-92.928 14.784-123.2 44.352-30.976 29.568-45.76 70.4-45.76 122.496h80.256c0-29.568 5.632-52.8 17.6-68.992 13.376-19.712 35.2-28.864 66.176-28.864 23.936 0 42.944 6.336 56.32 19.712 12.672 13.376 19.712 31.68 19.712 54.912 0 17.6-6.336 34.496-19.008 49.984l-8.448 9.856c-45.76 40.832-73.216 70.4-82.368 89.408-9.856 19.008-14.08 42.24-14.08 68.992v9.856h80.96v-9.856c0-16.896 3.52-31.68 10.56-45.76 6.336-12.672 15.488-24.64 28.16-35.2 33.792-29.568 54.208-48.576 60.544-55.616 16.896-22.528 26.048-51.392 26.048-86.592q0-64.416-42.24-101.376c-28.16-25.344-65.472-37.312-111.232-37.312m-12.672 406.208a54.27 54.27 0 0 0-38.72 14.784 49.4 49.4 0 0 0-15.488 38.016c0 15.488 4.928 28.16 15.488 38.016A54.85 54.85 0 0 0 523.072 768c15.488 0 28.16-4.928 38.72-14.784a51.52 51.52 0 0 0 16.192-38.72 51.97 51.97 0 0 0-15.488-38.016 55.94 55.94 0 0 0-39.424-14.784\"\n }, null, -1)\n ])))\n}\nexport default { render: render }","<!--\n * @Author: WangXin\n * @Date: 2023-06-08 10:10:13\n * @LastEditors: WangXin\n * @LastEditTime: 2025-06-04 14:15:03\n * @FilePath: /yxuse/packages/components/YxForm/index.vue\n * @Description: \n * \n * Copyright (c) 2023 by YuXing, All Rights Reserved. \n-->\n<script setup lang=\"tsx\">\nimport { ref, useAttrs, useSlots, resolveComponent, watch, onBeforeMount, onUnmounted } from \"vue\";\nimport type { FormInstance, FormItemRule } from \"element-plus\";\nimport type { YxFormProps, FormItem, FormStyle } from \"./type\";\nimport Question from \"./icon/question.svg?component\";\nconst formData = ref<{ [key: string]: any }>({});\nconst formRules = ref<{ [key: string]: FormItemRule[] }>({});\nconst formColumn = ref<FormItem[]>([]);\nconst attrs = useAttrs();\nconst props = withDefaults(defineProps<YxFormProps>(), {\n\tformLayout: \"horizontal\",\n\tformStyle: () => ({\n\t\trow: 3,\n\t\tgap: \"15px\",\n\t\tlabelWidth: \"100px\",\n\t\talignItems: \"start\"\n\t})\n});\nconst isOptionsComponent = (type?: string): any => type && [\"select\", \"cascader\"].includes(type);\n//初始化表单data\nconst initForm = async () => {\n\tconst { formList, formParams } = props as YxFormProps;\n\t// 获取表单配置\n\tformColumn.value = typeof formList === \"function\" ? await formList() : formList;\n\tif (!Array.isArray(formColumn.value) || formColumn.value.length === 0) {\n\t\tconsole.warn(\"请配置表单项\");\n\t\treturn;\n\t}\n\t// 初始化表单数据\n\tconst initialData: Record<string, any> = {};\n\t// 填充默认值并加载选项(递归处理嵌套)\n\tconst fillFormData = (item: any) => {\n\t\tif (item.prop && !(item.prop in initialData)) {\n\t\t\tinitialData[item.prop] = undefined;\n\t\t}\n\t\tif (isOptionsComponent(item?.renderType)) {\n\t\t\tloadOptions(item); // 异步加载选项数据\n\t\t}\n\t\tif (Array.isArray(item.children)) {\n\t\t\titem.children.forEach(fillFormData);\n\t\t}\n\t\t//如果有配置关联的选项\n\t\thandleLinkOptions(item);\n\t};\n\tformColumn.value.forEach(item => fillFormData(item));\n\t// 编辑模式下回填数据\n\tif (formParams && Object.keys(formParams).length > 0) {\n\t\tif (hasLoadOptions()) {\n\t\t\tfor (const item of formColumn.value) {\n\t\t\t\tif (!item.prop) continue;\n\t\t\t\tconst isAsyncOption = item.config?.loadOptions && typeof item.config.loadOptions === \"function\";\n\t\t\t\t// 如果不是需要跳过赋值的字段,就赋值\n\t\t\t\tif (!(isAsyncOption && formParams[item.prop] !== undefined)) {\n\t\t\t\t\tformData.value[item.prop] = formParams[item.prop];\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\t//兼容老版本回写formParams数据\n\t\t\tformData.value = formParams;\n\t\t}\n\t} else {\n\t\tconsole.log(\"initialData\", initialData);\n\t\tformData.value = initialData;\n\t}\n\tconsole.log(\"formData\", formData.value);\n};\n/**处理关联选项的逻辑 */\nconst handleLinkOptions = (item: any) => {\n\tif (!item.config?.linkOptions || item?._linkedHandled) return;\n\tconst linkOptions = item.config.linkOptions;\n\tconst originOnChange = item.event?.onChange;\n\tconst newOnChange = async (e: any) => {\n\t\tconsole.log(\"执行事件\", e);\n\t\t// 执行你自己的逻辑\n\t\tconst updateForm: FormItem = formColumn.value.find((form: any) => form?.prop === linkOptions) as any;\n\t\t//没有自定义事件,不做处理\n\t\tif (!updateForm || !updateForm?.config?.loadOptions) return;\n\t\tconst options = await updateForm.config.loadOptions(e);\n\t\t//更新options\n\t\tupdateForm.config.options = options;\n\t\t// 调用原始事件\n\t\tif (typeof originOnChange === \"function\") {\n\t\t\toriginOnChange(e);\n\t\t}\n\t};\n\t// 保证 event 是对象\n\titem.event = {\n\t\t...item.event,\n\t\tonChange: newOnChange\n\t};\n\t//添加处理标识\n\titem._linkedHandled = true;\n};\n/**表单配置中是否有loadOptions兼容老版本formParams回写数据 */\nconst hasLoadOptions = () => {\n\treturn formColumn.value.some(item => item.config?.loadOptions && typeof item.config.loadOptions === \"function\");\n};\n/**远程加载下拉数据 */\nconst loadOptions = async ({ config, prop }: FormItem) => {\n\t//不自动加载选项\n\tif (!config || config.notAutoLoadOptions) return;\n\tconst { loadOptions, options } = config;\n\tif (!options || typeof loadOptions !== \"function\") return;\n\tconst { formParams } = props as YxFormProps;\n\t//回写联级表单\n\tconst parentProp = formColumn.value.find((item: any) => item?.config?.linkOptions === prop)?.prop;\n\tconst parentValue = parentProp ? formParams?.[parentProp] : undefined;\n\ttry {\n\t\tconfig.options = await loadOptions(parentValue);\n\t\t// 回填下拉框数据\n\t\tif (prop && formParams?.[prop]) {\n\t\t\tformData.value[prop] = formParams[prop];\n\t\t}\n\t} catch (err) {\n\t\tconsole.error(`加载选项失败: ${prop}`, err);\n\t}\n};\n//监听form配置更新后,则立即初始化form\nwatch(\n\t() => props.formList,\n\tformList => {\n\t\tif (formList.length > 0) {\n\t\t\tconsole.log(\"监听到了,formlist\", formList);\n\t\t\tinitForm();\n\t\t\tgetRules();\n\t\t}\n\t}\n);\n//监听默认参数变化后,重置form\nwatch(\n\t() => props.formParams,\n\tformParams => {\n\t\tif (formParams) {\n\t\t\tconsole.log(\"监听到了,formlist\");\n\t\t\tinitForm();\n\t\t}\n\t}\n);\n\n/**初始化规则 */\nconst getRules = () => {\n\tconst rules: { [key: string]: FormItemRule[] } = {};\n\tif (!formColumn.value?.length) return;\n\tconst handleRule = (item: FormItem) => {\n\t\tif (!item.prop) return;\n\t\tconst isSelect = item?.renderType && [\"select\", \"cascader\"].includes(item?.renderType);\n\t\tconst defaultRule = { required: true, message: `${item.label ?? \"该字段\"}不能为空`, trigger: isSelect ? \"change\" : \"blur\" };\n\t\tif (item.required) {\n\t\t\trules[item.prop] = [defaultRule];\n\t\t}\n\t\tif (item.rules && item.rules.length > 0) {\n\t\t\trules[item.prop] = [...(rules[item?.prop] || []), ...item.rules];\n\t\t}\n\t};\n\tformColumn.value.forEach((form: any) => {\n\t\tform.children?.forEach(handleRule); // 处理子项\n\t\thandleRule(form); // 处理自身\n\t});\n\tformRules.value = rules;\n\tconsole.log(\"rules\", rules);\n};\n\nonBeforeMount(async () => {\n\tif (props.formList) {\n\t\tawait initForm();\n\t\tgetRules();\n\t}\n});\nonUnmounted(() => {\n\t// formRef?.value && formRef?.value.resetFields();\n});\nconst formRef = ref<FormInstance>();\nconst getFormStyle = () => {\n\tconst { formStyle } = props;\n\tconst { row, gap, ...style } = formStyle as FormStyle;\n\treturn {\n\t\t\"grid-template-columns\": `repeat(${row}, 1fr)`,\n\t\t\"grid-gap\": gap,\n\t\t...style\n\t};\n};\n//分组样式\nconst getGroupStyle = (groupStyle: FormStyle) => {\n\tif (!groupStyle) return {};\n\tconst { row, gap, ...style } = groupStyle;\n\treturn {\n\t\t\"grid-template-columns\": `repeat(${row}, 1fr)`,\n\t\t\"grid-gap\": gap,\n\t\t...style\n\t};\n};\n/**动态渲染组件 */\nconst dynamicComponent = ({ renderType, event, prop, label, config }: FormItem) => {\n\tif (!prop) return;\n\tconst { options, ...conf } = config || {};\n\tif (renderType === \"cascader\")\n\t\treturn (\n\t\t\t<el-cascader\n\t\t\t\t{...event}\n\t\t\t\t{...conf}\n\t\t\t\toptions={options}\n\t\t\t\tv-model={formData.value[prop]}\n\t\t\t\tplaceholder={`请选择${label}`}\n\t\t\t></el-cascader>\n\t\t);\n\tconst Component = resolveComponent(\"el-\" + renderType) as any;\n\tconst renderChildComponent = () => {\n\t\tif (renderType === \"select\" && config?.options) {\n\t\t\treturn config?.options.map((item: any) => <el-option label={item.label} value={item.value} />);\n\t\t} else if (renderType === \"radio-group\" && config?.options) {\n\t\t\treturn config?.options.map((item: any) => <el-radio label={item.label} value={item.value} />);\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t};\n\tconst isSelect = renderType && [\"select\", \"cascader\"].includes(renderType);\n\treturn (\n\t\t<Component {...event} placeholder={`请${isSelect ? \"选择\" : \"输入\"}${label}`} {...conf} v-model={formData.value[prop]}>\n\t\t\t{renderChildComponent()}\n\t\t</Component>\n\t);\n};\nconst render = (props: YxFormProps) => {\n\tconst { formStyle, formLayout } = props;\n\tif (!formColumn.value?.length) return;\n\tconst slots = useSlots();\n\tconsole.log(\"slots\", slots);\n\t//动态插槽\n\tconst formItemSlots = (form: FormItem) => form.slotName && slots[form.slotName]?.(formData.value);\n\tconst renderFormItem = (formList: any[]) => {\n\t\tconst renderForm = (form: FormItem) => {\n\t\t\tconst { className, ...formProps } = form;\n\t\t\treturn (\n\t\t\t\t<el-form-item\n\t\t\t\t\tclass={`${formLayout === \"vertical\" ? \"flex flex-col \" : \"\"} ${formStyle?.formItemClassName ?? \"\"} ${className ?? \"\"} ${\n\t\t\t\t\t\t!form.label ? \"no-label-item\" : \"\"\n\t\t\t\t\t}`}\n\t\t\t\t\t{...formProps}\n\t\t\t\t\tprop={form.prop}\n\t\t\t\t\tlabelWidth={formStyle?.labelWidth}\n\t\t\t\t\tkey={form.prop}\n\t\t\t\t>\n\t\t\t\t\t{{\n\t\t\t\t\t\tdefault: () => {\n\t\t\t\t\t\t\tif (form?.render) return form?.render(formData.value);\n\t\t\t\t\t\t\tif (form.renderType) return dynamicComponent(form);\n\t\t\t\t\t\t\treturn form?.slotName && formItemSlots(form);\n\t\t\t\t\t\t},\n\t\t\t\t\t\tlabel: () =>\n\t\t\t\t\t\t\tform.label ? (\n\t\t\t\t\t\t\t\t<div class={`flex items-center gap-5 ${form.labelClassName ?? \"\"}`}>\n\t\t\t\t\t\t\t\t\t{form.label}\n\t\t\t\t\t\t\t\t\t{form.promptConf ? (\n\t\t\t\t\t\t\t\t\t\t<el-tooltip {...form.promptConf?.tooltipConf}>\n\t\t\t\t\t\t\t\t\t\t\t<el-icon size={form.promptConf?.size ?? 15} color={form.promptConf?.color}>\n\t\t\t\t\t\t\t\t\t\t\t\t<Question />\n\t\t\t\t\t\t\t\t\t\t\t</el-icon>\n\t\t\t\t\t\t\t\t\t\t</el-tooltip>\n\t\t\t\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t\t\t\t\"\"\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t) : null\n\t\t\t\t\t}}\n\t\t\t\t</el-form-item>\n\t\t\t);\n\t\t};\n\t\t//处理分组的情况\n\t\treturn formList\n\t\t\t.filter(form => !form.show || form.show(formData.value))\n\t\t\t.map((form: FormItem) => {\n\t\t\t\tif (form.children && form.children.length > 0) {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<div class={`flex flex-col ${form.groupWrapClassName ?? \"\"}`} style={{ ...form?.groupWrapStyle }}>\n\t\t\t\t\t\t\t<div class={form.groupTitleClassName ?? \"\"} style={{ ...form?.groupTitleStyle }}>\n\t\t\t\t\t\t\t\t{form.groupName}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t<div class={`grid ${form.groupClassName ?? \"\"}`} style={{ ...getGroupStyle(form?.groupStyle ?? {}) }}>\n\t\t\t\t\t\t\t\t{form.children.filter(form => !form.show || form.show(formData.value)).map(form => renderForm(form))}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\treturn renderForm(form);\n\t\t\t\t}\n\t\t\t});\n\t};\n\treturn (\n\t\t<>\n\t\t\t<el-form\n\t\t\t\tscroll-to-error\n\t\t\t\tmodel={formData.value}\n\t\t\t\trules={formRules.value}\n\t\t\t\tclass=\"grid\"\n\t\t\t\tref={formRef}\n\t\t\t\tvalidate-on-rule-change={false}\n\t\t\t\t{...attrs}\n\t\t\t\tstyle={{ ...getFormStyle() }}\n\t\t\t>\n\t\t\t\t{renderFormItem(formColumn.value)}\n\t\t\t</el-form>\n\t\t</>\n\t);\n};\n//表单验证\nconst formValidate = async (): Promise<boolean> => {\n\tif (!formRef.value) return Promise.resolve(false);\n\treturn await formRef.value.validate(() => Promise.resolve());\n};\ndefineExpose({\n\tformData,\n\tformValidate,\n\tformRef\n});\ndefineOptions({\n\tname: \"YxForm\"\n});\n</script>\n<template>\n\t<component :is=\"render(props)\" />\n</template>\n<style scoped lang=\"scss\">\n.no-label-item :deep() .el-form-item__label {\n\tpadding-right: 0;\n\theight: 0;\n\tline-height: 0;\n}\n</style>\n","/*\n * @Author: WangXin\n * @Date: 2023-12-06 17:21:49\n * @LastEditors: WangXin\n * @LastEditTime: 2023-12-08 10:35:59\n * @FilePath: \\yxUse\\packages\\utils\\common\\update.ts\n * @Description:\n *\n * Copyright (c) 2023 by YuXing, All Rights Reserved.\n */\nimport { Update } from \"@packages/components\";\nimport { createApp } from \"vue\";\nlet versionKey, versionJsonUrl, _timer, curVersion, updateApp, timeGap;\n//每5分钟请求一次\nexport const monitorUpdate = (systemName, gap = 300) => {\n\ttimeGap = gap;\n\ttimedExecution(systemName);\n};\nconst timedExecution = systemName => {\n\t_timer = setTimeout(() => {\n\t\tgetVersion(systemName);\n\t\t_timer && clearTimeout(_timer);\n\t\ttimedExecution(systemName);\n\t\t// localStorage.removeItem(versionKey + \"delayTime\");\n\t}, timeGap * 1000);\n};\nconst getVersion = async (systemName: string) => {\n\tversionKey = `${systemName}_version`;\n\tconst systemPre = window.location.pathname.split(\"/\")[1] || \"ttc\";\n\tconsole.log(versionKey, systemPre);\n\t// versionJsonUrl = `/${systemPre}/${systemName}/version.json`;\n\tversionJsonUrl = \"/version.json\";\n\tconst oldVersion = localStorage.getItem(versionKey) || \"\";\n\tconst data = await fetch(versionJsonUrl, { cache: \"no-cache\" });\n\tconst { version, message, isNotice } = await data.json();\n\t// 没有历史版本则给缓存注入版本\n\tif (!oldVersion) {\n\t\tlocalStorage.setItem(versionKey, version);\n\t}\n\t//如果新版本与用户当前版本不一致,则提醒用户有版本更新\n\n\tif (oldVersion !== version) {\n\t\tif (isNotice) {\n\t\t\t//通知用户\n\t\t\tconsole.log(\"监测到有新版本\", version);\n\t\t\tnoticeUser(message);\n\t\t}\n\t\tcurVersion = version;\n\t}\n};\n//立即更新\nexport const updateSysVersion = () => {\n\tlocalStorage.setItem(versionKey, curVersion);\n\twindow.location.reload(true);\n};\n//暂不更新,加入延迟时间1小时\nexport const delayUpdateSysVersion = () => {\n\t//隐藏弹窗\n\tupdateApp.unmount();\n\tdocument.body.removeChild(document.querySelector(\"#update\"));\n\tlocalStorage.setItem(versionKey, curVersion);\n};\nconst noticeUser = message => {\n\tif (!document.querySelector(\"#update\")) {\n\t\tconst div = document.createElement(\"div\");\n\t\tdiv.setAttribute(\"id\", \"update\");\n\t\tdiv.style.position = \"absolute\";\n\t\tdiv.style.width = \"100%\";\n\t\tdiv.style.height = \"100%\";\n\t\tdiv.style.top = \"0\";\n\t\tdiv.style.left = \"0\";\n\t\tdocument.body.appendChild(div);\n\t\tupdateApp = createApp(Update, message);\n\t\tupdateApp.mount(\"#update\");\n\t}\n};\n","<script setup lang=\"ts\">\nimport { ref, reactive, defineProps } from \"vue\";\nimport { updateSysVersion, delayUpdateSysVersion } from \"@packages/utils/common/update\";\n// const props =\ninterface UpdateProps {\n\ttitle: String;\n\tdescription: String;\n\tcontent: Object;\n\ttime: String;\n}\n\nconst props = defineProps<UpdateProps>();\nconsole.log(props);\n</script>\n<template>\n\t<div class=\"update-wrap flex items-center justify-center\">\n\t\t<div class=\"relative update-content\">\n\t\t\t<div class=\"flex items-center justify-center\">{{ props?.title }}</div>\n\t\t\t<div class=\"flex flex-col gap-5 mt-10\">\n\t\t\t\t<div class=\"update-title\">{{ props?.description }}</div>\n\t\t\t\t<div class=\"update-item px-20\" v-for=\"(item, key) in props?.content\">\n\t\t\t\t\t<span>{{ key }}:</span> <span>{{ item }}</span>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"text-end\">{{ props.time }} 软件专业部</div>\n\t\t\t\t<div class=\"flex justify-end items-center mt-10\">\n\t\t\t\t\t<el-button plain @click=\"delayUpdateSysVersion\">暂不更新</el-button>\n\t\t\t\t\t<el-button @click=\"updateSysVersion\">立即更新</el-button>\n\t\t\t\t</div>\n\t\t\t\t<span class=\"tips mt-10\"\n\t\t\t\t\t>提示: 选择立即更新后,会立即刷新页面更新系统,当前页面缓存数据会消失选择暂不更新后,请稍后自行刷新页面更新系统。</span\n\t\t\t\t>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</template>\n<style scoped lang=\"scss\">\n.update-wrap {\n\tposition: absolute;\n\twidth: 100%;\n\theight: 100%;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tbackground: var(--dialog-overlay-background);\n\tz-index: 9999;\n\tcolor: var(--dialog-header-text-color);\n\tfont-family: YX-TEXT;\n\t.update-content {\n\t\twidth: 30%;\n\t\theight: fit-content;\n\t\tbackground: var(--dialog-background);\n\t\tborder-radius: var(--border-radius-medium);\n\t\tpadding: 20px 20px 10px 20px;\n\t\tbox-sizing: border-box;\n\t\t.tips {\n\t\t\tfont-size: 12px;\n\t\t}\n\t}\n}\n</style>\n","<!--\n * @Author: WangXin\n * @Date: 2024-04-02 20:01:00\n * @LastEditors: WangXin\n * @LastEditTime: 2024-04-11 15:11:58\n * @FilePath: /yxuse/packages/components/YxIcon/index.vue\n * @Description: \n * \n * Copyright (c) 2024 by YuXing, All Rights Reserved. \n-->\n<template>\n\t<i class=\"yx-icon\" :style=\"[{ '--color': color, 'font-size': size + 'px' }]\">\n\t\t<slot />\n\t</i>\n</template>\n\n<script>\n// import { version, createApp } from \"vue\";\n// console.log(this.$options);\nexport default {\n\tprops: {\n\t\tcolor: {\n\t\t\ttype: String,\n\t\t\tdefault: \"inherit\"\n\t\t},\n\t\tsize: {\n\t\t\ttype: String,\n\t\t\tdefault: \"16\"\n\t\t}\n\t}\n};\n</script>\n\n<style scoped>\n.yx-icon {\n\t--color: inherit;\n\tposition: relative;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\twidth: 1em;\n\theight: 1em;\n\tline-height: 1em;\n\tcolor: var(--color);\n\tfill: currentColor;\n}\n</style>\n","<!--\r\n * @Author: WangXin\r\n * @Date: 2024-03-20 09:40:21\r\n * @LastEditors: WangXin\r\n * @LastEditTime: 2025-05-22 09:26:11\r\n * @FilePath: /yxuse/packages/components/YxUpload/index.vue\r\n * @Description: \r\n * \r\n * Copyright (c) 2024 by YuXing, All Rights Reserved. \r\n-->\r\n<script setup lang=\"tsx\">\r\nimport { ref, useAttrs, useSlots } from \"vue\";\r\nimport type { UploadProps, UploadRawFile, UploadUserFile, UploadInstance } from \"element-plus\";\r\nimport { genFileId } from \"element-plus\";\r\nimport type { YxUploadProps } from \"./type\";\r\nimport { assets } from \"@packages/api\";\r\nconst attrs = useAttrs();\r\nconst slots = useSlots();\r\nconst fileList = ref<UploadUserFile[]>([]);\r\nconst props = defineProps<YxUploadProps>();\r\nlet uploadFileList: UploadUserFile[] = [];\r\nconst fileObsUrl = ref(\"\");\r\nconst upload = ref<UploadInstance>();\r\nconst emit = defineEmits<{\r\n\t(e: \"update:fileObsUrl\", value: string): void;\r\n\t(e: \"getFile\", value: any): void;\r\n}>();\r\nconst uploadFile = async (file: any) => {\r\n\tif (props?.customUpload) {\r\n\t\treturn props?.customUpload(file);\r\n\t}\r\n\tconst fromData = new FormData();\r\n\tfromData.append(\"file\", file);\r\n\tconst { data } = await (props?.uploadResourceApi ? props?.uploadResourceApi(fromData) : assets.uploadResourceApi(fromData));\r\n\tfileObsUrl.value = data.fileUrl;\r\n\temit(\"update:fileObsUrl\", fileObsUrl.value);\r\n};\r\nconst onExceed: UploadProps[\"onExceed\"] = async files => {\r\n\tupload.value!.clearFiles();\r\n\tconst file = files[0] as UploadRawFile;\r\n\tfile.uid = genFileId();\r\n\tupload.value!.handleStart(file);\r\n};\r\nconst onChange = async (file: UploadUserFile, uploadFiles: UploadUserFile[]) => {\r\n\tuploadFileList = uploadFiles;\r\n\tif (attrs?.limit && attrs?.limit === 1) {\r\n\t\tawait uploadFile(uploadFileList[0]?.raw);\r\n\t} else {\r\n\t\tawait uploadFile(uploadFileList);\r\n\t}\r\n};\r\n/**多文件使用 getFileList*/\r\nconst getFileList = () => uploadFileList;\r\ndefineExpose({ upload, getFileList });\r\nconst render = (props: YxUploadProps) => {\r\n\tconst defaultTrigger = () => {\r\n\t\treturn <el-button>{props.triggerText ?? \"上传文件\"}</el-button>;\r\n\t};\r\n\treturn (\r\n\t\t<>\r\n\t\t\t<el-upload\r\n\t\t\t\tref={upload}\r\n\t\t\t\tclass=\"w-full h-full\"\r\n\t\t\t\thttp-request={uploadFile}\r\n\t\t\t\tfile-list={fileList.value}\r\n\t\t\t\t{...attrs}\r\n\t\t\t\ton-exceed={onExceed}\r\n\t\t\t\ton-change={onChange}\r\n\t\t\t\tauto-upload={false}\r\n\t\t\t>\r\n\t\t\t\t{{\r\n\t\t\t\t\ttrigger: () => {\r\n\t\t\t\t\t\treturn props?.triggerRender\r\n\t\t\t\t\t\t\t? props?.triggerRender(fileObsUrl.value)\r\n\t\t\t\t\t\t\t: slots[\"trigger\"]\r\n\t\t\t\t\t\t\t? slots[\"trigger\"]()\r\n\t\t\t\t\t\t\t: defaultTrigger();\r\n\t\t\t\t\t},\r\n\t\t\t\t\ttip: () => {\r\n\t\t\t\t\t\treturn <div class=\"el-upload__tip\">{props?.uploadTips}</div>;\r\n\t\t\t\t\t}\r\n\t\t\t\t}}\r\n\t\t\t</el-upload>\r\n\t\t</>\r\n\t);\r\n};\r\n</script>\r\n<template>\r\n\t<component :model-value=\"fileObsUrl\" :is=\"render(props)\" />\r\n</template>\r\n<style scoped lang=\"scss\"></style>\r\n","<!--\n * @Author: WangXin\n * @Date: 2025-05-08 14:48:05\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-12 10:02:39\n * @FilePath: /yxuse/packages/components/LogoTitle/index.vue\n * @Description: \n * \n * Copyright (c) ${2024} by YuXing, All Rights Reserved. \n-->\n<script lang=\"ts\">\nimport { auth } from \"@packages/api\";\nimport type { SystemConfig } from \"./type\";\nexport default {\n\tname: \"LogoTitle\",\n\tprops: {\n\t\tshowLogo: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true\n\t\t},\n\t\tshowTitle: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t},\n\t\tlogoCanJump: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: true\n\t\t}\n\t},\n\tdata() {\n\t\treturn {\n\t\t\tcustomConfig: {\n\t\t\t\ticonStyle: {\n\t\t\t\t\twidth: \"116px\",\n\t\t\t\t\theight: \"20px\"\n\t\t\t\t}\n\t\t\t} as SystemConfig\n\t\t};\n\t},\n\tasync created() {\n\t\ttry {\n\t\t\tconst data = await auth.getUserConfig();\n\t\t\tthis.customConfig = {\n\t\t\t\t...this.customConfig,\n\t\t\t\t...data\n\t\t\t};\n\t\t} catch (e) {\n\t\t\tconsole.error(\"获取用户配置失败\", e);\n\t\t}\n\t},\n\tmethods: {\n\t\tlogoJumpHandle() {\n\t\t\tif (this.customConfig?.logoCanJump === false) return;\n\t\t\tauth.jumpToHome();\n\t\t}\n\t}\n};\n</script>\n\n<template>\n\t<div\n\t\tclass=\"flex items-center gap-x-10 logo-wrap\"\n\t\t:class=\"{ 'cursor-pointer': customConfig?.logoCanJump !== false }\"\n\t\t@click=\"logoJumpHandle\"\n\t>\n\t\t<div\n\t\t\tv-if=\"showLogo && customConfig?.icon\"\n\t\t\t:style=\"customConfig.iconStyle\"\n\t\t\tclass=\"yx-icon theme-icon\"\n\t\t\tv-html=\"customConfig.icon\"\n\t\t/>\n\t\t<div\n\t\t\t:style=\"customConfig.titleStyle\"\n\t\t\tv-if=\"showTitle && customConfig?.title\"\n\t\t\tclass=\"text-xl text-[var(--text-color-title)] title\"\n\t\t>\n\t\t\t{{ customConfig?.title }}\n\t\t</div>\n\t</div>\n</template>\n\n<style scoped>\n.logo-wrap {\n\tline-height: 1;\n}\n.yx-icon :deep() svg {\n\tvertical-align: middle;\n}\n</style>\n","/*\n * @Author: WangXin\n * @Date: 2025-05-08 14:48:05\n * @LastEditors: WangXin\n * @LastEditTime: 2025-05-08 18:01:08\n * @FilePath: /yxuse/packages/components/LogoTitle/index.ts\n * @Description:\n *\n * Copyright (c) ${2024} by YuXing, All Rights Reserved.\n */\nexport { default as LogoTitle } from \"./index.vue\";\nimport { version, createApp } from \"vue\";\nimport type { LogoTitleProps } from \"./type\";\nimport LogoTitle from \"./index.vue\";\nexport class LogoTitleRender {\n\tconstructor(props: LogoTitleProps, domId: string = \"system-logo-title\") {\n\t\tthis.render(props, domId);\n\t}\n\tget vueVersion(): \"2\" | \"3\" {\n\t\treturn version[0] as `${\"2\" | \"3\"}`;\n\t}\n\trender(props: LogoTitleProps, domId: string) {\n\t\tif (this.vueVersion === \"3\") {\n\t\t\tcreateApp(LogoTitle, props).mount(`#${domId}`);\n\t\t} else {\n\t\t\tconst Vue = require(\"vue\");\n\t\t\treturn new Vue({ render: h => h(LogoTitle, { props }) }).$mount(`#${domId}`);\n\t\t}\n\t}\n}\n"],"names":["dialogOptions","reactive","width","show","title","loading","showFooter","autoClose","close","dialogMap","submit","async","err","__expose","cancel","beforeOpen","beforeSubmit","drawerOptions","drawerMap","_isSlot","s","_isVNode","Object","prototype","toString","call","props","__props","slots","useSlots","attrs","useAttrs","tableRef","ref","tableFormRef","columns","isFormTable","formTableRules","emit","__emit","onMounted","nextTick","startSort","watch","initTable","onBeforeMount","value","forEach","col","required","rules","length","renderType","includes","config","loadOptions","getRules","options","sort","sortDom","$el","querySelector","_pnpm","Sortable","create","animation","handle","sortHandle","onEnd","oldIndex","newIndex","renderForm","prop","index","component","_createVNode","createVNode","_resolveComponent","default","handleRule","item","isSelect","defaultRule","message","label","trigger","filter","cell","render","form","children","_slot2","rowKey","tableData","pageInfo","renderColumn","map","cellConf","scope","renderOperate","dynamicComponent","column","$index","row","_slot","event","Component","resolveComponent","restConfig","_mergeProps","modelValue","$event","placeholder","isFormCell","val","type","Number","key","renderResult","needsValidation","isFragment","slotName","columnSlots","header","class","_createTextVNode","headerRender","headerSlotName","className","operate","op","disabled","onClick","withModifiers","_Fragment","model","renderTable","pagination","currentPage","pageIndex","pageSize","small","layout","background","total","onSizeChange","e","onCurrentChange","_slot3","data","exportDataToExcel","fileName","finalData","ws","XLSX.utils","aoa_to_sheet","wb","utils","book_new","book_append_sheet","XLSX.writeFile","exportToExcel","Date","now","updateColumns","newColumns","tableFormValidate","validate","Promise","resolve","_hoisted_1","xmlns","viewBox","Question","_ctx","_cache","_openBlock","openBlock","_createElementBlock","createElementBlock","_createElementVNode","fill","d","formData","formRules","formColumn","initForm","formList","formParams","Array","isArray","initialData","fillFormData","undefined","handleLinkOptions","keys","hasLoadOptions","linkOptions","_linkedHandled","originOnChange","onChange","updateForm","find","some","notAutoLoadOptions","parentProp","parentValue","onUnmounted","formRef","getFormStyle","formStyle","gap","style","getGroupStyle","groupStyle","formLayout","Fragment","formProps","formItemClassName","labelWidth","conf","mergeProps","formItemSlots","labelClassName","promptConf","tooltipConf","size","color","groupWrapClassName","groupWrapStyle","groupTitleClassName","groupTitleStyle","groupName","groupClassName","renderFormItem","formValidate","versionKey","curVersion","updateSysVersion","localStorage","setItem","window","location","reload","delayUpdateSysVersion","updateApp","unmount","document","body","removeChild","_sfc_main","String","_normalizeStyle","normalizeStyle","$props","_renderSlot","renderSlot","$slots","fileList","uploadFileList","fileObsUrl","upload","uploadFile","file","customUpload","fromData","FormData","append","uploadResourceApi","assets","fileUrl","onExceed","files","clearFiles","uid","genFileId","handleStart","uploadFiles","limit","raw","getFileList","triggerRender","triggerText","tip","uploadTips","name","showLogo","Boolean","showTitle","logoCanJump","customConfig","iconStyle","height","created","auth.getUserConfig","this","methods","logoJumpHandle","_a","auth.jumpToHome","$setup","$data","$options","_normalizeClass","args","_b","icon","innerHTML","_createCommentVNode","createCommentVNode","_c","titleStyle","_toDisplayString","toDisplayString","_d","LogoTitleRender","constructor","domId","vueVersion","version","require","h","LogoTitle","$mount","createApp","mount"],"mappings":"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"}