handsontable 13.1.0 → 14.0.0-next-d97b156-20231027

Sign up to get free protection for your applications and to get access to all the features.
Files changed (691) hide show
  1. package/3rdparty/walkontable/src/calculator/constants.js +3 -6
  2. package/3rdparty/walkontable/src/calculator/viewportColumns.js +1 -2
  3. package/3rdparty/walkontable/src/calculator/viewportRows.js +1 -2
  4. package/3rdparty/walkontable/src/cell/coords.d.ts +8 -1
  5. package/3rdparty/walkontable/src/cell/coords.js +81 -13
  6. package/3rdparty/walkontable/src/cell/coords.mjs +80 -11
  7. package/3rdparty/walkontable/src/cell/range.d.ts +9 -2
  8. package/3rdparty/walkontable/src/cell/range.js +39 -9
  9. package/3rdparty/walkontable/src/cell/range.mjs +38 -7
  10. package/3rdparty/walkontable/src/core/_base.js +9 -3
  11. package/3rdparty/walkontable/src/core/_base.mjs +9 -3
  12. package/3rdparty/walkontable/src/core/clone.js +2 -2
  13. package/3rdparty/walkontable/src/core/clone.mjs +2 -2
  14. package/3rdparty/walkontable/src/core/core.js +3 -2
  15. package/3rdparty/walkontable/src/core/core.mjs +3 -2
  16. package/3rdparty/walkontable/src/event.js +13 -12
  17. package/3rdparty/walkontable/src/event.mjs +12 -10
  18. package/3rdparty/walkontable/src/facade/core.js +2 -2
  19. package/3rdparty/walkontable/src/facade/core.mjs +2 -2
  20. package/3rdparty/walkontable/src/filter/column.js +1 -2
  21. package/3rdparty/walkontable/src/filter/row.js +1 -2
  22. package/3rdparty/walkontable/src/index.js +12 -4
  23. package/3rdparty/walkontable/src/index.mjs +2 -2
  24. package/3rdparty/walkontable/src/overlay/_base.js +13 -2
  25. package/3rdparty/walkontable/src/overlay/_base.mjs +14 -3
  26. package/3rdparty/walkontable/src/overlay/constants.js +7 -14
  27. package/3rdparty/walkontable/src/overlay/inlineStart.js +2 -6
  28. package/3rdparty/walkontable/src/overlay/inlineStart.mjs +2 -6
  29. package/3rdparty/walkontable/src/overlay/top.js +2 -6
  30. package/3rdparty/walkontable/src/overlay/top.mjs +2 -6
  31. package/3rdparty/walkontable/src/overlays.js +1 -2
  32. package/3rdparty/walkontable/src/renderer/cells.js +10 -0
  33. package/3rdparty/walkontable/src/renderer/cells.mjs +11 -1
  34. package/3rdparty/walkontable/src/renderer/columnHeaders.js +13 -0
  35. package/3rdparty/walkontable/src/renderer/columnHeaders.mjs +14 -1
  36. package/3rdparty/walkontable/src/renderer/rowHeaders.js +8 -0
  37. package/3rdparty/walkontable/src/renderer/rowHeaders.mjs +8 -0
  38. package/3rdparty/walkontable/src/renderer/rows.js +13 -0
  39. package/3rdparty/walkontable/src/renderer/rows.mjs +13 -0
  40. package/3rdparty/walkontable/src/renderer/table.js +9 -0
  41. package/3rdparty/walkontable/src/renderer/table.mjs +9 -0
  42. package/3rdparty/walkontable/src/scroll.js +3 -2
  43. package/3rdparty/walkontable/src/scroll.mjs +2 -0
  44. package/3rdparty/walkontable/src/{border.js → selection/border/border.js} +8 -14
  45. package/3rdparty/walkontable/src/{border.mjs → selection/border/border.mjs} +7 -12
  46. package/3rdparty/walkontable/src/selection/border/constants.js +15 -0
  47. package/3rdparty/walkontable/src/selection/border/constants.mjs +12 -0
  48. package/3rdparty/walkontable/src/selection/constants.js +54 -0
  49. package/3rdparty/walkontable/src/selection/constants.mjs +51 -0
  50. package/3rdparty/walkontable/src/selection/index.js +26 -0
  51. package/3rdparty/walkontable/src/selection/index.mjs +5 -0
  52. package/3rdparty/walkontable/src/selection/manager.js +274 -0
  53. package/3rdparty/walkontable/src/selection/manager.mjs +269 -0
  54. package/3rdparty/walkontable/src/selection/scanner.js +270 -0
  55. package/3rdparty/walkontable/src/selection/scanner.mjs +267 -0
  56. package/3rdparty/walkontable/src/selection/selection.js +100 -0
  57. package/3rdparty/walkontable/src/selection/selection.mjs +96 -0
  58. package/3rdparty/walkontable/src/settings.js +13 -4
  59. package/3rdparty/walkontable/src/settings.mjs +13 -4
  60. package/3rdparty/walkontable/src/table/bottom.js +1 -2
  61. package/3rdparty/walkontable/src/table/bottomInlineStartCorner.js +1 -2
  62. package/3rdparty/walkontable/src/table/inlineStart.js +1 -2
  63. package/3rdparty/walkontable/src/table/master.js +3 -6
  64. package/3rdparty/walkontable/src/table/master.mjs +2 -4
  65. package/3rdparty/walkontable/src/table/mixin/calculatedColumns.js +10 -2
  66. package/3rdparty/walkontable/src/table/mixin/calculatedColumns.mjs +9 -0
  67. package/3rdparty/walkontable/src/table/mixin/calculatedRows.js +10 -2
  68. package/3rdparty/walkontable/src/table/mixin/calculatedRows.mjs +9 -0
  69. package/3rdparty/walkontable/src/table/mixin/stickyColumnsStart.js +10 -2
  70. package/3rdparty/walkontable/src/table/mixin/stickyColumnsStart.mjs +9 -0
  71. package/3rdparty/walkontable/src/table/mixin/stickyRowsBottom.js +10 -2
  72. package/3rdparty/walkontable/src/table/mixin/stickyRowsBottom.mjs +9 -0
  73. package/3rdparty/walkontable/src/table/mixin/stickyRowsTop.js +10 -2
  74. package/3rdparty/walkontable/src/table/mixin/stickyRowsTop.mjs +9 -0
  75. package/3rdparty/walkontable/src/table/top.js +1 -2
  76. package/3rdparty/walkontable/src/table/topInlineStartCorner.js +1 -2
  77. package/3rdparty/walkontable/src/table.js +20 -80
  78. package/3rdparty/walkontable/src/table.mjs +20 -79
  79. package/3rdparty/walkontable/src/utils/orderView/constants.js +3 -6
  80. package/3rdparty/walkontable/src/viewport.js +1 -2
  81. package/CHANGELOG.md +51 -0
  82. package/base.js +3 -4
  83. package/base.mjs +2 -2
  84. package/cellTypes/autocompleteType/autocompleteType.js +3 -5
  85. package/cellTypes/checkboxType/checkboxType.js +3 -5
  86. package/cellTypes/dateType/dateType.d.ts +3 -3
  87. package/cellTypes/dateType/dateType.js +5 -7
  88. package/cellTypes/dateType/dateType.mjs +2 -2
  89. package/cellTypes/dropdownType/dropdownType.js +3 -5
  90. package/cellTypes/handsontableType/handsontableType.d.ts +3 -3
  91. package/cellTypes/handsontableType/handsontableType.js +5 -7
  92. package/cellTypes/handsontableType/handsontableType.mjs +2 -2
  93. package/cellTypes/index.d.ts +3 -0
  94. package/cellTypes/index.js +4 -0
  95. package/cellTypes/index.mjs +3 -1
  96. package/cellTypes/numericType/numericType.js +3 -5
  97. package/cellTypes/passwordType/passwordType.js +3 -5
  98. package/cellTypes/selectType/index.d.ts +1 -0
  99. package/cellTypes/selectType/index.js +6 -0
  100. package/cellTypes/selectType/index.mjs +1 -0
  101. package/cellTypes/selectType/selectType.d.ts +14 -0
  102. package/cellTypes/selectType/selectType.js +11 -0
  103. package/cellTypes/selectType/selectType.mjs +8 -0
  104. package/cellTypes/textType/textType.js +3 -5
  105. package/cellTypes/timeType/timeType.js +3 -5
  106. package/common.d.ts +1 -1
  107. package/core/focusCatcher/focusDetector.js +63 -0
  108. package/core/focusCatcher/focusDetector.mjs +59 -0
  109. package/core/focusCatcher/index.js +148 -0
  110. package/core/focusCatcher/index.mjs +144 -0
  111. package/core/index.js +9 -0
  112. package/core/index.mjs +1 -0
  113. package/core.d.ts +10 -5
  114. package/core.js +327 -359
  115. package/core.mjs +327 -359
  116. package/dataMap/dataMap.js +1 -2
  117. package/dataMap/dataSource.js +1 -2
  118. package/dataMap/metaManager/metaSchema.js +65 -0
  119. package/dataMap/metaManager/metaSchema.mjs +65 -0
  120. package/dataMap/metaManager/mods/extendMetaProperties.js +7 -1
  121. package/dataMap/metaManager/mods/extendMetaProperties.mjs +7 -1
  122. package/dataMap/replaceData.js +5 -0
  123. package/dataMap/replaceData.mjs +5 -0
  124. package/dist/handsontable.css +94 -76
  125. package/dist/handsontable.full.css +94 -76
  126. package/dist/handsontable.full.js +21236 -14104
  127. package/dist/handsontable.full.min.css +8 -8
  128. package/dist/handsontable.full.min.js +170 -152
  129. package/dist/handsontable.js +22016 -15254
  130. package/dist/handsontable.min.css +7 -7
  131. package/dist/handsontable.min.js +31 -23
  132. package/dist/languages/all.js +47 -40
  133. package/dist/languages/all.min.js +1 -1
  134. package/dist/languages/ar-AR.js +1 -2
  135. package/dist/languages/cs-CZ.js +1 -2
  136. package/dist/languages/de-CH.js +1 -2
  137. package/dist/languages/de-DE.js +1 -2
  138. package/dist/languages/en-US.js +15 -3
  139. package/dist/languages/en-US.min.js +1 -1
  140. package/dist/languages/es-MX.js +1 -2
  141. package/dist/languages/fr-FR.js +1 -2
  142. package/dist/languages/it-IT.js +1 -2
  143. package/dist/languages/ja-JP.js +1 -2
  144. package/dist/languages/ko-KR.js +1 -2
  145. package/dist/languages/lv-LV.js +1 -2
  146. package/dist/languages/nb-NO.js +1 -2
  147. package/dist/languages/nl-NL.js +1 -2
  148. package/dist/languages/pl-PL.js +15 -3
  149. package/dist/languages/pl-PL.min.js +1 -1
  150. package/dist/languages/pt-BR.js +1 -2
  151. package/dist/languages/ru-RU.js +1 -2
  152. package/dist/languages/sr-SP.js +1 -2
  153. package/dist/languages/zh-CN.js +1 -2
  154. package/dist/languages/zh-TW.js +1 -2
  155. package/editorManager.js +17 -91
  156. package/editorManager.mjs +16 -87
  157. package/editors/autocompleteEditor/autocompleteEditor.js +65 -11
  158. package/editors/autocompleteEditor/autocompleteEditor.mjs +65 -10
  159. package/editors/baseEditor/baseEditor.js +19 -13
  160. package/editors/baseEditor/baseEditor.mjs +16 -7
  161. package/editors/checkboxEditor/checkboxEditor.js +1 -2
  162. package/editors/dateEditor/dateEditor.js +27 -9
  163. package/editors/dateEditor/dateEditor.mjs +27 -8
  164. package/editors/dropdownEditor/dropdownEditor.js +1 -2
  165. package/editors/handsontableEditor/handsontableEditor.js +14 -7
  166. package/editors/handsontableEditor/handsontableEditor.mjs +14 -6
  167. package/editors/numericEditor/numericEditor.js +1 -2
  168. package/editors/passwordEditor/passwordEditor.js +1 -2
  169. package/editors/selectEditor/selectEditor.js +1 -2
  170. package/editors/textEditor/textEditor.js +20 -29
  171. package/editors/textEditor/textEditor.mjs +22 -30
  172. package/editors/timeEditor/timeEditor.js +1 -2
  173. package/eventManager.js +1 -2
  174. package/focusManager.d.ts +12 -0
  175. package/focusManager.js +265 -0
  176. package/focusManager.mjs +261 -0
  177. package/helpers/a11y.js +81 -0
  178. package/helpers/a11y.mjs +39 -0
  179. package/helpers/dom/element.js +224 -12
  180. package/helpers/dom/element.mjs +216 -10
  181. package/helpers/dom/event.d.ts +1 -0
  182. package/helpers/dom/event.js +25 -0
  183. package/helpers/dom/event.mjs +24 -0
  184. package/helpers/mixed.js +2 -2
  185. package/helpers/mixed.mjs +2 -2
  186. package/helpers/number.d.ts +1 -0
  187. package/helpers/number.js +18 -0
  188. package/helpers/number.mjs +17 -0
  189. package/helpers/unicode.js +1 -2
  190. package/i18n/constants.js +97 -160
  191. package/i18n/constants.mjs +17 -1
  192. package/i18n/languages/ar-AR.js +3 -4
  193. package/i18n/languages/cs-CZ.js +3 -4
  194. package/i18n/languages/de-CH.js +3 -4
  195. package/i18n/languages/de-DE.js +3 -4
  196. package/i18n/languages/en-US.js +17 -5
  197. package/i18n/languages/en-US.mjs +14 -1
  198. package/i18n/languages/es-MX.js +3 -4
  199. package/i18n/languages/fr-FR.js +3 -4
  200. package/i18n/languages/it-IT.js +3 -4
  201. package/i18n/languages/ja-JP.js +3 -4
  202. package/i18n/languages/ko-KR.js +3 -4
  203. package/i18n/languages/lv-LV.js +3 -4
  204. package/i18n/languages/nb-NO.js +3 -4
  205. package/i18n/languages/nl-NL.js +3 -4
  206. package/i18n/languages/pl-PL.js +17 -5
  207. package/i18n/languages/pl-PL.mjs +14 -1
  208. package/i18n/languages/pt-BR.js +3 -4
  209. package/i18n/languages/ru-RU.js +3 -4
  210. package/i18n/languages/sr-SP.js +3 -4
  211. package/i18n/languages/zh-CN.js +3 -4
  212. package/i18n/languages/zh-TW.js +3 -4
  213. package/i18n/registry.js +4 -6
  214. package/index.js +3 -4
  215. package/languages/all.js +47 -40
  216. package/languages/ar-AR.js +1 -2
  217. package/languages/cs-CZ.js +1 -2
  218. package/languages/de-CH.js +1 -2
  219. package/languages/de-DE.js +1 -2
  220. package/languages/en-US.js +15 -3
  221. package/languages/en-US.mjs +14 -1
  222. package/languages/es-MX.js +1 -2
  223. package/languages/fr-FR.js +1 -2
  224. package/languages/index.js +47 -40
  225. package/languages/it-IT.js +1 -2
  226. package/languages/ja-JP.js +1 -2
  227. package/languages/ko-KR.js +1 -2
  228. package/languages/lv-LV.js +1 -2
  229. package/languages/nb-NO.js +1 -2
  230. package/languages/nl-NL.js +1 -2
  231. package/languages/pl-PL.js +15 -3
  232. package/languages/pl-PL.mjs +14 -1
  233. package/languages/pt-BR.js +1 -2
  234. package/languages/ru-RU.js +1 -2
  235. package/languages/sr-SP.js +1 -2
  236. package/languages/zh-CN.js +1 -2
  237. package/languages/zh-TW.js +1 -2
  238. package/mixins/hooksRefRegisterer.js +1 -2
  239. package/mixins/localHooks.js +1 -2
  240. package/package.json +119 -96
  241. package/pluginHooks.d.ts +42 -7
  242. package/pluginHooks.js +301 -65
  243. package/pluginHooks.mjs +300 -63
  244. package/plugins/autoColumnSize/autoColumnSize.d.ts +2 -0
  245. package/plugins/autoColumnSize/autoColumnSize.js +2 -4
  246. package/plugins/autoRowSize/autoRowSize.d.ts +2 -0
  247. package/plugins/autoRowSize/autoRowSize.js +15 -10
  248. package/plugins/autoRowSize/autoRowSize.mjs +13 -6
  249. package/plugins/autofill/autofill.js +2 -4
  250. package/plugins/autofill/utils.js +1 -2
  251. package/plugins/base/base.js +1 -2
  252. package/plugins/bindRowsWithHeaders/bindRowsWithHeaders.js +2 -4
  253. package/plugins/bindRowsWithHeaders/maps/looseBindsMap.js +1 -2
  254. package/plugins/bindRowsWithHeaders/maps/strictBindsMap.js +1 -2
  255. package/plugins/collapsibleColumns/collapsibleColumns.js +77 -8
  256. package/plugins/collapsibleColumns/collapsibleColumns.mjs +76 -5
  257. package/plugins/columnSorting/columnSorting.js +71 -6
  258. package/plugins/columnSorting/columnSorting.mjs +70 -3
  259. package/plugins/columnSorting/index.js +3 -1
  260. package/plugins/columnSorting/index.mjs +1 -1
  261. package/plugins/columnSorting/sortFunction/checkbox.js +1 -2
  262. package/plugins/columnSorting/sortFunction/date.js +1 -2
  263. package/plugins/columnSorting/sortFunction/default.js +1 -2
  264. package/plugins/columnSorting/sortFunction/numeric.js +1 -2
  265. package/plugins/columnSorting/sortService/engine.js +3 -6
  266. package/plugins/columnSorting/utils.js +3 -6
  267. package/plugins/columnSummary/columnSummary.js +2 -4
  268. package/plugins/columnSummary/endpoints.js +1 -2
  269. package/plugins/comments/commentEditor.js +2 -2
  270. package/plugins/comments/commentEditor.mjs +1 -0
  271. package/plugins/comments/comments.js +254 -197
  272. package/plugins/comments/comments.mjs +251 -190
  273. package/plugins/comments/contextMenuItem/addEditComment.js +41 -0
  274. package/plugins/comments/contextMenuItem/addEditComment.mjs +35 -0
  275. package/plugins/comments/contextMenuItem/readOnlyComment.js +49 -0
  276. package/plugins/comments/contextMenuItem/readOnlyComment.mjs +43 -0
  277. package/plugins/comments/contextMenuItem/removeComment.js +38 -0
  278. package/plugins/comments/contextMenuItem/removeComment.mjs +32 -0
  279. package/plugins/comments/displaySwitch.js +1 -2
  280. package/plugins/contextMenu/commandExecutor.js +2 -3
  281. package/plugins/contextMenu/commandExecutor.mjs +2 -3
  282. package/plugins/contextMenu/contextMenu.d.ts +1 -1
  283. package/plugins/contextMenu/contextMenu.js +77 -40
  284. package/plugins/contextMenu/contextMenu.mjs +74 -35
  285. package/plugins/contextMenu/itemsFactory.js +2 -3
  286. package/plugins/contextMenu/itemsFactory.mjs +3 -4
  287. package/plugins/contextMenu/{cursor.mjs → menu/cursor.js} +6 -4
  288. package/plugins/contextMenu/{cursor.js → menu/cursor.mjs} +4 -10
  289. package/plugins/contextMenu/menu/defaultShortcutsList.js +88 -0
  290. package/plugins/contextMenu/menu/defaultShortcutsList.mjs +84 -0
  291. package/plugins/contextMenu/menu/index.js +9 -0
  292. package/plugins/contextMenu/menu/index.mjs +1 -0
  293. package/plugins/contextMenu/{menu.js → menu/menu.js} +145 -421
  294. package/plugins/contextMenu/{menu.mjs → menu/menu.mjs} +146 -422
  295. package/plugins/contextMenu/menu/menuItemRenderer.js +70 -0
  296. package/plugins/contextMenu/menu/menuItemRenderer.mjs +66 -0
  297. package/plugins/contextMenu/menu/navigator.js +27 -0
  298. package/plugins/contextMenu/menu/navigator.mjs +23 -0
  299. package/plugins/contextMenu/menu/positioner.js +213 -0
  300. package/plugins/contextMenu/menu/positioner.mjs +209 -0
  301. package/plugins/contextMenu/menu/shortcuts.js +114 -0
  302. package/plugins/contextMenu/menu/shortcuts.mjs +110 -0
  303. package/plugins/contextMenu/menu/utils.js +177 -0
  304. package/plugins/contextMenu/menu/utils.mjs +163 -0
  305. package/plugins/contextMenu/predefinedItems/alignment.js +10 -4
  306. package/plugins/contextMenu/predefinedItems/alignment.mjs +7 -0
  307. package/plugins/contextMenu/predefinedItems/clearColumn.js +8 -7
  308. package/plugins/contextMenu/predefinedItems/clearColumn.mjs +5 -3
  309. package/plugins/contextMenu/predefinedItems/columnLeft.js +8 -7
  310. package/plugins/contextMenu/predefinedItems/columnLeft.mjs +5 -3
  311. package/plugins/contextMenu/predefinedItems/columnRight.js +8 -7
  312. package/plugins/contextMenu/predefinedItems/columnRight.mjs +5 -3
  313. package/plugins/contextMenu/predefinedItems/index.js +75 -0
  314. package/plugins/contextMenu/predefinedItems/index.mjs +68 -0
  315. package/plugins/contextMenu/predefinedItems/noItems.js +1 -2
  316. package/plugins/contextMenu/predefinedItems/readOnly.js +10 -4
  317. package/plugins/contextMenu/predefinedItems/readOnly.mjs +7 -0
  318. package/plugins/contextMenu/predefinedItems/redo.js +3 -4
  319. package/plugins/contextMenu/predefinedItems/removeColumn.js +10 -9
  320. package/plugins/contextMenu/predefinedItems/removeColumn.mjs +5 -3
  321. package/plugins/contextMenu/predefinedItems/removeRow.js +10 -9
  322. package/plugins/contextMenu/predefinedItems/removeRow.mjs +5 -3
  323. package/plugins/contextMenu/predefinedItems/rowAbove.js +8 -7
  324. package/plugins/contextMenu/predefinedItems/rowAbove.mjs +5 -3
  325. package/plugins/contextMenu/predefinedItems/rowBelow.js +8 -7
  326. package/plugins/contextMenu/predefinedItems/rowBelow.mjs +5 -3
  327. package/plugins/contextMenu/predefinedItems/separator.js +1 -2
  328. package/plugins/contextMenu/predefinedItems/undo.js +3 -4
  329. package/plugins/contextMenu/utils.js +35 -151
  330. package/plugins/contextMenu/utils.mjs +35 -144
  331. package/plugins/copyPaste/clipboardData/clipboardData.js +516 -0
  332. package/plugins/copyPaste/clipboardData/clipboardData.mjs +512 -0
  333. package/plugins/copyPaste/clipboardData/copyClipboardData.js +69 -0
  334. package/plugins/copyPaste/clipboardData/copyClipboardData.mjs +65 -0
  335. package/plugins/copyPaste/clipboardData/index.js +9 -0
  336. package/plugins/copyPaste/clipboardData/index.mjs +4 -0
  337. package/plugins/copyPaste/clipboardData/pasteClipboardData.js +81 -0
  338. package/plugins/copyPaste/clipboardData/pasteClipboardData.mjs +77 -0
  339. package/plugins/copyPaste/contextMenuItem/copy.js +7 -0
  340. package/plugins/copyPaste/contextMenuItem/copy.mjs +7 -0
  341. package/plugins/copyPaste/contextMenuItem/copyColumnHeadersOnly.js +9 -1
  342. package/plugins/copyPaste/contextMenuItem/copyColumnHeadersOnly.mjs +9 -1
  343. package/plugins/copyPaste/contextMenuItem/copyWithColumnGroupHeaders.js +9 -1
  344. package/plugins/copyPaste/contextMenuItem/copyWithColumnGroupHeaders.mjs +9 -1
  345. package/plugins/copyPaste/contextMenuItem/copyWithColumnHeaders.js +9 -1
  346. package/plugins/copyPaste/contextMenuItem/copyWithColumnHeaders.mjs +9 -1
  347. package/plugins/copyPaste/contextMenuItem/cut.js +9 -2
  348. package/plugins/copyPaste/contextMenuItem/cut.mjs +7 -0
  349. package/plugins/copyPaste/copyPaste.js +160 -167
  350. package/plugins/copyPaste/copyPaste.mjs +161 -166
  351. package/plugins/customBorders/contextMenuItem/bottom.js +2 -2
  352. package/plugins/customBorders/contextMenuItem/left.js +2 -2
  353. package/plugins/customBorders/contextMenuItem/noBorders.js +2 -2
  354. package/plugins/customBorders/contextMenuItem/right.js +2 -2
  355. package/plugins/customBorders/contextMenuItem/top.js +2 -2
  356. package/plugins/customBorders/customBorders.js +27 -26
  357. package/plugins/customBorders/customBorders.mjs +24 -21
  358. package/plugins/dragToScroll/dragToScroll.js +2 -4
  359. package/plugins/dropdownMenu/dropdownMenu.d.ts +1 -1
  360. package/plugins/dropdownMenu/dropdownMenu.js +130 -44
  361. package/plugins/dropdownMenu/dropdownMenu.mjs +127 -39
  362. package/plugins/exportFile/dataProvider.js +1 -2
  363. package/plugins/exportFile/exportFile.js +4 -6
  364. package/plugins/exportFile/typeFactory.js +5 -8
  365. package/plugins/exportFile/types/_base.js +1 -2
  366. package/plugins/exportFile/types/csv.js +1 -2
  367. package/plugins/filters/component/_base.js +23 -8
  368. package/plugins/filters/component/_base.mjs +23 -8
  369. package/plugins/filters/component/actionBar.js +31 -29
  370. package/plugins/filters/component/actionBar.mjs +26 -23
  371. package/plugins/filters/component/condition.js +48 -61
  372. package/plugins/filters/component/condition.mjs +40 -52
  373. package/plugins/filters/component/operators.js +21 -22
  374. package/plugins/filters/component/operators.mjs +18 -18
  375. package/plugins/filters/component/value.js +37 -28
  376. package/plugins/filters/component/value.mjs +32 -22
  377. package/plugins/filters/condition/beginsWith.js +3 -4
  378. package/plugins/filters/condition/between.js +3 -4
  379. package/plugins/filters/condition/byValue.js +1 -2
  380. package/plugins/filters/condition/contains.js +3 -4
  381. package/plugins/filters/condition/date/after.js +3 -4
  382. package/plugins/filters/condition/date/before.js +3 -4
  383. package/plugins/filters/condition/date/today.js +3 -4
  384. package/plugins/filters/condition/date/tomorrow.js +3 -4
  385. package/plugins/filters/condition/date/yesterday.js +3 -4
  386. package/plugins/filters/condition/empty.js +3 -4
  387. package/plugins/filters/condition/endsWith.js +3 -4
  388. package/plugins/filters/condition/equal.js +3 -4
  389. package/plugins/filters/condition/false.js +1 -2
  390. package/plugins/filters/condition/greaterThan.js +3 -4
  391. package/plugins/filters/condition/greaterThanOrEqual.js +3 -4
  392. package/plugins/filters/condition/lessThan.js +3 -4
  393. package/plugins/filters/condition/lessThanOrEqual.js +3 -4
  394. package/plugins/filters/condition/none.js +3 -4
  395. package/plugins/filters/condition/notBetween.js +3 -4
  396. package/plugins/filters/condition/notContains.js +3 -4
  397. package/plugins/filters/condition/notEmpty.js +3 -4
  398. package/plugins/filters/condition/notEqual.js +3 -4
  399. package/plugins/filters/condition/true.js +1 -2
  400. package/plugins/filters/conditionCollection.d.ts +3 -2
  401. package/plugins/filters/conditionCollection.js +1 -2
  402. package/plugins/filters/conditionRegisterer.js +1 -2
  403. package/plugins/filters/conditionUpdateObserver.js +1 -2
  404. package/plugins/filters/constants.js +4 -8
  405. package/plugins/filters/constants.mjs +1 -1
  406. package/plugins/filters/dataFilter.js +1 -2
  407. package/plugins/filters/filters.d.ts +3 -5
  408. package/plugins/filters/filters.js +108 -66
  409. package/plugins/filters/filters.mjs +99 -55
  410. package/plugins/filters/logicalOperationRegisterer.js +1 -2
  411. package/plugins/filters/logicalOperations/conjunction.js +4 -6
  412. package/plugins/filters/logicalOperations/disjunction.js +4 -6
  413. package/plugins/filters/logicalOperations/disjunctionWithExtraCondition.js +4 -6
  414. package/plugins/filters/menu/focusController.js +123 -0
  415. package/plugins/filters/menu/focusController.mjs +119 -0
  416. package/plugins/filters/menu/focusNavigator.js +30 -0
  417. package/plugins/filters/menu/focusNavigator.mjs +26 -0
  418. package/plugins/filters/ui/_base.js +37 -15
  419. package/plugins/filters/ui/_base.mjs +35 -13
  420. package/plugins/filters/ui/input.js +43 -35
  421. package/plugins/filters/ui/input.mjs +42 -33
  422. package/plugins/filters/ui/link.js +44 -12
  423. package/plugins/filters/ui/link.mjs +44 -11
  424. package/plugins/filters/ui/multipleSelect.js +237 -133
  425. package/plugins/filters/ui/multipleSelect.mjs +232 -127
  426. package/plugins/filters/ui/radioInput.js +42 -18
  427. package/plugins/filters/ui/radioInput.mjs +42 -17
  428. package/plugins/filters/ui/select.js +152 -77
  429. package/plugins/filters/ui/select.mjs +148 -72
  430. package/plugins/formulas/engine/settings.js +2 -4
  431. package/plugins/formulas/formulas.js +3 -6
  432. package/plugins/formulas/indexSyncer/axisSyncer.js +1 -2
  433. package/plugins/formulas/indexSyncer/index.js +1 -2
  434. package/plugins/hiddenColumns/contextMenuItem/hideColumn.js +2 -2
  435. package/plugins/hiddenColumns/contextMenuItem/showColumn.js +2 -2
  436. package/plugins/hiddenColumns/hiddenColumns.d.ts +1 -0
  437. package/plugins/hiddenColumns/hiddenColumns.js +49 -6
  438. package/plugins/hiddenColumns/hiddenColumns.mjs +48 -3
  439. package/plugins/hiddenRows/contextMenuItem/hideRow.js +2 -2
  440. package/plugins/hiddenRows/contextMenuItem/showRow.js +2 -2
  441. package/plugins/hiddenRows/hiddenRows.d.ts +1 -0
  442. package/plugins/hiddenRows/hiddenRows.js +49 -6
  443. package/plugins/hiddenRows/hiddenRows.mjs +48 -3
  444. package/plugins/manualColumnFreeze/contextMenuItem/freezeColumn.js +2 -2
  445. package/plugins/manualColumnFreeze/contextMenuItem/unfreezeColumn.js +2 -2
  446. package/plugins/manualColumnFreeze/manualColumnFreeze.js +2 -4
  447. package/plugins/manualColumnMove/manualColumnMove.js +9 -17
  448. package/plugins/manualColumnMove/manualColumnMove.mjs +7 -13
  449. package/plugins/manualColumnMove/ui/_base.js +1 -2
  450. package/plugins/manualColumnMove/ui/backlight.js +1 -2
  451. package/plugins/manualColumnMove/ui/guideline.js +1 -2
  452. package/plugins/manualColumnResize/manualColumnResize.js +2 -4
  453. package/plugins/manualRowMove/manualRowMove.js +6 -23
  454. package/plugins/manualRowMove/manualRowMove.mjs +4 -19
  455. package/plugins/manualRowMove/ui/_base.js +1 -2
  456. package/plugins/manualRowMove/ui/backlight.js +1 -2
  457. package/plugins/manualRowMove/ui/guideline.js +1 -2
  458. package/plugins/manualRowResize/manualRowResize.js +2 -4
  459. package/plugins/mergeCells/calculations/autofill.js +1 -2
  460. package/plugins/mergeCells/calculations/selection.js +1 -2
  461. package/plugins/mergeCells/cellCoords.js +1 -2
  462. package/plugins/mergeCells/cellsCollection.js +1 -2
  463. package/plugins/mergeCells/contextMenuItem/toggleMerge.js +2 -2
  464. package/plugins/mergeCells/mergeCells.js +7 -20
  465. package/plugins/mergeCells/mergeCells.mjs +5 -16
  466. package/plugins/multiColumnSorting/multiColumnSorting.js +60 -6
  467. package/plugins/multiColumnSorting/multiColumnSorting.mjs +59 -3
  468. package/plugins/multipleSelectionHandles/multipleSelectionHandles.js +2 -4
  469. package/plugins/nestedHeaders/nestedHeaders.js +263 -36
  470. package/plugins/nestedHeaders/nestedHeaders.mjs +262 -33
  471. package/plugins/nestedHeaders/stateManager/index.js +102 -3
  472. package/plugins/nestedHeaders/stateManager/index.mjs +102 -3
  473. package/plugins/nestedHeaders/stateManager/sourceSettings.js +1 -2
  474. package/plugins/nestedHeaders/utils/ghostTable.js +1 -2
  475. package/plugins/nestedRows/data/dataManager.js +1 -2
  476. package/plugins/nestedRows/nestedRows.js +47 -10
  477. package/plugins/nestedRows/nestedRows.mjs +45 -6
  478. package/plugins/nestedRows/ui/_base.js +1 -2
  479. package/plugins/nestedRows/ui/collapsing.js +1 -2
  480. package/plugins/nestedRows/ui/contextMenu.js +3 -4
  481. package/plugins/nestedRows/ui/headers.js +13 -3
  482. package/plugins/nestedRows/ui/headers.mjs +13 -2
  483. package/plugins/persistentState/persistentState.js +2 -4
  484. package/plugins/persistentState/storage.js +1 -2
  485. package/plugins/search/search.js +2 -4
  486. package/plugins/touchScroll/touchScroll.js +2 -4
  487. package/plugins/trimRows/trimRows.js +2 -4
  488. package/plugins/undoRedo/index.js +2 -2
  489. package/plugins/undoRedo/undoRedo.js +2 -4
  490. package/renderers/autocompleteRenderer/autocompleteRenderer.js +9 -2
  491. package/renderers/autocompleteRenderer/autocompleteRenderer.mjs +8 -0
  492. package/renderers/baseRenderer/baseRenderer.js +18 -2
  493. package/renderers/baseRenderer/baseRenderer.mjs +18 -1
  494. package/renderers/checkboxRenderer/checkboxRenderer.js +10 -6
  495. package/renderers/checkboxRenderer/checkboxRenderer.mjs +9 -4
  496. package/renderers/dateRenderer/dateRenderer.d.ts +5 -0
  497. package/renderers/dateRenderer/dateRenderer.js +28 -0
  498. package/renderers/dateRenderer/dateRenderer.mjs +24 -0
  499. package/renderers/dateRenderer/index.d.ts +1 -0
  500. package/renderers/dateRenderer/index.js +6 -0
  501. package/renderers/dateRenderer/index.mjs +1 -0
  502. package/renderers/handsontableRenderer/handsontableRenderer.d.ts +5 -0
  503. package/renderers/handsontableRenderer/handsontableRenderer.js +28 -0
  504. package/renderers/handsontableRenderer/handsontableRenderer.mjs +24 -0
  505. package/renderers/handsontableRenderer/index.d.ts +1 -0
  506. package/renderers/handsontableRenderer/index.js +6 -0
  507. package/renderers/handsontableRenderer/index.mjs +1 -0
  508. package/renderers/htmlRenderer/htmlRenderer.js +1 -2
  509. package/renderers/index.d.ts +9 -0
  510. package/renderers/numericRenderer/numericRenderer.js +1 -2
  511. package/renderers/passwordRenderer/passwordRenderer.js +1 -2
  512. package/renderers/selectRenderer/index.d.ts +1 -0
  513. package/renderers/selectRenderer/index.js +6 -0
  514. package/renderers/selectRenderer/index.mjs +1 -0
  515. package/renderers/selectRenderer/selectRenderer.d.ts +5 -0
  516. package/renderers/selectRenderer/selectRenderer.js +26 -0
  517. package/renderers/selectRenderer/selectRenderer.mjs +22 -0
  518. package/renderers/textRenderer/textRenderer.js +1 -2
  519. package/renderers/timeRenderer/timeRenderer.js +1 -2
  520. package/selection/highlight/highlight.js +257 -73
  521. package/selection/highlight/highlight.mjs +250 -71
  522. package/selection/highlight/types/activeHeader.js +10 -8
  523. package/selection/highlight/types/activeHeader.mjs +10 -8
  524. package/selection/highlight/types/area.js +6 -18
  525. package/selection/highlight/types/area.mjs +6 -18
  526. package/selection/highlight/types/areaLayered.js +31 -0
  527. package/selection/highlight/types/areaLayered.mjs +26 -0
  528. package/selection/highlight/types/column.js +27 -0
  529. package/selection/highlight/types/column.mjs +22 -0
  530. package/selection/highlight/types/customSelection.js +7 -9
  531. package/selection/highlight/types/customSelection.mjs +7 -9
  532. package/selection/highlight/types/fill.js +5 -7
  533. package/selection/highlight/types/fill.mjs +5 -7
  534. package/selection/highlight/types/{cell.js → focus.js} +5 -7
  535. package/selection/highlight/types/{cell.mjs → focus.mjs} +5 -7
  536. package/selection/highlight/types/header.js +9 -18
  537. package/selection/highlight/types/header.mjs +9 -18
  538. package/selection/highlight/types/row.js +27 -0
  539. package/selection/highlight/types/row.mjs +22 -0
  540. package/selection/highlight/visualSelection.js +32 -29
  541. package/selection/highlight/visualSelection.mjs +31 -27
  542. package/selection/index.js +4 -7
  543. package/selection/index.mjs +2 -3
  544. package/selection/mouseEventHandler.js +7 -1
  545. package/selection/mouseEventHandler.mjs +7 -1
  546. package/selection/range.js +9 -10
  547. package/selection/range.mjs +8 -8
  548. package/selection/selection.js +334 -154
  549. package/selection/selection.mjs +330 -151
  550. package/selection/transformation.js +233 -94
  551. package/selection/transformation.mjs +232 -92
  552. package/selection/utils.js +20 -31
  553. package/selection/utils.mjs +16 -21
  554. package/settings.d.ts +4 -0
  555. package/shortcutContexts/commands/editor/closeAndSave.js +11 -0
  556. package/shortcutContexts/commands/editor/closeAndSave.mjs +8 -0
  557. package/shortcutContexts/commands/editor/closeWithoutSaving.js +11 -0
  558. package/shortcutContexts/commands/editor/closeWithoutSaving.mjs +8 -0
  559. package/shortcutContexts/commands/editor/fastOpen.js +15 -0
  560. package/shortcutContexts/commands/editor/fastOpen.mjs +12 -0
  561. package/shortcutContexts/commands/editor/index.js +16 -0
  562. package/shortcutContexts/commands/editor/index.mjs +12 -0
  563. package/shortcutContexts/commands/editor/open.js +26 -0
  564. package/shortcutContexts/commands/editor/open.mjs +23 -0
  565. package/shortcutContexts/commands/emptySelectedCells.js +10 -0
  566. package/shortcutContexts/commands/emptySelectedCells.mjs +7 -0
  567. package/shortcutContexts/commands/extendCellsSelection/down.js +14 -0
  568. package/shortcutContexts/commands/extendCellsSelection/down.mjs +11 -0
  569. package/shortcutContexts/commands/extendCellsSelection/downByViewportHeight.js +24 -0
  570. package/shortcutContexts/commands/extendCellsSelection/downByViewportHeight.mjs +21 -0
  571. package/shortcutContexts/commands/extendCellsSelection/index.js +26 -0
  572. package/shortcutContexts/commands/extendCellsSelection/index.mjs +22 -0
  573. package/shortcutContexts/commands/extendCellsSelection/left.js +14 -0
  574. package/shortcutContexts/commands/extendCellsSelection/left.mjs +11 -0
  575. package/shortcutContexts/commands/extendCellsSelection/right.js +14 -0
  576. package/shortcutContexts/commands/extendCellsSelection/right.mjs +11 -0
  577. package/shortcutContexts/commands/extendCellsSelection/toColumns.js +18 -0
  578. package/shortcutContexts/commands/extendCellsSelection/toColumns.mjs +15 -0
  579. package/shortcutContexts/commands/extendCellsSelection/toMostBottom.js +28 -0
  580. package/shortcutContexts/commands/extendCellsSelection/toMostBottom.mjs +25 -0
  581. package/shortcutContexts/commands/extendCellsSelection/toMostInlineEnd.js +18 -0
  582. package/shortcutContexts/commands/extendCellsSelection/toMostInlineEnd.mjs +15 -0
  583. package/shortcutContexts/commands/extendCellsSelection/toMostInlineStart.js +18 -0
  584. package/shortcutContexts/commands/extendCellsSelection/toMostInlineStart.mjs +15 -0
  585. package/shortcutContexts/commands/extendCellsSelection/toMostLeft.js +28 -0
  586. package/shortcutContexts/commands/extendCellsSelection/toMostLeft.mjs +25 -0
  587. package/shortcutContexts/commands/extendCellsSelection/toMostRight.js +28 -0
  588. package/shortcutContexts/commands/extendCellsSelection/toMostRight.mjs +25 -0
  589. package/shortcutContexts/commands/extendCellsSelection/toMostTop.js +28 -0
  590. package/shortcutContexts/commands/extendCellsSelection/toMostTop.mjs +25 -0
  591. package/shortcutContexts/commands/extendCellsSelection/toRows.js +18 -0
  592. package/shortcutContexts/commands/extendCellsSelection/toRows.mjs +15 -0
  593. package/shortcutContexts/commands/extendCellsSelection/up.js +14 -0
  594. package/shortcutContexts/commands/extendCellsSelection/up.mjs +11 -0
  595. package/shortcutContexts/commands/extendCellsSelection/upByViewportHeight.js +24 -0
  596. package/shortcutContexts/commands/extendCellsSelection/upByViewportHeight.mjs +21 -0
  597. package/shortcutContexts/commands/index.js +35 -0
  598. package/shortcutContexts/commands/index.mjs +31 -0
  599. package/shortcutContexts/commands/moveCellSelection/down.js +12 -0
  600. package/shortcutContexts/commands/moveCellSelection/down.mjs +9 -0
  601. package/shortcutContexts/commands/moveCellSelection/downByViewportHeight.js +32 -0
  602. package/shortcutContexts/commands/moveCellSelection/downByViewportHeight.mjs +29 -0
  603. package/shortcutContexts/commands/moveCellSelection/index.js +28 -0
  604. package/shortcutContexts/commands/moveCellSelection/index.mjs +24 -0
  605. package/shortcutContexts/commands/moveCellSelection/inlineEnd.js +11 -0
  606. package/shortcutContexts/commands/moveCellSelection/inlineEnd.mjs +8 -0
  607. package/shortcutContexts/commands/moveCellSelection/inlineStart.js +11 -0
  608. package/shortcutContexts/commands/moveCellSelection/inlineStart.mjs +8 -0
  609. package/shortcutContexts/commands/moveCellSelection/left.js +9 -0
  610. package/shortcutContexts/commands/moveCellSelection/left.mjs +6 -0
  611. package/shortcutContexts/commands/moveCellSelection/right.js +9 -0
  612. package/shortcutContexts/commands/moveCellSelection/right.mjs +6 -0
  613. package/shortcutContexts/commands/moveCellSelection/toMostBottom.js +16 -0
  614. package/shortcutContexts/commands/moveCellSelection/toMostBottom.mjs +13 -0
  615. package/shortcutContexts/commands/moveCellSelection/toMostBottomInlineEnd.js +17 -0
  616. package/shortcutContexts/commands/moveCellSelection/toMostBottomInlineEnd.mjs +14 -0
  617. package/shortcutContexts/commands/moveCellSelection/toMostInlineEnd.js +13 -0
  618. package/shortcutContexts/commands/moveCellSelection/toMostInlineEnd.mjs +10 -0
  619. package/shortcutContexts/commands/moveCellSelection/toMostInlineStart.js +16 -0
  620. package/shortcutContexts/commands/moveCellSelection/toMostInlineStart.mjs +13 -0
  621. package/shortcutContexts/commands/moveCellSelection/toMostLeft.js +18 -0
  622. package/shortcutContexts/commands/moveCellSelection/toMostLeft.mjs +15 -0
  623. package/shortcutContexts/commands/moveCellSelection/toMostRight.js +20 -0
  624. package/shortcutContexts/commands/moveCellSelection/toMostRight.mjs +17 -0
  625. package/shortcutContexts/commands/moveCellSelection/toMostTop.js +16 -0
  626. package/shortcutContexts/commands/moveCellSelection/toMostTop.mjs +13 -0
  627. package/shortcutContexts/commands/moveCellSelection/toMostTopInlineStart.js +18 -0
  628. package/shortcutContexts/commands/moveCellSelection/toMostTopInlineStart.mjs +15 -0
  629. package/shortcutContexts/commands/moveCellSelection/up.js +12 -0
  630. package/shortcutContexts/commands/moveCellSelection/up.mjs +9 -0
  631. package/shortcutContexts/commands/moveCellSelection/upByViewportHeight.js +32 -0
  632. package/shortcutContexts/commands/moveCellSelection/upByViewportHeight.mjs +29 -0
  633. package/shortcutContexts/commands/populateSelectedCellsData.js +28 -0
  634. package/shortcutContexts/commands/populateSelectedCellsData.mjs +25 -0
  635. package/shortcutContexts/commands/scrollToFocusedCell.js +34 -0
  636. package/shortcutContexts/commands/scrollToFocusedCell.mjs +31 -0
  637. package/shortcutContexts/commands/selectAll.js +11 -0
  638. package/shortcutContexts/commands/selectAll.mjs +8 -0
  639. package/shortcutContexts/constants.js +11 -0
  640. package/shortcutContexts/constants.mjs +8 -0
  641. package/shortcutContexts/editor.js +25 -0
  642. package/shortcutContexts/editor.mjs +21 -0
  643. package/shortcutContexts/grid.js +167 -0
  644. package/shortcutContexts/grid.mjs +163 -0
  645. package/shortcutContexts/index.js +24 -0
  646. package/shortcutContexts/index.mjs +11 -0
  647. package/shortcuts/context.d.ts +1 -0
  648. package/shortcuts/context.js +23 -4
  649. package/shortcuts/context.mjs +23 -5
  650. package/shortcuts/manager.js +31 -7
  651. package/shortcuts/manager.mjs +32 -7
  652. package/shortcuts/recorder.js +30 -14
  653. package/shortcuts/recorder.mjs +30 -14
  654. package/shortcuts/utils.js +19 -5
  655. package/shortcuts/utils.mjs +18 -4
  656. package/tableView.js +113 -16
  657. package/tableView.mjs +113 -15
  658. package/utils/dataStructures/linkedList.js +1 -2
  659. package/utils/dataStructures/priorityMap.js +2 -4
  660. package/utils/dataStructures/queue.js +1 -2
  661. package/utils/dataStructures/stack.js +1 -2
  662. package/utils/dataStructures/tree.js +3 -6
  663. package/utils/ghostTable.js +32 -17
  664. package/utils/ghostTable.mjs +31 -15
  665. package/utils/interval.js +1 -2
  666. package/utils/paginator.js +151 -0
  667. package/utils/paginator.mjs +147 -0
  668. package/utils/parseTable.js +527 -83
  669. package/utils/parseTable.mjs +523 -82
  670. package/utils/rootInstance.js +2 -4
  671. package/utils/samplesGenerator.js +21 -13
  672. package/utils/samplesGenerator.mjs +20 -11
  673. package/utils/staticRegister.js +1 -2
  674. package/validators/autocompleteValidator/autocompleteValidator.js +1 -2
  675. package/validators/dateValidator/dateValidator.js +1 -2
  676. package/validators/numericValidator/numericValidator.js +1 -2
  677. package/validators/timeValidator/timeValidator.js +1 -2
  678. package/3rdparty/walkontable/src/selection.js +0 -295
  679. package/3rdparty/walkontable/src/selection.mjs +0 -290
  680. package/plugins/contextMenu/predefinedItems.js +0 -76
  681. package/plugins/contextMenu/predefinedItems.mjs +0 -68
  682. package/plugins/copyPaste/clipboardData.js +0 -18
  683. package/plugins/copyPaste/clipboardData.mjs +0 -14
  684. package/plugins/copyPaste/focusableElement.js +0 -186
  685. package/plugins/copyPaste/focusableElement.mjs +0 -180
  686. package/plugins/copyPaste/pasteEvent.js +0 -14
  687. package/plugins/copyPaste/pasteEvent.mjs +0 -9
  688. package/selection/highlight/constants.js +0 -15
  689. package/selection/highlight/constants.mjs +0 -6
  690. package/selection/highlight/types/index.js +0 -35
  691. package/selection/highlight/types/index.mjs +0 -31
@@ -1,5 +1,8 @@
1
1
  import "core-js/modules/es.array.push.js";
2
+ import "core-js/modules/es.string.replace-all.js";
2
3
  import { isEmpty } from "./../helpers/mixed.mjs";
4
+ import { isObject } from "./../helpers/object.mjs";
5
+ import { rangeEach } from "../helpers/number.mjs";
3
6
  const ESCAPED_HTML_CHARS = {
4
7
  ' ': '\x20',
5
8
  '&': '&',
@@ -18,102 +21,539 @@ function isHTMLTable(element) {
18
21
  return (element && element.nodeName || '') === 'TABLE';
19
22
  }
20
23
 
24
+ /**
25
+ * Parses empty values to an empty string or leave them untouched otherwise.
26
+ *
27
+ * @private
28
+ * @param {string} cellValue Parsed cell value.
29
+ * @returns {string}
30
+ */
31
+ function parseEmptyValues(cellValue) {
32
+ if (isEmpty(cellValue)) {
33
+ return '';
34
+ }
35
+ return cellValue;
36
+ }
37
+
21
38
  /**
22
39
  * Converts Handsontable into HTMLTableElement.
23
40
  *
24
- * @param {Core} instance The Handsontable instance.
41
+ * @param {Core} hotInstance The Handsontable instance.
25
42
  * @returns {string} OuterHTML of the HTMLTableElement.
26
43
  */
27
- export function instanceToHTML(instance) {
28
- const hasColumnHeaders = instance.hasColHeaders();
29
- const hasRowHeaders = instance.hasRowHeaders();
30
- const coords = [hasColumnHeaders ? -1 : 0, hasRowHeaders ? -1 : 0, instance.countRows() - 1, instance.countCols() - 1];
31
- const data = instance.getData(...coords);
32
- const countRows = data.length;
33
- const countCols = countRows > 0 ? data[0].length : 0;
34
- const TABLE = ['<table>', '</table>'];
35
- const THEAD = hasColumnHeaders ? ['<thead>', '</thead>'] : [];
36
- const TBODY = ['<tbody>', '</tbody>'];
37
- const rowModifier = hasRowHeaders ? 1 : 0;
38
- const columnModifier = hasColumnHeaders ? 1 : 0;
39
- for (let row = 0; row < countRows; row += 1) {
40
- const isColumnHeadersRow = hasColumnHeaders && row === 0;
41
- const CELLS = [];
42
- for (let column = 0; column < countCols; column += 1) {
43
- const isRowHeadersColumn = !isColumnHeadersRow && hasRowHeaders && column === 0;
44
- let cell = '';
45
- if (isColumnHeadersRow) {
46
- cell = `<th>${instance.getColHeader(column - rowModifier)}</th>`;
47
- } else if (isRowHeadersColumn) {
48
- cell = `<th>${instance.getRowHeader(row - columnModifier)}</th>`;
49
- } else {
50
- const cellData = data[row][column];
44
+ export function instanceToHTML(hotInstance) {
45
+ const startColumn = hotInstance.hasRowHeaders() ? -1 : 0;
46
+ const startRow = hotInstance.hasColHeaders() ? -1 : 0;
47
+ const rows = Array.from({
48
+ length: hotInstance.countRows() + Math.abs(startRow)
49
+ }, (_, i) => i + startRow);
50
+ const columns = Array.from({
51
+ length: hotInstance.countCols() + Math.abs(startColumn)
52
+ }, (_, i) => i + startColumn);
53
+ return getHTMLByCoords(hotInstance, {
54
+ rows,
55
+ columns
56
+ });
57
+ }
58
+
59
+ /**
60
+ * Converts Handsontable's coordinates into HTMLTableElement.
61
+ *
62
+ * @param {Core} hotInstance The Handsontable instance.
63
+ * @param {object} config Configuration for building HTMLTableElement.
64
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the table.
65
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the table.
66
+ * @returns {string} OuterHTML of the HTMLTableElement.
67
+ */
68
+ export function getHTMLByCoords(hotInstance, config) {
69
+ return ['<table>', ...getHeadersHTMLByCoords(hotInstance, config), ...getBodyHTMLByCoords(hotInstance, config), '</table>'].join('');
70
+ }
71
+
72
+ /**
73
+ * Converts Handsontable's coordinates into list of cell values.
74
+ *
75
+ * @param {Core} hotInstance The Handsontable instance.
76
+ * @param {object} config Configuration for building the cell value list.
77
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the
78
+ * cell value list.
79
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the
80
+ * cell value list.
81
+ * @returns {Array<Array<string>>} List of displayed cell values.
82
+ */
83
+ export function getDataByCoords(hotInstance, config) {
84
+ return [...getHeadersDataByCoords(hotInstance, config), ...getBodyDataByCoords(hotInstance, config)];
85
+ }
86
+
87
+ /**
88
+ * Converts config into HTMLTableElement.
89
+ *
90
+ * @param {object} config Configuration for building HTMLTableElement.
91
+ * @param {Array<number>} [config.excludedRows] List of row indexes which should be excluded when creating the table.
92
+ * @param {Array<number>} [config.excludedColumns] List of column indexes which should be excluded when creating the table.
93
+ * @param {Array<Array<string>>} [config.data] List of cell data.
94
+ * @param {Array<object>} [config.mergeCells] List of merged cells.
95
+ * @param {Array<Array<string|object>>} [config.nestedHeaders] List of headers and corresponding information about some
96
+ * nested elements.
97
+ * @param {Array<string>} [config.colHeaders] List of first level header values.
98
+ * @returns {string} OuterHTML of the HTMLTableElement.
99
+ */
100
+ export function getHTMLFromConfig(config) {
101
+ return ['<table>', ...getHeadersHTMLByConfig(config), ...getBodyHTMLByConfig(config), '</table>'].join('');
102
+ }
103
+
104
+ /**
105
+ * Get list of filtered nested headers.
106
+ *
107
+ * @param {Array<Array<string|object>>} nestedHeaders List of nested headers which will be filtered.
108
+ * @param {Array<number>} excludedHeaders List of headers which should be excluded when creating the HTMLTableElement.tHead.
109
+ * @param {Array<number>} excludedColumns List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
110
+ * @returns {*}
111
+ */
112
+ function getFilteredNestedHeaders(nestedHeaders, excludedHeaders, excludedColumns) {
113
+ return nestedHeaders.reduce((listOfHeaders, headerValues, rowIndex) => {
114
+ if (excludedHeaders.includes(rowIndex - nestedHeaders.length)) {
115
+ return listOfHeaders;
116
+ }
117
+ const filteredNestedHeader = headerValues.filter((columnData, columnIndex) => excludedColumns.includes(columnIndex) === false);
118
+ if (filteredNestedHeader.length > 0) {
119
+ return listOfHeaders.concat([filteredNestedHeader]);
120
+ }
121
+ return listOfHeaders;
122
+ }, []);
123
+ }
124
+
125
+ /**
126
+ * Get HTML for nested headers.
127
+ *
128
+ * @param {Array<Array<string|object>>} nestedHeaders List of nested headers which will be filtered.
129
+ * @param {Array<number>} excludedHeaders List of headers which should be excluded when creating the HTMLTableElement.tHead.
130
+ * @param {Array<number>} excludedColumns List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
131
+ * @returns {Array<string>}
132
+ */
133
+ function getNestedHeadersHTML(nestedHeaders, excludedHeaders, excludedColumns) {
134
+ const headersHTML = [];
135
+ getFilteredNestedHeaders(nestedHeaders, excludedHeaders, excludedColumns).forEach(listOfHeaders => {
136
+ const rowHTML = ['<tr>'];
137
+ for (let i = 0; i < listOfHeaders.length; i += 1) {
138
+ const header = listOfHeaders[i];
139
+ let headerValue = header;
140
+ let colspanAttribute = '';
141
+ if (isObject(header)) {
142
+ const {
143
+ colspan,
144
+ label
145
+ } = header;
146
+ headerValue = label;
147
+ colspanAttribute = ` colspan=${colspan}`;
148
+ }
149
+ rowHTML.push(`<th${colspanAttribute}>${encodeHTMLEntities(parseEmptyValues(headerValue))}</th>`);
150
+ }
151
+ rowHTML.push('</tr>');
152
+ headersHTML.push(...rowHTML);
153
+ });
154
+ return headersHTML;
155
+ }
156
+
157
+ /**
158
+ * Get HTML for first level header.
159
+ *
160
+ * @param {Array<string>} columnHeaders List of header values which will be filtered.
161
+ * @param {Array<number>} excludedHeaders List of headers which should be excluded when creating the HTMLTableElement.tHead.
162
+ * @param {Array<number>} excludedColumns List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
163
+ * @returns {*[]}
164
+ */
165
+ function getSimpleHeadersHTML(columnHeaders, excludedHeaders, excludedColumns) {
166
+ if (excludedHeaders.includes(-1)) {
167
+ return [];
168
+ }
169
+ const filteredColumnHeaders = columnHeaders.filter((columnHeaderValue, columnIndex) => excludedColumns.includes(columnIndex) === false);
170
+ if (filteredColumnHeaders.length === 0) {
171
+ return [];
172
+ }
173
+ return ['<tr>', ...filteredColumnHeaders.map(columnHeader => `<th>${encodeHTMLEntities(parseEmptyValues(columnHeader))}</th>`), '</tr>'];
174
+ }
175
+
176
+ /**
177
+ * Get list of cells filtered by list of excluded rows and columns.
178
+ *
179
+ * @private
180
+ * @param {Array<Array<string>>} data List of cells values which will be filtered.
181
+ * @param {Array<number>} excludedRows List of row indexes which should be excluded when creating the HTMLTableElement.tHead.
182
+ * @param {Array<number>} excludedColumns List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
183
+ * @returns {Array<string>} List of cell values.
184
+ */
185
+ function getFilteredCells(data, excludedRows, excludedColumns) {
186
+ if (Array.isArray(data) === false) {
187
+ return [];
188
+ }
189
+ return data.reduce((listOfCells, rowData, rowIndex) => {
190
+ if (excludedRows.includes(rowIndex)) {
191
+ return listOfCells;
192
+ }
193
+ const filteredRowData = rowData.filter((cellData, columnIndex) => excludedColumns.includes(columnIndex) === false);
194
+ if (filteredRowData.length > 0) {
195
+ return listOfCells.concat([filteredRowData]);
196
+ }
197
+ return listOfCells;
198
+ }, []);
199
+ }
200
+
201
+ /**
202
+ * Prepare information about merged areas to reduce complexity of calculations.
203
+ *
204
+ * @private
205
+ * @param {Array<object>} mergedCellsConfig List of merged cells.
206
+ * @returns {{mergedCellsMap: Map<any, any>, mergedArea: Set<any>}}
207
+ */
208
+ function getMergedCellsInformation(mergedCellsConfig) {
209
+ const mergedCellsMap = new Map();
210
+ const mergedArea = new Set();
211
+ let mergedRows = 1;
212
+ let mergedColumns = 1;
213
+ mergedCellsConfig === null || mergedCellsConfig === void 0 || mergedCellsConfig.forEach(mergeArea => {
214
+ const {
215
+ row,
216
+ col,
217
+ rowspan,
218
+ colspan
219
+ } = mergeArea;
220
+ mergedCellsMap.set(`${row}x${col}`, {
221
+ rowspan,
222
+ colspan
223
+ });
224
+ if (Number.isInteger(rowspan)) {
225
+ mergedRows = rowspan;
226
+ }
227
+ if (Number.isInteger(colspan)) {
228
+ mergedColumns = colspan;
229
+ }
230
+ rangeEach(row, row + mergedRows - 1, rowIndex => {
231
+ rangeEach(col, col + mergedColumns - 1, columnIndex => {
232
+ // Other than start point.
233
+ if (rowIndex !== row || columnIndex !== col) {
234
+ mergedArea.add(`${rowIndex}x${columnIndex}`);
235
+ }
236
+ });
237
+ });
238
+ });
239
+ return {
240
+ mergedCellsMap,
241
+ mergedArea
242
+ };
243
+ }
244
+
245
+ /**
246
+ * Converts config with information about cells into HTMLTableElement.tBodies.
247
+ *
248
+ * @private
249
+ * @param {object} config Configuration for building HTMLTableElement.tBodies.
250
+ * @param {Array<Array<string>>} config.data List of cell data.
251
+ * @param {Array<number>} [config.excludedRows] List of row indexes which should be excluded when creating the HTMLTableElement.tBodies.
252
+ * @param {Array<number>} [config.excludedColumns] List of column indexes which should be excluded when creating the HTMLTableElement.tBodies.
253
+ * @param {Array<object>} [config.mergeCells] List of merged cells.
254
+ * @returns {Array<string>} List of HTMLElements stored as strings.
255
+ */
256
+ function getBodyHTMLByConfig(config) {
257
+ const excludedColumns = config.excludedColumns || [];
258
+ const excludedRows = config.excludedRows || [];
259
+ const {
260
+ data,
261
+ mergeCells
262
+ } = config;
263
+ const ignoredCellRows = excludedRows.filter(rowIndex => rowIndex >= 0);
264
+ const filteredData = getFilteredCells(data, ignoredCellRows, excludedColumns);
265
+ const cells = [];
266
+ if (filteredData.length === 0) {
267
+ return [];
268
+ }
269
+ const {
270
+ mergedCellsMap,
271
+ mergedArea
272
+ } = getMergedCellsInformation(mergeCells);
273
+ filteredData.forEach((rowData, rowIndex) => {
274
+ const rowHTML = ['<tr>'];
275
+ rowData.forEach((cellData, columnIndex) => {
276
+ const attrs = [];
277
+ const checkedMergeCoordinate = `${rowIndex}x${columnIndex}`;
278
+ const mergeParent = mergedCellsMap.get(checkedMergeCoordinate);
279
+ if (mergeParent !== undefined) {
51
280
  const {
52
- hidden,
53
281
  rowspan,
54
282
  colspan
55
- } = instance.getCellMeta(row - columnModifier, column - rowModifier);
56
- if (!hidden) {
57
- const attrs = [];
58
- if (rowspan) {
59
- attrs.push(`rowspan="${rowspan}"`);
60
- }
61
- if (colspan) {
62
- attrs.push(`colspan="${colspan}"`);
63
- }
64
- if (isEmpty(cellData)) {
65
- cell = `<td ${attrs.join(' ')}></td>`;
66
- } else {
67
- const value = cellData.toString().replace('<', '&lt;').replace('>', '&gt;').replace(/(<br(\s*|\/)>(\r\n|\n)?|\r\n|\n)/g, '<br>\r\n').replace(/\x20/gi, '&nbsp;').replace(/\t/gi, '&#9;');
68
- cell = `<td ${attrs.join(' ')}>${value}</td>`;
69
- }
283
+ } = mergeParent;
284
+ if (Number.isInteger(rowspan) && rowspan > 1) {
285
+ attrs.push(` rowspan="${rowspan}"`);
286
+ }
287
+ if (Number.isInteger(colspan) && colspan > 1) {
288
+ attrs.push(` colspan="${colspan}"`);
70
289
  }
290
+ } else if (mergedArea.has(checkedMergeCoordinate)) {
291
+ return;
71
292
  }
72
- CELLS.push(cell);
73
- }
74
- const TR = ['<tr>', ...CELLS, '</tr>'].join('');
75
- if (isColumnHeadersRow) {
76
- THEAD.splice(1, 0, TR);
77
- } else {
78
- TBODY.splice(-1, 0, TR);
79
- }
293
+ rowHTML.push(`<td${attrs.join('')}>${encodeHTMLEntities(parseEmptyValues(cellData))}</td>`);
294
+ });
295
+ rowHTML.push('</tr>');
296
+ cells.push(...rowHTML);
297
+ });
298
+ return ['<tbody>', ...cells, '</tbody>'];
299
+ }
300
+
301
+ /**
302
+ * Converts config with information about headers into HTMLTableElement.tHead.
303
+ *
304
+ * @private
305
+ * @param {object} config Configuration for building HTMLTableElement.tHead.
306
+ * @param {Array<Array<string|object>>} [config.nestedHeaders] List of headers and corresponding information about some
307
+ * nested elements.
308
+ * @param {Array<string>} [config.colHeaders] List of first level header values.
309
+ * @param {Array<number>} [config.excludedRows] List of row indexes which should be excluded when creating the HTMLTableElement.tHead.
310
+ * @param {Array<number>} [config.excludedColumns] List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
311
+ * @returns {Array<string>} List of HTMLElements stored as strings.
312
+ */
313
+ function getHeadersHTMLByConfig(config) {
314
+ const headersHTML = [];
315
+ const excludedColumns = Array.isArray(config === null || config === void 0 ? void 0 : config.excludedColumns) ? config.excludedColumns : [];
316
+ const excludedRows = Array.isArray(config === null || config === void 0 ? void 0 : config.excludedRows) ? config.excludedRows : [];
317
+ const {
318
+ nestedHeaders,
319
+ colHeaders
320
+ } = config;
321
+ const excludedHeaders = excludedRows.filter(rowIndex => rowIndex < 0);
322
+ if (Array.isArray(nestedHeaders)) {
323
+ headersHTML.push(...getNestedHeadersHTML(nestedHeaders, excludedHeaders, excludedColumns));
324
+ } else if (Array.isArray(colHeaders)) {
325
+ headersHTML.push(...getSimpleHeadersHTML(colHeaders, excludedHeaders, excludedColumns));
80
326
  }
81
- TABLE.splice(1, 0, THEAD.join(''), TBODY.join(''));
82
- return TABLE.join('');
327
+ if (headersHTML.length > 0) {
328
+ return ['<thead>', ...headersHTML, '</thead>'];
329
+ }
330
+ return [];
83
331
  }
84
332
 
85
333
  /**
86
- * Converts 2D array into HTMLTableElement.
334
+ * Converts config with information about cells and headers into list of values.
87
335
  *
88
- * @param {Array} input Input array which will be converted to HTMLTable.
89
- * @returns {string} OuterHTML of the HTMLTableElement.
336
+ * @param {object} config Configuration for building list of values.
337
+ * @param {Array<number>} [config.excludedRows] List of row indexes which should be excluded when creating the value list.
338
+ * @param {Array<number>} [config.excludedColumns] List of column indexes which should be excluded when creating the value list.
339
+ * @param {Array<Array<string|object>>} [config.nestedHeaders] List of headers and information about some nested elements.
340
+ * @param {Array<string>} [config.colHeaders] List of first level header values.
341
+ * @returns {string[][]} List of values.
90
342
  */
91
- // eslint-disable-next-line no-restricted-globals
92
- export function _dataToHTML(input) {
93
- const inputLen = input.length;
94
- const result = ['<table>'];
95
- for (let row = 0; row < inputLen; row += 1) {
96
- const rowData = input[row];
97
- const columnsLen = rowData.length;
98
- const columnsResult = [];
99
- if (row === 0) {
100
- result.push('<tbody>');
101
- }
102
- for (let column = 0; column < columnsLen; column += 1) {
103
- const cellData = rowData[column];
104
- const parsedCellData = isEmpty(cellData) ? '' : cellData.toString().replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/(<br(\s*|\/)>(\r\n|\n)?|\r\n|\n)/g, '<br>\r\n').replace(/\x20{2,}/gi, substring => {
105
- // The way how Excel serializes data with at least two spaces.
106
- return `<span style="mso-spacerun: yes">${'&nbsp;'.repeat(substring.length - 1)} </span>`;
107
- }).replace(/\t/gi, '&#9;');
108
- columnsResult.push(`<td>${parsedCellData}</td>`);
343
+ export function getDataWithHeadersByConfig(config) {
344
+ const dataWithHeaders = [];
345
+ const excludedColumns = Array.isArray(config === null || config === void 0 ? void 0 : config.excludedColumns) ? config.excludedColumns : [];
346
+ const excludedRows = Array.isArray(config === null || config === void 0 ? void 0 : config.excludedRows) ? config.excludedRows : [];
347
+ const {
348
+ data,
349
+ nestedHeaders,
350
+ colHeaders
351
+ } = config;
352
+ const excludedHeaders = excludedRows.filter(rowIndex => rowIndex < 0);
353
+ if (Array.isArray(nestedHeaders)) {
354
+ dataWithHeaders.push(...getFilteredNestedHeaders(nestedHeaders, excludedHeaders, excludedColumns).map(listOfHeaders => {
355
+ return listOfHeaders.reduce((headers, header) => {
356
+ if (isObject(header)) {
357
+ headers.push(header.label, ...new Array(header.colspan - 1).fill(''));
358
+ } else {
359
+ headers.push(header);
360
+ }
361
+ return headers;
362
+ }, []);
363
+ }));
364
+ } else if (Array.isArray(colHeaders)) {
365
+ dataWithHeaders.push([...colHeaders.filter((columnHeaderData, columnIndex) => excludedColumns.includes(columnIndex) === false)]);
366
+ }
367
+ dataWithHeaders.push(...getFilteredCells(data, excludedRows.filter(rowIndex => rowIndex >= 0), excludedColumns.filter(columnIndex => columnIndex >= 0)));
368
+ return dataWithHeaders;
369
+ }
370
+
371
+ /**
372
+ * Encode text to HTML.
373
+ *
374
+ * @param {string} text Text to prepare.
375
+ * @returns {string}
376
+ */
377
+ function encodeHTMLEntities(text) {
378
+ return `${text}`.replace(/&/g, '&amp;').replace('<', '&lt;').replace('>', '&gt;').replace(/(<br(\s*|\/)>(\r\n|\n)?|\r\n|\n)/g, '<br>\r\n').replace(/\x20{2,}/gi, substring => {
379
+ // The way how Excel serializes data with at least two spaces.
380
+ return `<span style="mso-spacerun: yes">${'&nbsp;'.repeat(substring.length - 1)} </span>`;
381
+ }).replace(/\t/gi, '&#9;');
382
+ }
383
+
384
+ /**
385
+ * Decode HTML to simple text.
386
+ *
387
+ * @param {string} html HTML for handling.
388
+ * @returns {string}
389
+ */
390
+ function decodeHTMLEntities(html) {
391
+ return html.replace(regEscapedChars, match => ESCAPED_HTML_CHARS[match])
392
+ // The way how Excel serializes data with at least two spaces.
393
+ .replace(/<span style="mso-spacerun: yes">(.+?)<\/span>/, '$1').replaceAll('&nbsp;', ' ');
394
+ }
395
+
396
+ /**
397
+ * Converts Handsontable's header coordinates into HTMLTableElement.tHead.
398
+ *
399
+ * @param {Core} hotInstance The Handsontable instance.
400
+ * @param {object} config Configuration for building HTMLTableElement.tHead.
401
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating
402
+ * the HTMLTableElement.tHead.
403
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating
404
+ * the HTMLTableElement.tHead.
405
+ * @returns {Array<string>} List of HTMLElements stored as strings.
406
+ */
407
+ function getHeadersHTMLByCoords(hotInstance, config) {
408
+ const {
409
+ rows,
410
+ columns
411
+ } = config;
412
+ const headers = rows.filter(rowIndex => rowIndex < 0);
413
+ const headersHTML = [];
414
+ if (headers.length === 0 || columns.length === 0) {
415
+ return [];
416
+ }
417
+ headers.forEach(rowIndex => {
418
+ const rowHTML = ['<tr>'];
419
+ for (let i = 0; i < columns.length; i += 1) {
420
+ const columnIndex = columns[i];
421
+ const headerCell = hotInstance.getCell(rowIndex, columnIndex);
422
+ const colspan = headerCell === null || headerCell === void 0 ? void 0 : headerCell.getAttribute('colspan');
423
+ let colspanAttribute = '';
424
+ if (colspan) {
425
+ const parsedColspan = parseInt(colspan, 10);
426
+ colspanAttribute = ` colspan=${parsedColspan}`;
427
+ i += parsedColspan - 1;
428
+ }
429
+ rowHTML.push(`<th${colspanAttribute}>${encodeHTMLEntities(parseEmptyValues(hotInstance.getColHeader(columnIndex, rowIndex)))}</th>`);
109
430
  }
110
- result.push('<tr>', ...columnsResult, '</tr>');
111
- if (row + 1 === inputLen) {
112
- result.push('</tbody>');
431
+ rowHTML.push('</tr>');
432
+ headersHTML.push(...rowHTML);
433
+ });
434
+ return ['<thead>', ...headersHTML, '</thead>'];
435
+ }
436
+
437
+ /**
438
+ * Converts Handsontable's coordinates into list of values for cells being headers.
439
+ *
440
+ * @param {Core} hotInstance The Handsontable instance.
441
+ * @param {object} config Configuration for building the cell value list.
442
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the
443
+ * cell value list.
444
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the
445
+ * cell value list.
446
+ * @returns {Array[]} List of displayed cell values.
447
+ */
448
+ function getHeadersDataByCoords(hotInstance, config) {
449
+ const headersData = [];
450
+ const {
451
+ columns,
452
+ rows
453
+ } = config;
454
+ const headers = rows.filter(rowIndex => rowIndex < 0);
455
+ headers.forEach(rowIndex => {
456
+ const rowData = [];
457
+ for (let i = 0; i < columns.length; i += 1) {
458
+ const columnIndex = columns[i];
459
+ const headerCell = hotInstance.getCell(rowIndex, columnIndex);
460
+ const colspan = headerCell === null || headerCell === void 0 ? void 0 : headerCell.getAttribute('colspan');
461
+ rowData.push(hotInstance.getColHeader(columnIndex, rowIndex));
462
+ if (colspan) {
463
+ const parsedColspan = parseInt(colspan, 10);
464
+ rowData.push(...new Array(parsedColspan - 1).fill(''));
465
+ i += parsedColspan - 1;
466
+ }
113
467
  }
468
+ headersData.push(rowData);
469
+ });
470
+ return headersData;
471
+ }
472
+
473
+ /**
474
+ * Converts Handsontable's header coordinates into HTMLTableElement.tBodies.
475
+ *
476
+ * @param {Core} hotInstance The Handsontable instance.
477
+ * @param {object} config Configuration for building HTMLTableElement.
478
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the table.
479
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the table.
480
+ * @returns {Array<string>} List of HTMLElements stored as strings.
481
+ */
482
+ function getBodyHTMLByCoords(hotInstance, config) {
483
+ const {
484
+ columns,
485
+ rows
486
+ } = config;
487
+ const bodyRows = rows.filter(rowIndex => rowIndex >= 0);
488
+ const cells = [];
489
+ if (bodyRows.length === 0 || columns.length === 0) {
490
+ return [];
114
491
  }
115
- result.push('</table>');
116
- return result.join('');
492
+ bodyRows.forEach((rowIndex, nthRow) => {
493
+ const rowHTML = ['<tr>'];
494
+ columns.forEach((columnIndex, nthColumn) => {
495
+ if (columnIndex < 0) {
496
+ rowHTML.push(`<th>${encodeHTMLEntities(parseEmptyValues(hotInstance.getRowHeader(rowIndex)))}</th>`);
497
+ return;
498
+ }
499
+ const cellValue = hotInstance.getCopyableData(rowIndex, columnIndex);
500
+ const cellValueParsed = encodeHTMLEntities(parseEmptyValues(cellValue));
501
+ const {
502
+ hidden,
503
+ rowspan,
504
+ colspan
505
+ } = hotInstance.getCellMeta(rowIndex, columnIndex);
506
+ if (!hidden) {
507
+ const attrs = [];
508
+ if (rowspan) {
509
+ const recalculatedRowSpan = Math.min(rowspan, bodyRows.slice(nthRow).length);
510
+ if (recalculatedRowSpan > 1) {
511
+ attrs.push(` rowspan="${recalculatedRowSpan}"`);
512
+ }
513
+ }
514
+ if (colspan) {
515
+ const recalculatedColumnSpan = Math.min(colspan, columns.slice(nthColumn).length);
516
+ if (recalculatedColumnSpan > 1) {
517
+ attrs.push(` colspan="${recalculatedColumnSpan}"`);
518
+ }
519
+ }
520
+ rowHTML.push(`<td${attrs.join('')}>${cellValueParsed}</td>`);
521
+ }
522
+ });
523
+ rowHTML.push('</tr>');
524
+ cells.push(...rowHTML);
525
+ });
526
+ return ['<tbody>', ...cells, '</tbody>'];
527
+ }
528
+
529
+ /**
530
+ * Converts Handsontable's coordinates into list of values for cells not being headers.
531
+ *
532
+ * @param {Core} hotInstance The Handsontable instance.
533
+ * @param {object} config Configuration for building the cell value list.
534
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the
535
+ * cell value list.
536
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the
537
+ * cell value list.
538
+ * @returns {Array[]} List of displayed cell values.
539
+ */
540
+ function getBodyDataByCoords(hotInstance, config) {
541
+ const cells = [];
542
+ const {
543
+ columns,
544
+ rows
545
+ } = config;
546
+ const bodyRows = rows.filter(rowIndex => rowIndex >= 0);
547
+ bodyRows.forEach(rowIndex => {
548
+ const rowData = [];
549
+ columns.forEach(columnIndex => {
550
+ const cellValue = hotInstance.getCopyableData(rowIndex, columnIndex);
551
+ const cellValueParsed = isEmpty(cellValue) ? '' : cellValue;
552
+ rowData.push(cellValueParsed);
553
+ });
554
+ cells.push(rowData);
555
+ });
556
+ return cells;
117
557
  }
118
558
 
119
559
  /**
@@ -161,18 +601,19 @@ export function htmlToGridSettings(element) {
161
601
  }
162
602
  return !isDataRow;
163
603
  });
604
+ const isAnyNested = thRows.find(tr => tr.querySelector('th[colspan]') !== null) !== undefined;
164
605
  thRowsLen = thRows.length;
165
606
  hasColHeaders = thRowsLen > 0;
166
- if (thRowsLen > 1) {
607
+ if (thRowsLen > 1 || isAnyNested) {
167
608
  settingsObj.nestedHeaders = Array.from(thRows).reduce((rows, row) => {
168
609
  const headersRow = Array.from(row.cells).reduce((headers, header, currentIndex) => {
169
610
  if (hasRowHeaders && currentIndex === 0) {
170
611
  return headers;
171
612
  }
172
613
  const {
173
- colSpan: colspan,
174
- innerHTML
614
+ colSpan: colspan
175
615
  } = header;
616
+ const innerHTML = decodeHTMLEntities(header.innerHTML);
176
617
  const nextHeader = colspan > 1 ? {
177
618
  label: innerHTML,
178
619
  colspan
@@ -188,7 +629,7 @@ export function htmlToGridSettings(element) {
188
629
  if (hasRowHeaders && index === 0) {
189
630
  return headers;
190
631
  }
191
- headers.push(header.innerHTML);
632
+ headers.push(decodeHTMLEntities(header.innerHTML));
192
633
  return headers;
193
634
  }, []);
194
635
  }
@@ -249,7 +690,7 @@ export function htmlToGridSettings(element) {
249
690
  } else {
250
691
  cellValue = innerHTML.replace(/<br(\s*|\/)>[\r\n]?/gim, '\r\n');
251
692
  }
252
- dataArr[row][col] = cellValue.replace(regEscapedChars, match => ESCAPED_HTML_CHARS[match]);
693
+ dataArr[row][col] = decodeHTMLEntities(cellValue);
253
694
  } else {
254
695
  rowHeaders.push(innerHTML);
255
696
  }