@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,20 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { Filters, FilterItem } from '../../interfaces';
|
|
3
|
+
import { TablePipeline } from '../pipeline';
|
|
4
|
+
export interface FilterFeatureOptions {
|
|
5
|
+
/** (非受控用法) 默认的过滤字段列表 */
|
|
6
|
+
defaultFilters?: Filters;
|
|
7
|
+
/** (受控用法) 过滤字段列表 */
|
|
8
|
+
filters?: Filters;
|
|
9
|
+
/** 更新过滤字段列表的回调函数 */
|
|
10
|
+
onChangeFilters?(nextFilters: Filters, currentFilter: FilterItem): void;
|
|
11
|
+
/** 是否保持 dataSource 不变 */
|
|
12
|
+
keepDataSource?: boolean;
|
|
13
|
+
/** 过滤模式。单列过滤 single,多列过滤 multiple,默认为多选 */
|
|
14
|
+
mode?: 'single' | 'multiple';
|
|
15
|
+
/**过滤图标 */
|
|
16
|
+
filterIcon?: ReactNode;
|
|
17
|
+
/** 是否对触发弹出过滤面板 的 click 事件调用 event.stopPropagation() */
|
|
18
|
+
stopClickEventPropagation?: boolean;
|
|
19
|
+
}
|
|
20
|
+
export declare function filter(opts?: FilterFeatureOptions): (pipeline: TablePipeline) => TablePipeline;
|
|
@@ -0,0 +1,197 @@
|
|
|
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.filter = filter;
|
|
9
|
+
|
|
10
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
|
|
11
|
+
|
|
12
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/toConsumableArray"));
|
|
13
|
+
|
|
14
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
|
15
|
+
|
|
16
|
+
var _slice = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/slice"));
|
|
17
|
+
|
|
18
|
+
var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/map"));
|
|
19
|
+
|
|
20
|
+
var _map2 = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
|
|
21
|
+
|
|
22
|
+
var _filter = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/filter"));
|
|
23
|
+
|
|
24
|
+
var _from = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/array/from"));
|
|
25
|
+
|
|
26
|
+
var _values = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/values"));
|
|
27
|
+
|
|
28
|
+
var _concat = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat"));
|
|
29
|
+
|
|
30
|
+
var _reduce = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/reduce"));
|
|
31
|
+
|
|
32
|
+
var _react = _interopRequireDefault(require("react"));
|
|
33
|
+
|
|
34
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
35
|
+
|
|
36
|
+
var _internals = require("../../internals");
|
|
37
|
+
|
|
38
|
+
var _utils = require("../../utils");
|
|
39
|
+
|
|
40
|
+
var _filter2 = require("./filter");
|
|
41
|
+
|
|
42
|
+
var _styles = require("../../base/styles");
|
|
43
|
+
|
|
44
|
+
var stateKey = 'filter';
|
|
45
|
+
|
|
46
|
+
function filter() {
|
|
47
|
+
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
48
|
+
return function step(pipeline) {
|
|
49
|
+
var _a, _b;
|
|
50
|
+
|
|
51
|
+
var dataSource = pipeline.getDataSource();
|
|
52
|
+
var columns = pipeline.getColumns();
|
|
53
|
+
var filters = opts.filters,
|
|
54
|
+
defaultFilters = opts.defaultFilters,
|
|
55
|
+
onChangeFilters = opts.onChangeFilters,
|
|
56
|
+
keepDataSource = opts.keepDataSource,
|
|
57
|
+
mode = opts.mode,
|
|
58
|
+
filterIcon = opts.filterIcon,
|
|
59
|
+
stopClickEventPropagation = opts.stopClickEventPropagation;
|
|
60
|
+
var inputFilters = (_b = (_a = filters !== null && filters !== void 0 ? filters : pipeline.getStateAtKey(stateKey)) !== null && _a !== void 0 ? _a : defaultFilters) !== null && _b !== void 0 ? _b : [];
|
|
61
|
+
inputFilters = mode === 'single' ? (0, _slice.default)(inputFilters).call(inputFilters, 0, 1) : inputFilters;
|
|
62
|
+
var inputFiltersMap = new _map.default((0, _map2.default)(inputFilters).call(inputFilters, function (filterItem) {
|
|
63
|
+
return [filterItem.code, (0, _extends2.default)({}, filterItem)];
|
|
64
|
+
}));
|
|
65
|
+
|
|
66
|
+
function processColumns(columns) {
|
|
67
|
+
return (0, _map2.default)(columns).call(columns, dfs);
|
|
68
|
+
|
|
69
|
+
function dfs(col) {
|
|
70
|
+
var _a, _b, _c, _d, _e;
|
|
71
|
+
|
|
72
|
+
var result = (0, _extends2.default)({}, col);
|
|
73
|
+
var filterable = col.code && ((_a = col.features) === null || _a === void 0 ? void 0 : _a.filterable);
|
|
74
|
+
var filterActive = filterable && ((_c = (_b = inputFiltersMap === null || inputFiltersMap === void 0 ? void 0 : inputFiltersMap.get(col.code)) === null || _b === void 0 ? void 0 : (0, _filter.default)(_b)) === null || _c === void 0 ? void 0 : _c.length) > 0;
|
|
75
|
+
|
|
76
|
+
if (filterable) {
|
|
77
|
+
var _context, _context2, _cx;
|
|
78
|
+
|
|
79
|
+
var handleFilterChanged = function handleFilterChanged(filterItem) {
|
|
80
|
+
var nextFiltersMap = new _map.default(inputFiltersMap);
|
|
81
|
+
var currentFilter = (0, _extends2.default)({
|
|
82
|
+
code: col.code
|
|
83
|
+
}, filterItem);
|
|
84
|
+
|
|
85
|
+
if (filterItem == null) {
|
|
86
|
+
nextFiltersMap.delete(col.code);
|
|
87
|
+
} else {
|
|
88
|
+
if (mode === 'single') {
|
|
89
|
+
nextFiltersMap.clear();
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
nextFiltersMap.set(col.code, currentFilter);
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
var nextFilters = (0, _from.default)((0, _values.default)(nextFiltersMap).call(nextFiltersMap));
|
|
96
|
+
onChangeFilters === null || onChangeFilters === void 0 ? void 0 : onChangeFilters(nextFilters, currentFilter);
|
|
97
|
+
pipeline.setStateAtKey(stateKey, nextFilters);
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
var setFilter = function setFilter(filter, filterCondition) {
|
|
101
|
+
handleFilterChanged(!filter ? undefined : {
|
|
102
|
+
code: col.code,
|
|
103
|
+
filter: filter,
|
|
104
|
+
filterCondition: filterCondition
|
|
105
|
+
});
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
var filterPanel = (_d = col.features) === null || _d === void 0 ? void 0 : _d.filterPanel;
|
|
109
|
+
result.title = (0, _concat.default)(_context = []).call(_context, (0, _toConsumableArray2.default)((0, _concat.default)(_context2 = []).call(_context2, (_e = result.title) !== null && _e !== void 0 ? _e : [_internals.internals.safeRenderHeader((0, _extends2.default)((0, _extends2.default)({}, col), {
|
|
110
|
+
title: null
|
|
111
|
+
}))])), [/*#__PURE__*/_react.default.createElement(_filter2.Filter, {
|
|
112
|
+
key: "filter",
|
|
113
|
+
FilterPanelContent: filterPanel,
|
|
114
|
+
filterIcon: filterIcon,
|
|
115
|
+
filterModel: inputFiltersMap.get(col.code),
|
|
116
|
+
setFilterModel: handleFilterChanged,
|
|
117
|
+
setFilter: setFilter,
|
|
118
|
+
isFilterActive: filterActive,
|
|
119
|
+
className: (0, _classnames.default)((_cx = {}, (0, _defineProperty2.default)(_cx, _styles.Classes.tableFilterTrigger, true), (0, _defineProperty2.default)(_cx, "active", filterActive), _cx)),
|
|
120
|
+
stopClickEventPropagation: stopClickEventPropagation
|
|
121
|
+
})]);
|
|
122
|
+
result.headerCellProps = (0, _utils.mergeCellProps)(col.headerCellProps, {
|
|
123
|
+
style: {
|
|
124
|
+
paddingRight: '18px'
|
|
125
|
+
}
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
if (!(0, _utils.isLeafNode)(col)) {
|
|
130
|
+
var _context3;
|
|
131
|
+
|
|
132
|
+
result.children = (0, _map2.default)(_context3 = col.children).call(_context3, dfs);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
return result;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
function processDataSource(dataSource) {
|
|
140
|
+
var _context4, _context5;
|
|
141
|
+
|
|
142
|
+
var filtersKeys = [];
|
|
143
|
+
inputFiltersMap.forEach(function (value, key) {
|
|
144
|
+
filtersKeys.push(key);
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
if (keepDataSource || filtersKeys.length <= 0) {
|
|
148
|
+
return dataSource;
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
var columns = pipeline.getColumns();
|
|
152
|
+
var columnsMap = new _map.default((0, _map2.default)(_context4 = (0, _filter.default)(_context5 = (0, _utils.collectNodes)(columns, 'leaf-only')).call(_context5, function (col) {
|
|
153
|
+
var _a, _b;
|
|
154
|
+
|
|
155
|
+
return ((_a = col.features) === null || _a === void 0 ? void 0 : _a.filterable) !== false && ((_b = col.features) === null || _b === void 0 ? void 0 : _b.filterable) != null;
|
|
156
|
+
})).call(_context4, function (col) {
|
|
157
|
+
return [col.code, col];
|
|
158
|
+
}));
|
|
159
|
+
var defaultFilterOptionsMap = new _map.default((0, _map2.default)(_filter2.DEFAULT_FILTER_OPTIONS).call(_filter2.DEFAULT_FILTER_OPTIONS, function (item) {
|
|
160
|
+
return [item.key, (0, _extends2.default)({}, item)];
|
|
161
|
+
}));
|
|
162
|
+
|
|
163
|
+
function isMatchedFilterCondition(record) {
|
|
164
|
+
return !filtersKeys.some(function (key) {
|
|
165
|
+
var _a, _b;
|
|
166
|
+
|
|
167
|
+
var filterItem = inputFiltersMap.get(key);
|
|
168
|
+
var filterable = (_b = (_a = columnsMap.get(key)) === null || _a === void 0 ? void 0 : _a.features) === null || _b === void 0 ? void 0 : _b.filterable;
|
|
169
|
+
var comparisonFn;
|
|
170
|
+
|
|
171
|
+
if (typeof filterable === 'function') {
|
|
172
|
+
comparisonFn = filterable;
|
|
173
|
+
} else if (defaultFilterOptionsMap.get(filterItem.filterCondition)) {
|
|
174
|
+
comparisonFn = (0, _filter.default)(defaultFilterOptionsMap.get(filterItem.filterCondition));
|
|
175
|
+
} else {
|
|
176
|
+
console.warn("\u5217[".concat(key, "]\u672A\u914D\u7F6E\u7B5B\u9009\u51FD\u6570\uFF0C\u8BF7\u8BBE\u7F6E column.features.filterable \u6765\u4F5C\u4E3A\u8BE5\u5217\u7684\u7B5B\u9009\u51FD\u6570, \u76EE\u524D\u4F7F\u7528\u9ED8\u8BA4\u5305\u542B\u7B5B\u9009\u51FD\u6570"));
|
|
177
|
+
comparisonFn = (0, _filter.default)(defaultFilterOptionsMap.get('contain'));
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
return !comparisonFn((0, _filter.default)(filterItem))(record[key]); //不符合过滤条件,退出循环
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
return (0, _reduce.default)(dataSource).call(dataSource, function (pre, record) {
|
|
185
|
+
if (isMatchedFilterCondition(record)) {
|
|
186
|
+
return (0, _concat.default)(pre).call(pre, [record]);
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
return pre;
|
|
190
|
+
}, []);
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
pipeline.dataSource(processDataSource(dataSource));
|
|
194
|
+
pipeline.columns(processColumns(columns));
|
|
195
|
+
return pipeline;
|
|
196
|
+
};
|
|
197
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { TablePipeline } from '../pipeline';
|
|
2
|
+
export interface ColumnHoverFeatureOptions {
|
|
3
|
+
/** 鼠标悬停的颜色,默认为 'var(--hover-bgcolor)' */
|
|
4
|
+
hoverColor?: string;
|
|
5
|
+
/** 非受控用法:默认的 colIndex */
|
|
6
|
+
defaultHoverColIndex?: number;
|
|
7
|
+
/** 受控用法:当前鼠标悬停列的下标(colIndex) */
|
|
8
|
+
hoverColIndex?: number;
|
|
9
|
+
/** 受控用法:colIndex 改变的回调 */
|
|
10
|
+
onChangeHoverColIndex?(nextColIndex: number): void;
|
|
11
|
+
}
|
|
12
|
+
export declare function columnHover(opts?: ColumnHoverFeatureOptions): (pipeline: TablePipeline) => TablePipeline;
|
|
@@ -0,0 +1,62 @@
|
|
|
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.columnHover = columnHover;
|
|
9
|
+
|
|
10
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
|
11
|
+
|
|
12
|
+
var _utils = require("../../utils");
|
|
13
|
+
|
|
14
|
+
function columnHover() {
|
|
15
|
+
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
16
|
+
var stateKey = 'columnHover';
|
|
17
|
+
return function (pipeline) {
|
|
18
|
+
var _a, _b, _c, _d;
|
|
19
|
+
|
|
20
|
+
var hoverColor = (_a = opts.hoverColor) !== null && _a !== void 0 ? _a : 'var(--hover-bgcolor)';
|
|
21
|
+
var hoverColIndex = (_d = (_c = (_b = opts.hoverColIndex) !== null && _b !== void 0 ? _b : pipeline.getStateAtKey(stateKey)) !== null && _c !== void 0 ? _c : opts.defaultHoverColIndex) !== null && _d !== void 0 ? _d : -1;
|
|
22
|
+
|
|
23
|
+
var onChangeHoverColIndex = function onChangeHoverColIndex(nextColIndex) {
|
|
24
|
+
var _a;
|
|
25
|
+
|
|
26
|
+
pipeline.setStateAtKey(stateKey, nextColIndex);
|
|
27
|
+
(_a = opts.onChangeHoverColIndex) === null || _a === void 0 ? void 0 : _a.call(opts, nextColIndex);
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
return pipeline.mapColumns((0, _utils.makeRecursiveMapper)(function (col, _ref) {
|
|
31
|
+
var startIndex = _ref.startIndex,
|
|
32
|
+
endIndex = _ref.endIndex;
|
|
33
|
+
var range = {
|
|
34
|
+
start: startIndex,
|
|
35
|
+
end: endIndex
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
if (!(0, _utils.isLeafNode)(col)) {
|
|
39
|
+
return col;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
var colIndexMatched = range.start <= hoverColIndex && hoverColIndex < range.end;
|
|
43
|
+
var prevGetCellProps = col.getCellProps;
|
|
44
|
+
return (0, _extends2.default)((0, _extends2.default)({}, col), {
|
|
45
|
+
getCellProps: function getCellProps(value, record, rowIndex) {
|
|
46
|
+
var prevCellProps = prevGetCellProps === null || prevGetCellProps === void 0 ? void 0 : prevGetCellProps(value, record, rowIndex);
|
|
47
|
+
return (0, _utils.mergeCellProps)(prevCellProps, {
|
|
48
|
+
style: {
|
|
49
|
+
'--bgcolor': colIndexMatched ? hoverColor : undefined
|
|
50
|
+
},
|
|
51
|
+
onMouseEnter: function onMouseEnter() {
|
|
52
|
+
onChangeHoverColIndex(range.start);
|
|
53
|
+
},
|
|
54
|
+
onMouseLeave: function onMouseLeave() {
|
|
55
|
+
onChangeHoverColIndex(-1);
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
}));
|
|
61
|
+
};
|
|
62
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { HoverRange } from '../../interfaces';
|
|
2
|
+
import { TablePipeline } from '../pipeline';
|
|
3
|
+
export interface ColumnRangeHoverFeatureOptions {
|
|
4
|
+
/** 鼠标悬停时单元格的背景色,默认为 'var(--hover-bgcolor)' */
|
|
5
|
+
hoverColor?: string;
|
|
6
|
+
/** 鼠标悬停时表头的背景色,默认为 'var(--header-hover-bgcolor)' */
|
|
7
|
+
headerHoverColor?: string;
|
|
8
|
+
/** 非受控用法:默认的悬停范围 */
|
|
9
|
+
defaultHoverRange?: HoverRange;
|
|
10
|
+
/** 受控用法:当前悬停范围 */
|
|
11
|
+
hoverRange?: HoverRange;
|
|
12
|
+
/** 受控用法:悬停渲染改变的回调 */
|
|
13
|
+
onChangeHoverRange?(nextColIndexRange: HoverRange): void;
|
|
14
|
+
}
|
|
15
|
+
export declare function columnRangeHover(opts?: ColumnRangeHoverFeatureOptions): (pipeline: TablePipeline) => TablePipeline;
|
|
@@ -0,0 +1,95 @@
|
|
|
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.columnRangeHover = columnRangeHover;
|
|
9
|
+
|
|
10
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
|
11
|
+
|
|
12
|
+
var _utils = require("../../utils");
|
|
13
|
+
|
|
14
|
+
var EMPTY_RANGE = {
|
|
15
|
+
start: -1,
|
|
16
|
+
end: -1
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
function columnRangeHover() {
|
|
20
|
+
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
21
|
+
var stateKey = 'columnHover';
|
|
22
|
+
return function columnRangeHoverStep(pipeline) {
|
|
23
|
+
var _a, _b, _c, _d, _e;
|
|
24
|
+
|
|
25
|
+
var hoverRange = (_c = (_b = (_a = opts.hoverRange) !== null && _a !== void 0 ? _a : pipeline.getStateAtKey(stateKey)) !== null && _b !== void 0 ? _b : opts.defaultHoverRange) !== null && _c !== void 0 ? _c : EMPTY_RANGE;
|
|
26
|
+
var hoverColor = (_d = opts.hoverColor) !== null && _d !== void 0 ? _d : 'var(--hover-bgcolor)';
|
|
27
|
+
var headerHoverColor = (_e = opts.headerHoverColor) !== null && _e !== void 0 ? _e : 'var(--header-hover-bgcolor)';
|
|
28
|
+
|
|
29
|
+
var onChangeHoverRange = function onChangeHoverRange(nextColIndexRange) {
|
|
30
|
+
var _a;
|
|
31
|
+
|
|
32
|
+
pipeline.setStateAtKey(stateKey, nextColIndexRange);
|
|
33
|
+
(_a = opts.onChangeHoverRange) === null || _a === void 0 ? void 0 : _a.call(opts, nextColIndexRange);
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
return pipeline.mapColumns((0, _utils.makeRecursiveMapper)(function (col, _ref) {
|
|
37
|
+
var startIndex = _ref.startIndex,
|
|
38
|
+
endIndex = _ref.endIndex;
|
|
39
|
+
var colRange = {
|
|
40
|
+
start: startIndex,
|
|
41
|
+
end: endIndex
|
|
42
|
+
};
|
|
43
|
+
var match = colRange.end > hoverRange.start && hoverRange.end > colRange.start;
|
|
44
|
+
|
|
45
|
+
if (!(0, _utils.isLeafNode)(col)) {
|
|
46
|
+
if (headerHoverColor == null) {
|
|
47
|
+
return col;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
return (0, _extends2.default)((0, _extends2.default)({}, col), {
|
|
51
|
+
headerCellProps: (0, _utils.mergeCellProps)(col.headerCellProps, {
|
|
52
|
+
onMouseEnter: function onMouseEnter() {
|
|
53
|
+
onChangeHoverRange(colRange);
|
|
54
|
+
},
|
|
55
|
+
onMouseLeave: function onMouseLeave() {
|
|
56
|
+
onChangeHoverRange(EMPTY_RANGE);
|
|
57
|
+
},
|
|
58
|
+
style: {
|
|
59
|
+
'--header-bgcolor': match ? headerHoverColor : undefined
|
|
60
|
+
}
|
|
61
|
+
})
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
var prevGetCellProps = col.getCellProps;
|
|
66
|
+
return (0, _extends2.default)((0, _extends2.default)({}, col), {
|
|
67
|
+
headerCellProps: (0, _utils.mergeCellProps)(col.headerCellProps, {
|
|
68
|
+
onMouseEnter: function onMouseEnter() {
|
|
69
|
+
onChangeHoverRange(colRange);
|
|
70
|
+
},
|
|
71
|
+
onMouseLeave: function onMouseLeave() {
|
|
72
|
+
onChangeHoverRange(EMPTY_RANGE);
|
|
73
|
+
},
|
|
74
|
+
style: {
|
|
75
|
+
'--header-bgcolor': match ? headerHoverColor : undefined
|
|
76
|
+
}
|
|
77
|
+
}),
|
|
78
|
+
getCellProps: function getCellProps(value, record, rowIndex) {
|
|
79
|
+
var prevCellProps = prevGetCellProps === null || prevGetCellProps === void 0 ? void 0 : prevGetCellProps(value, record, rowIndex);
|
|
80
|
+
return (0, _utils.mergeCellProps)(prevCellProps, {
|
|
81
|
+
onMouseEnter: function onMouseEnter() {
|
|
82
|
+
onChangeHoverRange(colRange);
|
|
83
|
+
},
|
|
84
|
+
onMouseLeave: function onMouseLeave() {
|
|
85
|
+
onChangeHoverRange(EMPTY_RANGE);
|
|
86
|
+
},
|
|
87
|
+
style: {
|
|
88
|
+
'--bgcolor': match ? hoverColor : undefined
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
}));
|
|
94
|
+
};
|
|
95
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { TablePipeline } from '../pipeline';
|
|
2
|
+
interface ColumnSize {
|
|
3
|
+
[key: string]: number;
|
|
4
|
+
}
|
|
5
|
+
interface ChangedColumnSize {
|
|
6
|
+
code: string;
|
|
7
|
+
width: number;
|
|
8
|
+
}
|
|
9
|
+
export interface ColumnResizeOptions {
|
|
10
|
+
columnSize?: ColumnSize;
|
|
11
|
+
/** 列的最小宽度,默认为 60 */
|
|
12
|
+
minSize?: number;
|
|
13
|
+
/** 如果列宽数组中没有提供有效的宽度,fallbackSize 将作为该列的宽度,默认为 150 */
|
|
14
|
+
fallbackSize?: number;
|
|
15
|
+
/** 列的最大宽度,默认为 1000 */
|
|
16
|
+
maxSize?: number;
|
|
17
|
+
onChangeSize?(nextSize: ColumnSize): void;
|
|
18
|
+
afterChangeSize?(nextSize: ColumnSize, changedColumnSize: ChangedColumnSize[]): void;
|
|
19
|
+
}
|
|
20
|
+
export declare function columnResize(opts?: ColumnResizeOptions): (pipeline: TablePipeline) => TablePipeline;
|
|
21
|
+
export {};
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _interopRequireWildcard = require("@babel/runtime-corejs3/helpers/interopRequireWildcard");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.columnResize = columnResize;
|
|
11
|
+
|
|
12
|
+
var _reduce = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/reduce"));
|
|
13
|
+
|
|
14
|
+
var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
|
|
15
|
+
|
|
16
|
+
var _keys = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/keys"));
|
|
17
|
+
|
|
18
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
|
19
|
+
|
|
20
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/taggedTemplateLiteral"));
|
|
21
|
+
|
|
22
|
+
var _react = _interopRequireDefault(require("react"));
|
|
23
|
+
|
|
24
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
25
|
+
|
|
26
|
+
var _rxjs = require("rxjs");
|
|
27
|
+
|
|
28
|
+
var op = _interopRequireWildcard(require("rxjs/operators"));
|
|
29
|
+
|
|
30
|
+
var _utils = require("../../utils");
|
|
31
|
+
|
|
32
|
+
var _internals = require("../../internals");
|
|
33
|
+
|
|
34
|
+
var _styles = require("../../base/styles");
|
|
35
|
+
|
|
36
|
+
var _templateObject, _templateObject2;
|
|
37
|
+
|
|
38
|
+
var TableHeaderCellResize = _styledComponents.default.div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n position: absolute;\n top: 0;\n right: -5px;\n height: 100%;\n width: 10px;\n cursor: ew-resize;\n display: flex;\n flex-direction: column;\n align-items: center;\n z-index:1;\n\n &:after {\n content: \"\";\n position: absolute;\n display: block;\n left: calc(50% - 1px);\n width: 1px;\n height: calc(100% - 14px);\n top: 7px;\n background-color: var(--border-color);\n }\n"])));
|
|
39
|
+
|
|
40
|
+
var TableHeaderGroupCellResize = (0, _styledComponents.default)(TableHeaderCellResize)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2.default)(["\n &:after {\n height: 100%;\n top: 0;\n }\n"])));
|
|
41
|
+
|
|
42
|
+
function clamp(min, x, max) {
|
|
43
|
+
return Math.max(min, Math.min(max, x));
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function disableSelect(event) {
|
|
47
|
+
event.preventDefault();
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
function columnResize() {
|
|
51
|
+
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
52
|
+
|
|
53
|
+
var _a, _b, _c;
|
|
54
|
+
|
|
55
|
+
var stateKey = 'columnResize';
|
|
56
|
+
var minSize = (_a = opts.minSize) !== null && _a !== void 0 ? _a : 60;
|
|
57
|
+
var fallbackSize = (_b = opts.fallbackSize) !== null && _b !== void 0 ? _b : 150;
|
|
58
|
+
var maxSize = (_c = opts.maxSize) !== null && _c !== void 0 ? _c : 1000;
|
|
59
|
+
return function columnResizeFeature(pipeline) {
|
|
60
|
+
var _a, _b, _c;
|
|
61
|
+
|
|
62
|
+
var columnSize = (_b = (_a = opts.columnSize) !== null && _a !== void 0 ? _a : pipeline.getStateAtKey(stateKey)) !== null && _b !== void 0 ? _b : {};
|
|
63
|
+
var leafColumns = (0, _utils.collectNodes)(pipeline.getColumns(), 'leaf-only');
|
|
64
|
+
leafColumns.forEach(function (_ref) {
|
|
65
|
+
var code = _ref.code,
|
|
66
|
+
width = _ref.width;
|
|
67
|
+
|
|
68
|
+
if (columnSize[code] === undefined) {
|
|
69
|
+
if (typeof width === 'number') {
|
|
70
|
+
columnSize[code] = width;
|
|
71
|
+
} else {
|
|
72
|
+
columnSize[code] = fallbackSize;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}); // 初始化 || opts.columnSize发生变化(为了autofill时能取到最新值)
|
|
76
|
+
|
|
77
|
+
if (!pipeline.getStateAtKey(stateKey) || ((_c = pipeline.ref) === null || _c === void 0 ? void 0 : _c.current.lastOptColumnSize) !== opts.columnSize) {
|
|
78
|
+
pipeline.setStateAtKey(stateKey, columnSize);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
if (pipeline.ref) {
|
|
82
|
+
pipeline.ref.current.lastOptColumnSize = opts.columnSize;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
var onChangeSize = function onChangeSize(nextColumnSize) {
|
|
86
|
+
window.requestAnimationFrame(function () {
|
|
87
|
+
var _a;
|
|
88
|
+
|
|
89
|
+
pipeline.setStateAtKey(stateKey, nextColumnSize);
|
|
90
|
+
(_a = opts === null || opts === void 0 ? void 0 : opts.onChangeSize) === null || _a === void 0 ? void 0 : _a.call(opts, nextColumnSize);
|
|
91
|
+
|
|
92
|
+
if (opts.columnSize) {
|
|
93
|
+
if (pipeline.ref) {
|
|
94
|
+
pipeline.ref.current.lastOptColumnSize = nextColumnSize; // 这里记录由列宽拖拽导致的opts.columnSize变化,避免重复渲染
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
var handleMouseDown = function handleMouseDown(e, col) {
|
|
101
|
+
window.addEventListener('selectstart', disableSelect);
|
|
102
|
+
var changedColumnSize = {};
|
|
103
|
+
var startX = e.clientX;
|
|
104
|
+
var children = col.children,
|
|
105
|
+
code = col.code;
|
|
106
|
+
var recordColumnSize = columnSize;
|
|
107
|
+
e.stopPropagation();
|
|
108
|
+
var nextSize$ = (0, _rxjs.fromEvent)(window, 'mousemove').pipe(op.takeUntil((0, _rxjs.fromEvent)(window, 'mouseup')), op.map(function (e) {
|
|
109
|
+
var movingX = e.clientX;
|
|
110
|
+
var nextColumnSize = (0, _extends2.default)({}, columnSize);
|
|
111
|
+
var deltaSum = movingX - startX;
|
|
112
|
+
var deltaRemaining = deltaSum;
|
|
113
|
+
|
|
114
|
+
if ((children === null || children === void 0 ? void 0 : children.length) > 0) {
|
|
115
|
+
var leafChildColumns = (0, _utils.collectNodes)(children, 'leaf-only');
|
|
116
|
+
var childrenWidthSum = (0, _reduce.default)(leafChildColumns).call(leafChildColumns, function (sum, _ref2) {
|
|
117
|
+
var code = _ref2.code;
|
|
118
|
+
return sum + columnSize[code];
|
|
119
|
+
}, 0);
|
|
120
|
+
leafChildColumns.forEach(function (_ref3, index) {
|
|
121
|
+
var code = _ref3.code;
|
|
122
|
+
var startSize = columnSize[code];
|
|
123
|
+
var currentDeltaWidth = Math.round(deltaSum * startSize / childrenWidthSum);
|
|
124
|
+
|
|
125
|
+
if (index < leafChildColumns.length - 1) {
|
|
126
|
+
nextColumnSize[code] = clamp(minSize, startSize + currentDeltaWidth, maxSize);
|
|
127
|
+
changedColumnSize[code] = nextColumnSize[code];
|
|
128
|
+
deltaRemaining -= currentDeltaWidth;
|
|
129
|
+
} else {
|
|
130
|
+
nextColumnSize[code] = clamp(minSize, startSize + deltaRemaining, maxSize);
|
|
131
|
+
changedColumnSize[code] = nextColumnSize[code];
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
} else {
|
|
135
|
+
var startSize = columnSize[code];
|
|
136
|
+
nextColumnSize[code] = clamp(minSize, startSize + deltaSum, maxSize);
|
|
137
|
+
changedColumnSize[code] = nextColumnSize[code];
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
recordColumnSize = nextColumnSize;
|
|
141
|
+
return nextColumnSize;
|
|
142
|
+
}));
|
|
143
|
+
nextSize$.subscribe({
|
|
144
|
+
next: onChangeSize,
|
|
145
|
+
complete: function complete() {
|
|
146
|
+
var _context;
|
|
147
|
+
|
|
148
|
+
var changedColumnSizes = (0, _map.default)(_context = (0, _keys.default)(changedColumnSize)).call(_context, function (code) {
|
|
149
|
+
return {
|
|
150
|
+
code: code,
|
|
151
|
+
width: changedColumnSize[code]
|
|
152
|
+
};
|
|
153
|
+
});
|
|
154
|
+
window.requestAnimationFrame(function () {
|
|
155
|
+
var _a;
|
|
156
|
+
|
|
157
|
+
(_a = opts === null || opts === void 0 ? void 0 : opts.afterChangeSize) === null || _a === void 0 ? void 0 : _a.call(opts, recordColumnSize, changedColumnSizes);
|
|
158
|
+
});
|
|
159
|
+
window.removeEventListener('selectstart', disableSelect);
|
|
160
|
+
}
|
|
161
|
+
});
|
|
162
|
+
};
|
|
163
|
+
|
|
164
|
+
var isGroup = (0, _utils.isGroupColumn)(pipeline.getColumns());
|
|
165
|
+
return pipeline.mapColumns((0, _utils.makeRecursiveMapper)(function (col) {
|
|
166
|
+
var _a;
|
|
167
|
+
|
|
168
|
+
var prevTitle = _internals.internals.safeRenderHeader(col);
|
|
169
|
+
|
|
170
|
+
var code = col.code,
|
|
171
|
+
features = col.features,
|
|
172
|
+
width = col.width;
|
|
173
|
+
return (0, _extends2.default)((0, _extends2.default)({}, col), {
|
|
174
|
+
width: (_a = columnSize[code]) !== null && _a !== void 0 ? _a : width,
|
|
175
|
+
title: /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, prevTitle, (features === null || features === void 0 ? void 0 : features.resizeable) !== false && (isGroup ? /*#__PURE__*/_react.default.createElement(TableHeaderGroupCellResize, {
|
|
176
|
+
className: _styles.Classes.tableHeaderCellResize,
|
|
177
|
+
onMouseDown: function onMouseDown(e) {
|
|
178
|
+
return handleMouseDown(e, col);
|
|
179
|
+
}
|
|
180
|
+
}) : /*#__PURE__*/_react.default.createElement(TableHeaderCellResize, {
|
|
181
|
+
className: _styles.Classes.tableHeaderCellResize,
|
|
182
|
+
onMouseDown: function onMouseDown(e) {
|
|
183
|
+
return handleMouseDown(e, col);
|
|
184
|
+
}
|
|
185
|
+
}))),
|
|
186
|
+
headerCellProps: (0, _utils.mergeCellProps)(col.headerCellProps, {
|
|
187
|
+
className: 'resizeable'
|
|
188
|
+
})
|
|
189
|
+
});
|
|
190
|
+
}));
|
|
191
|
+
};
|
|
192
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { TablePipeline } from '../pipeline';
|
|
2
|
+
interface ContextMenuItem {
|
|
3
|
+
name: string;
|
|
4
|
+
action: () => {};
|
|
5
|
+
disabled?: boolean;
|
|
6
|
+
}
|
|
7
|
+
export interface ContextMenuFeatureOptions {
|
|
8
|
+
/** 获得自定义菜单 */
|
|
9
|
+
getContextMenuItems?: (params: any) => ContextMenuItem[];
|
|
10
|
+
/** 弹出框的父容器 */
|
|
11
|
+
popupParent?: HTMLElement;
|
|
12
|
+
}
|
|
13
|
+
export declare function contextMenu(opts?: ContextMenuFeatureOptions): (pipeline: TablePipeline) => TablePipeline;
|
|
14
|
+
export {};
|