tntd 2.0.2 → 2.0.4
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/es/drawer/drawer.js +28 -0
- package/es/drawer/drawer.js.map +1 -0
- package/es/drawer/drawer.less +18 -0
- package/es/drawer/index.js +2 -1
- package/es/drawer/index.js.map +1 -1
- package/es/index.js +1 -0
- package/es/index.js.map +1 -1
- package/es/locale/en_US.js +3 -0
- package/es/locale/en_US.js.map +1 -1
- package/es/locale/zh_CN.js +3 -0
- package/es/locale/zh_CN.js.map +1 -1
- package/es/message/index.js +1 -0
- package/es/message/index.js.map +1 -1
- package/es/message/message.less +8 -0
- package/es/modal/index.js +1 -0
- package/es/modal/index.js.map +1 -1
- package/es/modal/modal.less +35 -0
- package/es/page/index.js +1 -1
- package/es/page/index.js.map +1 -1
- package/es/prev-locale.js +7 -1
- package/es/prev-locale.js.map +1 -1
- package/es/steps/index.js +2 -2
- package/es/steps/index.js.map +1 -1
- package/es/steps/steps.js +46 -0
- package/es/steps/steps.js.map +1 -0
- package/es/steps/style/nav.less +158 -64
- package/es/tntd-cascader/AntdCascader/component/DisabledContext.js +8 -0
- package/es/tntd-cascader/AntdCascader/component/DisabledContext.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js +3 -0
- package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/component/SizeContext.js +3 -0
- package/es/tntd-cascader/AntdCascader/component/SizeContext.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/component/context.js +14 -0
- package/es/tntd-cascader/AntdCascader/component/context.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +20 -0
- package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/component/getIcons.js +52 -0
- package/es/tntd-cascader/AntdCascader/component/getIcons.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js +24 -0
- package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/config/utils.js +24 -0
- package/es/tntd-cascader/AntdCascader/config/utils.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/config/warning.js +15 -0
- package/es/tntd-cascader/AntdCascader/config/warning.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/index.js +147 -0
- package/es/tntd-cascader/AntdCascader/index.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/index.less +2325 -0
- package/es/tntd-cascader/AntdCascader/interface.js +5 -0
- package/es/tntd-cascader/AntdCascader/interface.js.map +1 -0
- package/es/tntd-cascader/img/no-data-s.png +0 -0
- package/es/tntd-cascader/index.js +2 -0
- package/es/tntd-cascader/index.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/Cascader.js +274 -0
- package/es/tntd-cascader/rc-cascader/Cascader.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js +14 -0
- package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/OptionList/Column.js +126 -0
- package/es/tntd-cascader/rc-cascader/OptionList/Column.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/OptionList/index.js +141 -0
- package/es/tntd-cascader/rc-cascader/OptionList/index.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/OptionList/useActive.js +26 -0
- package/es/tntd-cascader/rc-cascader/OptionList/useActive.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +145 -0
- package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/context.js +4 -0
- package/es/tntd-cascader/rc-cascader/context.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +41 -0
- package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/hooks/useEntities.js +30 -0
- package/es/tntd-cascader/rc-cascader/hooks/useEntities.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js +19 -0
- package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js +15 -0
- package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +26 -0
- package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +46 -0
- package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/index.js +3 -0
- package/es/tntd-cascader/rc-cascader/index.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/index.less +19 -0
- package/es/tntd-cascader/rc-cascader/utils/commonUtil.js +41 -0
- package/es/tntd-cascader/rc-cascader/utils/commonUtil.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/utils/treeUtil.js +37 -0
- package/es/tntd-cascader/rc-cascader/utils/treeUtil.js.map +1 -0
- package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +30 -0
- package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js.map +1 -0
- package/es/tntd-layout/Avatar.js +25 -19
- package/es/tntd-layout/Avatar.js.map +1 -1
- package/es/tntd-layout/EnterpriseLayout/Avatar.js +10 -8
- package/es/tntd-layout/EnterpriseLayout/Avatar.js.map +1 -1
- package/es/tntd-layout/EnterpriseLayout/Language.js +5 -4
- package/es/tntd-layout/EnterpriseLayout/Language.js.map +1 -1
- package/es/tntd-layout/EnterpriseLayout/Theme.js +7 -6
- package/es/tntd-layout/EnterpriseLayout/Theme.js.map +1 -1
- package/es/tntd-layout/HeaderActions.js +5 -4
- package/es/tntd-layout/HeaderActions.js.map +1 -1
- package/es/tntd-layout/Layout.js +2 -2
- package/es/tntd-layout/Layout.js.map +1 -1
- package/es/tntd-layout/SideMenu.js.map +1 -1
- package/es/tntd-layout/index.js +2 -2
- package/es/tntd-layout/index.js.map +1 -1
- package/es/tntd-layout/storage.js +10 -2
- package/es/tntd-layout/storage.js.map +1 -1
- package/lib/drawer/drawer.d.ts +4 -0
- package/lib/drawer/drawer.d.ts.map +1 -0
- package/lib/drawer/drawer.js +35 -0
- package/lib/drawer/drawer.js.map +1 -0
- package/lib/drawer/drawer.less +18 -0
- package/lib/drawer/index.d.ts +2 -1
- package/lib/drawer/index.d.ts.map +1 -1
- package/lib/drawer/index.js +3 -5
- package/lib/drawer/index.js.map +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +3 -1
- package/lib/index.js.map +1 -1
- package/lib/locale/default.d.ts +3 -0
- package/lib/locale/default.d.ts.map +1 -1
- package/lib/locale/en_US.d.ts +3 -0
- package/lib/locale/en_US.d.ts.map +1 -1
- package/lib/locale/en_US.js +3 -0
- package/lib/locale/en_US.js.map +1 -1
- package/lib/locale/zh_CN.d.ts +3 -0
- package/lib/locale/zh_CN.d.ts.map +1 -1
- package/lib/locale/zh_CN.js +3 -0
- package/lib/locale/zh_CN.js.map +1 -1
- package/lib/message/index.d.ts +1 -0
- package/lib/message/index.d.ts.map +1 -1
- package/lib/message/index.js +1 -0
- package/lib/message/index.js.map +1 -1
- package/lib/message/message.less +8 -0
- package/lib/modal/index.d.ts +1 -0
- package/lib/modal/index.d.ts.map +1 -1
- package/lib/modal/index.js +1 -0
- package/lib/modal/index.js.map +1 -1
- package/lib/modal/modal.less +35 -0
- package/lib/page/index.js +1 -1
- package/lib/page/index.js.map +1 -1
- package/lib/prev-locale.d.ts +6 -0
- package/lib/prev-locale.d.ts.map +1 -1
- package/lib/prev-locale.js +7 -1
- package/lib/prev-locale.js.map +1 -1
- package/lib/steps/index.d.ts +2 -2
- package/lib/steps/index.d.ts.map +1 -1
- package/lib/steps/index.js +3 -6
- package/lib/steps/index.js.map +1 -1
- package/lib/steps/steps.d.ts +12 -0
- package/lib/steps/steps.d.ts.map +1 -0
- package/lib/steps/steps.js +67 -0
- package/lib/steps/steps.js.map +1 -0
- package/lib/steps/style/nav.less +158 -64
- package/lib/svg-components/illustration-403.d.ts +1 -1
- package/lib/svg-components/illustration-404.d.ts +1 -1
- package/lib/svg-components/illustration-500.d.ts +1 -1
- package/lib/svg-components/illustration-empty.d.ts +1 -1
- package/lib/svg-components/illustration-failure.d.ts +1 -1
- package/lib/svg-components/illustration-no-access.d.ts +1 -1
- package/lib/svg-components/illustration-no-chart.d.ts +1 -1
- package/lib/svg-components/illustration-no-result.d.ts +1 -1
- package/lib/svg-components/illustration-offline.d.ts +1 -1
- package/lib/svg-components/illustration-success.d.ts +1 -1
- package/lib/table/assets/image-loading-background.d.ts +1 -1
- package/lib/table/assets/image-loading.d.ts +1 -1
- package/lib/tntd-cascader/AntdCascader/component/DisabledContext.d.ts +10 -0
- package/lib/tntd-cascader/AntdCascader/component/DisabledContext.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js +35 -0
- package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.d.ts +4 -0
- package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js +29 -0
- package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/SizeContext.d.ts +4 -0
- package/lib/tntd-cascader/AntdCascader/component/SizeContext.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/SizeContext.js +29 -0
- package/lib/tntd-cascader/AntdCascader/component/SizeContext.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/context.d.ts +42 -0
- package/lib/tntd-cascader/AntdCascader/component/context.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/context.js +20 -0
- package/lib/tntd-cascader/AntdCascader/component/context.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.d.ts +5 -0
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +48 -0
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/getIcons.d.ts +25 -0
- package/lib/tntd-cascader/AntdCascader/component/getIcons.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/getIcons.js +78 -0
- package/lib/tntd-cascader/AntdCascader/component/getIcons.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.d.ts +9 -0
- package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js +54 -0
- package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/config/utils.d.ts +6 -0
- package/lib/tntd-cascader/AntdCascader/config/utils.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/config/utils.js +34 -0
- package/lib/tntd-cascader/AntdCascader/config/utils.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/config/warning.d.ts +4 -0
- package/lib/tntd-cascader/AntdCascader/config/warning.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/config/warning.js +40 -0
- package/lib/tntd-cascader/AntdCascader/config/warning.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/index.d.ts +44 -0
- package/lib/tntd-cascader/AntdCascader/index.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/index.js +175 -0
- package/lib/tntd-cascader/AntdCascader/index.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/index.less +2325 -0
- package/lib/tntd-cascader/AntdCascader/interface.d.ts +25 -0
- package/lib/tntd-cascader/AntdCascader/interface.d.ts.map +1 -0
- package/lib/tntd-cascader/AntdCascader/interface.js +9 -0
- package/lib/tntd-cascader/AntdCascader/interface.js.map +1 -0
- package/lib/tntd-cascader/img/no-data-s.png +0 -0
- package/lib/tntd-cascader/index.d.ts +2 -0
- package/lib/tntd-cascader/index.d.ts.map +1 -0
- package/lib/tntd-cascader/index.js +9 -0
- package/lib/tntd-cascader/index.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/Cascader.d.ts +92 -0
- package/lib/tntd-cascader/rc-cascader/Cascader.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/Cascader.js +302 -0
- package/lib/tntd-cascader/rc-cascader/Cascader.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.d.ts +10 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js +43 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/Column.d.ts +27 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/Column.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/Column.js +156 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/Column.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/index.d.ts +5 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/index.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/index.js +169 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/index.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/useActive.d.ts +7 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/useActive.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js +54 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.d.ts +6 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +173 -0
- package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/context.d.ts +26 -0
- package/lib/tntd-cascader/rc-cascader/context.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/context.js +29 -0
- package/lib/tntd-cascader/rc-cascader/context.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.d.ts +11 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +66 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useEntities.d.ts +11 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useEntities.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js +55 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.d.ts +4 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js +44 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.d.ts +6 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js +41 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.d.ts +3 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +55 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.d.ts +5 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +72 -0
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/index.d.ts +4 -0
- package/lib/tntd-cascader/rc-cascader/index.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/index.js +8 -0
- package/lib/tntd-cascader/rc-cascader/index.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/index.less +19 -0
- package/lib/tntd-cascader/rc-cascader/utils/commonUtil.d.ts +11 -0
- package/lib/tntd-cascader/rc-cascader/utils/commonUtil.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js +50 -0
- package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/utils/treeUtil.d.ts +10 -0
- package/lib/tntd-cascader/rc-cascader/utils/treeUtil.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js +42 -0
- package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js.map +1 -0
- package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.d.ts +5 -0
- package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.d.ts.map +1 -0
- package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +37 -0
- package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js.map +1 -0
- package/lib/tntd-layout/Avatar.d.ts.map +1 -1
- package/lib/tntd-layout/Avatar.js +25 -19
- package/lib/tntd-layout/Avatar.js.map +1 -1
- package/lib/tntd-layout/EnterpriseLayout/Avatar.d.ts.map +1 -1
- package/lib/tntd-layout/EnterpriseLayout/Avatar.js +10 -8
- package/lib/tntd-layout/EnterpriseLayout/Avatar.js.map +1 -1
- package/lib/tntd-layout/EnterpriseLayout/Language.js +4 -3
- package/lib/tntd-layout/EnterpriseLayout/Language.js.map +1 -1
- package/lib/tntd-layout/EnterpriseLayout/Theme.js +6 -5
- package/lib/tntd-layout/EnterpriseLayout/Theme.js.map +1 -1
- package/lib/tntd-layout/HeaderActions.js +5 -4
- package/lib/tntd-layout/HeaderActions.js.map +1 -1
- package/lib/tntd-layout/Layout.js +2 -2
- package/lib/tntd-layout/Layout.js.map +1 -1
- package/lib/tntd-layout/SideMenu.js.map +1 -1
- package/lib/tntd-layout/index.d.ts.map +1 -1
- package/lib/tntd-layout/index.js +2 -2
- package/lib/tntd-layout/index.js.map +1 -1
- package/lib/tntd-layout/storage.d.ts +3 -2
- package/lib/tntd-layout/storage.d.ts.map +1 -1
- package/lib/tntd-layout/storage.js +15 -3
- package/lib/tntd-layout/storage.js.map +1 -1
- package/package.json +11 -2
- package/themes/default/colors.less +3 -3
- package/themes/default/variables.less +6 -2
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
/* eslint-disable default-case */
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
import classNames from 'classnames';
|
|
4
|
+
import { useBaseProps } from 'rc-select';
|
|
5
|
+
import * as React from 'react';
|
|
6
|
+
import CascaderContext from '../context';
|
|
7
|
+
import { isLeaf, scrollIntoParentView, toPathKey, toPathKeys, toPathValueStr, } from '../utils/commonUtil';
|
|
8
|
+
import { toPathOptions } from '../utils/treeUtil';
|
|
9
|
+
import Column, { FIX_LABEL } from './Column';
|
|
10
|
+
import useActive from './useActive';
|
|
11
|
+
import useKeyboard from './useKeyboard';
|
|
12
|
+
const RefOptionList = React.forwardRef((props, ref) => {
|
|
13
|
+
var _a, _b;
|
|
14
|
+
const { prefixCls, multiple, searchValue, toggleOpen, notFoundContent, direction, optionHeight } = useBaseProps();
|
|
15
|
+
const containerRef = React.useRef();
|
|
16
|
+
const rtl = direction === 'rtl';
|
|
17
|
+
const { options, values, halfValues, fieldNames, changeOnSelect, onSelect, searchOptions, dropdownPrefixCls, loadData, expandTrigger, renderItem, dropdownVisible, } = React.useContext(CascaderContext);
|
|
18
|
+
const mergedPrefixCls = dropdownPrefixCls || prefixCls;
|
|
19
|
+
// ========================= loadData =========================
|
|
20
|
+
const [loadingKeys, setLoadingKeys] = React.useState([]);
|
|
21
|
+
const internalLoadData = (valueCells) => {
|
|
22
|
+
// Do not load when search
|
|
23
|
+
if (!loadData || searchValue) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const optionList = toPathOptions(valueCells, options, fieldNames);
|
|
27
|
+
const rawOptions = optionList.map(({ option }) => option);
|
|
28
|
+
const lastOption = rawOptions[rawOptions.length - 1];
|
|
29
|
+
if (lastOption && !isLeaf(lastOption, fieldNames)) {
|
|
30
|
+
const pathKey = toPathKey(valueCells);
|
|
31
|
+
setLoadingKeys((keys) => [...keys, pathKey]);
|
|
32
|
+
loadData(rawOptions);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
// zombieJ: This is bad. We should make this same as `rc-tree` to use Promise instead.
|
|
36
|
+
React.useEffect(() => {
|
|
37
|
+
if (loadingKeys.length) {
|
|
38
|
+
loadingKeys.forEach((loadingKey) => {
|
|
39
|
+
const valueStrCells = toPathValueStr(loadingKey);
|
|
40
|
+
const optionList = toPathOptions(valueStrCells, options, fieldNames, true).map(({ option }) => option);
|
|
41
|
+
const lastOption = optionList[optionList.length - 1];
|
|
42
|
+
if (!lastOption || lastOption[fieldNames.children] || isLeaf(lastOption, fieldNames)) {
|
|
43
|
+
setLoadingKeys((keys) => keys.filter((key) => key !== loadingKey));
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
}, [options, loadingKeys, fieldNames]);
|
|
48
|
+
// ========================== Values ==========================
|
|
49
|
+
const checkedSet = React.useMemo(() => new Set(toPathKeys(values)), [values]);
|
|
50
|
+
const halfCheckedSet = React.useMemo(() => new Set(toPathKeys(halfValues)), [halfValues]);
|
|
51
|
+
// ====================== Accessibility =======================
|
|
52
|
+
const [activeValueCells, setActiveValueCells] = useActive();
|
|
53
|
+
// =========================== Path ===========================
|
|
54
|
+
const onPathOpen = (nextValueCells) => {
|
|
55
|
+
setActiveValueCells(nextValueCells);
|
|
56
|
+
// Trigger loadData
|
|
57
|
+
internalLoadData(nextValueCells);
|
|
58
|
+
};
|
|
59
|
+
const isSelectable = (option) => {
|
|
60
|
+
const { disabled } = option;
|
|
61
|
+
const isMergedLeaf = isLeaf(option, fieldNames);
|
|
62
|
+
return !disabled && (isMergedLeaf || changeOnSelect || multiple);
|
|
63
|
+
};
|
|
64
|
+
const onPathSelect = (valuePath, leaf, fromKeyboard = false) => {
|
|
65
|
+
onSelect(valuePath);
|
|
66
|
+
if (!multiple && (leaf || (changeOnSelect && (expandTrigger === 'hover' || fromKeyboard)))) {
|
|
67
|
+
toggleOpen(false);
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
// ========================== Option ==========================
|
|
71
|
+
const mergedOptions = React.useMemo(() => {
|
|
72
|
+
if (searchValue) {
|
|
73
|
+
return searchOptions;
|
|
74
|
+
}
|
|
75
|
+
return options;
|
|
76
|
+
}, [searchValue, searchOptions, options]);
|
|
77
|
+
// ========================== Column ==========================
|
|
78
|
+
const optionColumns = React.useMemo(() => {
|
|
79
|
+
const optionList = [{ options: mergedOptions }];
|
|
80
|
+
let currentList = mergedOptions;
|
|
81
|
+
for (let i = 0; i < activeValueCells.length; i += 1) {
|
|
82
|
+
const activeValueCell = activeValueCells[i];
|
|
83
|
+
const currentOption = currentList.find((option) => option[fieldNames.value] === activeValueCell);
|
|
84
|
+
const subOptions = currentOption === null || currentOption === void 0 ? void 0 : currentOption[fieldNames.children];
|
|
85
|
+
if (!(subOptions === null || subOptions === void 0 ? void 0 : subOptions.length)) {
|
|
86
|
+
break;
|
|
87
|
+
}
|
|
88
|
+
currentList = subOptions;
|
|
89
|
+
optionList.push({ options: subOptions });
|
|
90
|
+
}
|
|
91
|
+
return optionList;
|
|
92
|
+
}, [mergedOptions, activeValueCells, fieldNames]);
|
|
93
|
+
// ========================= Keyboard =========================
|
|
94
|
+
const onKeyboardSelect = (selectValueCells, option) => {
|
|
95
|
+
if (isSelectable(option)) {
|
|
96
|
+
onPathSelect(selectValueCells, isLeaf(option, fieldNames), true);
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
useKeyboard(ref, mergedOptions, fieldNames, activeValueCells, onPathOpen, onKeyboardSelect);
|
|
100
|
+
// >>>>> Active Scroll
|
|
101
|
+
React.useEffect(() => {
|
|
102
|
+
var _a;
|
|
103
|
+
for (let i = 0; i < activeValueCells.length; i += 1) {
|
|
104
|
+
const cellPath = activeValueCells.slice(0, i + 1);
|
|
105
|
+
const cellKeyPath = toPathKey(cellPath);
|
|
106
|
+
const ele = (_a = containerRef.current) === null || _a === void 0 ? void 0 : _a.querySelector(`li[data-path-key="${cellKeyPath.replace(/\\{0,2}"/g, '\\"')}"]` // matches unescaped double quotes
|
|
107
|
+
);
|
|
108
|
+
if (ele) {
|
|
109
|
+
scrollIntoParentView(ele);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}, [activeValueCells]);
|
|
113
|
+
// ========================== Render ==========================
|
|
114
|
+
// >>>>> Empty
|
|
115
|
+
const isEmpty = !((_b = (_a = optionColumns[0]) === null || _a === void 0 ? void 0 : _a.options) === null || _b === void 0 ? void 0 : _b.length);
|
|
116
|
+
const emptyList = [
|
|
117
|
+
{
|
|
118
|
+
[fieldNames.value]: '__EMPTY__',
|
|
119
|
+
[FIX_LABEL]: notFoundContent,
|
|
120
|
+
disabled: true,
|
|
121
|
+
},
|
|
122
|
+
];
|
|
123
|
+
const columnProps = Object.assign(Object.assign({}, props), { multiple: !isEmpty && multiple, onSelect: onPathSelect, onActive: onPathOpen, onToggleOpen: toggleOpen, checkedSet,
|
|
124
|
+
halfCheckedSet,
|
|
125
|
+
loadingKeys,
|
|
126
|
+
isSelectable });
|
|
127
|
+
// >>>>> Columns
|
|
128
|
+
const mergedOptionColumns = isEmpty ? [{ options: emptyList }] : optionColumns;
|
|
129
|
+
const columnNodes = mergedOptionColumns.map((col, index) => {
|
|
130
|
+
const prevValuePath = activeValueCells.slice(0, index);
|
|
131
|
+
const activeValue = activeValueCells[index];
|
|
132
|
+
return (React.createElement(Column, Object.assign({ key: index, level: index, optionHeight: optionHeight, dropdownVisible: dropdownVisible }, columnProps, { prefixCls: mergedPrefixCls, options: col.options, searchValue: searchValue, prevValuePath: prevValuePath, activeValue: activeValue, renderItem: renderItem })));
|
|
133
|
+
});
|
|
134
|
+
// >>>>> Render
|
|
135
|
+
return (React.createElement("div", { className: classNames(`${mergedPrefixCls}-menus`, {
|
|
136
|
+
[`${mergedPrefixCls}-menu-empty`]: isEmpty,
|
|
137
|
+
[`${mergedPrefixCls}-rtl`]: rtl,
|
|
138
|
+
}), ref: containerRef }, columnNodes));
|
|
139
|
+
});
|
|
140
|
+
export default RefOptionList;
|
|
141
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/OptionList/index.tsx"],"names":[],"mappings":"AAAA,iCAAiC;AACjC,cAAc;AACd,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA;AAExC,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,eAAe,MAAM,YAAY,CAAA;AACxC,OAAO,EACL,MAAM,EACN,oBAAoB,EACpB,SAAS,EACT,UAAU,EACV,cAAc,GACf,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACjD,OAAO,MAAM,EAAE,EAAE,SAAS,EAAE,MAAM,UAAU,CAAA;AAC5C,OAAO,SAAS,MAAM,aAAa,CAAA;AACnC,OAAO,WAAW,MAAM,eAAe,CAAA;AAEvC,MAAM,aAAa,GAAG,KAAK,CAAC,UAAU,CAAqB,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;;IACxE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,eAAe,EAAE,SAAS,EAAE,YAAY,EAAE,GAC9F,YAAY,EAAE,CAAA;IAEhB,MAAM,YAAY,GAAG,KAAK,CAAC,MAAM,EAAkB,CAAA;IACnD,MAAM,GAAG,GAAG,SAAS,KAAK,KAAK,CAAA;IAE/B,MAAM,EACJ,OAAO,EACP,MAAM,EACN,UAAU,EACV,UAAU,EACV,cAAc,EACd,QAAQ,EACR,aAAa,EACb,iBAAiB,EACjB,QAAQ,EACR,aAAa,EACb,UAAU,EACV,eAAe,GAChB,GAAG,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAA;IAErC,MAAM,eAAe,GAAG,iBAAiB,IAAI,SAAS,CAAA;IAEtD,+DAA+D;IAC/D,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;IAExD,MAAM,gBAAgB,GAAG,CAAC,UAAuB,EAAE,EAAE;QACnD,0BAA0B;QAC1B,IAAI,CAAC,QAAQ,IAAI,WAAW,EAAE;YAC5B,OAAM;SACP;QAED,MAAM,UAAU,GAAG,aAAa,CAAC,UAAU,EAAE,OAAO,EAAE,UAAU,CAAC,CAAA;QACjE,MAAM,UAAU,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,CAAA;QACzD,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAEpD,IAAI,UAAU,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,UAAU,CAAC,EAAE;YACjD,MAAM,OAAO,GAAG,SAAS,CAAC,UAAU,CAAC,CAAA;YAErC,cAAc,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC,CAAC,CAAA;YAE5C,QAAQ,CAAC,UAAU,CAAC,CAAA;SACrB;IACH,CAAC,CAAA;IAED,sFAAsF;IACtF,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,IAAI,WAAW,CAAC,MAAM,EAAE;YACtB,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE;gBACjC,MAAM,aAAa,GAAG,cAAc,CAAC,UAAU,CAAC,CAAA;gBAChD,MAAM,UAAU,GAAG,aAAa,CAAC,aAAa,EAAE,OAAO,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC,GAAG,CAC5E,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CACvB,CAAA;gBACD,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;gBAEpD,IAAI,CAAC,UAAU,IAAI,UAAU,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,MAAM,CAAC,UAAU,EAAE,UAAU,CAAC,EAAE;oBACpF,cAAc,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,KAAK,UAAU,CAAC,CAAC,CAAA;iBACnE;YACH,CAAC,CAAC,CAAA;SACH;IACH,CAAC,EAAE,CAAC,OAAO,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC,CAAA;IAEtC,+DAA+D;IAC/D,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;IAC7E,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAA;IAEzF,+DAA+D;IAC/D,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,SAAS,EAAE,CAAA;IAE3D,+DAA+D;IAC/D,MAAM,UAAU,GAAG,CAAC,cAA2B,EAAE,EAAE;QACjD,mBAAmB,CAAC,cAAc,CAAC,CAAA;QAEnC,mBAAmB;QACnB,gBAAgB,CAAC,cAAc,CAAC,CAAA;IAClC,CAAC,CAAA;IAED,MAAM,YAAY,GAAG,CAAC,MAAyB,EAAE,EAAE;QACjD,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAA;QAE3B,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAA;QAC/C,OAAO,CAAC,QAAQ,IAAI,CAAC,YAAY,IAAI,cAAc,IAAI,QAAQ,CAAC,CAAA;IAClE,CAAC,CAAA;IAED,MAAM,YAAY,GAAG,CAAC,SAA0B,EAAE,IAAa,EAAE,YAAY,GAAG,KAAK,EAAE,EAAE;QACvF,QAAQ,CAAC,SAAS,CAAC,CAAA;QAEnB,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,IAAI,CAAC,cAAc,IAAI,CAAC,aAAa,KAAK,OAAO,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE;YAC1F,UAAU,CAAC,KAAK,CAAC,CAAA;SAClB;IACH,CAAC,CAAA;IAED,+DAA+D;IAC/D,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACvC,IAAI,WAAW,EAAE;YACf,OAAO,aAAa,CAAA;SACrB;QAED,OAAO,OAAO,CAAA;IAChB,CAAC,EAAE,CAAC,WAAW,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC,CAAA;IAEzC,+DAA+D;IAC/D,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACvC,MAAM,UAAU,GAAG,CAAC,EAAE,OAAO,EAAE,aAAa,EAAE,CAAC,CAAA;QAC/C,IAAI,WAAW,GAAG,aAAa,CAAA;QAE/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,gBAAgB,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;YACnD,MAAM,eAAe,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAA;YAC3C,MAAM,aAAa,GAAG,WAAW,CAAC,IAAI,CACpC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,eAAe,CACzD,CAAA;YAED,MAAM,UAAU,GAAG,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAG,UAAU,CAAC,QAAQ,CAAC,CAAA;YACvD,IAAI,CAAC,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,MAAM,CAAA,EAAE;gBACvB,MAAK;aACN;YAED,WAAW,GAAG,UAAU,CAAA;YACxB,UAAU,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,CAAA;SACzC;QAED,OAAO,UAAU,CAAA;IACnB,CAAC,EAAE,CAAC,aAAa,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAC,CAAA;IAEjD,+DAA+D;IAC/D,MAAM,gBAAgB,GAAG,CAAC,gBAAiC,EAAE,MAAyB,EAAE,EAAE;QACxF,IAAI,YAAY,CAAC,MAAM,CAAC,EAAE;YACxB,YAAY,CAAC,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,IAAI,CAAC,CAAA;SACjE;IACH,CAAC,CAAA;IAED,WAAW,CAAC,GAAG,EAAE,aAAa,EAAE,UAAU,EAAE,gBAAgB,EAAE,UAAU,EAAE,gBAAgB,CAAC,CAAA;IAE3F,sBAAsB;IACtB,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;;QACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,gBAAgB,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;YACnD,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAA;YACjD,MAAM,WAAW,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAA;YACvC,MAAM,GAAG,GAAG,MAAA,YAAY,CAAC,OAAO,0CAAE,aAAa,CAC7C,qBAAqB,WAAW,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,CAAC,IAAI,CAAC,kCAAkC;aACpG,CAAA;YACD,IAAI,GAAG,EAAE;gBACP,oBAAoB,CAAC,GAAG,CAAC,CAAA;aAC1B;SACF;IACH,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAA;IAEtB,+DAA+D;IAC/D,cAAc;IACd,MAAM,OAAO,GAAG,CAAC,CAAA,MAAA,MAAA,aAAa,CAAC,CAAC,CAAC,0CAAE,OAAO,0CAAE,MAAM,CAAA,CAAA;IAElD,MAAM,SAAS,GAAwB;QACrC;YACE,CAAC,UAAU,CAAC,KAAgB,CAAC,EAAE,WAAW;YAC1C,CAAC,SAAoB,CAAC,EAAE,eAAe;YACvC,QAAQ,EAAE,IAAI;SACf;KACF,CAAA;IAED,MAAM,WAAW,mCACZ,KAAK,KACR,QAAQ,EAAE,CAAC,OAAO,IAAI,QAAQ,EAC9B,QAAQ,EAAE,YAAY,EACtB,QAAQ,EAAE,UAAU,EACpB,YAAY,EAAE,UAAU,EACxB,UAAU;QACV,cAAc;QACd,WAAW;QACX,YAAY,GACb,CAAA;IAED,gBAAgB;IAChB,MAAM,mBAAmB,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAA;IAE9E,MAAM,WAAW,GAAyB,mBAAmB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;QAC/E,MAAM,aAAa,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAA;QACtD,MAAM,WAAW,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAA;QAE3C,OAAO,CACL,oBAAC,MAAM,kBACL,GAAG,EAAE,KAAK,EACV,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,YAAY,EAC1B,eAAe,EAAE,eAAe,IAC5B,WAAW,IACf,SAAS,EAAE,eAAe,EAC1B,OAAO,EAAE,GAAG,CAAC,OAAO,EACpB,WAAW,EAAE,WAAW,EACxB,aAAa,EAAE,aAAa,EAC5B,WAAW,EAAE,WAAW,EACxB,UAAU,EAAE,UAAU,IACtB,CACH,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,eAAe;IACf,OAAO,CACL,6BACE,SAAS,EAAE,UAAU,CAAC,GAAG,eAAe,QAAQ,EAAE;YAChD,CAAC,GAAG,eAAe,aAAa,CAAC,EAAE,OAAO;YAC1C,CAAC,GAAG,eAAe,MAAM,CAAC,EAAE,GAAG;SAChC,CAAC,EACF,GAAG,EAAE,YAAY,IAEhB,WAAW,CACR,CACP,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,aAAa,CAAA","sourcesContent":["/* eslint-disable default-case */\n// @ts-nocheck\nimport classNames from 'classnames'\nimport { useBaseProps } from 'rc-select'\nimport type { RefOptionListProps } from 'rc-select/lib/OptionList'\nimport * as React from 'react'\nimport type { DefaultOptionType, SingleValueType } from '../Cascader'\nimport CascaderContext from '../context'\nimport {\n isLeaf,\n scrollIntoParentView,\n toPathKey,\n toPathKeys,\n toPathValueStr,\n} from '../utils/commonUtil'\nimport { toPathOptions } from '../utils/treeUtil'\nimport Column, { FIX_LABEL } from './Column'\nimport useActive from './useActive'\nimport useKeyboard from './useKeyboard'\n\nconst RefOptionList = React.forwardRef<RefOptionListProps>((props, ref) => {\n const { prefixCls, multiple, searchValue, toggleOpen, notFoundContent, direction, optionHeight } =\n useBaseProps()\n\n const containerRef = React.useRef<HTMLDivElement>()\n const rtl = direction === 'rtl'\n\n const {\n options,\n values,\n halfValues,\n fieldNames,\n changeOnSelect,\n onSelect,\n searchOptions,\n dropdownPrefixCls,\n loadData,\n expandTrigger,\n renderItem,\n dropdownVisible,\n } = React.useContext(CascaderContext)\n\n const mergedPrefixCls = dropdownPrefixCls || prefixCls\n\n // ========================= loadData =========================\n const [loadingKeys, setLoadingKeys] = React.useState([])\n\n const internalLoadData = (valueCells: React.Key[]) => {\n // Do not load when search\n if (!loadData || searchValue) {\n return\n }\n\n const optionList = toPathOptions(valueCells, options, fieldNames)\n const rawOptions = optionList.map(({ option }) => option)\n const lastOption = rawOptions[rawOptions.length - 1]\n\n if (lastOption && !isLeaf(lastOption, fieldNames)) {\n const pathKey = toPathKey(valueCells)\n\n setLoadingKeys((keys) => [...keys, pathKey])\n\n loadData(rawOptions)\n }\n }\n\n // zombieJ: This is bad. We should make this same as `rc-tree` to use Promise instead.\n React.useEffect(() => {\n if (loadingKeys.length) {\n loadingKeys.forEach((loadingKey) => {\n const valueStrCells = toPathValueStr(loadingKey)\n const optionList = toPathOptions(valueStrCells, options, fieldNames, true).map(\n ({ option }) => option\n )\n const lastOption = optionList[optionList.length - 1]\n\n if (!lastOption || lastOption[fieldNames.children] || isLeaf(lastOption, fieldNames)) {\n setLoadingKeys((keys) => keys.filter((key) => key !== loadingKey))\n }\n })\n }\n }, [options, loadingKeys, fieldNames])\n\n // ========================== Values ==========================\n const checkedSet = React.useMemo(() => new Set(toPathKeys(values)), [values])\n const halfCheckedSet = React.useMemo(() => new Set(toPathKeys(halfValues)), [halfValues])\n\n // ====================== Accessibility =======================\n const [activeValueCells, setActiveValueCells] = useActive()\n\n // =========================== Path ===========================\n const onPathOpen = (nextValueCells: React.Key[]) => {\n setActiveValueCells(nextValueCells)\n\n // Trigger loadData\n internalLoadData(nextValueCells)\n }\n\n const isSelectable = (option: DefaultOptionType) => {\n const { disabled } = option\n\n const isMergedLeaf = isLeaf(option, fieldNames)\n return !disabled && (isMergedLeaf || changeOnSelect || multiple)\n }\n\n const onPathSelect = (valuePath: SingleValueType, leaf: boolean, fromKeyboard = false) => {\n onSelect(valuePath)\n\n if (!multiple && (leaf || (changeOnSelect && (expandTrigger === 'hover' || fromKeyboard)))) {\n toggleOpen(false)\n }\n }\n\n // ========================== Option ==========================\n const mergedOptions = React.useMemo(() => {\n if (searchValue) {\n return searchOptions\n }\n\n return options\n }, [searchValue, searchOptions, options])\n\n // ========================== Column ==========================\n const optionColumns = React.useMemo(() => {\n const optionList = [{ options: mergedOptions }]\n let currentList = mergedOptions\n\n for (let i = 0; i < activeValueCells.length; i += 1) {\n const activeValueCell = activeValueCells[i]\n const currentOption = currentList.find(\n (option) => option[fieldNames.value] === activeValueCell\n )\n\n const subOptions = currentOption?.[fieldNames.children]\n if (!subOptions?.length) {\n break\n }\n\n currentList = subOptions\n optionList.push({ options: subOptions })\n }\n\n return optionList\n }, [mergedOptions, activeValueCells, fieldNames])\n\n // ========================= Keyboard =========================\n const onKeyboardSelect = (selectValueCells: SingleValueType, option: DefaultOptionType) => {\n if (isSelectable(option)) {\n onPathSelect(selectValueCells, isLeaf(option, fieldNames), true)\n }\n }\n\n useKeyboard(ref, mergedOptions, fieldNames, activeValueCells, onPathOpen, onKeyboardSelect)\n\n // >>>>> Active Scroll\n React.useEffect(() => {\n for (let i = 0; i < activeValueCells.length; i += 1) {\n const cellPath = activeValueCells.slice(0, i + 1)\n const cellKeyPath = toPathKey(cellPath)\n const ele = containerRef.current?.querySelector<HTMLElement>(\n `li[data-path-key=\"${cellKeyPath.replace(/\\\\{0,2}\"/g, '\\\\\"')}\"]` // matches unescaped double quotes\n )\n if (ele) {\n scrollIntoParentView(ele)\n }\n }\n }, [activeValueCells])\n\n // ========================== Render ==========================\n // >>>>> Empty\n const isEmpty = !optionColumns[0]?.options?.length\n\n const emptyList: DefaultOptionType[] = [\n {\n [fieldNames.value as 'value']: '__EMPTY__',\n [FIX_LABEL as 'label']: notFoundContent,\n disabled: true,\n },\n ]\n\n const columnProps = {\n ...props,\n multiple: !isEmpty && multiple,\n onSelect: onPathSelect,\n onActive: onPathOpen,\n onToggleOpen: toggleOpen,\n checkedSet,\n halfCheckedSet,\n loadingKeys,\n isSelectable,\n }\n\n // >>>>> Columns\n const mergedOptionColumns = isEmpty ? [{ options: emptyList }] : optionColumns\n\n const columnNodes: React.ReactElement[] = mergedOptionColumns.map((col, index) => {\n const prevValuePath = activeValueCells.slice(0, index)\n const activeValue = activeValueCells[index]\n\n return (\n <Column\n key={index}\n level={index}\n optionHeight={optionHeight}\n dropdownVisible={dropdownVisible}\n {...columnProps}\n prefixCls={mergedPrefixCls}\n options={col.options}\n searchValue={searchValue}\n prevValuePath={prevValuePath}\n activeValue={activeValue}\n renderItem={renderItem}\n />\n )\n })\n\n // >>>>> Render\n return (\n <div\n className={classNames(`${mergedPrefixCls}-menus`, {\n [`${mergedPrefixCls}-menu-empty`]: isEmpty,\n [`${mergedPrefixCls}-rtl`]: rtl,\n })}\n ref={containerRef}\n >\n {columnNodes}\n </div>\n )\n})\n\nexport default RefOptionList\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import CascaderContext from '../context';
|
|
4
|
+
import { useBaseProps } from 'rc-select';
|
|
5
|
+
/**
|
|
6
|
+
* Control the active open options path.
|
|
7
|
+
*/
|
|
8
|
+
export default () => {
|
|
9
|
+
const { multiple, open } = useBaseProps();
|
|
10
|
+
const { values } = React.useContext(CascaderContext);
|
|
11
|
+
// Record current dropdown active options
|
|
12
|
+
// This also control the open status
|
|
13
|
+
const [activeValueCells, setActiveValueCells] = React.useState([]);
|
|
14
|
+
React.useEffect(() => {
|
|
15
|
+
if (open && !multiple) {
|
|
16
|
+
const firstValueCells = values[0];
|
|
17
|
+
setActiveValueCells(firstValueCells || []);
|
|
18
|
+
}
|
|
19
|
+
},
|
|
20
|
+
/* eslint-disable react-hooks/exhaustive-deps */
|
|
21
|
+
[open]
|
|
22
|
+
/* eslint-enable react-hooks/exhaustive-deps */
|
|
23
|
+
);
|
|
24
|
+
return [activeValueCells, setActiveValueCells];
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=useActive.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useActive.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/OptionList/useActive.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,eAAe,MAAM,YAAY,CAAA;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA;AAExC;;GAEG;AACH,eAAe,GAA2D,EAAE;IAC1E,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,YAAY,EAAE,CAAA;IACzC,MAAM,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAA;IAEpD,yCAAyC;IACzC,oCAAoC;IACpC,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAc,EAAE,CAAC,CAAA;IAE/E,KAAK,CAAC,SAAS,CACb,GAAG,EAAE;QACH,IAAI,IAAI,IAAI,CAAC,QAAQ,EAAE;YACrB,MAAM,eAAe,GAAG,MAAM,CAAC,CAAC,CAAC,CAAA;YACjC,mBAAmB,CAAC,eAAe,IAAI,EAAE,CAAC,CAAA;SAC3C;IACH,CAAC;IACD,gDAAgD;IAChD,CAAC,IAAI,CAAC;IACN,+CAA+C;KAChD,CAAA;IAED,OAAO,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,CAAA;AAChD,CAAC,CAAA","sourcesContent":["// @ts-nocheck\nimport * as React from 'react'\nimport CascaderContext from '../context'\nimport { useBaseProps } from 'rc-select'\n\n/**\n * Control the active open options path.\n */\nexport default (): [React.Key[], (activeValueCells: React.Key[]) => void] => {\n const { multiple, open } = useBaseProps()\n const { values } = React.useContext(CascaderContext)\n\n // Record current dropdown active options\n // This also control the open status\n const [activeValueCells, setActiveValueCells] = React.useState<React.Key[]>([])\n\n React.useEffect(\n () => {\n if (open && !multiple) {\n const firstValueCells = values[0]\n setActiveValueCells(firstValueCells || [])\n }\n },\n /* eslint-disable react-hooks/exhaustive-deps */\n [open]\n /* eslint-enable react-hooks/exhaustive-deps */\n )\n\n return [activeValueCells, setActiveValueCells]\n}\n"]}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { useBaseProps } from 'rc-select';
|
|
3
|
+
import KeyCode from 'rc-util/lib/KeyCode';
|
|
4
|
+
import { SEARCH_MARK } from '../hooks/useSearchOptions';
|
|
5
|
+
export default (ref, options, fieldNames, activeValueCells, setActiveValueCells, onKeyBoardSelect) => {
|
|
6
|
+
const { direction, searchValue, toggleOpen, open } = useBaseProps();
|
|
7
|
+
const rtl = direction === 'rtl';
|
|
8
|
+
const [validActiveValueCells, lastActiveIndex, lastActiveOptions] = React.useMemo(() => {
|
|
9
|
+
let activeIndex = -1;
|
|
10
|
+
let currentOptions = options;
|
|
11
|
+
const mergedActiveIndexes = [];
|
|
12
|
+
const mergedActiveValueCells = [];
|
|
13
|
+
const len = activeValueCells.length;
|
|
14
|
+
// Fill validate active value cells and index
|
|
15
|
+
for (let i = 0; i < len && currentOptions; i += 1) {
|
|
16
|
+
// Mark the active index for current options
|
|
17
|
+
const nextActiveIndex = currentOptions.findIndex((option) => option[fieldNames.value] === activeValueCells[i]);
|
|
18
|
+
if (nextActiveIndex === -1) {
|
|
19
|
+
break;
|
|
20
|
+
}
|
|
21
|
+
activeIndex = nextActiveIndex;
|
|
22
|
+
mergedActiveIndexes.push(activeIndex);
|
|
23
|
+
mergedActiveValueCells.push(activeValueCells[i]);
|
|
24
|
+
currentOptions = currentOptions[activeIndex][fieldNames.children];
|
|
25
|
+
}
|
|
26
|
+
// Fill last active options
|
|
27
|
+
let activeOptions = options;
|
|
28
|
+
for (let i = 0; i < mergedActiveIndexes.length - 1; i += 1) {
|
|
29
|
+
activeOptions = activeOptions[mergedActiveIndexes[i]][fieldNames.children];
|
|
30
|
+
}
|
|
31
|
+
return [mergedActiveValueCells, activeIndex, activeOptions];
|
|
32
|
+
}, [activeValueCells, fieldNames, options]);
|
|
33
|
+
// Update active value cells and scroll to target element
|
|
34
|
+
const internalSetActiveValueCells = (next) => {
|
|
35
|
+
setActiveValueCells(next);
|
|
36
|
+
};
|
|
37
|
+
// Same options offset
|
|
38
|
+
const offsetActiveOption = (offset) => {
|
|
39
|
+
const len = lastActiveOptions.length;
|
|
40
|
+
let currentIndex = lastActiveIndex;
|
|
41
|
+
if (currentIndex === -1 && offset < 0) {
|
|
42
|
+
currentIndex = len;
|
|
43
|
+
}
|
|
44
|
+
for (let i = 0; i < len; i += 1) {
|
|
45
|
+
currentIndex = (currentIndex + offset + len) % len;
|
|
46
|
+
const option = lastActiveOptions[currentIndex];
|
|
47
|
+
if (option && !option.disabled) {
|
|
48
|
+
const value = option[fieldNames.value];
|
|
49
|
+
const nextActiveCells = validActiveValueCells.slice(0, -1).concat(value);
|
|
50
|
+
internalSetActiveValueCells(nextActiveCells);
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
// Different options offset
|
|
56
|
+
const prevColumn = () => {
|
|
57
|
+
if (validActiveValueCells.length > 1) {
|
|
58
|
+
const nextActiveCells = validActiveValueCells.slice(0, -1);
|
|
59
|
+
internalSetActiveValueCells(nextActiveCells);
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
toggleOpen(false);
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
const nextColumn = () => {
|
|
66
|
+
var _a;
|
|
67
|
+
const nextOptions = ((_a = lastActiveOptions[lastActiveIndex]) === null || _a === void 0 ? void 0 : _a[fieldNames.children]) || [];
|
|
68
|
+
const nextOption = nextOptions.find((option) => !option.disabled);
|
|
69
|
+
if (nextOption) {
|
|
70
|
+
const nextActiveCells = [...validActiveValueCells, nextOption[fieldNames.value]];
|
|
71
|
+
internalSetActiveValueCells(nextActiveCells);
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
React.useImperativeHandle(ref, () => ({
|
|
75
|
+
// scrollTo: treeRef.current?.scrollTo,
|
|
76
|
+
onKeyDown: (event) => {
|
|
77
|
+
const { which } = event;
|
|
78
|
+
switch (which) {
|
|
79
|
+
// >>> Arrow keys
|
|
80
|
+
case KeyCode.UP:
|
|
81
|
+
case KeyCode.DOWN: {
|
|
82
|
+
let offset = 0;
|
|
83
|
+
if (which === KeyCode.UP) {
|
|
84
|
+
offset = -1;
|
|
85
|
+
}
|
|
86
|
+
else if (which === KeyCode.DOWN) {
|
|
87
|
+
offset = 1;
|
|
88
|
+
}
|
|
89
|
+
if (offset !== 0) {
|
|
90
|
+
offsetActiveOption(offset);
|
|
91
|
+
}
|
|
92
|
+
break;
|
|
93
|
+
}
|
|
94
|
+
case KeyCode.LEFT: {
|
|
95
|
+
if (rtl) {
|
|
96
|
+
nextColumn();
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
prevColumn();
|
|
100
|
+
}
|
|
101
|
+
break;
|
|
102
|
+
}
|
|
103
|
+
case KeyCode.RIGHT: {
|
|
104
|
+
if (rtl) {
|
|
105
|
+
prevColumn();
|
|
106
|
+
}
|
|
107
|
+
else {
|
|
108
|
+
nextColumn();
|
|
109
|
+
}
|
|
110
|
+
break;
|
|
111
|
+
}
|
|
112
|
+
case KeyCode.BACKSPACE: {
|
|
113
|
+
if (!searchValue) {
|
|
114
|
+
prevColumn();
|
|
115
|
+
}
|
|
116
|
+
break;
|
|
117
|
+
}
|
|
118
|
+
// >>> Select
|
|
119
|
+
case KeyCode.ENTER: {
|
|
120
|
+
if (validActiveValueCells.length) {
|
|
121
|
+
const option = lastActiveOptions[lastActiveIndex];
|
|
122
|
+
// Search option should revert back of origin options
|
|
123
|
+
const originOptions = (option === null || option === void 0 ? void 0 : option[SEARCH_MARK]) || [];
|
|
124
|
+
if (originOptions.length) {
|
|
125
|
+
onKeyBoardSelect(originOptions.map((opt) => opt[fieldNames.value]), originOptions[originOptions.length - 1]);
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
onKeyBoardSelect(validActiveValueCells, lastActiveOptions[lastActiveIndex]);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
break;
|
|
132
|
+
}
|
|
133
|
+
// >>> Close
|
|
134
|
+
case KeyCode.ESC: {
|
|
135
|
+
toggleOpen(false);
|
|
136
|
+
if (open) {
|
|
137
|
+
event.stopPropagation();
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
},
|
|
142
|
+
onKeyUp: () => { },
|
|
143
|
+
}));
|
|
144
|
+
};
|
|
145
|
+
//# sourceMappingURL=useKeyboard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useKeyboard.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/OptionList/useKeyboard.ts"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react'\nimport type { RefOptionListProps } from 'rc-select/lib/OptionList'\nimport { useBaseProps } from 'rc-select'\nimport KeyCode from 'rc-util/lib/KeyCode'\nimport type { DefaultOptionType, InternalFieldNames, SingleValueType } from '../Cascader'\nimport { SEARCH_MARK } from '../hooks/useSearchOptions'\n\nexport default (\n ref: React.Ref<RefOptionListProps>,\n options: DefaultOptionType[],\n fieldNames: InternalFieldNames,\n activeValueCells: React.Key[],\n setActiveValueCells: (activeValueCells: React.Key[]) => void,\n onKeyBoardSelect: (valueCells: SingleValueType, option: DefaultOptionType) => void\n) => {\n const { direction, searchValue, toggleOpen, open } = useBaseProps()\n const rtl = direction === 'rtl'\n\n const [validActiveValueCells, lastActiveIndex, lastActiveOptions] = React.useMemo(() => {\n let activeIndex = -1\n let currentOptions = options\n\n const mergedActiveIndexes: number[] = []\n const mergedActiveValueCells: React.Key[] = []\n\n const len = activeValueCells.length\n\n // Fill validate active value cells and index\n for (let i = 0; i < len && currentOptions; i += 1) {\n // Mark the active index for current options\n const nextActiveIndex = currentOptions.findIndex(\n (option) => option[fieldNames.value] === activeValueCells[i]\n )\n\n if (nextActiveIndex === -1) {\n break\n }\n\n activeIndex = nextActiveIndex\n mergedActiveIndexes.push(activeIndex)\n mergedActiveValueCells.push(activeValueCells[i])\n\n currentOptions = currentOptions[activeIndex][fieldNames.children]\n }\n\n // Fill last active options\n let activeOptions = options\n for (let i = 0; i < mergedActiveIndexes.length - 1; i += 1) {\n activeOptions = activeOptions[mergedActiveIndexes[i]][fieldNames.children]\n }\n\n return [mergedActiveValueCells, activeIndex, activeOptions]\n }, [activeValueCells, fieldNames, options])\n\n // Update active value cells and scroll to target element\n const internalSetActiveValueCells = (next: React.Key[]) => {\n setActiveValueCells(next)\n }\n\n // Same options offset\n const offsetActiveOption = (offset: number) => {\n const len = lastActiveOptions.length\n\n let currentIndex = lastActiveIndex\n if (currentIndex === -1 && offset < 0) {\n currentIndex = len\n }\n\n for (let i = 0; i < len; i += 1) {\n currentIndex = (currentIndex + offset + len) % len\n const option = lastActiveOptions[currentIndex]\n\n if (option && !option.disabled) {\n const value = option[fieldNames.value]\n const nextActiveCells = validActiveValueCells.slice(0, -1).concat(value)\n internalSetActiveValueCells(nextActiveCells)\n return\n }\n }\n }\n\n // Different options offset\n const prevColumn = () => {\n if (validActiveValueCells.length > 1) {\n const nextActiveCells = validActiveValueCells.slice(0, -1)\n internalSetActiveValueCells(nextActiveCells)\n } else {\n toggleOpen(false)\n }\n }\n\n const nextColumn = () => {\n const nextOptions: DefaultOptionType[] =\n lastActiveOptions[lastActiveIndex]?.[fieldNames.children] || []\n\n const nextOption = nextOptions.find((option) => !option.disabled)\n\n if (nextOption) {\n const nextActiveCells = [...validActiveValueCells, nextOption[fieldNames.value]]\n internalSetActiveValueCells(nextActiveCells)\n }\n }\n\n React.useImperativeHandle(ref, () => ({\n // scrollTo: treeRef.current?.scrollTo,\n onKeyDown: (event) => {\n const { which } = event\n\n switch (which) {\n // >>> Arrow keys\n case KeyCode.UP:\n case KeyCode.DOWN: {\n let offset = 0\n if (which === KeyCode.UP) {\n offset = -1\n } else if (which === KeyCode.DOWN) {\n offset = 1\n }\n\n if (offset !== 0) {\n offsetActiveOption(offset)\n }\n\n break\n }\n\n case KeyCode.LEFT: {\n if (rtl) {\n nextColumn()\n } else {\n prevColumn()\n }\n break\n }\n\n case KeyCode.RIGHT: {\n if (rtl) {\n prevColumn()\n } else {\n nextColumn()\n }\n break\n }\n\n case KeyCode.BACKSPACE: {\n if (!searchValue) {\n prevColumn()\n }\n break\n }\n\n // >>> Select\n case KeyCode.ENTER: {\n if (validActiveValueCells.length) {\n const option = lastActiveOptions[lastActiveIndex]\n\n // Search option should revert back of origin options\n const originOptions: DefaultOptionType[] = option?.[SEARCH_MARK] || []\n if (originOptions.length) {\n onKeyBoardSelect(\n originOptions.map((opt) => opt[fieldNames.value]),\n originOptions[originOptions.length - 1]\n )\n } else {\n onKeyBoardSelect(validActiveValueCells, lastActiveOptions[lastActiveIndex])\n }\n }\n break\n }\n\n // >>> Close\n case KeyCode.ESC: {\n toggleOpen(false)\n\n if (open) {\n event.stopPropagation()\n }\n }\n }\n },\n onKeyUp: () => {},\n }))\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../src/tntd-cascader/rc-cascader/context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AA+B9B,MAAM,eAAe,GAAG,KAAK,CAAC,aAAa,CAA8B,IAAI,CAAC,CAAA;AAE9E,eAAe,eAAe,CAAA","sourcesContent":["import * as React from 'react'\nimport type {\n CascaderProps,\n InternalFieldNames,\n DefaultOptionType,\n SingleValueType,\n} from './Cascader'\n\nexport interface RenderItem {\n label: any\n value: any\n}\n\nexport interface CascaderContextProps {\n options: CascaderProps['options']\n fieldNames: InternalFieldNames\n values: SingleValueType[]\n halfValues: SingleValueType[]\n changeOnSelect?: boolean\n onSelect: (valuePath: SingleValueType) => void\n checkable?: boolean | React.ReactNode\n searchOptions: DefaultOptionType[]\n dropdownPrefixCls?: string\n loadData?: (selectOptions: DefaultOptionType[]) => void\n expandTrigger?: 'hover' | 'click'\n expandIcon?: React.ReactNode\n loadingIcon?: React.ReactNode\n dropdownMenuColumnStyle?: React.CSSProperties\n renderItem?: (item: RenderItem) => React.ReactNode\n}\n\nconst CascaderContext = React.createContext<CascaderContextProps | null>(null)\n\nexport default CascaderContext\n"]}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import { toPathOptions } from '../utils/treeUtil';
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import { toPathKey } from '../utils/commonUtil';
|
|
5
|
+
export default (rawValues, options, fieldNames, multiple, displayRender) => {
|
|
6
|
+
return React.useMemo(() => {
|
|
7
|
+
const mergedDisplayRender = displayRender ||
|
|
8
|
+
// Default displayRender
|
|
9
|
+
((labels) => {
|
|
10
|
+
const mergedLabels = multiple ? labels.slice(-1) : labels;
|
|
11
|
+
const SPLIT = ' / ';
|
|
12
|
+
if (mergedLabels.every((label) => ['string', 'number'].includes(typeof label))) {
|
|
13
|
+
return mergedLabels.join(SPLIT);
|
|
14
|
+
}
|
|
15
|
+
// If exist non-string value, use ReactNode instead
|
|
16
|
+
return mergedLabels.reduce((list, label, index) => {
|
|
17
|
+
const keyedLabel = React.isValidElement(label)
|
|
18
|
+
? React.cloneElement(label, { key: index })
|
|
19
|
+
: label;
|
|
20
|
+
if (index === 0) {
|
|
21
|
+
return [keyedLabel];
|
|
22
|
+
}
|
|
23
|
+
return [...list, SPLIT, keyedLabel];
|
|
24
|
+
}, []);
|
|
25
|
+
});
|
|
26
|
+
return rawValues.map((valueCells) => {
|
|
27
|
+
var _a, _b;
|
|
28
|
+
const valueOptions = toPathOptions(valueCells, options, fieldNames);
|
|
29
|
+
const label = mergedDisplayRender(valueOptions.map(({ option, value }) => { var _a; return (_a = option === null || option === void 0 ? void 0 : option[fieldNames.label]) !== null && _a !== void 0 ? _a : value; }), valueOptions.map(({ option }) => option));
|
|
30
|
+
const value = toPathKey(valueCells);
|
|
31
|
+
return {
|
|
32
|
+
label,
|
|
33
|
+
value,
|
|
34
|
+
key: value,
|
|
35
|
+
valueCells,
|
|
36
|
+
disabled: (_b = (_a = valueOptions[valueOptions.length - 1]) === null || _a === void 0 ? void 0 : _a.option) === null || _b === void 0 ? void 0 : _b.disabled,
|
|
37
|
+
};
|
|
38
|
+
});
|
|
39
|
+
}, [rawValues, options, fieldNames, displayRender, multiple]);
|
|
40
|
+
};
|
|
41
|
+
//# sourceMappingURL=useDisplayValues.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDisplayValues.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/hooks/useDisplayValues.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACjD,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAO9B,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAE/C,eAAe,CACb,SAA4B,EAC5B,OAA4B,EAC5B,UAA8B,EAC9B,QAAiB,EACjB,aAA6C,EAC7C,EAAE;IACF,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACxB,MAAM,mBAAmB,GACvB,aAAa;YACb,wBAAwB;YACxB,CAAC,CAAC,MAAM,EAAE,EAAE;gBACV,MAAM,YAAY,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAA;gBACzD,MAAM,KAAK,GAAG,KAAK,CAAA;gBAEnB,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,OAAO,KAAK,CAAC,CAAC,EAAE;oBAC9E,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;iBAChC;gBAED,mDAAmD;gBACnD,OAAO,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;oBAChD,MAAM,UAAU,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC;wBAC5C,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;wBAC3C,CAAC,CAAC,KAAK,CAAA;oBAET,IAAI,KAAK,KAAK,CAAC,EAAE;wBACf,OAAO,CAAC,UAAU,CAAC,CAAA;qBACpB;oBAED,OAAO,CAAC,GAAG,IAAI,EAAE,KAAK,EAAE,UAAU,CAAC,CAAA;gBACrC,CAAC,EAAE,EAAE,CAAC,CAAA;YACR,CAAC,CAAC,CAAA;QAEJ,OAAO,SAAS,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;;YAClC,MAAM,YAAY,GAAG,aAAa,CAAC,UAAU,EAAE,OAAO,EAAE,UAAU,CAAC,CAAA;YAEnE,MAAM,KAAK,GAAG,mBAAmB,CAC/B,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,WAAC,OAAA,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,UAAU,CAAC,KAAK,CAAC,mCAAI,KAAK,CAAA,EAAA,CAAC,EAC5E,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,CACzC,CAAA;YAED,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAA;YAEnC,OAAO;gBACL,KAAK;gBACL,KAAK;gBACL,GAAG,EAAE,KAAK;gBACV,UAAU;gBACV,QAAQ,EAAE,MAAA,MAAA,YAAY,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,0CAAE,MAAM,0CAAE,QAAQ;aAClE,CAAA;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC,CAAA;AAC/D,CAAC,CAAA","sourcesContent":["// @ts-nocheck\nimport { toPathOptions } from '../utils/treeUtil'\nimport * as React from 'react'\nimport type {\n DefaultOptionType,\n SingleValueType,\n CascaderProps,\n InternalFieldNames,\n} from '../Cascader'\nimport { toPathKey } from '../utils/commonUtil'\n\nexport default (\n rawValues: SingleValueType[],\n options: DefaultOptionType[],\n fieldNames: InternalFieldNames,\n multiple: boolean,\n displayRender: CascaderProps['displayRender']\n) => {\n return React.useMemo(() => {\n const mergedDisplayRender =\n displayRender ||\n // Default displayRender\n ((labels) => {\n const mergedLabels = multiple ? labels.slice(-1) : labels\n const SPLIT = ' / '\n\n if (mergedLabels.every((label) => ['string', 'number'].includes(typeof label))) {\n return mergedLabels.join(SPLIT)\n }\n\n // If exist non-string value, use ReactNode instead\n return mergedLabels.reduce((list, label, index) => {\n const keyedLabel = React.isValidElement(label)\n ? React.cloneElement(label, { key: index })\n : label\n\n if (index === 0) {\n return [keyedLabel]\n }\n\n return [...list, SPLIT, keyedLabel]\n }, [])\n })\n\n return rawValues.map((valueCells) => {\n const valueOptions = toPathOptions(valueCells, options, fieldNames)\n\n const label = mergedDisplayRender(\n valueOptions.map(({ option, value }) => option?.[fieldNames.label] ?? value),\n valueOptions.map(({ option }) => option)\n )\n\n const value = toPathKey(valueCells)\n\n return {\n label,\n value,\n key: value,\n valueCells,\n disabled: valueOptions[valueOptions.length - 1]?.option?.disabled,\n }\n })\n }, [rawValues, options, fieldNames, displayRender, multiple])\n}\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { convertDataToEntities } from 'rc-tree/lib/utils/treeUtil';
|
|
4
|
+
import { VALUE_SPLIT } from '../utils/commonUtil';
|
|
5
|
+
/** Lazy parse options data into conduct-able info to avoid perf issue in single mode */
|
|
6
|
+
export default (options, fieldNames) => {
|
|
7
|
+
const cacheRef = React.useRef({
|
|
8
|
+
options: null,
|
|
9
|
+
info: null,
|
|
10
|
+
});
|
|
11
|
+
const getEntities = React.useCallback(() => {
|
|
12
|
+
if (cacheRef.current.options !== options) {
|
|
13
|
+
cacheRef.current.options = options;
|
|
14
|
+
cacheRef.current.info = convertDataToEntities(options, {
|
|
15
|
+
fieldNames,
|
|
16
|
+
initWrapper: (wrapper) => (Object.assign(Object.assign({}, wrapper), { pathKeyEntities: {} })),
|
|
17
|
+
processEntity: (entity, wrapper) => {
|
|
18
|
+
const pathKey = entity.nodes.map((node) => node[fieldNames.value]).join(VALUE_SPLIT);
|
|
19
|
+
wrapper.pathKeyEntities[pathKey] = entity;
|
|
20
|
+
// Overwrite origin key.
|
|
21
|
+
// this is very hack but we need let conduct logic work with connect path
|
|
22
|
+
entity.key = pathKey;
|
|
23
|
+
},
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
return cacheRef.current.info.pathKeyEntities;
|
|
27
|
+
}, [fieldNames, options]);
|
|
28
|
+
return getEntities;
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=useEntities.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useEntities.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/hooks/useEntities.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAA;AAGlE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AASjD,wFAAwF;AACxF,eAAe,CAAC,OAA4B,EAAE,UAA8B,EAAE,EAAE;IAC9E,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAG1B;QACD,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,IAAI;KACX,CAAC,CAAA;IAEF,MAAM,WAAW,GAAgB,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QACtD,IAAI,QAAQ,CAAC,OAAO,CAAC,OAAO,KAAK,OAAO,EAAE;YACxC,QAAQ,CAAC,OAAO,CAAC,OAAO,GAAG,OAAO,CAAA;YAClC,QAAQ,CAAC,OAAO,CAAC,IAAI,GAAG,qBAAqB,CAAC,OAAc,EAAE;gBAC5D,UAAU;gBACV,WAAW,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,iCACrB,OAAO,KACV,eAAe,EAAE,EAAE,IACnB;gBACF,aAAa,EAAE,CAAC,MAAM,EAAE,OAAY,EAAE,EAAE;oBACtC,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;oBAEpF,OAAO,CAAC,eAAe,CAAC,OAAO,CAAC,GAAG,MAAM,CAAA;oBAEzC,wBAAwB;oBACxB,yEAAyE;oBACzE,MAAM,CAAC,GAAG,GAAG,OAAO,CAAA;gBACtB,CAAC;aACF,CAAQ,CAAA;SACV;QAED,OAAO,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAA;IAC9C,CAAC,EAAE,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,CAAA;IAEzB,OAAO,WAAW,CAAA;AACpB,CAAC,CAAA","sourcesContent":["// @ts-nocheck\nimport * as React from 'react'\nimport { convertDataToEntities } from 'rc-tree/lib/utils/treeUtil'\nimport type { DefaultOptionType, InternalFieldNames } from '../Cascader'\nimport type { DataEntity } from 'rc-tree/lib/interface'\nimport { VALUE_SPLIT } from '../utils/commonUtil'\n\nexport interface OptionsInfo {\n keyEntities: Record<string, DataEntity>\n pathKeyEntities: Record<string, DataEntity>\n}\n\nexport type GetEntities = () => OptionsInfo['pathKeyEntities']\n\n/** Lazy parse options data into conduct-able info to avoid perf issue in single mode */\nexport default (options: DefaultOptionType[], fieldNames: InternalFieldNames) => {\n const cacheRef = React.useRef<{\n options: DefaultOptionType[]\n info: OptionsInfo\n }>({\n options: null,\n info: null,\n })\n\n const getEntities: GetEntities = React.useCallback(() => {\n if (cacheRef.current.options !== options) {\n cacheRef.current.options = options\n cacheRef.current.info = convertDataToEntities(options as any, {\n fieldNames,\n initWrapper: (wrapper) => ({\n ...wrapper,\n pathKeyEntities: {},\n }),\n processEntity: (entity, wrapper: any) => {\n const pathKey = entity.nodes.map((node) => node[fieldNames.value]).join(VALUE_SPLIT)\n\n wrapper.pathKeyEntities[pathKey] = entity\n\n // Overwrite origin key.\n // this is very hack but we need let conduct logic work with connect path\n entity.key = pathKey\n },\n }) as any\n }\n\n return cacheRef.current.info.pathKeyEntities\n }, [fieldNames, options])\n\n return getEntities\n}\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { toPathOptions } from '../utils/treeUtil';
|
|
3
|
+
export default (options, fieldNames) => {
|
|
4
|
+
return React.useCallback((rawValues) => {
|
|
5
|
+
const missingValues = [];
|
|
6
|
+
const existsValues = [];
|
|
7
|
+
rawValues.forEach((valueCell) => {
|
|
8
|
+
const pathOptions = toPathOptions(valueCell, options, fieldNames);
|
|
9
|
+
if (pathOptions.every((opt) => opt.option)) {
|
|
10
|
+
existsValues.push(valueCell);
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
missingValues.push(valueCell);
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
return [existsValues, missingValues];
|
|
17
|
+
}, [options, fieldNames]);
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=useMissingValues.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useMissingValues.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/hooks/useMissingValues.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAEjD,eAAe,CAAC,OAA4B,EAAE,UAA8B,EAAE,EAAE;IAC9E,OAAO,KAAK,CAAC,WAAW,CACtB,CAAC,SAA4B,EAA0C,EAAE;QACvE,MAAM,aAAa,GAAsB,EAAE,CAAA;QAC3C,MAAM,YAAY,GAAsB,EAAE,CAAA;QAE1C,SAAS,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAC9B,MAAM,WAAW,GAAG,aAAa,CAAC,SAAS,EAAE,OAAO,EAAE,UAAU,CAAC,CAAA;YACjE,IAAI,WAAW,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;gBAC1C,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;aAC7B;iBAAM;gBACL,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;aAC9B;QACH,CAAC,CAAC,CAAA;QAEF,OAAO,CAAC,YAAY,EAAE,aAAa,CAAC,CAAA;IACtC,CAAC,EACD,CAAC,OAAO,EAAE,UAAU,CAAC,CACtB,CAAA;AACH,CAAC,CAAA","sourcesContent":["import * as React from 'react'\nimport type { SingleValueType, DefaultOptionType, InternalFieldNames } from '../Cascader'\nimport { toPathOptions } from '../utils/treeUtil'\n\nexport default (options: DefaultOptionType[], fieldNames: InternalFieldNames) => {\n return React.useCallback(\n (rawValues: SingleValueType[]): [SingleValueType[], SingleValueType[]] => {\n const missingValues: SingleValueType[] = []\n const existsValues: SingleValueType[] = []\n\n rawValues.forEach((valueCell) => {\n const pathOptions = toPathOptions(valueCell, options, fieldNames)\n if (pathOptions.every((opt) => opt.option)) {\n existsValues.push(valueCell)\n } else {\n missingValues.push(valueCell)\n }\n })\n\n return [existsValues, missingValues]\n },\n [options, fieldNames]\n )\n}\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
/**
|
|
4
|
+
* Same as `React.useCallback` but always return a memoized function
|
|
5
|
+
* but redirect to real function.
|
|
6
|
+
*/
|
|
7
|
+
export default function useRefFunc(callback) {
|
|
8
|
+
const funcRef = React.useRef();
|
|
9
|
+
funcRef.current = callback;
|
|
10
|
+
const cacheFn = React.useCallback((...args) => {
|
|
11
|
+
return funcRef.current(...args);
|
|
12
|
+
}, []);
|
|
13
|
+
return cacheFn;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=useRefFunc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useRefFunc.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/hooks/useRefFunc.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B;;;GAGG;AACH,MAAM,CAAC,OAAO,UAAU,UAAU,CAAoC,QAAW;IAC/E,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,EAAK,CAAA;IACjC,OAAO,CAAC,OAAO,GAAG,QAAQ,CAAA;IAE1B,MAAM,OAAO,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,GAAG,IAAW,EAAE,EAAE;QACnD,OAAO,OAAO,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,CAAA;IACjC,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,OAAc,CAAA;AACvB,CAAC","sourcesContent":["// @ts-nocheck\nimport * as React from 'react'\n\n/**\n * Same as `React.useCallback` but always return a memoized function\n * but redirect to real function.\n */\nexport default function useRefFunc<T extends (...args: any[]) => any>(callback: T): T {\n const funcRef = React.useRef<T>()\n funcRef.current = callback\n\n const cacheFn = React.useCallback((...args: any[]) => {\n return funcRef.current(...args)\n }, [])\n\n return cacheFn as any\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import warning from 'rc-util/lib/warning';
|
|
4
|
+
// Convert `showSearch` to unique config
|
|
5
|
+
export default function useSearchConfig(showSearch) {
|
|
6
|
+
return React.useMemo(() => {
|
|
7
|
+
if (!showSearch) {
|
|
8
|
+
return [false, {}];
|
|
9
|
+
}
|
|
10
|
+
let searchConfig = {
|
|
11
|
+
matchInputWidth: true,
|
|
12
|
+
limit: 50,
|
|
13
|
+
};
|
|
14
|
+
if (showSearch && typeof showSearch === 'object') {
|
|
15
|
+
searchConfig = Object.assign(Object.assign({}, searchConfig), showSearch);
|
|
16
|
+
}
|
|
17
|
+
if (searchConfig.limit <= 0) {
|
|
18
|
+
delete searchConfig.limit;
|
|
19
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
20
|
+
warning(false, "'limit' of showSearch should be positive number or false.");
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
return [true, searchConfig];
|
|
24
|
+
}, [showSearch]);
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=useSearchConfig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useSearchConfig.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/hooks/useSearchConfig.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,OAAO,MAAM,qBAAqB,CAAA;AAGzC,wCAAwC;AACxC,MAAM,CAAC,OAAO,UAAU,eAAe,CAAC,UAAwC;IAC9E,OAAO,KAAK,CAAC,OAAO,CAA4B,GAAG,EAAE;QACnD,IAAI,CAAC,UAAU,EAAE;YACf,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;SACnB;QAED,IAAI,YAAY,GAAmB;YACjC,eAAe,EAAE,IAAI;YACrB,KAAK,EAAE,EAAE;SACV,CAAA;QAED,IAAI,UAAU,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;YAChD,YAAY,mCACP,YAAY,GACZ,UAAU,CACd,CAAA;SACF;QAED,IAAI,YAAY,CAAC,KAAK,IAAI,CAAC,EAAE;YAC3B,OAAO,YAAY,CAAC,KAAK,CAAA;YAEzB,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,EAAE;gBACzC,OAAO,CAAC,KAAK,EAAE,2DAA2D,CAAC,CAAA;aAC5E;SACF;QAED,OAAO,CAAC,IAAI,EAAE,YAAY,CAAC,CAAA;IAC7B,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAA;AAClB,CAAC","sourcesContent":["// @ts-nocheck\nimport * as React from 'react'\nimport warning from 'rc-util/lib/warning'\nimport type { CascaderProps, ShowSearchType } from '../Cascader'\n\n// Convert `showSearch` to unique config\nexport default function useSearchConfig(showSearch?: CascaderProps['showSearch']) {\n return React.useMemo<[boolean, ShowSearchType]>(() => {\n if (!showSearch) {\n return [false, {}]\n }\n\n let searchConfig: ShowSearchType = {\n matchInputWidth: true,\n limit: 50,\n }\n\n if (showSearch && typeof showSearch === 'object') {\n searchConfig = {\n ...searchConfig,\n ...showSearch,\n }\n }\n\n if (searchConfig.limit <= 0) {\n delete searchConfig.limit\n\n if (process.env.NODE_ENV !== 'production') {\n warning(false, \"'limit' of showSearch should be positive number or false.\")\n }\n }\n\n return [true, searchConfig]\n }, [showSearch])\n}\n"]}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export const SEARCH_MARK = '__rc_cascader_search_mark__';
|
|
3
|
+
const defaultFilter = (search, options, { label }) => options.some((opt) => String(opt[label]).toLowerCase().includes(search.toLowerCase()));
|
|
4
|
+
const defaultRender = (inputValue, path, prefixCls, fieldNames) => path.map((opt) => opt[fieldNames.label]).join(' / ');
|
|
5
|
+
export default (search, options, fieldNames, prefixCls, config, changeOnSelect) => {
|
|
6
|
+
const { filter = defaultFilter, render = defaultRender, limit = 50, sort } = config;
|
|
7
|
+
return React.useMemo(() => {
|
|
8
|
+
const filteredOptions = [];
|
|
9
|
+
if (!search) {
|
|
10
|
+
return [];
|
|
11
|
+
}
|
|
12
|
+
function dig(list, pathOptions) {
|
|
13
|
+
list.forEach((option) => {
|
|
14
|
+
// Perf saving when `sort` is disabled and `limit` is provided
|
|
15
|
+
if (!sort && limit > 0 && filteredOptions.length >= limit) {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
const connectedPathOptions = [...pathOptions, option];
|
|
19
|
+
const children = option[fieldNames.children];
|
|
20
|
+
// If current option is filterable
|
|
21
|
+
if (
|
|
22
|
+
// If is leaf option
|
|
23
|
+
!children ||
|
|
24
|
+
children.length === 0 ||
|
|
25
|
+
// If is changeOnSelect
|
|
26
|
+
changeOnSelect) {
|
|
27
|
+
if (filter(search, connectedPathOptions, { label: fieldNames.label })) {
|
|
28
|
+
filteredOptions.push(Object.assign(Object.assign({}, option), { [fieldNames.label]: render(search, connectedPathOptions, prefixCls, fieldNames), [SEARCH_MARK]: connectedPathOptions }));
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
if (children) {
|
|
32
|
+
dig(option[fieldNames.children], connectedPathOptions);
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
dig(options, []);
|
|
37
|
+
// Do sort
|
|
38
|
+
if (sort) {
|
|
39
|
+
filteredOptions.sort((a, b) => {
|
|
40
|
+
return sort(a[SEARCH_MARK], b[SEARCH_MARK], search, fieldNames);
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
return limit > 0 ? filteredOptions.slice(0, limit) : filteredOptions;
|
|
44
|
+
}, [search, options, fieldNames, prefixCls, render, changeOnSelect, filter, sort, limit]);
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=useSearchOptions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useSearchOptions.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/hooks/useSearchOptions.ts"],"names":[],"mappings":"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","sourcesContent":["// @ts-nocheck\nimport type { DefaultOptionType, ShowSearchType, InternalFieldNames } from '../Cascader'\nimport * as React from 'react'\n\nexport const SEARCH_MARK = '__rc_cascader_search_mark__'\n\nconst defaultFilter: ShowSearchType['filter'] = (search, options, { label }) =>\n options.some((opt) => String(opt[label]).toLowerCase().includes(search.toLowerCase()))\n\nconst defaultRender: ShowSearchType['render'] = (inputValue, path, prefixCls, fieldNames) =>\n path.map((opt) => opt[fieldNames.label]).join(' / ')\n\nexport default (\n search: string,\n options: DefaultOptionType[],\n fieldNames: InternalFieldNames,\n prefixCls: string,\n config: ShowSearchType,\n changeOnSelect: boolean\n) => {\n const { filter = defaultFilter, render = defaultRender, limit = 50, sort } = config\n\n return React.useMemo(() => {\n const filteredOptions: DefaultOptionType[] = []\n if (!search) {\n return []\n }\n\n function dig(list: DefaultOptionType[], pathOptions: DefaultOptionType[]) {\n list.forEach((option) => {\n // Perf saving when `sort` is disabled and `limit` is provided\n if (!sort && limit > 0 && filteredOptions.length >= limit) {\n return\n }\n\n const connectedPathOptions = [...pathOptions, option]\n const children = option[fieldNames.children]\n\n // If current option is filterable\n if (\n // If is leaf option\n !children ||\n children.length === 0 ||\n // If is changeOnSelect\n changeOnSelect\n ) {\n if (filter(search, connectedPathOptions, { label: fieldNames.label })) {\n filteredOptions.push({\n ...option,\n [fieldNames.label as 'label']: render(\n search,\n connectedPathOptions,\n prefixCls,\n fieldNames\n ),\n [SEARCH_MARK]: connectedPathOptions,\n })\n }\n }\n\n if (children) {\n dig(option[fieldNames.children] as DefaultOptionType[], connectedPathOptions)\n }\n })\n }\n\n dig(options, [])\n\n // Do sort\n if (sort) {\n filteredOptions.sort((a, b) => {\n return sort(a[SEARCH_MARK], b[SEARCH_MARK], search, fieldNames)\n })\n }\n\n return limit > 0 ? filteredOptions.slice(0, limit as number) : filteredOptions\n }, [search, options, fieldNames, prefixCls, render, changeOnSelect, filter, sort, limit])\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tntd-cascader/rc-cascader/index.tsx"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,YAAY,CAAA;AAWjC,eAAe,QAAQ,CAAA","sourcesContent":["import Cascader from './Cascader'\n\nexport type {\n CascaderProps,\n FieldNames,\n ShowSearchType,\n DefaultOptionType,\n BaseOptionType,\n SingleCascaderProps,\n MultipleCascaderProps,\n} from './Cascader'\nexport default Cascader\n"]}
|