handsontable 13.1.0 → 14.0.0-next-e8f87aa-20231030
Sign up to get free protection for your applications and to get access to all the features.
- package/3rdparty/walkontable/src/calculator/constants.js +3 -6
- package/3rdparty/walkontable/src/calculator/viewportColumns.js +1 -2
- package/3rdparty/walkontable/src/calculator/viewportRows.js +1 -2
- package/3rdparty/walkontable/src/cell/coords.d.ts +8 -1
- package/3rdparty/walkontable/src/cell/coords.js +81 -13
- package/3rdparty/walkontable/src/cell/coords.mjs +80 -11
- package/3rdparty/walkontable/src/cell/range.d.ts +9 -2
- package/3rdparty/walkontable/src/cell/range.js +39 -9
- package/3rdparty/walkontable/src/cell/range.mjs +38 -7
- package/3rdparty/walkontable/src/core/_base.js +9 -3
- package/3rdparty/walkontable/src/core/_base.mjs +9 -3
- package/3rdparty/walkontable/src/core/clone.js +2 -2
- package/3rdparty/walkontable/src/core/clone.mjs +2 -2
- package/3rdparty/walkontable/src/core/core.js +3 -2
- package/3rdparty/walkontable/src/core/core.mjs +3 -2
- package/3rdparty/walkontable/src/event.js +13 -12
- package/3rdparty/walkontable/src/event.mjs +12 -10
- package/3rdparty/walkontable/src/facade/core.js +2 -2
- package/3rdparty/walkontable/src/facade/core.mjs +2 -2
- package/3rdparty/walkontable/src/filter/column.js +1 -2
- package/3rdparty/walkontable/src/filter/row.js +1 -2
- package/3rdparty/walkontable/src/index.js +12 -4
- package/3rdparty/walkontable/src/index.mjs +2 -2
- package/3rdparty/walkontable/src/overlay/_base.js +13 -2
- package/3rdparty/walkontable/src/overlay/_base.mjs +14 -3
- package/3rdparty/walkontable/src/overlay/constants.js +7 -14
- package/3rdparty/walkontable/src/overlay/inlineStart.js +2 -6
- package/3rdparty/walkontable/src/overlay/inlineStart.mjs +2 -6
- package/3rdparty/walkontable/src/overlay/top.js +2 -6
- package/3rdparty/walkontable/src/overlay/top.mjs +2 -6
- package/3rdparty/walkontable/src/overlays.js +1 -2
- package/3rdparty/walkontable/src/renderer/cells.js +10 -0
- package/3rdparty/walkontable/src/renderer/cells.mjs +11 -1
- package/3rdparty/walkontable/src/renderer/columnHeaders.js +13 -0
- package/3rdparty/walkontable/src/renderer/columnHeaders.mjs +14 -1
- package/3rdparty/walkontable/src/renderer/rowHeaders.js +8 -0
- package/3rdparty/walkontable/src/renderer/rowHeaders.mjs +8 -0
- package/3rdparty/walkontable/src/renderer/rows.js +13 -0
- package/3rdparty/walkontable/src/renderer/rows.mjs +13 -0
- package/3rdparty/walkontable/src/renderer/table.js +9 -0
- package/3rdparty/walkontable/src/renderer/table.mjs +9 -0
- package/3rdparty/walkontable/src/scroll.js +3 -2
- package/3rdparty/walkontable/src/scroll.mjs +2 -0
- package/3rdparty/walkontable/src/{border.js → selection/border/border.js} +8 -14
- package/3rdparty/walkontable/src/{border.mjs → selection/border/border.mjs} +7 -12
- package/3rdparty/walkontable/src/selection/border/constants.js +15 -0
- package/3rdparty/walkontable/src/selection/border/constants.mjs +12 -0
- package/3rdparty/walkontable/src/selection/constants.js +54 -0
- package/3rdparty/walkontable/src/selection/constants.mjs +51 -0
- package/3rdparty/walkontable/src/selection/index.js +26 -0
- package/3rdparty/walkontable/src/selection/index.mjs +5 -0
- package/3rdparty/walkontable/src/selection/manager.js +274 -0
- package/3rdparty/walkontable/src/selection/manager.mjs +269 -0
- package/3rdparty/walkontable/src/selection/scanner.js +270 -0
- package/3rdparty/walkontable/src/selection/scanner.mjs +267 -0
- package/3rdparty/walkontable/src/selection/selection.js +100 -0
- package/3rdparty/walkontable/src/selection/selection.mjs +96 -0
- package/3rdparty/walkontable/src/settings.js +13 -4
- package/3rdparty/walkontable/src/settings.mjs +13 -4
- package/3rdparty/walkontable/src/table/bottom.js +1 -2
- package/3rdparty/walkontable/src/table/bottomInlineStartCorner.js +1 -2
- package/3rdparty/walkontable/src/table/inlineStart.js +1 -2
- package/3rdparty/walkontable/src/table/master.js +3 -6
- package/3rdparty/walkontable/src/table/master.mjs +2 -4
- package/3rdparty/walkontable/src/table/mixin/calculatedColumns.js +10 -2
- package/3rdparty/walkontable/src/table/mixin/calculatedColumns.mjs +9 -0
- package/3rdparty/walkontable/src/table/mixin/calculatedRows.js +10 -2
- package/3rdparty/walkontable/src/table/mixin/calculatedRows.mjs +9 -0
- package/3rdparty/walkontable/src/table/mixin/stickyColumnsStart.js +10 -2
- package/3rdparty/walkontable/src/table/mixin/stickyColumnsStart.mjs +9 -0
- package/3rdparty/walkontable/src/table/mixin/stickyRowsBottom.js +10 -2
- package/3rdparty/walkontable/src/table/mixin/stickyRowsBottom.mjs +9 -0
- package/3rdparty/walkontable/src/table/mixin/stickyRowsTop.js +10 -2
- package/3rdparty/walkontable/src/table/mixin/stickyRowsTop.mjs +9 -0
- package/3rdparty/walkontable/src/table/top.js +1 -2
- package/3rdparty/walkontable/src/table/topInlineStartCorner.js +1 -2
- package/3rdparty/walkontable/src/table.js +20 -80
- package/3rdparty/walkontable/src/table.mjs +20 -79
- package/3rdparty/walkontable/src/utils/orderView/constants.js +3 -6
- package/3rdparty/walkontable/src/viewport.js +1 -2
- package/CHANGELOG.md +51 -0
- package/base.js +3 -4
- package/base.mjs +2 -2
- package/cellTypes/autocompleteType/autocompleteType.js +3 -5
- package/cellTypes/checkboxType/checkboxType.js +3 -5
- package/cellTypes/dateType/dateType.d.ts +3 -3
- package/cellTypes/dateType/dateType.js +5 -7
- package/cellTypes/dateType/dateType.mjs +2 -2
- package/cellTypes/dropdownType/dropdownType.js +3 -5
- package/cellTypes/handsontableType/handsontableType.d.ts +3 -3
- package/cellTypes/handsontableType/handsontableType.js +5 -7
- package/cellTypes/handsontableType/handsontableType.mjs +2 -2
- package/cellTypes/index.d.ts +3 -0
- package/cellTypes/index.js +4 -0
- package/cellTypes/index.mjs +3 -1
- package/cellTypes/numericType/numericType.js +3 -5
- package/cellTypes/passwordType/passwordType.js +3 -5
- package/cellTypes/selectType/index.d.ts +1 -0
- package/cellTypes/selectType/index.js +6 -0
- package/cellTypes/selectType/index.mjs +1 -0
- package/cellTypes/selectType/selectType.d.ts +14 -0
- package/cellTypes/selectType/selectType.js +11 -0
- package/cellTypes/selectType/selectType.mjs +8 -0
- package/cellTypes/textType/textType.js +3 -5
- package/cellTypes/timeType/timeType.js +3 -5
- package/common.d.ts +1 -1
- package/core/focusCatcher/focusDetector.js +63 -0
- package/core/focusCatcher/focusDetector.mjs +59 -0
- package/core/focusCatcher/index.js +148 -0
- package/core/focusCatcher/index.mjs +144 -0
- package/core/index.js +9 -0
- package/core/index.mjs +1 -0
- package/core.d.ts +10 -5
- package/core.js +327 -359
- package/core.mjs +327 -359
- package/dataMap/dataMap.js +1 -2
- package/dataMap/dataSource.js +1 -2
- package/dataMap/metaManager/metaSchema.js +65 -0
- package/dataMap/metaManager/metaSchema.mjs +65 -0
- package/dataMap/metaManager/mods/extendMetaProperties.js +7 -1
- package/dataMap/metaManager/mods/extendMetaProperties.mjs +7 -1
- package/dataMap/replaceData.js +5 -0
- package/dataMap/replaceData.mjs +5 -0
- package/dist/handsontable.css +94 -76
- package/dist/handsontable.full.css +94 -76
- package/dist/handsontable.full.js +23133 -15992
- package/dist/handsontable.full.min.css +8 -8
- package/dist/handsontable.full.min.js +170 -152
- package/dist/handsontable.js +21856 -15085
- package/dist/handsontable.min.css +7 -7
- package/dist/handsontable.min.js +30 -22
- package/dist/languages/all.js +47 -40
- package/dist/languages/all.min.js +1 -1
- package/dist/languages/ar-AR.js +1 -2
- package/dist/languages/cs-CZ.js +1 -2
- package/dist/languages/de-CH.js +1 -2
- package/dist/languages/de-DE.js +1 -2
- package/dist/languages/en-US.js +15 -3
- package/dist/languages/en-US.min.js +1 -1
- package/dist/languages/es-MX.js +1 -2
- package/dist/languages/fr-FR.js +1 -2
- package/dist/languages/it-IT.js +1 -2
- package/dist/languages/ja-JP.js +1 -2
- package/dist/languages/ko-KR.js +1 -2
- package/dist/languages/lv-LV.js +1 -2
- package/dist/languages/nb-NO.js +1 -2
- package/dist/languages/nl-NL.js +1 -2
- package/dist/languages/pl-PL.js +15 -3
- package/dist/languages/pl-PL.min.js +1 -1
- package/dist/languages/pt-BR.js +1 -2
- package/dist/languages/ru-RU.js +1 -2
- package/dist/languages/sr-SP.js +1 -2
- package/dist/languages/zh-CN.js +1 -2
- package/dist/languages/zh-TW.js +1 -2
- package/editorManager.js +17 -91
- package/editorManager.mjs +16 -87
- package/editors/autocompleteEditor/autocompleteEditor.js +65 -11
- package/editors/autocompleteEditor/autocompleteEditor.mjs +65 -10
- package/editors/baseEditor/baseEditor.js +19 -13
- package/editors/baseEditor/baseEditor.mjs +16 -7
- package/editors/checkboxEditor/checkboxEditor.js +1 -2
- package/editors/dateEditor/dateEditor.js +27 -9
- package/editors/dateEditor/dateEditor.mjs +27 -8
- package/editors/dropdownEditor/dropdownEditor.js +1 -2
- package/editors/handsontableEditor/handsontableEditor.js +14 -7
- package/editors/handsontableEditor/handsontableEditor.mjs +14 -6
- package/editors/numericEditor/numericEditor.js +1 -2
- package/editors/passwordEditor/passwordEditor.js +1 -2
- package/editors/selectEditor/selectEditor.js +1 -2
- package/editors/textEditor/textEditor.js +20 -29
- package/editors/textEditor/textEditor.mjs +22 -30
- package/editors/timeEditor/timeEditor.js +1 -2
- package/eventManager.js +1 -2
- package/focusManager.d.ts +12 -0
- package/focusManager.js +265 -0
- package/focusManager.mjs +261 -0
- package/helpers/a11y.js +81 -0
- package/helpers/a11y.mjs +39 -0
- package/helpers/dom/element.js +224 -12
- package/helpers/dom/element.mjs +216 -10
- package/helpers/dom/event.d.ts +1 -0
- package/helpers/dom/event.js +25 -0
- package/helpers/dom/event.mjs +24 -0
- package/helpers/mixed.js +2 -2
- package/helpers/mixed.mjs +2 -2
- package/helpers/number.d.ts +1 -0
- package/helpers/number.js +18 -0
- package/helpers/number.mjs +17 -0
- package/helpers/unicode.js +1 -2
- package/i18n/constants.js +97 -160
- package/i18n/constants.mjs +17 -1
- package/i18n/languages/ar-AR.js +3 -4
- package/i18n/languages/cs-CZ.js +3 -4
- package/i18n/languages/de-CH.js +3 -4
- package/i18n/languages/de-DE.js +3 -4
- package/i18n/languages/en-US.js +17 -5
- package/i18n/languages/en-US.mjs +14 -1
- package/i18n/languages/es-MX.js +3 -4
- package/i18n/languages/fr-FR.js +3 -4
- package/i18n/languages/it-IT.js +3 -4
- package/i18n/languages/ja-JP.js +3 -4
- package/i18n/languages/ko-KR.js +3 -4
- package/i18n/languages/lv-LV.js +3 -4
- package/i18n/languages/nb-NO.js +3 -4
- package/i18n/languages/nl-NL.js +3 -4
- package/i18n/languages/pl-PL.js +17 -5
- package/i18n/languages/pl-PL.mjs +14 -1
- package/i18n/languages/pt-BR.js +3 -4
- package/i18n/languages/ru-RU.js +3 -4
- package/i18n/languages/sr-SP.js +3 -4
- package/i18n/languages/zh-CN.js +3 -4
- package/i18n/languages/zh-TW.js +3 -4
- package/i18n/registry.js +4 -6
- package/index.js +3 -4
- package/languages/all.js +47 -40
- package/languages/ar-AR.js +1 -2
- package/languages/cs-CZ.js +1 -2
- package/languages/de-CH.js +1 -2
- package/languages/de-DE.js +1 -2
- package/languages/en-US.js +15 -3
- package/languages/en-US.mjs +14 -1
- package/languages/es-MX.js +1 -2
- package/languages/fr-FR.js +1 -2
- package/languages/index.js +47 -40
- package/languages/it-IT.js +1 -2
- package/languages/ja-JP.js +1 -2
- package/languages/ko-KR.js +1 -2
- package/languages/lv-LV.js +1 -2
- package/languages/nb-NO.js +1 -2
- package/languages/nl-NL.js +1 -2
- package/languages/pl-PL.js +15 -3
- package/languages/pl-PL.mjs +14 -1
- package/languages/pt-BR.js +1 -2
- package/languages/ru-RU.js +1 -2
- package/languages/sr-SP.js +1 -2
- package/languages/zh-CN.js +1 -2
- package/languages/zh-TW.js +1 -2
- package/mixins/hooksRefRegisterer.js +1 -2
- package/mixins/localHooks.js +1 -2
- package/package.json +119 -96
- package/pluginHooks.d.ts +42 -7
- package/pluginHooks.js +301 -65
- package/pluginHooks.mjs +300 -63
- package/plugins/autoColumnSize/autoColumnSize.d.ts +2 -0
- package/plugins/autoColumnSize/autoColumnSize.js +2 -4
- package/plugins/autoRowSize/autoRowSize.d.ts +2 -0
- package/plugins/autoRowSize/autoRowSize.js +15 -10
- package/plugins/autoRowSize/autoRowSize.mjs +13 -6
- package/plugins/autofill/autofill.js +2 -4
- package/plugins/autofill/utils.js +1 -2
- package/plugins/base/base.js +1 -2
- package/plugins/bindRowsWithHeaders/bindRowsWithHeaders.js +2 -4
- package/plugins/bindRowsWithHeaders/maps/looseBindsMap.js +1 -2
- package/plugins/bindRowsWithHeaders/maps/strictBindsMap.js +1 -2
- package/plugins/collapsibleColumns/collapsibleColumns.js +77 -8
- package/plugins/collapsibleColumns/collapsibleColumns.mjs +76 -5
- package/plugins/columnSorting/columnSorting.js +71 -6
- package/plugins/columnSorting/columnSorting.mjs +70 -3
- package/plugins/columnSorting/index.js +3 -1
- package/plugins/columnSorting/index.mjs +1 -1
- package/plugins/columnSorting/sortFunction/checkbox.js +1 -2
- package/plugins/columnSorting/sortFunction/date.js +1 -2
- package/plugins/columnSorting/sortFunction/default.js +1 -2
- package/plugins/columnSorting/sortFunction/numeric.js +1 -2
- package/plugins/columnSorting/sortService/engine.js +3 -6
- package/plugins/columnSorting/utils.js +3 -6
- package/plugins/columnSummary/columnSummary.js +2 -4
- package/plugins/columnSummary/endpoints.js +1 -2
- package/plugins/comments/commentEditor.js +2 -2
- package/plugins/comments/commentEditor.mjs +1 -0
- package/plugins/comments/comments.js +254 -197
- package/plugins/comments/comments.mjs +251 -190
- package/plugins/comments/contextMenuItem/addEditComment.js +41 -0
- package/plugins/comments/contextMenuItem/addEditComment.mjs +35 -0
- package/plugins/comments/contextMenuItem/readOnlyComment.js +49 -0
- package/plugins/comments/contextMenuItem/readOnlyComment.mjs +43 -0
- package/plugins/comments/contextMenuItem/removeComment.js +38 -0
- package/plugins/comments/contextMenuItem/removeComment.mjs +32 -0
- package/plugins/comments/displaySwitch.js +1 -2
- package/plugins/contextMenu/commandExecutor.js +2 -3
- package/plugins/contextMenu/commandExecutor.mjs +2 -3
- package/plugins/contextMenu/contextMenu.d.ts +1 -1
- package/plugins/contextMenu/contextMenu.js +77 -40
- package/plugins/contextMenu/contextMenu.mjs +74 -35
- package/plugins/contextMenu/itemsFactory.js +2 -3
- package/plugins/contextMenu/itemsFactory.mjs +3 -4
- package/plugins/contextMenu/{cursor.mjs → menu/cursor.js} +6 -4
- package/plugins/contextMenu/{cursor.js → menu/cursor.mjs} +4 -10
- package/plugins/contextMenu/menu/defaultShortcutsList.js +88 -0
- package/plugins/contextMenu/menu/defaultShortcutsList.mjs +84 -0
- package/plugins/contextMenu/menu/index.js +9 -0
- package/plugins/contextMenu/menu/index.mjs +1 -0
- package/plugins/contextMenu/{menu.js → menu/menu.js} +145 -421
- package/plugins/contextMenu/{menu.mjs → menu/menu.mjs} +146 -422
- package/plugins/contextMenu/menu/menuItemRenderer.js +70 -0
- package/plugins/contextMenu/menu/menuItemRenderer.mjs +66 -0
- package/plugins/contextMenu/menu/navigator.js +27 -0
- package/plugins/contextMenu/menu/navigator.mjs +23 -0
- package/plugins/contextMenu/menu/positioner.js +213 -0
- package/plugins/contextMenu/menu/positioner.mjs +209 -0
- package/plugins/contextMenu/menu/shortcuts.js +114 -0
- package/plugins/contextMenu/menu/shortcuts.mjs +110 -0
- package/plugins/contextMenu/menu/utils.js +177 -0
- package/plugins/contextMenu/menu/utils.mjs +163 -0
- package/plugins/contextMenu/predefinedItems/alignment.js +10 -4
- package/plugins/contextMenu/predefinedItems/alignment.mjs +7 -0
- package/plugins/contextMenu/predefinedItems/clearColumn.js +8 -7
- package/plugins/contextMenu/predefinedItems/clearColumn.mjs +5 -3
- package/plugins/contextMenu/predefinedItems/columnLeft.js +8 -7
- package/plugins/contextMenu/predefinedItems/columnLeft.mjs +5 -3
- package/plugins/contextMenu/predefinedItems/columnRight.js +8 -7
- package/plugins/contextMenu/predefinedItems/columnRight.mjs +5 -3
- package/plugins/contextMenu/predefinedItems/index.js +75 -0
- package/plugins/contextMenu/predefinedItems/index.mjs +68 -0
- package/plugins/contextMenu/predefinedItems/noItems.js +1 -2
- package/plugins/contextMenu/predefinedItems/readOnly.js +10 -4
- package/plugins/contextMenu/predefinedItems/readOnly.mjs +7 -0
- package/plugins/contextMenu/predefinedItems/redo.js +3 -4
- package/plugins/contextMenu/predefinedItems/removeColumn.js +10 -9
- package/plugins/contextMenu/predefinedItems/removeColumn.mjs +5 -3
- package/plugins/contextMenu/predefinedItems/removeRow.js +10 -9
- package/plugins/contextMenu/predefinedItems/removeRow.mjs +5 -3
- package/plugins/contextMenu/predefinedItems/rowAbove.js +8 -7
- package/plugins/contextMenu/predefinedItems/rowAbove.mjs +5 -3
- package/plugins/contextMenu/predefinedItems/rowBelow.js +8 -7
- package/plugins/contextMenu/predefinedItems/rowBelow.mjs +5 -3
- package/plugins/contextMenu/predefinedItems/separator.js +1 -2
- package/plugins/contextMenu/predefinedItems/undo.js +3 -4
- package/plugins/contextMenu/utils.js +35 -151
- package/plugins/contextMenu/utils.mjs +35 -144
- package/plugins/copyPaste/clipboardData/clipboardData.js +516 -0
- package/plugins/copyPaste/clipboardData/clipboardData.mjs +512 -0
- package/plugins/copyPaste/clipboardData/copyClipboardData.js +69 -0
- package/plugins/copyPaste/clipboardData/copyClipboardData.mjs +65 -0
- package/plugins/copyPaste/clipboardData/index.js +9 -0
- package/plugins/copyPaste/clipboardData/index.mjs +4 -0
- package/plugins/copyPaste/clipboardData/pasteClipboardData.js +81 -0
- package/plugins/copyPaste/clipboardData/pasteClipboardData.mjs +77 -0
- package/plugins/copyPaste/contextMenuItem/copy.js +7 -0
- package/plugins/copyPaste/contextMenuItem/copy.mjs +7 -0
- package/plugins/copyPaste/contextMenuItem/copyColumnHeadersOnly.js +9 -1
- package/plugins/copyPaste/contextMenuItem/copyColumnHeadersOnly.mjs +9 -1
- package/plugins/copyPaste/contextMenuItem/copyWithColumnGroupHeaders.js +9 -1
- package/plugins/copyPaste/contextMenuItem/copyWithColumnGroupHeaders.mjs +9 -1
- package/plugins/copyPaste/contextMenuItem/copyWithColumnHeaders.js +9 -1
- package/plugins/copyPaste/contextMenuItem/copyWithColumnHeaders.mjs +9 -1
- package/plugins/copyPaste/contextMenuItem/cut.js +9 -2
- package/plugins/copyPaste/contextMenuItem/cut.mjs +7 -0
- package/plugins/copyPaste/copyPaste.js +160 -167
- package/plugins/copyPaste/copyPaste.mjs +161 -166
- package/plugins/customBorders/contextMenuItem/bottom.js +2 -2
- package/plugins/customBorders/contextMenuItem/left.js +2 -2
- package/plugins/customBorders/contextMenuItem/noBorders.js +2 -2
- package/plugins/customBorders/contextMenuItem/right.js +2 -2
- package/plugins/customBorders/contextMenuItem/top.js +2 -2
- package/plugins/customBorders/customBorders.js +27 -26
- package/plugins/customBorders/customBorders.mjs +24 -21
- package/plugins/dragToScroll/dragToScroll.js +2 -4
- package/plugins/dropdownMenu/dropdownMenu.d.ts +1 -1
- package/plugins/dropdownMenu/dropdownMenu.js +130 -44
- package/plugins/dropdownMenu/dropdownMenu.mjs +127 -39
- package/plugins/exportFile/dataProvider.js +1 -2
- package/plugins/exportFile/exportFile.js +4 -6
- package/plugins/exportFile/typeFactory.js +5 -8
- package/plugins/exportFile/types/_base.js +1 -2
- package/plugins/exportFile/types/csv.js +1 -2
- package/plugins/filters/component/_base.js +23 -8
- package/plugins/filters/component/_base.mjs +23 -8
- package/plugins/filters/component/actionBar.js +31 -29
- package/plugins/filters/component/actionBar.mjs +26 -23
- package/plugins/filters/component/condition.js +48 -61
- package/plugins/filters/component/condition.mjs +40 -52
- package/plugins/filters/component/operators.js +21 -22
- package/plugins/filters/component/operators.mjs +18 -18
- package/plugins/filters/component/value.js +37 -28
- package/plugins/filters/component/value.mjs +32 -22
- package/plugins/filters/condition/beginsWith.js +3 -4
- package/plugins/filters/condition/between.js +3 -4
- package/plugins/filters/condition/byValue.js +1 -2
- package/plugins/filters/condition/contains.js +3 -4
- package/plugins/filters/condition/date/after.js +3 -4
- package/plugins/filters/condition/date/before.js +3 -4
- package/plugins/filters/condition/date/today.js +3 -4
- package/plugins/filters/condition/date/tomorrow.js +3 -4
- package/plugins/filters/condition/date/yesterday.js +3 -4
- package/plugins/filters/condition/empty.js +3 -4
- package/plugins/filters/condition/endsWith.js +3 -4
- package/plugins/filters/condition/equal.js +3 -4
- package/plugins/filters/condition/false.js +1 -2
- package/plugins/filters/condition/greaterThan.js +3 -4
- package/plugins/filters/condition/greaterThanOrEqual.js +3 -4
- package/plugins/filters/condition/lessThan.js +3 -4
- package/plugins/filters/condition/lessThanOrEqual.js +3 -4
- package/plugins/filters/condition/none.js +3 -4
- package/plugins/filters/condition/notBetween.js +3 -4
- package/plugins/filters/condition/notContains.js +3 -4
- package/plugins/filters/condition/notEmpty.js +3 -4
- package/plugins/filters/condition/notEqual.js +3 -4
- package/plugins/filters/condition/true.js +1 -2
- package/plugins/filters/conditionCollection.d.ts +3 -2
- package/plugins/filters/conditionCollection.js +1 -2
- package/plugins/filters/conditionRegisterer.js +1 -2
- package/plugins/filters/conditionUpdateObserver.js +1 -2
- package/plugins/filters/constants.js +4 -8
- package/plugins/filters/constants.mjs +1 -1
- package/plugins/filters/dataFilter.js +1 -2
- package/plugins/filters/filters.d.ts +3 -5
- package/plugins/filters/filters.js +118 -67
- package/plugins/filters/filters.mjs +109 -56
- package/plugins/filters/logicalOperationRegisterer.js +1 -2
- package/plugins/filters/logicalOperations/conjunction.js +4 -6
- package/plugins/filters/logicalOperations/disjunction.js +4 -6
- package/plugins/filters/logicalOperations/disjunctionWithExtraCondition.js +4 -6
- package/plugins/filters/menu/focusController.js +123 -0
- package/plugins/filters/menu/focusController.mjs +119 -0
- package/plugins/filters/menu/focusNavigator.js +30 -0
- package/plugins/filters/menu/focusNavigator.mjs +26 -0
- package/plugins/filters/ui/_base.js +37 -15
- package/plugins/filters/ui/_base.mjs +35 -13
- package/plugins/filters/ui/input.js +43 -35
- package/plugins/filters/ui/input.mjs +42 -33
- package/plugins/filters/ui/link.js +44 -12
- package/plugins/filters/ui/link.mjs +44 -11
- package/plugins/filters/ui/multipleSelect.js +237 -133
- package/plugins/filters/ui/multipleSelect.mjs +232 -127
- package/plugins/filters/ui/radioInput.js +42 -18
- package/plugins/filters/ui/radioInput.mjs +42 -17
- package/plugins/filters/ui/select.js +152 -77
- package/plugins/filters/ui/select.mjs +148 -72
- package/plugins/formulas/engine/settings.js +2 -4
- package/plugins/formulas/formulas.js +3 -6
- package/plugins/formulas/indexSyncer/axisSyncer.js +1 -2
- package/plugins/formulas/indexSyncer/index.js +1 -2
- package/plugins/hiddenColumns/contextMenuItem/hideColumn.js +2 -2
- package/plugins/hiddenColumns/contextMenuItem/showColumn.js +2 -2
- package/plugins/hiddenColumns/hiddenColumns.d.ts +1 -0
- package/plugins/hiddenColumns/hiddenColumns.js +49 -6
- package/plugins/hiddenColumns/hiddenColumns.mjs +48 -3
- package/plugins/hiddenRows/contextMenuItem/hideRow.js +2 -2
- package/plugins/hiddenRows/contextMenuItem/showRow.js +2 -2
- package/plugins/hiddenRows/hiddenRows.d.ts +1 -0
- package/plugins/hiddenRows/hiddenRows.js +49 -6
- package/plugins/hiddenRows/hiddenRows.mjs +48 -3
- package/plugins/manualColumnFreeze/contextMenuItem/freezeColumn.js +2 -2
- package/plugins/manualColumnFreeze/contextMenuItem/unfreezeColumn.js +2 -2
- package/plugins/manualColumnFreeze/manualColumnFreeze.js +2 -4
- package/plugins/manualColumnMove/manualColumnMove.js +9 -17
- package/plugins/manualColumnMove/manualColumnMove.mjs +7 -13
- package/plugins/manualColumnMove/ui/_base.js +1 -2
- package/plugins/manualColumnMove/ui/backlight.js +1 -2
- package/plugins/manualColumnMove/ui/guideline.js +1 -2
- package/plugins/manualColumnResize/manualColumnResize.js +2 -4
- package/plugins/manualRowMove/manualRowMove.js +6 -23
- package/plugins/manualRowMove/manualRowMove.mjs +4 -19
- package/plugins/manualRowMove/ui/_base.js +1 -2
- package/plugins/manualRowMove/ui/backlight.js +1 -2
- package/plugins/manualRowMove/ui/guideline.js +1 -2
- package/plugins/manualRowResize/manualRowResize.js +2 -4
- package/plugins/mergeCells/calculations/autofill.js +1 -2
- package/plugins/mergeCells/calculations/selection.js +1 -2
- package/plugins/mergeCells/cellCoords.js +1 -2
- package/plugins/mergeCells/cellsCollection.js +1 -2
- package/plugins/mergeCells/contextMenuItem/toggleMerge.js +2 -2
- package/plugins/mergeCells/mergeCells.js +7 -20
- package/plugins/mergeCells/mergeCells.mjs +5 -16
- package/plugins/multiColumnSorting/multiColumnSorting.js +60 -6
- package/plugins/multiColumnSorting/multiColumnSorting.mjs +59 -3
- package/plugins/multipleSelectionHandles/multipleSelectionHandles.js +2 -4
- package/plugins/nestedHeaders/nestedHeaders.js +263 -36
- package/plugins/nestedHeaders/nestedHeaders.mjs +262 -33
- package/plugins/nestedHeaders/stateManager/index.js +102 -3
- package/plugins/nestedHeaders/stateManager/index.mjs +102 -3
- package/plugins/nestedHeaders/stateManager/sourceSettings.js +1 -2
- package/plugins/nestedHeaders/utils/ghostTable.js +1 -2
- package/plugins/nestedRows/data/dataManager.js +1 -2
- package/plugins/nestedRows/nestedRows.js +47 -10
- package/plugins/nestedRows/nestedRows.mjs +45 -6
- package/plugins/nestedRows/ui/_base.js +1 -2
- package/plugins/nestedRows/ui/collapsing.js +1 -2
- package/plugins/nestedRows/ui/contextMenu.js +3 -4
- package/plugins/nestedRows/ui/headers.js +13 -3
- package/plugins/nestedRows/ui/headers.mjs +13 -2
- package/plugins/persistentState/persistentState.js +2 -4
- package/plugins/persistentState/storage.js +1 -2
- package/plugins/search/search.js +2 -4
- package/plugins/touchScroll/touchScroll.js +2 -4
- package/plugins/trimRows/trimRows.js +2 -4
- package/plugins/undoRedo/index.js +2 -2
- package/plugins/undoRedo/undoRedo.js +2 -4
- package/renderers/autocompleteRenderer/autocompleteRenderer.js +9 -2
- package/renderers/autocompleteRenderer/autocompleteRenderer.mjs +8 -0
- package/renderers/baseRenderer/baseRenderer.js +18 -2
- package/renderers/baseRenderer/baseRenderer.mjs +18 -1
- package/renderers/checkboxRenderer/checkboxRenderer.js +10 -6
- package/renderers/checkboxRenderer/checkboxRenderer.mjs +9 -4
- package/renderers/dateRenderer/dateRenderer.d.ts +5 -0
- package/renderers/dateRenderer/dateRenderer.js +28 -0
- package/renderers/dateRenderer/dateRenderer.mjs +24 -0
- package/renderers/dateRenderer/index.d.ts +1 -0
- package/renderers/dateRenderer/index.js +6 -0
- package/renderers/dateRenderer/index.mjs +1 -0
- package/renderers/handsontableRenderer/handsontableRenderer.d.ts +5 -0
- package/renderers/handsontableRenderer/handsontableRenderer.js +28 -0
- package/renderers/handsontableRenderer/handsontableRenderer.mjs +24 -0
- package/renderers/handsontableRenderer/index.d.ts +1 -0
- package/renderers/handsontableRenderer/index.js +6 -0
- package/renderers/handsontableRenderer/index.mjs +1 -0
- package/renderers/htmlRenderer/htmlRenderer.js +1 -2
- package/renderers/index.d.ts +9 -0
- package/renderers/numericRenderer/numericRenderer.js +1 -2
- package/renderers/passwordRenderer/passwordRenderer.js +1 -2
- package/renderers/selectRenderer/index.d.ts +1 -0
- package/renderers/selectRenderer/index.js +6 -0
- package/renderers/selectRenderer/index.mjs +1 -0
- package/renderers/selectRenderer/selectRenderer.d.ts +5 -0
- package/renderers/selectRenderer/selectRenderer.js +26 -0
- package/renderers/selectRenderer/selectRenderer.mjs +22 -0
- package/renderers/textRenderer/textRenderer.js +1 -2
- package/renderers/timeRenderer/timeRenderer.js +1 -2
- package/selection/highlight/highlight.js +257 -73
- package/selection/highlight/highlight.mjs +250 -71
- package/selection/highlight/types/activeHeader.js +10 -8
- package/selection/highlight/types/activeHeader.mjs +10 -8
- package/selection/highlight/types/area.js +6 -18
- package/selection/highlight/types/area.mjs +6 -18
- package/selection/highlight/types/areaLayered.js +31 -0
- package/selection/highlight/types/areaLayered.mjs +26 -0
- package/selection/highlight/types/column.js +27 -0
- package/selection/highlight/types/column.mjs +22 -0
- package/selection/highlight/types/customSelection.js +7 -9
- package/selection/highlight/types/customSelection.mjs +7 -9
- package/selection/highlight/types/fill.js +5 -7
- package/selection/highlight/types/fill.mjs +5 -7
- package/selection/highlight/types/{cell.js → focus.js} +5 -7
- package/selection/highlight/types/{cell.mjs → focus.mjs} +5 -7
- package/selection/highlight/types/header.js +9 -18
- package/selection/highlight/types/header.mjs +9 -18
- package/selection/highlight/types/row.js +27 -0
- package/selection/highlight/types/row.mjs +22 -0
- package/selection/highlight/visualSelection.js +32 -29
- package/selection/highlight/visualSelection.mjs +31 -27
- package/selection/index.js +4 -7
- package/selection/index.mjs +2 -3
- package/selection/mouseEventHandler.js +7 -1
- package/selection/mouseEventHandler.mjs +7 -1
- package/selection/range.js +9 -10
- package/selection/range.mjs +8 -8
- package/selection/selection.js +334 -154
- package/selection/selection.mjs +330 -151
- package/selection/transformation.js +233 -94
- package/selection/transformation.mjs +232 -92
- package/selection/utils.js +20 -31
- package/selection/utils.mjs +16 -21
- package/settings.d.ts +4 -0
- package/shortcutContexts/commands/editor/closeAndSave.js +11 -0
- package/shortcutContexts/commands/editor/closeAndSave.mjs +8 -0
- package/shortcutContexts/commands/editor/closeWithoutSaving.js +11 -0
- package/shortcutContexts/commands/editor/closeWithoutSaving.mjs +8 -0
- package/shortcutContexts/commands/editor/fastOpen.js +15 -0
- package/shortcutContexts/commands/editor/fastOpen.mjs +12 -0
- package/shortcutContexts/commands/editor/index.js +16 -0
- package/shortcutContexts/commands/editor/index.mjs +12 -0
- package/shortcutContexts/commands/editor/open.js +26 -0
- package/shortcutContexts/commands/editor/open.mjs +23 -0
- package/shortcutContexts/commands/emptySelectedCells.js +10 -0
- package/shortcutContexts/commands/emptySelectedCells.mjs +7 -0
- package/shortcutContexts/commands/extendCellsSelection/down.js +14 -0
- package/shortcutContexts/commands/extendCellsSelection/down.mjs +11 -0
- package/shortcutContexts/commands/extendCellsSelection/downByViewportHeight.js +24 -0
- package/shortcutContexts/commands/extendCellsSelection/downByViewportHeight.mjs +21 -0
- package/shortcutContexts/commands/extendCellsSelection/index.js +26 -0
- package/shortcutContexts/commands/extendCellsSelection/index.mjs +22 -0
- package/shortcutContexts/commands/extendCellsSelection/left.js +14 -0
- package/shortcutContexts/commands/extendCellsSelection/left.mjs +11 -0
- package/shortcutContexts/commands/extendCellsSelection/right.js +14 -0
- package/shortcutContexts/commands/extendCellsSelection/right.mjs +11 -0
- package/shortcutContexts/commands/extendCellsSelection/toColumns.js +18 -0
- package/shortcutContexts/commands/extendCellsSelection/toColumns.mjs +15 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostBottom.js +28 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostBottom.mjs +25 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostInlineEnd.js +18 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostInlineEnd.mjs +15 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostInlineStart.js +18 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostInlineStart.mjs +15 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostLeft.js +28 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostLeft.mjs +25 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostRight.js +28 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostRight.mjs +25 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostTop.js +28 -0
- package/shortcutContexts/commands/extendCellsSelection/toMostTop.mjs +25 -0
- package/shortcutContexts/commands/extendCellsSelection/toRows.js +18 -0
- package/shortcutContexts/commands/extendCellsSelection/toRows.mjs +15 -0
- package/shortcutContexts/commands/extendCellsSelection/up.js +14 -0
- package/shortcutContexts/commands/extendCellsSelection/up.mjs +11 -0
- package/shortcutContexts/commands/extendCellsSelection/upByViewportHeight.js +24 -0
- package/shortcutContexts/commands/extendCellsSelection/upByViewportHeight.mjs +21 -0
- package/shortcutContexts/commands/index.js +35 -0
- package/shortcutContexts/commands/index.mjs +31 -0
- package/shortcutContexts/commands/moveCellSelection/down.js +12 -0
- package/shortcutContexts/commands/moveCellSelection/down.mjs +9 -0
- package/shortcutContexts/commands/moveCellSelection/downByViewportHeight.js +32 -0
- package/shortcutContexts/commands/moveCellSelection/downByViewportHeight.mjs +29 -0
- package/shortcutContexts/commands/moveCellSelection/index.js +28 -0
- package/shortcutContexts/commands/moveCellSelection/index.mjs +24 -0
- package/shortcutContexts/commands/moveCellSelection/inlineEnd.js +11 -0
- package/shortcutContexts/commands/moveCellSelection/inlineEnd.mjs +8 -0
- package/shortcutContexts/commands/moveCellSelection/inlineStart.js +11 -0
- package/shortcutContexts/commands/moveCellSelection/inlineStart.mjs +8 -0
- package/shortcutContexts/commands/moveCellSelection/left.js +9 -0
- package/shortcutContexts/commands/moveCellSelection/left.mjs +6 -0
- package/shortcutContexts/commands/moveCellSelection/right.js +9 -0
- package/shortcutContexts/commands/moveCellSelection/right.mjs +6 -0
- package/shortcutContexts/commands/moveCellSelection/toMostBottom.js +16 -0
- package/shortcutContexts/commands/moveCellSelection/toMostBottom.mjs +13 -0
- package/shortcutContexts/commands/moveCellSelection/toMostBottomInlineEnd.js +17 -0
- package/shortcutContexts/commands/moveCellSelection/toMostBottomInlineEnd.mjs +14 -0
- package/shortcutContexts/commands/moveCellSelection/toMostInlineEnd.js +13 -0
- package/shortcutContexts/commands/moveCellSelection/toMostInlineEnd.mjs +10 -0
- package/shortcutContexts/commands/moveCellSelection/toMostInlineStart.js +16 -0
- package/shortcutContexts/commands/moveCellSelection/toMostInlineStart.mjs +13 -0
- package/shortcutContexts/commands/moveCellSelection/toMostLeft.js +18 -0
- package/shortcutContexts/commands/moveCellSelection/toMostLeft.mjs +15 -0
- package/shortcutContexts/commands/moveCellSelection/toMostRight.js +20 -0
- package/shortcutContexts/commands/moveCellSelection/toMostRight.mjs +17 -0
- package/shortcutContexts/commands/moveCellSelection/toMostTop.js +16 -0
- package/shortcutContexts/commands/moveCellSelection/toMostTop.mjs +13 -0
- package/shortcutContexts/commands/moveCellSelection/toMostTopInlineStart.js +18 -0
- package/shortcutContexts/commands/moveCellSelection/toMostTopInlineStart.mjs +15 -0
- package/shortcutContexts/commands/moveCellSelection/up.js +12 -0
- package/shortcutContexts/commands/moveCellSelection/up.mjs +9 -0
- package/shortcutContexts/commands/moveCellSelection/upByViewportHeight.js +32 -0
- package/shortcutContexts/commands/moveCellSelection/upByViewportHeight.mjs +29 -0
- package/shortcutContexts/commands/populateSelectedCellsData.js +28 -0
- package/shortcutContexts/commands/populateSelectedCellsData.mjs +25 -0
- package/shortcutContexts/commands/scrollToFocusedCell.js +34 -0
- package/shortcutContexts/commands/scrollToFocusedCell.mjs +31 -0
- package/shortcutContexts/commands/selectAll.js +11 -0
- package/shortcutContexts/commands/selectAll.mjs +8 -0
- package/shortcutContexts/constants.js +11 -0
- package/shortcutContexts/constants.mjs +8 -0
- package/shortcutContexts/editor.js +25 -0
- package/shortcutContexts/editor.mjs +21 -0
- package/shortcutContexts/grid.js +167 -0
- package/shortcutContexts/grid.mjs +163 -0
- package/shortcutContexts/index.js +24 -0
- package/shortcutContexts/index.mjs +11 -0
- package/shortcuts/context.d.ts +1 -0
- package/shortcuts/context.js +23 -4
- package/shortcuts/context.mjs +23 -5
- package/shortcuts/manager.js +31 -7
- package/shortcuts/manager.mjs +32 -7
- package/shortcuts/recorder.js +30 -14
- package/shortcuts/recorder.mjs +30 -14
- package/shortcuts/utils.js +19 -5
- package/shortcuts/utils.mjs +18 -4
- package/tableView.js +113 -16
- package/tableView.mjs +113 -15
- package/utils/dataStructures/linkedList.js +1 -2
- package/utils/dataStructures/priorityMap.js +2 -4
- package/utils/dataStructures/queue.js +1 -2
- package/utils/dataStructures/stack.js +1 -2
- package/utils/dataStructures/tree.js +3 -6
- package/utils/ghostTable.js +32 -17
- package/utils/ghostTable.mjs +31 -15
- package/utils/interval.js +1 -2
- package/utils/paginator.js +151 -0
- package/utils/paginator.mjs +147 -0
- package/utils/parseTable.js +527 -83
- package/utils/parseTable.mjs +523 -82
- package/utils/rootInstance.js +2 -4
- package/utils/samplesGenerator.js +21 -13
- package/utils/samplesGenerator.mjs +20 -11
- package/utils/staticRegister.js +1 -2
- package/validators/autocompleteValidator/autocompleteValidator.js +1 -2
- package/validators/dateValidator/dateValidator.js +1 -2
- package/validators/numericValidator/numericValidator.js +1 -2
- package/validators/timeValidator/timeValidator.js +1 -2
- package/3rdparty/walkontable/src/selection.js +0 -295
- package/3rdparty/walkontable/src/selection.mjs +0 -290
- package/plugins/contextMenu/predefinedItems.js +0 -76
- package/plugins/contextMenu/predefinedItems.mjs +0 -68
- package/plugins/copyPaste/clipboardData.js +0 -18
- package/plugins/copyPaste/clipboardData.mjs +0 -14
- package/plugins/copyPaste/focusableElement.js +0 -186
- package/plugins/copyPaste/focusableElement.mjs +0 -180
- package/plugins/copyPaste/pasteEvent.js +0 -14
- package/plugins/copyPaste/pasteEvent.mjs +0 -9
- package/selection/highlight/constants.js +0 -15
- package/selection/highlight/constants.mjs +0 -6
- package/selection/highlight/types/index.js +0 -35
- package/selection/highlight/types/index.mjs +0 -31
package/utils/parseTable.js
CHANGED
@@ -1,11 +1,17 @@
|
|
1
1
|
"use strict";
|
2
2
|
|
3
3
|
exports.__esModule = true;
|
4
|
-
exports.
|
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}
|
50
|
+
* @param {Core} hotInstance The Handsontable instance.
|
31
51
|
* @returns {string} OuterHTML of the HTMLTableElement.
|
32
52
|
*/
|
33
|
-
function instanceToHTML(
|
34
|
-
const
|
35
|
-
const
|
36
|
-
const
|
37
|
-
|
38
|
-
|
39
|
-
const
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
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
|
-
} =
|
62
|
-
if (
|
63
|
-
|
64
|
-
|
65
|
-
|
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('<', '<').replace('>', '>').replace(/(<br(\s*|\/)>(\r\n|\n)?|\r\n|\n)/g, '<br>\r\n').replace(/\x20/gi, ' ').replace(/\t/gi, '	');
|
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
|
-
|
79
|
-
}
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
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
|
-
|
88
|
-
|
336
|
+
if (headersHTML.length > 0) {
|
337
|
+
return ['<thead>', ...headersHTML, '</thead>'];
|
338
|
+
}
|
339
|
+
return [];
|
89
340
|
}
|
90
341
|
|
91
342
|
/**
|
92
|
-
* Converts
|
343
|
+
* Converts config with information about cells and headers into list of values.
|
93
344
|
*
|
94
|
-
* @param {
|
95
|
-
* @
|
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
|
-
|
98
|
-
|
99
|
-
const
|
100
|
-
const
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
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, '&').replace('<', '<').replace('>', '>').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">${' '.repeat(substring.length - 1)} </span>`;
|
390
|
+
}).replace(/\t/gi, '	');
|
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(' ', ' ');
|
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
|
-
|
117
|
-
|
118
|
-
|
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
|
-
|
122
|
-
|
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
|
702
|
+
dataArr[row][col] = decodeHTMLEntities(cellValue);
|
259
703
|
} else {
|
260
704
|
rowHeaders.push(innerHTML);
|
261
705
|
}
|