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,11 +1,17 @@
1
1
  "use strict";
2
2
 
3
3
  exports.__esModule = true;
4
- exports._dataToHTML = _dataToHTML;
4
+ exports.getDataByCoords = getDataByCoords;
5
+ exports.getDataWithHeadersByConfig = getDataWithHeadersByConfig;
6
+ exports.getHTMLByCoords = getHTMLByCoords;
7
+ exports.getHTMLFromConfig = getHTMLFromConfig;
5
8
  exports.htmlToGridSettings = htmlToGridSettings;
6
9
  exports.instanceToHTML = instanceToHTML;
7
10
  require("core-js/modules/es.array.push.js");
11
+ require("core-js/modules/es.string.replace-all.js");
8
12
  var _mixed = require("./../helpers/mixed");
13
+ var _object = require("./../helpers/object");
14
+ var _number = require("../helpers/number");
9
15
  const ESCAPED_HTML_CHARS = {
10
16
  ' ': '\x20',
11
17
  '&': '&',
@@ -24,102 +30,539 @@ function isHTMLTable(element) {
24
30
  return (element && element.nodeName || '') === 'TABLE';
25
31
  }
26
32
 
33
+ /**
34
+ * Parses empty values to an empty string or leave them untouched otherwise.
35
+ *
36
+ * @private
37
+ * @param {string} cellValue Parsed cell value.
38
+ * @returns {string}
39
+ */
40
+ function parseEmptyValues(cellValue) {
41
+ if ((0, _mixed.isEmpty)(cellValue)) {
42
+ return '';
43
+ }
44
+ return cellValue;
45
+ }
46
+
27
47
  /**
28
48
  * Converts Handsontable into HTMLTableElement.
29
49
  *
30
- * @param {Core} instance The Handsontable instance.
50
+ * @param {Core} hotInstance The Handsontable instance.
31
51
  * @returns {string} OuterHTML of the HTMLTableElement.
32
52
  */
33
- function instanceToHTML(instance) {
34
- const hasColumnHeaders = instance.hasColHeaders();
35
- const hasRowHeaders = instance.hasRowHeaders();
36
- const coords = [hasColumnHeaders ? -1 : 0, hasRowHeaders ? -1 : 0, instance.countRows() - 1, instance.countCols() - 1];
37
- const data = instance.getData(...coords);
38
- const countRows = data.length;
39
- const countCols = countRows > 0 ? data[0].length : 0;
40
- const TABLE = ['<table>', '</table>'];
41
- const THEAD = hasColumnHeaders ? ['<thead>', '</thead>'] : [];
42
- const TBODY = ['<tbody>', '</tbody>'];
43
- const rowModifier = hasRowHeaders ? 1 : 0;
44
- const columnModifier = hasColumnHeaders ? 1 : 0;
45
- for (let row = 0; row < countRows; row += 1) {
46
- const isColumnHeadersRow = hasColumnHeaders && row === 0;
47
- const CELLS = [];
48
- for (let column = 0; column < countCols; column += 1) {
49
- const isRowHeadersColumn = !isColumnHeadersRow && hasRowHeaders && column === 0;
50
- let cell = '';
51
- if (isColumnHeadersRow) {
52
- cell = `<th>${instance.getColHeader(column - rowModifier)}</th>`;
53
- } else if (isRowHeadersColumn) {
54
- cell = `<th>${instance.getRowHeader(row - columnModifier)}</th>`;
55
- } else {
56
- const cellData = data[row][column];
53
+ function instanceToHTML(hotInstance) {
54
+ const startColumn = hotInstance.hasRowHeaders() ? -1 : 0;
55
+ const startRow = hotInstance.hasColHeaders() ? -1 : 0;
56
+ const rows = Array.from({
57
+ length: hotInstance.countRows() + Math.abs(startRow)
58
+ }, (_, i) => i + startRow);
59
+ const columns = Array.from({
60
+ length: hotInstance.countCols() + Math.abs(startColumn)
61
+ }, (_, i) => i + startColumn);
62
+ return getHTMLByCoords(hotInstance, {
63
+ rows,
64
+ columns
65
+ });
66
+ }
67
+
68
+ /**
69
+ * Converts Handsontable's coordinates into HTMLTableElement.
70
+ *
71
+ * @param {Core} hotInstance The Handsontable instance.
72
+ * @param {object} config Configuration for building HTMLTableElement.
73
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the table.
74
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the table.
75
+ * @returns {string} OuterHTML of the HTMLTableElement.
76
+ */
77
+ function getHTMLByCoords(hotInstance, config) {
78
+ return ['<table>', ...getHeadersHTMLByCoords(hotInstance, config), ...getBodyHTMLByCoords(hotInstance, config), '</table>'].join('');
79
+ }
80
+
81
+ /**
82
+ * Converts Handsontable's coordinates into list of cell values.
83
+ *
84
+ * @param {Core} hotInstance The Handsontable instance.
85
+ * @param {object} config Configuration for building the cell value list.
86
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the
87
+ * cell value list.
88
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the
89
+ * cell value list.
90
+ * @returns {Array<Array<string>>} List of displayed cell values.
91
+ */
92
+ function getDataByCoords(hotInstance, config) {
93
+ return [...getHeadersDataByCoords(hotInstance, config), ...getBodyDataByCoords(hotInstance, config)];
94
+ }
95
+
96
+ /**
97
+ * Converts config into HTMLTableElement.
98
+ *
99
+ * @param {object} config Configuration for building HTMLTableElement.
100
+ * @param {Array<number>} [config.excludedRows] List of row indexes which should be excluded when creating the table.
101
+ * @param {Array<number>} [config.excludedColumns] List of column indexes which should be excluded when creating the table.
102
+ * @param {Array<Array<string>>} [config.data] List of cell data.
103
+ * @param {Array<object>} [config.mergeCells] List of merged cells.
104
+ * @param {Array<Array<string|object>>} [config.nestedHeaders] List of headers and corresponding information about some
105
+ * nested elements.
106
+ * @param {Array<string>} [config.colHeaders] List of first level header values.
107
+ * @returns {string} OuterHTML of the HTMLTableElement.
108
+ */
109
+ function getHTMLFromConfig(config) {
110
+ return ['<table>', ...getHeadersHTMLByConfig(config), ...getBodyHTMLByConfig(config), '</table>'].join('');
111
+ }
112
+
113
+ /**
114
+ * Get list of filtered nested headers.
115
+ *
116
+ * @param {Array<Array<string|object>>} nestedHeaders List of nested headers which will be filtered.
117
+ * @param {Array<number>} excludedHeaders List of headers which should be excluded when creating the HTMLTableElement.tHead.
118
+ * @param {Array<number>} excludedColumns List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
119
+ * @returns {*}
120
+ */
121
+ function getFilteredNestedHeaders(nestedHeaders, excludedHeaders, excludedColumns) {
122
+ return nestedHeaders.reduce((listOfHeaders, headerValues, rowIndex) => {
123
+ if (excludedHeaders.includes(rowIndex - nestedHeaders.length)) {
124
+ return listOfHeaders;
125
+ }
126
+ const filteredNestedHeader = headerValues.filter((columnData, columnIndex) => excludedColumns.includes(columnIndex) === false);
127
+ if (filteredNestedHeader.length > 0) {
128
+ return listOfHeaders.concat([filteredNestedHeader]);
129
+ }
130
+ return listOfHeaders;
131
+ }, []);
132
+ }
133
+
134
+ /**
135
+ * Get HTML for nested headers.
136
+ *
137
+ * @param {Array<Array<string|object>>} nestedHeaders List of nested headers which will be filtered.
138
+ * @param {Array<number>} excludedHeaders List of headers which should be excluded when creating the HTMLTableElement.tHead.
139
+ * @param {Array<number>} excludedColumns List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
140
+ * @returns {Array<string>}
141
+ */
142
+ function getNestedHeadersHTML(nestedHeaders, excludedHeaders, excludedColumns) {
143
+ const headersHTML = [];
144
+ getFilteredNestedHeaders(nestedHeaders, excludedHeaders, excludedColumns).forEach(listOfHeaders => {
145
+ const rowHTML = ['<tr>'];
146
+ for (let i = 0; i < listOfHeaders.length; i += 1) {
147
+ const header = listOfHeaders[i];
148
+ let headerValue = header;
149
+ let colspanAttribute = '';
150
+ if ((0, _object.isObject)(header)) {
151
+ const {
152
+ colspan,
153
+ label
154
+ } = header;
155
+ headerValue = label;
156
+ colspanAttribute = ` colspan=${colspan}`;
157
+ }
158
+ rowHTML.push(`<th${colspanAttribute}>${encodeHTMLEntities(parseEmptyValues(headerValue))}</th>`);
159
+ }
160
+ rowHTML.push('</tr>');
161
+ headersHTML.push(...rowHTML);
162
+ });
163
+ return headersHTML;
164
+ }
165
+
166
+ /**
167
+ * Get HTML for first level header.
168
+ *
169
+ * @param {Array<string>} columnHeaders List of header values which will be filtered.
170
+ * @param {Array<number>} excludedHeaders List of headers which should be excluded when creating the HTMLTableElement.tHead.
171
+ * @param {Array<number>} excludedColumns List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
172
+ * @returns {*[]}
173
+ */
174
+ function getSimpleHeadersHTML(columnHeaders, excludedHeaders, excludedColumns) {
175
+ if (excludedHeaders.includes(-1)) {
176
+ return [];
177
+ }
178
+ const filteredColumnHeaders = columnHeaders.filter((columnHeaderValue, columnIndex) => excludedColumns.includes(columnIndex) === false);
179
+ if (filteredColumnHeaders.length === 0) {
180
+ return [];
181
+ }
182
+ return ['<tr>', ...filteredColumnHeaders.map(columnHeader => `<th>${encodeHTMLEntities(parseEmptyValues(columnHeader))}</th>`), '</tr>'];
183
+ }
184
+
185
+ /**
186
+ * Get list of cells filtered by list of excluded rows and columns.
187
+ *
188
+ * @private
189
+ * @param {Array<Array<string>>} data List of cells values which will be filtered.
190
+ * @param {Array<number>} excludedRows List of row indexes which should be excluded when creating the HTMLTableElement.tHead.
191
+ * @param {Array<number>} excludedColumns List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
192
+ * @returns {Array<string>} List of cell values.
193
+ */
194
+ function getFilteredCells(data, excludedRows, excludedColumns) {
195
+ if (Array.isArray(data) === false) {
196
+ return [];
197
+ }
198
+ return data.reduce((listOfCells, rowData, rowIndex) => {
199
+ if (excludedRows.includes(rowIndex)) {
200
+ return listOfCells;
201
+ }
202
+ const filteredRowData = rowData.filter((cellData, columnIndex) => excludedColumns.includes(columnIndex) === false);
203
+ if (filteredRowData.length > 0) {
204
+ return listOfCells.concat([filteredRowData]);
205
+ }
206
+ return listOfCells;
207
+ }, []);
208
+ }
209
+
210
+ /**
211
+ * Prepare information about merged areas to reduce complexity of calculations.
212
+ *
213
+ * @private
214
+ * @param {Array<object>} mergedCellsConfig List of merged cells.
215
+ * @returns {{mergedCellsMap: Map<any, any>, mergedArea: Set<any>}}
216
+ */
217
+ function getMergedCellsInformation(mergedCellsConfig) {
218
+ const mergedCellsMap = new Map();
219
+ const mergedArea = new Set();
220
+ let mergedRows = 1;
221
+ let mergedColumns = 1;
222
+ mergedCellsConfig === null || mergedCellsConfig === void 0 || mergedCellsConfig.forEach(mergeArea => {
223
+ const {
224
+ row,
225
+ col,
226
+ rowspan,
227
+ colspan
228
+ } = mergeArea;
229
+ mergedCellsMap.set(`${row}x${col}`, {
230
+ rowspan,
231
+ colspan
232
+ });
233
+ if (Number.isInteger(rowspan)) {
234
+ mergedRows = rowspan;
235
+ }
236
+ if (Number.isInteger(colspan)) {
237
+ mergedColumns = colspan;
238
+ }
239
+ (0, _number.rangeEach)(row, row + mergedRows - 1, rowIndex => {
240
+ (0, _number.rangeEach)(col, col + mergedColumns - 1, columnIndex => {
241
+ // Other than start point.
242
+ if (rowIndex !== row || columnIndex !== col) {
243
+ mergedArea.add(`${rowIndex}x${columnIndex}`);
244
+ }
245
+ });
246
+ });
247
+ });
248
+ return {
249
+ mergedCellsMap,
250
+ mergedArea
251
+ };
252
+ }
253
+
254
+ /**
255
+ * Converts config with information about cells into HTMLTableElement.tBodies.
256
+ *
257
+ * @private
258
+ * @param {object} config Configuration for building HTMLTableElement.tBodies.
259
+ * @param {Array<Array<string>>} config.data List of cell data.
260
+ * @param {Array<number>} [config.excludedRows] List of row indexes which should be excluded when creating the HTMLTableElement.tBodies.
261
+ * @param {Array<number>} [config.excludedColumns] List of column indexes which should be excluded when creating the HTMLTableElement.tBodies.
262
+ * @param {Array<object>} [config.mergeCells] List of merged cells.
263
+ * @returns {Array<string>} List of HTMLElements stored as strings.
264
+ */
265
+ function getBodyHTMLByConfig(config) {
266
+ const excludedColumns = config.excludedColumns || [];
267
+ const excludedRows = config.excludedRows || [];
268
+ const {
269
+ data,
270
+ mergeCells
271
+ } = config;
272
+ const ignoredCellRows = excludedRows.filter(rowIndex => rowIndex >= 0);
273
+ const filteredData = getFilteredCells(data, ignoredCellRows, excludedColumns);
274
+ const cells = [];
275
+ if (filteredData.length === 0) {
276
+ return [];
277
+ }
278
+ const {
279
+ mergedCellsMap,
280
+ mergedArea
281
+ } = getMergedCellsInformation(mergeCells);
282
+ filteredData.forEach((rowData, rowIndex) => {
283
+ const rowHTML = ['<tr>'];
284
+ rowData.forEach((cellData, columnIndex) => {
285
+ const attrs = [];
286
+ const checkedMergeCoordinate = `${rowIndex}x${columnIndex}`;
287
+ const mergeParent = mergedCellsMap.get(checkedMergeCoordinate);
288
+ if (mergeParent !== undefined) {
57
289
  const {
58
- hidden,
59
290
  rowspan,
60
291
  colspan
61
- } = instance.getCellMeta(row - columnModifier, column - rowModifier);
62
- if (!hidden) {
63
- const attrs = [];
64
- if (rowspan) {
65
- attrs.push(`rowspan="${rowspan}"`);
66
- }
67
- if (colspan) {
68
- attrs.push(`colspan="${colspan}"`);
69
- }
70
- if ((0, _mixed.isEmpty)(cellData)) {
71
- cell = `<td ${attrs.join(' ')}></td>`;
72
- } else {
73
- 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;');
74
- cell = `<td ${attrs.join(' ')}>${value}</td>`;
75
- }
292
+ } = mergeParent;
293
+ if (Number.isInteger(rowspan) && rowspan > 1) {
294
+ attrs.push(` rowspan="${rowspan}"`);
295
+ }
296
+ if (Number.isInteger(colspan) && colspan > 1) {
297
+ attrs.push(` colspan="${colspan}"`);
76
298
  }
299
+ } else if (mergedArea.has(checkedMergeCoordinate)) {
300
+ return;
77
301
  }
78
- CELLS.push(cell);
79
- }
80
- const TR = ['<tr>', ...CELLS, '</tr>'].join('');
81
- if (isColumnHeadersRow) {
82
- THEAD.splice(1, 0, TR);
83
- } else {
84
- TBODY.splice(-1, 0, TR);
85
- }
302
+ rowHTML.push(`<td${attrs.join('')}>${encodeHTMLEntities(parseEmptyValues(cellData))}</td>`);
303
+ });
304
+ rowHTML.push('</tr>');
305
+ cells.push(...rowHTML);
306
+ });
307
+ return ['<tbody>', ...cells, '</tbody>'];
308
+ }
309
+
310
+ /**
311
+ * Converts config with information about headers into HTMLTableElement.tHead.
312
+ *
313
+ * @private
314
+ * @param {object} config Configuration for building HTMLTableElement.tHead.
315
+ * @param {Array<Array<string|object>>} [config.nestedHeaders] List of headers and corresponding information about some
316
+ * nested elements.
317
+ * @param {Array<string>} [config.colHeaders] List of first level header values.
318
+ * @param {Array<number>} [config.excludedRows] List of row indexes which should be excluded when creating the HTMLTableElement.tHead.
319
+ * @param {Array<number>} [config.excludedColumns] List of column indexes which should be excluded when creating the HTMLTableElement.tHead.
320
+ * @returns {Array<string>} List of HTMLElements stored as strings.
321
+ */
322
+ function getHeadersHTMLByConfig(config) {
323
+ const headersHTML = [];
324
+ const excludedColumns = Array.isArray(config === null || config === void 0 ? void 0 : config.excludedColumns) ? config.excludedColumns : [];
325
+ const excludedRows = Array.isArray(config === null || config === void 0 ? void 0 : config.excludedRows) ? config.excludedRows : [];
326
+ const {
327
+ nestedHeaders,
328
+ colHeaders
329
+ } = config;
330
+ const excludedHeaders = excludedRows.filter(rowIndex => rowIndex < 0);
331
+ if (Array.isArray(nestedHeaders)) {
332
+ headersHTML.push(...getNestedHeadersHTML(nestedHeaders, excludedHeaders, excludedColumns));
333
+ } else if (Array.isArray(colHeaders)) {
334
+ headersHTML.push(...getSimpleHeadersHTML(colHeaders, excludedHeaders, excludedColumns));
86
335
  }
87
- TABLE.splice(1, 0, THEAD.join(''), TBODY.join(''));
88
- return TABLE.join('');
336
+ if (headersHTML.length > 0) {
337
+ return ['<thead>', ...headersHTML, '</thead>'];
338
+ }
339
+ return [];
89
340
  }
90
341
 
91
342
  /**
92
- * Converts 2D array into HTMLTableElement.
343
+ * Converts config with information about cells and headers into list of values.
93
344
  *
94
- * @param {Array} input Input array which will be converted to HTMLTable.
95
- * @returns {string} OuterHTML of the HTMLTableElement.
345
+ * @param {object} config Configuration for building list of values.
346
+ * @param {Array<number>} [config.excludedRows] List of row indexes which should be excluded when creating the value list.
347
+ * @param {Array<number>} [config.excludedColumns] List of column indexes which should be excluded when creating the value list.
348
+ * @param {Array<Array<string|object>>} [config.nestedHeaders] List of headers and information about some nested elements.
349
+ * @param {Array<string>} [config.colHeaders] List of first level header values.
350
+ * @returns {string[][]} List of values.
96
351
  */
97
- // eslint-disable-next-line no-restricted-globals
98
- function _dataToHTML(input) {
99
- const inputLen = input.length;
100
- const result = ['<table>'];
101
- for (let row = 0; row < inputLen; row += 1) {
102
- const rowData = input[row];
103
- const columnsLen = rowData.length;
104
- const columnsResult = [];
105
- if (row === 0) {
106
- result.push('<tbody>');
107
- }
108
- for (let column = 0; column < columnsLen; column += 1) {
109
- const cellData = rowData[column];
110
- const parsedCellData = (0, _mixed.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 => {
111
- // The way how Excel serializes data with at least two spaces.
112
- return `<span style="mso-spacerun: yes">${'&nbsp;'.repeat(substring.length - 1)} </span>`;
113
- }).replace(/\t/gi, '&#9;');
114
- columnsResult.push(`<td>${parsedCellData}</td>`);
352
+ function getDataWithHeadersByConfig(config) {
353
+ const dataWithHeaders = [];
354
+ const excludedColumns = Array.isArray(config === null || config === void 0 ? void 0 : config.excludedColumns) ? config.excludedColumns : [];
355
+ const excludedRows = Array.isArray(config === null || config === void 0 ? void 0 : config.excludedRows) ? config.excludedRows : [];
356
+ const {
357
+ data,
358
+ nestedHeaders,
359
+ colHeaders
360
+ } = config;
361
+ const excludedHeaders = excludedRows.filter(rowIndex => rowIndex < 0);
362
+ if (Array.isArray(nestedHeaders)) {
363
+ dataWithHeaders.push(...getFilteredNestedHeaders(nestedHeaders, excludedHeaders, excludedColumns).map(listOfHeaders => {
364
+ return listOfHeaders.reduce((headers, header) => {
365
+ if ((0, _object.isObject)(header)) {
366
+ headers.push(header.label, ...new Array(header.colspan - 1).fill(''));
367
+ } else {
368
+ headers.push(header);
369
+ }
370
+ return headers;
371
+ }, []);
372
+ }));
373
+ } else if (Array.isArray(colHeaders)) {
374
+ dataWithHeaders.push([...colHeaders.filter((columnHeaderData, columnIndex) => excludedColumns.includes(columnIndex) === false)]);
375
+ }
376
+ dataWithHeaders.push(...getFilteredCells(data, excludedRows.filter(rowIndex => rowIndex >= 0), excludedColumns.filter(columnIndex => columnIndex >= 0)));
377
+ return dataWithHeaders;
378
+ }
379
+
380
+ /**
381
+ * Encode text to HTML.
382
+ *
383
+ * @param {string} text Text to prepare.
384
+ * @returns {string}
385
+ */
386
+ function encodeHTMLEntities(text) {
387
+ 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 => {
388
+ // The way how Excel serializes data with at least two spaces.
389
+ return `<span style="mso-spacerun: yes">${'&nbsp;'.repeat(substring.length - 1)} </span>`;
390
+ }).replace(/\t/gi, '&#9;');
391
+ }
392
+
393
+ /**
394
+ * Decode HTML to simple text.
395
+ *
396
+ * @param {string} html HTML for handling.
397
+ * @returns {string}
398
+ */
399
+ function decodeHTMLEntities(html) {
400
+ return html.replace(regEscapedChars, match => ESCAPED_HTML_CHARS[match])
401
+ // The way how Excel serializes data with at least two spaces.
402
+ .replace(/<span style="mso-spacerun: yes">(.+?)<\/span>/, '$1').replaceAll('&nbsp;', ' ');
403
+ }
404
+
405
+ /**
406
+ * Converts Handsontable's header coordinates into HTMLTableElement.tHead.
407
+ *
408
+ * @param {Core} hotInstance The Handsontable instance.
409
+ * @param {object} config Configuration for building HTMLTableElement.tHead.
410
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating
411
+ * the HTMLTableElement.tHead.
412
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating
413
+ * the HTMLTableElement.tHead.
414
+ * @returns {Array<string>} List of HTMLElements stored as strings.
415
+ */
416
+ function getHeadersHTMLByCoords(hotInstance, config) {
417
+ const {
418
+ rows,
419
+ columns
420
+ } = config;
421
+ const headers = rows.filter(rowIndex => rowIndex < 0);
422
+ const headersHTML = [];
423
+ if (headers.length === 0 || columns.length === 0) {
424
+ return [];
425
+ }
426
+ headers.forEach(rowIndex => {
427
+ const rowHTML = ['<tr>'];
428
+ for (let i = 0; i < columns.length; i += 1) {
429
+ const columnIndex = columns[i];
430
+ const headerCell = hotInstance.getCell(rowIndex, columnIndex);
431
+ const colspan = headerCell === null || headerCell === void 0 ? void 0 : headerCell.getAttribute('colspan');
432
+ let colspanAttribute = '';
433
+ if (colspan) {
434
+ const parsedColspan = parseInt(colspan, 10);
435
+ colspanAttribute = ` colspan=${parsedColspan}`;
436
+ i += parsedColspan - 1;
437
+ }
438
+ rowHTML.push(`<th${colspanAttribute}>${encodeHTMLEntities(parseEmptyValues(hotInstance.getColHeader(columnIndex, rowIndex)))}</th>`);
115
439
  }
116
- result.push('<tr>', ...columnsResult, '</tr>');
117
- if (row + 1 === inputLen) {
118
- result.push('</tbody>');
440
+ rowHTML.push('</tr>');
441
+ headersHTML.push(...rowHTML);
442
+ });
443
+ return ['<thead>', ...headersHTML, '</thead>'];
444
+ }
445
+
446
+ /**
447
+ * Converts Handsontable's coordinates into list of values for cells being headers.
448
+ *
449
+ * @param {Core} hotInstance The Handsontable instance.
450
+ * @param {object} config Configuration for building the cell value list.
451
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the
452
+ * cell value list.
453
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the
454
+ * cell value list.
455
+ * @returns {Array[]} List of displayed cell values.
456
+ */
457
+ function getHeadersDataByCoords(hotInstance, config) {
458
+ const headersData = [];
459
+ const {
460
+ columns,
461
+ rows
462
+ } = config;
463
+ const headers = rows.filter(rowIndex => rowIndex < 0);
464
+ headers.forEach(rowIndex => {
465
+ const rowData = [];
466
+ for (let i = 0; i < columns.length; i += 1) {
467
+ const columnIndex = columns[i];
468
+ const headerCell = hotInstance.getCell(rowIndex, columnIndex);
469
+ const colspan = headerCell === null || headerCell === void 0 ? void 0 : headerCell.getAttribute('colspan');
470
+ rowData.push(hotInstance.getColHeader(columnIndex, rowIndex));
471
+ if (colspan) {
472
+ const parsedColspan = parseInt(colspan, 10);
473
+ rowData.push(...new Array(parsedColspan - 1).fill(''));
474
+ i += parsedColspan - 1;
475
+ }
119
476
  }
477
+ headersData.push(rowData);
478
+ });
479
+ return headersData;
480
+ }
481
+
482
+ /**
483
+ * Converts Handsontable's header coordinates into HTMLTableElement.tBodies.
484
+ *
485
+ * @param {Core} hotInstance The Handsontable instance.
486
+ * @param {object} config Configuration for building HTMLTableElement.
487
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the table.
488
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the table.
489
+ * @returns {Array<string>} List of HTMLElements stored as strings.
490
+ */
491
+ function getBodyHTMLByCoords(hotInstance, config) {
492
+ const {
493
+ columns,
494
+ rows
495
+ } = config;
496
+ const bodyRows = rows.filter(rowIndex => rowIndex >= 0);
497
+ const cells = [];
498
+ if (bodyRows.length === 0 || columns.length === 0) {
499
+ return [];
120
500
  }
121
- result.push('</table>');
122
- return result.join('');
501
+ bodyRows.forEach((rowIndex, nthRow) => {
502
+ const rowHTML = ['<tr>'];
503
+ columns.forEach((columnIndex, nthColumn) => {
504
+ if (columnIndex < 0) {
505
+ rowHTML.push(`<th>${encodeHTMLEntities(parseEmptyValues(hotInstance.getRowHeader(rowIndex)))}</th>`);
506
+ return;
507
+ }
508
+ const cellValue = hotInstance.getCopyableData(rowIndex, columnIndex);
509
+ const cellValueParsed = encodeHTMLEntities(parseEmptyValues(cellValue));
510
+ const {
511
+ hidden,
512
+ rowspan,
513
+ colspan
514
+ } = hotInstance.getCellMeta(rowIndex, columnIndex);
515
+ if (!hidden) {
516
+ const attrs = [];
517
+ if (rowspan) {
518
+ const recalculatedRowSpan = Math.min(rowspan, bodyRows.slice(nthRow).length);
519
+ if (recalculatedRowSpan > 1) {
520
+ attrs.push(` rowspan="${recalculatedRowSpan}"`);
521
+ }
522
+ }
523
+ if (colspan) {
524
+ const recalculatedColumnSpan = Math.min(colspan, columns.slice(nthColumn).length);
525
+ if (recalculatedColumnSpan > 1) {
526
+ attrs.push(` colspan="${recalculatedColumnSpan}"`);
527
+ }
528
+ }
529
+ rowHTML.push(`<td${attrs.join('')}>${cellValueParsed}</td>`);
530
+ }
531
+ });
532
+ rowHTML.push('</tr>');
533
+ cells.push(...rowHTML);
534
+ });
535
+ return ['<tbody>', ...cells, '</tbody>'];
536
+ }
537
+
538
+ /**
539
+ * Converts Handsontable's coordinates into list of values for cells not being headers.
540
+ *
541
+ * @param {Core} hotInstance The Handsontable instance.
542
+ * @param {object} config Configuration for building the cell value list.
543
+ * @param {Array<number>} config.rows List of row indexes which should be taken into account when creating the
544
+ * cell value list.
545
+ * @param {Array<number>} config.columns List of column indexes which should be taken into account when creating the
546
+ * cell value list.
547
+ * @returns {Array[]} List of displayed cell values.
548
+ */
549
+ function getBodyDataByCoords(hotInstance, config) {
550
+ const cells = [];
551
+ const {
552
+ columns,
553
+ rows
554
+ } = config;
555
+ const bodyRows = rows.filter(rowIndex => rowIndex >= 0);
556
+ bodyRows.forEach(rowIndex => {
557
+ const rowData = [];
558
+ columns.forEach(columnIndex => {
559
+ const cellValue = hotInstance.getCopyableData(rowIndex, columnIndex);
560
+ const cellValueParsed = (0, _mixed.isEmpty)(cellValue) ? '' : cellValue;
561
+ rowData.push(cellValueParsed);
562
+ });
563
+ cells.push(rowData);
564
+ });
565
+ return cells;
123
566
  }
124
567
 
125
568
  /**
@@ -167,18 +610,19 @@ function htmlToGridSettings(element) {
167
610
  }
168
611
  return !isDataRow;
169
612
  });
613
+ const isAnyNested = thRows.find(tr => tr.querySelector('th[colspan]') !== null) !== undefined;
170
614
  thRowsLen = thRows.length;
171
615
  hasColHeaders = thRowsLen > 0;
172
- if (thRowsLen > 1) {
616
+ if (thRowsLen > 1 || isAnyNested) {
173
617
  settingsObj.nestedHeaders = Array.from(thRows).reduce((rows, row) => {
174
618
  const headersRow = Array.from(row.cells).reduce((headers, header, currentIndex) => {
175
619
  if (hasRowHeaders && currentIndex === 0) {
176
620
  return headers;
177
621
  }
178
622
  const {
179
- colSpan: colspan,
180
- innerHTML
623
+ colSpan: colspan
181
624
  } = header;
625
+ const innerHTML = decodeHTMLEntities(header.innerHTML);
182
626
  const nextHeader = colspan > 1 ? {
183
627
  label: innerHTML,
184
628
  colspan
@@ -194,7 +638,7 @@ function htmlToGridSettings(element) {
194
638
  if (hasRowHeaders && index === 0) {
195
639
  return headers;
196
640
  }
197
- headers.push(header.innerHTML);
641
+ headers.push(decodeHTMLEntities(header.innerHTML));
198
642
  return headers;
199
643
  }, []);
200
644
  }
@@ -255,7 +699,7 @@ function htmlToGridSettings(element) {
255
699
  } else {
256
700
  cellValue = innerHTML.replace(/<br(\s*|\/)>[\r\n]?/gim, '\r\n');
257
701
  }
258
- dataArr[row][col] = cellValue.replace(regEscapedChars, match => ESCAPED_HTML_CHARS[match]);
702
+ dataArr[row][col] = decodeHTMLEntities(cellValue);
259
703
  } else {
260
704
  rowHeaders.push(innerHTML);
261
705
  }