devextreme-exceljs-fork 4.4.7 → 4.4.8

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 (109) hide show
  1. package/dist/dx-exceljs-fork.bare.js +445 -541
  2. package/dist/dx-exceljs-fork.bare.js.map +18 -18
  3. package/dist/dx-exceljs-fork.bare.min.js +7 -7
  4. package/dist/dx-exceljs-fork.bare.min.js.map +1 -1
  5. package/dist/dx-exceljs-fork.js +445 -541
  6. package/dist/dx-exceljs-fork.js.map +18 -18
  7. package/dist/dx-exceljs-fork.min.js +6 -6
  8. package/dist/dx-exceljs-fork.min.js.map +1 -1
  9. package/dist/es5/csv/csv.js +1 -1
  10. package/dist/es5/csv/csv.js.map +1 -1
  11. package/dist/es5/doc/cell.js +5 -5
  12. package/dist/es5/doc/cell.js.map +1 -1
  13. package/dist/es5/doc/pivot-table.js +1 -1
  14. package/dist/es5/doc/pivot-table.js.map +1 -1
  15. package/dist/es5/doc/range.js +7 -7
  16. package/dist/es5/doc/range.js.map +1 -1
  17. package/dist/es5/doc/row.js +1 -1
  18. package/dist/es5/doc/row.js.map +1 -1
  19. package/dist/es5/doc/table.js +10 -10
  20. package/dist/es5/doc/table.js.map +1 -1
  21. package/dist/es5/doc/worksheet.js +7 -6
  22. package/dist/es5/doc/worksheet.js.map +1 -1
  23. package/dist/es5/stream/xlsx/hyperlink-reader.js +26 -49
  24. package/dist/es5/stream/xlsx/hyperlink-reader.js.map +1 -1
  25. package/dist/es5/stream/xlsx/sheet-comments-writer.js +6 -6
  26. package/dist/es5/stream/xlsx/sheet-comments-writer.js.map +1 -1
  27. package/dist/es5/stream/xlsx/sheet-rels-writer.js +6 -5
  28. package/dist/es5/stream/xlsx/sheet-rels-writer.js.map +1 -1
  29. package/dist/es5/stream/xlsx/workbook-reader.js +215 -320
  30. package/dist/es5/stream/xlsx/workbook-reader.js.map +1 -1
  31. package/dist/es5/stream/xlsx/workbook-writer.js +8 -8
  32. package/dist/es5/stream/xlsx/workbook-writer.js.map +1 -1
  33. package/dist/es5/stream/xlsx/worksheet-reader.js +265 -341
  34. package/dist/es5/stream/xlsx/worksheet-reader.js.map +1 -1
  35. package/dist/es5/stream/xlsx/worksheet-writer.js +9 -13
  36. package/dist/es5/stream/xlsx/worksheet-writer.js.map +1 -1
  37. package/dist/es5/utils/col-cache.js +14 -18
  38. package/dist/es5/utils/col-cache.js.map +1 -1
  39. package/dist/es5/utils/copy-style.js +12 -10
  40. package/dist/es5/utils/copy-style.js.map +1 -1
  41. package/dist/es5/utils/encryptor.js +1 -1
  42. package/dist/es5/utils/encryptor.js.map +1 -1
  43. package/dist/es5/utils/iterate-stream.js +26 -37
  44. package/dist/es5/utils/iterate-stream.js.map +1 -1
  45. package/dist/es5/utils/parse-sax.js +34 -67
  46. package/dist/es5/utils/parse-sax.js.map +1 -1
  47. package/dist/es5/utils/utils.js +1 -1
  48. package/dist/es5/utils/utils.js.map +1 -1
  49. package/dist/es5/utils/xml-stream.js +1 -1
  50. package/dist/es5/utils/xml-stream.js.map +1 -1
  51. package/dist/es5/xlsx/xform/base-xform.js +12 -35
  52. package/dist/es5/xlsx/xform/base-xform.js.map +1 -1
  53. package/dist/es5/xlsx/xform/book/defined-name-xform.js +2 -2
  54. package/dist/es5/xlsx/xform/book/defined-name-xform.js.map +1 -1
  55. package/dist/es5/xlsx/xform/book/workbook-xform.js +5 -5
  56. package/dist/es5/xlsx/xform/book/workbook-xform.js.map +1 -1
  57. package/dist/es5/xlsx/xform/comment/comment-xform.js +4 -8
  58. package/dist/es5/xlsx/xform/comment/comment-xform.js.map +1 -1
  59. package/dist/es5/xlsx/xform/comment/vml-shape-xform.js +1 -1
  60. package/dist/es5/xlsx/xform/comment/vml-shape-xform.js.map +1 -1
  61. package/dist/es5/xlsx/xform/comment/vml-textbox-xform.js +1 -1
  62. package/dist/es5/xlsx/xform/comment/vml-textbox-xform.js.map +1 -1
  63. package/dist/es5/xlsx/xform/core/content-types-xform.js +5 -5
  64. package/dist/es5/xlsx/xform/core/content-types-xform.js.map +1 -1
  65. package/dist/es5/xlsx/xform/core/core-xform.js +2 -2
  66. package/dist/es5/xlsx/xform/core/core-xform.js.map +1 -1
  67. package/dist/es5/xlsx/xform/core/relationships-xform.js +2 -2
  68. package/dist/es5/xlsx/xform/core/relationships-xform.js.map +1 -1
  69. package/dist/es5/xlsx/xform/drawing/c-nv-pr-xform.js +1 -1
  70. package/dist/es5/xlsx/xform/drawing/c-nv-pr-xform.js.map +1 -1
  71. package/dist/es5/xlsx/xform/list-xform.js +1 -1
  72. package/dist/es5/xlsx/xform/list-xform.js.map +1 -1
  73. package/dist/es5/xlsx/xform/pivot-table/cache-field.js +8 -2
  74. package/dist/es5/xlsx/xform/pivot-table/cache-field.js.map +1 -1
  75. package/dist/es5/xlsx/xform/pivot-table/pivot-cache-definition-xform.js +3 -7
  76. package/dist/es5/xlsx/xform/pivot-table/pivot-cache-definition-xform.js.map +1 -1
  77. package/dist/es5/xlsx/xform/pivot-table/pivot-cache-records-xform.js +7 -11
  78. package/dist/es5/xlsx/xform/pivot-table/pivot-cache-records-xform.js.map +1 -1
  79. package/dist/es5/xlsx/xform/pivot-table/pivot-table-xform.js +70 -10
  80. package/dist/es5/xlsx/xform/pivot-table/pivot-table-xform.js.map +1 -1
  81. package/dist/es5/xlsx/xform/sheet/auto-filter-xform.js +1 -1
  82. package/dist/es5/xlsx/xform/sheet/auto-filter-xform.js.map +1 -1
  83. package/dist/es5/xlsx/xform/sheet/cell-xform.js +4 -8
  84. package/dist/es5/xlsx/xform/sheet/cell-xform.js.map +1 -1
  85. package/dist/es5/xlsx/xform/sheet/cf/cf-rule-xform.js +18 -22
  86. package/dist/es5/xlsx/xform/sheet/cf/cf-rule-xform.js.map +1 -1
  87. package/dist/es5/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js +2 -2
  88. package/dist/es5/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js.map +1 -1
  89. package/dist/es5/xlsx/xform/sheet/data-validations-xform.js +11 -13
  90. package/dist/es5/xlsx/xform/sheet/data-validations-xform.js.map +1 -1
  91. package/dist/es5/xlsx/xform/sheet/merges.js +1 -1
  92. package/dist/es5/xlsx/xform/sheet/merges.js.map +1 -1
  93. package/dist/es5/xlsx/xform/sheet/row-xform.js +2 -2
  94. package/dist/es5/xlsx/xform/sheet/row-xform.js.map +1 -1
  95. package/dist/es5/xlsx/xform/sheet/worksheet-xform.js +10 -10
  96. package/dist/es5/xlsx/xform/sheet/worksheet-xform.js.map +1 -1
  97. package/dist/es5/xlsx/xform/strings/shared-strings-xform.js +2 -2
  98. package/dist/es5/xlsx/xform/strings/shared-strings-xform.js.map +1 -1
  99. package/dist/es5/xlsx/xform/style/border-xform.js +3 -7
  100. package/dist/es5/xlsx/xform/style/border-xform.js.map +1 -1
  101. package/dist/es5/xlsx/xform/table/auto-filter-xform.js +2 -2
  102. package/dist/es5/xlsx/xform/table/auto-filter-xform.js.map +1 -1
  103. package/dist/es5/xlsx/xform/table/filter-column-xform.js +1 -1
  104. package/dist/es5/xlsx/xform/table/filter-column-xform.js.map +1 -1
  105. package/dist/es5/xlsx/xform/table/table-xform.js +3 -7
  106. package/dist/es5/xlsx/xform/table/table-xform.js.map +1 -1
  107. package/dist/es5/xlsx/xlsx.js +22 -45
  108. package/dist/es5/xlsx/xlsx.js.map +1 -1
  109. package/package.json +13 -14
@@ -48,7 +48,7 @@ class CSV {
48
48
  async readFile(filename, options) {
49
49
  options = options || {};
50
50
  if (!(await exists(filename))) {
51
- throw new Error("File not found: ".concat(filename));
51
+ throw new Error(`File not found: ${filename}`);
52
52
  }
53
53
  const stream = fs.createReadStream(filename);
54
54
  const worksheet = await this.read(stream, options);
@@ -1 +1 @@
1
- {"version":3,"file":"csv.js","names":["fs","require","fastCsv","customParseFormat","utc","dayjs","extend","StreamBuf","exists","SpecialValues","true","false","error","CSV","constructor","workbook","worksheet","readFile","filename","options","Error","concat","stream","createReadStream","read","close","Promise","resolve","reject","addWorksheet","sheetName","dateFormats","map","datum","datumNumber","Number","isNaN","Infinity","dt","reduce","matchingDate","currentDateFormat","dayjsObj","isValid","Date","valueOf","special","undefined","csvStream","parse","parserOptions","on","data","addRow","emit","pipe","createInputStream","write","getWorksheet","sheetId","format","formatterOptions","dateFormat","dateUTC","value","text","hyperlink","formula","result","JSON","stringify","includeEmptyRows","lastRow","eachRow","row","rowNumber","values","shift","end","writeFile","streamOptions","encoding","createWriteStream","writeBuffer","module","exports"],"sources":["../../../lib/csv/csv.js"],"sourcesContent":["const fs = require('fs');\nconst fastCsv = require('fast-csv');\nconst customParseFormat = require('dayjs/plugin/customParseFormat');\nconst utc = require('dayjs/plugin/utc');\nconst dayjs = require('dayjs').extend(customParseFormat).extend(utc);\nconst StreamBuf = require('../utils/stream-buf');\n\nconst {\n fs: {exists},\n} = require('../utils/utils');\n\n/* eslint-disable quote-props */\nconst SpecialValues = {\n true: true,\n false: false,\n '#N/A': {error: '#N/A'},\n '#REF!': {error: '#REF!'},\n '#NAME?': {error: '#NAME?'},\n '#DIV/0!': {error: '#DIV/0!'},\n '#NULL!': {error: '#NULL!'},\n '#VALUE!': {error: '#VALUE!'},\n '#NUM!': {error: '#NUM!'},\n};\n/* eslint-ensable quote-props */\n\nclass CSV {\n constructor(workbook) {\n this.workbook = workbook;\n this.worksheet = null;\n }\n\n async readFile(filename, options) {\n options = options || {};\n if (!(await exists(filename))) {\n throw new Error(`File not found: ${filename}`);\n }\n const stream = fs.createReadStream(filename);\n const worksheet = await this.read(stream, options);\n stream.close();\n return worksheet;\n }\n\n read(stream, options) {\n options = options || {};\n\n return new Promise((resolve, reject) => {\n const worksheet = this.workbook.addWorksheet(options.sheetName);\n\n const dateFormats = options.dateFormats || [\n 'YYYY-MM-DD[T]HH:mm:ssZ',\n 'YYYY-MM-DD[T]HH:mm:ss',\n 'MM-DD-YYYY',\n 'YYYY-MM-DD',\n ];\n const map =\n options.map ||\n function(datum) {\n if (datum === '') {\n return null;\n }\n const datumNumber = Number(datum);\n if (!Number.isNaN(datumNumber) && datumNumber !== Infinity) {\n return datumNumber;\n }\n const dt = dateFormats.reduce((matchingDate, currentDateFormat) => {\n if (matchingDate) {\n return matchingDate;\n }\n const dayjsObj = dayjs(datum, currentDateFormat, true);\n if (dayjsObj.isValid()) {\n return dayjsObj;\n }\n return null;\n }, null);\n if (dt) {\n return new Date(dt.valueOf());\n }\n const special = SpecialValues[datum];\n if (special !== undefined) {\n return special;\n }\n return datum;\n };\n\n const csvStream = fastCsv\n .parse(options.parserOptions)\n .on('data', data => {\n worksheet.addRow(data.map(map));\n })\n .on('end', () => {\n csvStream.emit('worksheet', worksheet);\n });\n\n csvStream.on('worksheet', resolve).on('error', reject);\n\n stream.pipe(csvStream);\n });\n }\n\n /**\n * @deprecated since version 4.0. You should use `CSV#read` instead. Please follow upgrade instruction: https://github.com/exceljs/exceljs/blob/master/UPGRADE-4.0.md\n */\n createInputStream() {\n throw new Error(\n '`CSV#createInputStream` is deprecated. You should use `CSV#read` instead. This method will be removed in version 5.0. Please follow upgrade instruction: https://github.com/exceljs/exceljs/blob/master/UPGRADE-4.0.md'\n );\n }\n\n write(stream, options) {\n return new Promise((resolve, reject) => {\n options = options || {};\n // const encoding = options.encoding || 'utf8';\n // const separator = options.separator || ',';\n // const quoteChar = options.quoteChar || '\\'';\n\n const worksheet = this.workbook.getWorksheet(options.sheetName || options.sheetId);\n\n const csvStream = fastCsv.format(options.formatterOptions);\n stream.on('finish', () => {\n resolve();\n });\n csvStream.on('error', reject);\n csvStream.pipe(stream);\n\n const {dateFormat, dateUTC} = options;\n const map =\n options.map ||\n (value => {\n if (value) {\n if (value.text || value.hyperlink) {\n return value.hyperlink || value.text || '';\n }\n if (value.formula || value.result) {\n return value.result || '';\n }\n if (value instanceof Date) {\n if (dateFormat) {\n return dateUTC\n ? dayjs.utc(value).format(dateFormat)\n : dayjs(value).format(dateFormat);\n }\n return dateUTC ? dayjs.utc(value).format() : dayjs(value).format();\n }\n if (value.error) {\n return value.error;\n }\n if (typeof value === 'object') {\n return JSON.stringify(value);\n }\n }\n return value;\n });\n\n const includeEmptyRows = options.includeEmptyRows === undefined || options.includeEmptyRows;\n let lastRow = 1;\n if (worksheet) {\n worksheet.eachRow((row, rowNumber) => {\n if (includeEmptyRows) {\n while (lastRow++ < rowNumber - 1) {\n csvStream.write([]);\n }\n }\n const {values} = row;\n values.shift();\n csvStream.write(values.map(map));\n lastRow = rowNumber;\n });\n }\n csvStream.end();\n });\n }\n\n writeFile(filename, options) {\n options = options || {};\n\n const streamOptions = {\n encoding: options.encoding || 'utf8',\n };\n const stream = fs.createWriteStream(filename, streamOptions);\n\n return this.write(stream, options);\n }\n\n async writeBuffer(options) {\n const stream = new StreamBuf();\n await this.write(stream, options);\n return stream.read();\n }\n}\n\nmodule.exports = CSV;\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"csv.js","names":["fs","require","fastCsv","customParseFormat","utc","dayjs","extend","StreamBuf","exists","SpecialValues","true","false","error","CSV","constructor","workbook","worksheet","readFile","filename","options","Error","stream","createReadStream","read","close","Promise","resolve","reject","addWorksheet","sheetName","dateFormats","map","datum","datumNumber","Number","isNaN","Infinity","dt","reduce","matchingDate","currentDateFormat","dayjsObj","isValid","Date","valueOf","special","undefined","csvStream","parse","parserOptions","on","data","addRow","emit","pipe","createInputStream","write","getWorksheet","sheetId","format","formatterOptions","dateFormat","dateUTC","value","text","hyperlink","formula","result","JSON","stringify","includeEmptyRows","lastRow","eachRow","row","rowNumber","values","shift","end","writeFile","streamOptions","encoding","createWriteStream","writeBuffer","module","exports"],"sources":["../../../lib/csv/csv.js"],"sourcesContent":["const fs = require('fs');\nconst fastCsv = require('fast-csv');\nconst customParseFormat = require('dayjs/plugin/customParseFormat');\nconst utc = require('dayjs/plugin/utc');\nconst dayjs = require('dayjs').extend(customParseFormat).extend(utc);\nconst StreamBuf = require('../utils/stream-buf');\n\nconst {\n fs: {exists},\n} = require('../utils/utils');\n\n/* eslint-disable quote-props */\nconst SpecialValues = {\n true: true,\n false: false,\n '#N/A': {error: '#N/A'},\n '#REF!': {error: '#REF!'},\n '#NAME?': {error: '#NAME?'},\n '#DIV/0!': {error: '#DIV/0!'},\n '#NULL!': {error: '#NULL!'},\n '#VALUE!': {error: '#VALUE!'},\n '#NUM!': {error: '#NUM!'},\n};\n/* eslint-ensable quote-props */\n\nclass CSV {\n constructor(workbook) {\n this.workbook = workbook;\n this.worksheet = null;\n }\n\n async readFile(filename, options) {\n options = options || {};\n if (!(await exists(filename))) {\n throw new Error(`File not found: ${filename}`);\n }\n const stream = fs.createReadStream(filename);\n const worksheet = await this.read(stream, options);\n stream.close();\n return worksheet;\n }\n\n read(stream, options) {\n options = options || {};\n\n return new Promise((resolve, reject) => {\n const worksheet = this.workbook.addWorksheet(options.sheetName);\n\n const dateFormats = options.dateFormats || [\n 'YYYY-MM-DD[T]HH:mm:ssZ',\n 'YYYY-MM-DD[T]HH:mm:ss',\n 'MM-DD-YYYY',\n 'YYYY-MM-DD',\n ];\n const map =\n options.map ||\n function(datum) {\n if (datum === '') {\n return null;\n }\n const datumNumber = Number(datum);\n if (!Number.isNaN(datumNumber) && datumNumber !== Infinity) {\n return datumNumber;\n }\n const dt = dateFormats.reduce((matchingDate, currentDateFormat) => {\n if (matchingDate) {\n return matchingDate;\n }\n const dayjsObj = dayjs(datum, currentDateFormat, true);\n if (dayjsObj.isValid()) {\n return dayjsObj;\n }\n return null;\n }, null);\n if (dt) {\n return new Date(dt.valueOf());\n }\n const special = SpecialValues[datum];\n if (special !== undefined) {\n return special;\n }\n return datum;\n };\n\n const csvStream = fastCsv\n .parse(options.parserOptions)\n .on('data', data => {\n worksheet.addRow(data.map(map));\n })\n .on('end', () => {\n csvStream.emit('worksheet', worksheet);\n });\n\n csvStream.on('worksheet', resolve).on('error', reject);\n\n stream.pipe(csvStream);\n });\n }\n\n /**\n * @deprecated since version 4.0. You should use `CSV#read` instead. Please follow upgrade instruction: https://github.com/exceljs/exceljs/blob/master/UPGRADE-4.0.md\n */\n createInputStream() {\n throw new Error(\n '`CSV#createInputStream` is deprecated. You should use `CSV#read` instead. This method will be removed in version 5.0. Please follow upgrade instruction: https://github.com/exceljs/exceljs/blob/master/UPGRADE-4.0.md'\n );\n }\n\n write(stream, options) {\n return new Promise((resolve, reject) => {\n options = options || {};\n // const encoding = options.encoding || 'utf8';\n // const separator = options.separator || ',';\n // const quoteChar = options.quoteChar || '\\'';\n\n const worksheet = this.workbook.getWorksheet(options.sheetName || options.sheetId);\n\n const csvStream = fastCsv.format(options.formatterOptions);\n stream.on('finish', () => {\n resolve();\n });\n csvStream.on('error', reject);\n csvStream.pipe(stream);\n\n const {dateFormat, dateUTC} = options;\n const map =\n options.map ||\n (value => {\n if (value) {\n if (value.text || value.hyperlink) {\n return value.hyperlink || value.text || '';\n }\n if (value.formula || value.result) {\n return value.result || '';\n }\n if (value instanceof Date) {\n if (dateFormat) {\n return dateUTC\n ? dayjs.utc(value).format(dateFormat)\n : dayjs(value).format(dateFormat);\n }\n return dateUTC ? dayjs.utc(value).format() : dayjs(value).format();\n }\n if (value.error) {\n return value.error;\n }\n if (typeof value === 'object') {\n return JSON.stringify(value);\n }\n }\n return value;\n });\n\n const includeEmptyRows = options.includeEmptyRows === undefined || options.includeEmptyRows;\n let lastRow = 1;\n if (worksheet) {\n worksheet.eachRow((row, rowNumber) => {\n if (includeEmptyRows) {\n while (lastRow++ < rowNumber - 1) {\n csvStream.write([]);\n }\n }\n const {values} = row;\n values.shift();\n csvStream.write(values.map(map));\n lastRow = rowNumber;\n });\n }\n csvStream.end();\n });\n }\n\n writeFile(filename, options) {\n options = options || {};\n\n const streamOptions = {\n encoding: options.encoding || 'utf8',\n };\n const stream = fs.createWriteStream(filename, streamOptions);\n\n return this.write(stream, options);\n }\n\n async writeBuffer(options) {\n const stream = new StreamBuf();\n await this.write(stream, options);\n return stream.read();\n }\n}\n\nmodule.exports = CSV;\n"],"mappings":"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","ignoreList":[]}
@@ -110,7 +110,7 @@ class Cell {
110
110
  return this._column.number;
111
111
  }
112
112
  get $col$row() {
113
- return "$".concat(this._column.letter, "$").concat(this.row);
113
+ return `$${this._column.letter}$${this.row}`;
114
114
  }
115
115
 
116
116
  // =========================================================================
@@ -406,7 +406,7 @@ class StringValue {
406
406
  this.model.address = value;
407
407
  }
408
408
  toCsvString() {
409
- return "\"".concat(this.model.value.replace(/"/g, '""'), "\"");
409
+ return `"${this.model.value.replace(/"/g, '""')}"`;
410
410
  }
411
411
  release() {}
412
412
  toString() {
@@ -443,7 +443,7 @@ class RichTextValue {
443
443
  this.model.address = value;
444
444
  }
445
445
  toCsvString() {
446
- return "\"".concat(this.text.replace(/"/g, '""'), "\"");
446
+ return `"${this.text.replace(/"/g, '""')}"`;
447
447
  }
448
448
  release() {}
449
449
  }
@@ -726,7 +726,7 @@ class FormulaValue {
726
726
  return this._translatedFormula;
727
727
  }
728
728
  toCsvString() {
729
- return "".concat(this.model.result || '');
729
+ return `${this.model.result || ''}`;
730
730
  }
731
731
  release() {}
732
732
  toString() {
@@ -951,7 +951,7 @@ const Value = {
951
951
  create(type, cell, value) {
952
952
  const T = this.types[type];
953
953
  if (!T) {
954
- throw new Error("Could not create Value of type ".concat(type));
954
+ throw new Error(`Could not create Value of type ${type}`);
955
955
  }
956
956
  return new T(cell, value);
957
957
  }
@@ -1 +1 @@
1
- {"version":3,"file":"cell.js","names":["colCache","require","_","Enums","slideFormula","Note","Cell","constructor","row","column","address","Error","_row","_column","validateAddress","_address","_value","Value","create","Types","Null","style","_mergeStyle","_mergeCount","worksheet","workbook","destroy","numFmt","value","font","alignment","border","fill","protection","rowStyle","colStyle","number","col","$col$row","concat","letter","type","effectiveType","toCsvString","addMergeRef","releaseMergeRef","isMerged","Merge","merge","master","ignoreStyle","release","unmerge","isMergedTo","isHyperlink","Hyperlink","hyperlink","v","getType","note","_comment","text","toString","html","escapeHtml","_upgradeToHyperlink","String","formula","result","formulaType","fullAddress","sheetName","name","names","definedNames","getNamesEx","removeAllNames","forEach","addEx","addName","removeName","removeEx","_dataValidations","dataValidations","dataValidation","find","add","model","comment","fromModel","ValueType","NullValue","cell","NumberValue","Number","StringValue","replace","RichTextValue","richText","map","t","join","RichText","DateValue","Date","toISOString","HyperlinkValue","undefined","tooltip","MergeValue","_master","FormulaValue","Formula","shareType","ref","sharedFormula","_copyModel","copy","cp","validate","dependencies","ranges","match","cells","_getTranslatedFormula","FormulaType","Master","Shared","None","_translatedFormula","findCell","SharedStringValue","SharedString","BooleanValue","Boolean","ErrorValue","error","JSONValue","JSON","stringify","rawValue","sharedString","types","f","reduce","p","T","module","exports"],"sources":["../../../lib/doc/cell.js"],"sourcesContent":["/* eslint-disable max-classes-per-file */\nconst colCache = require('../utils/col-cache');\nconst _ = require('../utils/under-dash');\nconst Enums = require('./enums');\nconst {slideFormula} = require('../utils/shared-formula');\nconst Note = require('./note');\n// Cell requirements\n// Operate inside a worksheet\n// Store and retrieve a value with a range of types: text, number, date, hyperlink, reference, formula, etc.\n// Manage/use and manipulate cell format either as local to cell or inherited from column or row.\n\nclass Cell {\n constructor(row, column, address) {\n if (!row || !column) {\n throw new Error('A Cell needs a Row');\n }\n\n this._row = row;\n this._column = column;\n\n colCache.validateAddress(address);\n this._address = address;\n\n // TODO: lazy evaluation of this._value\n this._value = Value.create(Cell.Types.Null, this);\n\n this.style = this._mergeStyle(row.style, column.style, {});\n\n this._mergeCount = 0;\n }\n\n get worksheet() {\n return this._row.worksheet;\n }\n\n get workbook() {\n return this._row.worksheet.workbook;\n }\n\n // help GC by removing cyclic (and other) references\n destroy() {\n delete this.style;\n delete this._value;\n delete this._row;\n delete this._column;\n delete this._address;\n }\n\n // =========================================================================\n // Styles stuff\n get numFmt() {\n return this.style.numFmt;\n }\n\n set numFmt(value) {\n this.style.numFmt = value;\n }\n\n get font() {\n return this.style.font;\n }\n\n set font(value) {\n this.style.font = value;\n }\n\n get alignment() {\n return this.style.alignment;\n }\n\n set alignment(value) {\n this.style.alignment = value;\n }\n\n get border() {\n return this.style.border;\n }\n\n set border(value) {\n this.style.border = value;\n }\n\n get fill() {\n return this.style.fill;\n }\n\n set fill(value) {\n this.style.fill = value;\n }\n\n get protection() {\n return this.style.protection;\n }\n\n set protection(value) {\n this.style.protection = value;\n }\n\n _mergeStyle(rowStyle, colStyle, style) {\n const numFmt = (rowStyle && rowStyle.numFmt) || (colStyle && colStyle.numFmt);\n if (numFmt) style.numFmt = numFmt;\n\n const font = (rowStyle && rowStyle.font) || (colStyle && colStyle.font);\n if (font) style.font = font;\n\n const alignment = (rowStyle && rowStyle.alignment) || (colStyle && colStyle.alignment);\n if (alignment) style.alignment = alignment;\n\n const border = (rowStyle && rowStyle.border) || (colStyle && colStyle.border);\n if (border) style.border = border;\n\n const fill = (rowStyle && rowStyle.fill) || (colStyle && colStyle.fill);\n if (fill) style.fill = fill;\n\n const protection = (rowStyle && rowStyle.protection) || (colStyle && colStyle.protection);\n if (protection) style.protection = protection;\n\n return style;\n }\n\n // =========================================================================\n // return the address for this cell\n get address() {\n return this._address;\n }\n\n get row() {\n return this._row.number;\n }\n\n get col() {\n return this._column.number;\n }\n\n get $col$row() {\n return `$${this._column.letter}$${this.row}`;\n }\n\n // =========================================================================\n // Value stuff\n\n get type() {\n return this._value.type;\n }\n\n get effectiveType() {\n return this._value.effectiveType;\n }\n\n toCsvString() {\n return this._value.toCsvString();\n }\n\n // =========================================================================\n // Merge stuff\n\n addMergeRef() {\n this._mergeCount++;\n }\n\n releaseMergeRef() {\n this._mergeCount--;\n }\n\n get isMerged() {\n return this._mergeCount > 0 || this.type === Cell.Types.Merge;\n }\n\n merge(master, ignoreStyle) {\n this._value.release();\n this._value = Value.create(Cell.Types.Merge, this, master);\n if (!ignoreStyle) {\n this.style = master.style;\n }\n }\n\n unmerge() {\n if (this.type === Cell.Types.Merge) {\n this._value.release();\n this._value = Value.create(Cell.Types.Null, this);\n this.style = this._mergeStyle(this._row.style, this._column.style, {});\n }\n }\n\n isMergedTo(master) {\n if (this._value.type !== Cell.Types.Merge) return false;\n return this._value.isMergedTo(master);\n }\n\n get master() {\n if (this.type === Cell.Types.Merge) {\n return this._value.master;\n }\n return this; // an unmerged cell is its own master\n }\n\n get isHyperlink() {\n return this._value.type === Cell.Types.Hyperlink;\n }\n\n get hyperlink() {\n return this._value.hyperlink;\n }\n\n // return the value\n get value() {\n return this._value.value;\n }\n\n // set the value - can be number, string or raw\n set value(v) {\n // special case - merge cells set their master's value\n if (this.type === Cell.Types.Merge) {\n this._value.master.value = v;\n return;\n }\n\n this._value.release();\n\n // assign value\n this._value = Value.create(Value.getType(v), this, v);\n }\n\n get note() {\n return this._comment && this._comment.note;\n }\n\n set note(note) {\n this._comment = new Note(note);\n }\n\n get text() {\n return this._value.toString();\n }\n\n get html() {\n return _.escapeHtml(this.text);\n }\n\n toString() {\n return this.text;\n }\n\n _upgradeToHyperlink(hyperlink) {\n // if this cell is a string, turn it into a Hyperlink\n if (this.type === Cell.Types.String) {\n this._value = Value.create(Cell.Types.Hyperlink, this, {\n text: this._value.value,\n hyperlink,\n });\n }\n }\n\n // =========================================================================\n // Formula stuff\n get formula() {\n return this._value.formula;\n }\n\n get result() {\n return this._value.result;\n }\n\n get formulaType() {\n return this._value.formulaType;\n }\n\n // =========================================================================\n // Name stuff\n get fullAddress() {\n const {worksheet} = this._row;\n return {\n sheetName: worksheet.name,\n address: this.address,\n row: this.row,\n col: this.col,\n };\n }\n\n get name() {\n return this.names[0];\n }\n\n set name(value) {\n this.names = [value];\n }\n\n get names() {\n return this.workbook.definedNames.getNamesEx(this.fullAddress);\n }\n\n set names(value) {\n const {definedNames} = this.workbook;\n definedNames.removeAllNames(this.fullAddress);\n value.forEach(name => {\n definedNames.addEx(this.fullAddress, name);\n });\n }\n\n addName(name) {\n this.workbook.definedNames.addEx(this.fullAddress, name);\n }\n\n removeName(name) {\n this.workbook.definedNames.removeEx(this.fullAddress, name);\n }\n\n removeAllNames() {\n this.workbook.definedNames.removeAllNames(this.fullAddress);\n }\n\n // =========================================================================\n // Data Validation stuff\n get _dataValidations() {\n return this.worksheet.dataValidations;\n }\n\n get dataValidation() {\n return this._dataValidations.find(this.address);\n }\n\n set dataValidation(value) {\n this._dataValidations.add(this.address, value);\n }\n\n // =========================================================================\n // Model stuff\n\n get model() {\n const {model} = this._value;\n model.style = this.style;\n if (this._comment) {\n model.comment = this._comment.model;\n }\n return model;\n }\n\n set model(value) {\n this._value.release();\n this._value = Value.create(value.type, this);\n this._value.model = value;\n\n if (value.comment) {\n switch (value.comment.type) {\n case 'note':\n this._comment = Note.fromModel(value.comment);\n break;\n }\n }\n\n if (value.style) {\n this.style = value.style;\n } else {\n this.style = {};\n }\n }\n}\nCell.Types = Enums.ValueType;\n\n// =============================================================================\n// Internal Value Types\n\nclass NullValue {\n constructor(cell) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Null,\n };\n }\n\n get value() {\n return null;\n }\n\n set value(value) {\n // nothing to do\n }\n\n get type() {\n return Cell.Types.Null;\n }\n\n get effectiveType() {\n return Cell.Types.Null;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return '';\n }\n\n release() {}\n\n toString() {\n return '';\n }\n}\n\nclass NumberValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Number,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.Number;\n }\n\n get effectiveType() {\n return Cell.Types.Number;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value.toString();\n }\n\n release() {}\n\n toString() {\n return this.model.value.toString();\n }\n}\n\nclass StringValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.String,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.String;\n }\n\n get effectiveType() {\n return Cell.Types.String;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return `\"${this.model.value.replace(/\"/g, '\"\"')}\"`;\n }\n\n release() {}\n\n toString() {\n return this.model.value;\n }\n}\n\nclass RichTextValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.String,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n toString() {\n return this.model.value.richText.map(t => t.text).join('');\n }\n\n get type() {\n return Cell.Types.RichText;\n }\n\n get effectiveType() {\n return Cell.Types.RichText;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return `\"${this.text.replace(/\"/g, '\"\"')}\"`;\n }\n\n release() {}\n}\n\nclass DateValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Date,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.Date;\n }\n\n get effectiveType() {\n return Cell.Types.Date;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value.toISOString();\n }\n\n release() {}\n\n toString() {\n return this.model.value.toString();\n }\n}\n\nclass HyperlinkValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Hyperlink,\n text: value ? value.text : undefined,\n hyperlink: value ? value.hyperlink : undefined,\n };\n if (value && value.tooltip) {\n this.model.tooltip = value.tooltip;\n }\n }\n\n get value() {\n const v = {\n text: this.model.text,\n hyperlink: this.model.hyperlink,\n };\n if (this.model.tooltip) {\n v.tooltip = this.model.tooltip;\n }\n return v;\n }\n\n set value(value) {\n this.model = {\n text: value.text,\n hyperlink: value.hyperlink,\n };\n if (value.tooltip) {\n this.model.tooltip = value.tooltip;\n }\n }\n\n get text() {\n return this.model.text;\n }\n\n set text(value) {\n this.model.text = value;\n }\n\n /*\n get tooltip() {\n return this.model.tooltip;\n }\n\n set tooltip(value) {\n this.model.tooltip = value;\n } */\n\n get hyperlink() {\n return this.model.hyperlink;\n }\n\n set hyperlink(value) {\n this.model.hyperlink = value;\n }\n\n get type() {\n return Cell.Types.Hyperlink;\n }\n\n get effectiveType() {\n return Cell.Types.Hyperlink;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.hyperlink;\n }\n\n release() {}\n\n toString() {\n return this.model.text;\n }\n}\n\nclass MergeValue {\n constructor(cell, master) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Merge,\n master: master ? master.address : undefined,\n };\n this._master = master;\n if (master) {\n master.addMergeRef();\n }\n }\n\n get value() {\n return this._master.value;\n }\n\n set value(value) {\n if (value instanceof Cell) {\n if (this._master) {\n this._master.releaseMergeRef();\n }\n value.addMergeRef();\n this._master = value;\n } else {\n this._master.value = value;\n }\n }\n\n isMergedTo(master) {\n return master === this._master;\n }\n\n get master() {\n return this._master;\n }\n\n get type() {\n return Cell.Types.Merge;\n }\n\n get effectiveType() {\n return this._master.effectiveType;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return '';\n }\n\n release() {\n this._master.releaseMergeRef();\n }\n\n toString() {\n return this.value.toString();\n }\n}\n\nclass FormulaValue {\n constructor(cell, value) {\n this.cell = cell;\n\n this.model = {\n address: cell.address,\n type: Cell.Types.Formula,\n shareType: value ? value.shareType : undefined,\n ref: value ? value.ref : undefined,\n formula: value ? value.formula : undefined,\n sharedFormula: value ? value.sharedFormula : undefined,\n result: value ? value.result : undefined,\n };\n }\n\n _copyModel(model) {\n const copy = {};\n const cp = name => {\n const value = model[name];\n if (value) {\n copy[name] = value;\n }\n };\n cp('formula');\n cp('result');\n cp('ref');\n cp('shareType');\n cp('sharedFormula');\n return copy;\n }\n\n get value() {\n return this._copyModel(this.model);\n }\n\n set value(value) {\n this.model = this._copyModel(value);\n }\n\n validate(value) {\n switch (Value.getType(value)) {\n case Cell.Types.Null:\n case Cell.Types.String:\n case Cell.Types.Number:\n case Cell.Types.Date:\n break;\n case Cell.Types.Hyperlink:\n case Cell.Types.Formula:\n default:\n throw new Error('Cannot process that type of result value');\n }\n }\n\n get dependencies() {\n // find all the ranges and cells mentioned in the formula\n const ranges = this.formula.match(/([a-zA-Z0-9]+!)?[A-Z]{1,3}\\d{1,4}:[A-Z]{1,3}\\d{1,4}/g);\n const cells = this.formula\n .replace(/([a-zA-Z0-9]+!)?[A-Z]{1,3}\\d{1,4}:[A-Z]{1,3}\\d{1,4}/g, '')\n .match(/([a-zA-Z0-9]+!)?[A-Z]{1,3}\\d{1,4}/g);\n return {\n ranges,\n cells,\n };\n }\n\n get formula() {\n return this.model.formula || this._getTranslatedFormula();\n }\n\n set formula(value) {\n this.model.formula = value;\n }\n\n get formulaType() {\n if (this.model.formula) {\n return Enums.FormulaType.Master;\n }\n if (this.model.sharedFormula) {\n return Enums.FormulaType.Shared;\n }\n return Enums.FormulaType.None;\n }\n\n get result() {\n return this.model.result;\n }\n\n set result(value) {\n this.model.result = value;\n }\n\n get type() {\n return Cell.Types.Formula;\n }\n\n get effectiveType() {\n const v = this.model.result;\n if (v === null || v === undefined) {\n return Enums.ValueType.Null;\n }\n if (v instanceof String || typeof v === 'string') {\n return Enums.ValueType.String;\n }\n if (typeof v === 'number') {\n return Enums.ValueType.Number;\n }\n if (v instanceof Date) {\n return Enums.ValueType.Date;\n }\n if (v.text && v.hyperlink) {\n return Enums.ValueType.Hyperlink;\n }\n if (v.formula) {\n return Enums.ValueType.Formula;\n }\n\n return Enums.ValueType.Null;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n _getTranslatedFormula() {\n if (!this._translatedFormula && this.model.sharedFormula) {\n const {worksheet} = this.cell;\n const master = worksheet.findCell(this.model.sharedFormula);\n this._translatedFormula =\n master && slideFormula(master.formula, master.address, this.model.address);\n }\n return this._translatedFormula;\n }\n\n toCsvString() {\n return `${this.model.result || ''}`;\n }\n\n release() {}\n\n toString() {\n return this.model.result ? this.model.result.toString() : '';\n }\n}\n\nclass SharedStringValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.SharedString,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.SharedString;\n }\n\n get effectiveType() {\n return Cell.Types.SharedString;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value.toString();\n }\n\n release() {}\n\n toString() {\n return this.model.value.toString();\n }\n}\n\nclass BooleanValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Boolean,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.Boolean;\n }\n\n get effectiveType() {\n return Cell.Types.Boolean;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value ? 1 : 0;\n }\n\n release() {}\n\n toString() {\n return this.model.value.toString();\n }\n}\n\nclass ErrorValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Error,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.Error;\n }\n\n get effectiveType() {\n return Cell.Types.Error;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.toString();\n }\n\n release() {}\n\n toString() {\n return this.model.value.error.toString();\n }\n}\n\nclass JSONValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.String,\n value: JSON.stringify(value),\n rawValue: value,\n };\n }\n\n get value() {\n return this.model.rawValue;\n }\n\n set value(value) {\n this.model.rawValue = value;\n this.model.value = JSON.stringify(value);\n }\n\n get type() {\n return Cell.Types.String;\n }\n\n get effectiveType() {\n return Cell.Types.String;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value;\n }\n\n release() {}\n\n toString() {\n return this.model.value;\n }\n}\n\n// Value is a place to hold common static Value type functions\nconst Value = {\n getType(value) {\n if (value === null || value === undefined) {\n return Cell.Types.Null;\n }\n if (value instanceof String || typeof value === 'string') {\n return Cell.Types.String;\n }\n if (typeof value === 'number') {\n return Cell.Types.Number;\n }\n if (typeof value === 'boolean') {\n return Cell.Types.Boolean;\n }\n if (value instanceof Date) {\n return Cell.Types.Date;\n }\n if (value.text && value.hyperlink) {\n return Cell.Types.Hyperlink;\n }\n if (value.formula || value.sharedFormula) {\n return Cell.Types.Formula;\n }\n if (value.richText) {\n return Cell.Types.RichText;\n }\n if (value.sharedString) {\n return Cell.Types.SharedString;\n }\n if (value.error) {\n return Cell.Types.Error;\n }\n return Cell.Types.JSON;\n },\n\n // map valueType to constructor\n types: [\n {t: Cell.Types.Null, f: NullValue},\n {t: Cell.Types.Number, f: NumberValue},\n {t: Cell.Types.String, f: StringValue},\n {t: Cell.Types.Date, f: DateValue},\n {t: Cell.Types.Hyperlink, f: HyperlinkValue},\n {t: Cell.Types.Formula, f: FormulaValue},\n {t: Cell.Types.Merge, f: MergeValue},\n {t: Cell.Types.JSON, f: JSONValue},\n {t: Cell.Types.SharedString, f: SharedStringValue},\n {t: Cell.Types.RichText, f: RichTextValue},\n {t: Cell.Types.Boolean, f: BooleanValue},\n {t: Cell.Types.Error, f: ErrorValue},\n ].reduce((p, t) => {\n p[t.t] = t.f;\n return p;\n }, []),\n\n create(type, cell, value) {\n const T = this.types[type];\n if (!T) {\n throw new Error(`Could not create Value of type ${type}`);\n }\n return new T(cell, value);\n },\n};\n\nmodule.exports = Cell;\n"],"mappings":";;AAAA;AACA,MAAMA,QAAQ,GAAGC,OAAO,CAAC,oBAAoB,CAAC;AAC9C,MAAMC,CAAC,GAAGD,OAAO,CAAC,qBAAqB,CAAC;AACxC,MAAME,KAAK,GAAGF,OAAO,CAAC,SAAS,CAAC;AAChC,MAAM;EAACG;AAAY,CAAC,GAAGH,OAAO,CAAC,yBAAyB,CAAC;AACzD,MAAMI,IAAI,GAAGJ,OAAO,CAAC,QAAQ,CAAC;AAC9B;AACA;AACA;AACA;;AAEA,MAAMK,IAAI,CAAC;EACTC,WAAWA,CAACC,GAAG,EAAEC,MAAM,EAAEC,OAAO,EAAE;IAChC,IAAI,CAACF,GAAG,IAAI,CAACC,MAAM,EAAE;MACnB,MAAM,IAAIE,KAAK,CAAC,oBAAoB,CAAC;IACvC;IAEA,IAAI,CAACC,IAAI,GAAGJ,GAAG;IACf,IAAI,CAACK,OAAO,GAAGJ,MAAM;IAErBT,QAAQ,CAACc,eAAe,CAACJ,OAAO,CAAC;IACjC,IAAI,CAACK,QAAQ,GAAGL,OAAO;;IAEvB;IACA,IAAI,CAACM,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACZ,IAAI,CAACa,KAAK,CAACC,IAAI,EAAE,IAAI,CAAC;IAEjD,IAAI,CAACC,KAAK,GAAG,IAAI,CAACC,WAAW,CAACd,GAAG,CAACa,KAAK,EAAEZ,MAAM,CAACY,KAAK,EAAE,CAAC,CAAC,CAAC;IAE1D,IAAI,CAACE,WAAW,GAAG,CAAC;EACtB;EAEA,IAAIC,SAASA,CAAA,EAAG;IACd,OAAO,IAAI,CAACZ,IAAI,CAACY,SAAS;EAC5B;EAEA,IAAIC,QAAQA,CAAA,EAAG;IACb,OAAO,IAAI,CAACb,IAAI,CAACY,SAAS,CAACC,QAAQ;EACrC;;EAEA;EACAC,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAACL,KAAK;IACjB,OAAO,IAAI,CAACL,MAAM;IAClB,OAAO,IAAI,CAACJ,IAAI;IAChB,OAAO,IAAI,CAACC,OAAO;IACnB,OAAO,IAAI,CAACE,QAAQ;EACtB;;EAEA;EACA;EACA,IAAIY,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAACN,KAAK,CAACM,MAAM;EAC1B;EAEA,IAAIA,MAAMA,CAACC,KAAK,EAAE;IAChB,IAAI,CAACP,KAAK,CAACM,MAAM,GAAGC,KAAK;EAC3B;EAEA,IAAIC,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACR,KAAK,CAACQ,IAAI;EACxB;EAEA,IAAIA,IAAIA,CAACD,KAAK,EAAE;IACd,IAAI,CAACP,KAAK,CAACQ,IAAI,GAAGD,KAAK;EACzB;EAEA,IAAIE,SAASA,CAAA,EAAG;IACd,OAAO,IAAI,CAACT,KAAK,CAACS,SAAS;EAC7B;EAEA,IAAIA,SAASA,CAACF,KAAK,EAAE;IACnB,IAAI,CAACP,KAAK,CAACS,SAAS,GAAGF,KAAK;EAC9B;EAEA,IAAIG,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAACV,KAAK,CAACU,MAAM;EAC1B;EAEA,IAAIA,MAAMA,CAACH,KAAK,EAAE;IAChB,IAAI,CAACP,KAAK,CAACU,MAAM,GAAGH,KAAK;EAC3B;EAEA,IAAII,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACX,KAAK,CAACW,IAAI;EACxB;EAEA,IAAIA,IAAIA,CAACJ,KAAK,EAAE;IACd,IAAI,CAACP,KAAK,CAACW,IAAI,GAAGJ,KAAK;EACzB;EAEA,IAAIK,UAAUA,CAAA,EAAG;IACf,OAAO,IAAI,CAACZ,KAAK,CAACY,UAAU;EAC9B;EAEA,IAAIA,UAAUA,CAACL,KAAK,EAAE;IACpB,IAAI,CAACP,KAAK,CAACY,UAAU,GAAGL,KAAK;EAC/B;EAEAN,WAAWA,CAACY,QAAQ,EAAEC,QAAQ,EAAEd,KAAK,EAAE;IACrC,MAAMM,MAAM,GAAIO,QAAQ,IAAIA,QAAQ,CAACP,MAAM,IAAMQ,QAAQ,IAAIA,QAAQ,CAACR,MAAO;IAC7E,IAAIA,MAAM,EAAEN,KAAK,CAACM,MAAM,GAAGA,MAAM;IAEjC,MAAME,IAAI,GAAIK,QAAQ,IAAIA,QAAQ,CAACL,IAAI,IAAMM,QAAQ,IAAIA,QAAQ,CAACN,IAAK;IACvE,IAAIA,IAAI,EAAER,KAAK,CAACQ,IAAI,GAAGA,IAAI;IAE3B,MAAMC,SAAS,GAAII,QAAQ,IAAIA,QAAQ,CAACJ,SAAS,IAAMK,QAAQ,IAAIA,QAAQ,CAACL,SAAU;IACtF,IAAIA,SAAS,EAAET,KAAK,CAACS,SAAS,GAAGA,SAAS;IAE1C,MAAMC,MAAM,GAAIG,QAAQ,IAAIA,QAAQ,CAACH,MAAM,IAAMI,QAAQ,IAAIA,QAAQ,CAACJ,MAAO;IAC7E,IAAIA,MAAM,EAAEV,KAAK,CAACU,MAAM,GAAGA,MAAM;IAEjC,MAAMC,IAAI,GAAIE,QAAQ,IAAIA,QAAQ,CAACF,IAAI,IAAMG,QAAQ,IAAIA,QAAQ,CAACH,IAAK;IACvE,IAAIA,IAAI,EAAEX,KAAK,CAACW,IAAI,GAAGA,IAAI;IAE3B,MAAMC,UAAU,GAAIC,QAAQ,IAAIA,QAAQ,CAACD,UAAU,IAAME,QAAQ,IAAIA,QAAQ,CAACF,UAAW;IACzF,IAAIA,UAAU,EAAEZ,KAAK,CAACY,UAAU,GAAGA,UAAU;IAE7C,OAAOZ,KAAK;EACd;;EAEA;EACA;EACA,IAAIX,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACK,QAAQ;EACtB;EAEA,IAAIP,GAAGA,CAAA,EAAG;IACR,OAAO,IAAI,CAACI,IAAI,CAACwB,MAAM;EACzB;EAEA,IAAIC,GAAGA,CAAA,EAAG;IACR,OAAO,IAAI,CAACxB,OAAO,CAACuB,MAAM;EAC5B;EAEA,IAAIE,QAAQA,CAAA,EAAG;IACb,WAAAC,MAAA,CAAW,IAAI,CAAC1B,OAAO,CAAC2B,MAAM,OAAAD,MAAA,CAAI,IAAI,CAAC/B,GAAG;EAC5C;;EAEA;EACA;;EAEA,IAAIiC,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACzB,MAAM,CAACyB,IAAI;EACzB;EAEA,IAAIC,aAAaA,CAAA,EAAG;IAClB,OAAO,IAAI,CAAC1B,MAAM,CAAC0B,aAAa;EAClC;EAEAC,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC3B,MAAM,CAAC2B,WAAW,CAAC,CAAC;EAClC;;EAEA;EACA;;EAEAC,WAAWA,CAAA,EAAG;IACZ,IAAI,CAACrB,WAAW,EAAE;EACpB;EAEAsB,eAAeA,CAAA,EAAG;IAChB,IAAI,CAACtB,WAAW,EAAE;EACpB;EAEA,IAAIuB,QAAQA,CAAA,EAAG;IACb,OAAO,IAAI,CAACvB,WAAW,GAAG,CAAC,IAAI,IAAI,CAACkB,IAAI,KAAKnC,IAAI,CAACa,KAAK,CAAC4B,KAAK;EAC/D;EAEAC,KAAKA,CAACC,MAAM,EAAEC,WAAW,EAAE;IACzB,IAAI,CAAClC,MAAM,CAACmC,OAAO,CAAC,CAAC;IACrB,IAAI,CAACnC,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACZ,IAAI,CAACa,KAAK,CAAC4B,KAAK,EAAE,IAAI,EAAEE,MAAM,CAAC;IAC1D,IAAI,CAACC,WAAW,EAAE;MAChB,IAAI,CAAC7B,KAAK,GAAG4B,MAAM,CAAC5B,KAAK;IAC3B;EACF;EAEA+B,OAAOA,CAAA,EAAG;IACR,IAAI,IAAI,CAACX,IAAI,KAAKnC,IAAI,CAACa,KAAK,CAAC4B,KAAK,EAAE;MAClC,IAAI,CAAC/B,MAAM,CAACmC,OAAO,CAAC,CAAC;MACrB,IAAI,CAACnC,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACZ,IAAI,CAACa,KAAK,CAACC,IAAI,EAAE,IAAI,CAAC;MACjD,IAAI,CAACC,KAAK,GAAG,IAAI,CAACC,WAAW,CAAC,IAAI,CAACV,IAAI,CAACS,KAAK,EAAE,IAAI,CAACR,OAAO,CAACQ,KAAK,EAAE,CAAC,CAAC,CAAC;IACxE;EACF;EAEAgC,UAAUA,CAACJ,MAAM,EAAE;IACjB,IAAI,IAAI,CAACjC,MAAM,CAACyB,IAAI,KAAKnC,IAAI,CAACa,KAAK,CAAC4B,KAAK,EAAE,OAAO,KAAK;IACvD,OAAO,IAAI,CAAC/B,MAAM,CAACqC,UAAU,CAACJ,MAAM,CAAC;EACvC;EAEA,IAAIA,MAAMA,CAAA,EAAG;IACX,IAAI,IAAI,CAACR,IAAI,KAAKnC,IAAI,CAACa,KAAK,CAAC4B,KAAK,EAAE;MAClC,OAAO,IAAI,CAAC/B,MAAM,CAACiC,MAAM;IAC3B;IACA,OAAO,IAAI,CAAC,CAAC;EACf;EAEA,IAAIK,WAAWA,CAAA,EAAG;IAChB,OAAO,IAAI,CAACtC,MAAM,CAACyB,IAAI,KAAKnC,IAAI,CAACa,KAAK,CAACoC,SAAS;EAClD;EAEA,IAAIC,SAASA,CAAA,EAAG;IACd,OAAO,IAAI,CAACxC,MAAM,CAACwC,SAAS;EAC9B;;EAEA;EACA,IAAI5B,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAACZ,MAAM,CAACY,KAAK;EAC1B;;EAEA;EACA,IAAIA,KAAKA,CAAC6B,CAAC,EAAE;IACX;IACA,IAAI,IAAI,CAAChB,IAAI,KAAKnC,IAAI,CAACa,KAAK,CAAC4B,KAAK,EAAE;MAClC,IAAI,CAAC/B,MAAM,CAACiC,MAAM,CAACrB,KAAK,GAAG6B,CAAC;MAC5B;IACF;IAEA,IAAI,CAACzC,MAAM,CAACmC,OAAO,CAAC,CAAC;;IAErB;IACA,IAAI,CAACnC,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACD,KAAK,CAACyC,OAAO,CAACD,CAAC,CAAC,EAAE,IAAI,EAAEA,CAAC,CAAC;EACvD;EAEA,IAAIE,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACC,QAAQ,IAAI,IAAI,CAACA,QAAQ,CAACD,IAAI;EAC5C;EAEA,IAAIA,IAAIA,CAACA,IAAI,EAAE;IACb,IAAI,CAACC,QAAQ,GAAG,IAAIvD,IAAI,CAACsD,IAAI,CAAC;EAChC;EAEA,IAAIE,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAAC7C,MAAM,CAAC8C,QAAQ,CAAC,CAAC;EAC/B;EAEA,IAAIC,IAAIA,CAAA,EAAG;IACT,OAAO7D,CAAC,CAAC8D,UAAU,CAAC,IAAI,CAACH,IAAI,CAAC;EAChC;EAEAC,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACD,IAAI;EAClB;EAEAI,mBAAmBA,CAACT,SAAS,EAAE;IAC7B;IACA,IAAI,IAAI,CAACf,IAAI,KAAKnC,IAAI,CAACa,KAAK,CAAC+C,MAAM,EAAE;MACnC,IAAI,CAAClD,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACZ,IAAI,CAACa,KAAK,CAACoC,SAAS,EAAE,IAAI,EAAE;QACrDM,IAAI,EAAE,IAAI,CAAC7C,MAAM,CAACY,KAAK;QACvB4B;MACF,CAAC,CAAC;IACJ;EACF;;EAEA;EACA;EACA,IAAIW,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACnD,MAAM,CAACmD,OAAO;EAC5B;EAEA,IAAIC,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAACpD,MAAM,CAACoD,MAAM;EAC3B;EAEA,IAAIC,WAAWA,CAAA,EAAG;IAChB,OAAO,IAAI,CAACrD,MAAM,CAACqD,WAAW;EAChC;;EAEA;EACA;EACA,IAAIC,WAAWA,CAAA,EAAG;IAChB,MAAM;MAAC9C;IAAS,CAAC,GAAG,IAAI,CAACZ,IAAI;IAC7B,OAAO;MACL2D,SAAS,EAAE/C,SAAS,CAACgD,IAAI;MACzB9D,OAAO,EAAE,IAAI,CAACA,OAAO;MACrBF,GAAG,EAAE,IAAI,CAACA,GAAG;MACb6B,GAAG,EAAE,IAAI,CAACA;IACZ,CAAC;EACH;EAEA,IAAImC,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACC,KAAK,CAAC,CAAC,CAAC;EACtB;EAEA,IAAID,IAAIA,CAAC5C,KAAK,EAAE;IACd,IAAI,CAAC6C,KAAK,GAAG,CAAC7C,KAAK,CAAC;EACtB;EAEA,IAAI6C,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAChD,QAAQ,CAACiD,YAAY,CAACC,UAAU,CAAC,IAAI,CAACL,WAAW,CAAC;EAChE;EAEA,IAAIG,KAAKA,CAAC7C,KAAK,EAAE;IACf,MAAM;MAAC8C;IAAY,CAAC,GAAG,IAAI,CAACjD,QAAQ;IACpCiD,YAAY,CAACE,cAAc,CAAC,IAAI,CAACN,WAAW,CAAC;IAC7C1C,KAAK,CAACiD,OAAO,CAACL,IAAI,IAAI;MACpBE,YAAY,CAACI,KAAK,CAAC,IAAI,CAACR,WAAW,EAAEE,IAAI,CAAC;IAC5C,CAAC,CAAC;EACJ;EAEAO,OAAOA,CAACP,IAAI,EAAE;IACZ,IAAI,CAAC/C,QAAQ,CAACiD,YAAY,CAACI,KAAK,CAAC,IAAI,CAACR,WAAW,EAAEE,IAAI,CAAC;EAC1D;EAEAQ,UAAUA,CAACR,IAAI,EAAE;IACf,IAAI,CAAC/C,QAAQ,CAACiD,YAAY,CAACO,QAAQ,CAAC,IAAI,CAACX,WAAW,EAAEE,IAAI,CAAC;EAC7D;EAEAI,cAAcA,CAAA,EAAG;IACf,IAAI,CAACnD,QAAQ,CAACiD,YAAY,CAACE,cAAc,CAAC,IAAI,CAACN,WAAW,CAAC;EAC7D;;EAEA;EACA;EACA,IAAIY,gBAAgBA,CAAA,EAAG;IACrB,OAAO,IAAI,CAAC1D,SAAS,CAAC2D,eAAe;EACvC;EAEA,IAAIC,cAAcA,CAAA,EAAG;IACnB,OAAO,IAAI,CAACF,gBAAgB,CAACG,IAAI,CAAC,IAAI,CAAC3E,OAAO,CAAC;EACjD;EAEA,IAAI0E,cAAcA,CAACxD,KAAK,EAAE;IACxB,IAAI,CAACsD,gBAAgB,CAACI,GAAG,CAAC,IAAI,CAAC5E,OAAO,EAAEkB,KAAK,CAAC;EAChD;;EAEA;EACA;;EAEA,IAAI2D,KAAKA,CAAA,EAAG;IACV,MAAM;MAACA;IAAK,CAAC,GAAG,IAAI,CAACvE,MAAM;IAC3BuE,KAAK,CAAClE,KAAK,GAAG,IAAI,CAACA,KAAK;IACxB,IAAI,IAAI,CAACuC,QAAQ,EAAE;MACjB2B,KAAK,CAACC,OAAO,GAAG,IAAI,CAAC5B,QAAQ,CAAC2B,KAAK;IACrC;IACA,OAAOA,KAAK;EACd;EAEA,IAAIA,KAAKA,CAAC3D,KAAK,EAAE;IACf,IAAI,CAACZ,MAAM,CAACmC,OAAO,CAAC,CAAC;IACrB,IAAI,CAACnC,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACU,KAAK,CAACa,IAAI,EAAE,IAAI,CAAC;IAC5C,IAAI,CAACzB,MAAM,CAACuE,KAAK,GAAG3D,KAAK;IAEzB,IAAIA,KAAK,CAAC4D,OAAO,EAAE;MACjB,QAAQ5D,KAAK,CAAC4D,OAAO,CAAC/C,IAAI;QACxB,KAAK,MAAM;UACT,IAAI,CAACmB,QAAQ,GAAGvD,IAAI,CAACoF,SAAS,CAAC7D,KAAK,CAAC4D,OAAO,CAAC;UAC7C;MACJ;IACF;IAEA,IAAI5D,KAAK,CAACP,KAAK,EAAE;MACf,IAAI,CAACA,KAAK,GAAGO,KAAK,CAACP,KAAK;IAC1B,CAAC,MAAM;MACL,IAAI,CAACA,KAAK,GAAG,CAAC,CAAC;IACjB;EACF;AACF;AACAf,IAAI,CAACa,KAAK,GAAGhB,KAAK,CAACuF,SAAS;;AAE5B;AACA;;AAEA,MAAMC,SAAS,CAAC;EACdpF,WAAWA,CAACqF,IAAI,EAAE;IAChB,IAAI,CAACL,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAACC;IACnB,CAAC;EACH;EAEA,IAAIQ,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI;EACb;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf;EAAA;EAGF,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAACC,IAAI;EACxB;EAEA,IAAIsB,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAACC,IAAI;EACxB;EAEA,IAAIV,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,OAAO,EAAE;EACX;EAEAQ,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,EAAE;EACX;AACF;AAEA,MAAM+B,WAAW,CAAC;EAChBtF,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAAC2D,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAAC2E,MAAM;MACvBlE;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC2D,KAAK,CAAC3D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,CAAC3D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAAC2E,MAAM;EAC1B;EAEA,IAAIpD,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAAC2E,MAAM;EAC1B;EAEA,IAAIpF,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC3D,KAAK,CAACkC,QAAQ,CAAC,CAAC;EACpC;EAEAX,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC3D,KAAK,CAACkC,QAAQ,CAAC,CAAC;EACpC;AACF;AAEA,MAAMiC,WAAW,CAAC;EAChBxF,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAAC2D,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAAC+C,MAAM;MACvBtC;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC2D,KAAK,CAAC3D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,CAAC3D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAAC+C,MAAM;EAC1B;EAEA,IAAIxB,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAAC+C,MAAM;EAC1B;EAEA,IAAIxD,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,YAAAJ,MAAA,CAAW,IAAI,CAACgD,KAAK,CAAC3D,KAAK,CAACoE,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC;EACjD;EAEA7C,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC3D,KAAK;EACzB;AACF;AAEA,MAAMqE,aAAa,CAAC;EAClB1F,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAAC2D,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAAC+C,MAAM;MACvBtC;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC2D,KAAK,CAAC3D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,CAAC3D,KAAK,GAAGA,KAAK;EAC1B;EAEAkC,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC3D,KAAK,CAACsE,QAAQ,CAACC,GAAG,CAACC,CAAC,IAAIA,CAAC,CAACvC,IAAI,CAAC,CAACwC,IAAI,CAAC,EAAE,CAAC;EAC5D;EAEA,IAAI5D,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAACmF,QAAQ;EAC5B;EAEA,IAAI5D,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAACmF,QAAQ;EAC5B;EAEA,IAAI5F,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,YAAAJ,MAAA,CAAW,IAAI,CAACsB,IAAI,CAACmC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC;EAC1C;EAEA7C,OAAOA,CAAA,EAAG,CAAC;AACb;AAEA,MAAMoD,SAAS,CAAC;EACdhG,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAAC2D,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAACqF,IAAI;MACrB5E;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC2D,KAAK,CAAC3D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,CAAC3D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAACqF,IAAI;EACxB;EAEA,IAAI9D,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAACqF,IAAI;EACxB;EAEA,IAAI9F,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC3D,KAAK,CAAC6E,WAAW,CAAC,CAAC;EACvC;EAEAtD,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC3D,KAAK,CAACkC,QAAQ,CAAC,CAAC;EACpC;AACF;AAEA,MAAM4C,cAAc,CAAC;EACnBnG,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAAC2D,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAACoC,SAAS;MAC1BM,IAAI,EAAEjC,KAAK,GAAGA,KAAK,CAACiC,IAAI,GAAG8C,SAAS;MACpCnD,SAAS,EAAE5B,KAAK,GAAGA,KAAK,CAAC4B,SAAS,GAAGmD;IACvC,CAAC;IACD,IAAI/E,KAAK,IAAIA,KAAK,CAACgF,OAAO,EAAE;MAC1B,IAAI,CAACrB,KAAK,CAACqB,OAAO,GAAGhF,KAAK,CAACgF,OAAO;IACpC;EACF;EAEA,IAAIhF,KAAKA,CAAA,EAAG;IACV,MAAM6B,CAAC,GAAG;MACRI,IAAI,EAAE,IAAI,CAAC0B,KAAK,CAAC1B,IAAI;MACrBL,SAAS,EAAE,IAAI,CAAC+B,KAAK,CAAC/B;IACxB,CAAC;IACD,IAAI,IAAI,CAAC+B,KAAK,CAACqB,OAAO,EAAE;MACtBnD,CAAC,CAACmD,OAAO,GAAG,IAAI,CAACrB,KAAK,CAACqB,OAAO;IAChC;IACA,OAAOnD,CAAC;EACV;EAEA,IAAI7B,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,GAAG;MACX1B,IAAI,EAAEjC,KAAK,CAACiC,IAAI;MAChBL,SAAS,EAAE5B,KAAK,CAAC4B;IACnB,CAAC;IACD,IAAI5B,KAAK,CAACgF,OAAO,EAAE;MACjB,IAAI,CAACrB,KAAK,CAACqB,OAAO,GAAGhF,KAAK,CAACgF,OAAO;IACpC;EACF;EAEA,IAAI/C,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAAC0B,KAAK,CAAC1B,IAAI;EACxB;EAEA,IAAIA,IAAIA,CAACjC,KAAK,EAAE;IACd,IAAI,CAAC2D,KAAK,CAAC1B,IAAI,GAAGjC,KAAK;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;;EAGE,IAAI4B,SAASA,CAAA,EAAG;IACd,OAAO,IAAI,CAAC+B,KAAK,CAAC/B,SAAS;EAC7B;EAEA,IAAIA,SAASA,CAAC5B,KAAK,EAAE;IACnB,IAAI,CAAC2D,KAAK,CAAC/B,SAAS,GAAG5B,KAAK;EAC9B;EAEA,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAACoC,SAAS;EAC7B;EAEA,IAAIb,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAACoC,SAAS;EAC7B;EAEA,IAAI7C,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC/B,SAAS;EAC7B;EAEAL,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1B,IAAI;EACxB;AACF;AAEA,MAAMgD,UAAU,CAAC;EACftG,WAAWA,CAACqF,IAAI,EAAE3C,MAAM,EAAE;IACxB,IAAI,CAACsC,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAAC4B,KAAK;MACtBE,MAAM,EAAEA,MAAM,GAAGA,MAAM,CAACvC,OAAO,GAAGiG;IACpC,CAAC;IACD,IAAI,CAACG,OAAO,GAAG7D,MAAM;IACrB,IAAIA,MAAM,EAAE;MACVA,MAAM,CAACL,WAAW,CAAC,CAAC;IACtB;EACF;EAEA,IAAIhB,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAACkF,OAAO,CAAClF,KAAK;EAC3B;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAIA,KAAK,YAAYtB,IAAI,EAAE;MACzB,IAAI,IAAI,CAACwG,OAAO,EAAE;QAChB,IAAI,CAACA,OAAO,CAACjE,eAAe,CAAC,CAAC;MAChC;MACAjB,KAAK,CAACgB,WAAW,CAAC,CAAC;MACnB,IAAI,CAACkE,OAAO,GAAGlF,KAAK;IACtB,CAAC,MAAM;MACL,IAAI,CAACkF,OAAO,CAAClF,KAAK,GAAGA,KAAK;IAC5B;EACF;EAEAyB,UAAUA,CAACJ,MAAM,EAAE;IACjB,OAAOA,MAAM,KAAK,IAAI,CAAC6D,OAAO;EAChC;EAEA,IAAI7D,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAAC6D,OAAO;EACrB;EAEA,IAAIrE,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAAC4B,KAAK;EACzB;EAEA,IAAIL,aAAaA,CAAA,EAAG;IAClB,OAAO,IAAI,CAACoE,OAAO,CAACpE,aAAa;EACnC;EAEA,IAAIhC,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,OAAO,EAAE;EACX;EAEAQ,OAAOA,CAAA,EAAG;IACR,IAAI,CAAC2D,OAAO,CAACjE,eAAe,CAAC,CAAC;EAChC;EAEAiB,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAAClC,KAAK,CAACkC,QAAQ,CAAC,CAAC;EAC9B;AACF;AAEA,MAAMiD,YAAY,CAAC;EACjBxG,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAACgE,IAAI,GAAGA,IAAI;IAEhB,IAAI,CAACL,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAAC6F,OAAO;MACxBC,SAAS,EAAErF,KAAK,GAAGA,KAAK,CAACqF,SAAS,GAAGN,SAAS;MAC9CO,GAAG,EAAEtF,KAAK,GAAGA,KAAK,CAACsF,GAAG,GAAGP,SAAS;MAClCxC,OAAO,EAAEvC,KAAK,GAAGA,KAAK,CAACuC,OAAO,GAAGwC,SAAS;MAC1CQ,aAAa,EAAEvF,KAAK,GAAGA,KAAK,CAACuF,aAAa,GAAGR,SAAS;MACtDvC,MAAM,EAAExC,KAAK,GAAGA,KAAK,CAACwC,MAAM,GAAGuC;IACjC,CAAC;EACH;EAEAS,UAAUA,CAAC7B,KAAK,EAAE;IAChB,MAAM8B,IAAI,GAAG,CAAC,CAAC;IACf,MAAMC,EAAE,GAAG9C,IAAI,IAAI;MACjB,MAAM5C,KAAK,GAAG2D,KAAK,CAACf,IAAI,CAAC;MACzB,IAAI5C,KAAK,EAAE;QACTyF,IAAI,CAAC7C,IAAI,CAAC,GAAG5C,KAAK;MACpB;IACF,CAAC;IACD0F,EAAE,CAAC,SAAS,CAAC;IACbA,EAAE,CAAC,QAAQ,CAAC;IACZA,EAAE,CAAC,KAAK,CAAC;IACTA,EAAE,CAAC,WAAW,CAAC;IACfA,EAAE,CAAC,eAAe,CAAC;IACnB,OAAOD,IAAI;EACb;EAEA,IAAIzF,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAACwF,UAAU,CAAC,IAAI,CAAC7B,KAAK,CAAC;EACpC;EAEA,IAAI3D,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,GAAG,IAAI,CAAC6B,UAAU,CAACxF,KAAK,CAAC;EACrC;EAEA2F,QAAQA,CAAC3F,KAAK,EAAE;IACd,QAAQX,KAAK,CAACyC,OAAO,CAAC9B,KAAK,CAAC;MAC1B,KAAKtB,IAAI,CAACa,KAAK,CAACC,IAAI;MACpB,KAAKd,IAAI,CAACa,KAAK,CAAC+C,MAAM;MACtB,KAAK5D,IAAI,CAACa,KAAK,CAAC2E,MAAM;MACtB,KAAKxF,IAAI,CAACa,KAAK,CAACqF,IAAI;QAClB;MACF,KAAKlG,IAAI,CAACa,KAAK,CAACoC,SAAS;MACzB,KAAKjD,IAAI,CAACa,KAAK,CAAC6F,OAAO;MACvB;QACE,MAAM,IAAIrG,KAAK,CAAC,0CAA0C,CAAC;IAC/D;EACF;EAEA,IAAI6G,YAAYA,CAAA,EAAG;IACjB;IACA,MAAMC,MAAM,GAAG,IAAI,CAACtD,OAAO,CAACuD,KAAK,CAAC,sDAAsD,CAAC;IACzF,MAAMC,KAAK,GAAG,IAAI,CAACxD,OAAO,CACvB6B,OAAO,CAAC,sDAAsD,EAAE,EAAE,CAAC,CACnE0B,KAAK,CAAC,oCAAoC,CAAC;IAC9C,OAAO;MACLD,MAAM;MACNE;IACF,CAAC;EACH;EAEA,IAAIxD,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACoB,KAAK,CAACpB,OAAO,IAAI,IAAI,CAACyD,qBAAqB,CAAC,CAAC;EAC3D;EAEA,IAAIzD,OAAOA,CAACvC,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAACpB,OAAO,GAAGvC,KAAK;EAC5B;EAEA,IAAIyC,WAAWA,CAAA,EAAG;IAChB,IAAI,IAAI,CAACkB,KAAK,CAACpB,OAAO,EAAE;MACtB,OAAOhE,KAAK,CAAC0H,WAAW,CAACC,MAAM;IACjC;IACA,IAAI,IAAI,CAACvC,KAAK,CAAC4B,aAAa,EAAE;MAC5B,OAAOhH,KAAK,CAAC0H,WAAW,CAACE,MAAM;IACjC;IACA,OAAO5H,KAAK,CAAC0H,WAAW,CAACG,IAAI;EAC/B;EAEA,IAAI5D,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAACmB,KAAK,CAACnB,MAAM;EAC1B;EAEA,IAAIA,MAAMA,CAACxC,KAAK,EAAE;IAChB,IAAI,CAAC2D,KAAK,CAACnB,MAAM,GAAGxC,KAAK;EAC3B;EAEA,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAAC6F,OAAO;EAC3B;EAEA,IAAItE,aAAaA,CAAA,EAAG;IAClB,MAAMe,CAAC,GAAG,IAAI,CAAC8B,KAAK,CAACnB,MAAM;IAC3B,IAAIX,CAAC,KAAK,IAAI,IAAIA,CAAC,KAAKkD,SAAS,EAAE;MACjC,OAAOxG,KAAK,CAACuF,SAAS,CAACtE,IAAI;IAC7B;IACA,IAAIqC,CAAC,YAAYS,MAAM,IAAI,OAAOT,CAAC,KAAK,QAAQ,EAAE;MAChD,OAAOtD,KAAK,CAACuF,SAAS,CAACxB,MAAM;IAC/B;IACA,IAAI,OAAOT,CAAC,KAAK,QAAQ,EAAE;MACzB,OAAOtD,KAAK,CAACuF,SAAS,CAACI,MAAM;IAC/B;IACA,IAAIrC,CAAC,YAAY+C,IAAI,EAAE;MACrB,OAAOrG,KAAK,CAACuF,SAAS,CAACc,IAAI;IAC7B;IACA,IAAI/C,CAAC,CAACI,IAAI,IAAIJ,CAAC,CAACD,SAAS,EAAE;MACzB,OAAOrD,KAAK,CAACuF,SAAS,CAACnC,SAAS;IAClC;IACA,IAAIE,CAAC,CAACU,OAAO,EAAE;MACb,OAAOhE,KAAK,CAACuF,SAAS,CAACsB,OAAO;IAChC;IAEA,OAAO7G,KAAK,CAACuF,SAAS,CAACtE,IAAI;EAC7B;EAEA,IAAIV,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAgG,qBAAqBA,CAAA,EAAG;IACtB,IAAI,CAAC,IAAI,CAACK,kBAAkB,IAAI,IAAI,CAAC1C,KAAK,CAAC4B,aAAa,EAAE;MACxD,MAAM;QAAC3F;MAAS,CAAC,GAAG,IAAI,CAACoE,IAAI;MAC7B,MAAM3C,MAAM,GAAGzB,SAAS,CAAC0G,QAAQ,CAAC,IAAI,CAAC3C,KAAK,CAAC4B,aAAa,CAAC;MAC3D,IAAI,CAACc,kBAAkB,GACrBhF,MAAM,IAAI7C,YAAY,CAAC6C,MAAM,CAACkB,OAAO,EAAElB,MAAM,CAACvC,OAAO,EAAE,IAAI,CAAC6E,KAAK,CAAC7E,OAAO,CAAC;IAC9E;IACA,OAAO,IAAI,CAACuH,kBAAkB;EAChC;EAEAtF,WAAWA,CAAA,EAAG;IACZ,UAAAJ,MAAA,CAAU,IAAI,CAACgD,KAAK,CAACnB,MAAM,IAAI,EAAE;EACnC;EAEAjB,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAACnB,MAAM,GAAG,IAAI,CAACmB,KAAK,CAACnB,MAAM,CAACN,QAAQ,CAAC,CAAC,GAAG,EAAE;EAC9D;AACF;AAEA,MAAMqE,iBAAiB,CAAC;EACtB5H,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAAC2D,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAACiH,YAAY;MAC7BxG;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC2D,KAAK,CAAC3D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,CAAC3D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAACiH,YAAY;EAChC;EAEA,IAAI1F,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAACiH,YAAY;EAChC;EAEA,IAAI1H,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC3D,KAAK,CAACkC,QAAQ,CAAC,CAAC;EACpC;EAEAX,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC3D,KAAK,CAACkC,QAAQ,CAAC,CAAC;EACpC;AACF;AAEA,MAAMuE,YAAY,CAAC;EACjB9H,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAAC2D,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAACmH,OAAO;MACxB1G;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC2D,KAAK,CAAC3D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,CAAC3D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAACmH,OAAO;EAC3B;EAEA,IAAI5F,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAACmH,OAAO;EAC3B;EAEA,IAAI5H,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC3D,KAAK,GAAG,CAAC,GAAG,CAAC;EACjC;EAEAuB,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC3D,KAAK,CAACkC,QAAQ,CAAC,CAAC;EACpC;AACF;AAEA,MAAMyE,UAAU,CAAC;EACfhI,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAAC2D,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAACR,KAAK;MACtBiB;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC2D,KAAK,CAAC3D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,CAAC3D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAACR,KAAK;EACzB;EAEA,IAAI+B,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAACR,KAAK;EACzB;EAEA,IAAID,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACmB,QAAQ,CAAC,CAAC;EACxB;EAEAX,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC3D,KAAK,CAAC4G,KAAK,CAAC1E,QAAQ,CAAC,CAAC;EAC1C;AACF;AAEA,MAAM2E,SAAS,CAAC;EACdlI,WAAWA,CAACqF,IAAI,EAAEhE,KAAK,EAAE;IACvB,IAAI,CAAC2D,KAAK,GAAG;MACX7E,OAAO,EAAEkF,IAAI,CAAClF,OAAO;MACrB+B,IAAI,EAAEnC,IAAI,CAACa,KAAK,CAAC+C,MAAM;MACvBtC,KAAK,EAAE8G,IAAI,CAACC,SAAS,CAAC/G,KAAK,CAAC;MAC5BgH,QAAQ,EAAEhH;IACZ,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC2D,KAAK,CAACqD,QAAQ;EAC5B;EAEA,IAAIhH,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC2D,KAAK,CAACqD,QAAQ,GAAGhH,KAAK;IAC3B,IAAI,CAAC2D,KAAK,CAAC3D,KAAK,GAAG8G,IAAI,CAACC,SAAS,CAAC/G,KAAK,CAAC;EAC1C;EAEA,IAAIa,IAAIA,CAAA,EAAG;IACT,OAAOnC,IAAI,CAACa,KAAK,CAAC+C,MAAM;EAC1B;EAEA,IAAIxB,aAAaA,CAAA,EAAG;IAClB,OAAOpC,IAAI,CAACa,KAAK,CAAC+C,MAAM;EAC1B;EAEA,IAAIxD,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC6E,KAAK,CAAC7E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC2D,KAAK,CAAC7E,OAAO,GAAGkB,KAAK;EAC5B;EAEAe,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC3D,KAAK;EACzB;EAEAuB,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC3D,KAAK;EACzB;AACF;;AAEA;AACA,MAAMX,KAAK,GAAG;EACZyC,OAAOA,CAAC9B,KAAK,EAAE;IACb,IAAIA,KAAK,KAAK,IAAI,IAAIA,KAAK,KAAK+E,SAAS,EAAE;MACzC,OAAOrG,IAAI,CAACa,KAAK,CAACC,IAAI;IACxB;IACA,IAAIQ,KAAK,YAAYsC,MAAM,IAAI,OAAOtC,KAAK,KAAK,QAAQ,EAAE;MACxD,OAAOtB,IAAI,CAACa,KAAK,CAAC+C,MAAM;IAC1B;IACA,IAAI,OAAOtC,KAAK,KAAK,QAAQ,EAAE;MAC7B,OAAOtB,IAAI,CAACa,KAAK,CAAC2E,MAAM;IAC1B;IACA,IAAI,OAAOlE,KAAK,KAAK,SAAS,EAAE;MAC9B,OAAOtB,IAAI,CAACa,KAAK,CAACmH,OAAO;IAC3B;IACA,IAAI1G,KAAK,YAAY4E,IAAI,EAAE;MACzB,OAAOlG,IAAI,CAACa,KAAK,CAACqF,IAAI;IACxB;IACA,IAAI5E,KAAK,CAACiC,IAAI,IAAIjC,KAAK,CAAC4B,SAAS,EAAE;MACjC,OAAOlD,IAAI,CAACa,KAAK,CAACoC,SAAS;IAC7B;IACA,IAAI3B,KAAK,CAACuC,OAAO,IAAIvC,KAAK,CAACuF,aAAa,EAAE;MACxC,OAAO7G,IAAI,CAACa,KAAK,CAAC6F,OAAO;IAC3B;IACA,IAAIpF,KAAK,CAACsE,QAAQ,EAAE;MAClB,OAAO5F,IAAI,CAACa,KAAK,CAACmF,QAAQ;IAC5B;IACA,IAAI1E,KAAK,CAACiH,YAAY,EAAE;MACtB,OAAOvI,IAAI,CAACa,KAAK,CAACiH,YAAY;IAChC;IACA,IAAIxG,KAAK,CAAC4G,KAAK,EAAE;MACf,OAAOlI,IAAI,CAACa,KAAK,CAACR,KAAK;IACzB;IACA,OAAOL,IAAI,CAACa,KAAK,CAACuH,IAAI;EACxB,CAAC;EAED;EACAI,KAAK,EAAE,CACL;IAAC1C,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAACC,IAAI;IAAE2H,CAAC,EAAEpD;EAAS,CAAC,EAClC;IAACS,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAAC2E,MAAM;IAAEiD,CAAC,EAAElD;EAAW,CAAC,EACtC;IAACO,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAAC+C,MAAM;IAAE6E,CAAC,EAAEhD;EAAW,CAAC,EACtC;IAACK,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAACqF,IAAI;IAAEuC,CAAC,EAAExC;EAAS,CAAC,EAClC;IAACH,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAACoC,SAAS;IAAEwF,CAAC,EAAErC;EAAc,CAAC,EAC5C;IAACN,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAAC6F,OAAO;IAAE+B,CAAC,EAAEhC;EAAY,CAAC,EACxC;IAACX,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAAC4B,KAAK;IAAEgG,CAAC,EAAElC;EAAU,CAAC,EACpC;IAACT,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAACuH,IAAI;IAAEK,CAAC,EAAEN;EAAS,CAAC,EAClC;IAACrC,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAACiH,YAAY;IAAEW,CAAC,EAAEZ;EAAiB,CAAC,EAClD;IAAC/B,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAACmF,QAAQ;IAAEyC,CAAC,EAAE9C;EAAa,CAAC,EAC1C;IAACG,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAACmH,OAAO;IAAES,CAAC,EAAEV;EAAY,CAAC,EACxC;IAACjC,CAAC,EAAE9F,IAAI,CAACa,KAAK,CAACR,KAAK;IAAEoI,CAAC,EAAER;EAAU,CAAC,CACrC,CAACS,MAAM,CAAC,CAACC,CAAC,EAAE7C,CAAC,KAAK;IACjB6C,CAAC,CAAC7C,CAAC,CAACA,CAAC,CAAC,GAAGA,CAAC,CAAC2C,CAAC;IACZ,OAAOE,CAAC;EACV,CAAC,EAAE,EAAE,CAAC;EAEN/H,MAAMA,CAACuB,IAAI,EAAEmD,IAAI,EAAEhE,KAAK,EAAE;IACxB,MAAMsH,CAAC,GAAG,IAAI,CAACJ,KAAK,CAACrG,IAAI,CAAC;IAC1B,IAAI,CAACyG,CAAC,EAAE;MACN,MAAM,IAAIvI,KAAK,mCAAA4B,MAAA,CAAmCE,IAAI,CAAE,CAAC;IAC3D;IACA,OAAO,IAAIyG,CAAC,CAACtD,IAAI,EAAEhE,KAAK,CAAC;EAC3B;AACF,CAAC;AAEDuH,MAAM,CAACC,OAAO,GAAG9I,IAAI","ignoreList":[]}
1
+ {"version":3,"file":"cell.js","names":["colCache","require","_","Enums","slideFormula","Note","Cell","constructor","row","column","address","Error","_row","_column","validateAddress","_address","_value","Value","create","Types","Null","style","_mergeStyle","_mergeCount","worksheet","workbook","destroy","numFmt","value","font","alignment","border","fill","protection","rowStyle","colStyle","number","col","$col$row","letter","type","effectiveType","toCsvString","addMergeRef","releaseMergeRef","isMerged","Merge","merge","master","ignoreStyle","release","unmerge","isMergedTo","isHyperlink","Hyperlink","hyperlink","v","getType","note","_comment","text","toString","html","escapeHtml","_upgradeToHyperlink","String","formula","result","formulaType","fullAddress","sheetName","name","names","definedNames","getNamesEx","removeAllNames","forEach","addEx","addName","removeName","removeEx","_dataValidations","dataValidations","dataValidation","find","add","model","comment","fromModel","ValueType","NullValue","cell","NumberValue","Number","StringValue","replace","RichTextValue","richText","map","t","join","RichText","DateValue","Date","toISOString","HyperlinkValue","undefined","tooltip","MergeValue","_master","FormulaValue","Formula","shareType","ref","sharedFormula","_copyModel","copy","cp","validate","dependencies","ranges","match","cells","_getTranslatedFormula","FormulaType","Master","Shared","None","_translatedFormula","findCell","SharedStringValue","SharedString","BooleanValue","Boolean","ErrorValue","error","JSONValue","JSON","stringify","rawValue","sharedString","types","f","reduce","p","T","module","exports"],"sources":["../../../lib/doc/cell.js"],"sourcesContent":["/* eslint-disable max-classes-per-file */\nconst colCache = require('../utils/col-cache');\nconst _ = require('../utils/under-dash');\nconst Enums = require('./enums');\nconst {slideFormula} = require('../utils/shared-formula');\nconst Note = require('./note');\n// Cell requirements\n// Operate inside a worksheet\n// Store and retrieve a value with a range of types: text, number, date, hyperlink, reference, formula, etc.\n// Manage/use and manipulate cell format either as local to cell or inherited from column or row.\n\nclass Cell {\n constructor(row, column, address) {\n if (!row || !column) {\n throw new Error('A Cell needs a Row');\n }\n\n this._row = row;\n this._column = column;\n\n colCache.validateAddress(address);\n this._address = address;\n\n // TODO: lazy evaluation of this._value\n this._value = Value.create(Cell.Types.Null, this);\n\n this.style = this._mergeStyle(row.style, column.style, {});\n\n this._mergeCount = 0;\n }\n\n get worksheet() {\n return this._row.worksheet;\n }\n\n get workbook() {\n return this._row.worksheet.workbook;\n }\n\n // help GC by removing cyclic (and other) references\n destroy() {\n delete this.style;\n delete this._value;\n delete this._row;\n delete this._column;\n delete this._address;\n }\n\n // =========================================================================\n // Styles stuff\n get numFmt() {\n return this.style.numFmt;\n }\n\n set numFmt(value) {\n this.style.numFmt = value;\n }\n\n get font() {\n return this.style.font;\n }\n\n set font(value) {\n this.style.font = value;\n }\n\n get alignment() {\n return this.style.alignment;\n }\n\n set alignment(value) {\n this.style.alignment = value;\n }\n\n get border() {\n return this.style.border;\n }\n\n set border(value) {\n this.style.border = value;\n }\n\n get fill() {\n return this.style.fill;\n }\n\n set fill(value) {\n this.style.fill = value;\n }\n\n get protection() {\n return this.style.protection;\n }\n\n set protection(value) {\n this.style.protection = value;\n }\n\n _mergeStyle(rowStyle, colStyle, style) {\n const numFmt = (rowStyle && rowStyle.numFmt) || (colStyle && colStyle.numFmt);\n if (numFmt) style.numFmt = numFmt;\n\n const font = (rowStyle && rowStyle.font) || (colStyle && colStyle.font);\n if (font) style.font = font;\n\n const alignment = (rowStyle && rowStyle.alignment) || (colStyle && colStyle.alignment);\n if (alignment) style.alignment = alignment;\n\n const border = (rowStyle && rowStyle.border) || (colStyle && colStyle.border);\n if (border) style.border = border;\n\n const fill = (rowStyle && rowStyle.fill) || (colStyle && colStyle.fill);\n if (fill) style.fill = fill;\n\n const protection = (rowStyle && rowStyle.protection) || (colStyle && colStyle.protection);\n if (protection) style.protection = protection;\n\n return style;\n }\n\n // =========================================================================\n // return the address for this cell\n get address() {\n return this._address;\n }\n\n get row() {\n return this._row.number;\n }\n\n get col() {\n return this._column.number;\n }\n\n get $col$row() {\n return `$${this._column.letter}$${this.row}`;\n }\n\n // =========================================================================\n // Value stuff\n\n get type() {\n return this._value.type;\n }\n\n get effectiveType() {\n return this._value.effectiveType;\n }\n\n toCsvString() {\n return this._value.toCsvString();\n }\n\n // =========================================================================\n // Merge stuff\n\n addMergeRef() {\n this._mergeCount++;\n }\n\n releaseMergeRef() {\n this._mergeCount--;\n }\n\n get isMerged() {\n return this._mergeCount > 0 || this.type === Cell.Types.Merge;\n }\n\n merge(master, ignoreStyle) {\n this._value.release();\n this._value = Value.create(Cell.Types.Merge, this, master);\n if (!ignoreStyle) {\n this.style = master.style;\n }\n }\n\n unmerge() {\n if (this.type === Cell.Types.Merge) {\n this._value.release();\n this._value = Value.create(Cell.Types.Null, this);\n this.style = this._mergeStyle(this._row.style, this._column.style, {});\n }\n }\n\n isMergedTo(master) {\n if (this._value.type !== Cell.Types.Merge) return false;\n return this._value.isMergedTo(master);\n }\n\n get master() {\n if (this.type === Cell.Types.Merge) {\n return this._value.master;\n }\n return this; // an unmerged cell is its own master\n }\n\n get isHyperlink() {\n return this._value.type === Cell.Types.Hyperlink;\n }\n\n get hyperlink() {\n return this._value.hyperlink;\n }\n\n // return the value\n get value() {\n return this._value.value;\n }\n\n // set the value - can be number, string or raw\n set value(v) {\n // special case - merge cells set their master's value\n if (this.type === Cell.Types.Merge) {\n this._value.master.value = v;\n return;\n }\n\n this._value.release();\n\n // assign value\n this._value = Value.create(Value.getType(v), this, v);\n }\n\n get note() {\n return this._comment && this._comment.note;\n }\n\n set note(note) {\n this._comment = new Note(note);\n }\n\n get text() {\n return this._value.toString();\n }\n\n get html() {\n return _.escapeHtml(this.text);\n }\n\n toString() {\n return this.text;\n }\n\n _upgradeToHyperlink(hyperlink) {\n // if this cell is a string, turn it into a Hyperlink\n if (this.type === Cell.Types.String) {\n this._value = Value.create(Cell.Types.Hyperlink, this, {\n text: this._value.value,\n hyperlink,\n });\n }\n }\n\n // =========================================================================\n // Formula stuff\n get formula() {\n return this._value.formula;\n }\n\n get result() {\n return this._value.result;\n }\n\n get formulaType() {\n return this._value.formulaType;\n }\n\n // =========================================================================\n // Name stuff\n get fullAddress() {\n const {worksheet} = this._row;\n return {\n sheetName: worksheet.name,\n address: this.address,\n row: this.row,\n col: this.col,\n };\n }\n\n get name() {\n return this.names[0];\n }\n\n set name(value) {\n this.names = [value];\n }\n\n get names() {\n return this.workbook.definedNames.getNamesEx(this.fullAddress);\n }\n\n set names(value) {\n const {definedNames} = this.workbook;\n definedNames.removeAllNames(this.fullAddress);\n value.forEach(name => {\n definedNames.addEx(this.fullAddress, name);\n });\n }\n\n addName(name) {\n this.workbook.definedNames.addEx(this.fullAddress, name);\n }\n\n removeName(name) {\n this.workbook.definedNames.removeEx(this.fullAddress, name);\n }\n\n removeAllNames() {\n this.workbook.definedNames.removeAllNames(this.fullAddress);\n }\n\n // =========================================================================\n // Data Validation stuff\n get _dataValidations() {\n return this.worksheet.dataValidations;\n }\n\n get dataValidation() {\n return this._dataValidations.find(this.address);\n }\n\n set dataValidation(value) {\n this._dataValidations.add(this.address, value);\n }\n\n // =========================================================================\n // Model stuff\n\n get model() {\n const {model} = this._value;\n model.style = this.style;\n if (this._comment) {\n model.comment = this._comment.model;\n }\n return model;\n }\n\n set model(value) {\n this._value.release();\n this._value = Value.create(value.type, this);\n this._value.model = value;\n\n if (value.comment) {\n switch (value.comment.type) {\n case 'note':\n this._comment = Note.fromModel(value.comment);\n break;\n }\n }\n\n if (value.style) {\n this.style = value.style;\n } else {\n this.style = {};\n }\n }\n}\nCell.Types = Enums.ValueType;\n\n// =============================================================================\n// Internal Value Types\n\nclass NullValue {\n constructor(cell) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Null,\n };\n }\n\n get value() {\n return null;\n }\n\n set value(value) {\n // nothing to do\n }\n\n get type() {\n return Cell.Types.Null;\n }\n\n get effectiveType() {\n return Cell.Types.Null;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return '';\n }\n\n release() {}\n\n toString() {\n return '';\n }\n}\n\nclass NumberValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Number,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.Number;\n }\n\n get effectiveType() {\n return Cell.Types.Number;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value.toString();\n }\n\n release() {}\n\n toString() {\n return this.model.value.toString();\n }\n}\n\nclass StringValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.String,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.String;\n }\n\n get effectiveType() {\n return Cell.Types.String;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return `\"${this.model.value.replace(/\"/g, '\"\"')}\"`;\n }\n\n release() {}\n\n toString() {\n return this.model.value;\n }\n}\n\nclass RichTextValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.String,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n toString() {\n return this.model.value.richText.map(t => t.text).join('');\n }\n\n get type() {\n return Cell.Types.RichText;\n }\n\n get effectiveType() {\n return Cell.Types.RichText;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return `\"${this.text.replace(/\"/g, '\"\"')}\"`;\n }\n\n release() {}\n}\n\nclass DateValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Date,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.Date;\n }\n\n get effectiveType() {\n return Cell.Types.Date;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value.toISOString();\n }\n\n release() {}\n\n toString() {\n return this.model.value.toString();\n }\n}\n\nclass HyperlinkValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Hyperlink,\n text: value ? value.text : undefined,\n hyperlink: value ? value.hyperlink : undefined,\n };\n if (value && value.tooltip) {\n this.model.tooltip = value.tooltip;\n }\n }\n\n get value() {\n const v = {\n text: this.model.text,\n hyperlink: this.model.hyperlink,\n };\n if (this.model.tooltip) {\n v.tooltip = this.model.tooltip;\n }\n return v;\n }\n\n set value(value) {\n this.model = {\n text: value.text,\n hyperlink: value.hyperlink,\n };\n if (value.tooltip) {\n this.model.tooltip = value.tooltip;\n }\n }\n\n get text() {\n return this.model.text;\n }\n\n set text(value) {\n this.model.text = value;\n }\n\n /*\n get tooltip() {\n return this.model.tooltip;\n }\n\n set tooltip(value) {\n this.model.tooltip = value;\n } */\n\n get hyperlink() {\n return this.model.hyperlink;\n }\n\n set hyperlink(value) {\n this.model.hyperlink = value;\n }\n\n get type() {\n return Cell.Types.Hyperlink;\n }\n\n get effectiveType() {\n return Cell.Types.Hyperlink;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.hyperlink;\n }\n\n release() {}\n\n toString() {\n return this.model.text;\n }\n}\n\nclass MergeValue {\n constructor(cell, master) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Merge,\n master: master ? master.address : undefined,\n };\n this._master = master;\n if (master) {\n master.addMergeRef();\n }\n }\n\n get value() {\n return this._master.value;\n }\n\n set value(value) {\n if (value instanceof Cell) {\n if (this._master) {\n this._master.releaseMergeRef();\n }\n value.addMergeRef();\n this._master = value;\n } else {\n this._master.value = value;\n }\n }\n\n isMergedTo(master) {\n return master === this._master;\n }\n\n get master() {\n return this._master;\n }\n\n get type() {\n return Cell.Types.Merge;\n }\n\n get effectiveType() {\n return this._master.effectiveType;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return '';\n }\n\n release() {\n this._master.releaseMergeRef();\n }\n\n toString() {\n return this.value.toString();\n }\n}\n\nclass FormulaValue {\n constructor(cell, value) {\n this.cell = cell;\n\n this.model = {\n address: cell.address,\n type: Cell.Types.Formula,\n shareType: value ? value.shareType : undefined,\n ref: value ? value.ref : undefined,\n formula: value ? value.formula : undefined,\n sharedFormula: value ? value.sharedFormula : undefined,\n result: value ? value.result : undefined,\n };\n }\n\n _copyModel(model) {\n const copy = {};\n const cp = name => {\n const value = model[name];\n if (value) {\n copy[name] = value;\n }\n };\n cp('formula');\n cp('result');\n cp('ref');\n cp('shareType');\n cp('sharedFormula');\n return copy;\n }\n\n get value() {\n return this._copyModel(this.model);\n }\n\n set value(value) {\n this.model = this._copyModel(value);\n }\n\n validate(value) {\n switch (Value.getType(value)) {\n case Cell.Types.Null:\n case Cell.Types.String:\n case Cell.Types.Number:\n case Cell.Types.Date:\n break;\n case Cell.Types.Hyperlink:\n case Cell.Types.Formula:\n default:\n throw new Error('Cannot process that type of result value');\n }\n }\n\n get dependencies() {\n // find all the ranges and cells mentioned in the formula\n const ranges = this.formula.match(/([a-zA-Z0-9]+!)?[A-Z]{1,3}\\d{1,4}:[A-Z]{1,3}\\d{1,4}/g);\n const cells = this.formula\n .replace(/([a-zA-Z0-9]+!)?[A-Z]{1,3}\\d{1,4}:[A-Z]{1,3}\\d{1,4}/g, '')\n .match(/([a-zA-Z0-9]+!)?[A-Z]{1,3}\\d{1,4}/g);\n return {\n ranges,\n cells,\n };\n }\n\n get formula() {\n return this.model.formula || this._getTranslatedFormula();\n }\n\n set formula(value) {\n this.model.formula = value;\n }\n\n get formulaType() {\n if (this.model.formula) {\n return Enums.FormulaType.Master;\n }\n if (this.model.sharedFormula) {\n return Enums.FormulaType.Shared;\n }\n return Enums.FormulaType.None;\n }\n\n get result() {\n return this.model.result;\n }\n\n set result(value) {\n this.model.result = value;\n }\n\n get type() {\n return Cell.Types.Formula;\n }\n\n get effectiveType() {\n const v = this.model.result;\n if (v === null || v === undefined) {\n return Enums.ValueType.Null;\n }\n if (v instanceof String || typeof v === 'string') {\n return Enums.ValueType.String;\n }\n if (typeof v === 'number') {\n return Enums.ValueType.Number;\n }\n if (v instanceof Date) {\n return Enums.ValueType.Date;\n }\n if (v.text && v.hyperlink) {\n return Enums.ValueType.Hyperlink;\n }\n if (v.formula) {\n return Enums.ValueType.Formula;\n }\n\n return Enums.ValueType.Null;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n _getTranslatedFormula() {\n if (!this._translatedFormula && this.model.sharedFormula) {\n const {worksheet} = this.cell;\n const master = worksheet.findCell(this.model.sharedFormula);\n this._translatedFormula =\n master && slideFormula(master.formula, master.address, this.model.address);\n }\n return this._translatedFormula;\n }\n\n toCsvString() {\n return `${this.model.result || ''}`;\n }\n\n release() {}\n\n toString() {\n return this.model.result ? this.model.result.toString() : '';\n }\n}\n\nclass SharedStringValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.SharedString,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.SharedString;\n }\n\n get effectiveType() {\n return Cell.Types.SharedString;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value.toString();\n }\n\n release() {}\n\n toString() {\n return this.model.value.toString();\n }\n}\n\nclass BooleanValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Boolean,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.Boolean;\n }\n\n get effectiveType() {\n return Cell.Types.Boolean;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value ? 1 : 0;\n }\n\n release() {}\n\n toString() {\n return this.model.value.toString();\n }\n}\n\nclass ErrorValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.Error,\n value,\n };\n }\n\n get value() {\n return this.model.value;\n }\n\n set value(value) {\n this.model.value = value;\n }\n\n get type() {\n return Cell.Types.Error;\n }\n\n get effectiveType() {\n return Cell.Types.Error;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.toString();\n }\n\n release() {}\n\n toString() {\n return this.model.value.error.toString();\n }\n}\n\nclass JSONValue {\n constructor(cell, value) {\n this.model = {\n address: cell.address,\n type: Cell.Types.String,\n value: JSON.stringify(value),\n rawValue: value,\n };\n }\n\n get value() {\n return this.model.rawValue;\n }\n\n set value(value) {\n this.model.rawValue = value;\n this.model.value = JSON.stringify(value);\n }\n\n get type() {\n return Cell.Types.String;\n }\n\n get effectiveType() {\n return Cell.Types.String;\n }\n\n get address() {\n return this.model.address;\n }\n\n set address(value) {\n this.model.address = value;\n }\n\n toCsvString() {\n return this.model.value;\n }\n\n release() {}\n\n toString() {\n return this.model.value;\n }\n}\n\n// Value is a place to hold common static Value type functions\nconst Value = {\n getType(value) {\n if (value === null || value === undefined) {\n return Cell.Types.Null;\n }\n if (value instanceof String || typeof value === 'string') {\n return Cell.Types.String;\n }\n if (typeof value === 'number') {\n return Cell.Types.Number;\n }\n if (typeof value === 'boolean') {\n return Cell.Types.Boolean;\n }\n if (value instanceof Date) {\n return Cell.Types.Date;\n }\n if (value.text && value.hyperlink) {\n return Cell.Types.Hyperlink;\n }\n if (value.formula || value.sharedFormula) {\n return Cell.Types.Formula;\n }\n if (value.richText) {\n return Cell.Types.RichText;\n }\n if (value.sharedString) {\n return Cell.Types.SharedString;\n }\n if (value.error) {\n return Cell.Types.Error;\n }\n return Cell.Types.JSON;\n },\n\n // map valueType to constructor\n types: [\n {t: Cell.Types.Null, f: NullValue},\n {t: Cell.Types.Number, f: NumberValue},\n {t: Cell.Types.String, f: StringValue},\n {t: Cell.Types.Date, f: DateValue},\n {t: Cell.Types.Hyperlink, f: HyperlinkValue},\n {t: Cell.Types.Formula, f: FormulaValue},\n {t: Cell.Types.Merge, f: MergeValue},\n {t: Cell.Types.JSON, f: JSONValue},\n {t: Cell.Types.SharedString, f: SharedStringValue},\n {t: Cell.Types.RichText, f: RichTextValue},\n {t: Cell.Types.Boolean, f: BooleanValue},\n {t: Cell.Types.Error, f: ErrorValue},\n ].reduce((p, t) => {\n p[t.t] = t.f;\n return p;\n }, []),\n\n create(type, cell, value) {\n const T = this.types[type];\n if (!T) {\n throw new Error(`Could not create Value of type ${type}`);\n }\n return new T(cell, value);\n },\n};\n\nmodule.exports = Cell;\n"],"mappings":";;AAAA;AACA,MAAMA,QAAQ,GAAGC,OAAO,CAAC,oBAAoB,CAAC;AAC9C,MAAMC,CAAC,GAAGD,OAAO,CAAC,qBAAqB,CAAC;AACxC,MAAME,KAAK,GAAGF,OAAO,CAAC,SAAS,CAAC;AAChC,MAAM;EAACG;AAAY,CAAC,GAAGH,OAAO,CAAC,yBAAyB,CAAC;AACzD,MAAMI,IAAI,GAAGJ,OAAO,CAAC,QAAQ,CAAC;AAC9B;AACA;AACA;AACA;;AAEA,MAAMK,IAAI,CAAC;EACTC,WAAWA,CAACC,GAAG,EAAEC,MAAM,EAAEC,OAAO,EAAE;IAChC,IAAI,CAACF,GAAG,IAAI,CAACC,MAAM,EAAE;MACnB,MAAM,IAAIE,KAAK,CAAC,oBAAoB,CAAC;IACvC;IAEA,IAAI,CAACC,IAAI,GAAGJ,GAAG;IACf,IAAI,CAACK,OAAO,GAAGJ,MAAM;IAErBT,QAAQ,CAACc,eAAe,CAACJ,OAAO,CAAC;IACjC,IAAI,CAACK,QAAQ,GAAGL,OAAO;;IAEvB;IACA,IAAI,CAACM,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACZ,IAAI,CAACa,KAAK,CAACC,IAAI,EAAE,IAAI,CAAC;IAEjD,IAAI,CAACC,KAAK,GAAG,IAAI,CAACC,WAAW,CAACd,GAAG,CAACa,KAAK,EAAEZ,MAAM,CAACY,KAAK,EAAE,CAAC,CAAC,CAAC;IAE1D,IAAI,CAACE,WAAW,GAAG,CAAC;EACtB;EAEA,IAAIC,SAASA,CAAA,EAAG;IACd,OAAO,IAAI,CAACZ,IAAI,CAACY,SAAS;EAC5B;EAEA,IAAIC,QAAQA,CAAA,EAAG;IACb,OAAO,IAAI,CAACb,IAAI,CAACY,SAAS,CAACC,QAAQ;EACrC;;EAEA;EACAC,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAACL,KAAK;IACjB,OAAO,IAAI,CAACL,MAAM;IAClB,OAAO,IAAI,CAACJ,IAAI;IAChB,OAAO,IAAI,CAACC,OAAO;IACnB,OAAO,IAAI,CAACE,QAAQ;EACtB;;EAEA;EACA;EACA,IAAIY,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAACN,KAAK,CAACM,MAAM;EAC1B;EAEA,IAAIA,MAAMA,CAACC,KAAK,EAAE;IAChB,IAAI,CAACP,KAAK,CAACM,MAAM,GAAGC,KAAK;EAC3B;EAEA,IAAIC,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACR,KAAK,CAACQ,IAAI;EACxB;EAEA,IAAIA,IAAIA,CAACD,KAAK,EAAE;IACd,IAAI,CAACP,KAAK,CAACQ,IAAI,GAAGD,KAAK;EACzB;EAEA,IAAIE,SAASA,CAAA,EAAG;IACd,OAAO,IAAI,CAACT,KAAK,CAACS,SAAS;EAC7B;EAEA,IAAIA,SAASA,CAACF,KAAK,EAAE;IACnB,IAAI,CAACP,KAAK,CAACS,SAAS,GAAGF,KAAK;EAC9B;EAEA,IAAIG,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAACV,KAAK,CAACU,MAAM;EAC1B;EAEA,IAAIA,MAAMA,CAACH,KAAK,EAAE;IAChB,IAAI,CAACP,KAAK,CAACU,MAAM,GAAGH,KAAK;EAC3B;EAEA,IAAII,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACX,KAAK,CAACW,IAAI;EACxB;EAEA,IAAIA,IAAIA,CAACJ,KAAK,EAAE;IACd,IAAI,CAACP,KAAK,CAACW,IAAI,GAAGJ,KAAK;EACzB;EAEA,IAAIK,UAAUA,CAAA,EAAG;IACf,OAAO,IAAI,CAACZ,KAAK,CAACY,UAAU;EAC9B;EAEA,IAAIA,UAAUA,CAACL,KAAK,EAAE;IACpB,IAAI,CAACP,KAAK,CAACY,UAAU,GAAGL,KAAK;EAC/B;EAEAN,WAAWA,CAACY,QAAQ,EAAEC,QAAQ,EAAEd,KAAK,EAAE;IACrC,MAAMM,MAAM,GAAIO,QAAQ,IAAIA,QAAQ,CAACP,MAAM,IAAMQ,QAAQ,IAAIA,QAAQ,CAACR,MAAO;IAC7E,IAAIA,MAAM,EAAEN,KAAK,CAACM,MAAM,GAAGA,MAAM;IAEjC,MAAME,IAAI,GAAIK,QAAQ,IAAIA,QAAQ,CAACL,IAAI,IAAMM,QAAQ,IAAIA,QAAQ,CAACN,IAAK;IACvE,IAAIA,IAAI,EAAER,KAAK,CAACQ,IAAI,GAAGA,IAAI;IAE3B,MAAMC,SAAS,GAAII,QAAQ,IAAIA,QAAQ,CAACJ,SAAS,IAAMK,QAAQ,IAAIA,QAAQ,CAACL,SAAU;IACtF,IAAIA,SAAS,EAAET,KAAK,CAACS,SAAS,GAAGA,SAAS;IAE1C,MAAMC,MAAM,GAAIG,QAAQ,IAAIA,QAAQ,CAACH,MAAM,IAAMI,QAAQ,IAAIA,QAAQ,CAACJ,MAAO;IAC7E,IAAIA,MAAM,EAAEV,KAAK,CAACU,MAAM,GAAGA,MAAM;IAEjC,MAAMC,IAAI,GAAIE,QAAQ,IAAIA,QAAQ,CAACF,IAAI,IAAMG,QAAQ,IAAIA,QAAQ,CAACH,IAAK;IACvE,IAAIA,IAAI,EAAEX,KAAK,CAACW,IAAI,GAAGA,IAAI;IAE3B,MAAMC,UAAU,GAAIC,QAAQ,IAAIA,QAAQ,CAACD,UAAU,IAAME,QAAQ,IAAIA,QAAQ,CAACF,UAAW;IACzF,IAAIA,UAAU,EAAEZ,KAAK,CAACY,UAAU,GAAGA,UAAU;IAE7C,OAAOZ,KAAK;EACd;;EAEA;EACA;EACA,IAAIX,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACK,QAAQ;EACtB;EAEA,IAAIP,GAAGA,CAAA,EAAG;IACR,OAAO,IAAI,CAACI,IAAI,CAACwB,MAAM;EACzB;EAEA,IAAIC,GAAGA,CAAA,EAAG;IACR,OAAO,IAAI,CAACxB,OAAO,CAACuB,MAAM;EAC5B;EAEA,IAAIE,QAAQA,CAAA,EAAG;IACb,OAAO,IAAI,IAAI,CAACzB,OAAO,CAAC0B,MAAM,IAAI,IAAI,CAAC/B,GAAG,EAAE;EAC9C;;EAEA;EACA;;EAEA,IAAIgC,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACxB,MAAM,CAACwB,IAAI;EACzB;EAEA,IAAIC,aAAaA,CAAA,EAAG;IAClB,OAAO,IAAI,CAACzB,MAAM,CAACyB,aAAa;EAClC;EAEAC,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC1B,MAAM,CAAC0B,WAAW,CAAC,CAAC;EAClC;;EAEA;EACA;;EAEAC,WAAWA,CAAA,EAAG;IACZ,IAAI,CAACpB,WAAW,EAAE;EACpB;EAEAqB,eAAeA,CAAA,EAAG;IAChB,IAAI,CAACrB,WAAW,EAAE;EACpB;EAEA,IAAIsB,QAAQA,CAAA,EAAG;IACb,OAAO,IAAI,CAACtB,WAAW,GAAG,CAAC,IAAI,IAAI,CAACiB,IAAI,KAAKlC,IAAI,CAACa,KAAK,CAAC2B,KAAK;EAC/D;EAEAC,KAAKA,CAACC,MAAM,EAAEC,WAAW,EAAE;IACzB,IAAI,CAACjC,MAAM,CAACkC,OAAO,CAAC,CAAC;IACrB,IAAI,CAAClC,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACZ,IAAI,CAACa,KAAK,CAAC2B,KAAK,EAAE,IAAI,EAAEE,MAAM,CAAC;IAC1D,IAAI,CAACC,WAAW,EAAE;MAChB,IAAI,CAAC5B,KAAK,GAAG2B,MAAM,CAAC3B,KAAK;IAC3B;EACF;EAEA8B,OAAOA,CAAA,EAAG;IACR,IAAI,IAAI,CAACX,IAAI,KAAKlC,IAAI,CAACa,KAAK,CAAC2B,KAAK,EAAE;MAClC,IAAI,CAAC9B,MAAM,CAACkC,OAAO,CAAC,CAAC;MACrB,IAAI,CAAClC,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACZ,IAAI,CAACa,KAAK,CAACC,IAAI,EAAE,IAAI,CAAC;MACjD,IAAI,CAACC,KAAK,GAAG,IAAI,CAACC,WAAW,CAAC,IAAI,CAACV,IAAI,CAACS,KAAK,EAAE,IAAI,CAACR,OAAO,CAACQ,KAAK,EAAE,CAAC,CAAC,CAAC;IACxE;EACF;EAEA+B,UAAUA,CAACJ,MAAM,EAAE;IACjB,IAAI,IAAI,CAAChC,MAAM,CAACwB,IAAI,KAAKlC,IAAI,CAACa,KAAK,CAAC2B,KAAK,EAAE,OAAO,KAAK;IACvD,OAAO,IAAI,CAAC9B,MAAM,CAACoC,UAAU,CAACJ,MAAM,CAAC;EACvC;EAEA,IAAIA,MAAMA,CAAA,EAAG;IACX,IAAI,IAAI,CAACR,IAAI,KAAKlC,IAAI,CAACa,KAAK,CAAC2B,KAAK,EAAE;MAClC,OAAO,IAAI,CAAC9B,MAAM,CAACgC,MAAM;IAC3B;IACA,OAAO,IAAI,CAAC,CAAC;EACf;EAEA,IAAIK,WAAWA,CAAA,EAAG;IAChB,OAAO,IAAI,CAACrC,MAAM,CAACwB,IAAI,KAAKlC,IAAI,CAACa,KAAK,CAACmC,SAAS;EAClD;EAEA,IAAIC,SAASA,CAAA,EAAG;IACd,OAAO,IAAI,CAACvC,MAAM,CAACuC,SAAS;EAC9B;;EAEA;EACA,IAAI3B,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAACZ,MAAM,CAACY,KAAK;EAC1B;;EAEA;EACA,IAAIA,KAAKA,CAAC4B,CAAC,EAAE;IACX;IACA,IAAI,IAAI,CAAChB,IAAI,KAAKlC,IAAI,CAACa,KAAK,CAAC2B,KAAK,EAAE;MAClC,IAAI,CAAC9B,MAAM,CAACgC,MAAM,CAACpB,KAAK,GAAG4B,CAAC;MAC5B;IACF;IAEA,IAAI,CAACxC,MAAM,CAACkC,OAAO,CAAC,CAAC;;IAErB;IACA,IAAI,CAAClC,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACD,KAAK,CAACwC,OAAO,CAACD,CAAC,CAAC,EAAE,IAAI,EAAEA,CAAC,CAAC;EACvD;EAEA,IAAIE,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACC,QAAQ,IAAI,IAAI,CAACA,QAAQ,CAACD,IAAI;EAC5C;EAEA,IAAIA,IAAIA,CAACA,IAAI,EAAE;IACb,IAAI,CAACC,QAAQ,GAAG,IAAItD,IAAI,CAACqD,IAAI,CAAC;EAChC;EAEA,IAAIE,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAAC5C,MAAM,CAAC6C,QAAQ,CAAC,CAAC;EAC/B;EAEA,IAAIC,IAAIA,CAAA,EAAG;IACT,OAAO5D,CAAC,CAAC6D,UAAU,CAAC,IAAI,CAACH,IAAI,CAAC;EAChC;EAEAC,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACD,IAAI;EAClB;EAEAI,mBAAmBA,CAACT,SAAS,EAAE;IAC7B;IACA,IAAI,IAAI,CAACf,IAAI,KAAKlC,IAAI,CAACa,KAAK,CAAC8C,MAAM,EAAE;MACnC,IAAI,CAACjD,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACZ,IAAI,CAACa,KAAK,CAACmC,SAAS,EAAE,IAAI,EAAE;QACrDM,IAAI,EAAE,IAAI,CAAC5C,MAAM,CAACY,KAAK;QACvB2B;MACF,CAAC,CAAC;IACJ;EACF;;EAEA;EACA;EACA,IAAIW,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAClD,MAAM,CAACkD,OAAO;EAC5B;EAEA,IAAIC,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAACnD,MAAM,CAACmD,MAAM;EAC3B;EAEA,IAAIC,WAAWA,CAAA,EAAG;IAChB,OAAO,IAAI,CAACpD,MAAM,CAACoD,WAAW;EAChC;;EAEA;EACA;EACA,IAAIC,WAAWA,CAAA,EAAG;IAChB,MAAM;MAAC7C;IAAS,CAAC,GAAG,IAAI,CAACZ,IAAI;IAC7B,OAAO;MACL0D,SAAS,EAAE9C,SAAS,CAAC+C,IAAI;MACzB7D,OAAO,EAAE,IAAI,CAACA,OAAO;MACrBF,GAAG,EAAE,IAAI,CAACA,GAAG;MACb6B,GAAG,EAAE,IAAI,CAACA;IACZ,CAAC;EACH;EAEA,IAAIkC,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAACC,KAAK,CAAC,CAAC,CAAC;EACtB;EAEA,IAAID,IAAIA,CAAC3C,KAAK,EAAE;IACd,IAAI,CAAC4C,KAAK,GAAG,CAAC5C,KAAK,CAAC;EACtB;EAEA,IAAI4C,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC/C,QAAQ,CAACgD,YAAY,CAACC,UAAU,CAAC,IAAI,CAACL,WAAW,CAAC;EAChE;EAEA,IAAIG,KAAKA,CAAC5C,KAAK,EAAE;IACf,MAAM;MAAC6C;IAAY,CAAC,GAAG,IAAI,CAAChD,QAAQ;IACpCgD,YAAY,CAACE,cAAc,CAAC,IAAI,CAACN,WAAW,CAAC;IAC7CzC,KAAK,CAACgD,OAAO,CAACL,IAAI,IAAI;MACpBE,YAAY,CAACI,KAAK,CAAC,IAAI,CAACR,WAAW,EAAEE,IAAI,CAAC;IAC5C,CAAC,CAAC;EACJ;EAEAO,OAAOA,CAACP,IAAI,EAAE;IACZ,IAAI,CAAC9C,QAAQ,CAACgD,YAAY,CAACI,KAAK,CAAC,IAAI,CAACR,WAAW,EAAEE,IAAI,CAAC;EAC1D;EAEAQ,UAAUA,CAACR,IAAI,EAAE;IACf,IAAI,CAAC9C,QAAQ,CAACgD,YAAY,CAACO,QAAQ,CAAC,IAAI,CAACX,WAAW,EAAEE,IAAI,CAAC;EAC7D;EAEAI,cAAcA,CAAA,EAAG;IACf,IAAI,CAAClD,QAAQ,CAACgD,YAAY,CAACE,cAAc,CAAC,IAAI,CAACN,WAAW,CAAC;EAC7D;;EAEA;EACA;EACA,IAAIY,gBAAgBA,CAAA,EAAG;IACrB,OAAO,IAAI,CAACzD,SAAS,CAAC0D,eAAe;EACvC;EAEA,IAAIC,cAAcA,CAAA,EAAG;IACnB,OAAO,IAAI,CAACF,gBAAgB,CAACG,IAAI,CAAC,IAAI,CAAC1E,OAAO,CAAC;EACjD;EAEA,IAAIyE,cAAcA,CAACvD,KAAK,EAAE;IACxB,IAAI,CAACqD,gBAAgB,CAACI,GAAG,CAAC,IAAI,CAAC3E,OAAO,EAAEkB,KAAK,CAAC;EAChD;;EAEA;EACA;;EAEA,IAAI0D,KAAKA,CAAA,EAAG;IACV,MAAM;MAACA;IAAK,CAAC,GAAG,IAAI,CAACtE,MAAM;IAC3BsE,KAAK,CAACjE,KAAK,GAAG,IAAI,CAACA,KAAK;IACxB,IAAI,IAAI,CAACsC,QAAQ,EAAE;MACjB2B,KAAK,CAACC,OAAO,GAAG,IAAI,CAAC5B,QAAQ,CAAC2B,KAAK;IACrC;IACA,OAAOA,KAAK;EACd;EAEA,IAAIA,KAAKA,CAAC1D,KAAK,EAAE;IACf,IAAI,CAACZ,MAAM,CAACkC,OAAO,CAAC,CAAC;IACrB,IAAI,CAAClC,MAAM,GAAGC,KAAK,CAACC,MAAM,CAACU,KAAK,CAACY,IAAI,EAAE,IAAI,CAAC;IAC5C,IAAI,CAACxB,MAAM,CAACsE,KAAK,GAAG1D,KAAK;IAEzB,IAAIA,KAAK,CAAC2D,OAAO,EAAE;MACjB,QAAQ3D,KAAK,CAAC2D,OAAO,CAAC/C,IAAI;QACxB,KAAK,MAAM;UACT,IAAI,CAACmB,QAAQ,GAAGtD,IAAI,CAACmF,SAAS,CAAC5D,KAAK,CAAC2D,OAAO,CAAC;UAC7C;MACJ;IACF;IAEA,IAAI3D,KAAK,CAACP,KAAK,EAAE;MACf,IAAI,CAACA,KAAK,GAAGO,KAAK,CAACP,KAAK;IAC1B,CAAC,MAAM;MACL,IAAI,CAACA,KAAK,GAAG,CAAC,CAAC;IACjB;EACF;AACF;AACAf,IAAI,CAACa,KAAK,GAAGhB,KAAK,CAACsF,SAAS;;AAE5B;AACA;;AAEA,MAAMC,SAAS,CAAC;EACdnF,WAAWA,CAACoF,IAAI,EAAE;IAChB,IAAI,CAACL,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAACC;IACnB,CAAC;EACH;EAEA,IAAIQ,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI;EACb;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf;EAAA;EAGF,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAACC,IAAI;EACxB;EAEA,IAAIqB,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAACC,IAAI;EACxB;EAEA,IAAIV,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,EAAE;EACX;EAEAQ,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,EAAE;EACX;AACF;AAEA,MAAM+B,WAAW,CAAC;EAChBrF,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC0D,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAAC0E,MAAM;MACvBjE;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC0D,KAAK,CAAC1D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,CAAC1D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAAC0E,MAAM;EAC1B;EAEA,IAAIpD,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAAC0E,MAAM;EAC1B;EAEA,IAAInF,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC1D,KAAK,CAACiC,QAAQ,CAAC,CAAC;EACpC;EAEAX,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1D,KAAK,CAACiC,QAAQ,CAAC,CAAC;EACpC;AACF;AAEA,MAAMiC,WAAW,CAAC;EAChBvF,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC0D,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAAC8C,MAAM;MACvBrC;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC0D,KAAK,CAAC1D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,CAAC1D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAAC8C,MAAM;EAC1B;EAEA,IAAIxB,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAAC8C,MAAM;EAC1B;EAEA,IAAIvD,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,IAAI,CAAC4C,KAAK,CAAC1D,KAAK,CAACmE,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG;EACpD;EAEA7C,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1D,KAAK;EACzB;AACF;AAEA,MAAMoE,aAAa,CAAC;EAClBzF,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC0D,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAAC8C,MAAM;MACvBrC;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC0D,KAAK,CAAC1D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,CAAC1D,KAAK,GAAGA,KAAK;EAC1B;EAEAiC,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1D,KAAK,CAACqE,QAAQ,CAACC,GAAG,CAACC,CAAC,IAAIA,CAAC,CAACvC,IAAI,CAAC,CAACwC,IAAI,CAAC,EAAE,CAAC;EAC5D;EAEA,IAAI5D,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAACkF,QAAQ;EAC5B;EAEA,IAAI5D,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAACkF,QAAQ;EAC5B;EAEA,IAAI3F,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,IAAI,CAACkB,IAAI,CAACmC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG;EAC7C;EAEA7C,OAAOA,CAAA,EAAG,CAAC;AACb;AAEA,MAAMoD,SAAS,CAAC;EACd/F,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC0D,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAACoF,IAAI;MACrB3E;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC0D,KAAK,CAAC1D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,CAAC1D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAACoF,IAAI;EACxB;EAEA,IAAI9D,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAACoF,IAAI;EACxB;EAEA,IAAI7F,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC1D,KAAK,CAAC4E,WAAW,CAAC,CAAC;EACvC;EAEAtD,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1D,KAAK,CAACiC,QAAQ,CAAC,CAAC;EACpC;AACF;AAEA,MAAM4C,cAAc,CAAC;EACnBlG,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC0D,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAACmC,SAAS;MAC1BM,IAAI,EAAEhC,KAAK,GAAGA,KAAK,CAACgC,IAAI,GAAG8C,SAAS;MACpCnD,SAAS,EAAE3B,KAAK,GAAGA,KAAK,CAAC2B,SAAS,GAAGmD;IACvC,CAAC;IACD,IAAI9E,KAAK,IAAIA,KAAK,CAAC+E,OAAO,EAAE;MAC1B,IAAI,CAACrB,KAAK,CAACqB,OAAO,GAAG/E,KAAK,CAAC+E,OAAO;IACpC;EACF;EAEA,IAAI/E,KAAKA,CAAA,EAAG;IACV,MAAM4B,CAAC,GAAG;MACRI,IAAI,EAAE,IAAI,CAAC0B,KAAK,CAAC1B,IAAI;MACrBL,SAAS,EAAE,IAAI,CAAC+B,KAAK,CAAC/B;IACxB,CAAC;IACD,IAAI,IAAI,CAAC+B,KAAK,CAACqB,OAAO,EAAE;MACtBnD,CAAC,CAACmD,OAAO,GAAG,IAAI,CAACrB,KAAK,CAACqB,OAAO;IAChC;IACA,OAAOnD,CAAC;EACV;EAEA,IAAI5B,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,GAAG;MACX1B,IAAI,EAAEhC,KAAK,CAACgC,IAAI;MAChBL,SAAS,EAAE3B,KAAK,CAAC2B;IACnB,CAAC;IACD,IAAI3B,KAAK,CAAC+E,OAAO,EAAE;MACjB,IAAI,CAACrB,KAAK,CAACqB,OAAO,GAAG/E,KAAK,CAAC+E,OAAO;IACpC;EACF;EAEA,IAAI/C,IAAIA,CAAA,EAAG;IACT,OAAO,IAAI,CAAC0B,KAAK,CAAC1B,IAAI;EACxB;EAEA,IAAIA,IAAIA,CAAChC,KAAK,EAAE;IACd,IAAI,CAAC0D,KAAK,CAAC1B,IAAI,GAAGhC,KAAK;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;;EAGE,IAAI2B,SAASA,CAAA,EAAG;IACd,OAAO,IAAI,CAAC+B,KAAK,CAAC/B,SAAS;EAC7B;EAEA,IAAIA,SAASA,CAAC3B,KAAK,EAAE;IACnB,IAAI,CAAC0D,KAAK,CAAC/B,SAAS,GAAG3B,KAAK;EAC9B;EAEA,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAACmC,SAAS;EAC7B;EAEA,IAAIb,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAACmC,SAAS;EAC7B;EAEA,IAAI5C,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC/B,SAAS;EAC7B;EAEAL,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1B,IAAI;EACxB;AACF;AAEA,MAAMgD,UAAU,CAAC;EACfrG,WAAWA,CAACoF,IAAI,EAAE3C,MAAM,EAAE;IACxB,IAAI,CAACsC,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAAC2B,KAAK;MACtBE,MAAM,EAAEA,MAAM,GAAGA,MAAM,CAACtC,OAAO,GAAGgG;IACpC,CAAC;IACD,IAAI,CAACG,OAAO,GAAG7D,MAAM;IACrB,IAAIA,MAAM,EAAE;MACVA,MAAM,CAACL,WAAW,CAAC,CAAC;IACtB;EACF;EAEA,IAAIf,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAACiF,OAAO,CAACjF,KAAK;EAC3B;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAIA,KAAK,YAAYtB,IAAI,EAAE;MACzB,IAAI,IAAI,CAACuG,OAAO,EAAE;QAChB,IAAI,CAACA,OAAO,CAACjE,eAAe,CAAC,CAAC;MAChC;MACAhB,KAAK,CAACe,WAAW,CAAC,CAAC;MACnB,IAAI,CAACkE,OAAO,GAAGjF,KAAK;IACtB,CAAC,MAAM;MACL,IAAI,CAACiF,OAAO,CAACjF,KAAK,GAAGA,KAAK;IAC5B;EACF;EAEAwB,UAAUA,CAACJ,MAAM,EAAE;IACjB,OAAOA,MAAM,KAAK,IAAI,CAAC6D,OAAO;EAChC;EAEA,IAAI7D,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAAC6D,OAAO;EACrB;EAEA,IAAIrE,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAAC2B,KAAK;EACzB;EAEA,IAAIL,aAAaA,CAAA,EAAG;IAClB,OAAO,IAAI,CAACoE,OAAO,CAACpE,aAAa;EACnC;EAEA,IAAI/B,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,EAAE;EACX;EAEAQ,OAAOA,CAAA,EAAG;IACR,IAAI,CAAC2D,OAAO,CAACjE,eAAe,CAAC,CAAC;EAChC;EAEAiB,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACjC,KAAK,CAACiC,QAAQ,CAAC,CAAC;EAC9B;AACF;AAEA,MAAMiD,YAAY,CAAC;EACjBvG,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC+D,IAAI,GAAGA,IAAI;IAEhB,IAAI,CAACL,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAAC4F,OAAO;MACxBC,SAAS,EAAEpF,KAAK,GAAGA,KAAK,CAACoF,SAAS,GAAGN,SAAS;MAC9CO,GAAG,EAAErF,KAAK,GAAGA,KAAK,CAACqF,GAAG,GAAGP,SAAS;MAClCxC,OAAO,EAAEtC,KAAK,GAAGA,KAAK,CAACsC,OAAO,GAAGwC,SAAS;MAC1CQ,aAAa,EAAEtF,KAAK,GAAGA,KAAK,CAACsF,aAAa,GAAGR,SAAS;MACtDvC,MAAM,EAAEvC,KAAK,GAAGA,KAAK,CAACuC,MAAM,GAAGuC;IACjC,CAAC;EACH;EAEAS,UAAUA,CAAC7B,KAAK,EAAE;IAChB,MAAM8B,IAAI,GAAG,CAAC,CAAC;IACf,MAAMC,EAAE,GAAG9C,IAAI,IAAI;MACjB,MAAM3C,KAAK,GAAG0D,KAAK,CAACf,IAAI,CAAC;MACzB,IAAI3C,KAAK,EAAE;QACTwF,IAAI,CAAC7C,IAAI,CAAC,GAAG3C,KAAK;MACpB;IACF,CAAC;IACDyF,EAAE,CAAC,SAAS,CAAC;IACbA,EAAE,CAAC,QAAQ,CAAC;IACZA,EAAE,CAAC,KAAK,CAAC;IACTA,EAAE,CAAC,WAAW,CAAC;IACfA,EAAE,CAAC,eAAe,CAAC;IACnB,OAAOD,IAAI;EACb;EAEA,IAAIxF,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAACuF,UAAU,CAAC,IAAI,CAAC7B,KAAK,CAAC;EACpC;EAEA,IAAI1D,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,GAAG,IAAI,CAAC6B,UAAU,CAACvF,KAAK,CAAC;EACrC;EAEA0F,QAAQA,CAAC1F,KAAK,EAAE;IACd,QAAQX,KAAK,CAACwC,OAAO,CAAC7B,KAAK,CAAC;MAC1B,KAAKtB,IAAI,CAACa,KAAK,CAACC,IAAI;MACpB,KAAKd,IAAI,CAACa,KAAK,CAAC8C,MAAM;MACtB,KAAK3D,IAAI,CAACa,KAAK,CAAC0E,MAAM;MACtB,KAAKvF,IAAI,CAACa,KAAK,CAACoF,IAAI;QAClB;MACF,KAAKjG,IAAI,CAACa,KAAK,CAACmC,SAAS;MACzB,KAAKhD,IAAI,CAACa,KAAK,CAAC4F,OAAO;MACvB;QACE,MAAM,IAAIpG,KAAK,CAAC,0CAA0C,CAAC;IAC/D;EACF;EAEA,IAAI4G,YAAYA,CAAA,EAAG;IACjB;IACA,MAAMC,MAAM,GAAG,IAAI,CAACtD,OAAO,CAACuD,KAAK,CAAC,sDAAsD,CAAC;IACzF,MAAMC,KAAK,GAAG,IAAI,CAACxD,OAAO,CACvB6B,OAAO,CAAC,sDAAsD,EAAE,EAAE,CAAC,CACnE0B,KAAK,CAAC,oCAAoC,CAAC;IAC9C,OAAO;MACLD,MAAM;MACNE;IACF,CAAC;EACH;EAEA,IAAIxD,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACoB,KAAK,CAACpB,OAAO,IAAI,IAAI,CAACyD,qBAAqB,CAAC,CAAC;EAC3D;EAEA,IAAIzD,OAAOA,CAACtC,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAACpB,OAAO,GAAGtC,KAAK;EAC5B;EAEA,IAAIwC,WAAWA,CAAA,EAAG;IAChB,IAAI,IAAI,CAACkB,KAAK,CAACpB,OAAO,EAAE;MACtB,OAAO/D,KAAK,CAACyH,WAAW,CAACC,MAAM;IACjC;IACA,IAAI,IAAI,CAACvC,KAAK,CAAC4B,aAAa,EAAE;MAC5B,OAAO/G,KAAK,CAACyH,WAAW,CAACE,MAAM;IACjC;IACA,OAAO3H,KAAK,CAACyH,WAAW,CAACG,IAAI;EAC/B;EAEA,IAAI5D,MAAMA,CAAA,EAAG;IACX,OAAO,IAAI,CAACmB,KAAK,CAACnB,MAAM;EAC1B;EAEA,IAAIA,MAAMA,CAACvC,KAAK,EAAE;IAChB,IAAI,CAAC0D,KAAK,CAACnB,MAAM,GAAGvC,KAAK;EAC3B;EAEA,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAAC4F,OAAO;EAC3B;EAEA,IAAItE,aAAaA,CAAA,EAAG;IAClB,MAAMe,CAAC,GAAG,IAAI,CAAC8B,KAAK,CAACnB,MAAM;IAC3B,IAAIX,CAAC,KAAK,IAAI,IAAIA,CAAC,KAAKkD,SAAS,EAAE;MACjC,OAAOvG,KAAK,CAACsF,SAAS,CAACrE,IAAI;IAC7B;IACA,IAAIoC,CAAC,YAAYS,MAAM,IAAI,OAAOT,CAAC,KAAK,QAAQ,EAAE;MAChD,OAAOrD,KAAK,CAACsF,SAAS,CAACxB,MAAM;IAC/B;IACA,IAAI,OAAOT,CAAC,KAAK,QAAQ,EAAE;MACzB,OAAOrD,KAAK,CAACsF,SAAS,CAACI,MAAM;IAC/B;IACA,IAAIrC,CAAC,YAAY+C,IAAI,EAAE;MACrB,OAAOpG,KAAK,CAACsF,SAAS,CAACc,IAAI;IAC7B;IACA,IAAI/C,CAAC,CAACI,IAAI,IAAIJ,CAAC,CAACD,SAAS,EAAE;MACzB,OAAOpD,KAAK,CAACsF,SAAS,CAACnC,SAAS;IAClC;IACA,IAAIE,CAAC,CAACU,OAAO,EAAE;MACb,OAAO/D,KAAK,CAACsF,SAAS,CAACsB,OAAO;IAChC;IAEA,OAAO5G,KAAK,CAACsF,SAAS,CAACrE,IAAI;EAC7B;EAEA,IAAIV,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEA+F,qBAAqBA,CAAA,EAAG;IACtB,IAAI,CAAC,IAAI,CAACK,kBAAkB,IAAI,IAAI,CAAC1C,KAAK,CAAC4B,aAAa,EAAE;MACxD,MAAM;QAAC1F;MAAS,CAAC,GAAG,IAAI,CAACmE,IAAI;MAC7B,MAAM3C,MAAM,GAAGxB,SAAS,CAACyG,QAAQ,CAAC,IAAI,CAAC3C,KAAK,CAAC4B,aAAa,CAAC;MAC3D,IAAI,CAACc,kBAAkB,GACrBhF,MAAM,IAAI5C,YAAY,CAAC4C,MAAM,CAACkB,OAAO,EAAElB,MAAM,CAACtC,OAAO,EAAE,IAAI,CAAC4E,KAAK,CAAC5E,OAAO,CAAC;IAC9E;IACA,OAAO,IAAI,CAACsH,kBAAkB;EAChC;EAEAtF,WAAWA,CAAA,EAAG;IACZ,OAAO,GAAG,IAAI,CAAC4C,KAAK,CAACnB,MAAM,IAAI,EAAE,EAAE;EACrC;EAEAjB,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAACnB,MAAM,GAAG,IAAI,CAACmB,KAAK,CAACnB,MAAM,CAACN,QAAQ,CAAC,CAAC,GAAG,EAAE;EAC9D;AACF;AAEA,MAAMqE,iBAAiB,CAAC;EACtB3H,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC0D,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAACgH,YAAY;MAC7BvG;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC0D,KAAK,CAAC1D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,CAAC1D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAACgH,YAAY;EAChC;EAEA,IAAI1F,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAACgH,YAAY;EAChC;EAEA,IAAIzH,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC1D,KAAK,CAACiC,QAAQ,CAAC,CAAC;EACpC;EAEAX,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1D,KAAK,CAACiC,QAAQ,CAAC,CAAC;EACpC;AACF;AAEA,MAAMuE,YAAY,CAAC;EACjB7H,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC0D,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAACkH,OAAO;MACxBzG;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC0D,KAAK,CAAC1D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,CAAC1D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAACkH,OAAO;EAC3B;EAEA,IAAI5F,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAACkH,OAAO;EAC3B;EAEA,IAAI3H,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC1D,KAAK,GAAG,CAAC,GAAG,CAAC;EACjC;EAEAsB,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1D,KAAK,CAACiC,QAAQ,CAAC,CAAC;EACpC;AACF;AAEA,MAAMyE,UAAU,CAAC;EACf/H,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC0D,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAACR,KAAK;MACtBiB;IACF,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC0D,KAAK,CAAC1D,KAAK;EACzB;EAEA,IAAIA,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,CAAC1D,KAAK,GAAGA,KAAK;EAC1B;EAEA,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAACR,KAAK;EACzB;EAEA,IAAI8B,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAACR,KAAK;EACzB;EAEA,IAAID,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACmB,QAAQ,CAAC,CAAC;EACxB;EAEAX,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1D,KAAK,CAAC2G,KAAK,CAAC1E,QAAQ,CAAC,CAAC;EAC1C;AACF;AAEA,MAAM2E,SAAS,CAAC;EACdjI,WAAWA,CAACoF,IAAI,EAAE/D,KAAK,EAAE;IACvB,IAAI,CAAC0D,KAAK,GAAG;MACX5E,OAAO,EAAEiF,IAAI,CAACjF,OAAO;MACrB8B,IAAI,EAAElC,IAAI,CAACa,KAAK,CAAC8C,MAAM;MACvBrC,KAAK,EAAE6G,IAAI,CAACC,SAAS,CAAC9G,KAAK,CAAC;MAC5B+G,QAAQ,EAAE/G;IACZ,CAAC;EACH;EAEA,IAAIA,KAAKA,CAAA,EAAG;IACV,OAAO,IAAI,CAAC0D,KAAK,CAACqD,QAAQ;EAC5B;EAEA,IAAI/G,KAAKA,CAACA,KAAK,EAAE;IACf,IAAI,CAAC0D,KAAK,CAACqD,QAAQ,GAAG/G,KAAK;IAC3B,IAAI,CAAC0D,KAAK,CAAC1D,KAAK,GAAG6G,IAAI,CAACC,SAAS,CAAC9G,KAAK,CAAC;EAC1C;EAEA,IAAIY,IAAIA,CAAA,EAAG;IACT,OAAOlC,IAAI,CAACa,KAAK,CAAC8C,MAAM;EAC1B;EAEA,IAAIxB,aAAaA,CAAA,EAAG;IAClB,OAAOnC,IAAI,CAACa,KAAK,CAAC8C,MAAM;EAC1B;EAEA,IAAIvD,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4E,KAAK,CAAC5E,OAAO;EAC3B;EAEA,IAAIA,OAAOA,CAACkB,KAAK,EAAE;IACjB,IAAI,CAAC0D,KAAK,CAAC5E,OAAO,GAAGkB,KAAK;EAC5B;EAEAc,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC4C,KAAK,CAAC1D,KAAK;EACzB;EAEAsB,OAAOA,CAAA,EAAG,CAAC;EAEXW,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACyB,KAAK,CAAC1D,KAAK;EACzB;AACF;;AAEA;AACA,MAAMX,KAAK,GAAG;EACZwC,OAAOA,CAAC7B,KAAK,EAAE;IACb,IAAIA,KAAK,KAAK,IAAI,IAAIA,KAAK,KAAK8E,SAAS,EAAE;MACzC,OAAOpG,IAAI,CAACa,KAAK,CAACC,IAAI;IACxB;IACA,IAAIQ,KAAK,YAAYqC,MAAM,IAAI,OAAOrC,KAAK,KAAK,QAAQ,EAAE;MACxD,OAAOtB,IAAI,CAACa,KAAK,CAAC8C,MAAM;IAC1B;IACA,IAAI,OAAOrC,KAAK,KAAK,QAAQ,EAAE;MAC7B,OAAOtB,IAAI,CAACa,KAAK,CAAC0E,MAAM;IAC1B;IACA,IAAI,OAAOjE,KAAK,KAAK,SAAS,EAAE;MAC9B,OAAOtB,IAAI,CAACa,KAAK,CAACkH,OAAO;IAC3B;IACA,IAAIzG,KAAK,YAAY2E,IAAI,EAAE;MACzB,OAAOjG,IAAI,CAACa,KAAK,CAACoF,IAAI;IACxB;IACA,IAAI3E,KAAK,CAACgC,IAAI,IAAIhC,KAAK,CAAC2B,SAAS,EAAE;MACjC,OAAOjD,IAAI,CAACa,KAAK,CAACmC,SAAS;IAC7B;IACA,IAAI1B,KAAK,CAACsC,OAAO,IAAItC,KAAK,CAACsF,aAAa,EAAE;MACxC,OAAO5G,IAAI,CAACa,KAAK,CAAC4F,OAAO;IAC3B;IACA,IAAInF,KAAK,CAACqE,QAAQ,EAAE;MAClB,OAAO3F,IAAI,CAACa,KAAK,CAACkF,QAAQ;IAC5B;IACA,IAAIzE,KAAK,CAACgH,YAAY,EAAE;MACtB,OAAOtI,IAAI,CAACa,KAAK,CAACgH,YAAY;IAChC;IACA,IAAIvG,KAAK,CAAC2G,KAAK,EAAE;MACf,OAAOjI,IAAI,CAACa,KAAK,CAACR,KAAK;IACzB;IACA,OAAOL,IAAI,CAACa,KAAK,CAACsH,IAAI;EACxB,CAAC;EAED;EACAI,KAAK,EAAE,CACL;IAAC1C,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAACC,IAAI;IAAE0H,CAAC,EAAEpD;EAAS,CAAC,EAClC;IAACS,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAAC0E,MAAM;IAAEiD,CAAC,EAAElD;EAAW,CAAC,EACtC;IAACO,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAAC8C,MAAM;IAAE6E,CAAC,EAAEhD;EAAW,CAAC,EACtC;IAACK,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAACoF,IAAI;IAAEuC,CAAC,EAAExC;EAAS,CAAC,EAClC;IAACH,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAACmC,SAAS;IAAEwF,CAAC,EAAErC;EAAc,CAAC,EAC5C;IAACN,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAAC4F,OAAO;IAAE+B,CAAC,EAAEhC;EAAY,CAAC,EACxC;IAACX,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAAC2B,KAAK;IAAEgG,CAAC,EAAElC;EAAU,CAAC,EACpC;IAACT,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAACsH,IAAI;IAAEK,CAAC,EAAEN;EAAS,CAAC,EAClC;IAACrC,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAACgH,YAAY;IAAEW,CAAC,EAAEZ;EAAiB,CAAC,EAClD;IAAC/B,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAACkF,QAAQ;IAAEyC,CAAC,EAAE9C;EAAa,CAAC,EAC1C;IAACG,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAACkH,OAAO;IAAES,CAAC,EAAEV;EAAY,CAAC,EACxC;IAACjC,CAAC,EAAE7F,IAAI,CAACa,KAAK,CAACR,KAAK;IAAEmI,CAAC,EAAER;EAAU,CAAC,CACrC,CAACS,MAAM,CAAC,CAACC,CAAC,EAAE7C,CAAC,KAAK;IACjB6C,CAAC,CAAC7C,CAAC,CAACA,CAAC,CAAC,GAAGA,CAAC,CAAC2C,CAAC;IACZ,OAAOE,CAAC;EACV,CAAC,EAAE,EAAE,CAAC;EAEN9H,MAAMA,CAACsB,IAAI,EAAEmD,IAAI,EAAE/D,KAAK,EAAE;IACxB,MAAMqH,CAAC,GAAG,IAAI,CAACJ,KAAK,CAACrG,IAAI,CAAC;IAC1B,IAAI,CAACyG,CAAC,EAAE;MACN,MAAM,IAAItI,KAAK,CAAC,kCAAkC6B,IAAI,EAAE,CAAC;IAC3D;IACA,OAAO,IAAIyG,CAAC,CAACtD,IAAI,EAAE/D,KAAK,CAAC;EAC3B;AACF,CAAC;AAEDsH,MAAM,CAACC,OAAO,GAAG7I,IAAI","ignoreList":[]}
@@ -70,7 +70,7 @@ function validate(worksheet, model) {
70
70
  const isInHeaderNames = objectFromProps(headerNames, true);
71
71
  for (const name of [...model.rows, ...model.columns, ...model.values]) {
72
72
  if (!isInHeaderNames[name]) {
73
- throw new Error("The header name \"".concat(name, "\" was not found in ").concat(model.sourceSheet.name, "."));
73
+ throw new Error(`The header name "${name}" was not found in ${model.sourceSheet.name}.`);
74
74
  }
75
75
  }
76
76
  if (!model.rows.length) {
@@ -1 +1 @@
1
- {"version":3,"file":"pivot-table.js","names":["objectFromProps","range","toSortedArray","require","makePivotTable","worksheet","model","validate","sourceSheet","rows","columns","values","cacheFields","makeCacheFields","nameToIndex","reduce","result","cacheField","index","name","map","row","column","value","metric","cacheId","workbook","pivotTables","length","Error","headerNames","getRow","slice","isInHeaderNames","concat","fieldNamesWithSharedItems","names","nameToHasSharedItems","aggregate","columnIndex","columnValues","getColumn","splice","columnValuesAsSet","Set","sharedItems","push","module","exports"],"sources":["../../../lib/doc/pivot-table.js"],"sourcesContent":["const {objectFromProps, range, toSortedArray} = require('../utils/utils');\n\n// TK(2023-10-10): turn this into a class constructor.\n\nfunction makePivotTable(worksheet, model) {\n // Example `model`:\n // {\n // // Source of data: the entire sheet range is taken,\n // // akin to `worksheet1.getSheetValues()`.\n // sourceSheet: worksheet1,\n //\n // // Pivot table fields: values indicate field names;\n // // they come from the first row in `worksheet1`.\n // rows: ['A', 'B'],\n // columns: ['C'],\n // values: ['E'], // only 1 item possible for now\n // metric: 'sum', // only 'sum' possible for now\n // }\n\n validate(worksheet, model);\n\n const {sourceSheet} = model;\n let {rows, columns, values} = model;\n\n const cacheFields = makeCacheFields(sourceSheet, [...rows, ...columns]);\n\n // let {rows, columns, values} use indices instead of names;\n // names can then be accessed via `pivotTable.cacheFields[index].name`.\n // *Note*: Using `reduce` as `Object.fromEntries` requires Node 12+;\n // ExcelJS is >=8.3.0 (as of 2023-10-08).\n const nameToIndex = cacheFields.reduce((result, cacheField, index) => {\n result[cacheField.name] = index;\n return result;\n }, {});\n rows = rows.map(row => nameToIndex[row]);\n columns = columns.map(column => nameToIndex[column]);\n values = values.map(value => nameToIndex[value]);\n\n // form pivot table object\n return {\n sourceSheet,\n rows,\n columns,\n values,\n metric: 'sum',\n cacheFields,\n // defined in <pivotTableDefinition> of xl/pivotTables/pivotTable1.xml;\n // also used in xl/workbook.xml\n cacheId: '10',\n };\n}\n\nfunction validate(worksheet, model) {\n if (worksheet.workbook.pivotTables.length === 1) {\n throw new Error(\n 'A pivot table was already added. At this time, ExcelJS supports at most one pivot table per file.'\n );\n }\n\n if (model.metric && model.metric !== 'sum') {\n throw new Error('Only the \"sum\" metric is supported at this time.');\n }\n\n const headerNames = model.sourceSheet.getRow(1).values.slice(1);\n const isInHeaderNames = objectFromProps(headerNames, true);\n for (const name of [...model.rows, ...model.columns, ...model.values]) {\n if (!isInHeaderNames[name]) {\n throw new Error(`The header name \"${name}\" was not found in ${model.sourceSheet.name}.`);\n }\n }\n\n if (!model.rows.length) {\n throw new Error('No pivot table rows specified.');\n }\n\n if (!model.columns.length) {\n throw new Error('No pivot table columns specified.');\n }\n\n if (model.values.length !== 1) {\n throw new Error('Exactly 1 value needs to be specified at this time.');\n }\n}\n\nfunction makeCacheFields(worksheet, fieldNamesWithSharedItems) {\n // Cache fields are used in pivot tables to reference source data.\n //\n // Example\n // -------\n // Turn\n //\n // `worksheet` sheet values [\n // ['A', 'B', 'C', 'D', 'E'],\n // ['a1', 'b1', 'c1', 4, 5],\n // ['a1', 'b2', 'c1', 4, 5],\n // ['a2', 'b1', 'c2', 14, 24],\n // ['a2', 'b2', 'c2', 24, 35],\n // ['a3', 'b1', 'c3', 34, 45],\n // ['a3', 'b2', 'c3', 44, 45]\n // ];\n // fieldNamesWithSharedItems = ['A', 'B', 'C'];\n //\n // into\n //\n // [\n // { name: 'A', sharedItems: ['a1', 'a2', 'a3'] },\n // { name: 'B', sharedItems: ['b1', 'b2'] },\n // { name: 'C', sharedItems: ['c1', 'c2', 'c3'] },\n // { name: 'D', sharedItems: null },\n // { name: 'E', sharedItems: null }\n // ]\n\n const names = worksheet.getRow(1).values;\n const nameToHasSharedItems = objectFromProps(fieldNamesWithSharedItems, true);\n\n const aggregate = columnIndex => {\n const columnValues = worksheet.getColumn(columnIndex).values.splice(2);\n const columnValuesAsSet = new Set(columnValues);\n return toSortedArray(columnValuesAsSet);\n };\n\n // make result\n const result = [];\n for (const columnIndex of range(1, names.length)) {\n const name = names[columnIndex];\n const sharedItems = nameToHasSharedItems[name] ? aggregate(columnIndex) : null;\n result.push({name, sharedItems});\n }\n return result;\n}\n\nmodule.exports = {makePivotTable};\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"pivot-table.js","names":["objectFromProps","range","toSortedArray","require","makePivotTable","worksheet","model","validate","sourceSheet","rows","columns","values","cacheFields","makeCacheFields","nameToIndex","reduce","result","cacheField","index","name","map","row","column","value","metric","cacheId","workbook","pivotTables","length","Error","headerNames","getRow","slice","isInHeaderNames","fieldNamesWithSharedItems","names","nameToHasSharedItems","aggregate","columnIndex","columnValues","getColumn","splice","columnValuesAsSet","Set","sharedItems","push","module","exports"],"sources":["../../../lib/doc/pivot-table.js"],"sourcesContent":["const {objectFromProps, range, toSortedArray} = require('../utils/utils');\n\n// TK(2023-10-10): turn this into a class constructor.\n\nfunction makePivotTable(worksheet, model) {\n // Example `model`:\n // {\n // // Source of data: the entire sheet range is taken,\n // // akin to `worksheet1.getSheetValues()`.\n // sourceSheet: worksheet1,\n //\n // // Pivot table fields: values indicate field names;\n // // they come from the first row in `worksheet1`.\n // rows: ['A', 'B'],\n // columns: ['C'],\n // values: ['E'], // only 1 item possible for now\n // metric: 'sum', // only 'sum' possible for now\n // }\n\n validate(worksheet, model);\n\n const {sourceSheet} = model;\n let {rows, columns, values} = model;\n\n const cacheFields = makeCacheFields(sourceSheet, [...rows, ...columns]);\n\n // let {rows, columns, values} use indices instead of names;\n // names can then be accessed via `pivotTable.cacheFields[index].name`.\n // *Note*: Using `reduce` as `Object.fromEntries` requires Node 12+;\n // ExcelJS is >=8.3.0 (as of 2023-10-08).\n const nameToIndex = cacheFields.reduce((result, cacheField, index) => {\n result[cacheField.name] = index;\n return result;\n }, {});\n rows = rows.map(row => nameToIndex[row]);\n columns = columns.map(column => nameToIndex[column]);\n values = values.map(value => nameToIndex[value]);\n\n // form pivot table object\n return {\n sourceSheet,\n rows,\n columns,\n values,\n metric: 'sum',\n cacheFields,\n // defined in <pivotTableDefinition> of xl/pivotTables/pivotTable1.xml;\n // also used in xl/workbook.xml\n cacheId: '10',\n };\n}\n\nfunction validate(worksheet, model) {\n if (worksheet.workbook.pivotTables.length === 1) {\n throw new Error(\n 'A pivot table was already added. At this time, ExcelJS supports at most one pivot table per file.'\n );\n }\n\n if (model.metric && model.metric !== 'sum') {\n throw new Error('Only the \"sum\" metric is supported at this time.');\n }\n\n const headerNames = model.sourceSheet.getRow(1).values.slice(1);\n const isInHeaderNames = objectFromProps(headerNames, true);\n for (const name of [...model.rows, ...model.columns, ...model.values]) {\n if (!isInHeaderNames[name]) {\n throw new Error(`The header name \"${name}\" was not found in ${model.sourceSheet.name}.`);\n }\n }\n\n if (!model.rows.length) {\n throw new Error('No pivot table rows specified.');\n }\n\n if (!model.columns.length) {\n throw new Error('No pivot table columns specified.');\n }\n\n if (model.values.length !== 1) {\n throw new Error('Exactly 1 value needs to be specified at this time.');\n }\n}\n\nfunction makeCacheFields(worksheet, fieldNamesWithSharedItems) {\n // Cache fields are used in pivot tables to reference source data.\n //\n // Example\n // -------\n // Turn\n //\n // `worksheet` sheet values [\n // ['A', 'B', 'C', 'D', 'E'],\n // ['a1', 'b1', 'c1', 4, 5],\n // ['a1', 'b2', 'c1', 4, 5],\n // ['a2', 'b1', 'c2', 14, 24],\n // ['a2', 'b2', 'c2', 24, 35],\n // ['a3', 'b1', 'c3', 34, 45],\n // ['a3', 'b2', 'c3', 44, 45]\n // ];\n // fieldNamesWithSharedItems = ['A', 'B', 'C'];\n //\n // into\n //\n // [\n // { name: 'A', sharedItems: ['a1', 'a2', 'a3'] },\n // { name: 'B', sharedItems: ['b1', 'b2'] },\n // { name: 'C', sharedItems: ['c1', 'c2', 'c3'] },\n // { name: 'D', sharedItems: null },\n // { name: 'E', sharedItems: null }\n // ]\n\n const names = worksheet.getRow(1).values;\n const nameToHasSharedItems = objectFromProps(fieldNamesWithSharedItems, true);\n\n const aggregate = columnIndex => {\n const columnValues = worksheet.getColumn(columnIndex).values.splice(2);\n const columnValuesAsSet = new Set(columnValues);\n return toSortedArray(columnValuesAsSet);\n };\n\n // make result\n const result = [];\n for (const columnIndex of range(1, names.length)) {\n const name = names[columnIndex];\n const sharedItems = nameToHasSharedItems[name] ? aggregate(columnIndex) : null;\n result.push({name, sharedItems});\n }\n return result;\n}\n\nmodule.exports = {makePivotTable};\n"],"mappings":"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","ignoreList":[]}
@@ -105,7 +105,7 @@ class Range {
105
105
  };
106
106
  break;
107
107
  default:
108
- throw new Error("Invalid number of arguments to _getDimensions() - ".concat(argv.length));
108
+ throw new Error(`Invalid number of arguments to _getDimensions() - ${argv.length}`);
109
109
  }
110
110
  }
111
111
  get top() {
@@ -144,9 +144,9 @@ class Range {
144
144
  } = this.model;
145
145
  if (sheetName) {
146
146
  if (/^[a-zA-Z0-9]*$/.test(sheetName)) {
147
- return "".concat(sheetName, "!");
147
+ return `${sheetName}!`;
148
148
  }
149
- return "'".concat(sheetName, "'!");
149
+ return `'${sheetName}'!`;
150
150
  }
151
151
  return '';
152
152
  }
@@ -175,19 +175,19 @@ class Range {
175
175
  return colCache.n2l(this.left) + this.top;
176
176
  }
177
177
  get $t$l() {
178
- return "$".concat(colCache.n2l(this.left), "$").concat(this.top);
178
+ return `$${colCache.n2l(this.left)}$${this.top}`;
179
179
  }
180
180
  get br() {
181
181
  return colCache.n2l(this.right) + this.bottom;
182
182
  }
183
183
  get $b$r() {
184
- return "$".concat(colCache.n2l(this.right), "$").concat(this.bottom);
184
+ return `$${colCache.n2l(this.right)}$${this.bottom}`;
185
185
  }
186
186
  get range() {
187
- return "".concat(this._serialisedSheetName + this.tl, ":").concat(this.br);
187
+ return `${this._serialisedSheetName + this.tl}:${this.br}`;
188
188
  }
189
189
  get $range() {
190
- return "".concat(this._serialisedSheetName + this.$t$l, ":").concat(this.$b$r);
190
+ return `${this._serialisedSheetName + this.$t$l}:${this.$b$r}`;
191
191
  }
192
192
  get shortRange() {
193
193
  return this.count > 1 ? this.range : this._serialisedSheetName + this.tl;
@@ -1 +1 @@
1
- {"version":3,"file":"range.js","names":["colCache","require","Range","constructor","decode","arguments","setTLBR","t","l","b","r","s","length","tl","decodeAddress","br","model","top","Math","min","row","left","col","bottom","max","right","sheetName","argv","value","Array","tlbr","decodeEx","Error","concat","_serialisedSheetName","test","expand","expandRow","dimensions","number","expandToAddress","addressStr","address","n2l","$t$l","$b$r","range","$range","shortRange","count","$shortRange","toString","intersects","other","contains","containsEx","forEachAddress","cb","encodeAddress","module","exports"],"sources":["../../../lib/doc/range.js"],"sourcesContent":["const colCache = require('../utils/col-cache');\n\n// used by worksheet to calculate sheet dimensions\nclass Range {\n constructor() {\n this.decode(arguments);\n }\n\n setTLBR(t, l, b, r, s) {\n if (arguments.length < 4) {\n // setTLBR(tl, br, s)\n const tl = colCache.decodeAddress(t);\n const br = colCache.decodeAddress(l);\n this.model = {\n top: Math.min(tl.row, br.row),\n left: Math.min(tl.col, br.col),\n bottom: Math.max(tl.row, br.row),\n right: Math.max(tl.col, br.col),\n sheetName: b,\n };\n\n this.setTLBR(tl.row, tl.col, br.row, br.col, s);\n } else {\n // setTLBR(t, l, b, r, s)\n this.model = {\n top: Math.min(t, b),\n left: Math.min(l, r),\n bottom: Math.max(t, b),\n right: Math.max(l, r),\n sheetName: s,\n };\n }\n }\n\n decode(argv) {\n switch (argv.length) {\n case 5: // [t,l,b,r,s]\n this.setTLBR(argv[0], argv[1], argv[2], argv[3], argv[4]);\n break;\n case 4: // [t,l,b,r]\n this.setTLBR(argv[0], argv[1], argv[2], argv[3]);\n break;\n\n case 3: // [tl,br,s]\n this.setTLBR(argv[0], argv[1], argv[2]);\n break;\n case 2: // [tl,br]\n this.setTLBR(argv[0], argv[1]);\n break;\n\n case 1: {\n const value = argv[0];\n if (value instanceof Range) {\n // copy constructor\n this.model = {\n top: value.model.top,\n left: value.model.left,\n bottom: value.model.bottom,\n right: value.model.right,\n sheetName: value.sheetName,\n };\n } else if (value instanceof Array) {\n // an arguments array\n this.decode(value);\n } else if (value.top && value.left && value.bottom && value.right) {\n // a model\n this.model = {\n top: value.top,\n left: value.left,\n bottom: value.bottom,\n right: value.right,\n sheetName: value.sheetName,\n };\n } else {\n // [sheetName!]tl:br\n const tlbr = colCache.decodeEx(value);\n if (tlbr.top) {\n this.model = {\n top: tlbr.top,\n left: tlbr.left,\n bottom: tlbr.bottom,\n right: tlbr.right,\n sheetName: tlbr.sheetName,\n };\n } else {\n this.model = {\n top: tlbr.row,\n left: tlbr.col,\n bottom: tlbr.row,\n right: tlbr.col,\n sheetName: tlbr.sheetName,\n };\n }\n }\n break;\n }\n\n case 0:\n this.model = {\n top: 0,\n left: 0,\n bottom: 0,\n right: 0,\n };\n break;\n\n default:\n throw new Error(`Invalid number of arguments to _getDimensions() - ${argv.length}`);\n }\n }\n\n get top() {\n return this.model.top || 1;\n }\n\n set top(value) {\n this.model.top = value;\n }\n\n get left() {\n return this.model.left || 1;\n }\n\n set left(value) {\n this.model.left = value;\n }\n\n get bottom() {\n return this.model.bottom || 1;\n }\n\n set bottom(value) {\n this.model.bottom = value;\n }\n\n get right() {\n return this.model.right || 1;\n }\n\n set right(value) {\n this.model.right = value;\n }\n\n get sheetName() {\n return this.model.sheetName;\n }\n\n set sheetName(value) {\n this.model.sheetName = value;\n }\n\n get _serialisedSheetName() {\n const {sheetName} = this.model;\n if (sheetName) {\n if (/^[a-zA-Z0-9]*$/.test(sheetName)) {\n return `${sheetName}!`;\n }\n return `'${sheetName}'!`;\n }\n return '';\n }\n\n expand(top, left, bottom, right) {\n if (!this.model.top || top < this.top) this.top = top;\n if (!this.model.left || left < this.left) this.left = left;\n if (!this.model.bottom || bottom > this.bottom) this.bottom = bottom;\n if (!this.model.right || right > this.right) this.right = right;\n }\n\n expandRow(row) {\n if (row) {\n const {dimensions, number} = row;\n if (dimensions) {\n this.expand(number, dimensions.min, number, dimensions.max);\n }\n }\n }\n\n expandToAddress(addressStr) {\n const address = colCache.decodeEx(addressStr);\n this.expand(address.row, address.col, address.row, address.col);\n }\n\n get tl() {\n return colCache.n2l(this.left) + this.top;\n }\n\n get $t$l() {\n return `$${colCache.n2l(this.left)}$${this.top}`;\n }\n\n get br() {\n return colCache.n2l(this.right) + this.bottom;\n }\n\n get $b$r() {\n return `$${colCache.n2l(this.right)}$${this.bottom}`;\n }\n\n get range() {\n return `${this._serialisedSheetName + this.tl}:${this.br}`;\n }\n\n get $range() {\n return `${this._serialisedSheetName + this.$t$l}:${this.$b$r}`;\n }\n\n get shortRange() {\n return this.count > 1 ? this.range : this._serialisedSheetName + this.tl;\n }\n\n get $shortRange() {\n return this.count > 1 ? this.$range : this._serialisedSheetName + this.$t$l;\n }\n\n get count() {\n return (1 + this.bottom - this.top) * (1 + this.right - this.left);\n }\n\n toString() {\n return this.range;\n }\n\n intersects(other) {\n if (other.sheetName && this.sheetName && other.sheetName !== this.sheetName) return false;\n if (other.bottom < this.top) return false;\n if (other.top > this.bottom) return false;\n if (other.right < this.left) return false;\n if (other.left > this.right) return false;\n return true;\n }\n\n contains(addressStr) {\n const address = colCache.decodeEx(addressStr);\n return this.containsEx(address);\n }\n\n containsEx(address) {\n if (address.sheetName && this.sheetName && address.sheetName !== this.sheetName) return false;\n return (\n address.row >= this.top &&\n address.row <= this.bottom &&\n address.col >= this.left &&\n address.col <= this.right\n );\n }\n\n forEachAddress(cb) {\n for (let col = this.left; col <= this.right; col++) {\n for (let row = this.top; row <= this.bottom; row++) {\n cb(colCache.encodeAddress(row, col), row, col);\n }\n }\n }\n}\n\nmodule.exports = Range;\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"range.js","names":["colCache","require","Range","constructor","decode","arguments","setTLBR","t","l","b","r","s","length","tl","decodeAddress","br","model","top","Math","min","row","left","col","bottom","max","right","sheetName","argv","value","Array","tlbr","decodeEx","Error","_serialisedSheetName","test","expand","expandRow","dimensions","number","expandToAddress","addressStr","address","n2l","$t$l","$b$r","range","$range","shortRange","count","$shortRange","toString","intersects","other","contains","containsEx","forEachAddress","cb","encodeAddress","module","exports"],"sources":["../../../lib/doc/range.js"],"sourcesContent":["const colCache = require('../utils/col-cache');\n\n// used by worksheet to calculate sheet dimensions\nclass Range {\n constructor() {\n this.decode(arguments);\n }\n\n setTLBR(t, l, b, r, s) {\n if (arguments.length < 4) {\n // setTLBR(tl, br, s)\n const tl = colCache.decodeAddress(t);\n const br = colCache.decodeAddress(l);\n this.model = {\n top: Math.min(tl.row, br.row),\n left: Math.min(tl.col, br.col),\n bottom: Math.max(tl.row, br.row),\n right: Math.max(tl.col, br.col),\n sheetName: b,\n };\n\n this.setTLBR(tl.row, tl.col, br.row, br.col, s);\n } else {\n // setTLBR(t, l, b, r, s)\n this.model = {\n top: Math.min(t, b),\n left: Math.min(l, r),\n bottom: Math.max(t, b),\n right: Math.max(l, r),\n sheetName: s,\n };\n }\n }\n\n decode(argv) {\n switch (argv.length) {\n case 5: // [t,l,b,r,s]\n this.setTLBR(argv[0], argv[1], argv[2], argv[3], argv[4]);\n break;\n case 4: // [t,l,b,r]\n this.setTLBR(argv[0], argv[1], argv[2], argv[3]);\n break;\n\n case 3: // [tl,br,s]\n this.setTLBR(argv[0], argv[1], argv[2]);\n break;\n case 2: // [tl,br]\n this.setTLBR(argv[0], argv[1]);\n break;\n\n case 1: {\n const value = argv[0];\n if (value instanceof Range) {\n // copy constructor\n this.model = {\n top: value.model.top,\n left: value.model.left,\n bottom: value.model.bottom,\n right: value.model.right,\n sheetName: value.sheetName,\n };\n } else if (value instanceof Array) {\n // an arguments array\n this.decode(value);\n } else if (value.top && value.left && value.bottom && value.right) {\n // a model\n this.model = {\n top: value.top,\n left: value.left,\n bottom: value.bottom,\n right: value.right,\n sheetName: value.sheetName,\n };\n } else {\n // [sheetName!]tl:br\n const tlbr = colCache.decodeEx(value);\n if (tlbr.top) {\n this.model = {\n top: tlbr.top,\n left: tlbr.left,\n bottom: tlbr.bottom,\n right: tlbr.right,\n sheetName: tlbr.sheetName,\n };\n } else {\n this.model = {\n top: tlbr.row,\n left: tlbr.col,\n bottom: tlbr.row,\n right: tlbr.col,\n sheetName: tlbr.sheetName,\n };\n }\n }\n break;\n }\n\n case 0:\n this.model = {\n top: 0,\n left: 0,\n bottom: 0,\n right: 0,\n };\n break;\n\n default:\n throw new Error(`Invalid number of arguments to _getDimensions() - ${argv.length}`);\n }\n }\n\n get top() {\n return this.model.top || 1;\n }\n\n set top(value) {\n this.model.top = value;\n }\n\n get left() {\n return this.model.left || 1;\n }\n\n set left(value) {\n this.model.left = value;\n }\n\n get bottom() {\n return this.model.bottom || 1;\n }\n\n set bottom(value) {\n this.model.bottom = value;\n }\n\n get right() {\n return this.model.right || 1;\n }\n\n set right(value) {\n this.model.right = value;\n }\n\n get sheetName() {\n return this.model.sheetName;\n }\n\n set sheetName(value) {\n this.model.sheetName = value;\n }\n\n get _serialisedSheetName() {\n const {sheetName} = this.model;\n if (sheetName) {\n if (/^[a-zA-Z0-9]*$/.test(sheetName)) {\n return `${sheetName}!`;\n }\n return `'${sheetName}'!`;\n }\n return '';\n }\n\n expand(top, left, bottom, right) {\n if (!this.model.top || top < this.top) this.top = top;\n if (!this.model.left || left < this.left) this.left = left;\n if (!this.model.bottom || bottom > this.bottom) this.bottom = bottom;\n if (!this.model.right || right > this.right) this.right = right;\n }\n\n expandRow(row) {\n if (row) {\n const {dimensions, number} = row;\n if (dimensions) {\n this.expand(number, dimensions.min, number, dimensions.max);\n }\n }\n }\n\n expandToAddress(addressStr) {\n const address = colCache.decodeEx(addressStr);\n this.expand(address.row, address.col, address.row, address.col);\n }\n\n get tl() {\n return colCache.n2l(this.left) + this.top;\n }\n\n get $t$l() {\n return `$${colCache.n2l(this.left)}$${this.top}`;\n }\n\n get br() {\n return colCache.n2l(this.right) + this.bottom;\n }\n\n get $b$r() {\n return `$${colCache.n2l(this.right)}$${this.bottom}`;\n }\n\n get range() {\n return `${this._serialisedSheetName + this.tl}:${this.br}`;\n }\n\n get $range() {\n return `${this._serialisedSheetName + this.$t$l}:${this.$b$r}`;\n }\n\n get shortRange() {\n return this.count > 1 ? this.range : this._serialisedSheetName + this.tl;\n }\n\n get $shortRange() {\n return this.count > 1 ? this.$range : this._serialisedSheetName + this.$t$l;\n }\n\n get count() {\n return (1 + this.bottom - this.top) * (1 + this.right - this.left);\n }\n\n toString() {\n return this.range;\n }\n\n intersects(other) {\n if (other.sheetName && this.sheetName && other.sheetName !== this.sheetName) return false;\n if (other.bottom < this.top) return false;\n if (other.top > this.bottom) return false;\n if (other.right < this.left) return false;\n if (other.left > this.right) return false;\n return true;\n }\n\n contains(addressStr) {\n const address = colCache.decodeEx(addressStr);\n return this.containsEx(address);\n }\n\n containsEx(address) {\n if (address.sheetName && this.sheetName && address.sheetName !== this.sheetName) return false;\n return (\n address.row >= this.top &&\n address.row <= this.bottom &&\n address.col >= this.left &&\n address.col <= this.right\n );\n }\n\n forEachAddress(cb) {\n for (let col = this.left; col <= this.right; col++) {\n for (let row = this.top; row <= this.bottom; row++) {\n cb(colCache.encodeAddress(row, col), row, col);\n }\n }\n }\n}\n\nmodule.exports = Range;\n"],"mappings":"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","ignoreList":[]}
@@ -358,7 +358,7 @@ class Row {
358
358
  row,
359
359
  col,
360
360
  address: colCache.encodeAddress(row, col),
361
- $col$row: "$".concat(colCache.n2l(col), "$").concat(row)
361
+ $col$row: `$${colCache.n2l(col)}$${row}`
362
362
  };
363
363
  }
364
364
  previousAddress = address;