handsontable 12.1.3 → 12.3.0-next-bb1a7c2-20221208

Sign up to get free protection for your applications and to get access to all the features.
Files changed (948) hide show
  1. package/3rdparty/SheetClip/SheetClip.js +3 -32
  2. package/3rdparty/SheetClip/SheetClip.mjs +3 -23
  3. package/3rdparty/SheetClip/index.js +0 -2
  4. package/3rdparty/autoResize/autoResize.js +119 -145
  5. package/3rdparty/autoResize/autoResize.mjs +119 -143
  6. package/3rdparty/autoResize/index.js +0 -2
  7. package/3rdparty/walkontable/src/border.js +44 -154
  8. package/3rdparty/walkontable/src/border.mjs +41 -136
  9. package/3rdparty/walkontable/src/calculator/constants.js +0 -3
  10. package/3rdparty/walkontable/src/calculator/constants.mjs +0 -2
  11. package/3rdparty/walkontable/src/calculator/index.js +0 -10
  12. package/3rdparty/walkontable/src/calculator/viewportColumns.js +36 -77
  13. package/3rdparty/walkontable/src/calculator/viewportColumns.mjs +36 -70
  14. package/3rdparty/walkontable/src/calculator/viewportRows.js +30 -49
  15. package/3rdparty/walkontable/src/calculator/viewportRows.mjs +30 -42
  16. package/3rdparty/walkontable/src/cell/coords.d.ts +1 -1
  17. package/3rdparty/walkontable/src/cell/coords.js +73 -65
  18. package/3rdparty/walkontable/src/cell/coords.mjs +73 -60
  19. package/3rdparty/walkontable/src/cell/range.d.ts +19 -16
  20. package/3rdparty/walkontable/src/cell/range.js +251 -231
  21. package/3rdparty/walkontable/src/cell/range.mjs +251 -222
  22. package/3rdparty/walkontable/src/core/_base.js +30 -74
  23. package/3rdparty/walkontable/src/core/_base.mjs +30 -67
  24. package/3rdparty/walkontable/src/core/clone.js +11 -44
  25. package/3rdparty/walkontable/src/core/clone.mjs +11 -32
  26. package/3rdparty/walkontable/src/core/core.js +8 -56
  27. package/3rdparty/walkontable/src/core/core.mjs +8 -38
  28. package/3rdparty/walkontable/src/event.js +41 -79
  29. package/3rdparty/walkontable/src/event.mjs +41 -66
  30. package/3rdparty/walkontable/src/facade/core.js +14 -16
  31. package/3rdparty/walkontable/src/facade/core.mjs +14 -13
  32. package/3rdparty/walkontable/src/filter/column.js +22 -17
  33. package/3rdparty/walkontable/src/filter/column.mjs +22 -16
  34. package/3rdparty/walkontable/src/filter/row.js +22 -17
  35. package/3rdparty/walkontable/src/filter/row.mjs +22 -16
  36. package/3rdparty/walkontable/src/index.js +0 -31
  37. package/3rdparty/walkontable/src/overlay/_base.js +38 -69
  38. package/3rdparty/walkontable/src/overlay/_base.mjs +38 -61
  39. package/3rdparty/walkontable/src/overlay/bottom.js +38 -103
  40. package/3rdparty/walkontable/src/overlay/bottom.mjs +38 -88
  41. package/3rdparty/walkontable/src/overlay/bottomInlineStartCorner.js +12 -52
  42. package/3rdparty/walkontable/src/overlay/bottomInlineStartCorner.mjs +12 -37
  43. package/3rdparty/walkontable/src/overlay/constants.js +0 -6
  44. package/3rdparty/walkontable/src/overlay/constants.mjs +0 -1
  45. package/3rdparty/walkontable/src/overlay/index.js +0 -17
  46. package/3rdparty/walkontable/src/overlay/inlineStart.js +26 -90
  47. package/3rdparty/walkontable/src/overlay/inlineStart.mjs +26 -75
  48. package/3rdparty/walkontable/src/overlay/top.js +37 -104
  49. package/3rdparty/walkontable/src/overlay/top.mjs +37 -89
  50. package/3rdparty/walkontable/src/overlay/topInlineStartCorner.js +14 -55
  51. package/3rdparty/walkontable/src/overlay/topInlineStartCorner.mjs +14 -40
  52. package/3rdparty/walkontable/src/overlays.js +124 -145
  53. package/3rdparty/walkontable/src/overlays.mjs +124 -135
  54. package/3rdparty/walkontable/src/renderer/_base.js +17 -19
  55. package/3rdparty/walkontable/src/renderer/_base.mjs +17 -17
  56. package/3rdparty/walkontable/src/renderer/cells.js +15 -53
  57. package/3rdparty/walkontable/src/renderer/cells.mjs +15 -39
  58. package/3rdparty/walkontable/src/renderer/colGroup.js +15 -46
  59. package/3rdparty/walkontable/src/renderer/colGroup.mjs +15 -34
  60. package/3rdparty/walkontable/src/renderer/columnHeaders.js +13 -49
  61. package/3rdparty/walkontable/src/renderer/columnHeaders.mjs +13 -37
  62. package/3rdparty/walkontable/src/renderer/index.js +26 -35
  63. package/3rdparty/walkontable/src/renderer/index.mjs +26 -22
  64. package/3rdparty/walkontable/src/renderer/rowHeaders.js +13 -49
  65. package/3rdparty/walkontable/src/renderer/rowHeaders.mjs +13 -36
  66. package/3rdparty/walkontable/src/renderer/rows.js +11 -49
  67. package/3rdparty/walkontable/src/renderer/rows.mjs +11 -32
  68. package/3rdparty/walkontable/src/renderer/table.js +35 -48
  69. package/3rdparty/walkontable/src/renderer/table.mjs +35 -47
  70. package/3rdparty/walkontable/src/scroll.js +69 -86
  71. package/3rdparty/walkontable/src/scroll.mjs +69 -84
  72. package/3rdparty/walkontable/src/selection.js +28 -103
  73. package/3rdparty/walkontable/src/selection.mjs +26 -83
  74. package/3rdparty/walkontable/src/settings.js +25 -31
  75. package/3rdparty/walkontable/src/settings.mjs +25 -29
  76. package/3rdparty/walkontable/src/table/bottom.js +6 -34
  77. package/3rdparty/walkontable/src/table/bottom.mjs +6 -19
  78. package/3rdparty/walkontable/src/table/bottomInlineStartCorner.js +6 -34
  79. package/3rdparty/walkontable/src/table/bottomInlineStartCorner.mjs +6 -19
  80. package/3rdparty/walkontable/src/table/inlineStart.js +6 -34
  81. package/3rdparty/walkontable/src/table/inlineStart.mjs +6 -19
  82. package/3rdparty/walkontable/src/table/master.js +15 -54
  83. package/3rdparty/walkontable/src/table/master.mjs +15 -38
  84. package/3rdparty/walkontable/src/table/mixin/calculatedColumns.js +1 -16
  85. package/3rdparty/walkontable/src/table/mixin/calculatedColumns.mjs +1 -14
  86. package/3rdparty/walkontable/src/table/mixin/calculatedRows.js +1 -16
  87. package/3rdparty/walkontable/src/table/mixin/calculatedRows.mjs +1 -14
  88. package/3rdparty/walkontable/src/table/mixin/stickyColumnsStart.js +1 -10
  89. package/3rdparty/walkontable/src/table/mixin/stickyColumnsStart.mjs +1 -8
  90. package/3rdparty/walkontable/src/table/mixin/stickyRowsBottom.js +1 -11
  91. package/3rdparty/walkontable/src/table/mixin/stickyRowsBottom.mjs +1 -9
  92. package/3rdparty/walkontable/src/table/mixin/stickyRowsTop.js +1 -10
  93. package/3rdparty/walkontable/src/table/mixin/stickyRowsTop.mjs +1 -8
  94. package/3rdparty/walkontable/src/table/top.js +6 -34
  95. package/3rdparty/walkontable/src/table/top.mjs +6 -19
  96. package/3rdparty/walkontable/src/table/topInlineStartCorner.js +6 -34
  97. package/3rdparty/walkontable/src/table/topInlineStartCorner.mjs +6 -19
  98. package/3rdparty/walkontable/src/table.js +73 -233
  99. package/3rdparty/walkontable/src/table.mjs +71 -210
  100. package/3rdparty/walkontable/src/types.js +0 -5
  101. package/3rdparty/walkontable/src/types.mjs +0 -5
  102. package/3rdparty/walkontable/src/utils/column.js +18 -30
  103. package/3rdparty/walkontable/src/utils/column.mjs +18 -25
  104. package/3rdparty/walkontable/src/utils/nodesPool.js +16 -11
  105. package/3rdparty/walkontable/src/utils/nodesPool.mjs +16 -10
  106. package/3rdparty/walkontable/src/utils/orderView/constants.js +0 -3
  107. package/3rdparty/walkontable/src/utils/orderView/constants.mjs +0 -2
  108. package/3rdparty/walkontable/src/utils/orderView/index.js +0 -5
  109. package/3rdparty/walkontable/src/utils/orderView/sharedView.js +7 -32
  110. package/3rdparty/walkontable/src/utils/orderView/sharedView.mjs +7 -21
  111. package/3rdparty/walkontable/src/utils/orderView/view.js +27 -45
  112. package/3rdparty/walkontable/src/utils/orderView/view.mjs +27 -42
  113. package/3rdparty/walkontable/src/utils/orderView/viewSize.js +16 -14
  114. package/3rdparty/walkontable/src/utils/orderView/viewSize.mjs +16 -13
  115. package/3rdparty/walkontable/src/utils/orderView/viewSizeSet.js +21 -21
  116. package/3rdparty/walkontable/src/utils/orderView/viewSizeSet.mjs +21 -18
  117. package/3rdparty/walkontable/src/utils/row.js +15 -12
  118. package/3rdparty/walkontable/src/utils/row.mjs +15 -11
  119. package/3rdparty/walkontable/src/viewport.js +51 -99
  120. package/3rdparty/walkontable/src/viewport.mjs +51 -96
  121. package/CHANGELOG.md +99 -1
  122. package/base.d.ts +1 -0
  123. package/base.js +11 -17
  124. package/base.mjs +10 -11
  125. package/cellTypes/autocompleteType/autocompleteType.js +0 -4
  126. package/cellTypes/autocompleteType/index.js +0 -2
  127. package/cellTypes/checkboxType/checkboxType.js +0 -3
  128. package/cellTypes/checkboxType/index.js +0 -2
  129. package/cellTypes/dateType/dateType.js +0 -4
  130. package/cellTypes/dateType/index.js +0 -2
  131. package/cellTypes/dropdownType/dropdownType.js +0 -4
  132. package/cellTypes/dropdownType/index.js +0 -2
  133. package/cellTypes/handsontableType/handsontableType.js +0 -3
  134. package/cellTypes/handsontableType/index.js +0 -2
  135. package/cellTypes/index.js +0 -21
  136. package/cellTypes/index.mjs +0 -1
  137. package/cellTypes/numericType/index.js +0 -2
  138. package/cellTypes/numericType/numericType.js +0 -4
  139. package/cellTypes/passwordType/index.js +0 -2
  140. package/cellTypes/passwordType/passwordType.js +0 -3
  141. package/cellTypes/registry.js +10 -25
  142. package/cellTypes/registry.mjs +10 -20
  143. package/cellTypes/textType/index.js +0 -2
  144. package/cellTypes/textType/textType.js +0 -3
  145. package/cellTypes/timeType/index.js +0 -2
  146. package/cellTypes/timeType/timeType.js +0 -4
  147. package/core.d.ts +6 -2
  148. package/core.js +714 -1070
  149. package/core.mjs +717 -1015
  150. package/dataMap/dataMap.js +202 -236
  151. package/dataMap/dataMap.mjs +201 -209
  152. package/{dataSource.js → dataMap/dataSource.js} +29 -65
  153. package/{dataSource.mjs → dataMap/dataSource.mjs} +29 -57
  154. package/dataMap/index.js +0 -13
  155. package/dataMap/metaManager/index.js +33 -45
  156. package/dataMap/metaManager/index.mjs +33 -37
  157. package/dataMap/metaManager/lazyFactoryMap.js +17 -62
  158. package/dataMap/metaManager/lazyFactoryMap.mjs +17 -46
  159. package/dataMap/metaManager/metaLayers/cellMeta.js +26 -57
  160. package/dataMap/metaManager/metaLayers/cellMeta.mjs +25 -41
  161. package/dataMap/metaManager/metaLayers/columnMeta.js +23 -24
  162. package/dataMap/metaManager/metaLayers/columnMeta.mjs +24 -21
  163. package/dataMap/metaManager/metaLayers/globalMeta.js +30 -21
  164. package/dataMap/metaManager/metaLayers/globalMeta.mjs +31 -18
  165. package/dataMap/metaManager/metaLayers/tableMeta.js +18 -15
  166. package/dataMap/metaManager/metaLayers/tableMeta.mjs +19 -14
  167. package/dataMap/metaManager/metaSchema.js +173 -213
  168. package/dataMap/metaManager/metaSchema.mjs +173 -204
  169. package/dataMap/metaManager/mods/dynamicCellMeta.js +15 -35
  170. package/dataMap/metaManager/mods/dynamicCellMeta.mjs +15 -24
  171. package/dataMap/metaManager/mods/extendMetaProperties.js +14 -27
  172. package/dataMap/metaManager/mods/extendMetaProperties.mjs +14 -19
  173. package/dataMap/metaManager/utils.js +49 -28
  174. package/dataMap/metaManager/utils.mjs +50 -21
  175. package/dataMap/replaceData.js +15 -35
  176. package/dataMap/replaceData.mjs +15 -23
  177. package/dist/handsontable.css +9 -9
  178. package/dist/handsontable.full.css +9 -9
  179. package/dist/handsontable.full.js +13065 -28165
  180. package/dist/handsontable.full.min.css +2 -2
  181. package/dist/handsontable.full.min.js +108 -114
  182. package/dist/handsontable.js +11528 -21792
  183. package/dist/handsontable.min.css +2 -2
  184. package/dist/handsontable.min.js +3 -3
  185. package/dist/languages/all.js +111 -240
  186. package/dist/languages/all.min.js +1 -1
  187. package/dist/languages/ar-AR.js +50 -14
  188. package/dist/languages/ar-AR.min.js +1 -1
  189. package/dist/languages/cs-CZ.js +52 -16
  190. package/dist/languages/cs-CZ.min.js +1 -1
  191. package/dist/languages/de-CH.js +52 -16
  192. package/dist/languages/de-CH.min.js +1 -1
  193. package/dist/languages/de-DE.js +53 -17
  194. package/dist/languages/de-DE.min.js +1 -1
  195. package/dist/languages/en-US.js +56 -20
  196. package/dist/languages/en-US.min.js +1 -1
  197. package/dist/languages/es-MX.js +56 -20
  198. package/dist/languages/es-MX.min.js +1 -1
  199. package/dist/languages/fr-FR.js +55 -19
  200. package/dist/languages/fr-FR.min.js +1 -1
  201. package/dist/languages/it-IT.js +55 -19
  202. package/dist/languages/it-IT.min.js +1 -1
  203. package/dist/languages/ja-JP.js +83 -43
  204. package/dist/languages/ja-JP.min.js +1 -1
  205. package/dist/languages/ko-KR.js +84 -43
  206. package/dist/languages/ko-KR.min.js +1 -1
  207. package/dist/languages/lv-LV.js +85 -43
  208. package/dist/languages/lv-LV.min.js +1 -1
  209. package/dist/languages/nb-NO.js +86 -43
  210. package/dist/languages/nb-NO.min.js +1 -1
  211. package/dist/languages/nl-NL.js +87 -43
  212. package/dist/languages/nl-NL.min.js +1 -1
  213. package/dist/languages/pl-PL.js +88 -43
  214. package/dist/languages/pl-PL.min.js +1 -1
  215. package/dist/languages/pt-BR.js +67 -28
  216. package/dist/languages/pt-BR.min.js +1 -1
  217. package/dist/languages/ru-RU.js +67 -28
  218. package/dist/languages/ru-RU.min.js +1 -1
  219. package/dist/languages/sr-SP.js +55 -16
  220. package/dist/languages/sr-SP.min.js +1 -1
  221. package/dist/languages/zh-CN.js +55 -16
  222. package/dist/languages/zh-CN.min.js +1 -1
  223. package/dist/languages/zh-TW.js +55 -16
  224. package/dist/languages/zh-TW.min.js +1 -1
  225. package/editorManager.js +53 -113
  226. package/editorManager.mjs +50 -90
  227. package/editors/autocompleteEditor/autocompleteEditor.js +36 -138
  228. package/editors/autocompleteEditor/autocompleteEditor.mjs +35 -108
  229. package/editors/autocompleteEditor/index.js +0 -2
  230. package/editors/baseEditor/baseEditor.js +55 -160
  231. package/editors/baseEditor/baseEditor.mjs +54 -133
  232. package/editors/baseEditor/index.js +0 -2
  233. package/editors/checkboxEditor/checkboxEditor.js +8 -34
  234. package/editors/checkboxEditor/checkboxEditor.mjs +8 -20
  235. package/editors/checkboxEditor/index.js +0 -2
  236. package/editors/dateEditor/dateEditor.js +26 -97
  237. package/editors/dateEditor/dateEditor.mjs +26 -76
  238. package/editors/dateEditor/index.js +0 -2
  239. package/editors/dropdownEditor/dropdownEditor.js +7 -42
  240. package/editors/dropdownEditor/dropdownEditor.mjs +7 -23
  241. package/editors/dropdownEditor/index.js +0 -2
  242. package/editors/handsontableEditor/handsontableEditor.js +19 -86
  243. package/editors/handsontableEditor/handsontableEditor.mjs +19 -67
  244. package/editors/handsontableEditor/index.js +0 -2
  245. package/editors/index.js +0 -25
  246. package/editors/index.mjs +0 -1
  247. package/editors/numericEditor/index.js +0 -2
  248. package/editors/numericEditor/numericEditor.js +7 -32
  249. package/editors/numericEditor/numericEditor.mjs +7 -19
  250. package/editors/passwordEditor/index.js +0 -2
  251. package/editors/passwordEditor/passwordEditor.js +7 -39
  252. package/editors/passwordEditor/passwordEditor.mjs +7 -23
  253. package/editors/registry.js +13 -36
  254. package/editors/registry.mjs +12 -26
  255. package/editors/selectEditor/index.js +0 -2
  256. package/editors/selectEditor/selectEditor.js +27 -74
  257. package/editors/selectEditor/selectEditor.mjs +27 -57
  258. package/editors/textEditor/caretPositioner.js +0 -8
  259. package/editors/textEditor/caretPositioner.mjs +0 -7
  260. package/editors/textEditor/index.js +0 -2
  261. package/editors/textEditor/textEditor.js +45 -139
  262. package/editors/textEditor/textEditor.mjs +45 -108
  263. package/editors/timeEditor/index.js +0 -2
  264. package/editors/timeEditor/timeEditor.js +7 -37
  265. package/editors/timeEditor/timeEditor.mjs +7 -22
  266. package/eventManager.js +26 -47
  267. package/eventManager.mjs +27 -45
  268. package/helpers/array.js +22 -88
  269. package/helpers/array.mjs +22 -58
  270. package/helpers/browser.js +25 -51
  271. package/helpers/browser.mjs +25 -32
  272. package/helpers/console.js +3 -13
  273. package/helpers/console.mjs +3 -10
  274. package/helpers/data.d.ts +0 -2
  275. package/helpers/data.js +8 -102
  276. package/helpers/data.mjs +9 -80
  277. package/helpers/date.js +2 -3
  278. package/helpers/date.mjs +2 -2
  279. package/helpers/dom/element.js +89 -256
  280. package/helpers/dom/element.mjs +88 -184
  281. package/helpers/dom/event.js +3 -7
  282. package/helpers/dom/event.mjs +3 -3
  283. package/helpers/feature.js +21 -82
  284. package/helpers/feature.mjs +15 -60
  285. package/helpers/function.js +14 -59
  286. package/helpers/function.mjs +14 -45
  287. package/helpers/mixed.js +9 -64
  288. package/helpers/mixed.mjs +9 -43
  289. package/helpers/number.js +4 -46
  290. package/helpers/number.mjs +4 -23
  291. package/helpers/object.js +30 -77
  292. package/helpers/object.mjs +25 -47
  293. package/helpers/string.js +6 -28
  294. package/helpers/string.mjs +6 -14
  295. package/helpers/templateLiteralTag.js +0 -6
  296. package/helpers/templateLiteralTag.mjs +0 -2
  297. package/helpers/unicode.js +17 -22
  298. package/helpers/unicode.mjs +17 -13
  299. package/helpers/wrappers/jquery.js +4 -14
  300. package/helpers/wrappers/jquery.mjs +4 -13
  301. package/i18n/constants.js +50 -45
  302. package/i18n/constants.mjs +46 -42
  303. package/i18n/index.js +0 -7
  304. package/i18n/languages/ar-AR.js +12 -23
  305. package/i18n/languages/ar-AR.mjs +14 -3
  306. package/i18n/languages/cs-CZ.js +12 -23
  307. package/i18n/languages/cs-CZ.mjs +14 -3
  308. package/i18n/languages/de-CH.js +12 -23
  309. package/i18n/languages/de-CH.mjs +14 -3
  310. package/i18n/languages/de-DE.js +12 -23
  311. package/i18n/languages/de-DE.mjs +14 -3
  312. package/i18n/languages/en-US.js +13 -24
  313. package/i18n/languages/en-US.mjs +15 -4
  314. package/i18n/languages/es-MX.js +13 -24
  315. package/i18n/languages/es-MX.mjs +17 -5
  316. package/i18n/languages/fr-FR.js +12 -23
  317. package/i18n/languages/fr-FR.mjs +14 -3
  318. package/i18n/languages/index.js +0 -39
  319. package/i18n/languages/it-IT.js +12 -23
  320. package/i18n/languages/it-IT.mjs +14 -3
  321. package/i18n/languages/ja-JP.js +12 -23
  322. package/i18n/languages/ja-JP.mjs +14 -3
  323. package/i18n/languages/ko-KR.js +12 -23
  324. package/i18n/languages/ko-KR.mjs +14 -3
  325. package/i18n/languages/lv-LV.js +13 -24
  326. package/i18n/languages/lv-LV.mjs +17 -6
  327. package/i18n/languages/nb-NO.js +12 -23
  328. package/i18n/languages/nb-NO.mjs +14 -3
  329. package/i18n/languages/nl-NL.js +13 -24
  330. package/i18n/languages/nl-NL.mjs +17 -6
  331. package/i18n/languages/pl-PL.js +13 -24
  332. package/i18n/languages/pl-PL.mjs +16 -5
  333. package/i18n/languages/pt-BR.js +12 -23
  334. package/i18n/languages/pt-BR.mjs +14 -3
  335. package/i18n/languages/ru-RU.js +12 -23
  336. package/i18n/languages/ru-RU.mjs +14 -3
  337. package/i18n/languages/sr-SP.js +12 -23
  338. package/i18n/languages/sr-SP.mjs +14 -3
  339. package/i18n/languages/zh-CN.js +12 -23
  340. package/i18n/languages/zh-CN.mjs +14 -3
  341. package/i18n/languages/zh-TW.js +12 -23
  342. package/i18n/languages/zh-TW.mjs +14 -3
  343. package/i18n/phraseFormatters/index.js +4 -11
  344. package/i18n/phraseFormatters/index.mjs +4 -6
  345. package/i18n/phraseFormatters/pluralize.js +0 -5
  346. package/i18n/phraseFormatters/pluralize.mjs +0 -3
  347. package/i18n/phraseFormatters/substituteVariables.js +0 -4
  348. package/i18n/phraseFormatters/substituteVariables.mjs +0 -2
  349. package/i18n/registry.js +18 -59
  350. package/i18n/registry.mjs +18 -30
  351. package/i18n/utils.js +4 -22
  352. package/i18n/utils.mjs +4 -11
  353. package/index.d.ts +9 -0
  354. package/index.js +23 -58
  355. package/index.mjs +21 -16
  356. package/languages/all.js +111 -240
  357. package/languages/ar-AR.js +50 -14
  358. package/languages/ar-AR.mjs +14 -3
  359. package/languages/cs-CZ.js +52 -16
  360. package/languages/cs-CZ.mjs +14 -3
  361. package/languages/de-CH.js +52 -16
  362. package/languages/de-CH.mjs +14 -3
  363. package/languages/de-DE.js +53 -17
  364. package/languages/de-DE.mjs +14 -3
  365. package/languages/en-US.js +56 -20
  366. package/languages/en-US.mjs +15 -4
  367. package/languages/es-MX.js +56 -20
  368. package/languages/es-MX.mjs +17 -5
  369. package/languages/fr-FR.js +55 -19
  370. package/languages/fr-FR.mjs +14 -3
  371. package/languages/index.js +111 -240
  372. package/languages/it-IT.js +55 -19
  373. package/languages/it-IT.mjs +14 -3
  374. package/languages/ja-JP.js +83 -43
  375. package/languages/ja-JP.mjs +14 -3
  376. package/languages/ko-KR.js +84 -43
  377. package/languages/ko-KR.mjs +14 -3
  378. package/languages/lv-LV.js +85 -43
  379. package/languages/lv-LV.mjs +17 -6
  380. package/languages/nb-NO.js +86 -43
  381. package/languages/nb-NO.mjs +14 -3
  382. package/languages/nl-NL.js +87 -43
  383. package/languages/nl-NL.mjs +17 -6
  384. package/languages/pl-PL.js +88 -43
  385. package/languages/pl-PL.mjs +16 -5
  386. package/languages/pt-BR.js +67 -28
  387. package/languages/pt-BR.mjs +14 -3
  388. package/languages/ru-RU.js +67 -28
  389. package/languages/ru-RU.mjs +14 -3
  390. package/languages/sr-SP.js +55 -16
  391. package/languages/sr-SP.mjs +14 -3
  392. package/languages/zh-CN.js +55 -16
  393. package/languages/zh-CN.mjs +14 -3
  394. package/languages/zh-TW.js +55 -16
  395. package/languages/zh-TW.mjs +14 -3
  396. package/mixins/hooksRefRegisterer.js +1 -12
  397. package/mixins/hooksRefRegisterer.mjs +1 -9
  398. package/mixins/localHooks.js +4 -11
  399. package/mixins/localHooks.mjs +4 -8
  400. package/package.json +2 -2
  401. package/pluginHooks.d.ts +10 -5
  402. package/pluginHooks.js +376 -116
  403. package/pluginHooks.mjs +375 -103
  404. package/plugins/autoColumnSize/autoColumnSize.js +81 -174
  405. package/plugins/autoColumnSize/autoColumnSize.mjs +81 -139
  406. package/plugins/autoColumnSize/index.js +0 -2
  407. package/plugins/autoRowSize/autoRowSize.js +89 -160
  408. package/plugins/autoRowSize/autoRowSize.mjs +89 -131
  409. package/plugins/autoRowSize/index.js +0 -2
  410. package/plugins/autofill/autofill.js +53 -165
  411. package/plugins/autofill/autofill.mjs +53 -133
  412. package/plugins/autofill/index.js +0 -2
  413. package/plugins/autofill/utils.js +4 -26
  414. package/plugins/autofill/utils.mjs +4 -18
  415. package/plugins/base/base.js +28 -91
  416. package/plugins/base/base.mjs +28 -63
  417. package/plugins/base/index.js +0 -2
  418. package/plugins/bindRowsWithHeaders/bindRowsWithHeaders.js +25 -53
  419. package/plugins/bindRowsWithHeaders/bindRowsWithHeaders.mjs +25 -34
  420. package/plugins/bindRowsWithHeaders/index.js +0 -2
  421. package/plugins/bindRowsWithHeaders/maps/looseBindsMap.js +11 -42
  422. package/plugins/bindRowsWithHeaders/maps/looseBindsMap.mjs +11 -30
  423. package/plugins/bindRowsWithHeaders/maps/strictBindsMap.js +12 -54
  424. package/plugins/bindRowsWithHeaders/maps/strictBindsMap.mjs +12 -38
  425. package/plugins/collapsibleColumns/collapsibleColumns.js +106 -193
  426. package/plugins/collapsibleColumns/collapsibleColumns.mjs +106 -162
  427. package/plugins/collapsibleColumns/index.js +0 -2
  428. package/plugins/columnSorting/columnSorting.js +58 -192
  429. package/plugins/columnSorting/columnSorting.mjs +58 -147
  430. package/plugins/columnSorting/columnStatesManager.js +27 -77
  431. package/plugins/columnSorting/columnStatesManager.mjs +24 -51
  432. package/plugins/columnSorting/domHelpers.js +2 -18
  433. package/plugins/columnSorting/domHelpers.mjs +2 -7
  434. package/plugins/columnSorting/index.js +0 -2
  435. package/plugins/columnSorting/rootComparator.js +5 -24
  436. package/plugins/columnSorting/rootComparator.mjs +5 -13
  437. package/plugins/columnSorting/sortFunction/checkbox.js +8 -16
  438. package/plugins/columnSorting/sortFunction/checkbox.mjs +8 -12
  439. package/plugins/columnSorting/sortFunction/date.js +2 -19
  440. package/plugins/columnSorting/sortFunction/date.mjs +2 -14
  441. package/plugins/columnSorting/sortFunction/default.js +2 -17
  442. package/plugins/columnSorting/sortFunction/default.mjs +2 -14
  443. package/plugins/columnSorting/sortFunction/numeric.js +2 -11
  444. package/plugins/columnSorting/sortFunction/numeric.mjs +2 -8
  445. package/plugins/columnSorting/sortService/engine.js +1 -7
  446. package/plugins/columnSorting/sortService/engine.mjs +1 -3
  447. package/plugins/columnSorting/sortService/index.js +0 -5
  448. package/plugins/columnSorting/sortService/registry.js +6 -18
  449. package/plugins/columnSorting/sortService/registry.mjs +6 -10
  450. package/plugins/columnSorting/utils.js +9 -34
  451. package/plugins/columnSorting/utils.mjs +9 -15
  452. package/plugins/columnSummary/columnSummary.js +65 -126
  453. package/plugins/columnSummary/columnSummary.mjs +65 -101
  454. package/plugins/columnSummary/endpoints.js +33 -109
  455. package/plugins/columnSummary/endpoints.mjs +33 -105
  456. package/plugins/columnSummary/index.js +0 -2
  457. package/plugins/columnSummary/utils.js +0 -1
  458. package/plugins/comments/commentEditor.js +29 -27
  459. package/plugins/comments/commentEditor.mjs +29 -26
  460. package/plugins/comments/comments.js +106 -178
  461. package/plugins/comments/comments.mjs +106 -152
  462. package/plugins/comments/displaySwitch.js +20 -24
  463. package/plugins/comments/displaySwitch.mjs +20 -19
  464. package/plugins/comments/index.js +0 -2
  465. package/plugins/contextMenu/commandExecutor.js +17 -29
  466. package/plugins/contextMenu/commandExecutor.mjs +17 -27
  467. package/plugins/contextMenu/contextMenu.d.ts +4 -3
  468. package/plugins/contextMenu/contextMenu.js +28 -121
  469. package/plugins/contextMenu/contextMenu.mjs +28 -91
  470. package/plugins/contextMenu/cursor.js +19 -19
  471. package/plugins/contextMenu/cursor.mjs +19 -18
  472. package/plugins/contextMenu/index.js +0 -2
  473. package/plugins/contextMenu/itemsFactory.js +21 -35
  474. package/plugins/contextMenu/itemsFactory.mjs +21 -31
  475. package/plugins/contextMenu/menu.js +71 -180
  476. package/plugins/contextMenu/menu.mjs +70 -151
  477. package/plugins/contextMenu/predefinedItems/alignment.js +1 -55
  478. package/plugins/contextMenu/predefinedItems/alignment.mjs +1 -37
  479. package/plugins/contextMenu/predefinedItems/clearColumn.js +1 -20
  480. package/plugins/contextMenu/predefinedItems/clearColumn.mjs +1 -4
  481. package/plugins/contextMenu/predefinedItems/columnLeft.js +6 -43
  482. package/plugins/contextMenu/predefinedItems/columnLeft.mjs +6 -26
  483. package/plugins/contextMenu/predefinedItems/columnRight.js +4 -42
  484. package/plugins/contextMenu/predefinedItems/columnRight.mjs +4 -25
  485. package/plugins/contextMenu/predefinedItems/noItems.js +1 -4
  486. package/plugins/contextMenu/predefinedItems/noItems.mjs +1 -1
  487. package/plugins/contextMenu/predefinedItems/readOnly.js +1 -25
  488. package/plugins/contextMenu/predefinedItems/readOnly.mjs +1 -8
  489. package/plugins/contextMenu/predefinedItems/redo.js +1 -16
  490. package/plugins/contextMenu/predefinedItems/redo.mjs +1 -1
  491. package/plugins/contextMenu/predefinedItems/removeColumn.js +4 -39
  492. package/plugins/contextMenu/predefinedItems/removeColumn.mjs +4 -19
  493. package/plugins/contextMenu/predefinedItems/removeRow.js +4 -38
  494. package/plugins/contextMenu/predefinedItems/removeRow.mjs +4 -18
  495. package/plugins/contextMenu/predefinedItems/rowAbove.js +6 -35
  496. package/plugins/contextMenu/predefinedItems/rowAbove.mjs +6 -19
  497. package/plugins/contextMenu/predefinedItems/rowBelow.js +4 -42
  498. package/plugins/contextMenu/predefinedItems/rowBelow.mjs +4 -25
  499. package/plugins/contextMenu/predefinedItems/separator.js +1 -2
  500. package/plugins/contextMenu/predefinedItems/separator.mjs +1 -1
  501. package/plugins/contextMenu/predefinedItems/undo.js +1 -16
  502. package/plugins/contextMenu/predefinedItems/undo.mjs +1 -1
  503. package/plugins/contextMenu/predefinedItems.js +14 -55
  504. package/plugins/contextMenu/predefinedItems.mjs +16 -8
  505. package/plugins/contextMenu/utils.js +17 -57
  506. package/plugins/contextMenu/utils.mjs +17 -34
  507. package/plugins/copyPaste/clipboardData.js +14 -9
  508. package/plugins/copyPaste/clipboardData.mjs +14 -8
  509. package/plugins/copyPaste/contextMenuItem/copy.js +5 -32
  510. package/plugins/copyPaste/contextMenuItem/copy.mjs +5 -7
  511. package/plugins/copyPaste/contextMenuItem/copyColumnHeadersOnly.js +35 -0
  512. package/plugins/copyPaste/contextMenuItem/copyColumnHeadersOnly.mjs +31 -0
  513. package/plugins/copyPaste/contextMenuItem/copyWithColumnGroupHeaders.js +35 -0
  514. package/plugins/copyPaste/contextMenuItem/copyWithColumnGroupHeaders.mjs +31 -0
  515. package/plugins/copyPaste/contextMenuItem/copyWithColumnHeaders.js +35 -0
  516. package/plugins/copyPaste/contextMenuItem/copyWithColumnHeaders.mjs +31 -0
  517. package/plugins/copyPaste/contextMenuItem/cut.js +2 -17
  518. package/plugins/copyPaste/contextMenuItem/cut.mjs +2 -4
  519. package/plugins/copyPaste/copyPaste.d.ts +10 -2
  520. package/plugins/copyPaste/copyPaste.js +339 -372
  521. package/plugins/copyPaste/copyPaste.mjs +339 -331
  522. package/plugins/copyPaste/copyableRanges.js +269 -0
  523. package/plugins/copyPaste/copyableRanges.mjs +264 -0
  524. package/plugins/copyPaste/focusableElement.js +21 -55
  525. package/plugins/copyPaste/focusableElement.mjs +21 -45
  526. package/plugins/copyPaste/index.js +0 -2
  527. package/plugins/copyPaste/pasteEvent.js +14 -9
  528. package/plugins/copyPaste/pasteEvent.mjs +14 -7
  529. package/plugins/customBorders/contextMenuItem/bottom.js +0 -17
  530. package/plugins/customBorders/contextMenuItem/bottom.mjs +0 -3
  531. package/plugins/customBorders/contextMenuItem/index.js +0 -11
  532. package/plugins/customBorders/contextMenuItem/left.js +0 -17
  533. package/plugins/customBorders/contextMenuItem/left.mjs +0 -3
  534. package/plugins/customBorders/contextMenuItem/noBorders.js +0 -15
  535. package/plugins/customBorders/contextMenuItem/noBorders.mjs +0 -1
  536. package/plugins/customBorders/contextMenuItem/right.js +0 -17
  537. package/plugins/customBorders/contextMenuItem/right.mjs +0 -3
  538. package/plugins/customBorders/contextMenuItem/top.js +0 -17
  539. package/plugins/customBorders/contextMenuItem/top.mjs +0 -3
  540. package/plugins/customBorders/customBorders.js +64 -188
  541. package/plugins/customBorders/customBorders.mjs +63 -153
  542. package/plugins/customBorders/index.js +0 -2
  543. package/plugins/customBorders/utils.js +13 -52
  544. package/plugins/customBorders/utils.mjs +13 -31
  545. package/plugins/dragToScroll/dragToScroll.js +23 -75
  546. package/plugins/dragToScroll/dragToScroll.mjs +23 -56
  547. package/plugins/dragToScroll/index.js +0 -2
  548. package/plugins/dropdownMenu/dropdownMenu.js +49 -127
  549. package/plugins/dropdownMenu/dropdownMenu.mjs +49 -96
  550. package/plugins/dropdownMenu/index.js +0 -2
  551. package/plugins/exportFile/dataProvider.js +34 -72
  552. package/plugins/exportFile/dataProvider.mjs +31 -58
  553. package/plugins/exportFile/exportFile.js +56 -61
  554. package/plugins/exportFile/exportFile.mjs +54 -37
  555. package/plugins/exportFile/index.js +0 -2
  556. package/plugins/exportFile/typeFactory.js +15 -12
  557. package/plugins/exportFile/typeFactory.mjs +15 -5
  558. package/plugins/exportFile/types/_base.js +15 -15
  559. package/plugins/exportFile/types/_base.mjs +15 -13
  560. package/plugins/exportFile/types/csv.js +8 -51
  561. package/plugins/exportFile/types/csv.mjs +8 -30
  562. package/plugins/filters/component/_base.js +25 -31
  563. package/plugins/filters/component/_base.mjs +25 -26
  564. package/plugins/filters/component/actionBar.js +13 -56
  565. package/plugins/filters/component/actionBar.mjs +11 -34
  566. package/plugins/filters/component/condition.js +22 -95
  567. package/plugins/filters/component/condition.mjs +20 -63
  568. package/plugins/filters/component/operators.js +18 -71
  569. package/plugins/filters/component/operators.mjs +18 -48
  570. package/plugins/filters/component/value.js +22 -97
  571. package/plugins/filters/component/value.mjs +22 -67
  572. package/plugins/filters/condition/beginsWith.js +3 -33
  573. package/plugins/filters/condition/beginsWith.mjs +3 -11
  574. package/plugins/filters/condition/between.js +4 -38
  575. package/plugins/filters/condition/between.mjs +4 -16
  576. package/plugins/filters/condition/byValue.js +4 -28
  577. package/plugins/filters/condition/byValue.mjs +4 -13
  578. package/plugins/filters/condition/contains.js +3 -33
  579. package/plugins/filters/condition/contains.mjs +3 -11
  580. package/plugins/filters/condition/date/after.js +3 -35
  581. package/plugins/filters/condition/date/after.mjs +3 -13
  582. package/plugins/filters/condition/date/before.js +3 -35
  583. package/plugins/filters/condition/date/before.mjs +3 -13
  584. package/plugins/filters/condition/date/today.js +1 -22
  585. package/plugins/filters/condition/date/today.mjs +1 -3
  586. package/plugins/filters/condition/date/tomorrow.js +1 -22
  587. package/plugins/filters/condition/date/tomorrow.mjs +1 -3
  588. package/plugins/filters/condition/date/yesterday.js +1 -22
  589. package/plugins/filters/condition/date/yesterday.mjs +1 -3
  590. package/plugins/filters/condition/empty.js +1 -19
  591. package/plugins/filters/condition/empty.mjs +1 -1
  592. package/plugins/filters/condition/endsWith.js +3 -33
  593. package/plugins/filters/condition/endsWith.mjs +3 -11
  594. package/plugins/filters/condition/equal.js +3 -32
  595. package/plugins/filters/condition/equal.mjs +3 -11
  596. package/plugins/filters/condition/false.js +1 -5
  597. package/plugins/filters/condition/false.mjs +1 -1
  598. package/plugins/filters/condition/greaterThan.js +3 -33
  599. package/plugins/filters/condition/greaterThan.mjs +3 -13
  600. package/plugins/filters/condition/greaterThanOrEqual.js +3 -33
  601. package/plugins/filters/condition/greaterThanOrEqual.mjs +3 -13
  602. package/plugins/filters/condition/lessThan.js +3 -33
  603. package/plugins/filters/condition/lessThan.mjs +3 -13
  604. package/plugins/filters/condition/lessThanOrEqual.js +3 -33
  605. package/plugins/filters/condition/lessThanOrEqual.mjs +3 -13
  606. package/plugins/filters/condition/none.js +1 -18
  607. package/plugins/filters/condition/none.mjs +1 -1
  608. package/plugins/filters/condition/notBetween.js +1 -19
  609. package/plugins/filters/condition/notBetween.mjs +1 -1
  610. package/plugins/filters/condition/notContains.js +1 -19
  611. package/plugins/filters/condition/notContains.mjs +1 -1
  612. package/plugins/filters/condition/notEmpty.js +1 -19
  613. package/plugins/filters/condition/notEmpty.mjs +1 -1
  614. package/plugins/filters/condition/notEqual.js +1 -19
  615. package/plugins/filters/condition/notEqual.mjs +1 -1
  616. package/plugins/filters/condition/true.js +1 -5
  617. package/plugins/filters/condition/true.mjs +1 -1
  618. package/plugins/filters/conditionCollection.js +31 -84
  619. package/plugins/filters/conditionCollection.mjs +39 -69
  620. package/plugins/filters/conditionRegisterer.js +5 -14
  621. package/plugins/filters/conditionRegisterer.mjs +5 -9
  622. package/plugins/filters/conditionUpdateObserver.js +29 -56
  623. package/plugins/filters/conditionUpdateObserver.mjs +29 -44
  624. package/plugins/filters/constants.js +15 -67
  625. package/plugins/filters/constants.mjs +15 -9
  626. package/plugins/filters/dataFilter.js +17 -20
  627. package/plugins/filters/dataFilter.mjs +17 -19
  628. package/plugins/filters/filters.js +110 -210
  629. package/plugins/filters/filters.mjs +110 -165
  630. package/plugins/filters/index.js +0 -2
  631. package/plugins/filters/logicalOperationRegisterer.js +3 -9
  632. package/plugins/filters/logicalOperationRegisterer.mjs +3 -4
  633. package/plugins/filters/logicalOperations/conjunction.js +2 -19
  634. package/plugins/filters/logicalOperations/conjunction.mjs +2 -2
  635. package/plugins/filters/logicalOperations/disjunction.js +2 -19
  636. package/plugins/filters/logicalOperations/disjunction.mjs +2 -2
  637. package/plugins/filters/logicalOperations/disjunctionWithExtraCondition.js +2 -21
  638. package/plugins/filters/logicalOperations/disjunctionWithExtraCondition.mjs +2 -3
  639. package/plugins/filters/ui/_base.js +24 -62
  640. package/plugins/filters/ui/_base.mjs +26 -36
  641. package/plugins/filters/ui/input.js +13 -53
  642. package/plugins/filters/ui/input.mjs +13 -35
  643. package/plugins/filters/ui/link.js +9 -44
  644. package/plugins/filters/ui/link.mjs +9 -26
  645. package/plugins/filters/ui/multipleSelect.js +25 -113
  646. package/plugins/filters/ui/multipleSelect.mjs +26 -77
  647. package/plugins/filters/ui/radioInput.js +12 -48
  648. package/plugins/filters/ui/radioInput.mjs +12 -31
  649. package/plugins/filters/ui/select.js +20 -77
  650. package/plugins/filters/ui/select.mjs +20 -53
  651. package/plugins/filters/utils.js +6 -39
  652. package/plugins/filters/utils.mjs +6 -23
  653. package/plugins/formulas/engine/register.js +24 -74
  654. package/plugins/formulas/engine/register.mjs +24 -45
  655. package/plugins/formulas/engine/settings.js +16 -25
  656. package/plugins/formulas/engine/settings.mjs +16 -13
  657. package/plugins/formulas/formulas.js +127 -306
  658. package/plugins/formulas/formulas.mjs +128 -259
  659. package/plugins/formulas/index.js +0 -2
  660. package/plugins/formulas/utils.js +1 -3
  661. package/plugins/formulas/utils.mjs +1 -1
  662. package/plugins/hiddenColumns/contextMenuItem/hideColumn.js +5 -39
  663. package/plugins/hiddenColumns/contextMenuItem/hideColumn.mjs +5 -21
  664. package/plugins/hiddenColumns/contextMenuItem/showColumn.js +17 -45
  665. package/plugins/hiddenColumns/contextMenuItem/showColumn.mjs +17 -24
  666. package/plugins/hiddenColumns/hiddenColumns.js +77 -150
  667. package/plugins/hiddenColumns/hiddenColumns.mjs +77 -109
  668. package/plugins/hiddenColumns/index.js +0 -2
  669. package/plugins/hiddenRows/contextMenuItem/hideRow.js +5 -39
  670. package/plugins/hiddenRows/contextMenuItem/hideRow.mjs +5 -21
  671. package/plugins/hiddenRows/contextMenuItem/showRow.js +17 -45
  672. package/plugins/hiddenRows/contextMenuItem/showRow.mjs +17 -24
  673. package/plugins/hiddenRows/hiddenRows.js +75 -149
  674. package/plugins/hiddenRows/hiddenRows.mjs +75 -108
  675. package/plugins/hiddenRows/index.js +0 -2
  676. package/plugins/index.js +0 -71
  677. package/plugins/index.mjs +0 -1
  678. package/plugins/manualColumnFreeze/contextMenuItem/freezeColumn.js +2 -29
  679. package/plugins/manualColumnFreeze/contextMenuItem/freezeColumn.mjs +2 -13
  680. package/plugins/manualColumnFreeze/contextMenuItem/unfreezeColumn.js +2 -29
  681. package/plugins/manualColumnFreeze/contextMenuItem/unfreezeColumn.mjs +2 -13
  682. package/plugins/manualColumnFreeze/index.js +0 -2
  683. package/plugins/manualColumnFreeze/manualColumnFreeze.js +27 -79
  684. package/plugins/manualColumnFreeze/manualColumnFreeze.mjs +27 -55
  685. package/plugins/manualColumnMove/index.js +0 -2
  686. package/plugins/manualColumnMove/manualColumnMove.js +51 -135
  687. package/plugins/manualColumnMove/manualColumnMove.mjs +51 -107
  688. package/plugins/manualColumnMove/ui/_base.js +26 -31
  689. package/plugins/manualColumnMove/ui/_base.mjs +26 -28
  690. package/plugins/manualColumnMove/ui/backlight.js +7 -38
  691. package/plugins/manualColumnMove/ui/backlight.mjs +7 -23
  692. package/plugins/manualColumnMove/ui/guideline.js +7 -38
  693. package/plugins/manualColumnMove/ui/guideline.mjs +7 -23
  694. package/plugins/manualColumnResize/index.js +0 -2
  695. package/plugins/manualColumnResize/manualColumnResize.js +50 -144
  696. package/plugins/manualColumnResize/manualColumnResize.mjs +49 -119
  697. package/plugins/manualRowMove/index.js +0 -2
  698. package/plugins/manualRowMove/manualRowMove.js +51 -138
  699. package/plugins/manualRowMove/manualRowMove.mjs +51 -110
  700. package/plugins/manualRowMove/ui/_base.js +26 -28
  701. package/plugins/manualRowMove/ui/_base.mjs +26 -27
  702. package/plugins/manualRowMove/ui/backlight.js +7 -38
  703. package/plugins/manualRowMove/ui/backlight.mjs +7 -23
  704. package/plugins/manualRowMove/ui/guideline.js +7 -38
  705. package/plugins/manualRowMove/ui/guideline.mjs +7 -23
  706. package/plugins/manualRowResize/index.js +0 -2
  707. package/plugins/manualRowResize/manualRowResize.js +48 -139
  708. package/plugins/manualRowResize/manualRowResize.mjs +47 -113
  709. package/plugins/mergeCells/calculations/autofill.js +49 -133
  710. package/plugins/mergeCells/calculations/autofill.mjs +46 -117
  711. package/plugins/mergeCells/calculations/selection.js +22 -39
  712. package/plugins/mergeCells/calculations/selection.mjs +22 -36
  713. package/plugins/mergeCells/cellCoords.js +43 -50
  714. package/plugins/mergeCells/cellCoords.mjs +43 -48
  715. package/plugins/mergeCells/cellsCollection.js +22 -86
  716. package/plugins/mergeCells/cellsCollection.mjs +19 -63
  717. package/plugins/mergeCells/contextMenuItem/toggleMerge.js +0 -22
  718. package/plugins/mergeCells/contextMenuItem/toggleMerge.mjs +0 -6
  719. package/plugins/mergeCells/index.js +0 -2
  720. package/plugins/mergeCells/mergeCells.js +136 -334
  721. package/plugins/mergeCells/mergeCells.mjs +136 -293
  722. package/plugins/mergeCells/utils.js +0 -3
  723. package/plugins/mergeCells/utils.mjs +0 -1
  724. package/plugins/multiColumnSorting/domHelpers.js +2 -12
  725. package/plugins/multiColumnSorting/domHelpers.mjs +2 -5
  726. package/plugins/multiColumnSorting/index.js +0 -2
  727. package/plugins/multiColumnSorting/multiColumnSorting.js +20 -67
  728. package/plugins/multiColumnSorting/multiColumnSorting.mjs +20 -45
  729. package/plugins/multiColumnSorting/rootComparator.js +2 -26
  730. package/plugins/multiColumnSorting/rootComparator.mjs +2 -15
  731. package/plugins/multiColumnSorting/utils.js +0 -7
  732. package/plugins/multiColumnSorting/utils.mjs +0 -4
  733. package/plugins/multipleSelectionHandles/index.js +0 -2
  734. package/plugins/multipleSelectionHandles/multipleSelectionHandles.js +12 -110
  735. package/plugins/multipleSelectionHandles/multipleSelectionHandles.mjs +12 -88
  736. package/plugins/nestedHeaders/index.js +0 -2
  737. package/plugins/nestedHeaders/nestedHeaders.js +198 -211
  738. package/plugins/nestedHeaders/nestedHeaders.mjs +206 -191
  739. package/plugins/nestedHeaders/stateManager/headersTree.js +26 -96
  740. package/plugins/nestedHeaders/stateManager/headersTree.mjs +26 -76
  741. package/plugins/nestedHeaders/stateManager/index.js +55 -118
  742. package/plugins/nestedHeaders/stateManager/index.mjs +61 -105
  743. package/plugins/nestedHeaders/stateManager/matrixGenerator.js +7 -25
  744. package/plugins/nestedHeaders/stateManager/matrixGenerator.mjs +7 -18
  745. package/plugins/nestedHeaders/stateManager/nodeModifiers/collapse.js +12 -27
  746. package/plugins/nestedHeaders/stateManager/nodeModifiers/collapse.mjs +12 -17
  747. package/plugins/nestedHeaders/stateManager/nodeModifiers/expand.js +10 -25
  748. package/plugins/nestedHeaders/stateManager/nodeModifiers/expand.mjs +10 -15
  749. package/plugins/nestedHeaders/stateManager/nodeModifiers/hideColumn.js +3 -19
  750. package/plugins/nestedHeaders/stateManager/nodeModifiers/hideColumn.mjs +3 -13
  751. package/plugins/nestedHeaders/stateManager/nodeModifiers/index.js +2 -12
  752. package/plugins/nestedHeaders/stateManager/nodeModifiers/index.mjs +1 -3
  753. package/plugins/nestedHeaders/stateManager/nodeModifiers/showColumn.js +3 -22
  754. package/plugins/nestedHeaders/stateManager/nodeModifiers/showColumn.mjs +3 -14
  755. package/plugins/nestedHeaders/stateManager/nodeModifiers/utils/tree.js +3 -10
  756. package/plugins/nestedHeaders/stateManager/nodeModifiers/utils/tree.mjs +3 -7
  757. package/plugins/nestedHeaders/stateManager/settingsNormalizer.js +5 -36
  758. package/plugins/nestedHeaders/stateManager/settingsNormalizer.mjs +5 -20
  759. package/plugins/nestedHeaders/stateManager/sourceSettings.js +27 -81
  760. package/plugins/nestedHeaders/stateManager/sourceSettings.mjs +33 -71
  761. package/plugins/nestedHeaders/stateManager/utils.js +19 -22
  762. package/plugins/nestedHeaders/stateManager/utils.mjs +19 -20
  763. package/plugins/nestedHeaders/utils/ghostTable.js +23 -37
  764. package/plugins/nestedHeaders/utils/ghostTable.mjs +23 -36
  765. package/plugins/nestedRows/data/dataManager.js +47 -162
  766. package/plugins/nestedRows/data/dataManager.mjs +45 -143
  767. package/plugins/nestedRows/index.js +0 -2
  768. package/plugins/nestedRows/nestedRows.js +46 -119
  769. package/plugins/nestedRows/nestedRows.mjs +46 -86
  770. package/plugins/nestedRows/ui/_base.js +14 -8
  771. package/plugins/nestedRows/ui/_base.mjs +14 -7
  772. package/plugins/nestedRows/ui/collapsing.js +33 -133
  773. package/plugins/nestedRows/ui/collapsing.mjs +33 -111
  774. package/plugins/nestedRows/ui/contextMenu.js +9 -55
  775. package/plugins/nestedRows/ui/contextMenu.mjs +8 -33
  776. package/plugins/nestedRows/ui/headers.js +10 -49
  777. package/plugins/nestedRows/ui/headers.mjs +10 -34
  778. package/plugins/nestedRows/utils/rowMoveController.js +36 -79
  779. package/plugins/nestedRows/utils/rowMoveController.mjs +45 -71
  780. package/plugins/persistentState/index.js +0 -2
  781. package/plugins/persistentState/persistentState.js +16 -59
  782. package/plugins/persistentState/persistentState.mjs +16 -38
  783. package/plugins/persistentState/storage.js +22 -24
  784. package/plugins/persistentState/storage.mjs +22 -22
  785. package/plugins/registry.js +8 -52
  786. package/plugins/registry.mjs +8 -33
  787. package/plugins/search/index.js +0 -2
  788. package/plugins/search/search.js +22 -97
  789. package/plugins/search/search.mjs +22 -68
  790. package/plugins/touchScroll/index.js +0 -2
  791. package/plugins/touchScroll/touchScroll.js +21 -77
  792. package/plugins/touchScroll/touchScroll.mjs +21 -59
  793. package/plugins/trimRows/index.js +0 -2
  794. package/plugins/trimRows/trimRows.js +64 -86
  795. package/plugins/trimRows/trimRows.mjs +64 -63
  796. package/plugins/undoRedo/index.js +0 -14
  797. package/plugins/undoRedo/undoRedo.js +98 -250
  798. package/plugins/undoRedo/undoRedo.mjs +98 -220
  799. package/registry.js +0 -11
  800. package/registry.mjs +1 -2
  801. package/renderers/autocompleteRenderer/autocompleteRenderer.js +5 -14
  802. package/renderers/autocompleteRenderer/autocompleteRenderer.mjs +5 -6
  803. package/renderers/autocompleteRenderer/index.js +0 -2
  804. package/renderers/baseRenderer/baseRenderer.js +2 -11
  805. package/renderers/baseRenderer/baseRenderer.mjs +1 -7
  806. package/renderers/baseRenderer/index.js +0 -2
  807. package/renderers/checkboxRenderer/checkboxRenderer.js +22 -103
  808. package/renderers/checkboxRenderer/checkboxRenderer.mjs +22 -81
  809. package/renderers/checkboxRenderer/index.js +0 -2
  810. package/renderers/htmlRenderer/htmlRenderer.js +1 -7
  811. package/renderers/htmlRenderer/htmlRenderer.mjs +1 -1
  812. package/renderers/htmlRenderer/index.js +0 -2
  813. package/renderers/index.js +0 -19
  814. package/renderers/index.mjs +0 -1
  815. package/renderers/numericRenderer/index.js +0 -2
  816. package/renderers/numericRenderer/numericRenderer.js +1 -21
  817. package/renderers/numericRenderer/numericRenderer.mjs +1 -9
  818. package/renderers/passwordRenderer/index.js +0 -2
  819. package/renderers/passwordRenderer/passwordRenderer.js +1 -8
  820. package/renderers/passwordRenderer/passwordRenderer.mjs +1 -1
  821. package/renderers/registry.js +7 -16
  822. package/renderers/registry.mjs +7 -14
  823. package/renderers/textRenderer/index.js +0 -2
  824. package/renderers/textRenderer/textRenderer.js +1 -13
  825. package/renderers/textRenderer/textRenderer.mjs +1 -5
  826. package/renderers/timeRenderer/index.js +0 -2
  827. package/renderers/timeRenderer/timeRenderer.js +1 -6
  828. package/renderers/timeRenderer/timeRenderer.mjs +1 -1
  829. package/selection/highlight/highlight.js +24 -73
  830. package/selection/highlight/highlight.mjs +24 -50
  831. package/selection/highlight/types/activeHeader.js +14 -23
  832. package/selection/highlight/types/activeHeader.mjs +14 -12
  833. package/selection/highlight/types/area.js +15 -24
  834. package/selection/highlight/types/area.mjs +15 -13
  835. package/selection/highlight/types/cell.js +14 -23
  836. package/selection/highlight/types/cell.mjs +14 -12
  837. package/selection/highlight/types/customSelection.js +15 -24
  838. package/selection/highlight/types/customSelection.mjs +15 -13
  839. package/selection/highlight/types/fill.js +16 -20
  840. package/selection/highlight/types/fill.mjs +16 -9
  841. package/selection/highlight/types/header.js +16 -25
  842. package/selection/highlight/types/header.mjs +16 -14
  843. package/selection/highlight/types/index.js +17 -27
  844. package/selection/highlight/types/index.mjs +17 -13
  845. package/selection/highlight/visualSelection.js +35 -80
  846. package/selection/highlight/visualSelection.mjs +35 -68
  847. package/selection/index.js +0 -14
  848. package/selection/mouseEventHandler.js +19 -30
  849. package/selection/mouseEventHandler.mjs +19 -22
  850. package/selection/range.js +17 -30
  851. package/selection/range.mjs +17 -21
  852. package/selection/selection.js +72 -160
  853. package/selection/selection.mjs +77 -137
  854. package/selection/transformation.js +23 -39
  855. package/selection/transformation.mjs +23 -36
  856. package/selection/utils.js +23 -71
  857. package/selection/utils.mjs +23 -48
  858. package/shortcuts/context.js +24 -79
  859. package/shortcuts/context.mjs +24 -56
  860. package/shortcuts/index.js +0 -2
  861. package/shortcuts/keyObserver.js +0 -9
  862. package/shortcuts/keyObserver.mjs +0 -4
  863. package/shortcuts/manager.js +17 -37
  864. package/shortcuts/manager.mjs +17 -34
  865. package/shortcuts/recorder.js +9 -40
  866. package/shortcuts/recorder.mjs +9 -31
  867. package/shortcuts/utils.js +5 -20
  868. package/shortcuts/utils.mjs +5 -6
  869. package/tableView.js +239 -330
  870. package/tableView.mjs +239 -308
  871. package/translations/changesObservable/observable.js +14 -53
  872. package/translations/changesObservable/observable.mjs +14 -43
  873. package/translations/changesObservable/observer.js +13 -31
  874. package/translations/changesObservable/observer.mjs +13 -23
  875. package/translations/changesObservable/utils.js +1 -5
  876. package/translations/changesObservable/utils.mjs +1 -4
  877. package/translations/index.js +0 -11
  878. package/translations/indexMapper.js +80 -162
  879. package/translations/indexMapper.mjs +85 -134
  880. package/translations/mapCollections/aggregatedCollection.js +14 -50
  881. package/translations/mapCollections/aggregatedCollection.mjs +14 -37
  882. package/translations/mapCollections/index.js +0 -7
  883. package/translations/mapCollections/mapCollection.js +20 -34
  884. package/translations/mapCollections/mapCollection.mjs +20 -23
  885. package/translations/maps/hidingMap.js +7 -34
  886. package/translations/maps/hidingMap.mjs +7 -22
  887. package/translations/maps/index.js +1 -24
  888. package/translations/maps/index.mjs +1 -3
  889. package/translations/maps/indexMap.js +25 -33
  890. package/translations/maps/indexMap.mjs +25 -27
  891. package/translations/maps/indexesSequence.js +8 -40
  892. package/translations/maps/indexesSequence.mjs +8 -25
  893. package/translations/maps/linkedPhysicalIndexToValueMap.js +18 -81
  894. package/translations/maps/linkedPhysicalIndexToValueMap.mjs +17 -54
  895. package/translations/maps/physicalIndexToValueMap.js +7 -38
  896. package/translations/maps/physicalIndexToValueMap.mjs +7 -24
  897. package/translations/maps/trimmingMap.js +7 -34
  898. package/translations/maps/trimmingMap.mjs +7 -22
  899. package/translations/maps/utils/actionsOnIndexes.js +1 -7
  900. package/translations/maps/utils/actionsOnIndexes.mjs +1 -3
  901. package/translations/maps/utils/index.js +0 -13
  902. package/translations/maps/utils/index.mjs +0 -3
  903. package/translations/maps/utils/indexesSequence.js +1 -24
  904. package/translations/maps/utils/indexesSequence.mjs +1 -9
  905. package/translations/maps/utils/physicallyIndexed.js +1 -27
  906. package/translations/maps/utils/physicallyIndexed.mjs +1 -10
  907. package/utils/dataStructures/linkedList.js +23 -50
  908. package/utils/dataStructures/linkedList.mjs +23 -48
  909. package/utils/dataStructures/priorityMap.js +9 -47
  910. package/utils/dataStructures/priorityMap.mjs +9 -30
  911. package/utils/dataStructures/queue.js +19 -16
  912. package/utils/dataStructures/queue.mjs +19 -15
  913. package/utils/dataStructures/stack.js +19 -16
  914. package/utils/dataStructures/stack.mjs +19 -15
  915. package/utils/dataStructures/tree.js +19 -77
  916. package/utils/dataStructures/tree.mjs +19 -56
  917. package/utils/dataStructures/uniqueMap.js +18 -57
  918. package/utils/dataStructures/uniqueMap.mjs +18 -43
  919. package/utils/dataStructures/uniqueSet.js +5 -32
  920. package/utils/dataStructures/uniqueSet.mjs +5 -19
  921. package/utils/ghostTable.js +42 -106
  922. package/utils/ghostTable.mjs +40 -90
  923. package/utils/interval.js +17 -29
  924. package/utils/interval.mjs +18 -26
  925. package/utils/parseTable.js +11 -92
  926. package/utils/parseTable.mjs +11 -62
  927. package/utils/rootInstance.js +3 -14
  928. package/utils/rootInstance.mjs +3 -3
  929. package/utils/samplesGenerator.js +25 -51
  930. package/utils/samplesGenerator.mjs +25 -42
  931. package/utils/staticRegister.js +6 -33
  932. package/utils/staticRegister.mjs +6 -19
  933. package/validators/autocompleteValidator/autocompleteValidator.js +2 -10
  934. package/validators/autocompleteValidator/autocompleteValidator.mjs +2 -8
  935. package/validators/autocompleteValidator/index.js +0 -2
  936. package/validators/dateValidator/dateValidator.js +2 -21
  937. package/validators/dateValidator/dateValidator.mjs +2 -11
  938. package/validators/dateValidator/index.js +0 -2
  939. package/validators/index.js +0 -11
  940. package/validators/index.mjs +0 -1
  941. package/validators/numericValidator/index.js +0 -2
  942. package/validators/numericValidator/numericValidator.js +1 -7
  943. package/validators/numericValidator/numericValidator.mjs +1 -3
  944. package/validators/registry.js +7 -16
  945. package/validators/registry.mjs +7 -14
  946. package/validators/timeValidator/index.js +0 -2
  947. package/validators/timeValidator/timeValidator.js +6 -18
  948. package/validators/timeValidator/timeValidator.mjs +8 -13
@@ -1,179 +1,105 @@
1
1
  "use strict";
2
2
 
3
+ require("core-js/modules/es.symbol.to-primitive.js");
4
+ require("core-js/modules/es.date.to-primitive.js");
5
+ require("core-js/modules/es.symbol.js");
6
+ require("core-js/modules/es.symbol.description.js");
7
+ require("core-js/modules/es.number.constructor.js");
3
8
  require("core-js/modules/es.object.set-prototype-of.js");
4
-
5
9
  require("core-js/modules/es.object.get-prototype-of.js");
6
-
7
10
  require("core-js/modules/es.reflect.construct.js");
8
-
9
11
  require("core-js/modules/es.reflect.get.js");
10
-
11
12
  require("core-js/modules/es.object.get-own-property-descriptor.js");
12
-
13
- require("core-js/modules/es.symbol.js");
14
-
15
- require("core-js/modules/es.symbol.description.js");
16
-
17
13
  require("core-js/modules/es.symbol.iterator.js");
18
-
19
14
  require("core-js/modules/es.array.slice.js");
20
-
21
15
  require("core-js/modules/es.function.name.js");
22
-
23
16
  require("core-js/modules/es.array.from.js");
24
-
25
17
  require("core-js/modules/es.regexp.exec.js");
26
-
27
18
  require("core-js/modules/es.object.keys.js");
28
-
29
19
  require("core-js/modules/es.array.filter.js");
30
-
31
20
  require("core-js/modules/es.object.get-own-property-descriptors.js");
32
-
33
21
  exports.__esModule = true;
34
22
  exports.PLUGIN_PRIORITY = exports.PLUGIN_KEY = exports.Formulas = void 0;
35
-
36
23
  require("core-js/modules/es.array.concat.js");
37
-
38
24
  require("core-js/modules/es.object.to-string.js");
39
-
40
25
  require("core-js/modules/web.dom-collections.for-each.js");
41
-
42
26
  require("core-js/modules/es.array.iterator.js");
43
-
44
27
  require("core-js/modules/es.set.js");
45
-
46
28
  require("core-js/modules/es.string.iterator.js");
47
-
48
29
  require("core-js/modules/web.dom-collections.iterator.js");
49
-
50
30
  require("core-js/modules/es.array.map.js");
51
-
52
31
  require("core-js/modules/es.array.includes.js");
53
-
54
32
  require("core-js/modules/es.string.includes.js");
55
-
56
33
  require("core-js/modules/es.array.reverse.js");
57
-
58
34
  require("core-js/modules/es.array.sort.js");
59
-
60
35
  require("core-js/modules/es.weak-map.js");
61
-
62
36
  var _base = require("../base");
63
-
64
37
  var _staticRegister = _interopRequireDefault(require("../../utils/staticRegister"));
65
-
66
38
  var _console = require("../../helpers/console");
67
-
68
39
  var _number = require("../../helpers/number");
69
-
70
40
  var _mixed = require("../../helpers/mixed");
71
-
72
41
  var _register = require("./engine/register");
73
-
74
42
  var _utils = require("./utils");
75
-
76
43
  var _settings = require("./engine/settings");
77
-
78
44
  var _data = require("../../helpers/data");
79
-
80
45
  var _string = require("../../helpers/string");
81
-
82
46
  var _pluginHooks = _interopRequireDefault(require("../../pluginHooks"));
83
-
84
47
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
85
-
86
48
  function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
87
-
88
49
  function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
89
-
90
50
  function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
91
-
92
51
  function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
93
-
94
52
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
95
-
96
53
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
97
-
98
54
  function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
99
-
100
55
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
101
-
102
56
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
103
-
104
57
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
105
-
106
58
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
107
-
108
- function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
109
-
59
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0) { ; } } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
110
60
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
111
-
112
61
  function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
113
-
114
- function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
115
-
62
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
116
63
  function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
117
-
118
64
  function _get() { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get.bind(); } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(arguments.length < 3 ? target : receiver); } return desc.value; }; } return _get.apply(this, arguments); }
119
-
120
65
  function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }
121
-
122
66
  function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
123
-
124
67
  function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
125
-
126
68
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
127
-
128
69
  function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
129
-
130
70
  function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
131
-
132
71
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
133
-
134
72
  function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
135
-
136
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
137
-
73
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
74
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
75
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
138
76
  function _classPrivateFieldInitSpec(obj, privateMap, value) { _checkPrivateRedeclaration(obj, privateMap); privateMap.set(obj, value); }
139
-
140
77
  function _checkPrivateRedeclaration(obj, privateCollection) { if (privateCollection.has(obj)) { throw new TypeError("Cannot initialize the same private elements twice on an object"); } }
141
-
142
78
  function _classPrivateFieldSet(receiver, privateMap, value) { var descriptor = _classExtractFieldDescriptor(receiver, privateMap, "set"); _classApplyDescriptorSet(receiver, descriptor, value); return value; }
143
-
144
79
  function _classApplyDescriptorSet(receiver, descriptor, value) { if (descriptor.set) { descriptor.set.call(receiver, value); } else { if (!descriptor.writable) { throw new TypeError("attempted to set read only private field"); } descriptor.value = value; } }
145
-
146
80
  function _classPrivateFieldGet(receiver, privateMap) { var descriptor = _classExtractFieldDescriptor(receiver, privateMap, "get"); return _classApplyDescriptorGet(receiver, descriptor); }
147
-
148
81
  function _classExtractFieldDescriptor(receiver, privateMap, action) { if (!privateMap.has(receiver)) { throw new TypeError("attempted to " + action + " private field on non-instance"); } return privateMap.get(receiver); }
149
-
150
82
  function _classApplyDescriptorGet(receiver, descriptor) { if (descriptor.get) { return descriptor.get.call(receiver); } return descriptor.value; }
151
-
152
83
  var PLUGIN_KEY = 'formulas';
153
84
  exports.PLUGIN_KEY = PLUGIN_KEY;
154
85
  var PLUGIN_PRIORITY = 260;
155
86
  exports.PLUGIN_PRIORITY = PLUGIN_PRIORITY;
156
87
  var ROW_MOVE_UNDO_REDO_NAME = 'row_move';
157
-
158
88
  _pluginHooks.default.getSingleton().register('afterNamedExpressionAdded');
159
-
160
89
  _pluginHooks.default.getSingleton().register('afterNamedExpressionRemoved');
161
-
162
90
  _pluginHooks.default.getSingleton().register('afterSheetAdded');
163
-
164
91
  _pluginHooks.default.getSingleton().register('afterSheetRemoved');
165
-
166
92
  _pluginHooks.default.getSingleton().register('afterSheetRenamed');
93
+ _pluginHooks.default.getSingleton().register('afterFormulasValuesUpdate');
167
94
 
168
- _pluginHooks.default.getSingleton().register('afterFormulasValuesUpdate'); // This function will be used for detecting changes coming from the `UndoRedo` plugin. This kind of change won't be
95
+ // This function will be used for detecting changes coming from the `UndoRedo` plugin. This kind of change won't be
169
96
  // handled by whole body of listeners and therefore won't change undo/redo stack inside engine provided by HyperFormula.
170
97
  // HyperFormula's `undo` and `redo` methods will do it instead. Please keep in mind that undo/redo stacks inside
171
98
  // instances of Handsontable and HyperFormula should be synced (number of actions should be the same).
172
-
173
-
174
99
  var isBlockedSource = function isBlockedSource(source) {
175
100
  return source === 'UndoRedo.undo' || source === 'UndoRedo.redo' || source === 'auto';
176
101
  };
102
+
177
103
  /**
178
104
  * This plugin allows you to perform Excel-like calculations in your business applications. It does it by an
179
105
  * integration with our other product, [HyperFormula](https://github.com/handsontable/hyperformula/), which is a
@@ -184,78 +110,54 @@ var isBlockedSource = function isBlockedSource(source) {
184
110
  * @plugin Formulas
185
111
  * @class Formulas
186
112
  */
187
-
188
-
189
113
  var _internalOperationPending = /*#__PURE__*/new WeakMap();
190
-
191
114
  var _hotWasInitializedWithEmptyData = /*#__PURE__*/new WeakMap();
192
-
193
115
  var _engineListeners = /*#__PURE__*/new WeakMap();
194
-
195
116
  var Formulas = /*#__PURE__*/function (_BasePlugin) {
196
117
  _inherits(Formulas, _BasePlugin);
197
-
198
118
  var _super = _createSuper(Formulas);
199
-
200
119
  function Formulas() {
201
120
  var _this;
202
-
203
121
  _classCallCheck(this, Formulas);
204
-
205
122
  for (var _len = arguments.length, _args = new Array(_len), _key = 0; _key < _len; _key++) {
206
123
  _args[_key] = arguments[_key];
207
124
  }
208
-
209
125
  _this = _super.call.apply(_super, [this].concat(_args));
210
-
211
126
  _classPrivateFieldInitSpec(_assertThisInitialized(_this), _internalOperationPending, {
212
127
  writable: true,
213
128
  value: false
214
129
  });
215
-
216
130
  _classPrivateFieldInitSpec(_assertThisInitialized(_this), _hotWasInitializedWithEmptyData, {
217
131
  writable: true,
218
132
  value: false
219
133
  });
220
-
221
134
  _classPrivateFieldInitSpec(_assertThisInitialized(_this), _engineListeners, {
222
135
  writable: true,
223
136
  value: [['valuesUpdated', function () {
224
137
  var _this2;
225
-
226
138
  return (_this2 = _this).onEngineValuesUpdated.apply(_this2, arguments);
227
139
  }], ['namedExpressionAdded', function () {
228
140
  var _this3;
229
-
230
141
  return (_this3 = _this).onEngineNamedExpressionsAdded.apply(_this3, arguments);
231
142
  }], ['namedExpressionRemoved', function () {
232
143
  var _this4;
233
-
234
144
  return (_this4 = _this).onEngineNamedExpressionsRemoved.apply(_this4, arguments);
235
145
  }], ['sheetAdded', function () {
236
146
  var _this5;
237
-
238
147
  return (_this5 = _this).onEngineSheetAdded.apply(_this5, arguments);
239
148
  }], ['sheetRenamed', function () {
240
149
  var _this6;
241
-
242
150
  return (_this6 = _this).onEngineSheetRenamed.apply(_this6, arguments);
243
151
  }], ['sheetRemoved', function () {
244
152
  var _this7;
245
-
246
153
  return (_this7 = _this).onEngineSheetRemoved.apply(_this7, arguments);
247
154
  }]]
248
155
  });
249
-
250
156
  _defineProperty(_assertThisInitialized(_this), "staticRegister", (0, _staticRegister.default)('formulas'));
251
-
252
157
  _defineProperty(_assertThisInitialized(_this), "engine", null);
253
-
254
158
  _defineProperty(_assertThisInitialized(_this), "sheetName", null);
255
-
256
159
  return _this;
257
160
  }
258
-
259
161
  _createClass(Formulas, [{
260
162
  key: "sheetId",
261
163
  get:
@@ -267,55 +169,58 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
267
169
  function get() {
268
170
  return this.sheetName === null ? null : this.engine.getSheetId(this.sheetName);
269
171
  }
172
+
270
173
  /**
271
174
  * Checks if the plugin is enabled in the handsontable settings. This method is executed in {@link Hooks#beforeInit}
272
- * hook and if it returns `true` than the {@link Formulas#enablePlugin} method is called.
175
+ * hook and if it returns `true` then the {@link Formulas#enablePlugin} method is called.
273
176
  *
274
177
  * @returns {boolean}
275
178
  */
276
-
277
179
  }, {
278
180
  key: "isEnabled",
279
181
  value: function isEnabled() {
280
182
  /* eslint-disable no-unneeded-ternary */
281
183
  return this.hot.getSettings()[PLUGIN_KEY] ? true : false;
282
184
  }
185
+
283
186
  /**
284
187
  * Enables the plugin functionality for this Handsontable instance.
285
188
  */
286
-
287
189
  }, {
288
190
  key: "enablePlugin",
289
191
  value: function enablePlugin() {
290
192
  var _setupEngine,
291
- _this8 = this;
292
-
193
+ _this8 = this;
293
194
  if (this.enabled) {
294
195
  return;
295
196
  }
296
-
297
197
  this.engine = (_setupEngine = (0, _register.setupEngine)(this.hot)) !== null && _setupEngine !== void 0 ? _setupEngine : this.engine;
298
-
299
198
  if (!this.engine) {
300
199
  (0, _console.warn)('Missing the required `engine` key in the Formulas settings. Please fill it with either an' + ' engine class or an engine instance.');
301
200
  return;
302
- } // Useful for disabling -> enabling the plugin using `updateSettings` or the API.
303
-
201
+ }
304
202
 
203
+ // Useful for disabling -> enabling the plugin using `updateSettings` or the API.
305
204
  if (this.sheetName !== null && !this.engine.doesSheetExist(this.sheetName)) {
306
205
  var newSheetName = this.addSheet(this.sheetName, this.hot.getSourceDataArray());
307
-
308
206
  if (newSheetName !== false) {
309
207
  this.sheetName = newSheetName;
310
208
  }
311
209
  }
312
-
313
210
  this.addHook('beforeLoadData', function () {
314
211
  return _this8.onBeforeLoadData.apply(_this8, arguments);
315
212
  });
316
213
  this.addHook('afterLoadData', function () {
317
214
  return _this8.onAfterLoadData.apply(_this8, arguments);
318
215
  });
216
+
217
+ // The `updateData` hooks utilize the same logic as the `loadData` hooks.
218
+ this.addHook('beforeUpdateData', function () {
219
+ return _this8.onBeforeLoadData.apply(_this8, arguments);
220
+ });
221
+ this.addHook('afterUpdateData', function () {
222
+ return _this8.onAfterLoadData.apply(_this8, arguments);
223
+ });
319
224
  this.addHook('modifyData', function () {
320
225
  return _this8.onModifyData.apply(_this8, arguments);
321
226
  });
@@ -357,23 +262,23 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
357
262
  });
358
263
  this.addHook('afterRemoveCol', function () {
359
264
  return _this8.onAfterRemoveCol.apply(_this8, arguments);
360
- }); // Handling undo actions on data just using HyperFormula's UndoRedo mechanism
265
+ });
361
266
 
267
+ // Handling undo actions on data just using HyperFormula's UndoRedo mechanism
362
268
  this.addHook('beforeUndo', function (action) {
363
269
  // TODO: Move action isn't handled by HyperFormula.
364
270
  if ((action === null || action === void 0 ? void 0 : action.actionType) === ROW_MOVE_UNDO_REDO_NAME) {
365
271
  return;
366
272
  }
367
-
368
273
  _this8.engine.undo();
369
- }); // Handling redo actions on data just using HyperFormula's UndoRedo mechanism
274
+ });
370
275
 
276
+ // Handling redo actions on data just using HyperFormula's UndoRedo mechanism
371
277
  this.addHook('beforeRedo', function (action) {
372
278
  // TODO: Move action isn't handled by HyperFormula.
373
279
  if ((action === null || action === void 0 ? void 0 : action.actionType) === ROW_MOVE_UNDO_REDO_NAME) {
374
280
  return;
375
281
  }
376
-
377
282
  _this8.engine.redo();
378
283
  });
379
284
  this.addHook('afterDetachChild', function () {
@@ -382,96 +287,81 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
382
287
  this.addHook('beforeAutofill', function () {
383
288
  return _this8.onBeforeAutofill.apply(_this8, arguments);
384
289
  });
385
-
386
290
  _classPrivateFieldGet(this, _engineListeners).forEach(function (_ref) {
387
291
  var _ref2 = _slicedToArray(_ref, 2),
388
- eventName = _ref2[0],
389
- listener = _ref2[1];
390
-
292
+ eventName = _ref2[0],
293
+ listener = _ref2[1];
391
294
  return _this8.engine.on(eventName, listener);
392
295
  });
393
-
394
296
  _get(_getPrototypeOf(Formulas.prototype), "enablePlugin", this).call(this);
395
297
  }
298
+
396
299
  /**
397
300
  * Disables the plugin functionality for this Handsontable instance.
398
301
  */
399
-
400
302
  }, {
401
303
  key: "disablePlugin",
402
304
  value: function disablePlugin() {
403
305
  var _this9 = this;
404
-
405
306
  _classPrivateFieldGet(this, _engineListeners).forEach(function (_ref3) {
406
307
  var _ref4 = _slicedToArray(_ref3, 2),
407
- eventName = _ref4[0],
408
- listener = _ref4[1];
409
-
308
+ eventName = _ref4[0],
309
+ listener = _ref4[1];
410
310
  return _this9.engine.off(eventName, listener);
411
311
  });
412
-
413
312
  (0, _register.unregisterEngine)(this.engine, this.hot);
414
313
  this.engine = null;
415
-
416
314
  _get(_getPrototypeOf(Formulas.prototype), "disablePlugin", this).call(this);
417
315
  }
316
+
418
317
  /**
419
318
  * Triggered on `updateSettings`.
420
319
  *
421
320
  * @private
422
321
  * @param {object} newSettings New set of settings passed to the `updateSettings` method.
423
322
  */
424
-
425
323
  }, {
426
324
  key: "updatePlugin",
427
325
  value: function updatePlugin(newSettings) {
428
326
  this.engine.updateConfig((0, _settings.getEngineSettingsWithOverrides)(this.hot.getSettings()));
429
327
  var pluginSettings = this.hot.getSettings()[PLUGIN_KEY];
430
-
431
328
  if ((0, _mixed.isDefined)(pluginSettings) && (0, _mixed.isDefined)(pluginSettings.sheetName) && pluginSettings.sheetName !== this.sheetName) {
432
329
  this.switchSheet(pluginSettings.sheetName);
433
- } // If no data was passed to the `updateSettings` method and no sheet is connected to the instance -> create a
434
- // new sheet using the currently used data. Otherwise, it will be handled by the `afterLoadData` call.
435
-
330
+ }
436
331
 
332
+ // If no data was passed to the `updateSettings` method and no sheet is connected to the instance -> create a
333
+ // new sheet using the currently used data. Otherwise, it will be handled by the `afterLoadData` call.
437
334
  if (!newSettings.data && this.sheetName === null) {
438
335
  var sheetName = this.hot.getSettings()[PLUGIN_KEY].sheetName;
439
-
440
336
  if (sheetName && this.engine.doesSheetExist(sheetName)) {
441
337
  this.switchSheet(this.sheetName);
442
338
  } else {
443
339
  this.sheetName = this.addSheet(sheetName !== null && sheetName !== void 0 ? sheetName : void 0, this.hot.getSourceDataArray());
444
340
  }
445
341
  }
446
-
447
342
  _get(_getPrototypeOf(Formulas.prototype), "updatePlugin", this).call(this, newSettings);
448
343
  }
344
+
449
345
  /**
450
346
  * Destroys the plugin instance.
451
347
  */
452
-
453
348
  }, {
454
349
  key: "destroy",
455
350
  value: function destroy() {
456
351
  var _this10 = this;
457
-
458
352
  _classPrivateFieldGet(this, _engineListeners).forEach(function (_ref5) {
459
353
  var _this10$engine;
460
-
461
354
  var _ref6 = _slicedToArray(_ref5, 2),
462
- eventName = _ref6[0],
463
- listener = _ref6[1];
464
-
355
+ eventName = _ref6[0],
356
+ listener = _ref6[1];
465
357
  return (_this10$engine = _this10.engine) === null || _this10$engine === void 0 ? void 0 : _this10$engine.off(eventName, listener);
466
358
  });
467
-
468
359
  _classPrivateFieldSet(this, _engineListeners, null);
469
-
470
360
  (0, _register.unregisterEngine)(this.engine, this.hot);
471
361
  this.engine = null;
472
-
473
362
  _get(_getPrototypeOf(Formulas.prototype), "destroy", this).call(this);
474
363
  }
364
+
475
365
  /**
476
366
  * Helper function for `toPhysicalRowPosition` and `toPhysicalColumnPosition`.
477
367
  *
@@ -484,7 +374,6 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
484
374
  * `toPhysical` alias.
485
375
  * @returns {*}
486
376
  */
487
-
488
377
  }, {
489
378
  key: "getPhysicalIndexPosition",
490
379
  value: function getPhysicalIndexPosition(visualIndex, physicalIndex, entriesCount, sourceEntriesCount, contained) {
@@ -493,9 +382,9 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
493
382
  return sourceEntriesCount + (visualIndex - entriesCount);
494
383
  }
495
384
  }
496
-
497
385
  return physicalIndex;
498
386
  }
387
+
499
388
  /**
500
389
  * Returns the physical row index. The difference between this and Core's `toPhysical` is that it doesn't return
501
390
  * `null` on rows with indexes higher than the number of rows.
@@ -506,13 +395,13 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
506
395
  * `toPhysical` alias.
507
396
  * @returns {number} The physical row index.
508
397
  */
509
-
510
398
  }, {
511
399
  key: "toPhysicalRowPosition",
512
400
  value: function toPhysicalRowPosition(row) {
513
401
  var contained = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
514
402
  return this.getPhysicalIndexPosition(row, this.hot.toPhysicalRow(row), this.hot.countRows(), this.hot.countSourceRows(), contained);
515
403
  }
404
+
516
405
  /**
517
406
  * Returns the physical column index. The difference between this and Core's `toPhysical` is that it doesn't return
518
407
  * `null` on columns with indexes higher than the number of columns.
@@ -523,13 +412,13 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
523
412
  * `toPhysical` alias.
524
413
  * @returns {number} The physical column index.
525
414
  */
526
-
527
415
  }, {
528
416
  key: "toPhysicalColumnPosition",
529
417
  value: function toPhysicalColumnPosition(column) {
530
418
  var contained = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
531
419
  return this.getPhysicalIndexPosition(column, this.hot.toPhysicalColumn(column), this.hot.countCols(), this.hot.countSourceCols(), contained);
532
420
  }
421
+
533
422
  /**
534
423
  * Add a sheet to the shared HyperFormula instance.
535
424
  *
@@ -540,7 +429,6 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
540
429
  * @returns {boolean|string} `false` if the data format is unusable or it is impossible to add a new sheet to the
541
430
  * engine, the created sheet name otherwise.
542
431
  */
543
-
544
432
  }, {
545
433
  key: "addSheet",
546
434
  value: function addSheet(sheetName, sheetData) {
@@ -548,32 +436,28 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
548
436
  (0, _console.warn)('The provided data should be an array of arrays.');
549
437
  return false;
550
438
  }
551
-
552
439
  if (sheetName !== void 0 && sheetName !== null && this.engine.doesSheetExist(sheetName)) {
553
440
  (0, _console.warn)('Sheet with the provided name already exists.');
554
441
  return false;
555
442
  }
556
-
557
443
  try {
558
444
  var actualSheetName = this.engine.addSheet(sheetName !== null && sheetName !== void 0 ? sheetName : void 0);
559
-
560
445
  if (sheetData) {
561
446
  this.engine.setSheetContent(this.engine.getSheetId(actualSheetName), sheetData);
562
447
  }
563
-
564
448
  return actualSheetName;
565
449
  } catch (e) {
566
450
  (0, _console.warn)(e.message);
567
451
  return false;
568
452
  }
569
453
  }
454
+
570
455
  /**
571
456
  * Switch the sheet used as data in the Handsontable instance (it loads the data from the shared HyperFormula
572
457
  * instance).
573
458
  *
574
459
  * @param {string} sheetName Sheet name used in the shared HyperFormula instance.
575
460
  */
576
-
577
461
  }, {
578
462
  key: "switchSheet",
579
463
  value: function switchSheet(sheetName) {
@@ -581,14 +465,13 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
581
465
  (0, _console.error)("The sheet named `".concat(sheetName, "` does not exist, switch aborted."));
582
466
  return;
583
467
  }
584
-
585
468
  this.sheetName = sheetName;
586
469
  var serialized = this.engine.getSheetSerialized(this.sheetId);
587
-
588
470
  if (serialized.length > 0) {
589
471
  this.hot.loadData(serialized, "".concat((0, _string.toUpperCaseFirst)(PLUGIN_KEY), ".switchSheet"));
590
472
  }
591
473
  }
474
+
592
475
  /**
593
476
  * Get the cell type under specified visual coordinates.
594
477
  *
@@ -597,14 +480,12 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
597
480
  * @param {number} [sheet] The target sheet id, defaults to the current sheet.
598
481
  * @returns {string} Possible values: 'FORMULA' | 'VALUE' | 'ARRAYFORMULA' | 'EMPTY'.
599
482
  */
600
-
601
483
  }, {
602
484
  key: "getCellType",
603
485
  value: function getCellType(row, column) {
604
486
  var sheet = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this.sheetId;
605
487
  var physicalRow = this.hot.toPhysicalRow(row);
606
488
  var physicalColumn = this.hot.toPhysicalColumn(column);
607
-
608
489
  if (physicalRow !== null && physicalColumn !== null) {
609
490
  return this.engine.getCellType({
610
491
  sheet: sheet,
@@ -616,6 +497,7 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
616
497
  return 'EMPTY';
617
498
  }
618
499
  }
500
+
619
501
  /**
620
502
  * Returns `true` if under specified visual coordinates is formula.
621
503
  *
@@ -624,24 +506,22 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
624
506
  * @param {number} [sheet] The target sheet id, defaults to the current sheet.
625
507
  * @returns {boolean}
626
508
  */
627
-
628
509
  }, {
629
510
  key: "isFormulaCellType",
630
511
  value: function isFormulaCellType(row, column) {
631
512
  var sheet = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this.sheetId;
632
513
  var physicalRow = this.hot.toPhysicalRow(row);
633
514
  var physicalColumn = this.hot.toPhysicalColumn(column);
634
-
635
515
  if (physicalRow === null || physicalColumn === null) {
636
516
  return false;
637
517
  }
638
-
639
518
  return this.engine.doesCellHaveFormula({
640
519
  sheet: sheet,
641
520
  row: physicalRow,
642
521
  col: physicalColumn
643
522
  });
644
523
  }
524
+
645
525
  /**
646
526
  * Renders dependent sheets (handsontable instances) based on the changes - list of the
647
527
  * recalculated dependent cells.
@@ -650,20 +530,16 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
650
530
  * @param {object[]} dependentCells The values and location of applied changes within HF engine.
651
531
  * @param {boolean} [renderSelf] `true` if it's supposed to render itself, `false` otherwise.
652
532
  */
653
-
654
533
  }, {
655
534
  key: "renderDependentSheets",
656
535
  value: function renderDependentSheets(dependentCells) {
657
536
  var _this11 = this;
658
-
659
537
  var renderSelf = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
660
538
  var affectedSheetIds = new Set();
661
539
  dependentCells.forEach(function (change) {
662
540
  var _change$address;
663
-
664
541
  // For the Named expression the address is empty, hence the `sheetId` is undefined.
665
542
  var sheetId = change === null || change === void 0 ? void 0 : (_change$address = change.address) === null || _change$address === void 0 ? void 0 : _change$address.sheet;
666
-
667
543
  if (sheetId !== void 0) {
668
544
  if (!affectedSheetIds.has(sheetId)) {
669
545
  affectedSheetIds.add(sheetId);
@@ -673,12 +549,12 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
673
549
  (0, _register.getRegisteredHotInstances)(this.engine).forEach(function (relatedHot, sheetId) {
674
550
  if ((renderSelf || sheetId !== _this11.sheetId) && affectedSheetIds.has(sheetId)) {
675
551
  var _relatedHot$view;
676
-
677
552
  relatedHot.render();
678
553
  (_relatedHot$view = relatedHot.view) === null || _relatedHot$view === void 0 ? void 0 : _relatedHot$view.adjustElementsSize();
679
554
  }
680
555
  });
681
556
  }
557
+
682
558
  /**
683
559
  * Validates dependent cells based on the cells that are modified by the change.
684
560
  *
@@ -686,59 +562,55 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
686
562
  * @param {object[]} dependentCells The values and location of applied changes within HF engine.
687
563
  * @param {object[]} [changedCells] The values and location of applied changes by developer (through API or UI).
688
564
  */
689
-
690
565
  }, {
691
566
  key: "validateDependentCells",
692
567
  value: function validateDependentCells(dependentCells) {
693
568
  var _this12 = this;
694
-
695
569
  var changedCells = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
696
-
697
570
  var stringifyAddress = function stringifyAddress(change) {
698
571
  var _change$address2;
699
-
700
572
  var _ref7 = (_change$address2 = change === null || change === void 0 ? void 0 : change.address) !== null && _change$address2 !== void 0 ? _change$address2 : {},
701
- row = _ref7.row,
702
- col = _ref7.col,
703
- sheet = _ref7.sheet;
704
-
573
+ row = _ref7.row,
574
+ col = _ref7.col,
575
+ sheet = _ref7.sheet;
705
576
  return (0, _mixed.isDefined)(sheet) ? "".concat(sheet, ":").concat(row, "x").concat(col) : '';
706
577
  };
707
-
708
578
  var changedCellsSet = new Set(changedCells.map(function (change) {
709
579
  return stringifyAddress(change);
710
580
  }));
711
581
  dependentCells.forEach(function (change) {
712
582
  var _change$address3, _change$address4;
713
-
714
583
  var _ref8 = (_change$address3 = change.address) !== null && _change$address3 !== void 0 ? _change$address3 : {},
715
- row = _ref8.row,
716
- col = _ref8.col;
717
-
584
+ row = _ref8.row,
585
+ col = _ref8.col;
718
586
  var visualRow = (0, _mixed.isDefined)(row) ? _this12.hot.toVisualRow(row) : null;
719
- var visualColumn = (0, _mixed.isDefined)(col) ? _this12.hot.toVisualColumn(col) : null; // Don't try to validate cells outside of the visual part of the table.
587
+ var visualColumn = (0, _mixed.isDefined)(col) ? _this12.hot.toVisualColumn(col) : null;
720
588
 
589
+ // Don't try to validate cells outside of the visual part of the table.
721
590
  if (visualRow === null || visualColumn === null) {
722
591
  return;
723
- } // For the Named expression the address is empty, hence the `sheetId` is undefined.
724
-
592
+ }
725
593
 
594
+ // For the Named expression the address is empty, hence the `sheetId` is undefined.
726
595
  var sheetId = change === null || change === void 0 ? void 0 : (_change$address4 = change.address) === null || _change$address4 === void 0 ? void 0 : _change$address4.sheet;
727
- var addressId = stringifyAddress(change); // Validate the cells that depend on the calculated formulas. Skip that cells
728
- // where the user directly changes the values - the Core triggers those validators.
596
+ var addressId = stringifyAddress(change);
729
597
 
598
+ // Validate the cells that depend on the calculated formulas. Skip that cells
599
+ // where the user directly changes the values - the Core triggers those validators.
730
600
  if (sheetId !== void 0 && !changedCellsSet.has(addressId)) {
731
- var boundHot = (0, _register.getRegisteredHotInstances)(_this12.engine).get(sheetId); // if `sheetId` is not bound to any Handsontable instance, skip the validation process
601
+ var boundHot = (0, _register.getRegisteredHotInstances)(_this12.engine).get(sheetId);
732
602
 
603
+ // if `sheetId` is not bound to any Handsontable instance, skip the validation process
733
604
  if (!boundHot) {
734
605
  return;
735
- } // It will just re-render certain cell when necessary.
736
-
606
+ }
737
607
 
608
+ // It will just re-render certain cell when necessary.
738
609
  boundHot.validateCell(boundHot.getDataAtCell(visualRow, visualColumn), boundHot.getCellMeta(visualRow, visualColumn), function () {});
739
610
  }
740
611
  });
741
612
  }
613
+
742
614
  /**
743
615
  * Sync a change from the change-related hooks with the engine.
744
616
  *
@@ -748,7 +620,6 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
748
620
  * @param {Handsontable.CellValue} newValue New value.
749
621
  * @returns {Array} Array of changes exported from the engine.
750
622
  */
751
-
752
623
  }, {
753
624
  key: "syncChangeWithEngine",
754
625
  value: function syncChangeWithEngine(row, column, newValue) {
@@ -757,14 +628,13 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
757
628
  col: this.toPhysicalColumnPosition(column),
758
629
  sheet: this.sheetId
759
630
  };
760
-
761
631
  if (!this.engine.isItPossibleToSetCellContents(address)) {
762
632
  (0, _console.warn)("Not possible to set cell data at ".concat(JSON.stringify(address)));
763
633
  return;
764
634
  }
765
-
766
635
  return this.engine.setCellContents(address, newValue);
767
636
  }
637
+
768
638
  /**
769
639
  * The hook allows to translate the formula value to calculated value before it goes to the
770
640
  * validator function.
@@ -775,25 +645,24 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
775
645
  * @param {number|string} prop The visual column index or property name of the column.
776
646
  * @returns {*} Returns value to validate.
777
647
  */
778
-
779
648
  }, {
780
649
  key: "onBeforeValidate",
781
650
  value: function onBeforeValidate(value, visualRow, prop) {
782
651
  var visualColumn = this.hot.propToCol(prop);
783
-
784
652
  if (this.isFormulaCellType(visualRow, visualColumn)) {
785
653
  var address = {
786
654
  row: this.hot.toPhysicalRow(visualRow),
787
655
  col: this.hot.toPhysicalColumn(visualColumn),
788
656
  sheet: this.sheetId
789
657
  };
790
- var cellValue = this.engine.getCellValue(address); // If `cellValue` is an object it is expected to be an error
658
+ var cellValue = this.engine.getCellValue(address);
791
659
 
660
+ // If `cellValue` is an object it is expected to be an error
792
661
  return _typeof(cellValue) === 'object' && cellValue !== null ? cellValue.value : cellValue;
793
662
  }
794
-
795
663
  return value;
796
664
  }
665
+
797
666
  /**
798
667
  * `onBeforeAutofill` hook callback.
799
668
  *
@@ -804,18 +673,15 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
804
673
  * @param {CellRange} targetRange The range new values will be filled into.
805
674
  * @returns {boolean|*}
806
675
  */
807
-
808
676
  }, {
809
677
  key: "onBeforeAutofill",
810
678
  value: function onBeforeAutofill(fillData, sourceRange, targetRange) {
811
679
  var _this13 = this;
812
-
813
680
  var withSheetId = function withSheetId(range) {
814
681
  return _objectSpread(_objectSpread({}, range), {}, {
815
682
  sheet: _this13.sheetId
816
683
  });
817
684
  };
818
-
819
685
  var engineSourceRange = {
820
686
  start: withSheetId(sourceRange.getTopStartCorner()),
821
687
  end: withSheetId(sourceRange.getBottomEndCorner())
@@ -823,15 +689,16 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
823
689
  var engineTargetRange = {
824
690
  start: withSheetId(targetRange.getTopStartCorner()),
825
691
  end: withSheetId(targetRange.getBottomEndCorner())
826
- }; // Blocks the autofill operation if HyperFormula says that at least one of
827
- // the underlying cell's contents cannot be set.
692
+ };
828
693
 
694
+ // Blocks the autofill operation if HyperFormula says that at least one of
695
+ // the underlying cell's contents cannot be set.
829
696
  if (this.engine.isItPossibleToSetCellContents(engineTargetRange) === false) {
830
697
  return false;
831
698
  }
832
-
833
699
  return this.engine.getFillRangeData(engineSourceRange, engineTargetRange);
834
700
  }
701
+
835
702
  /**
836
703
  * `beforeLoadData` hook callback.
837
704
  *
@@ -840,20 +707,19 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
840
707
  * @param {string} [source] Source of the call.
841
708
  * @private
842
709
  */
843
-
844
710
  }, {
845
711
  key: "onBeforeLoadData",
846
712
  value: function onBeforeLoadData(sourceData, initialLoad) {
847
713
  var source = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';
848
-
849
714
  if (source.includes((0, _string.toUpperCaseFirst)(PLUGIN_KEY))) {
850
715
  return;
851
- } // This flag needs to be defined, because not passing data to HOT results in HOT auto-generating a `null`-filled
852
- // initial dataset.
853
-
716
+ }
854
717
 
718
+ // This flag needs to be defined, because not passing data to HOT results in HOT auto-generating a `null`-filled
719
+ // initial dataset.
855
720
  _classPrivateFieldSet(this, _hotWasInitializedWithEmptyData, (0, _mixed.isUndefined)(this.hot.getSettings().data));
856
721
  }
722
+
857
723
  /**
858
724
  * `afterLoadData` hook callback.
859
725
  *
@@ -862,33 +728,27 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
862
728
  * @param {string} [source] Source of the call.
863
729
  * @private
864
730
  */
865
-
866
731
  }, {
867
732
  key: "onAfterLoadData",
868
733
  value: function onAfterLoadData(sourceData, initialLoad) {
869
734
  var source = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';
870
-
871
735
  if (source.includes((0, _string.toUpperCaseFirst)(PLUGIN_KEY))) {
872
736
  return;
873
737
  }
874
-
875
738
  this.sheetName = (0, _register.setupSheet)(this.engine, this.hot.getSettings()[PLUGIN_KEY].sheetName);
876
-
877
739
  if (!_classPrivateFieldGet(this, _hotWasInitializedWithEmptyData)) {
878
740
  var sourceDataArray = this.hot.getSourceDataArray();
879
-
880
741
  if (this.engine.isItPossibleToReplaceSheetContent(this.sheetId, sourceDataArray)) {
881
742
  _classPrivateFieldSet(this, _internalOperationPending, true);
882
-
883
743
  var dependentCells = this.engine.setSheetContent(this.sheetId, this.hot.getSourceDataArray());
884
744
  this.renderDependentSheets(dependentCells);
885
-
886
745
  _classPrivateFieldSet(this, _internalOperationPending, false);
887
746
  }
888
747
  } else {
889
748
  this.switchSheet(this.sheetName);
890
749
  }
891
750
  }
751
+
892
752
  /**
893
753
  * `modifyData` hook callback.
894
754
  *
@@ -899,41 +759,39 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
899
759
  * property.
900
760
  * @param {string} ioMode String which indicates for what operation hook is fired (`get` or `set`).
901
761
  */
902
-
903
762
  }, {
904
763
  key: "onModifyData",
905
764
  value: function onModifyData(row, column, valueHolder, ioMode) {
906
765
  if (ioMode !== 'get' || _classPrivateFieldGet(this, _internalOperationPending) || this.sheetName === null || !this.engine.doesSheetExist(this.sheetName)) {
907
766
  return;
908
767
  }
768
+ var visualRow = this.hot.toVisualRow(row);
909
769
 
910
- var visualRow = this.hot.toVisualRow(row); // `column` is here as visual index because of inconsistencies related to hook execution in `src/dataMap`.
911
-
770
+ // `column` is here as visual index because of inconsistencies related to hook execution in `src/dataMap`.
912
771
  var isFormulaCellType = this.isFormulaCellType(visualRow, column);
913
-
914
772
  if (!isFormulaCellType) {
915
773
  var cellType = this.getCellType(visualRow, column);
916
-
917
774
  if (cellType !== 'ARRAY') {
918
775
  if ((0, _utils.isEscapedFormulaExpression)(valueHolder.value)) {
919
776
  valueHolder.value = (0, _utils.unescapeFormulaExpression)(valueHolder.value);
920
777
  }
921
-
922
778
  return;
923
779
  }
924
- } // `toPhysicalColumn` is here because of inconsistencies related to hook execution in `DataMap`.
925
-
780
+ }
926
781
 
782
+ // `toPhysicalColumn` is here because of inconsistencies related to hook execution in `DataMap`.
927
783
  var address = {
928
784
  row: row,
929
785
  col: this.toPhysicalColumnPosition(column),
930
786
  sheet: this.sheetId
931
787
  };
932
- var cellValue = this.engine.getCellValue(address); // If `cellValue` is an object it is expected to be an error
788
+ var cellValue = this.engine.getCellValue(address);
933
789
 
790
+ // If `cellValue` is an object it is expected to be an error
934
791
  var value = _typeof(cellValue) === 'object' && cellValue !== null ? cellValue.value : cellValue;
935
792
  valueHolder.value = value;
936
793
  }
794
+
937
795
  /**
938
796
  * `modifySourceData` hook callback.
939
797
  *
@@ -944,36 +802,32 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
944
802
  * property.
945
803
  * @param {string} ioMode String which indicates for what operation hook is fired (`get` or `set`).
946
804
  */
947
-
948
805
  }, {
949
806
  key: "onModifySourceData",
950
807
  value: function onModifySourceData(row, columnOrProp, valueHolder, ioMode) {
951
808
  if (ioMode !== 'get' || _classPrivateFieldGet(this, _internalOperationPending) || this.sheetName === null || !this.engine.doesSheetExist(this.sheetName)) {
952
809
  return;
953
810
  }
954
-
955
811
  var visualRow = this.hot.toVisualRow(row);
956
- var visualColumn = this.hot.propToCol(columnOrProp); // `column` is here as visual index because of inconsistencies related to hook execution in `src/dataMap`.
812
+ var visualColumn = this.hot.propToCol(columnOrProp);
957
813
 
814
+ // `column` is here as visual index because of inconsistencies related to hook execution in `src/dataMap`.
958
815
  var isFormulaCellType = this.isFormulaCellType(visualRow, visualColumn);
959
-
960
816
  if (!isFormulaCellType) {
961
817
  var cellType = this.getCellType(visualRow, visualColumn);
962
-
963
818
  if (cellType !== 'ARRAY') {
964
819
  return;
965
820
  }
966
821
  }
822
+ var dimensions = this.engine.getSheetDimensions(this.engine.getSheetId(this.sheetName));
967
823
 
968
- var dimensions = this.engine.getSheetDimensions(this.engine.getSheetId(this.sheetName)); // Don't actually change the source data if HyperFormula is not
824
+ // Don't actually change the source data if HyperFormula is not
969
825
  // initialized yet. This is done to allow the `afterLoadData` hook to
970
826
  // load the existing source data with `Handsontable#getSourceDataArray`
971
827
  // properly.
972
-
973
828
  if (dimensions.width === 0 && dimensions.height === 0) {
974
829
  return;
975
830
  }
976
-
977
831
  var address = {
978
832
  row: row,
979
833
  // Workaround for inconsistencies in `src/dataSource.js`
@@ -982,57 +836,48 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
982
836
  };
983
837
  valueHolder.value = this.engine.getCellSerialized(address);
984
838
  }
839
+
985
840
  /**
986
841
  * `onAfterSetDataAtCell` hook callback.
987
842
  *
988
843
  * @private
989
844
  * @param {Array[]} changes An array of changes in format [[row, prop, oldValue, value], ...].
990
845
  * @param {string} [source] String that identifies source of hook call
991
- * ([list of all available sources]{@link http://docs.handsontable.com/tutorial-using-callbacks.html#page-source-definition}).
846
+ * ([list of all available sources]{@link https://handsontable.com/docs/javascript-data-grid/events-and-hooks/#handsontable-hooks}).
992
847
  */
993
-
994
848
  }, {
995
849
  key: "onAfterSetDataAtCell",
996
850
  value: function onAfterSetDataAtCell(changes, source) {
997
851
  var _this14 = this;
998
-
999
852
  if (isBlockedSource(source)) {
1000
853
  return;
1001
854
  }
1002
-
1003
855
  var outOfBoundsChanges = [];
1004
856
  var changedCells = [];
1005
857
  var dependentCells = this.engine.batch(function () {
1006
858
  changes.forEach(function (_ref9) {
1007
859
  var _ref10 = _slicedToArray(_ref9, 4),
1008
- row = _ref10[0],
1009
- prop = _ref10[1],
1010
- newValue = _ref10[3];
1011
-
860
+ row = _ref10[0],
861
+ prop = _ref10[1],
862
+ newValue = _ref10[3];
1012
863
  var column = _this14.hot.propToCol(prop);
1013
-
1014
864
  var physicalRow = _this14.hot.toPhysicalRow(row);
1015
-
1016
865
  var physicalColumn = _this14.hot.toPhysicalColumn(column);
1017
-
1018
866
  var address = {
1019
867
  row: physicalRow,
1020
868
  col: physicalColumn,
1021
869
  sheet: _this14.sheetId
1022
870
  };
1023
-
1024
871
  if (physicalRow !== null && physicalColumn !== null) {
1025
872
  _this14.syncChangeWithEngine(row, column, newValue);
1026
873
  } else {
1027
874
  outOfBoundsChanges.push([row, column, newValue]);
1028
875
  }
1029
-
1030
876
  changedCells.push({
1031
877
  address: address
1032
878
  });
1033
879
  });
1034
880
  });
1035
-
1036
881
  if (outOfBoundsChanges.length) {
1037
882
  // Workaround for rows/columns being created two times (by HOT and the engine).
1038
883
  // (unfortunately, this requires an extra re-render)
@@ -1040,64 +885,54 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1040
885
  var outOfBoundsDependentCells = _this14.engine.batch(function () {
1041
886
  outOfBoundsChanges.forEach(function (_ref11) {
1042
887
  var _ref12 = _slicedToArray(_ref11, 3),
1043
- row = _ref12[0],
1044
- column = _ref12[1],
1045
- newValue = _ref12[2];
1046
-
888
+ row = _ref12[0],
889
+ column = _ref12[1],
890
+ newValue = _ref12[2];
1047
891
  _this14.syncChangeWithEngine(row, column, newValue);
1048
892
  });
1049
893
  });
1050
-
1051
894
  _this14.renderDependentSheets(outOfBoundsDependentCells, true);
1052
895
  });
1053
896
  }
1054
-
1055
897
  this.renderDependentSheets(dependentCells);
1056
898
  this.validateDependentCells(dependentCells, changedCells);
1057
899
  }
900
+
1058
901
  /**
1059
902
  * `onAfterSetSourceDataAtCell` hook callback.
1060
903
  *
1061
904
  * @private
1062
905
  * @param {Array[]} changes An array of changes in format [[row, column, oldValue, value], ...].
1063
906
  * @param {string} [source] String that identifies source of hook call
1064
- * ([list of all available sources]{@link http://docs.handsontable.com/tutorial-using-callbacks.html#page-source-definition}).
907
+ * ([list of all available sources]{@link https://handsontable.com/docs/javascript-data-grid/events-and-hooks/#handsontable-hooks}).
1065
908
  */
1066
-
1067
909
  }, {
1068
910
  key: "onAfterSetSourceDataAtCell",
1069
911
  value: function onAfterSetSourceDataAtCell(changes, source) {
1070
912
  var _this15 = this;
1071
-
1072
913
  if (isBlockedSource(source)) {
1073
914
  return;
1074
915
  }
1075
-
1076
916
  var dependentCells = [];
1077
917
  var changedCells = [];
1078
918
  changes.forEach(function (_ref13) {
1079
919
  var _ref14 = _slicedToArray(_ref13, 4),
1080
- row = _ref14[0],
1081
- prop = _ref14[1],
1082
- newValue = _ref14[3];
1083
-
920
+ row = _ref14[0],
921
+ prop = _ref14[1],
922
+ newValue = _ref14[3];
1084
923
  var column = _this15.hot.propToCol(prop);
1085
-
1086
924
  if (!(0, _number.isNumeric)(column)) {
1087
925
  return;
1088
926
  }
1089
-
1090
927
  var address = {
1091
928
  row: row,
1092
929
  col: _this15.toPhysicalColumnPosition(column),
1093
930
  sheet: _this15.sheetId
1094
931
  };
1095
-
1096
932
  if (!_this15.engine.isItPossibleToSetCellContents(address)) {
1097
933
  (0, _console.warn)("Not possible to set source cell data at ".concat(JSON.stringify(address)));
1098
934
  return;
1099
935
  }
1100
-
1101
936
  changedCells.push({
1102
937
  address: address
1103
938
  });
@@ -1106,6 +941,7 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1106
941
  this.renderDependentSheets(dependentCells);
1107
942
  this.validateDependentCells(dependentCells, changedCells);
1108
943
  }
944
+
1109
945
  /**
1110
946
  * `beforeCreateRow` hook callback.
1111
947
  *
@@ -1114,7 +950,6 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1114
950
  * @param {number} amount Number of newly created rows in the data source array.
1115
951
  * @returns {*|boolean} If false is returned the action is canceled.
1116
952
  */
1117
-
1118
953
  }, {
1119
954
  key: "onBeforeCreateRow",
1120
955
  value: function onBeforeCreateRow(row, amount) {
@@ -1122,6 +957,7 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1122
957
  return false;
1123
958
  }
1124
959
  }
960
+
1125
961
  /**
1126
962
  * `beforeCreateCol` hook callback.
1127
963
  *
@@ -1130,7 +966,6 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1130
966
  * @param {number} amount Number of newly created columns in the data source.
1131
967
  * @returns {*|boolean} If false is returned the action is canceled.
1132
968
  */
1133
-
1134
969
  }, {
1135
970
  key: "onBeforeCreateCol",
1136
971
  value: function onBeforeCreateCol(col, amount) {
@@ -1138,6 +973,7 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1138
973
  return false;
1139
974
  }
1140
975
  }
976
+
1141
977
  /**
1142
978
  * `beforeRemoveRow` hook callback.
1143
979
  *
@@ -1147,17 +983,16 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1147
983
  * @param {number[]} physicalRows An array of physical rows removed from the data source.
1148
984
  * @returns {*|boolean} If false is returned the action is canceled.
1149
985
  */
1150
-
1151
986
  }, {
1152
987
  key: "onBeforeRemoveRow",
1153
988
  value: function onBeforeRemoveRow(row, amount, physicalRows) {
1154
989
  var _this16 = this;
1155
-
1156
990
  var possible = physicalRows.every(function (physicalRow) {
1157
991
  return _this16.engine.isItPossibleToRemoveRows(_this16.sheetId, [physicalRow, 1]);
1158
992
  });
1159
993
  return possible === false ? false : void 0;
1160
994
  }
995
+
1161
996
  /**
1162
997
  * `beforeRemoveCol` hook callback.
1163
998
  *
@@ -1167,17 +1002,16 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1167
1002
  * @param {number[]} physicalColumns An array of physical columns removed from the data source.
1168
1003
  * @returns {*|boolean} If false is returned the action is canceled.
1169
1004
  */
1170
-
1171
1005
  }, {
1172
1006
  key: "onBeforeRemoveCol",
1173
1007
  value: function onBeforeRemoveCol(col, amount, physicalColumns) {
1174
1008
  var _this17 = this;
1175
-
1176
1009
  var possible = physicalColumns.every(function (physicalColumn) {
1177
1010
  return _this17.engine.isItPossibleToRemoveColumns(_this17.sheetId, [physicalColumn, 1]);
1178
1011
  });
1179
1012
  return possible === false ? false : void 0;
1180
1013
  }
1014
+
1181
1015
  /**
1182
1016
  * `afterCreateRow` hook callback.
1183
1017
  *
@@ -1185,19 +1019,18 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1185
1019
  * @param {number} row Represents the visual index of first newly created row in the data source array.
1186
1020
  * @param {number} amount Number of newly created rows in the data source array.
1187
1021
  * @param {string} [source] String that identifies source of hook call
1188
- * ([list of all available sources]{@link http://docs.handsontable.com/tutorial-using-callbacks.html#page-source-definition}).
1022
+ * ([list of all available sources]{@link https://handsontable.com/docs/javascript-data-grid/events-and-hooks/#handsontable-hooks}).
1189
1023
  */
1190
-
1191
1024
  }, {
1192
1025
  key: "onAfterCreateRow",
1193
1026
  value: function onAfterCreateRow(row, amount, source) {
1194
1027
  if (isBlockedSource(source)) {
1195
1028
  return;
1196
1029
  }
1197
-
1198
1030
  var changes = this.engine.addRows(this.sheetId, [this.toPhysicalRowPosition(row), amount]);
1199
1031
  this.renderDependentSheets(changes);
1200
1032
  }
1033
+
1201
1034
  /**
1202
1035
  * `afterCreateCol` hook callback.
1203
1036
  *
@@ -1205,19 +1038,18 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1205
1038
  * @param {number} col Represents the visual index of first newly created column in the data source.
1206
1039
  * @param {number} amount Number of newly created columns in the data source.
1207
1040
  * @param {string} [source] String that identifies source of hook call
1208
- * ([list of all available sources]{@link http://docs.handsontable.com/tutorial-using-callbacks.html#page-source-definition}).
1041
+ * ([list of all available sources]{@link https://handsontable.com/docs/javascript-data-grid/events-and-hooks/#handsontable-hooks}).
1209
1042
  */
1210
-
1211
1043
  }, {
1212
1044
  key: "onAfterCreateCol",
1213
1045
  value: function onAfterCreateCol(col, amount, source) {
1214
1046
  if (isBlockedSource(source)) {
1215
1047
  return;
1216
1048
  }
1217
-
1218
1049
  var changes = this.engine.addColumns(this.sheetId, [this.toPhysicalColumnPosition(col), amount]);
1219
1050
  this.renderDependentSheets(changes);
1220
1051
  }
1052
+
1221
1053
  /**
1222
1054
  * `afterRemoveRow` hook callback.
1223
1055
  *
@@ -1226,18 +1058,15 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1226
1058
  * @param {number} amount An amount of removed rows.
1227
1059
  * @param {number[]} physicalRows An array of physical rows removed from the data source.
1228
1060
  * @param {string} [source] String that identifies source of hook call
1229
- * ([list of all available sources]{@link http://docs.handsontable.com/tutorial-using-callbacks.html#page-source-definition}).
1061
+ * ([list of all available sources]{@link https://handsontable.com/docs/javascript-data-grid/events-and-hooks/#handsontable-hooks}).
1230
1062
  */
1231
-
1232
1063
  }, {
1233
1064
  key: "onAfterRemoveRow",
1234
1065
  value: function onAfterRemoveRow(row, amount, physicalRows, source) {
1235
1066
  var _this18 = this;
1236
-
1237
1067
  if (isBlockedSource(source)) {
1238
1068
  return;
1239
1069
  }
1240
-
1241
1070
  var descendingPhysicalRows = physicalRows.sort().reverse();
1242
1071
  var changes = this.engine.batch(function () {
1243
1072
  descendingPhysicalRows.forEach(function (physicalRow) {
@@ -1246,6 +1075,7 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1246
1075
  });
1247
1076
  this.renderDependentSheets(changes);
1248
1077
  }
1078
+
1249
1079
  /**
1250
1080
  * `afterRemoveCol` hook callback.
1251
1081
  *
@@ -1254,18 +1084,15 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1254
1084
  * @param {number} amount An amount of removed columns.
1255
1085
  * @param {number[]} physicalColumns An array of physical columns removed from the data source.
1256
1086
  * @param {string} [source] String that identifies source of hook call
1257
- * ([list of all available sources]{@link http://docs.handsontable.com/tutorial-using-callbacks.html#page-source-definition}).
1087
+ * ([list of all available sources]{@link https://handsontable.com/docs/javascript-data-grid/events-and-hooks/#handsontable-hooks}).
1258
1088
  */
1259
-
1260
1089
  }, {
1261
1090
  key: "onAfterRemoveCol",
1262
1091
  value: function onAfterRemoveCol(col, amount, physicalColumns, source) {
1263
1092
  var _this19 = this;
1264
-
1265
1093
  if (isBlockedSource(source)) {
1266
1094
  return;
1267
1095
  }
1268
-
1269
1096
  var descendingPhysicalColumns = physicalColumns.sort().reverse();
1270
1097
  var changes = this.engine.batch(function () {
1271
1098
  descendingPhysicalColumns.forEach(function (physicalColumn) {
@@ -1274,6 +1101,7 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1274
1101
  });
1275
1102
  this.renderDependentSheets(changes);
1276
1103
  }
1104
+
1277
1105
  /**
1278
1106
  * `afterDetachChild` hook callback.
1279
1107
  * Used to sync the data of the rows detached in the Nested Rows plugin with the engine's dataset.
@@ -1283,19 +1111,14 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1283
1111
  * @param {object} element The detached element.
1284
1112
  * @param {number} finalElementRowIndex The final row index of the detached element.
1285
1113
  */
1286
-
1287
1114
  }, {
1288
1115
  key: "onAfterDetachChild",
1289
1116
  value: function onAfterDetachChild(parent, element, finalElementRowIndex) {
1290
1117
  var _element$__children,
1291
- _this20 = this;
1292
-
1118
+ _this20 = this;
1293
1119
  _classPrivateFieldSet(this, _internalOperationPending, true);
1294
-
1295
1120
  var rowsData = this.hot.getSourceDataArray(finalElementRowIndex, 0, finalElementRowIndex + (((_element$__children = element.__children) === null || _element$__children === void 0 ? void 0 : _element$__children.length) || 0), this.hot.countSourceCols());
1296
-
1297
1121
  _classPrivateFieldSet(this, _internalOperationPending, false);
1298
-
1299
1122
  rowsData.forEach(function (row, relativeRowIndex) {
1300
1123
  row.forEach(function (value, colIndex) {
1301
1124
  _this20.engine.setCellContents({
@@ -1306,6 +1129,7 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1306
1129
  });
1307
1130
  });
1308
1131
  }
1132
+
1309
1133
  /**
1310
1134
  * Called when a value is updated in the engine.
1311
1135
  *
@@ -1313,12 +1137,12 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1313
1137
  * @fires Hooks#afterFormulasValuesUpdate
1314
1138
  * @param {Array} changes The values and location of applied changes.
1315
1139
  */
1316
-
1317
1140
  }, {
1318
1141
  key: "onEngineValuesUpdated",
1319
1142
  value: function onEngineValuesUpdated(changes) {
1320
1143
  this.hot.runHooks('afterFormulasValuesUpdate', changes);
1321
1144
  }
1145
+
1322
1146
  /**
1323
1147
  * Called when a named expression is added to the engine instance.
1324
1148
  *
@@ -1327,12 +1151,12 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1327
1151
  * @param {string} namedExpressionName The name of the added expression.
1328
1152
  * @param {Array} changes The values and location of applied changes.
1329
1153
  */
1330
-
1331
1154
  }, {
1332
1155
  key: "onEngineNamedExpressionsAdded",
1333
1156
  value: function onEngineNamedExpressionsAdded(namedExpressionName, changes) {
1334
1157
  this.hot.runHooks('afterNamedExpressionAdded', namedExpressionName, changes);
1335
1158
  }
1159
+
1336
1160
  /**
1337
1161
  * Called when a named expression is removed from the engine instance.
1338
1162
  *
@@ -1341,12 +1165,12 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1341
1165
  * @param {string} namedExpressionName The name of the removed expression.
1342
1166
  * @param {Array} changes The values and location of applied changes.
1343
1167
  */
1344
-
1345
1168
  }, {
1346
1169
  key: "onEngineNamedExpressionsRemoved",
1347
1170
  value: function onEngineNamedExpressionsRemoved(namedExpressionName, changes) {
1348
1171
  this.hot.runHooks('afterNamedExpressionRemoved', namedExpressionName, changes);
1349
1172
  }
1173
+
1350
1174
  /**
1351
1175
  * Called when a new sheet is added to the engine instance.
1352
1176
  *
@@ -1354,12 +1178,12 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1354
1178
  * @fires Hooks#afterSheetAdded
1355
1179
  * @param {string} addedSheetDisplayName The name of the added sheet.
1356
1180
  */
1357
-
1358
1181
  }, {
1359
1182
  key: "onEngineSheetAdded",
1360
1183
  value: function onEngineSheetAdded(addedSheetDisplayName) {
1361
1184
  this.hot.runHooks('afterSheetAdded', addedSheetDisplayName);
1362
1185
  }
1186
+
1363
1187
  /**
1364
1188
  * Called when a sheet in the engine instance is renamed.
1365
1189
  *
@@ -1368,12 +1192,12 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1368
1192
  * @param {string} oldDisplayName The old name of the sheet.
1369
1193
  * @param {string} newDisplayName The new name of the sheet.
1370
1194
  */
1371
-
1372
1195
  }, {
1373
1196
  key: "onEngineSheetRenamed",
1374
1197
  value: function onEngineSheetRenamed(oldDisplayName, newDisplayName) {
1375
1198
  this.hot.runHooks('afterSheetRenamed', oldDisplayName, newDisplayName);
1376
1199
  }
1200
+
1377
1201
  /**
1378
1202
  * Called when a sheet is removed from the engine instance.
1379
1203
  *
@@ -1382,7 +1206,6 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1382
1206
  * @param {string} removedSheetDisplayName The removed sheet name.
1383
1207
  * @param {Array} changes The values and location of applied changes.
1384
1208
  */
1385
-
1386
1209
  }, {
1387
1210
  key: "onEngineSheetRemoved",
1388
1211
  value: function onEngineSheetRemoved(removedSheetDisplayName, changes) {
@@ -1398,16 +1221,14 @@ var Formulas = /*#__PURE__*/function (_BasePlugin) {
1398
1221
  get: function get() {
1399
1222
  return PLUGIN_PRIORITY;
1400
1223
  }
1224
+
1401
1225
  /**
1402
1226
  * Flag used to bypass hooks in internal operations.
1403
1227
  *
1404
1228
  * @private
1405
1229
  * @type {boolean}
1406
1230
  */
1407
-
1408
1231
  }]);
1409
-
1410
1232
  return Formulas;
1411
1233
  }(_base.BasePlugin);
1412
-
1413
1234
  exports.Formulas = Formulas;