@kdcloudjs/table 1.0.0
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/LICENSE +568 -0
- package/README.md +111 -0
- package/dist/@kdcloudjs/table.css +422 -0
- package/dist/@kdcloudjs/table.css.map +1 -0
- package/dist/@kdcloudjs/table.js +38578 -0
- package/dist/@kdcloudjs/table.js.map +1 -0
- package/dist/@kdcloudjs/table.min.css +9 -0
- package/dist/@kdcloudjs/table.min.js +208 -0
- package/dist/@kdcloudjs/table.min.js.map +1 -0
- package/dist/default-theme.js +344 -0
- package/dist/kd-table.css +422 -0
- package/dist/kd-table.css.map +1 -0
- package/dist/kd-table.js +38578 -0
- package/dist/kd-table.js.map +1 -0
- package/dist/kd-table.min.css +9 -0
- package/dist/kd-table.min.js +208 -0
- package/dist/kd-table.min.js.map +1 -0
- package/dist/kd-ui-complete.less +779 -0
- package/dist/kd-ui.less +2 -0
- package/dist/theme.js +13 -0
- package/es/_utils/arrayUtil.d.ts +5 -0
- package/es/_utils/arrayUtil.js +17 -0
- package/es/_utils/devwarning.d.ts +1 -0
- package/es/_utils/devwarning.js +10 -0
- package/es/_utils/formatUtil.d.ts +46 -0
- package/es/_utils/formatUtil.js +346 -0
- package/es/_utils/hooks.d.ts +51 -0
- package/es/_utils/hooks.js +165 -0
- package/es/_utils/index.d.ts +8 -0
- package/es/_utils/index.js +15 -0
- package/es/_utils/numberUtil.d.ts +34 -0
- package/es/_utils/numberUtil.js +181 -0
- package/es/_utils/omit.d.ts +1 -0
- package/es/_utils/omit.js +11 -0
- package/es/_utils/react-children.d.ts +2 -0
- package/es/_utils/react-children.js +8 -0
- package/es/_utils/type.d.ts +12 -0
- package/es/_utils/type.js +15 -0
- package/es/_utils/usePopper.d.ts +29 -0
- package/es/_utils/usePopper.js +546 -0
- package/es/config-provider/ConfigContext.d.ts +22 -0
- package/es/config-provider/ConfigContext.js +7 -0
- package/es/config-provider/compDefaultProps.d.ts +8 -0
- package/es/config-provider/compDefaultProps.js +10 -0
- package/es/config-provider/configProvider.d.ts +11 -0
- package/es/config-provider/configProvider.js +40 -0
- package/es/config-provider/defaultConfig.d.ts +10 -0
- package/es/config-provider/defaultConfig.js +18 -0
- package/es/config-provider/index.d.ts +6 -0
- package/es/config-provider/index.js +6 -0
- package/es/index.d.ts +2 -0
- package/es/index.js +4 -0
- package/es/locale/index.d.ts +3 -0
- package/es/locale/index.js +3 -0
- package/es/locale/locale.d.ts +50 -0
- package/es/locale/locale.js +251 -0
- package/es/locale/zh-CN.d.ts +8 -0
- package/es/locale/zh-CN.js +8 -0
- package/es/style/color/colors.less +2 -0
- package/es/style/core/index.less +2 -0
- package/es/style/core/motion/other.less +28 -0
- package/es/style/core/motion/slide.less +53 -0
- package/es/style/core/motion.less +2 -0
- package/es/style/core/reset.less +186 -0
- package/es/style/css.js +1 -0
- package/es/style/index.css +410 -0
- package/es/style/index.d.ts +1 -0
- package/es/style/index.js +1 -0
- package/es/style/index.less +2 -0
- package/es/style/mixins/index.less +19 -0
- package/es/style/mixins/overlay.less +22 -0
- package/es/style/mixins/reset.less +13 -0
- package/es/style/themes/default.less +445 -0
- package/es/style/themes/index.less +1 -0
- package/es/table/base/calculations.d.ts +5 -0
- package/es/table/base/calculations.js +364 -0
- package/es/table/base/colgroup.d.ts +5 -0
- package/es/table/base/colgroup.js +22 -0
- package/es/table/base/empty.d.ts +9 -0
- package/es/table/base/empty.js +38 -0
- package/es/table/base/header.d.ts +5 -0
- package/es/table/base/header.js +324 -0
- package/es/table/base/helpers/SpanManager.d.ts +9 -0
- package/es/table/base/helpers/SpanManager.js +50 -0
- package/es/table/base/helpers/TableDOMUtils.d.ts +18 -0
- package/es/table/base/helpers/TableDOMUtils.js +104 -0
- package/es/table/base/helpers/__test__/SpanManager.test.d.ts +1 -0
- package/es/table/base/helpers/__test__/SpanManager.test.js +18 -0
- package/es/table/base/helpers/__test__/TableDOMUtils.test.d.ts +1 -0
- package/es/table/base/helpers/__test__/TableDOMUtils.test.js +34 -0
- package/es/table/base/helpers/__test__/rowHeightManager.test.d.ts +1 -0
- package/es/table/base/helpers/__test__/rowHeightManager.test.js +30 -0
- package/es/table/base/helpers/__test__/visible-part.test.d.ts +1 -0
- package/es/table/base/helpers/__test__/visible-part.test.js +28 -0
- package/es/table/base/helpers/rowHeightManager.d.ts +7 -0
- package/es/table/base/helpers/rowHeightManager.js +157 -0
- package/es/table/base/helpers/visible-part.d.ts +23 -0
- package/es/table/base/helpers/visible-part.js +58 -0
- package/es/table/base/html-table.d.ts +15 -0
- package/es/table/base/html-table.js +132 -0
- package/es/table/base/index.d.ts +3 -0
- package/es/table/base/index.js +2 -0
- package/es/table/base/interfaces.d.ts +54 -0
- package/es/table/base/interfaces.js +0 -0
- package/es/table/base/loading.d.ts +13 -0
- package/es/table/base/loading.js +60 -0
- package/es/table/base/styles.d.ts +132 -0
- package/es/table/base/styles.js +112 -0
- package/es/table/base/table.d.ts +150 -0
- package/es/table/base/table.js +733 -0
- package/es/table/base/utils.d.ts +36 -0
- package/es/table/base/utils.js +193 -0
- package/es/table/common-views.d.ts +24 -0
- package/es/table/common-views.js +70 -0
- package/es/table/index.d.ts +6 -0
- package/es/table/index.js +6 -0
- package/es/table/interfaces.d.ts +98 -0
- package/es/table/interfaces.js +0 -0
- package/es/table/internals.d.ts +14 -0
- package/es/table/internals.js +56 -0
- package/es/table/pipeline/features/__test__/multiSelect.test.d.ts +1 -0
- package/es/table/pipeline/features/__test__/multiSelect.test.js +152 -0
- package/es/table/pipeline/features/__test__/rowDetail.test.d.ts +1 -0
- package/es/table/pipeline/features/__test__/rowDetail.test.js +223 -0
- package/es/table/pipeline/features/__test__/rowGrouping.test.d.ts +1 -0
- package/es/table/pipeline/features/__test__/rowGrouping.test.js +120 -0
- package/es/table/pipeline/features/__test__/singleSelect.test.d.ts +1 -0
- package/es/table/pipeline/features/__test__/singleSelect.test.js +191 -0
- package/es/table/pipeline/features/__test__/sort.test.d.ts +1 -0
- package/es/table/pipeline/features/__test__/sort.test.js +213 -0
- package/es/table/pipeline/features/__test__/tips.test.d.ts +1 -0
- package/es/table/pipeline/features/__test__/tips.test.js +123 -0
- package/es/table/pipeline/features/__test__/treeMode.test.d.ts +1 -0
- package/es/table/pipeline/features/__test__/treeMode.test.js +202 -0
- package/es/table/pipeline/features/autoFill.d.ts +4 -0
- package/es/table/pipeline/features/autoFill.js +63 -0
- package/es/table/pipeline/features/autoRowSpan.d.ts +2 -0
- package/es/table/pipeline/features/autoRowSpan.js +72 -0
- package/es/table/pipeline/features/buildTree.d.ts +2 -0
- package/es/table/pipeline/features/buildTree.js +8 -0
- package/es/table/pipeline/features/columnDrag.d.ts +6 -0
- package/es/table/pipeline/features/columnDrag.js +265 -0
- package/es/table/pipeline/features/columnFilter.d.ts +20 -0
- package/es/table/pipeline/features/columnFilter.js +173 -0
- package/es/table/pipeline/features/columnHover.d.ts +12 -0
- package/es/table/pipeline/features/columnHover.js +51 -0
- package/es/table/pipeline/features/columnRangeHover.d.ts +15 -0
- package/es/table/pipeline/features/columnRangeHover.js +83 -0
- package/es/table/pipeline/features/columnResizeWidth.d.ts +21 -0
- package/es/table/pipeline/features/columnResizeWidth.js +173 -0
- package/es/table/pipeline/features/contextMenu.d.ts +14 -0
- package/es/table/pipeline/features/contextMenu.js +370 -0
- package/es/table/pipeline/features/filter/DefaultFilterContent.d.ts +4 -0
- package/es/table/pipeline/features/filter/DefaultFilterContent.js +91 -0
- package/es/table/pipeline/features/filter/Filter.d.ts +17 -0
- package/es/table/pipeline/features/filter/Filter.js +111 -0
- package/es/table/pipeline/features/filter/FilterPanel.d.ts +20 -0
- package/es/table/pipeline/features/filter/FilterPanel.js +81 -0
- package/es/table/pipeline/features/filter/__test__/Filter.test.d.ts +1 -0
- package/es/table/pipeline/features/filter/__test__/Filter.test.js +29 -0
- package/es/table/pipeline/features/filter/index.d.ts +4 -0
- package/es/table/pipeline/features/filter/index.js +4 -0
- package/es/table/pipeline/features/filter/util.d.ts +10 -0
- package/es/table/pipeline/features/filter/util.js +67 -0
- package/es/table/pipeline/features/index.d.ts +16 -0
- package/es/table/pipeline/features/index.js +16 -0
- package/es/table/pipeline/features/multiSelect.d.ts +27 -0
- package/es/table/pipeline/features/multiSelect.js +208 -0
- package/es/table/pipeline/features/rowDetail.d.ts +35 -0
- package/es/table/pipeline/features/rowDetail.js +254 -0
- package/es/table/pipeline/features/rowGrouping.d.ts +14 -0
- package/es/table/pipeline/features/rowGrouping.js +200 -0
- package/es/table/pipeline/features/singleSelect.d.ts +23 -0
- package/es/table/pipeline/features/singleSelect.js +122 -0
- package/es/table/pipeline/features/sort.d.ts +40 -0
- package/es/table/pipeline/features/sort.js +332 -0
- package/es/table/pipeline/features/tips.d.ts +2 -0
- package/es/table/pipeline/features/tips.js +57 -0
- package/es/table/pipeline/features/treeMode.d.ts +37 -0
- package/es/table/pipeline/features/treeMode.js +234 -0
- package/es/table/pipeline/features/treeSelect.d.ts +38 -0
- package/es/table/pipeline/features/treeSelect.js +154 -0
- package/es/table/pipeline/index.d.ts +3 -0
- package/es/table/pipeline/index.js +3 -0
- package/es/table/pipeline/pipeline.d.ts +85 -0
- package/es/table/pipeline/pipeline.js +272 -0
- package/es/table/pivot/cross-table/buildCrossTable.d.ts +14 -0
- package/es/table/pivot/cross-table/buildCrossTable.js +294 -0
- package/es/table/pivot/cross-table/constants.d.ts +1 -0
- package/es/table/pivot/cross-table/constants.js +1 -0
- package/es/table/pivot/cross-table/cross-table.d.ts +18 -0
- package/es/table/pivot/cross-table/cross-table.js +55 -0
- package/es/table/pivot/cross-table/index.d.ts +4 -0
- package/es/table/pivot/cross-table/index.js +3 -0
- package/es/table/pivot/cross-table/interfaces.d.ts +29 -0
- package/es/table/pivot/cross-table/interfaces.js +0 -0
- package/es/table/pivot/cross-table/internals.d.ts +13 -0
- package/es/table/pivot/cross-table/internals.js +0 -0
- package/es/table/pivot/cross-tree-table/buildCrossTreeTable.d.ts +14 -0
- package/es/table/pivot/cross-tree-table/buildCrossTreeTable.js +219 -0
- package/es/table/pivot/cross-tree-table/cross-tree-table.d.ts +38 -0
- package/es/table/pivot/cross-tree-table/cross-tree-table.js +127 -0
- package/es/table/pivot/cross-tree-table/index.d.ts +2 -0
- package/es/table/pivot/cross-tree-table/index.js +2 -0
- package/es/table/pivot/pivot-utils/buildDrillTree.d.ts +16 -0
- package/es/table/pivot/pivot-utils/buildDrillTree.js +93 -0
- package/es/table/pivot/pivot-utils/builders.d.ts +26 -0
- package/es/table/pivot/pivot-utils/builders.js +252 -0
- package/es/table/pivot/pivot-utils/convert-utils.d.ts +31 -0
- package/es/table/pivot/pivot-utils/convert-utils.js +180 -0
- package/es/table/pivot/pivot-utils/index.d.ts +5 -0
- package/es/table/pivot/pivot-utils/index.js +4 -0
- package/es/table/pivot/pivot-utils/interfaces.d.ts +12 -0
- package/es/table/pivot/pivot-utils/interfaces.js +0 -0
- package/es/table/pivot/pivot-utils/simpleEncode.d.ts +1 -0
- package/es/table/pivot/pivot-utils/simpleEncode.js +7 -0
- package/es/table/style/css.js +2 -0
- package/es/table/style/index.css +0 -0
- package/es/table/style/index.d.ts +2 -0
- package/es/table/style/index.js +2 -0
- package/es/table/style/index.less +1 -0
- package/es/table/transforms/autoRowSpan.d.ts +3 -0
- package/es/table/transforms/autoRowSpan.js +73 -0
- package/es/table/transforms/autoWidth.d.ts +25 -0
- package/es/table/transforms/autoWidth.js +160 -0
- package/es/table/transforms/buildTree.d.ts +3 -0
- package/es/table/transforms/buildTree.js +15 -0
- package/es/table/transforms/columnHover.d.ts +17 -0
- package/es/table/transforms/columnHover.js +59 -0
- package/es/table/transforms/columnRangeHover.d.ts +17 -0
- package/es/table/transforms/columnRangeHover.js +94 -0
- package/es/table/transforms/columnResize.d.ts +27 -0
- package/es/table/transforms/columnResize.js +152 -0
- package/es/table/transforms/flatten.d.ts +3 -0
- package/es/table/transforms/flatten.js +16 -0
- package/es/table/transforms/index.d.ts +12 -0
- package/es/table/transforms/index.js +12 -0
- package/es/table/transforms/orderField.d.ts +3 -0
- package/es/table/transforms/orderField.js +22 -0
- package/es/table/transforms/sort.d.ts +43 -0
- package/es/table/transforms/sort.js +338 -0
- package/es/table/transforms/tips.d.ts +8 -0
- package/es/table/transforms/tips.js +54 -0
- package/es/table/transforms/treeMode.d.ts +30 -0
- package/es/table/transforms/treeMode.js +252 -0
- package/es/table/transforms/visible.d.ts +5 -0
- package/es/table/transforms/visible.js +19 -0
- package/es/table/transforms/warnTransformsDeprecated.d.ts +1 -0
- package/es/table/transforms/warnTransformsDeprecated.js +8 -0
- package/es/table/use/useResizeObserver.d.ts +2 -0
- package/es/table/use/useResizeObserver.js +20 -0
- package/es/table/utils/applyTransforms.d.ts +6 -0
- package/es/table/utils/applyTransforms.js +15 -0
- package/es/table/utils/buildTree.d.ts +36 -0
- package/es/table/utils/buildTree.js +119 -0
- package/es/table/utils/collectNodes.d.ts +8 -0
- package/es/table/utils/collectNodes.js +59 -0
- package/es/table/utils/console.d.ts +11 -0
- package/es/table/utils/console.js +58 -0
- package/es/table/utils/copyToClipboard.d.ts +3 -0
- package/es/table/utils/copyToClipboard.js +30 -0
- package/es/table/utils/element.d.ts +42 -0
- package/es/table/utils/element.js +228 -0
- package/es/table/utils/exportTableAsExcel.d.ts +4 -0
- package/es/table/utils/exportTableAsExcel.js +188 -0
- package/es/table/utils/getTreeDepth.d.ts +3 -0
- package/es/table/utils/getTreeDepth.js +41 -0
- package/es/table/utils/groupBy.d.ts +1 -0
- package/es/table/utils/groupBy.js +37 -0
- package/es/table/utils/index.d.ts +18 -0
- package/es/table/utils/index.js +18 -0
- package/es/table/utils/isGroupColumn.d.ts +2 -0
- package/es/table/utils/isGroupColumn.js +7 -0
- package/es/table/utils/isLeafNode.d.ts +2 -0
- package/es/table/utils/isLeafNode.js +4 -0
- package/es/table/utils/layeredFilter.d.ts +2 -0
- package/es/table/utils/layeredFilter.js +25 -0
- package/es/table/utils/layeredSort.d.ts +5 -0
- package/es/table/utils/layeredSort.js +26 -0
- package/es/table/utils/makeRecursiveMapper.d.ts +9 -0
- package/es/table/utils/makeRecursiveMapper.js +76 -0
- package/es/table/utils/mergeCellProps.d.ts +8 -0
- package/es/table/utils/mergeCellProps.js +67 -0
- package/es/table/utils/others.d.ts +16 -0
- package/es/table/utils/others.js +80 -0
- package/es/table/utils/proto.d.ts +21 -0
- package/es/table/utils/proto.js +106 -0
- package/es/table/utils/smartCompare.d.ts +9 -0
- package/es/table/utils/smartCompare.js +51 -0
- package/es/table/utils/traverseColumn.d.ts +11 -0
- package/es/table/utils/traverseColumn.js +88 -0
- package/es/table/utils/tree-data-helpers/StrictTreeDataHelper.d.ts +22 -0
- package/es/table/utils/tree-data-helpers/StrictTreeDataHelper.js +138 -0
- package/es/table/utils/tree-data-helpers/TreeDataHelper.d.ts +26 -0
- package/es/table/utils/tree-data-helpers/TreeDataHelper.js +337 -0
- package/lib/_utils/arrayUtil.d.ts +5 -0
- package/lib/_utils/arrayUtil.js +26 -0
- package/lib/_utils/devwarning.d.ts +1 -0
- package/lib/_utils/devwarning.js +21 -0
- package/lib/_utils/formatUtil.d.ts +46 -0
- package/lib/_utils/formatUtil.js +358 -0
- package/lib/_utils/hooks.d.ts +51 -0
- package/lib/_utils/hooks.js +187 -0
- package/lib/_utils/index.d.ts +8 -0
- package/lib/_utils/index.js +28 -0
- package/lib/_utils/numberUtil.d.ts +34 -0
- package/lib/_utils/numberUtil.js +202 -0
- package/lib/_utils/omit.d.ts +1 -0
- package/lib/_utils/omit.js +21 -0
- package/lib/_utils/react-children.d.ts +2 -0
- package/lib/_utils/react-children.js +20 -0
- package/lib/_utils/type.d.ts +12 -0
- package/lib/_utils/type.js +27 -0
- package/lib/_utils/usePopper.d.ts +29 -0
- package/lib/_utils/usePopper.js +574 -0
- package/lib/config-provider/ConfigContext.d.ts +22 -0
- package/lib/config-provider/ConfigContext.js +19 -0
- package/lib/config-provider/compDefaultProps.d.ts +8 -0
- package/lib/config-provider/compDefaultProps.js +17 -0
- package/lib/config-provider/configProvider.d.ts +11 -0
- package/lib/config-provider/configProvider.js +56 -0
- package/lib/config-provider/defaultConfig.d.ts +10 -0
- package/lib/config-provider/defaultConfig.js +30 -0
- package/lib/config-provider/index.d.ts +6 -0
- package/lib/config-provider/index.js +37 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.js +45 -0
- package/lib/locale/index.d.ts +3 -0
- package/lib/locale/index.js +25 -0
- package/lib/locale/locale.d.ts +50 -0
- package/lib/locale/locale.js +277 -0
- package/lib/locale/zh-CN.d.ts +8 -0
- package/lib/locale/zh-CN.js +15 -0
- package/lib/style/color/colors.less +2 -0
- package/lib/style/components.less +1 -0
- package/lib/style/core/index.less +2 -0
- package/lib/style/core/motion/other.less +28 -0
- package/lib/style/core/motion/slide.less +53 -0
- package/lib/style/core/motion.less +2 -0
- package/lib/style/core/reset.less +186 -0
- package/lib/style/css.js +3 -0
- package/lib/style/index.css +410 -0
- package/lib/style/index.d.ts +1 -0
- package/lib/style/index.js +3 -0
- package/lib/style/index.less +2 -0
- package/lib/style/mixins/index.less +19 -0
- package/lib/style/mixins/overlay.less +22 -0
- package/lib/style/mixins/reset.less +13 -0
- package/lib/style/themes/default.less +445 -0
- package/lib/style/themes/index.less +1 -0
- package/lib/table/base/calculations.d.ts +5 -0
- package/lib/table/base/calculations.js +385 -0
- package/lib/table/base/colgroup.d.ts +5 -0
- package/lib/table/base/colgroup.js +33 -0
- package/lib/table/base/empty.d.ts +9 -0
- package/lib/table/base/empty.js +54 -0
- package/lib/table/base/header.d.ts +5 -0
- package/lib/table/base/header.js +340 -0
- package/lib/table/base/helpers/SpanManager.d.ts +9 -0
- package/lib/table/base/helpers/SpanManager.js +59 -0
- package/lib/table/base/helpers/TableDOMUtils.d.ts +18 -0
- package/lib/table/base/helpers/TableDOMUtils.js +113 -0
- package/lib/table/base/helpers/__test__/SpanManager.test.d.ts +1 -0
- package/lib/table/base/helpers/__test__/SpanManager.test.js +23 -0
- package/lib/table/base/helpers/__test__/TableDOMUtils.test.d.ts +1 -0
- package/lib/table/base/helpers/__test__/TableDOMUtils.test.js +41 -0
- package/lib/table/base/helpers/__test__/rowHeightManager.test.d.ts +1 -0
- package/lib/table/base/helpers/__test__/rowHeightManager.test.js +33 -0
- package/lib/table/base/helpers/__test__/visible-part.test.d.ts +1 -0
- package/lib/table/base/helpers/__test__/visible-part.test.js +31 -0
- package/lib/table/base/helpers/rowHeightManager.d.ts +7 -0
- package/lib/table/base/helpers/rowHeightManager.js +170 -0
- package/lib/table/base/helpers/visible-part.d.ts +23 -0
- package/lib/table/base/helpers/visible-part.js +72 -0
- package/lib/table/base/html-table.d.ts +15 -0
- package/lib/table/base/html-table.js +149 -0
- package/lib/table/base/index.d.ts +3 -0
- package/lib/table/base/index.js +21 -0
- package/lib/table/base/interfaces.d.ts +54 -0
- package/lib/table/base/interfaces.js +0 -0
- package/lib/table/base/loading.d.ts +13 -0
- package/lib/table/base/loading.js +71 -0
- package/lib/table/base/styles.d.ts +132 -0
- package/lib/table/base/styles.js +136 -0
- package/lib/table/base/table.d.ts +150 -0
- package/lib/table/base/table.js +773 -0
- package/lib/table/base/utils.d.ts +36 -0
- package/lib/table/base/utils.js +234 -0
- package/lib/table/common-views.d.ts +24 -0
- package/lib/table/common-views.js +90 -0
- package/lib/table/index.d.ts +6 -0
- package/lib/table/index.js +85 -0
- package/lib/table/interfaces.d.ts +98 -0
- package/lib/table/interfaces.js +0 -0
- package/lib/table/internals.d.ts +14 -0
- package/lib/table/internals.js +64 -0
- package/lib/table/pipeline/features/__test__/multiSelect.test.d.ts +1 -0
- package/lib/table/pipeline/features/__test__/multiSelect.test.js +163 -0
- package/lib/table/pipeline/features/__test__/rowDetail.test.d.ts +1 -0
- package/lib/table/pipeline/features/__test__/rowDetail.test.js +230 -0
- package/lib/table/pipeline/features/__test__/rowGrouping.test.d.ts +1 -0
- package/lib/table/pipeline/features/__test__/rowGrouping.test.js +129 -0
- package/lib/table/pipeline/features/__test__/singleSelect.test.d.ts +1 -0
- package/lib/table/pipeline/features/__test__/singleSelect.test.js +201 -0
- package/lib/table/pipeline/features/__test__/sort.test.d.ts +1 -0
- package/lib/table/pipeline/features/__test__/sort.test.js +218 -0
- package/lib/table/pipeline/features/__test__/tips.test.d.ts +1 -0
- package/lib/table/pipeline/features/__test__/tips.test.js +133 -0
- package/lib/table/pipeline/features/__test__/treeMode.test.d.ts +1 -0
- package/lib/table/pipeline/features/__test__/treeMode.test.js +206 -0
- package/lib/table/pipeline/features/autoFill.d.ts +4 -0
- package/lib/table/pipeline/features/autoFill.js +80 -0
- package/lib/table/pipeline/features/autoRowSpan.d.ts +2 -0
- package/lib/table/pipeline/features/autoRowSpan.js +84 -0
- package/lib/table/pipeline/features/buildTree.d.ts +2 -0
- package/lib/table/pipeline/features/buildTree.js +16 -0
- package/lib/table/pipeline/features/columnDrag.d.ts +6 -0
- package/lib/table/pipeline/features/columnDrag.js +278 -0
- package/lib/table/pipeline/features/columnFilter.d.ts +20 -0
- package/lib/table/pipeline/features/columnFilter.js +197 -0
- package/lib/table/pipeline/features/columnHover.d.ts +12 -0
- package/lib/table/pipeline/features/columnHover.js +62 -0
- package/lib/table/pipeline/features/columnRangeHover.d.ts +15 -0
- package/lib/table/pipeline/features/columnRangeHover.js +95 -0
- package/lib/table/pipeline/features/columnResizeWidth.d.ts +21 -0
- package/lib/table/pipeline/features/columnResizeWidth.js +192 -0
- package/lib/table/pipeline/features/contextMenu.d.ts +14 -0
- package/lib/table/pipeline/features/contextMenu.js +397 -0
- package/lib/table/pipeline/features/filter/DefaultFilterContent.d.ts +4 -0
- package/lib/table/pipeline/features/filter/DefaultFilterContent.js +112 -0
- package/lib/table/pipeline/features/filter/Filter.d.ts +17 -0
- package/lib/table/pipeline/features/filter/Filter.js +129 -0
- package/lib/table/pipeline/features/filter/FilterPanel.d.ts +20 -0
- package/lib/table/pipeline/features/filter/FilterPanel.js +98 -0
- package/lib/table/pipeline/features/filter/__test__/Filter.test.d.ts +1 -0
- package/lib/table/pipeline/features/filter/__test__/Filter.test.js +36 -0
- package/lib/table/pipeline/features/filter/index.d.ts +4 -0
- package/lib/table/pipeline/features/filter/index.js +39 -0
- package/lib/table/pipeline/features/filter/util.d.ts +10 -0
- package/lib/table/pipeline/features/filter/util.js +77 -0
- package/lib/table/pipeline/features/index.d.ts +16 -0
- package/lib/table/pipeline/features/index.js +141 -0
- package/lib/table/pipeline/features/multiSelect.d.ts +27 -0
- package/lib/table/pipeline/features/multiSelect.js +227 -0
- package/lib/table/pipeline/features/rowDetail.d.ts +35 -0
- package/lib/table/pipeline/features/rowDetail.js +283 -0
- package/lib/table/pipeline/features/rowGrouping.d.ts +14 -0
- package/lib/table/pipeline/features/rowGrouping.js +227 -0
- package/lib/table/pipeline/features/singleSelect.d.ts +23 -0
- package/lib/table/pipeline/features/singleSelect.js +138 -0
- package/lib/table/pipeline/features/sort.d.ts +40 -0
- package/lib/table/pipeline/features/sort.js +361 -0
- package/lib/table/pipeline/features/tips.d.ts +2 -0
- package/lib/table/pipeline/features/tips.js +73 -0
- package/lib/table/pipeline/features/treeMode.d.ts +37 -0
- package/lib/table/pipeline/features/treeMode.js +266 -0
- package/lib/table/pipeline/features/treeSelect.d.ts +38 -0
- package/lib/table/pipeline/features/treeSelect.js +169 -0
- package/lib/table/pipeline/index.d.ts +3 -0
- package/lib/table/pipeline/index.js +26 -0
- package/lib/table/pipeline/pipeline.d.ts +85 -0
- package/lib/table/pipeline/pipeline.js +291 -0
- package/lib/table/pivot/cross-table/buildCrossTable.d.ts +14 -0
- package/lib/table/pivot/cross-table/buildCrossTable.js +313 -0
- package/lib/table/pivot/cross-table/constants.d.ts +1 -0
- package/lib/table/pivot/cross-table/constants.js +8 -0
- package/lib/table/pivot/cross-table/cross-table.d.ts +18 -0
- package/lib/table/pivot/cross-table/cross-table.js +71 -0
- package/lib/table/pivot/cross-table/index.d.ts +4 -0
- package/lib/table/pivot/cross-table/index.js +31 -0
- package/lib/table/pivot/cross-table/interfaces.d.ts +29 -0
- package/lib/table/pivot/cross-table/interfaces.js +0 -0
- package/lib/table/pivot/cross-table/internals.d.ts +13 -0
- package/lib/table/pivot/cross-table/internals.js +0 -0
- package/lib/table/pivot/cross-tree-table/buildCrossTreeTable.d.ts +14 -0
- package/lib/table/pivot/cross-tree-table/buildCrossTreeTable.js +240 -0
- package/lib/table/pivot/cross-tree-table/cross-tree-table.d.ts +38 -0
- package/lib/table/pivot/cross-tree-table/cross-tree-table.js +144 -0
- package/lib/table/pivot/cross-tree-table/index.d.ts +2 -0
- package/lib/table/pivot/cross-tree-table/index.js +23 -0
- package/lib/table/pivot/pivot-utils/buildDrillTree.d.ts +16 -0
- package/lib/table/pivot/pivot-utils/buildDrillTree.js +106 -0
- package/lib/table/pivot/pivot-utils/builders.d.ts +26 -0
- package/lib/table/pivot/pivot-utils/builders.js +272 -0
- package/lib/table/pivot/pivot-utils/convert-utils.d.ts +31 -0
- package/lib/table/pivot/pivot-utils/convert-utils.js +204 -0
- package/lib/table/pivot/pivot-utils/index.d.ts +5 -0
- package/lib/table/pivot/pivot-utils/index.js +59 -0
- package/lib/table/pivot/pivot-utils/interfaces.d.ts +12 -0
- package/lib/table/pivot/pivot-utils/interfaces.js +0 -0
- package/lib/table/pivot/pivot-utils/simpleEncode.d.ts +1 -0
- package/lib/table/pivot/pivot-utils/simpleEncode.js +14 -0
- package/lib/table/style/css.js +5 -0
- package/lib/table/style/index.css +0 -0
- package/lib/table/style/index.d.ts +2 -0
- package/lib/table/style/index.js +5 -0
- package/lib/table/style/index.less +1 -0
- package/lib/table/transforms/autoRowSpan.d.ts +3 -0
- package/lib/table/transforms/autoRowSpan.js +86 -0
- package/lib/table/transforms/autoWidth.d.ts +25 -0
- package/lib/table/transforms/autoWidth.js +187 -0
- package/lib/table/transforms/buildTree.d.ts +3 -0
- package/lib/table/transforms/buildTree.js +23 -0
- package/lib/table/transforms/columnHover.d.ts +17 -0
- package/lib/table/transforms/columnHover.js +74 -0
- package/lib/table/transforms/columnRangeHover.d.ts +17 -0
- package/lib/table/transforms/columnRangeHover.js +110 -0
- package/lib/table/transforms/columnResize.d.ts +27 -0
- package/lib/table/transforms/columnResize.js +176 -0
- package/lib/table/transforms/flatten.d.ts +3 -0
- package/lib/table/transforms/flatten.js +24 -0
- package/lib/table/transforms/index.d.ts +12 -0
- package/lib/table/transforms/index.js +131 -0
- package/lib/table/transforms/orderField.d.ts +3 -0
- package/lib/table/transforms/orderField.js +33 -0
- package/lib/table/transforms/sort.d.ts +43 -0
- package/lib/table/transforms/sort.js +369 -0
- package/lib/table/transforms/tips.d.ts +8 -0
- package/lib/table/transforms/tips.js +71 -0
- package/lib/table/transforms/treeMode.d.ts +30 -0
- package/lib/table/transforms/treeMode.js +286 -0
- package/lib/table/transforms/visible.d.ts +5 -0
- package/lib/table/transforms/visible.js +31 -0
- package/lib/table/transforms/warnTransformsDeprecated.d.ts +1 -0
- package/lib/table/transforms/warnTransformsDeprecated.js +19 -0
- package/lib/table/use/useResizeObserver.d.ts +2 -0
- package/lib/table/use/useResizeObserver.js +32 -0
- package/lib/table/utils/applyTransforms.d.ts +6 -0
- package/lib/table/utils/applyTransforms.js +24 -0
- package/lib/table/utils/buildTree.d.ts +36 -0
- package/lib/table/utils/buildTree.js +140 -0
- package/lib/table/utils/collectNodes.d.ts +8 -0
- package/lib/table/utils/collectNodes.js +72 -0
- package/lib/table/utils/console.d.ts +11 -0
- package/lib/table/utils/console.js +68 -0
- package/lib/table/utils/copyToClipboard.d.ts +3 -0
- package/lib/table/utils/copyToClipboard.js +40 -0
- package/lib/table/utils/element.d.ts +42 -0
- package/lib/table/utils/element.js +243 -0
- package/lib/table/utils/exportTableAsExcel.d.ts +4 -0
- package/lib/table/utils/exportTableAsExcel.js +205 -0
- package/lib/table/utils/getTreeDepth.d.ts +3 -0
- package/lib/table/utils/getTreeDepth.js +54 -0
- package/lib/table/utils/groupBy.d.ts +1 -0
- package/lib/table/utils/groupBy.js +48 -0
- package/lib/table/utils/index.d.ts +18 -0
- package/lib/table/utils/index.js +187 -0
- package/lib/table/utils/isGroupColumn.d.ts +2 -0
- package/lib/table/utils/isGroupColumn.js +17 -0
- package/lib/table/utils/isLeafNode.d.ts +2 -0
- package/lib/table/utils/isLeafNode.js +11 -0
- package/lib/table/utils/layeredFilter.d.ts +2 -0
- package/lib/table/utils/layeredFilter.js +38 -0
- package/lib/table/utils/layeredSort.d.ts +5 -0
- package/lib/table/utils/layeredSort.js +37 -0
- package/lib/table/utils/makeRecursiveMapper.d.ts +9 -0
- package/lib/table/utils/makeRecursiveMapper.js +94 -0
- package/lib/table/utils/mergeCellProps.d.ts +8 -0
- package/lib/table/utils/mergeCellProps.js +78 -0
- package/lib/table/utils/others.d.ts +16 -0
- package/lib/table/utils/others.js +108 -0
- package/lib/table/utils/proto.d.ts +21 -0
- package/lib/table/utils/proto.js +117 -0
- package/lib/table/utils/smartCompare.d.ts +9 -0
- package/lib/table/utils/smartCompare.js +58 -0
- package/lib/table/utils/traverseColumn.d.ts +11 -0
- package/lib/table/utils/traverseColumn.js +103 -0
- package/lib/table/utils/tree-data-helpers/StrictTreeDataHelper.d.ts +22 -0
- package/lib/table/utils/tree-data-helpers/StrictTreeDataHelper.js +154 -0
- package/lib/table/utils/tree-data-helpers/TreeDataHelper.d.ts +26 -0
- package/lib/table/utils/tree-data-helpers/TreeDataHelper.js +358 -0
- package/package.json +213 -0
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _find = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/find"));
|
|
6
|
+
|
|
7
|
+
var _treeMode = require("../treeMode");
|
|
8
|
+
|
|
9
|
+
var _pipeline = require("../../pipeline");
|
|
10
|
+
|
|
11
|
+
var _enzyme = require("enzyme");
|
|
12
|
+
|
|
13
|
+
var _reactHooks = require("@testing-library/react-hooks");
|
|
14
|
+
|
|
15
|
+
function makeChildren(prefix) {
|
|
16
|
+
return [{
|
|
17
|
+
id: "".concat(prefix, "-1"),
|
|
18
|
+
title: '二级标题',
|
|
19
|
+
dept: '应用部',
|
|
20
|
+
dest: '云南大理',
|
|
21
|
+
guide: 'Douglas Lee',
|
|
22
|
+
children: [{
|
|
23
|
+
id: "".concat(prefix, "-1-1"),
|
|
24
|
+
title: '三级标题',
|
|
25
|
+
dept: '平台大前端-UED',
|
|
26
|
+
dest: '云南大理',
|
|
27
|
+
guide: 'Douglas Lee'
|
|
28
|
+
}, {
|
|
29
|
+
id: "".concat(prefix, "-1-2"),
|
|
30
|
+
title: '三级标题',
|
|
31
|
+
dept: '平台大前端-前端',
|
|
32
|
+
dest: '云南大理',
|
|
33
|
+
guide: 'Douglas Lee'
|
|
34
|
+
}]
|
|
35
|
+
}, {
|
|
36
|
+
id: "".concat(prefix, "-2"),
|
|
37
|
+
title: '二级标题',
|
|
38
|
+
dept: '应用部',
|
|
39
|
+
dest: '云南大理',
|
|
40
|
+
guide: 'Douglas Lee',
|
|
41
|
+
children: [{
|
|
42
|
+
id: "".concat(prefix, "-2-1"),
|
|
43
|
+
title: '三级标题',
|
|
44
|
+
dept: '平台大前端-UED',
|
|
45
|
+
dest: '云南大理',
|
|
46
|
+
guide: 'Douglas Lee'
|
|
47
|
+
}, {
|
|
48
|
+
id: "".concat(prefix, "-2-2"),
|
|
49
|
+
title: '三级标题',
|
|
50
|
+
dept: '平台大前端-前端',
|
|
51
|
+
dest: '云南大理',
|
|
52
|
+
guide: 'Douglas Lee'
|
|
53
|
+
}]
|
|
54
|
+
}, {
|
|
55
|
+
id: "".concat(prefix, "-3"),
|
|
56
|
+
title: '二级标题',
|
|
57
|
+
dept: '应用部',
|
|
58
|
+
dest: '云南大理',
|
|
59
|
+
guide: 'Douglas Lee'
|
|
60
|
+
}];
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
var dataSource = [{
|
|
64
|
+
id: '1',
|
|
65
|
+
title: '一级标题',
|
|
66
|
+
dept: '云苍穹-前端',
|
|
67
|
+
dest: 'South Maddison',
|
|
68
|
+
guide: 'Don Moreno',
|
|
69
|
+
children: makeChildren('1')
|
|
70
|
+
}, {
|
|
71
|
+
id: '2',
|
|
72
|
+
title: '一级标题',
|
|
73
|
+
dept: '云苍穹-模型',
|
|
74
|
+
dest: 'Emilhaven',
|
|
75
|
+
guide: 'Douglas Richards',
|
|
76
|
+
children: makeChildren('2')
|
|
77
|
+
}, {
|
|
78
|
+
id: '3',
|
|
79
|
+
title: '一级标题',
|
|
80
|
+
dept: '云苍穹-基础',
|
|
81
|
+
dest: '云南大理',
|
|
82
|
+
guide: 'Douglas Lee',
|
|
83
|
+
children: makeChildren('3')
|
|
84
|
+
}, {
|
|
85
|
+
id: '4',
|
|
86
|
+
title: '一级标题',
|
|
87
|
+
dept: '云苍穹-体验',
|
|
88
|
+
dest: '杭州千岛湖',
|
|
89
|
+
guide: 'Eric Castillo',
|
|
90
|
+
children: makeChildren('4')
|
|
91
|
+
}, {
|
|
92
|
+
id: '5',
|
|
93
|
+
title: '一级标题',
|
|
94
|
+
dept: '云苍穹-运营',
|
|
95
|
+
dest: 'East Karl',
|
|
96
|
+
guide: 'Herbert Patton'
|
|
97
|
+
}];
|
|
98
|
+
var columns = [{
|
|
99
|
+
code: 'title',
|
|
100
|
+
name: '标题',
|
|
101
|
+
width: 200,
|
|
102
|
+
getCellProps: function getCellProps() {
|
|
103
|
+
return {
|
|
104
|
+
style: {
|
|
105
|
+
background: 'red'
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
}, {
|
|
110
|
+
code: 'dept',
|
|
111
|
+
name: '部门名称',
|
|
112
|
+
width: 180
|
|
113
|
+
}, {
|
|
114
|
+
code: 'dest',
|
|
115
|
+
name: '团建目的地',
|
|
116
|
+
width: 160
|
|
117
|
+
}, {
|
|
118
|
+
code: 'guide',
|
|
119
|
+
name: '当地导游',
|
|
120
|
+
width: 160
|
|
121
|
+
}];
|
|
122
|
+
describe('treeMode 单元测试', function () {
|
|
123
|
+
var opts = {
|
|
124
|
+
openKeys: ['4', '4-2'],
|
|
125
|
+
clickArea: 'content',
|
|
126
|
+
onChangeOpenKeys: jest.fn()
|
|
127
|
+
};
|
|
128
|
+
var newPipeline = null;
|
|
129
|
+
beforeEach(function () {
|
|
130
|
+
var _renderHook = (0, _reactHooks.renderHook)(function () {
|
|
131
|
+
return (0, _pipeline.useTablePipeline)({
|
|
132
|
+
primaryKey: 'id'
|
|
133
|
+
}).input({
|
|
134
|
+
dataSource: dataSource,
|
|
135
|
+
columns: columns
|
|
136
|
+
});
|
|
137
|
+
}),
|
|
138
|
+
result = _renderHook.result;
|
|
139
|
+
|
|
140
|
+
var tablePipeline = result.current;
|
|
141
|
+
newPipeline = (0, _treeMode.treeMode)(opts)(tablePipeline);
|
|
142
|
+
});
|
|
143
|
+
afterEach(function () {
|
|
144
|
+
newPipeline = null;
|
|
145
|
+
opts.onChangeOpenKeys.mockClear();
|
|
146
|
+
});
|
|
147
|
+
it('初始化展示', function () {
|
|
148
|
+
// 5 + 3 + 2
|
|
149
|
+
expect(newPipeline.getDataSource().length).toBe(10);
|
|
150
|
+
});
|
|
151
|
+
it('展开图标单元格渲染', function () {
|
|
152
|
+
var col = newPipeline.getColumns();
|
|
153
|
+
var wrapper = (0, _enzyme.mount)(col[0].render('一级标题', newPipeline.getDataSource()[0], 0));
|
|
154
|
+
expect((0, _find.default)(wrapper).call(wrapper, 'CaretRightIcon').length).toBe(1);
|
|
155
|
+
var div = (0, _find.default)(wrapper).call(wrapper, 'div').at(0);
|
|
156
|
+
div.simulate('click');
|
|
157
|
+
expect(opts.onChangeOpenKeys).toHaveBeenCalled();
|
|
158
|
+
expect(opts.onChangeOpenKeys).toBeCalledWith(['4', '4-2', '1'], '1', 'expand');
|
|
159
|
+
opts.onChangeOpenKeys.mockClear(); // 展开列点击
|
|
160
|
+
|
|
161
|
+
var expandColWrapper = (0, _enzyme.mount)(col[0].render('一级标题', newPipeline.getDataSource()[3], 3));
|
|
162
|
+
var div1 = (0, _find.default)(expandColWrapper).call(expandColWrapper, 'div').at(0);
|
|
163
|
+
div1.simulate('click');
|
|
164
|
+
expect(opts.onChangeOpenKeys).toBeCalledWith(['4-2'], '4', 'collapse'); // 叶子节点渲染
|
|
165
|
+
|
|
166
|
+
var leafWrapper = (0, _enzyme.mount)(col[0].render('一级标题', newPipeline.getDataSource()[9], 9));
|
|
167
|
+
expect((0, _find.default)(leafWrapper).call(leafWrapper, '.expansion-cell.leaf').length).toBe(2);
|
|
168
|
+
});
|
|
169
|
+
it('getCellProps', function () {
|
|
170
|
+
var col = newPipeline.getColumns(); // clickArea: 'content' 取默认的cellProps
|
|
171
|
+
|
|
172
|
+
expect(col[0].getCellProps()).toEqual({
|
|
173
|
+
style: {
|
|
174
|
+
background: 'red'
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
});
|
|
178
|
+
it('clickArea 为cell', function () {
|
|
179
|
+
var _renderHook2 = (0, _reactHooks.renderHook)(function () {
|
|
180
|
+
return (0, _pipeline.useTablePipeline)({
|
|
181
|
+
primaryKey: 'id'
|
|
182
|
+
}).input({
|
|
183
|
+
dataSource: dataSource,
|
|
184
|
+
columns: columns
|
|
185
|
+
});
|
|
186
|
+
}),
|
|
187
|
+
result = _renderHook2.result;
|
|
188
|
+
|
|
189
|
+
var tablePipeline = result.current;
|
|
190
|
+
opts.clickArea = 'cell';
|
|
191
|
+
var newPipeline = (0, _treeMode.treeMode)(opts)(tablePipeline);
|
|
192
|
+
var col = newPipeline.getColumns();
|
|
193
|
+
var cellProps = col[0].getCellProps('一级标题', newPipeline.getDataSource()[0], 0);
|
|
194
|
+
expect(cellProps.style).toEqual({
|
|
195
|
+
background: 'red',
|
|
196
|
+
cursor: 'pointer'
|
|
197
|
+
});
|
|
198
|
+
cellProps.onClick();
|
|
199
|
+
expect(opts.onChangeOpenKeys).toHaveBeenCalled(); // 叶子节点cellProps
|
|
200
|
+
|
|
201
|
+
var leafCellProps = col[0].getCellProps('一级标题', newPipeline.getDataSource()[9], 9);
|
|
202
|
+
expect(leafCellProps.style).toEqual({
|
|
203
|
+
background: 'red'
|
|
204
|
+
});
|
|
205
|
+
});
|
|
206
|
+
});
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.autoFillTableWidth = exports.tableWidthKey = exports.FILL_COLUMN_CODE = void 0;
|
|
9
|
+
|
|
10
|
+
var _find = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/find"));
|
|
11
|
+
|
|
12
|
+
var _slice = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/slice"));
|
|
13
|
+
|
|
14
|
+
var _splice = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/splice"));
|
|
15
|
+
|
|
16
|
+
var _calculations = require("../../base/calculations");
|
|
17
|
+
|
|
18
|
+
var _utils = require("../../utils");
|
|
19
|
+
|
|
20
|
+
var FILL_COLUMN_CODE = '$_fill_column_&';
|
|
21
|
+
exports.FILL_COLUMN_CODE = FILL_COLUMN_CODE;
|
|
22
|
+
var tableWidthKey = 'tableWidth';
|
|
23
|
+
exports.tableWidthKey = tableWidthKey;
|
|
24
|
+
var fillColumnWidthKey = 'fillColumnWidth';
|
|
25
|
+
|
|
26
|
+
var autoFillTableWidth = function autoFillTableWidth() {
|
|
27
|
+
return function (pipeline) {
|
|
28
|
+
var width = pipeline.getStateAtKey(fillColumnWidthKey, 0);
|
|
29
|
+
var columns = pipeline.getColumns();
|
|
30
|
+
var fillColumns = (0, _find.default)(columns).call(columns, function (col) {
|
|
31
|
+
return col.code === FILL_COLUMN_CODE;
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
if (fillColumns) {
|
|
35
|
+
fillColumns.width = width;
|
|
36
|
+
} else {
|
|
37
|
+
var rightNestedLockCount = (0, _calculations.getLeftNestedLockCount)((0, _slice.default)(columns).call(columns).reverse());
|
|
38
|
+
var spliceIndex = columns.length - rightNestedLockCount;
|
|
39
|
+
var _fillColumns = {
|
|
40
|
+
name: '',
|
|
41
|
+
code: FILL_COLUMN_CODE,
|
|
42
|
+
width: width,
|
|
43
|
+
features: {
|
|
44
|
+
resizeable: false
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
(0, _splice.default)(columns).call(columns, spliceIndex, 0, _fillColumns);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
pipeline.columns(columns);
|
|
51
|
+
setAutoFillWidth(pipeline);
|
|
52
|
+
return pipeline;
|
|
53
|
+
};
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
exports.autoFillTableWidth = autoFillTableWidth;
|
|
57
|
+
|
|
58
|
+
var setAutoFillWidth = function setAutoFillWidth(pipeline) {
|
|
59
|
+
var tableWidth = pipeline.getStateAtKey(tableWidthKey);
|
|
60
|
+
if (!tableWidth) return;
|
|
61
|
+
var columnWidthSum = 0;
|
|
62
|
+
pipeline.mapColumns((0, _utils.makeRecursiveMapper)(function (col) {
|
|
63
|
+
var width = col.width,
|
|
64
|
+
code = col.code;
|
|
65
|
+
|
|
66
|
+
if ((0, _utils.isLeafNode)(col) && code !== FILL_COLUMN_CODE) {
|
|
67
|
+
var resizeColumn = pipeline.getStateAtKey('columnResize');
|
|
68
|
+
columnWidthSum += resizeColumn && resizeColumn[code] || width;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
return col;
|
|
72
|
+
}));
|
|
73
|
+
var fillColumnWidth = Math.floor(tableWidth - columnWidthSum);
|
|
74
|
+
fillColumnWidth = fillColumnWidth > 0 ? fillColumnWidth : 0;
|
|
75
|
+
var preWidth = pipeline.getStateAtKey(fillColumnWidthKey, 0);
|
|
76
|
+
|
|
77
|
+
if (preWidth !== fillColumnWidth) {
|
|
78
|
+
pipeline.setStateAtKey('fillColumnWidth', fillColumnWidth);
|
|
79
|
+
}
|
|
80
|
+
};
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.autoRowSpan = autoRowSpan;
|
|
9
|
+
|
|
10
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
|
11
|
+
|
|
12
|
+
var _internals = require("../../internals");
|
|
13
|
+
|
|
14
|
+
var _utils = require("../../utils");
|
|
15
|
+
|
|
16
|
+
function isIdentity(x, y) {
|
|
17
|
+
return x === y;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
function autoRowSpan() {
|
|
21
|
+
return function autoRowSpanStep(pipeline) {
|
|
22
|
+
var dataSource = pipeline.getDataSource();
|
|
23
|
+
return pipeline.mapColumns((0, _utils.makeRecursiveMapper)(function (col, _ref) {
|
|
24
|
+
var startIndex = _ref.startIndex,
|
|
25
|
+
endIndex = _ref.endIndex;
|
|
26
|
+
|
|
27
|
+
var _a;
|
|
28
|
+
|
|
29
|
+
if (!((_a = col.features) === null || _a === void 0 ? void 0 : _a.autoRowSpan)) {
|
|
30
|
+
return col;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
if (!(0, _utils.isLeafNode)(col)) {
|
|
34
|
+
return col;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
var isFunc = typeof col.features.autoRowSpan === 'function';
|
|
38
|
+
var shouldMergeCell = isFunc ? col.features.autoRowSpan : isIdentity;
|
|
39
|
+
var spanRects = [];
|
|
40
|
+
var lastBottom = 0;
|
|
41
|
+
var prevValue = null;
|
|
42
|
+
var prevRow = null;
|
|
43
|
+
|
|
44
|
+
for (var rowIndex = 0; rowIndex < dataSource.length; rowIndex++) {
|
|
45
|
+
var row = dataSource[rowIndex];
|
|
46
|
+
|
|
47
|
+
var value = _internals.internals.safeGetValue(col, row, rowIndex);
|
|
48
|
+
|
|
49
|
+
if (rowIndex === 0 || !shouldMergeCell(prevValue, value, prevRow, row)) {
|
|
50
|
+
var spanRect = {
|
|
51
|
+
top: lastBottom,
|
|
52
|
+
bottom: rowIndex,
|
|
53
|
+
left: startIndex,
|
|
54
|
+
right: endIndex
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
for (var i = lastBottom; i < rowIndex; i++) {
|
|
58
|
+
spanRects.push(spanRect);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
lastBottom = rowIndex;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
prevValue = value;
|
|
65
|
+
prevRow = row;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
for (var _i = lastBottom; _i < dataSource.length; _i++) {
|
|
69
|
+
spanRects.push({
|
|
70
|
+
top: lastBottom,
|
|
71
|
+
bottom: dataSource.length,
|
|
72
|
+
left: startIndex,
|
|
73
|
+
right: endIndex
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
return (0, _extends2.default)((0, _extends2.default)({}, col), {
|
|
78
|
+
getSpanRect: function getSpanRect(value, row, rowIndex) {
|
|
79
|
+
return spanRects[rowIndex];
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
}));
|
|
83
|
+
};
|
|
84
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.buildTree = buildTree;
|
|
7
|
+
|
|
8
|
+
var _utils = require("../../utils");
|
|
9
|
+
|
|
10
|
+
function buildTree(idProp, parentIdProp) {
|
|
11
|
+
return function (pipeline) {
|
|
12
|
+
return pipeline.mapDataSource(function (rows) {
|
|
13
|
+
return (0, _utils.buildTree)(idProp, parentIdProp, rows);
|
|
14
|
+
});
|
|
15
|
+
};
|
|
16
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { TablePipeline } from '../pipeline';
|
|
2
|
+
import { ArtColumn } from '../../interfaces';
|
|
3
|
+
export interface ColumnDragOptions {
|
|
4
|
+
onColumnDragStopped?: (columnMoved: boolean, columns: ArtColumn[]) => void;
|
|
5
|
+
}
|
|
6
|
+
export declare function columnDrag(opts?: ColumnDragOptions): (pipeline: TablePipeline) => TablePipeline;
|
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.columnDrag = columnDrag;
|
|
9
|
+
|
|
10
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
|
|
11
|
+
|
|
12
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
|
13
|
+
|
|
14
|
+
var _filter = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/filter"));
|
|
15
|
+
|
|
16
|
+
var _utils = require("../../utils");
|
|
17
|
+
|
|
18
|
+
var _autoFill = require("./autoFill");
|
|
19
|
+
|
|
20
|
+
var stateKey = 'columnDrag';
|
|
21
|
+
|
|
22
|
+
function sortColumns(cloumns, sort) {
|
|
23
|
+
var res = new Array(cloumns.length);
|
|
24
|
+
|
|
25
|
+
while (cloumns.length) {
|
|
26
|
+
var cloumn = cloumns.pop();
|
|
27
|
+
res[sort[cloumn.code]] = cloumn;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
return res;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
function columnDrag() {
|
|
34
|
+
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
35
|
+
return function (pipeline) {
|
|
36
|
+
var _pipeline$getStateAtK = pipeline.getStateAtKey(stateKey, {}),
|
|
37
|
+
cloumnsSortData = _pipeline$getStateAtK.cloumnsSortData,
|
|
38
|
+
cloumnsTranslateData = _pipeline$getStateAtK.cloumnsTranslateData;
|
|
39
|
+
|
|
40
|
+
var columns = pipeline.getColumns();
|
|
41
|
+
|
|
42
|
+
if (cloumnsSortData) {
|
|
43
|
+
columns = sortColumns(columns, cloumnsSortData);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
pipeline.columns((0, _filter.default)(columns).call(columns, function (column) {
|
|
47
|
+
return column;
|
|
48
|
+
}));
|
|
49
|
+
return pipeline.mapColumns((0, _utils.makeRecursiveMapper)(function (col) {
|
|
50
|
+
var style = cloumnsTranslateData ? {
|
|
51
|
+
transition: '.3s',
|
|
52
|
+
transform: "translate3d(".concat(cloumnsTranslateData[col.code], "px, 0px, 0px)")
|
|
53
|
+
} : {};
|
|
54
|
+
var prevGetCellProps = col.getCellProps; // !col.code: 选择列 col.lock: 固定列 不允许拖拽
|
|
55
|
+
|
|
56
|
+
if (col.lock || !col.code) return col;
|
|
57
|
+
return (0, _extends2.default)((0, _extends2.default)({}, col), {
|
|
58
|
+
getCellProps: function getCellProps(value, record, rowIndex) {
|
|
59
|
+
var prevCellProps = prevGetCellProps === null || prevGetCellProps === void 0 ? void 0 : prevGetCellProps(value, record, rowIndex);
|
|
60
|
+
return (0, _utils.mergeCellProps)(prevCellProps, {
|
|
61
|
+
style: style
|
|
62
|
+
});
|
|
63
|
+
},
|
|
64
|
+
headerCellProps: (0, _utils.mergeCellProps)(col.headerCellProps, {
|
|
65
|
+
onMouseDown: function onMouseDown(e) {
|
|
66
|
+
if (e.button !== 0) {
|
|
67
|
+
return;
|
|
68
|
+
} // const cx = e.clientX
|
|
69
|
+
// const width = col.width
|
|
70
|
+
// const a = startIndex
|
|
71
|
+
// const b = endIndex
|
|
72
|
+
// const newColumnDragData = [...columnDragData]
|
|
73
|
+
// let newColumn = [...columns]
|
|
74
|
+
// let newStartIndex = startIndex
|
|
75
|
+
// let endIdx = endIndex
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
var columnMoved = false;
|
|
79
|
+
var columns = pipeline.getColumns();
|
|
80
|
+
|
|
81
|
+
var _pipeline$getStateAtK2 = pipeline.getStateAtKey(stateKey, {}),
|
|
82
|
+
cloumnsSortData = _pipeline$getStateAtK2.cloumnsSortData,
|
|
83
|
+
cloumnsTranslateData = _pipeline$getStateAtK2.cloumnsTranslateData;
|
|
84
|
+
|
|
85
|
+
if (cloumnsSortData) {
|
|
86
|
+
columns = sortColumns(columns, cloumnsSortData);
|
|
87
|
+
} else {
|
|
88
|
+
cloumnsSortData = {};
|
|
89
|
+
columns.forEach(function (item, index) {
|
|
90
|
+
cloumnsSortData[item.code] = index;
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
var currentTarget = e.currentTarget;
|
|
95
|
+
var rect = e.currentTarget.parentElement.getClientRects()[0];
|
|
96
|
+
var startX = rect.left;
|
|
97
|
+
var moveData = [];
|
|
98
|
+
|
|
99
|
+
function handleMouseMove(e) {
|
|
100
|
+
if (e.clientX - startX < 20) {
|
|
101
|
+
return;
|
|
102
|
+
} else {
|
|
103
|
+
e.stopPropagation();
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
document.body.style.userSelect = 'none';
|
|
107
|
+
currentTarget.style.cursor = 'move'; // 计算平移位置
|
|
108
|
+
|
|
109
|
+
var replaceIndex = 0;
|
|
110
|
+
var totalWitdth = columns[replaceIndex].width;
|
|
111
|
+
|
|
112
|
+
while (totalWitdth < e.clientX - startX && replaceIndex < columns.length - 1) {
|
|
113
|
+
replaceIndex++;
|
|
114
|
+
totalWitdth += columns[replaceIndex].width;
|
|
115
|
+
} // 重置位置信息
|
|
116
|
+
|
|
117
|
+
|
|
118
|
+
cloumnsTranslateData = {};
|
|
119
|
+
columns.forEach(function (item) {
|
|
120
|
+
cloumnsTranslateData[item.code] = 0;
|
|
121
|
+
}); // 循环计算每一个的位置
|
|
122
|
+
// if (startIndex !== replaceIndex) {
|
|
123
|
+
// const optionColumn = columns[startIndex]
|
|
124
|
+
// const move = startIndex > replaceIndex ? 1 : -1
|
|
125
|
+
// let index = Math.min(startIndex, replaceIndex)
|
|
126
|
+
// while (index < Math.max(startIndex, replaceIndex)) {
|
|
127
|
+
// const code = columns[index].code
|
|
128
|
+
// cloumnsTranslateData[code] += move * optionColumn.width
|
|
129
|
+
// cloumnsTranslateData[optionColumn.code] -= move * optionColumn.width
|
|
130
|
+
// index += move
|
|
131
|
+
// }
|
|
132
|
+
// }
|
|
133
|
+
// const opColumn = columns[startIndex]
|
|
134
|
+
// let index = Math.min(startIndex, replaceIndex)
|
|
135
|
+
// while (index <= Math.max(startIndex, replaceIndex)) {
|
|
136
|
+
// const code = columns[index].code
|
|
137
|
+
// if (index !== startIndex && index !== replaceIndex) {
|
|
138
|
+
// cloumnsTranslateData[code] += opColumn.width * (index > startIndex ? -1 : 1)
|
|
139
|
+
// cloumnsTranslateData[opColumn.code] += columns[index].width * (index < startIndex ? -1 : 1)
|
|
140
|
+
// }
|
|
141
|
+
// index++
|
|
142
|
+
// }
|
|
143
|
+
// 需要取最新startIndex, 不能直接用makeRecursiveMapper提供的startIndex(因为map时还没添加选择列、充满列等后面use添加的列)
|
|
144
|
+
|
|
145
|
+
var startIndex;
|
|
146
|
+
var leafColumns = (0, _utils.collectNodes)((0, _utils.collectNodes)(columns, 'leaf-only'));
|
|
147
|
+
leafColumns.forEach(function (column, index) {
|
|
148
|
+
if (column.code === col.code) {
|
|
149
|
+
startIndex = index;
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
var optionColumn = columns[startIndex];
|
|
153
|
+
var index = replaceIndex;
|
|
154
|
+
|
|
155
|
+
if (startIndex > replaceIndex) {
|
|
156
|
+
// 左移
|
|
157
|
+
while (index < startIndex) {
|
|
158
|
+
var code = columns[index].code;
|
|
159
|
+
|
|
160
|
+
if (code && code !== _autoFill.FILL_COLUMN_CODE && !columns[index].lock) {
|
|
161
|
+
cloumnsTranslateData[code] += optionColumn.width;
|
|
162
|
+
cloumnsTranslateData[optionColumn.code] -= columns[index].width;
|
|
163
|
+
columnMoved = true;
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
index++;
|
|
167
|
+
}
|
|
168
|
+
} else if (startIndex < replaceIndex) {
|
|
169
|
+
// 右移
|
|
170
|
+
while (startIndex < index) {
|
|
171
|
+
var _code = columns[index].code;
|
|
172
|
+
|
|
173
|
+
if (_code && _code !== _autoFill.FILL_COLUMN_CODE && !columns[index].lock) {
|
|
174
|
+
cloumnsTranslateData[_code] -= optionColumn.width;
|
|
175
|
+
cloumnsTranslateData[optionColumn.code] += columns[index].width;
|
|
176
|
+
columnMoved = true;
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
index--;
|
|
180
|
+
}
|
|
181
|
+
} else {// 不动或者移动回原位
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
window.requestAnimationFrame(function () {
|
|
185
|
+
pipeline.setStateAtKey(stateKey, {
|
|
186
|
+
cloumnsSortData: cloumnsSortData,
|
|
187
|
+
cloumnsTranslateData: cloumnsTranslateData
|
|
188
|
+
});
|
|
189
|
+
moveData = [startIndex, replaceIndex];
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
function handleMouseUp(e) {
|
|
194
|
+
e.stopPropagation();
|
|
195
|
+
document.body.removeEventListener('mousemove', handleMouseMove);
|
|
196
|
+
document.body.removeEventListener('mouseup', handleMouseUp);
|
|
197
|
+
window.requestAnimationFrame(function () {
|
|
198
|
+
var _moveData = moveData,
|
|
199
|
+
_moveData2 = (0, _slicedToArray2.default)(_moveData, 2),
|
|
200
|
+
startIndex = _moveData2[0],
|
|
201
|
+
replaceIndex = _moveData2[1];
|
|
202
|
+
|
|
203
|
+
var optionColumn = columns[startIndex]; // const move = startIndex > replaceIndex ? 1 : -1
|
|
204
|
+
// let index = Math.min(startIndex, replaceIndex)
|
|
205
|
+
// while (index < Math.max(startIndex, replaceIndex) && index > 0) {
|
|
206
|
+
// const code = columns[index].code
|
|
207
|
+
// cloumnsSortData[optionColumn.code] -= move
|
|
208
|
+
// cloumnsSortData[code] += move
|
|
209
|
+
// index += move
|
|
210
|
+
// }
|
|
211
|
+
|
|
212
|
+
var index = replaceIndex;
|
|
213
|
+
|
|
214
|
+
if (startIndex > replaceIndex) {
|
|
215
|
+
// 左移
|
|
216
|
+
while (index < startIndex) {
|
|
217
|
+
var code = columns[index].code;
|
|
218
|
+
|
|
219
|
+
if (code && code !== _autoFill.FILL_COLUMN_CODE && !columns[index].lock) {
|
|
220
|
+
cloumnsSortData[code] += 1;
|
|
221
|
+
cloumnsSortData[optionColumn.code] -= 1;
|
|
222
|
+
columnMoved = true;
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
index++;
|
|
226
|
+
}
|
|
227
|
+
} else if (startIndex < replaceIndex) {
|
|
228
|
+
// 右移
|
|
229
|
+
while (index > startIndex) {
|
|
230
|
+
var _code2 = columns[index].code;
|
|
231
|
+
|
|
232
|
+
if (_code2 && _code2 !== _autoFill.FILL_COLUMN_CODE && !columns[index].lock) {
|
|
233
|
+
cloumnsSortData[_code2] -= 1;
|
|
234
|
+
cloumnsSortData[optionColumn.code] += 1;
|
|
235
|
+
columnMoved = true;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
index--;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
var onColumnDragStopped = opts.onColumnDragStopped; // 拖拽结束返回列顺序
|
|
243
|
+
|
|
244
|
+
if (onColumnDragStopped) {
|
|
245
|
+
var _context;
|
|
246
|
+
|
|
247
|
+
var newColumns = (0, _filter.default)(_context = sortColumns(columns, cloumnsSortData)).call(_context, function (_ref) {
|
|
248
|
+
var code = _ref.code;
|
|
249
|
+
return code !== _autoFill.FILL_COLUMN_CODE;
|
|
250
|
+
}); // TODO drag需要在resize之后use,否则这里返回的列对应的宽度不是拖拽后的
|
|
251
|
+
|
|
252
|
+
onColumnDragStopped(columnMoved, newColumns);
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
pipeline.setStateAtKey(stateKey, {
|
|
256
|
+
cloumnsSortData: cloumnsSortData,
|
|
257
|
+
cloumnsTranslateData: null
|
|
258
|
+
});
|
|
259
|
+
});
|
|
260
|
+
document.body.style.userSelect = '';
|
|
261
|
+
currentTarget.style.opacity = '';
|
|
262
|
+
currentTarget.style.cursor = '';
|
|
263
|
+
currentTarget = null;
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
document.body.addEventListener('mousemove', handleMouseMove);
|
|
267
|
+
document.body.addEventListener('mouseup', handleMouseUp);
|
|
268
|
+
|
|
269
|
+
document.body.onselectstart = function () {
|
|
270
|
+
return false;
|
|
271
|
+
};
|
|
272
|
+
},
|
|
273
|
+
style: style
|
|
274
|
+
})
|
|
275
|
+
});
|
|
276
|
+
}));
|
|
277
|
+
};
|
|
278
|
+
}
|