@gridsheet/react-core 1.4.0-alpha.2 → 1.4.0-alpha.3

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 (235) hide show
  1. package/dist/_virtual/_commonjsHelpers.js +7 -0
  2. package/dist/_virtual/_commonjsHelpers.js.map +1 -0
  3. package/dist/_virtual/dayjs.min.js +8 -0
  4. package/dist/_virtual/dayjs.min.js.map +1 -0
  5. package/dist/_virtual/dayjs.min2.js +5 -0
  6. package/dist/_virtual/dayjs.min2.js.map +1 -0
  7. package/dist/_virtual/jsx-runtime.js +6 -0
  8. package/dist/_virtual/jsx-runtime.js.map +1 -0
  9. package/dist/_virtual/jsx-runtime2.js +5 -0
  10. package/dist/_virtual/jsx-runtime2.js.map +1 -0
  11. package/dist/_virtual/react-jsx-runtime.development.js +5 -0
  12. package/dist/_virtual/react-jsx-runtime.development.js.map +1 -0
  13. package/dist/_virtual/react-jsx-runtime.production.js +5 -0
  14. package/dist/_virtual/react-jsx-runtime.production.js.map +1 -0
  15. package/dist/_virtual/timezone.js +8 -0
  16. package/dist/_virtual/timezone.js.map +1 -0
  17. package/dist/_virtual/timezone2.js +5 -0
  18. package/dist/_virtual/timezone2.js.map +1 -0
  19. package/dist/_virtual/utc.js +8 -0
  20. package/dist/_virtual/utc.js.map +1 -0
  21. package/dist/_virtual/utc2.js +5 -0
  22. package/dist/_virtual/utc2.js.map +1 -0
  23. package/dist/components/Cell.js +232 -0
  24. package/dist/components/Cell.js.map +1 -0
  25. package/dist/components/ContextMenu.js +297 -0
  26. package/dist/components/ContextMenu.js.map +1 -0
  27. package/dist/components/Editor.js +455 -0
  28. package/dist/components/Editor.js.map +1 -0
  29. package/dist/components/Emitter.js +26 -0
  30. package/dist/components/Emitter.js.map +1 -0
  31. package/dist/components/Fixed.js +17 -0
  32. package/dist/components/Fixed.js.map +1 -0
  33. package/dist/components/FormulaBar.js +149 -0
  34. package/dist/components/FormulaBar.js.map +1 -0
  35. package/dist/components/GridSheet.js +246 -0
  36. package/dist/components/GridSheet.js.map +1 -0
  37. package/dist/components/HeaderCellLeft.js +131 -0
  38. package/dist/components/HeaderCellLeft.js.map +1 -0
  39. package/dist/components/HeaderCellTop.js +132 -0
  40. package/dist/components/HeaderCellTop.js.map +1 -0
  41. package/dist/components/PluginBase.js +35 -0
  42. package/dist/components/PluginBase.js.map +1 -0
  43. package/dist/components/Resizer.js +98 -0
  44. package/dist/components/Resizer.js.map +1 -0
  45. package/dist/components/SearchBar.js +108 -0
  46. package/dist/components/SearchBar.js.map +1 -0
  47. package/dist/components/SheetProvider.js +56 -0
  48. package/dist/components/SheetProvider.js.map +1 -0
  49. package/dist/components/StoreInitializer.js +84 -0
  50. package/dist/components/StoreInitializer.js.map +1 -0
  51. package/dist/components/Tabular.js +308 -0
  52. package/dist/components/Tabular.js.map +1 -0
  53. package/dist/components/hooks.js +15 -0
  54. package/dist/components/hooks.js.map +1 -0
  55. package/dist/components/svg/Base.js +24 -0
  56. package/dist/components/svg/Base.js.map +1 -0
  57. package/dist/components/svg/CloseIcon.js +13 -0
  58. package/dist/components/svg/CloseIcon.js.map +1 -0
  59. package/dist/components/svg/SearchIcon.js +13 -0
  60. package/dist/components/svg/SearchIcon.js.map +1 -0
  61. package/dist/constants.js +43 -0
  62. package/dist/constants.js.map +1 -0
  63. package/dist/formula/evaluator.js +674 -0
  64. package/dist/formula/evaluator.js.map +1 -0
  65. package/dist/formula/functions/__base.js +19 -0
  66. package/dist/formula/functions/__base.js.map +1 -0
  67. package/dist/formula/functions/__utils.js +145 -0
  68. package/dist/formula/functions/__utils.js.map +1 -0
  69. package/dist/formula/functions/abs.js +24 -0
  70. package/dist/formula/functions/abs.js.map +1 -0
  71. package/dist/formula/functions/acos.js +32 -0
  72. package/dist/formula/functions/acos.js.map +1 -0
  73. package/dist/formula/functions/add.js +57 -0
  74. package/dist/formula/functions/add.js.map +1 -0
  75. package/dist/formula/functions/and.js +28 -0
  76. package/dist/formula/functions/and.js.map +1 -0
  77. package/dist/formula/functions/asin.js +32 -0
  78. package/dist/formula/functions/asin.js.map +1 -0
  79. package/dist/formula/functions/atan.js +29 -0
  80. package/dist/formula/functions/atan.js.map +1 -0
  81. package/dist/formula/functions/atan2.js +35 -0
  82. package/dist/formula/functions/atan2.js.map +1 -0
  83. package/dist/formula/functions/average.js +44 -0
  84. package/dist/formula/functions/average.js.map +1 -0
  85. package/dist/formula/functions/col.js +31 -0
  86. package/dist/formula/functions/col.js.map +1 -0
  87. package/dist/formula/functions/concat.js +27 -0
  88. package/dist/formula/functions/concat.js.map +1 -0
  89. package/dist/formula/functions/concatenate.js +28 -0
  90. package/dist/formula/functions/concatenate.js.map +1 -0
  91. package/dist/formula/functions/cos.js +29 -0
  92. package/dist/formula/functions/cos.js.map +1 -0
  93. package/dist/formula/functions/count.js +38 -0
  94. package/dist/formula/functions/count.js.map +1 -0
  95. package/dist/formula/functions/counta.js +38 -0
  96. package/dist/formula/functions/counta.js.map +1 -0
  97. package/dist/formula/functions/countif.js +32 -0
  98. package/dist/formula/functions/countif.js.map +1 -0
  99. package/dist/formula/functions/divide.js +33 -0
  100. package/dist/formula/functions/divide.js.map +1 -0
  101. package/dist/formula/functions/eq.js +29 -0
  102. package/dist/formula/functions/eq.js.map +1 -0
  103. package/dist/formula/functions/exp.js +29 -0
  104. package/dist/formula/functions/exp.js.map +1 -0
  105. package/dist/formula/functions/gt.js +29 -0
  106. package/dist/formula/functions/gt.js.map +1 -0
  107. package/dist/formula/functions/gte.js +29 -0
  108. package/dist/formula/functions/gte.js.map +1 -0
  109. package/dist/formula/functions/hlookup.js +75 -0
  110. package/dist/formula/functions/hlookup.js.map +1 -0
  111. package/dist/formula/functions/if.js +39 -0
  112. package/dist/formula/functions/if.js.map +1 -0
  113. package/dist/formula/functions/iferror.js +45 -0
  114. package/dist/formula/functions/iferror.js.map +1 -0
  115. package/dist/formula/functions/len.js +29 -0
  116. package/dist/formula/functions/len.js.map +1 -0
  117. package/dist/formula/functions/lenb.js +29 -0
  118. package/dist/formula/functions/lenb.js.map +1 -0
  119. package/dist/formula/functions/ln.js +32 -0
  120. package/dist/formula/functions/ln.js.map +1 -0
  121. package/dist/formula/functions/log.js +36 -0
  122. package/dist/formula/functions/log.js.map +1 -0
  123. package/dist/formula/functions/log10.js +32 -0
  124. package/dist/formula/functions/log10.js.map +1 -0
  125. package/dist/formula/functions/lt.js +29 -0
  126. package/dist/formula/functions/lt.js.map +1 -0
  127. package/dist/formula/functions/lte.js +29 -0
  128. package/dist/formula/functions/lte.js.map +1 -0
  129. package/dist/formula/functions/max.js +47 -0
  130. package/dist/formula/functions/max.js.map +1 -0
  131. package/dist/formula/functions/min.js +47 -0
  132. package/dist/formula/functions/min.js.map +1 -0
  133. package/dist/formula/functions/minus.js +57 -0
  134. package/dist/formula/functions/minus.js.map +1 -0
  135. package/dist/formula/functions/mod.js +33 -0
  136. package/dist/formula/functions/mod.js.map +1 -0
  137. package/dist/formula/functions/multiply.js +27 -0
  138. package/dist/formula/functions/multiply.js.map +1 -0
  139. package/dist/formula/functions/ne.js +29 -0
  140. package/dist/formula/functions/ne.js.map +1 -0
  141. package/dist/formula/functions/not.js +30 -0
  142. package/dist/formula/functions/not.js.map +1 -0
  143. package/dist/formula/functions/now.js +22 -0
  144. package/dist/formula/functions/now.js.map +1 -0
  145. package/dist/formula/functions/or.js +28 -0
  146. package/dist/formula/functions/or.js.map +1 -0
  147. package/dist/formula/functions/pi.js +22 -0
  148. package/dist/formula/functions/pi.js.map +1 -0
  149. package/dist/formula/functions/power.js +27 -0
  150. package/dist/formula/functions/power.js.map +1 -0
  151. package/dist/formula/functions/product.js +40 -0
  152. package/dist/formula/functions/product.js.map +1 -0
  153. package/dist/formula/functions/radians.js +29 -0
  154. package/dist/formula/functions/radians.js.map +1 -0
  155. package/dist/formula/functions/rand.js +22 -0
  156. package/dist/formula/functions/rand.js.map +1 -0
  157. package/dist/formula/functions/round.js +35 -0
  158. package/dist/formula/functions/round.js.map +1 -0
  159. package/dist/formula/functions/rounddown.js +35 -0
  160. package/dist/formula/functions/rounddown.js.map +1 -0
  161. package/dist/formula/functions/roundup.js +35 -0
  162. package/dist/formula/functions/roundup.js.map +1 -0
  163. package/dist/formula/functions/row.js +31 -0
  164. package/dist/formula/functions/row.js.map +1 -0
  165. package/dist/formula/functions/sin.js +29 -0
  166. package/dist/formula/functions/sin.js.map +1 -0
  167. package/dist/formula/functions/sqrt.js +32 -0
  168. package/dist/formula/functions/sqrt.js.map +1 -0
  169. package/dist/formula/functions/sum.js +47 -0
  170. package/dist/formula/functions/sum.js.map +1 -0
  171. package/dist/formula/functions/sumif.js +65 -0
  172. package/dist/formula/functions/sumif.js.map +1 -0
  173. package/dist/formula/functions/tan.js +29 -0
  174. package/dist/formula/functions/tan.js.map +1 -0
  175. package/dist/formula/functions/uminus.js +24 -0
  176. package/dist/formula/functions/uminus.js.map +1 -0
  177. package/dist/formula/functions/vlookup.js +75 -0
  178. package/dist/formula/functions/vlookup.js.map +1 -0
  179. package/dist/formula/mapping.js +118 -0
  180. package/dist/formula/mapping.js.map +1 -0
  181. package/dist/formula/solver.js +70 -0
  182. package/dist/formula/solver.js.map +1 -0
  183. package/dist/index.js +16 -9113
  184. package/dist/index.js.map +1 -1
  185. package/dist/lib/autofill.js +391 -0
  186. package/dist/lib/autofill.js.map +1 -0
  187. package/dist/lib/clipboard.js +46 -0
  188. package/dist/lib/clipboard.js.map +1 -0
  189. package/dist/lib/converters.js +141 -0
  190. package/dist/lib/converters.js.map +1 -0
  191. package/dist/lib/input.js +52 -0
  192. package/dist/lib/input.js.map +1 -0
  193. package/dist/lib/palette.js +24 -0
  194. package/dist/lib/palette.js.map +1 -0
  195. package/dist/lib/prevention.js +82 -0
  196. package/dist/lib/prevention.js.map +1 -0
  197. package/dist/lib/structs.js +276 -0
  198. package/dist/lib/structs.js.map +1 -0
  199. package/dist/lib/table.js +1248 -0
  200. package/dist/lib/table.js.map +1 -0
  201. package/dist/lib/time.js +79 -0
  202. package/dist/lib/time.js.map +1 -0
  203. package/dist/lib/virtualization.js +129 -0
  204. package/dist/lib/virtualization.js.map +1 -0
  205. package/dist/node_modules/.pnpm/dayjs@1.11.13/node_modules/dayjs/dayjs.min.js +287 -0
  206. package/dist/node_modules/.pnpm/dayjs@1.11.13/node_modules/dayjs/dayjs.min.js.map +1 -0
  207. package/dist/node_modules/.pnpm/dayjs@1.11.13/node_modules/dayjs/plugin/timezone.js +72 -0
  208. package/dist/node_modules/.pnpm/dayjs@1.11.13/node_modules/dayjs/plugin/timezone.js.map +1 -0
  209. package/dist/node_modules/.pnpm/dayjs@1.11.13/node_modules/dayjs/plugin/utc.js +85 -0
  210. package/dist/node_modules/.pnpm/dayjs@1.11.13/node_modules/dayjs/plugin/utc.js.map +1 -0
  211. package/dist/node_modules/.pnpm/react@19.0.0/node_modules/react/cjs/react-jsx-runtime.development.js +454 -0
  212. package/dist/node_modules/.pnpm/react@19.0.0/node_modules/react/cjs/react-jsx-runtime.development.js.map +1 -0
  213. package/dist/node_modules/.pnpm/react@19.0.0/node_modules/react/cjs/react-jsx-runtime.production.js +42 -0
  214. package/dist/node_modules/.pnpm/react@19.0.0/node_modules/react/cjs/react-jsx-runtime.production.js.map +1 -0
  215. package/dist/node_modules/.pnpm/react@19.0.0/node_modules/react/jsx-runtime.js +18 -0
  216. package/dist/node_modules/.pnpm/react@19.0.0/node_modules/react/jsx-runtime.js.map +1 -0
  217. package/dist/parsers/core.js +139 -0
  218. package/dist/parsers/core.js.map +1 -0
  219. package/dist/renderers/checkbox.js +20 -0
  220. package/dist/renderers/checkbox.js.map +1 -0
  221. package/dist/renderers/core.js +147 -0
  222. package/dist/renderers/core.js.map +1 -0
  223. package/dist/renderers/thousand_separator.js +17 -0
  224. package/dist/renderers/thousand_separator.js.map +1 -0
  225. package/dist/store/actions.js +762 -0
  226. package/dist/store/actions.js.map +1 -0
  227. package/dist/store/helpers.js +88 -0
  228. package/dist/store/helpers.js.map +1 -0
  229. package/dist/store/index.js +8 -0
  230. package/dist/store/index.js.map +1 -0
  231. package/dist/styles/embedder.js +19 -0
  232. package/dist/styles/embedder.js.map +1 -0
  233. package/dist/styles/minified.js +7 -0
  234. package/dist/styles/minified.js.map +1 -0
  235. package/package.json +1 -7
@@ -0,0 +1,52 @@
1
+ import { Lexer } from "../formula/evaluator.js";
2
+ const insertTextAtCursor = (input, text) => {
3
+ var _a;
4
+ input.focus();
5
+ const deprecated = !((_a = document.execCommand) == null ? void 0 : _a.call(document, "insertText", false, text));
6
+ if (!deprecated) {
7
+ return;
8
+ }
9
+ input.setRangeText(text, input.selectionStart, input.selectionEnd, "end");
10
+ return;
11
+ };
12
+ const insertRef = (input, ref, dryRun = false) => {
13
+ var _a;
14
+ if (!((_a = input == null ? void 0 : input.value) == null ? void 0 : _a.startsWith("=")) || input.selectionStart === 0) {
15
+ return false;
16
+ }
17
+ const lexer = new Lexer(input.value.substring(1));
18
+ lexer.tokenize();
19
+ const tokenIndex = lexer.getTokenIndexByCharPosition(input.selectionStart - 1);
20
+ let token = lexer.tokens[tokenIndex];
21
+ if ((token == null ? void 0 : token.type) === "SPACE") {
22
+ token = lexer.tokens[tokenIndex - 1];
23
+ }
24
+ if (token == null || token.type === "OPEN" || token.type === "COMMA" || token.type === "INFIX_OPERATOR" || token.type === "PREFIX_OPERATOR") {
25
+ if (!dryRun) {
26
+ insertTextAtCursor(input, ref);
27
+ }
28
+ } else if (token.type === "REF" || token.type === "RANGE") {
29
+ if (!dryRun) {
30
+ const [start, end] = lexer.getTokenPositionRange(tokenIndex + 1, 1);
31
+ input.setSelectionRange(start, end);
32
+ insertTextAtCursor(input, ref);
33
+ }
34
+ } else {
35
+ return false;
36
+ }
37
+ return true;
38
+ };
39
+ const isRefInsertable = (input) => {
40
+ return insertRef(input, "", true);
41
+ };
42
+ const expandInput = (input) => {
43
+ input.style.width = `${input.scrollWidth}px`;
44
+ input.style.height = `${input.scrollHeight}px`;
45
+ };
46
+ export {
47
+ expandInput,
48
+ insertRef,
49
+ insertTextAtCursor,
50
+ isRefInsertable
51
+ };
52
+ //# sourceMappingURL=input.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"input.js","sources":["../../lib/input.ts"],"sourcesContent":["import { Lexer } from '../formula/evaluator';\n\nexport const insertTextAtCursor = (input: HTMLTextAreaElement, text: string) => {\n input.focus();\n const deprecated = !document.execCommand?.('insertText', false, text);\n if (!deprecated) {\n return;\n }\n input.setRangeText(text, input.selectionStart, input.selectionEnd, 'end');\n return;\n};\n\nexport const insertRef = (input: HTMLTextAreaElement | null, ref: string, dryRun = false): boolean => {\n // dryRun is used to check if the ref can be inserted without actually inserting it\n if (!input?.value?.startsWith('=') || input.selectionStart === 0) {\n return false;\n }\n const lexer = new Lexer(input.value.substring(1));\n lexer.tokenize();\n const tokenIndex = lexer.getTokenIndexByCharPosition(input.selectionStart - 1);\n let token = lexer.tokens[tokenIndex];\n if (token?.type === 'SPACE') {\n token = lexer.tokens[tokenIndex - 1];\n }\n if (\n token == null ||\n token.type === 'OPEN' ||\n token.type === 'COMMA' ||\n token.type === 'INFIX_OPERATOR' ||\n token.type === 'PREFIX_OPERATOR'\n ) {\n if (!dryRun) {\n insertTextAtCursor(input, ref);\n }\n } else if (token.type === 'REF' || token.type === 'RANGE') {\n if (!dryRun) {\n const [start, end] = lexer.getTokenPositionRange(tokenIndex + 1, 1);\n input.setSelectionRange(start, end);\n insertTextAtCursor(input, ref);\n }\n } else {\n return false;\n }\n return true;\n};\n\nexport const isRefInsertable = (input: HTMLTextAreaElement | null): boolean => {\n return insertRef(input, '', true);\n};\n\nexport const expandInput = (input: HTMLTextAreaElement) => {\n input.style.width = `${input.scrollWidth}px`;\n input.style.height = `${input.scrollHeight}px`;\n};\n"],"names":[],"mappings":";AAEa,MAAA,qBAAqB,CAAC,OAA4B,SAAiB;;AAC9E,QAAM,MAAM;AACZ,QAAM,aAAa,GAAC,cAAS,gBAAT,kCAAuB,cAAc,OAAO;AAChE,MAAI,CAAC,YAAY;AACf;AAAA,EAAA;AAEF,QAAM,aAAa,MAAM,MAAM,gBAAgB,MAAM,cAAc,KAAK;AACxE;AACF;AAEO,MAAM,YAAY,CAAC,OAAmC,KAAa,SAAS,UAAmB;;AAEhG,MAAA,GAAC,oCAAO,UAAP,mBAAc,WAAW,SAAQ,MAAM,mBAAmB,GAAG;AACzD,WAAA;AAAA,EAAA;AAET,QAAM,QAAQ,IAAI,MAAM,MAAM,MAAM,UAAU,CAAC,CAAC;AAChD,QAAM,SAAS;AACf,QAAM,aAAa,MAAM,4BAA4B,MAAM,iBAAiB,CAAC;AACzE,MAAA,QAAQ,MAAM,OAAO,UAAU;AAC/B,OAAA,+BAAO,UAAS,SAAS;AACnB,YAAA,MAAM,OAAO,aAAa,CAAC;AAAA,EAAA;AAErC,MACE,SAAS,QACT,MAAM,SAAS,UACf,MAAM,SAAS,WACf,MAAM,SAAS,oBACf,MAAM,SAAS,mBACf;AACA,QAAI,CAAC,QAAQ;AACX,yBAAmB,OAAO,GAAG;AAAA,IAAA;AAAA,EAC/B,WACS,MAAM,SAAS,SAAS,MAAM,SAAS,SAAS;AACzD,QAAI,CAAC,QAAQ;AACL,YAAA,CAAC,OAAO,GAAG,IAAI,MAAM,sBAAsB,aAAa,GAAG,CAAC;AAC5D,YAAA,kBAAkB,OAAO,GAAG;AAClC,yBAAmB,OAAO,GAAG;AAAA,IAAA;AAAA,EAC/B,OACK;AACE,WAAA;AAAA,EAAA;AAEF,SAAA;AACT;AAEa,MAAA,kBAAkB,CAAC,UAA+C;AACtE,SAAA,UAAU,OAAO,IAAI,IAAI;AAClC;AAEa,MAAA,cAAc,CAAC,UAA+B;AACzD,QAAM,MAAM,QAAQ,GAAG,MAAM,WAAW;AACxC,QAAM,MAAM,SAAS,GAAG,MAAM,YAAY;AAC5C;"}
@@ -0,0 +1,24 @@
1
+ const REF_PALETTE = [
2
+ // orange
3
+ "#FF6600",
4
+ // purple
5
+ "#AA44FF",
6
+ // emeraldblue
7
+ "#00CCCC",
8
+ // peach
9
+ "#EEAAEE",
10
+ // yellow
11
+ "#DDDD00",
12
+ // winered
13
+ "#AA4444",
14
+ // lightgreen
15
+ "#00FF00",
16
+ // pink
17
+ "#FF00FF",
18
+ // navy
19
+ "#3366FF"
20
+ ];
21
+ export {
22
+ REF_PALETTE
23
+ };
24
+ //# sourceMappingURL=palette.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"palette.js","sources":["../../lib/palette.ts"],"sourcesContent":["export const REF_PALETTE = [\n // orange\n '#FF6600',\n // purple\n '#AA44FF',\n // emeraldblue\n '#00CCCC',\n // peach\n '#EEAAEE',\n // yellow\n '#DDDD00',\n // winered\n '#AA4444',\n // lightgreen\n '#00FF00',\n // pink\n '#FF00FF',\n // navy\n '#3366FF',\n];\n"],"names":[],"mappings":"AAAO,MAAM,cAAc;AAAA;AAAA,EAEzB;AAAA;AAAA,EAEA;AAAA;AAAA,EAEA;AAAA;AAAA,EAEA;AAAA;AAAA,EAEA;AAAA;AAAA,EAEA;AAAA;AAAA,EAEA;AAAA;AAAA,EAEA;AAAA;AAAA,EAEA;AACF;"}
@@ -0,0 +1,82 @@
1
+ const DeleteRow = 1, DeleteCol = 2, AddRowAbove = 4, AddRowBelow = 8, AddColLeft = 16, AddColRight = 32, MoveFrom = 64, MoveTo = 128, Write = 256, Style = 512, Resize = 1024, SetRenderer = 2048, SetParser = 4096;
2
+ const Move = MoveFrom | MoveTo;
3
+ const Update = Write | Style | Resize | SetRenderer | SetParser;
4
+ const AddRow = AddRowAbove | AddRowBelow;
5
+ const AddCol = AddColLeft | AddColRight;
6
+ const Add = AddRow | AddCol;
7
+ const Delete = DeleteRow | DeleteCol;
8
+ const ReadOnly = Update | Delete | Add | Move;
9
+ const isPrevented = (prevention, flag) => {
10
+ if (prevention === void 0) {
11
+ return false;
12
+ }
13
+ return (prevention & flag) === flag;
14
+ };
15
+ const debugOperations = (prevention) => {
16
+ const preventions = [];
17
+ if (isPrevented(prevention, DeleteRow)) {
18
+ preventions.push("DeleteRow");
19
+ }
20
+ if (isPrevented(prevention, DeleteCol)) {
21
+ preventions.push("DeleteCol");
22
+ }
23
+ if (isPrevented(prevention, AddRowAbove)) {
24
+ preventions.push("AddRowAbove");
25
+ }
26
+ if (isPrevented(prevention, AddRowBelow)) {
27
+ preventions.push("AddRowBelow");
28
+ }
29
+ if (isPrevented(prevention, AddColLeft)) {
30
+ preventions.push("AddColLeft");
31
+ }
32
+ if (isPrevented(prevention, AddColRight)) {
33
+ preventions.push("AddColRight");
34
+ }
35
+ if (isPrevented(prevention, MoveFrom)) {
36
+ preventions.push("MoveFrom");
37
+ }
38
+ if (isPrevented(prevention, MoveTo)) {
39
+ preventions.push("MoveTo");
40
+ }
41
+ if (isPrevented(prevention, Write)) {
42
+ preventions.push("Write");
43
+ }
44
+ if (isPrevented(prevention, Style)) {
45
+ preventions.push("Style");
46
+ }
47
+ if (isPrevented(prevention, Resize)) {
48
+ preventions.push("Resize");
49
+ }
50
+ if (isPrevented(prevention, SetRenderer)) {
51
+ preventions.push("SetRenderer");
52
+ }
53
+ if (isPrevented(prevention, SetParser)) {
54
+ preventions.push("SetParser");
55
+ }
56
+ return preventions;
57
+ };
58
+ export {
59
+ Add,
60
+ AddCol,
61
+ AddColLeft,
62
+ AddColRight,
63
+ AddRow,
64
+ AddRowAbove,
65
+ AddRowBelow,
66
+ Delete,
67
+ DeleteCol,
68
+ DeleteRow,
69
+ Move,
70
+ MoveFrom,
71
+ MoveTo,
72
+ ReadOnly,
73
+ Resize,
74
+ SetParser,
75
+ SetRenderer,
76
+ Style,
77
+ Update,
78
+ Write,
79
+ debugOperations,
80
+ isPrevented
81
+ };
82
+ //# sourceMappingURL=prevention.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prevention.js","sources":["../../lib/prevention.ts"],"sourcesContent":["import { Prevention } from '../types';\n\nexport const DeleteRow: Prevention = 0b00000000000000000000000000000000000000000000000000001, // 1\n DeleteCol: Prevention = 0b00000000000000000000000000000000000000000000000000010, // 2\n AddRowAbove: Prevention = 0b00000000000000000000000000000000000000000000000000100, // 4\n AddRowBelow: Prevention = 0b00000000000000000000000000000000000000000000000001000, // 8\n AddColLeft: Prevention = 0b00000000000000000000000000000000000000000000000010000, // 16\n AddColRight: Prevention = 0b00000000000000000000000000000000000000000000000100000, // 32\n MoveFrom: Prevention = 0b00000000000000000000000000000000000000000000001000000, // 64\n MoveTo: Prevention = 0b00000000000000000000000000000000000000000000010000000, // 128\n Write: Prevention = 0b00000000000000000000000000000000000000000000100000000, // 256\n Style: Prevention = 0b00000000000000000000000000000000000000000001000000000, // 512\n Resize: Prevention = 0b00000000000000000000000000000000000000000010000000000, // 1024\n SetRenderer: Prevention = 0b00000000000000000000000000000000000000000100000000000, // 2048\n SetParser: Prevention = 0b00000000000000000000000000000000000000001000000000000; // 4096\n\nexport const Move: Prevention = MoveFrom | MoveTo; // 192\n\nexport const Update: Prevention = Write | Style | Resize | SetRenderer | SetParser; // 1792\n\nexport const AddRow: Prevention = AddRowAbove | AddRowBelow; // 12\n\nexport const AddCol: Prevention = AddColLeft | AddColRight; // 48\n\nexport const Add: Prevention = AddRow | AddCol; // 60\n\nexport const Delete: Prevention = DeleteRow | DeleteCol; // 3\n\nexport const ReadOnly: Prevention = Update | Delete | Add | Move; //\n\nexport const isPrevented = (prevention: Prevention | undefined, flag: Prevention) => {\n if (prevention === undefined) {\n return false;\n }\n return (prevention & flag) === flag;\n};\n\n// Don't use this function in production\nexport const debugOperations = (prevention: Prevention | undefined) => {\n const preventions: string[] = [];\n if (isPrevented(prevention, DeleteRow)) {\n preventions.push('DeleteRow');\n }\n if (isPrevented(prevention, DeleteCol)) {\n preventions.push('DeleteCol');\n }\n if (isPrevented(prevention, AddRowAbove)) {\n preventions.push('AddRowAbove');\n }\n if (isPrevented(prevention, AddRowBelow)) {\n preventions.push('AddRowBelow');\n }\n if (isPrevented(prevention, AddColLeft)) {\n preventions.push('AddColLeft');\n }\n if (isPrevented(prevention, AddColRight)) {\n preventions.push('AddColRight');\n }\n if (isPrevented(prevention, MoveFrom)) {\n preventions.push('MoveFrom');\n }\n if (isPrevented(prevention, MoveTo)) {\n preventions.push('MoveTo');\n }\n if (isPrevented(prevention, Write)) {\n preventions.push('Write');\n }\n if (isPrevented(prevention, Style)) {\n preventions.push('Style');\n }\n if (isPrevented(prevention, Resize)) {\n preventions.push('Resize');\n }\n if (isPrevented(prevention, SetRenderer)) {\n preventions.push('SetRenderer');\n }\n if (isPrevented(prevention, SetParser)) {\n preventions.push('SetParser');\n }\n return preventions;\n};\n"],"names":[],"mappings":"AAEa,MAAA,YAAwB,GACnC,YAAwB,GACxB,cAA0B,GAC1B,cAA0B,GAC1B,aAAyB,IACzB,cAA0B,IAC1B,WAAuB,IACvB,SAAqB,KACrB,QAAoB,KACpB,QAAoB,KACpB,SAAqB,MACrB,cAA0B,MAC1B,YAAwB;AAEnB,MAAM,OAAmB,WAAW;AAEpC,MAAM,SAAqB,QAAQ,QAAQ,SAAS,cAAc;AAElE,MAAM,SAAqB,cAAc;AAEzC,MAAM,SAAqB,aAAa;AAExC,MAAM,MAAkB,SAAS;AAEjC,MAAM,SAAqB,YAAY;AAEjC,MAAA,WAAuB,SAAS,SAAS,MAAM;AAE/C,MAAA,cAAc,CAAC,YAAoC,SAAqB;AACnF,MAAI,eAAe,QAAW;AACrB,WAAA;AAAA,EAAA;AAET,UAAQ,aAAa,UAAU;AACjC;AAGa,MAAA,kBAAkB,CAAC,eAAuC;AACrE,QAAM,cAAwB,CAAC;AAC3B,MAAA,YAAY,YAAY,SAAS,GAAG;AACtC,gBAAY,KAAK,WAAW;AAAA,EAAA;AAE1B,MAAA,YAAY,YAAY,SAAS,GAAG;AACtC,gBAAY,KAAK,WAAW;AAAA,EAAA;AAE1B,MAAA,YAAY,YAAY,WAAW,GAAG;AACxC,gBAAY,KAAK,aAAa;AAAA,EAAA;AAE5B,MAAA,YAAY,YAAY,WAAW,GAAG;AACxC,gBAAY,KAAK,aAAa;AAAA,EAAA;AAE5B,MAAA,YAAY,YAAY,UAAU,GAAG;AACvC,gBAAY,KAAK,YAAY;AAAA,EAAA;AAE3B,MAAA,YAAY,YAAY,WAAW,GAAG;AACxC,gBAAY,KAAK,aAAa;AAAA,EAAA;AAE5B,MAAA,YAAY,YAAY,QAAQ,GAAG;AACrC,gBAAY,KAAK,UAAU;AAAA,EAAA;AAEzB,MAAA,YAAY,YAAY,MAAM,GAAG;AACnC,gBAAY,KAAK,QAAQ;AAAA,EAAA;AAEvB,MAAA,YAAY,YAAY,KAAK,GAAG;AAClC,gBAAY,KAAK,OAAO;AAAA,EAAA;AAEtB,MAAA,YAAY,YAAY,KAAK,GAAG;AAClC,gBAAY,KAAK,OAAO;AAAA,EAAA;AAEtB,MAAA,YAAY,YAAY,MAAM,GAAG;AACnC,gBAAY,KAAK,QAAQ;AAAA,EAAA;AAEvB,MAAA,YAAY,YAAY,WAAW,GAAG;AACxC,gBAAY,KAAK,aAAa;AAAA,EAAA;AAE5B,MAAA,YAAY,YAAY,SAAS,GAAG;AACtC,gBAAY,KAAK,WAAW;AAAA,EAAA;AAEvB,SAAA;AACT;"}
@@ -0,0 +1,276 @@
1
+ import { a2p, c2x, x2c, p2a } from "./converters.js";
2
+ const superposeArea = (srcArea, dstArea) => {
3
+ const { height: srcHeight, width: srcWidth } = areaShape(srcArea);
4
+ const { height: dstHeight, width: dstWidth } = areaShape(dstArea);
5
+ return {
6
+ height: srcHeight > dstHeight ? srcHeight : dstHeight,
7
+ width: srcWidth > dstWidth ? srcWidth : dstWidth
8
+ };
9
+ };
10
+ const concatAreas = (area1, area2) => {
11
+ const result = { ...area1 };
12
+ if (area2.left < area1.left) {
13
+ result.left = area2.left;
14
+ }
15
+ if (area2.right > area1.right) {
16
+ result.right = area2.right;
17
+ }
18
+ if (area2.top < area1.top) {
19
+ result.top = area2.top;
20
+ }
21
+ if (area2.bottom > area1.bottom) {
22
+ result.bottom = area2.bottom;
23
+ }
24
+ return result;
25
+ };
26
+ const zoneToArea = (zone) => {
27
+ if (zone.endY === -1 || zone.endX === -1) {
28
+ return { top: -1, left: -1, bottom: -1, right: -1 };
29
+ }
30
+ const [top, bottom] = zone.startY < zone.endY ? [zone.startY, zone.endY] : [zone.endY, zone.startY];
31
+ const [left, right] = zone.startX < zone.endX ? [zone.startX, zone.endX] : [zone.endX, zone.startX];
32
+ return { top, left, bottom, right };
33
+ };
34
+ const areaToZone = (area) => {
35
+ return {
36
+ startY: area.top,
37
+ startX: area.left,
38
+ endY: area.bottom,
39
+ endX: area.right
40
+ };
41
+ };
42
+ const areaToRange = (area) => {
43
+ const { top, left, bottom, right } = area;
44
+ return `${p2a({ y: top, x: left })}:${p2a({
45
+ y: bottom,
46
+ x: right
47
+ })}`;
48
+ };
49
+ const between = (range2, index) => {
50
+ if (range2.start === -1 || range2.end === -1) {
51
+ return false;
52
+ }
53
+ return range2.start <= index && index <= range2.end || range2.end <= index && index <= range2.start;
54
+ };
55
+ const among = (area, point) => {
56
+ if (area.top === -1 || area.left === -1 || area.bottom === -1 || area.right === -1) {
57
+ return false;
58
+ }
59
+ const { y, x } = point;
60
+ const { top, left, bottom, right } = area;
61
+ return top <= y && y <= bottom && left <= x && x <= right;
62
+ };
63
+ const zoneShape = ({ base = 0, ...zone }) => {
64
+ return {
65
+ height: base + Math.abs(zone.startY - zone.endY),
66
+ width: base + Math.abs(zone.startX - zone.endX)
67
+ };
68
+ };
69
+ const areaShape = ({ base = 0, ...area }) => {
70
+ return {
71
+ height: base + Math.abs(area.top - area.bottom),
72
+ width: base + Math.abs(area.left - area.right)
73
+ };
74
+ };
75
+ const matrixShape = ({ base = 0, matrix }) => {
76
+ const h = matrix.length;
77
+ if (h === 0) {
78
+ return { height: 0, width: 0 };
79
+ }
80
+ return { height: base + h, width: base + matrix[0].length };
81
+ };
82
+ const makeSequence = (start, stop, step = 1) => {
83
+ return Array.from({ length: (stop - start - 1) / step + 1 }, (_, i) => start + i * step);
84
+ };
85
+ const oa2aa = (oa, fields) => {
86
+ const aa = [];
87
+ oa.forEach((o) => {
88
+ const a = [];
89
+ fields.forEach((field) => {
90
+ a.push(o[field]);
91
+ });
92
+ aa.push(a);
93
+ });
94
+ return aa;
95
+ };
96
+ const aa2oa = (aa, fields) => {
97
+ const oa = [];
98
+ aa.forEach((a) => {
99
+ const o = {};
100
+ a.forEach((v, i) => {
101
+ if (i >= fields.length) {
102
+ return;
103
+ }
104
+ const field = fields[i];
105
+ o[field] = v;
106
+ });
107
+ oa.push(o);
108
+ });
109
+ return oa;
110
+ };
111
+ const putMatrix = (dst, src, dstArea, filter = () => true) => {
112
+ const lostRows = {};
113
+ const { top, left, bottom, right } = dstArea;
114
+ const { height: dstNumRows, width: dstNumCols } = matrixShape({
115
+ matrix: dst,
116
+ base: 1
117
+ });
118
+ for (let y = top; y <= bottom; y++) {
119
+ const lostRow = [];
120
+ for (let x = left; x <= right; x++) {
121
+ const value = src[y - top][x - left];
122
+ if (y < dstNumRows - 1 && x < dstNumCols - 1) {
123
+ if (filter(value, dst[y][x])) {
124
+ dst[y][x] = value;
125
+ }
126
+ continue;
127
+ }
128
+ if (lostRow.length === 0) {
129
+ lostRows[p2a({ y, x })] = [lostRow];
130
+ }
131
+ lostRow.push(value);
132
+ }
133
+ }
134
+ return lostRows;
135
+ };
136
+ const createMatrix = (numRows, numCols, fill) => {
137
+ return [...Array(numRows)].map(() => Array(numCols).fill(fill));
138
+ };
139
+ const constructInitialCellsOrigin = ({
140
+ cells = {},
141
+ ensured = {},
142
+ matrix = [],
143
+ flattenAs = "value"
144
+ }) => {
145
+ return constructInitialCells({
146
+ cells,
147
+ ensured,
148
+ matrices: { A1: matrix },
149
+ flattenAs
150
+ });
151
+ };
152
+ const constructInitialCells = ({
153
+ cells = {},
154
+ ensured = {},
155
+ matrices = {},
156
+ flattenAs = "value"
157
+ } = {}) => {
158
+ upsert({ cells, flattenAs, matrices });
159
+ const { numRows, numCols } = Object.assign({ numRows: 1, numCols: 1 }, ensured);
160
+ const rightBottom = p2a({ y: numRows, x: numCols });
161
+ if (cells[rightBottom] == null) {
162
+ cells[rightBottom] = {};
163
+ }
164
+ return cells;
165
+ };
166
+ const upsert = ({
167
+ cells = {},
168
+ matrices = {},
169
+ flattenAs
170
+ }) => {
171
+ Object.keys(matrices).forEach((baseAddress) => {
172
+ const matrix = matrices[baseAddress];
173
+ const { y: baseY, x: baseX } = a2p(baseAddress);
174
+ matrix.forEach((row, y) => {
175
+ row.forEach((e, x) => {
176
+ const id = p2a({ y: baseY + y, x: baseX + x });
177
+ if (flattenAs) {
178
+ const cell = cells[id];
179
+ cells[id] = { [flattenAs]: e, ...cell };
180
+ } else {
181
+ cells[id] = e;
182
+ }
183
+ });
184
+ });
185
+ });
186
+ return cells;
187
+ };
188
+ const getMaxSizesFromCells = (cells = {}) => {
189
+ let [lastY, lastX] = [0, 0];
190
+ Object.keys(cells).map((address) => {
191
+ const { y, x } = a2p(address);
192
+ if (lastY < y) {
193
+ lastY = y;
194
+ }
195
+ if (lastX < x) {
196
+ lastX = x;
197
+ }
198
+ });
199
+ return { numRows: lastY, numCols: lastX };
200
+ };
201
+ const range = (start, end) => {
202
+ const list = [];
203
+ for (let i = start; i <= end; i++) {
204
+ list.push(i);
205
+ }
206
+ return list;
207
+ };
208
+ const complementSelectingArea = (selectingArea, choosing) => {
209
+ if (selectingArea.left === -1) {
210
+ selectingArea = {
211
+ left: choosing.x,
212
+ top: choosing.y,
213
+ right: choosing.x,
214
+ bottom: choosing.y
215
+ };
216
+ }
217
+ return selectingArea;
218
+ };
219
+ const expandRange = (range2) => {
220
+ if (range2.indexOf(":") === -1) {
221
+ return [range2];
222
+ }
223
+ const result = [];
224
+ const isRowRange = /^\d+\:\d+$/.test(range2);
225
+ if (isRowRange) {
226
+ const [startRow2, endRow2] = range2.split(":").map(Number);
227
+ for (let row = startRow2; row <= endRow2; row++) {
228
+ result.push(`${row}`);
229
+ }
230
+ return result;
231
+ }
232
+ const match = range2.match(/^([A-Z]*)(\d+)?\:([A-Z]*)(\d+)?$/);
233
+ if (!match) {
234
+ console.error("Invalid range format", range2);
235
+ return [range2];
236
+ }
237
+ const [, startCol, startRow, endCol, endRow] = match;
238
+ const startColIndex = startCol ? c2x(startCol) : 1;
239
+ const endColIndex = endCol ? c2x(endCol) : 1;
240
+ for (let col = startColIndex; col <= endColIndex; col++) {
241
+ const currentColumn = startCol || endCol ? x2c(col) : "";
242
+ if (startRow && endRow) {
243
+ for (let row = Number(startRow); row <= Number(endRow); row++) {
244
+ result.push(`${currentColumn}${row}`);
245
+ }
246
+ } else if (!startRow && !endRow) {
247
+ result.push(currentColumn);
248
+ }
249
+ }
250
+ return result;
251
+ };
252
+ export {
253
+ aa2oa,
254
+ among,
255
+ areaShape,
256
+ areaToRange,
257
+ areaToZone,
258
+ between,
259
+ complementSelectingArea,
260
+ concatAreas,
261
+ constructInitialCells,
262
+ constructInitialCellsOrigin,
263
+ createMatrix,
264
+ expandRange,
265
+ getMaxSizesFromCells,
266
+ makeSequence,
267
+ matrixShape,
268
+ oa2aa,
269
+ putMatrix,
270
+ range,
271
+ superposeArea,
272
+ upsert,
273
+ zoneShape,
274
+ zoneToArea
275
+ };
276
+ //# sourceMappingURL=structs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"structs.js","sources":["../../lib/structs.ts"],"sourcesContent":["import type {\n MatrixType,\n AreaType,\n ZoneType,\n RangeType,\n PointType,\n Y,\n X,\n CellsByAddressType,\n ShapeType,\n MatricesByAddress,\n CellType,\n Address,\n} from '../types';\nimport { a2p, p2a, x2c, c2x } from './converters';\n\nexport const slideArea = (area: AreaType, y: Y, x: X): AreaType => {\n const { top, left, bottom, right } = area;\n return { top: top + y, left: left + x, bottom: bottom + y, right: right + x };\n};\n\nexport const superposeArea = (srcArea: AreaType, dstArea: AreaType): ShapeType => {\n const { height: srcHeight, width: srcWidth } = areaShape(srcArea);\n const { height: dstHeight, width: dstWidth } = areaShape(dstArea);\n\n // biggerHeight, biggerWidth\n return {\n height: srcHeight > dstHeight ? srcHeight : dstHeight,\n width: srcWidth > dstWidth ? srcWidth : dstWidth,\n };\n};\n\nexport const concatAreas = (area1: AreaType, area2: AreaType): AreaType => {\n const result: AreaType = { ...area1 };\n if (area2.left < area1.left) {\n result.left = area2.left;\n }\n if (area2.right > area1.right) {\n result.right = area2.right;\n }\n if (area2.top < area1.top) {\n result.top = area2.top;\n }\n if (area2.bottom > area1.bottom) {\n result.bottom = area2.bottom;\n }\n return result;\n};\n\nexport const zoneToArea = (zone: ZoneType): AreaType => {\n if (zone.endY === -1 || zone.endX === -1) {\n return { top: -1, left: -1, bottom: -1, right: -1 };\n }\n const [top, bottom] = zone.startY < zone.endY ? [zone.startY, zone.endY] : [zone.endY, zone.startY];\n const [left, right] = zone.startX < zone.endX ? [zone.startX, zone.endX] : [zone.endX, zone.startX];\n return { top, left, bottom, right };\n};\n\nexport const areaToZone = (area: AreaType): ZoneType => {\n return {\n startY: area.top,\n startX: area.left,\n endY: area.bottom,\n endX: area.right,\n };\n};\n\nexport const areaToRange = (area: AreaType): string => {\n const { top, left, bottom, right } = area;\n return `${p2a({ y: top, x: left })}:${p2a({\n y: bottom,\n x: right,\n })}`;\n};\n\nexport const between = (range: RangeType, index: number) => {\n if (range.start === -1 || range.end === -1) {\n return false;\n }\n return (range.start <= index && index <= range.end) || (range.end <= index && index <= range.start);\n};\n\nexport const among = (area: AreaType, point: PointType) => {\n if (area.top === -1 || area.left === -1 || area.bottom === -1 || area.right === -1) {\n return false;\n }\n const { y, x } = point;\n const { top, left, bottom, right } = area;\n return top <= y && y <= bottom && left <= x && x <= right;\n};\n\ntype ShapeExtension = { base?: number };\n\nexport const zoneShape = ({ base = 0, ...zone }: ZoneType & ShapeExtension): ShapeType => {\n return {\n height: base + Math.abs(zone.startY - zone.endY),\n width: base + Math.abs(zone.startX - zone.endX),\n };\n};\n\nexport const areaShape = ({ base = 0, ...area }: AreaType & ShapeExtension): ShapeType => {\n return {\n height: base + Math.abs(area.top - area.bottom),\n width: base + Math.abs(area.left - area.right),\n };\n};\n\nexport const matrixShape = ({ base = 0, matrix }: { matrix: MatrixType } & ShapeExtension): ShapeType => {\n const h = matrix.length;\n if (h === 0) {\n return { height: 0, width: 0 };\n }\n return { height: base + h, width: base + matrix[0].length };\n};\n\nexport const makeSequence = (start: number, stop: number, step: number = 1) => {\n return Array.from({ length: (stop - start - 1) / step + 1 }, (_, i) => start + i * step);\n};\n\nexport const oa2aa = (oa: { [s: string]: any }[], fields: string[]): MatrixType => {\n const aa: any[][] = [];\n oa.forEach((o) => {\n const a: any[] = [];\n fields.forEach((field) => {\n a.push(o[field]);\n });\n aa.push(a);\n });\n return aa;\n};\n\nexport const aa2oa = (aa: MatrixType, fields: string[]): { [s: string]: any }[] => {\n const oa: { [s: string]: any }[] = [];\n aa.forEach((a) => {\n const o: { [s: string]: any } = {};\n a.forEach((v, i) => {\n if (i >= fields.length) {\n return;\n }\n const field = fields[i];\n o[field] = v;\n });\n oa.push(o);\n });\n return oa;\n};\n\nexport const putMatrix = <T = any>(\n dst: T[][],\n src: T[][],\n dstArea: AreaType,\n filter: (newValue: T, currentValue: T) => boolean = () => true,\n) => {\n const lostRows: MatricesByAddress<T> = {};\n const { top, left, bottom, right } = dstArea;\n const { height: dstNumRows, width: dstNumCols } = matrixShape({\n matrix: dst,\n base: 1,\n });\n for (let y = top; y <= bottom; y++) {\n const lostRow: T[] = [];\n for (let x = left; x <= right; x++) {\n const value = src[y - top][x - left];\n // -1 means excluding headers\n if (y < dstNumRows - 1 && x < dstNumCols - 1) {\n if (filter(value, dst[y][x])) {\n dst[y][x] = value;\n }\n continue;\n }\n if (lostRow.length === 0) {\n lostRows[p2a({ y, x })] = [lostRow];\n }\n lostRow.push(value);\n }\n }\n return lostRows;\n};\n\nexport const createMatrix = <T = any>(numRows: number, numCols: number, fill?: T): T[][] => {\n return [...Array(numRows)].map(() => Array(numCols).fill(fill));\n};\n\nexport const cropMatrix = <T = any>(matrix: T[][], area: AreaType): T[][] => {\n const { top, left, bottom, right } = area;\n return matrix.slice(top, bottom + 1).map((cols) => cols.slice(left, right + 1));\n};\n\nexport const constructInitialCellsOrigin = ({\n cells = {},\n ensured = {},\n matrix = [],\n flattenAs = 'value',\n}: {\n cells?: CellsByAddressType;\n ensured?: {\n numRows?: number;\n numCols?: number;\n };\n flattenAs?: keyof CellType;\n matrix?: MatrixType;\n}) => {\n return constructInitialCells({\n cells,\n ensured,\n matrices: { A1: matrix },\n flattenAs,\n });\n};\n\nexport const constructInitialCells = ({\n cells = {},\n ensured = {},\n matrices = {},\n flattenAs = 'value',\n}: {\n cells?: CellsByAddressType;\n ensured?: {\n numRows?: number;\n numCols?: number;\n };\n flattenAs?: keyof CellType;\n matrices?: MatricesByAddress<any>;\n} = {}) => {\n upsert({ cells, flattenAs, matrices });\n const { numRows, numCols } = Object.assign({ numRows: 1, numCols: 1 }, ensured);\n const rightBottom = p2a({ y: numRows, x: numCols });\n if (cells[rightBottom] == null) {\n cells[rightBottom] = {};\n }\n return cells;\n};\n\nexport const upsert = <T>({\n cells = {},\n matrices = {},\n flattenAs,\n}: {\n cells?: CellsByAddressType;\n flattenAs?: keyof CellType;\n matrices?: MatricesByAddress<T>;\n}) => {\n Object.keys(matrices).forEach((baseAddress) => {\n const matrix = matrices[baseAddress];\n const { y: baseY, x: baseX } = a2p(baseAddress);\n matrix.forEach((row, y) => {\n row.forEach((e, x) => {\n const id = p2a({ y: baseY + y, x: baseX + x });\n if (flattenAs) {\n const cell = cells[id];\n cells[id] = { [flattenAs]: e, ...cell };\n } else {\n cells[id] = e as CellType;\n }\n });\n });\n });\n return cells;\n};\n\nexport const getMaxSizesFromCells = (cells: CellsByAddressType = {}) => {\n let [lastY, lastX] = [0, 0];\n Object.keys(cells).map((address) => {\n const { y, x } = a2p(address);\n if (lastY < y) {\n lastY = y;\n }\n if (lastX < x) {\n lastX = x;\n }\n });\n return { numRows: lastY, numCols: lastX };\n};\n\nexport const range = (start: number, end: number) => {\n const list: number[] = [];\n for (let i = start; i <= end; i++) {\n list.push(i);\n }\n return list;\n};\n\nexport const complementSelectingArea = (selectingArea: AreaType, choosing: PointType) => {\n if (selectingArea.left === -1) {\n selectingArea = {\n left: choosing.x,\n top: choosing.y,\n right: choosing.x,\n bottom: choosing.y,\n };\n }\n return selectingArea;\n};\n\nexport const isSameArea = (area1: AreaType, area2: AreaType) => {\n if (area1.top !== area2.top) {\n return false;\n }\n if (area1.left !== area2.left) {\n return false;\n }\n if (area1.bottom !== area2.bottom) {\n return false;\n }\n if (area1.right !== area2.right) {\n return false;\n }\n return true;\n};\n\nexport const expandRange = (range: string): Address[] => {\n if (range.indexOf(':') === -1) {\n return [range];\n }\n\n const result: Address[] = [];\n\n const isRowRange = /^\\d+\\:\\d+$/.test(range);\n\n if (isRowRange) {\n const [startRow, endRow] = range.split(':').map(Number);\n for (let row = startRow; row <= endRow; row++) {\n result.push(`${row}`);\n }\n return result;\n }\n\n const match = range.match(/^([A-Z]*)(\\d+)?\\:([A-Z]*)(\\d+)?$/);\n if (!match) {\n console.error('Invalid range format', range);\n return [range];\n }\n\n const [, startCol, startRow, endCol, endRow] = match;\n const startColIndex = startCol ? c2x(startCol) : 1;\n const endColIndex = endCol ? c2x(endCol) : 1;\n\n for (let col = startColIndex; col <= endColIndex; col++) {\n const currentColumn = startCol || endCol ? x2c(col) : '';\n if (startRow && endRow) {\n for (let row = Number(startRow); row <= Number(endRow); row++) {\n result.push(`${currentColumn}${row}`);\n }\n } else if (!startRow && !endRow) {\n result.push(currentColumn);\n }\n }\n return result;\n};\n"],"names":["range","startRow","endRow"],"mappings":"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"}