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