tntd 2.7.23 → 2.7.25
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/index.js +1 -0
- package/es/index.js.map +1 -1
- package/es/locale/en_US.js +21 -3
- package/es/locale/en_US.js.map +1 -1
- package/es/locale/zh_CN.js +4 -1
- package/es/locale/zh_CN.js.map +1 -1
- package/es/table/context.js.map +1 -1
- package/es/table/table.js +3 -2
- package/es/table/table.js.map +1 -1
- package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +1 -1
- package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
- package/es/tntd-rc-select/_util/DisabledContext.js +8 -0
- package/es/tntd-rc-select/_util/DisabledContext.js.map +1 -0
- package/es/tntd-rc-select/_util/FormItemInputContext.js +3 -0
- package/es/tntd-rc-select/_util/FormItemInputContext.js.map +1 -0
- package/es/tntd-rc-select/_util/PurePanel.js +55 -0
- package/es/tntd-rc-select/_util/PurePanel.js.map +1 -0
- package/es/tntd-rc-select/_util/SizeContext.js +3 -0
- package/es/tntd-rc-select/_util/SizeContext.js.map +1 -0
- package/es/tntd-rc-select/_util/context.js +14 -0
- package/es/tntd-rc-select/_util/context.js.map +1 -0
- package/es/tntd-rc-select/_util/defaultRenderEmpty.js +20 -0
- package/es/tntd-rc-select/_util/defaultRenderEmpty.js.map +1 -0
- package/es/tntd-rc-select/_util/getIcons.js +52 -0
- package/es/tntd-rc-select/_util/getIcons.js.map +1 -0
- package/es/tntd-rc-select/_util/interface.js +5 -0
- package/es/tntd-rc-select/_util/interface.js.map +1 -0
- package/es/tntd-rc-select/_util/motion.js +38 -0
- package/es/tntd-rc-select/_util/motion.js.map +1 -0
- package/es/tntd-rc-select/_util/type.js +4 -0
- package/es/tntd-rc-select/_util/type.js.map +1 -0
- package/es/tntd-rc-select/_util/useCompactItemContext.js +24 -0
- package/es/tntd-rc-select/_util/useCompactItemContext.js.map +1 -0
- package/es/tntd-rc-select/_util/warning.js +15 -0
- package/es/tntd-rc-select/_util/warning.js.map +1 -0
- package/es/tntd-rc-select/img/no-data-s.png +0 -0
- package/es/tntd-rc-select/index.js +103 -0
- package/es/tntd-rc-select/index.js.map +1 -0
- package/es/tntd-rc-select/style/index.less +1657 -0
- package/es/tntd-select/_util/DisabledContext.js +8 -0
- package/es/tntd-select/_util/DisabledContext.js.map +1 -0
- package/es/tntd-select/_util/FormItemInputContext.js +3 -0
- package/es/tntd-select/_util/FormItemInputContext.js.map +1 -0
- package/es/tntd-select/_util/PurePanel.js +4 -17
- package/es/tntd-select/_util/PurePanel.js.map +1 -1
- package/es/tntd-select/_util/SizeContext.js +3 -0
- package/es/tntd-select/_util/SizeContext.js.map +1 -0
- package/es/tntd-select/_util/context.js +14 -0
- package/es/tntd-select/_util/context.js.map +1 -0
- package/es/tntd-select/_util/defaultRenderEmpty.js +20 -0
- package/es/tntd-select/_util/defaultRenderEmpty.js.map +1 -0
- package/es/tntd-select/_util/getIcons.js +52 -0
- package/es/tntd-select/_util/getIcons.js.map +1 -0
- package/es/tntd-select/_util/interface.js +5 -0
- package/es/tntd-select/_util/interface.js.map +1 -0
- package/es/tntd-select/_util/motion.js +15 -8
- package/es/tntd-select/_util/motion.js.map +1 -1
- package/es/tntd-select/_util/type.js +4 -0
- package/es/tntd-select/_util/type.js.map +1 -0
- package/es/tntd-select/_util/useCompactItemContext.js +24 -0
- package/es/tntd-select/_util/useCompactItemContext.js.map +1 -0
- package/es/tntd-select/_util/warning.js +14 -5
- package/es/tntd-select/_util/warning.js.map +1 -1
- package/es/tntd-select/index.js +7 -1
- package/es/tntd-select/index.js.map +1 -1
- package/es/tntd-select/rc-select/BaseSelect.js +429 -0
- package/es/tntd-select/rc-select/BaseSelect.js.map +1 -0
- package/es/tntd-select/rc-select/OptGroup.js +5 -0
- package/es/tntd-select/rc-select/OptGroup.js.map +1 -0
- package/es/tntd-select/rc-select/Option.js +5 -0
- package/es/tntd-select/rc-select/Option.js.map +1 -0
- package/es/tntd-select/rc-select/OptionList.js +257 -0
- package/es/tntd-select/rc-select/OptionList.js.map +1 -0
- package/es/tntd-select/rc-select/Select.js +428 -0
- package/es/tntd-select/rc-select/Select.js.map +1 -0
- package/es/tntd-select/rc-select/SelectContext.js +4 -0
- package/es/tntd-select/rc-select/SelectContext.js.map +1 -0
- package/es/tntd-select/rc-select/SelectTrigger.js +91 -0
- package/es/tntd-select/rc-select/SelectTrigger.js.map +1 -0
- package/es/tntd-select/rc-select/Selector/Input.js +47 -0
- package/es/tntd-select/rc-select/Selector/Input.js.map +1 -0
- package/es/tntd-select/rc-select/Selector/MultipleSelector.js +97 -0
- package/es/tntd-select/rc-select/Selector/MultipleSelector.js.map +1 -0
- package/es/tntd-select/rc-select/Selector/SingleSelector.js +45 -0
- package/es/tntd-select/rc-select/Selector/SingleSelector.js.map +1 -0
- package/es/tntd-select/rc-select/Selector/index.js +136 -0
- package/es/tntd-select/rc-select/Selector/index.js.map +1 -0
- package/es/tntd-select/rc-select/TransBtn.js +22 -0
- package/es/tntd-select/rc-select/TransBtn.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useAllowClear.js +25 -0
- package/es/tntd-select/rc-select/hooks/useAllowClear.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useBaseProps.js +10 -0
- package/es/tntd-select/rc-select/hooks/useBaseProps.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useCache.js +34 -0
- package/es/tntd-select/rc-select/hooks/useCache.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useDelayReset.js +24 -0
- package/es/tntd-select/rc-select/hooks/useDelayReset.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useFilterOptions.js +55 -0
- package/es/tntd-select/rc-select/hooks/useFilterOptions.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useId.js +28 -0
- package/es/tntd-select/rc-select/hooks/useId.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useLayoutEffect.js +18 -0
- package/es/tntd-select/rc-select/hooks/useLayoutEffect.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useLock.js +26 -0
- package/es/tntd-select/rc-select/hooks/useLock.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useOptions.js +45 -0
- package/es/tntd-select/rc-select/hooks/useOptions.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useRefFunc.js +14 -0
- package/es/tntd-select/rc-select/hooks/useRefFunc.js.map +1 -0
- package/es/tntd-select/rc-select/hooks/useSelectTriggerControl.js +32 -0
- package/es/tntd-select/rc-select/hooks/useSelectTriggerControl.js.map +1 -0
- package/es/tntd-select/rc-select/index.js +8 -0
- package/es/tntd-select/rc-select/index.js.map +1 -0
- package/es/tntd-select/rc-select/interface.js +2 -0
- package/es/tntd-select/rc-select/interface.js.map +1 -0
- package/es/tntd-select/rc-select/utils/commonUtil.js +32 -0
- package/es/tntd-select/rc-select/utils/commonUtil.js.map +1 -0
- package/es/tntd-select/rc-select/utils/keyUtil.js +34 -0
- package/es/tntd-select/rc-select/utils/keyUtil.js.map +1 -0
- package/es/tntd-select/rc-select/utils/legacyUtil.js +32 -0
- package/es/tntd-select/rc-select/utils/legacyUtil.js.map +1 -0
- package/es/tntd-select/rc-select/utils/platformUtil.js +5 -0
- package/es/tntd-select/rc-select/utils/platformUtil.js.map +1 -0
- package/es/tntd-select/rc-select/utils/valueUtil.js +99 -0
- package/es/tntd-select/rc-select/utils/valueUtil.js.map +1 -0
- package/es/tntd-select/rc-select/utils/warningPropsUtil.js +100 -0
- package/es/tntd-select/rc-select/utils/warningPropsUtil.js.map +1 -0
- 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 +4 -1
- package/lib/locale/default.d.ts.map +1 -1
- package/lib/locale/en_US.d.ts +11 -1
- package/lib/locale/en_US.d.ts.map +1 -1
- package/lib/locale/en_US.js +21 -3
- package/lib/locale/en_US.js.map +1 -1
- package/lib/locale/zh_CN.d.ts +4 -1
- package/lib/locale/zh_CN.d.ts.map +1 -1
- package/lib/locale/zh_CN.js +4 -1
- package/lib/locale/zh_CN.js.map +1 -1
- package/lib/table/context.d.ts +1 -0
- package/lib/table/context.d.ts.map +1 -1
- package/lib/table/context.js.map +1 -1
- package/lib/table/table.d.ts +2 -1
- package/lib/table/table.d.ts.map +1 -1
- package/lib/table/table.js +3 -2
- package/lib/table/table.js.map +1 -1
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +1 -1
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
- package/lib/tntd-rc-select/_util/DisabledContext.d.ts +10 -0
- package/lib/tntd-rc-select/_util/DisabledContext.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/DisabledContext.js +35 -0
- package/lib/tntd-rc-select/_util/DisabledContext.js.map +1 -0
- package/lib/tntd-rc-select/_util/FormItemInputContext.d.ts +4 -0
- package/lib/tntd-rc-select/_util/FormItemInputContext.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/FormItemInputContext.js +29 -0
- package/lib/tntd-rc-select/_util/FormItemInputContext.js.map +1 -0
- package/lib/tntd-rc-select/_util/PurePanel.d.ts +9 -0
- package/lib/tntd-rc-select/_util/PurePanel.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/PurePanel.js +84 -0
- package/lib/tntd-rc-select/_util/PurePanel.js.map +1 -0
- package/lib/tntd-rc-select/_util/SizeContext.d.ts +4 -0
- package/lib/tntd-rc-select/_util/SizeContext.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/SizeContext.js +29 -0
- package/lib/tntd-rc-select/_util/SizeContext.js.map +1 -0
- package/lib/tntd-rc-select/_util/context.d.ts +42 -0
- package/lib/tntd-rc-select/_util/context.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/context.js +20 -0
- package/lib/tntd-rc-select/_util/context.js.map +1 -0
- package/lib/tntd-rc-select/_util/defaultRenderEmpty.d.ts +5 -0
- package/lib/tntd-rc-select/_util/defaultRenderEmpty.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/defaultRenderEmpty.js +48 -0
- package/lib/tntd-rc-select/_util/defaultRenderEmpty.js.map +1 -0
- package/lib/tntd-rc-select/_util/getIcons.d.ts +25 -0
- package/lib/tntd-rc-select/_util/getIcons.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/getIcons.js +78 -0
- package/lib/tntd-rc-select/_util/getIcons.js.map +1 -0
- package/lib/tntd-rc-select/_util/interface.d.ts +25 -0
- package/lib/tntd-rc-select/_util/interface.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/interface.js +9 -0
- package/lib/tntd-rc-select/_util/interface.js.map +1 -0
- package/lib/tntd-rc-select/_util/motion.d.ts +9 -0
- package/lib/tntd-rc-select/_util/motion.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/motion.js +42 -0
- package/lib/tntd-rc-select/_util/motion.js.map +1 -0
- package/lib/tntd-rc-select/_util/type.d.ts +10 -0
- package/lib/tntd-rc-select/_util/type.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/type.js +9 -0
- package/lib/tntd-rc-select/_util/type.js.map +1 -0
- package/lib/tntd-rc-select/_util/useCompactItemContext.d.ts +9 -0
- package/lib/tntd-rc-select/_util/useCompactItemContext.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/useCompactItemContext.js +54 -0
- package/lib/tntd-rc-select/_util/useCompactItemContext.js.map +1 -0
- package/lib/tntd-rc-select/_util/warning.d.ts +4 -0
- package/lib/tntd-rc-select/_util/warning.d.ts.map +1 -0
- package/lib/tntd-rc-select/_util/warning.js +40 -0
- package/lib/tntd-rc-select/_util/warning.js.map +1 -0
- package/lib/tntd-rc-select/img/no-data-s.png +0 -0
- package/lib/tntd-rc-select/index.d.ts +44 -0
- package/lib/tntd-rc-select/index.d.ts.map +1 -0
- package/lib/tntd-rc-select/index.js +131 -0
- package/lib/tntd-rc-select/index.js.map +1 -0
- package/lib/tntd-rc-select/style/index.less +1657 -0
- package/lib/tntd-select/_util/DisabledContext.d.ts +10 -0
- package/lib/tntd-select/_util/DisabledContext.d.ts.map +1 -0
- package/lib/tntd-select/_util/DisabledContext.js +35 -0
- package/lib/tntd-select/_util/DisabledContext.js.map +1 -0
- package/lib/tntd-select/_util/FormItemInputContext.d.ts +4 -0
- package/lib/tntd-select/_util/FormItemInputContext.d.ts.map +1 -0
- package/lib/tntd-select/_util/FormItemInputContext.js +29 -0
- package/lib/tntd-select/_util/FormItemInputContext.js.map +1 -0
- package/lib/tntd-select/_util/PurePanel.d.ts +3 -2
- package/lib/tntd-select/_util/PurePanel.d.ts.map +1 -1
- package/lib/tntd-select/_util/PurePanel.js +4 -19
- package/lib/tntd-select/_util/PurePanel.js.map +1 -1
- package/lib/tntd-select/_util/SizeContext.d.ts +4 -0
- package/lib/tntd-select/_util/SizeContext.d.ts.map +1 -0
- package/lib/tntd-select/_util/SizeContext.js +29 -0
- package/lib/tntd-select/_util/SizeContext.js.map +1 -0
- package/lib/tntd-select/_util/context.d.ts +42 -0
- package/lib/tntd-select/_util/context.d.ts.map +1 -0
- package/lib/tntd-select/_util/context.js +20 -0
- package/lib/tntd-select/_util/context.js.map +1 -0
- package/lib/tntd-select/_util/defaultRenderEmpty.d.ts +5 -0
- package/lib/tntd-select/_util/defaultRenderEmpty.d.ts.map +1 -0
- package/lib/tntd-select/_util/defaultRenderEmpty.js +48 -0
- package/lib/tntd-select/_util/defaultRenderEmpty.js.map +1 -0
- package/lib/tntd-select/_util/getIcons.d.ts +25 -0
- package/lib/tntd-select/_util/getIcons.d.ts.map +1 -0
- package/lib/tntd-select/_util/getIcons.js +78 -0
- package/lib/tntd-select/_util/getIcons.js.map +1 -0
- package/lib/tntd-select/_util/interface.d.ts +25 -0
- package/lib/tntd-select/_util/interface.d.ts.map +1 -0
- package/lib/tntd-select/_util/interface.js +9 -0
- package/lib/tntd-select/_util/interface.js.map +1 -0
- package/lib/tntd-select/_util/motion.d.ts +5 -4
- package/lib/tntd-select/_util/motion.d.ts.map +1 -1
- package/lib/tntd-select/_util/motion.js +16 -8
- package/lib/tntd-select/_util/motion.js.map +1 -1
- package/lib/tntd-select/_util/type.d.ts +10 -0
- package/lib/tntd-select/_util/type.d.ts.map +1 -0
- package/lib/tntd-select/_util/type.js +9 -0
- package/lib/tntd-select/_util/type.js.map +1 -0
- package/lib/tntd-select/_util/useCompactItemContext.d.ts +9 -0
- package/lib/tntd-select/_util/useCompactItemContext.d.ts.map +1 -0
- package/lib/tntd-select/_util/useCompactItemContext.js +54 -0
- package/lib/tntd-select/_util/useCompactItemContext.js.map +1 -0
- package/lib/tntd-select/_util/warning.d.ts +3 -4
- package/lib/tntd-select/_util/warning.d.ts.map +1 -1
- package/lib/tntd-select/_util/warning.js +13 -5
- package/lib/tntd-select/_util/warning.js.map +1 -1
- package/lib/tntd-select/index.d.ts.map +1 -1
- package/lib/tntd-select/index.js +7 -1
- package/lib/tntd-select/index.js.map +1 -1
- package/lib/tntd-select/rc-select/BaseSelect.d.ts +114 -0
- package/lib/tntd-select/rc-select/BaseSelect.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/BaseSelect.js +459 -0
- package/lib/tntd-select/rc-select/BaseSelect.js.map +1 -0
- package/lib/tntd-select/rc-select/OptGroup.d.ts +13 -0
- package/lib/tntd-select/rc-select/OptGroup.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/OptGroup.js +7 -0
- package/lib/tntd-select/rc-select/OptGroup.js.map +1 -0
- package/lib/tntd-select/rc-select/Option.d.ts +15 -0
- package/lib/tntd-select/rc-select/Option.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/Option.js +7 -0
- package/lib/tntd-select/rc-select/Option.js.map +1 -0
- package/lib/tntd-select/rc-select/OptionList.d.ts +11 -0
- package/lib/tntd-select/rc-select/OptionList.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/OptionList.js +285 -0
- package/lib/tntd-select/rc-select/OptionList.js.map +1 -0
- package/lib/tntd-select/rc-select/Select.d.ts +115 -0
- package/lib/tntd-select/rc-select/Select.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/Select.js +456 -0
- package/lib/tntd-select/rc-select/Select.js.map +1 -0
- package/lib/tntd-select/rc-select/SelectContext.d.ts +23 -0
- package/lib/tntd-select/rc-select/SelectContext.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/SelectContext.js +29 -0
- package/lib/tntd-select/rc-select/SelectContext.js.map +1 -0
- package/lib/tntd-select/rc-select/SelectTrigger.d.ts +31 -0
- package/lib/tntd-select/rc-select/SelectTrigger.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/SelectTrigger.js +119 -0
- package/lib/tntd-select/rc-select/SelectTrigger.js.map +1 -0
- package/lib/tntd-select/rc-select/Selector/Input.d.ts +27 -0
- package/lib/tntd-select/rc-select/Selector/Input.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/Selector/Input.js +75 -0
- package/lib/tntd-select/rc-select/Selector/Input.js.map +1 -0
- package/lib/tntd-select/rc-select/Selector/MultipleSelector.d.ts +17 -0
- package/lib/tntd-select/rc-select/Selector/MultipleSelector.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/Selector/MultipleSelector.js +125 -0
- package/lib/tntd-select/rc-select/Selector/MultipleSelector.js.map +1 -0
- package/lib/tntd-select/rc-select/Selector/SingleSelector.d.ts +9 -0
- package/lib/tntd-select/rc-select/Selector/SingleSelector.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/Selector/SingleSelector.js +73 -0
- package/lib/tntd-select/rc-select/Selector/SingleSelector.js.map +1 -0
- package/lib/tntd-select/rc-select/Selector/index.d.ts +83 -0
- package/lib/tntd-select/rc-select/Selector/index.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/Selector/index.js +164 -0
- package/lib/tntd-select/rc-select/Selector/index.js.map +1 -0
- package/lib/tntd-select/rc-select/TransBtn.d.ts +13 -0
- package/lib/tntd-select/rc-select/TransBtn.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/TransBtn.js +50 -0
- package/lib/tntd-select/rc-select/TransBtn.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useAllowClear.d.ts +9 -0
- package/lib/tntd-select/rc-select/hooks/useAllowClear.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useAllowClear.js +32 -0
- package/lib/tntd-select/rc-select/hooks/useAllowClear.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useBaseProps.d.ts +14 -0
- package/lib/tntd-select/rc-select/hooks/useBaseProps.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useBaseProps.js +37 -0
- package/lib/tntd-select/rc-select/hooks/useBaseProps.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useCache.d.ts +8 -0
- package/lib/tntd-select/rc-select/hooks/useCache.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useCache.js +59 -0
- package/lib/tntd-select/rc-select/hooks/useCache.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useDelayReset.d.ts +6 -0
- package/lib/tntd-select/rc-select/hooks/useDelayReset.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useDelayReset.js +50 -0
- package/lib/tntd-select/rc-select/hooks/useDelayReset.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useFilterOptions.d.ts +4 -0
- package/lib/tntd-select/rc-select/hooks/useFilterOptions.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useFilterOptions.js +80 -0
- package/lib/tntd-select/rc-select/hooks/useFilterOptions.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useId.d.ts +6 -0
- package/lib/tntd-select/rc-select/hooks/useId.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useId.js +59 -0
- package/lib/tntd-select/rc-select/hooks/useId.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useLayoutEffect.d.ts +6 -0
- package/lib/tntd-select/rc-select/hooks/useLayoutEffect.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useLayoutEffect.js +44 -0
- package/lib/tntd-select/rc-select/hooks/useLayoutEffect.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useLock.d.ts +8 -0
- package/lib/tntd-select/rc-select/hooks/useLock.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useLock.js +52 -0
- package/lib/tntd-select/rc-select/hooks/useLock.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useOptions.d.ts +12 -0
- package/lib/tntd-select/rc-select/hooks/useOptions.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useOptions.js +71 -0
- package/lib/tntd-select/rc-select/hooks/useOptions.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useRefFunc.d.ts +6 -0
- package/lib/tntd-select/rc-select/hooks/useRefFunc.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useRefFunc.js +40 -0
- package/lib/tntd-select/rc-select/hooks/useRefFunc.js.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.d.ts +2 -0
- package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.js +58 -0
- package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.js.map +1 -0
- package/lib/tntd-select/rc-select/index.d.ts +11 -0
- package/lib/tntd-select/rc-select/index.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/index.js +17 -0
- package/lib/tntd-select/rc-select/index.js.map +1 -0
- package/lib/tntd-select/rc-select/interface.d.ts +23 -0
- package/lib/tntd-select/rc-select/interface.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/interface.js +3 -0
- package/lib/tntd-select/rc-select/interface.js.map +1 -0
- package/lib/tntd-select/rc-select/utils/commonUtil.d.ts +10 -0
- package/lib/tntd-select/rc-select/utils/commonUtil.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/utils/commonUtil.js +39 -0
- package/lib/tntd-select/rc-select/utils/commonUtil.js.map +1 -0
- package/lib/tntd-select/rc-select/utils/keyUtil.d.ts +3 -0
- package/lib/tntd-select/rc-select/utils/keyUtil.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/utils/keyUtil.js +41 -0
- package/lib/tntd-select/rc-select/utils/keyUtil.js.map +1 -0
- package/lib/tntd-select/rc-select/utils/legacyUtil.d.ts +4 -0
- package/lib/tntd-select/rc-select/utils/legacyUtil.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/utils/legacyUtil.js +62 -0
- package/lib/tntd-select/rc-select/utils/legacyUtil.js.map +1 -0
- package/lib/tntd-select/rc-select/utils/platformUtil.d.ts +2 -0
- package/lib/tntd-select/rc-select/utils/platformUtil.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/utils/platformUtil.js +9 -0
- package/lib/tntd-select/rc-select/utils/platformUtil.js.map +1 -0
- package/lib/tntd-select/rc-select/utils/valueUtil.d.ts +24 -0
- package/lib/tntd-select/rc-select/utils/valueUtil.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/utils/valueUtil.js +109 -0
- package/lib/tntd-select/rc-select/utils/valueUtil.js.map +1 -0
- package/lib/tntd-select/rc-select/utils/warningPropsUtil.d.ts +5 -0
- package/lib/tntd-select/rc-select/utils/warningPropsUtil.d.ts.map +1 -0
- package/lib/tntd-select/rc-select/utils/warningPropsUtil.js +130 -0
- package/lib/tntd-select/rc-select/utils/warningPropsUtil.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
import { composeRef } from 'rc-util/lib/ref';
|
|
4
|
+
import { warning } from 'rc-util/lib/warning';
|
|
5
|
+
const Input = ({ prefixCls, id, inputElement, disabled, tabIndex, autoFocus, autoComplete, editable, activeDescendantId, value, maxLength, onKeyDown, onMouseDown, onChange, onPaste, onCompositionStart, onCompositionEnd, open, attrs, }, ref) => {
|
|
6
|
+
var _a;
|
|
7
|
+
let inputNode = inputElement || React.createElement("input", null);
|
|
8
|
+
const { ref: originRef, props: originProps } = inputNode;
|
|
9
|
+
const { onKeyDown: onOriginKeyDown, onChange: onOriginChange, onMouseDown: onOriginMouseDown, onCompositionStart: onOriginCompositionStart, onCompositionEnd: onOriginCompositionEnd, style, } = originProps;
|
|
10
|
+
warning(!('maxLength' in inputNode.props), `Passing 'maxLength' to input element directly may not work because input in BaseSelect is controlled.`);
|
|
11
|
+
inputNode = React.cloneElement(inputNode, Object.assign(Object.assign(Object.assign(Object.assign({ type: 'search' }, originProps), {
|
|
12
|
+
// Override over origin props
|
|
13
|
+
id, ref: composeRef(ref, originRef), disabled,
|
|
14
|
+
tabIndex, autoComplete: autoComplete || 'off', autoFocus, className: classNames(`${prefixCls}-selection-search-input`, (_a = inputNode === null || inputNode === void 0 ? void 0 : inputNode.props) === null || _a === void 0 ? void 0 : _a.className), role: 'combobox', 'aria-expanded': open || false, 'aria-haspopup': 'listbox', 'aria-owns': `${id}_list`, 'aria-autocomplete': 'list', 'aria-controls': `${id}_list`, 'aria-activedescendant': open ? activeDescendantId : undefined }), attrs), { value: editable ? value : '', maxLength, readOnly: !editable, unselectable: !editable ? 'on' : null, style: Object.assign(Object.assign({}, style), { opacity: editable ? null : 0 }), onKeyDown: (event) => {
|
|
15
|
+
onKeyDown(event);
|
|
16
|
+
if (onOriginKeyDown) {
|
|
17
|
+
onOriginKeyDown(event);
|
|
18
|
+
}
|
|
19
|
+
}, onMouseDown: (event) => {
|
|
20
|
+
onMouseDown(event);
|
|
21
|
+
if (onOriginMouseDown) {
|
|
22
|
+
onOriginMouseDown(event);
|
|
23
|
+
}
|
|
24
|
+
}, onChange: (event) => {
|
|
25
|
+
onChange(event);
|
|
26
|
+
if (onOriginChange) {
|
|
27
|
+
onOriginChange(event);
|
|
28
|
+
}
|
|
29
|
+
}, onCompositionStart(event) {
|
|
30
|
+
onCompositionStart(event);
|
|
31
|
+
if (onOriginCompositionStart) {
|
|
32
|
+
onOriginCompositionStart(event);
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
onCompositionEnd(event) {
|
|
36
|
+
onCompositionEnd(event);
|
|
37
|
+
if (onOriginCompositionEnd) {
|
|
38
|
+
onOriginCompositionEnd(event);
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
onPaste }));
|
|
42
|
+
return inputNode;
|
|
43
|
+
};
|
|
44
|
+
const RefInput = React.forwardRef(Input);
|
|
45
|
+
RefInput.displayName = 'Input';
|
|
46
|
+
export default RefInput;
|
|
47
|
+
//# sourceMappingURL=Input.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Input.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/Selector/Input.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport classNames from 'classnames';\nimport { composeRef } from 'rc-util/lib/ref';\nimport { warning } from 'rc-util/lib/warning';\n\ntype InputRef = HTMLInputElement | HTMLTextAreaElement;\n\ninterface InputProps {\n prefixCls: string;\n id: string;\n inputElement: React.ReactElement;\n disabled: boolean;\n autoFocus: boolean;\n autoComplete: string;\n editable: boolean;\n activeDescendantId?: string;\n value: string;\n maxLength?: number;\n open: boolean;\n tabIndex: number;\n /** Pass accessibility props to input */\n attrs: Record<string, unknown>;\n\n onKeyDown: React.KeyboardEventHandler<HTMLInputElement | HTMLTextAreaElement | HTMLElement>;\n onMouseDown: React.MouseEventHandler<HTMLInputElement | HTMLTextAreaElement | HTMLElement>;\n onChange: React.ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement | HTMLElement>;\n onPaste: React.ClipboardEventHandler<HTMLInputElement | HTMLTextAreaElement | HTMLElement>;\n onCompositionStart: React.CompositionEventHandler<\n HTMLInputElement | HTMLTextAreaElement | HTMLElement\n >;\n onCompositionEnd: React.CompositionEventHandler<\n HTMLInputElement | HTMLTextAreaElement | HTMLElement\n >;\n}\n\nconst Input: React.RefForwardingComponent<InputRef, InputProps> = (\n {\n prefixCls,\n id,\n inputElement,\n disabled,\n tabIndex,\n autoFocus,\n autoComplete,\n editable,\n activeDescendantId,\n value,\n maxLength,\n onKeyDown,\n onMouseDown,\n onChange,\n onPaste,\n onCompositionStart,\n onCompositionEnd,\n open,\n attrs,\n },\n ref,\n) => {\n let inputNode: React.ComponentElement<any, any> = inputElement || <input />;\n\n const { ref: originRef, props: originProps } = inputNode;\n\n const {\n onKeyDown: onOriginKeyDown,\n onChange: onOriginChange,\n onMouseDown: onOriginMouseDown,\n onCompositionStart: onOriginCompositionStart,\n onCompositionEnd: onOriginCompositionEnd,\n style,\n } = originProps;\n\n warning(\n !('maxLength' in inputNode.props),\n `Passing 'maxLength' to input element directly may not work because input in BaseSelect is controlled.`,\n );\n\n inputNode = React.cloneElement(inputNode, {\n type: 'search',\n ...originProps,\n\n // Override over origin props\n id,\n ref: composeRef(ref, originRef as any),\n disabled,\n tabIndex,\n autoComplete: autoComplete || 'off',\n\n autoFocus,\n className: classNames(`${prefixCls}-selection-search-input`, inputNode?.props?.className),\n\n role: 'combobox',\n 'aria-expanded': open || false,\n 'aria-haspopup': 'listbox',\n 'aria-owns': `${id}_list`,\n 'aria-autocomplete': 'list',\n 'aria-controls': `${id}_list`,\n 'aria-activedescendant': open ? activeDescendantId : undefined,\n ...attrs,\n value: editable ? value : '',\n maxLength,\n readOnly: !editable,\n unselectable: !editable ? 'on' : null,\n\n style: { ...style, opacity: editable ? null : 0 },\n\n onKeyDown: (event: React.KeyboardEvent<HTMLElement>) => {\n onKeyDown(event);\n if (onOriginKeyDown) {\n onOriginKeyDown(event);\n }\n },\n onMouseDown: (event: React.MouseEvent<HTMLElement>) => {\n onMouseDown(event);\n if (onOriginMouseDown) {\n onOriginMouseDown(event);\n }\n },\n onChange: (event: React.ChangeEvent<HTMLElement>) => {\n onChange(event);\n if (onOriginChange) {\n onOriginChange(event);\n }\n },\n onCompositionStart(event: React.CompositionEvent<HTMLElement>) {\n onCompositionStart(event);\n if (onOriginCompositionStart) {\n onOriginCompositionStart(event);\n }\n },\n onCompositionEnd(event: React.CompositionEvent<HTMLElement>) {\n onCompositionEnd(event);\n if (onOriginCompositionEnd) {\n onOriginCompositionEnd(event);\n }\n },\n onPaste,\n });\n\n return inputNode;\n};\n\nconst RefInput = React.forwardRef<InputRef, InputProps>(Input);\nRefInput.displayName = 'Input';\n\nexport default RefInput;\n"]}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import classNames from 'classnames';
|
|
4
|
+
import pickAttrs from 'rc-util/lib/pickAttrs';
|
|
5
|
+
import Overflow from 'rc-overflow';
|
|
6
|
+
import TransBtn from '../TransBtn';
|
|
7
|
+
import Input from './Input';
|
|
8
|
+
import useLayoutEffect from '../hooks/useLayoutEffect';
|
|
9
|
+
import { getTitle } from '../utils/commonUtil';
|
|
10
|
+
function itemKey(value) {
|
|
11
|
+
var _a;
|
|
12
|
+
return (_a = value.key) !== null && _a !== void 0 ? _a : value.value;
|
|
13
|
+
}
|
|
14
|
+
const onPreventMouseDown = (event) => {
|
|
15
|
+
event.preventDefault();
|
|
16
|
+
event.stopPropagation();
|
|
17
|
+
};
|
|
18
|
+
const SelectSelector = (props) => {
|
|
19
|
+
const { id, prefixCls, values, open, searchValue, autoClearSearchValue, inputRef, placeholder, disabled, mode, showSearch, autoFocus, autoComplete, activeDescendantId, tabIndex, removeIcon, maxTagCount, maxTagTextLength, maxTagPlaceholder = (omittedValues) => `+ ${omittedValues.length} ...`, tagRender, onToggleOpen, onRemove, onInputChange, onInputPaste, onInputKeyDown, onInputMouseDown, onInputCompositionStart, onInputCompositionEnd, } = props;
|
|
20
|
+
const measureRef = React.useRef(null);
|
|
21
|
+
const [inputWidth, setInputWidth] = useState(0);
|
|
22
|
+
const [focused, setFocused] = useState(false);
|
|
23
|
+
const selectionPrefixCls = `${prefixCls}-selection`;
|
|
24
|
+
// ===================== Search ======================
|
|
25
|
+
const inputValue = open || (mode === "multiple" && autoClearSearchValue === false) || mode === 'tags' ? searchValue : '';
|
|
26
|
+
const inputEditable = mode === 'tags' || (mode === "multiple" && autoClearSearchValue === false) || (showSearch && (open || focused));
|
|
27
|
+
// We measure width and set to the input immediately
|
|
28
|
+
useLayoutEffect(() => {
|
|
29
|
+
setInputWidth(measureRef.current.scrollWidth);
|
|
30
|
+
}, [inputValue]);
|
|
31
|
+
// ===================== Render ======================
|
|
32
|
+
// >>> Render Selector Node. Includes Item & Rest
|
|
33
|
+
function defaultRenderSelector(item, content, itemDisabled, closable, onClose) {
|
|
34
|
+
return (React.createElement("span", { className: classNames(`${selectionPrefixCls}-item`, {
|
|
35
|
+
[`${selectionPrefixCls}-item-disabled`]: itemDisabled,
|
|
36
|
+
}), title: getTitle(item) },
|
|
37
|
+
React.createElement("span", { className: `${selectionPrefixCls}-item-content` }, content),
|
|
38
|
+
closable && (React.createElement(TransBtn, { className: `${selectionPrefixCls}-item-remove`, onMouseDown: onPreventMouseDown, onClick: onClose, customizeIcon: removeIcon }, "\u00D7"))));
|
|
39
|
+
}
|
|
40
|
+
function customizeRenderSelector(value, content, itemDisabled, closable, onClose) {
|
|
41
|
+
const onMouseDown = (e) => {
|
|
42
|
+
onPreventMouseDown(e);
|
|
43
|
+
onToggleOpen(!open);
|
|
44
|
+
};
|
|
45
|
+
return (React.createElement("span", { onMouseDown: onMouseDown }, tagRender({
|
|
46
|
+
label: content,
|
|
47
|
+
value,
|
|
48
|
+
disabled: itemDisabled,
|
|
49
|
+
closable,
|
|
50
|
+
onClose,
|
|
51
|
+
})));
|
|
52
|
+
}
|
|
53
|
+
function renderItem(valueItem) {
|
|
54
|
+
const { disabled: itemDisabled, label, value } = valueItem;
|
|
55
|
+
const closable = !disabled && !itemDisabled;
|
|
56
|
+
let displayLabel = label;
|
|
57
|
+
if (typeof maxTagTextLength === 'number') {
|
|
58
|
+
if (typeof label === 'string' || typeof label === 'number') {
|
|
59
|
+
const strLabel = String(displayLabel);
|
|
60
|
+
if (strLabel.length > maxTagTextLength) {
|
|
61
|
+
displayLabel = `${strLabel.slice(0, maxTagTextLength)}...`;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
const onClose = (event) => {
|
|
66
|
+
if (event)
|
|
67
|
+
event.stopPropagation();
|
|
68
|
+
onRemove(valueItem);
|
|
69
|
+
};
|
|
70
|
+
return typeof tagRender === 'function'
|
|
71
|
+
? customizeRenderSelector(value, displayLabel, itemDisabled, closable, onClose)
|
|
72
|
+
: defaultRenderSelector(valueItem, displayLabel, itemDisabled, closable, onClose);
|
|
73
|
+
}
|
|
74
|
+
function renderRest(omittedValues) {
|
|
75
|
+
const content = typeof maxTagPlaceholder === 'function'
|
|
76
|
+
? maxTagPlaceholder(omittedValues)
|
|
77
|
+
: maxTagPlaceholder;
|
|
78
|
+
return defaultRenderSelector({ title: content }, content, false);
|
|
79
|
+
}
|
|
80
|
+
// >>> Input Node
|
|
81
|
+
const inputNode = (React.createElement("div", { className: `${selectionPrefixCls}-search`, style: { width: inputWidth }, onFocus: () => {
|
|
82
|
+
setFocused(true);
|
|
83
|
+
}, onBlur: () => {
|
|
84
|
+
setFocused(false);
|
|
85
|
+
} },
|
|
86
|
+
React.createElement(Input, { ref: inputRef, open: open, prefixCls: prefixCls, id: id, inputElement: null, disabled: disabled, autoFocus: autoFocus, autoComplete: autoComplete, editable: inputEditable, activeDescendantId: activeDescendantId, value: inputValue, onKeyDown: onInputKeyDown, onMouseDown: onInputMouseDown, onChange: onInputChange, onPaste: onInputPaste, onCompositionStart: onInputCompositionStart, onCompositionEnd: onInputCompositionEnd, tabIndex: tabIndex, attrs: pickAttrs(props, true) }),
|
|
87
|
+
React.createElement("span", { ref: measureRef, className: `${selectionPrefixCls}-search-mirror`, "aria-hidden": true },
|
|
88
|
+
inputValue,
|
|
89
|
+
"\u00A0")));
|
|
90
|
+
// >>> Selections
|
|
91
|
+
const selectionNode = (React.createElement(Overflow, { prefixCls: `${selectionPrefixCls}-overflow`, data: values, renderItem: renderItem, renderRest: renderRest, suffix: inputNode, itemKey: itemKey, maxCount: maxTagCount }));
|
|
92
|
+
return (React.createElement(React.Fragment, null,
|
|
93
|
+
selectionNode,
|
|
94
|
+
!values.length && !inputValue && (React.createElement("span", { className: `${selectionPrefixCls}-placeholder` }, placeholder))));
|
|
95
|
+
};
|
|
96
|
+
export default SelectSelector;
|
|
97
|
+
//# sourceMappingURL=MultipleSelector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MultipleSelector.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/Selector/MultipleSelector.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport { useState } from 'react';\nimport classNames from 'classnames';\nimport pickAttrs from 'rc-util/lib/pickAttrs';\nimport Overflow from 'rc-overflow';\nimport TransBtn from '../TransBtn';\nimport type { InnerSelectorProps } from '.';\nimport Input from './Input';\nimport useLayoutEffect from '../hooks/useLayoutEffect';\nimport type { DisplayValueType, RenderNode, CustomTagProps, RawValueType } from '../BaseSelect';\nimport { getTitle } from '../utils/commonUtil';\n\nfunction itemKey(value: DisplayValueType) {\n return value.key ?? value.value;\n}\n\ninterface SelectorProps extends InnerSelectorProps {\n // Icon\n removeIcon?: RenderNode;\n\n // Tags\n maxTagCount?: number | 'responsive';\n maxTagTextLength?: number;\n maxTagPlaceholder?: React.ReactNode | ((omittedValues: DisplayValueType[]) => React.ReactNode);\n tokenSeparators?: string[];\n tagRender?: (props: CustomTagProps) => React.ReactElement;\n onToggleOpen: (open?: boolean) => void;\n\n // Motion\n choiceTransitionName?: string;\n\n // Event\n onRemove: (value: DisplayValueType) => void;\n}\n\nconst onPreventMouseDown = (event: React.MouseEvent) => {\n event.preventDefault();\n event.stopPropagation();\n};\nconst SelectSelector: React.FC<SelectorProps> = (props) => {\n const {\n id,\n prefixCls,\n\n values,\n open,\n searchValue,\n autoClearSearchValue,\n inputRef,\n placeholder,\n disabled,\n mode,\n showSearch,\n autoFocus,\n autoComplete,\n activeDescendantId,\n tabIndex,\n\n removeIcon,\n\n maxTagCount,\n maxTagTextLength,\n maxTagPlaceholder = (omittedValues: DisplayValueType[]) => `+ ${omittedValues.length} ...`,\n tagRender,\n onToggleOpen,\n\n onRemove,\n onInputChange,\n onInputPaste,\n onInputKeyDown,\n onInputMouseDown,\n onInputCompositionStart,\n onInputCompositionEnd,\n } = props;\n\n const measureRef = React.useRef<HTMLSpanElement>(null);\n const [inputWidth, setInputWidth] = useState(0);\n const [focused, setFocused] = useState(false);\n\n const selectionPrefixCls = `${prefixCls}-selection`;\n\n // ===================== Search ======================\n const inputValue = open || (mode === \"multiple\" && autoClearSearchValue === false) || mode === 'tags' ? searchValue : '';\n const inputEditable: boolean = mode === 'tags' || (mode === \"multiple\" && autoClearSearchValue === false) || (showSearch && (open || focused));\n\n // We measure width and set to the input immediately\n useLayoutEffect(() => {\n setInputWidth(measureRef.current.scrollWidth);\n }, [inputValue]);\n\n // ===================== Render ======================\n // >>> Render Selector Node. Includes Item & Rest\n function defaultRenderSelector(\n item: DisplayValueType,\n content: React.ReactNode,\n itemDisabled: boolean,\n closable?: boolean,\n onClose?: React.MouseEventHandler,\n ) {\n return (\n <span\n className={classNames(`${selectionPrefixCls}-item`, {\n [`${selectionPrefixCls}-item-disabled`]: itemDisabled,\n })}\n title={getTitle(item)}\n >\n <span className={`${selectionPrefixCls}-item-content`}>{content}</span>\n {closable && (\n <TransBtn\n className={`${selectionPrefixCls}-item-remove`}\n onMouseDown={onPreventMouseDown}\n onClick={onClose}\n customizeIcon={removeIcon}\n >\n ×\n </TransBtn>\n )}\n </span>\n );\n }\n\n function customizeRenderSelector(\n value: RawValueType,\n content: React.ReactNode,\n itemDisabled: boolean,\n closable: boolean,\n onClose: React.MouseEventHandler,\n ) {\n const onMouseDown = (e: React.MouseEvent) => {\n onPreventMouseDown(e);\n onToggleOpen(!open);\n };\n\n return (\n <span onMouseDown={onMouseDown}>\n {tagRender({\n label: content,\n value,\n disabled: itemDisabled,\n closable,\n onClose,\n })}\n </span>\n );\n }\n\n function renderItem(valueItem: DisplayValueType) {\n const { disabled: itemDisabled, label, value } = valueItem;\n const closable = !disabled && !itemDisabled;\n\n let displayLabel: React.ReactNode = label;\n\n if (typeof maxTagTextLength === 'number') {\n if (typeof label === 'string' || typeof label === 'number') {\n const strLabel = String(displayLabel);\n\n if (strLabel.length > maxTagTextLength) {\n displayLabel = `${strLabel.slice(0, maxTagTextLength)}...`;\n }\n }\n }\n\n const onClose = (event?: React.MouseEvent) => {\n if (event) event.stopPropagation();\n onRemove(valueItem);\n };\n\n return typeof tagRender === 'function'\n ? customizeRenderSelector(value, displayLabel, itemDisabled, closable, onClose)\n : defaultRenderSelector(valueItem, displayLabel, itemDisabled, closable, onClose);\n }\n\n function renderRest(omittedValues: DisplayValueType[]) {\n const content =\n typeof maxTagPlaceholder === 'function'\n ? maxTagPlaceholder(omittedValues)\n : maxTagPlaceholder;\n\n return defaultRenderSelector({ title: content }, content, false);\n }\n\n // >>> Input Node\n const inputNode = (\n <div\n className={`${selectionPrefixCls}-search`}\n style={{ width: inputWidth }}\n onFocus={() => {\n setFocused(true);\n }}\n onBlur={() => {\n setFocused(false);\n }}\n >\n <Input\n ref={inputRef}\n open={open}\n prefixCls={prefixCls}\n id={id}\n inputElement={null}\n disabled={disabled}\n autoFocus={autoFocus}\n autoComplete={autoComplete}\n editable={inputEditable}\n activeDescendantId={activeDescendantId}\n value={inputValue}\n onKeyDown={onInputKeyDown}\n onMouseDown={onInputMouseDown}\n onChange={onInputChange}\n onPaste={onInputPaste}\n onCompositionStart={onInputCompositionStart}\n onCompositionEnd={onInputCompositionEnd}\n tabIndex={tabIndex}\n attrs={pickAttrs(props, true)}\n />\n\n {/* Measure Node */}\n <span ref={measureRef} className={`${selectionPrefixCls}-search-mirror`} aria-hidden>\n {inputValue} \n </span>\n </div>\n );\n\n // >>> Selections\n const selectionNode = (\n <Overflow\n prefixCls={`${selectionPrefixCls}-overflow`}\n data={values}\n renderItem={renderItem}\n renderRest={renderRest}\n suffix={inputNode}\n itemKey={itemKey}\n maxCount={maxTagCount}\n />\n );\n\n return (\n <>\n {selectionNode}\n\n {!values.length && !inputValue && (\n <span className={`${selectionPrefixCls}-placeholder`}>{placeholder}</span>\n )}\n </>\n );\n};\n\nexport default SelectSelector;\n"]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import pickAttrs from 'rc-util/lib/pickAttrs';
|
|
3
|
+
import Input from './Input';
|
|
4
|
+
import { getTitle } from '../utils/commonUtil';
|
|
5
|
+
const SingleSelector = (props) => {
|
|
6
|
+
const { inputElement, prefixCls, id, inputRef, disabled, autoFocus, autoComplete, activeDescendantId, mode, open, values, placeholder, tabIndex, showSearch, searchValue, activeValue, maxLength, onInputKeyDown, onInputMouseDown, onInputChange, onInputPaste, onInputCompositionStart, onInputCompositionEnd, title, } = props;
|
|
7
|
+
const [inputChanged, setInputChanged] = React.useState(false);
|
|
8
|
+
const combobox = mode === 'combobox';
|
|
9
|
+
const inputEditable = combobox || showSearch;
|
|
10
|
+
const item = values[0];
|
|
11
|
+
let inputValue = searchValue || '';
|
|
12
|
+
if (combobox && activeValue && !inputChanged) {
|
|
13
|
+
inputValue = activeValue;
|
|
14
|
+
}
|
|
15
|
+
React.useEffect(() => {
|
|
16
|
+
if (combobox) {
|
|
17
|
+
setInputChanged(false);
|
|
18
|
+
}
|
|
19
|
+
}, [combobox, activeValue]);
|
|
20
|
+
// Not show text when closed expect combobox mode
|
|
21
|
+
const hasTextInput = mode !== 'combobox' && !open && !showSearch ? false : !!inputValue;
|
|
22
|
+
// Get title of selection item
|
|
23
|
+
const selectionTitle = title === undefined ? getTitle(item) : title;
|
|
24
|
+
const renderPlaceholder = () => {
|
|
25
|
+
if (item) {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
const hiddenStyle = hasTextInput ? { visibility: 'hidden' } : undefined;
|
|
29
|
+
return (React.createElement("span", { className: `${prefixCls}-selection-placeholder`, style: hiddenStyle }, placeholder));
|
|
30
|
+
};
|
|
31
|
+
return (React.createElement(React.Fragment, null,
|
|
32
|
+
React.createElement("span", { className: `${prefixCls}-selection-search` },
|
|
33
|
+
React.createElement(Input, { ref: inputRef, prefixCls: prefixCls, id: id, open: open, inputElement: inputElement, disabled: disabled, autoFocus: autoFocus, autoComplete: autoComplete, editable: inputEditable, activeDescendantId: activeDescendantId, value: inputValue, onKeyDown: onInputKeyDown, onMouseDown: onInputMouseDown, onChange: (e) => {
|
|
34
|
+
setInputChanged(true);
|
|
35
|
+
onInputChange(e);
|
|
36
|
+
}, onPaste: onInputPaste, onCompositionStart: onInputCompositionStart, onCompositionEnd: onInputCompositionEnd, tabIndex: tabIndex, attrs: pickAttrs(props, true), maxLength: combobox ? maxLength : undefined })),
|
|
37
|
+
(!combobox && item) ? (React.createElement("span", { className: `${prefixCls}-selection-item`, title: selectionTitle,
|
|
38
|
+
// 当 Select 已经选中选项时,还需 selection 隐藏但留在原地占位
|
|
39
|
+
// https://github.com/ant-design/ant-design/issues/27688
|
|
40
|
+
// https://github.com/ant-design/ant-design/issues/41530
|
|
41
|
+
style: hasTextInput ? { visibility: 'hidden' } : undefined }, item.label)) : null,
|
|
42
|
+
renderPlaceholder()));
|
|
43
|
+
};
|
|
44
|
+
export default SingleSelector;
|
|
45
|
+
//# sourceMappingURL=SingleSelector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SingleSelector.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/Selector/SingleSelector.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport pickAttrs from 'rc-util/lib/pickAttrs';\nimport Input from './Input';\nimport type { InnerSelectorProps } from '.';\nimport { getTitle } from '../utils/commonUtil';\n\ninterface SelectorProps extends InnerSelectorProps {\n inputElement: React.ReactElement;\n activeValue: string;\n}\n\nconst SingleSelector: React.FC<SelectorProps> = (props) => {\n const {\n inputElement,\n prefixCls,\n id,\n inputRef,\n disabled,\n autoFocus,\n autoComplete,\n activeDescendantId,\n mode,\n open,\n values,\n placeholder,\n tabIndex,\n\n showSearch,\n searchValue,\n activeValue,\n maxLength,\n\n onInputKeyDown,\n onInputMouseDown,\n onInputChange,\n onInputPaste,\n onInputCompositionStart,\n onInputCompositionEnd,\n title,\n } = props;\n\n const [inputChanged, setInputChanged] = React.useState(false);\n\n const combobox = mode === 'combobox';\n const inputEditable = combobox || showSearch;\n const item = values[0];\n\n let inputValue: string = searchValue || '';\n if (combobox && activeValue && !inputChanged) {\n inputValue = activeValue;\n }\n\n React.useEffect(() => {\n if (combobox) {\n setInputChanged(false);\n }\n }, [combobox, activeValue]);\n\n // Not show text when closed expect combobox mode\n const hasTextInput = mode !== 'combobox' && !open && !showSearch ? false : !!inputValue;\n\n // Get title of selection item\n const selectionTitle = title === undefined ? getTitle(item) : title;\n\n const renderPlaceholder = () => {\n if (item) {\n return null;\n }\n const hiddenStyle = hasTextInput ? { visibility: 'hidden' } as React.CSSProperties : undefined;\n return (\n <span\n className={`${prefixCls}-selection-placeholder`}\n style={hiddenStyle}\n >\n {placeholder}\n </span>\n );\n };\n\n return (\n <>\n <span className={`${prefixCls}-selection-search`}>\n <Input\n ref={inputRef}\n prefixCls={prefixCls}\n id={id}\n open={open}\n inputElement={inputElement}\n disabled={disabled}\n autoFocus={autoFocus}\n autoComplete={autoComplete}\n editable={inputEditable}\n activeDescendantId={activeDescendantId}\n value={inputValue}\n onKeyDown={onInputKeyDown}\n onMouseDown={onInputMouseDown}\n onChange={(e) => {\n setInputChanged(true);\n onInputChange(e as any);\n }}\n onPaste={onInputPaste}\n onCompositionStart={onInputCompositionStart}\n onCompositionEnd={onInputCompositionEnd}\n tabIndex={tabIndex}\n attrs={pickAttrs(props, true)}\n maxLength={combobox ? maxLength : undefined}\n />\n </span>\n\n {/* Display value */}\n {(!combobox && item) ? (\n <span\n className={`${prefixCls}-selection-item`}\n title={selectionTitle}\n // 当 Select 已经选中选项时,还需 selection 隐藏但留在原地占位\n // https://github.com/ant-design/ant-design/issues/27688\n // https://github.com/ant-design/ant-design/issues/41530\n style={hasTextInput ? { visibility: 'hidden' } as React.CSSProperties : undefined}\n >\n {item.label}\n </span>\n ) : null}\n\n {/* Display placeholder */}\n {renderPlaceholder()}\n </>\n );\n};\n\nexport default SingleSelector;\n"]}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cursor rule:
|
|
3
|
+
* 1. Only `showSearch` enabled
|
|
4
|
+
* 2. Only `open` is `true`
|
|
5
|
+
* 3. When typing, set `open` to `true` which hit rule of 2
|
|
6
|
+
*
|
|
7
|
+
* Accessibility:
|
|
8
|
+
* - https://www.w3.org/TR/wai-aria-practices/examples/combobox/aria1.1pattern/listbox-combo.html
|
|
9
|
+
*/
|
|
10
|
+
import * as React from 'react';
|
|
11
|
+
import { useRef } from 'react';
|
|
12
|
+
import KeyCode from 'rc-util/lib/KeyCode';
|
|
13
|
+
import MultipleSelector from './MultipleSelector';
|
|
14
|
+
import SingleSelector from './SingleSelector';
|
|
15
|
+
import useLock from '../hooks/useLock';
|
|
16
|
+
import { isValidateOpenKey } from '../utils/keyUtil';
|
|
17
|
+
const Selector = (props, ref) => {
|
|
18
|
+
const inputRef = useRef(null);
|
|
19
|
+
const compositionStatusRef = useRef(false);
|
|
20
|
+
const { prefixCls, open, mode, showSearch, tokenWithEnter, autoClearSearchValue, onSearch, onSearchSubmit, onToggleOpen, onInputKeyDown, domRef, } = props;
|
|
21
|
+
// ======================= Ref =======================
|
|
22
|
+
React.useImperativeHandle(ref, () => ({
|
|
23
|
+
focus: () => {
|
|
24
|
+
inputRef.current.focus();
|
|
25
|
+
},
|
|
26
|
+
blur: () => {
|
|
27
|
+
inputRef.current.blur();
|
|
28
|
+
},
|
|
29
|
+
}));
|
|
30
|
+
// ====================== Input ======================
|
|
31
|
+
const [getInputMouseDown, setInputMouseDown] = useLock(0);
|
|
32
|
+
const onInternalInputKeyDown = (event) => {
|
|
33
|
+
const { which } = event;
|
|
34
|
+
if (which === KeyCode.UP || which === KeyCode.DOWN) {
|
|
35
|
+
event.preventDefault();
|
|
36
|
+
}
|
|
37
|
+
if (onInputKeyDown) {
|
|
38
|
+
onInputKeyDown(event);
|
|
39
|
+
}
|
|
40
|
+
if (which === KeyCode.ENTER && mode === 'tags' && !compositionStatusRef.current && !open) {
|
|
41
|
+
// When menu isn't open, OptionList won't trigger a value change
|
|
42
|
+
// So when enter is pressed, the tag's input value should be emitted here to let selector know
|
|
43
|
+
onSearchSubmit === null || onSearchSubmit === void 0 ? void 0 : onSearchSubmit(event.target.value);
|
|
44
|
+
}
|
|
45
|
+
if (isValidateOpenKey(which)) {
|
|
46
|
+
onToggleOpen(true);
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
/**
|
|
50
|
+
* We can not use `findDOMNode` sine it will get warning,
|
|
51
|
+
* have to use timer to check if is input element.
|
|
52
|
+
*/
|
|
53
|
+
const onInternalInputMouseDown = () => {
|
|
54
|
+
setInputMouseDown(true);
|
|
55
|
+
};
|
|
56
|
+
// When paste come, ignore next onChange
|
|
57
|
+
const pastedTextRef = useRef(null);
|
|
58
|
+
const triggerOnSearch = (value) => {
|
|
59
|
+
if (onSearch(value, true, compositionStatusRef.current) !== false) {
|
|
60
|
+
onToggleOpen(true);
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
const onInputCompositionStart = () => {
|
|
64
|
+
compositionStatusRef.current = true;
|
|
65
|
+
};
|
|
66
|
+
const onInputCompositionEnd = (e) => {
|
|
67
|
+
compositionStatusRef.current = false;
|
|
68
|
+
// Trigger search again to support `tokenSeparators` with typewriting
|
|
69
|
+
if (mode !== 'combobox') {
|
|
70
|
+
triggerOnSearch(e.target.value);
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
const onInputChange = (event) => {
|
|
74
|
+
let { target: { value }, } = event;
|
|
75
|
+
// Pasted text should replace back to origin content
|
|
76
|
+
if (tokenWithEnter && pastedTextRef.current && /[\r\n]/.test(pastedTextRef.current)) {
|
|
77
|
+
// CRLF will be treated as a single space for input element
|
|
78
|
+
const replacedText = pastedTextRef.current
|
|
79
|
+
.replace(/[\r\n]+$/, '')
|
|
80
|
+
.replace(/\r\n/g, ' ')
|
|
81
|
+
.replace(/[\r\n]/g, ' ');
|
|
82
|
+
value = value.replace(replacedText, pastedTextRef.current);
|
|
83
|
+
}
|
|
84
|
+
pastedTextRef.current = null;
|
|
85
|
+
triggerOnSearch(value);
|
|
86
|
+
};
|
|
87
|
+
const onInputPaste = (e) => {
|
|
88
|
+
const { clipboardData } = e;
|
|
89
|
+
const value = clipboardData.getData('text');
|
|
90
|
+
pastedTextRef.current = value;
|
|
91
|
+
};
|
|
92
|
+
const onClick = ({ target }) => {
|
|
93
|
+
if (target !== inputRef.current) {
|
|
94
|
+
// Should focus input if click the selector
|
|
95
|
+
const isIE = document.body.style.msTouchAction !== undefined;
|
|
96
|
+
if (isIE) {
|
|
97
|
+
setTimeout(() => {
|
|
98
|
+
inputRef.current.focus();
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
inputRef.current.focus();
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
const onMouseDown = (event) => {
|
|
107
|
+
const inputMouseDown = getInputMouseDown();
|
|
108
|
+
// when mode is combobox, don't prevent default behavior
|
|
109
|
+
// https://github.com/ant-design/ant-design/issues/37320
|
|
110
|
+
if (event.target !== inputRef.current && !inputMouseDown && mode !== 'combobox') {
|
|
111
|
+
event.preventDefault();
|
|
112
|
+
}
|
|
113
|
+
if ((mode !== 'combobox' && (!showSearch || !inputMouseDown)) || !open) {
|
|
114
|
+
if (open && autoClearSearchValue !== false) {
|
|
115
|
+
onSearch('', true, false);
|
|
116
|
+
}
|
|
117
|
+
onToggleOpen();
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
// ================= Inner Selector ==================
|
|
121
|
+
const sharedProps = {
|
|
122
|
+
inputRef,
|
|
123
|
+
onInputKeyDown: onInternalInputKeyDown,
|
|
124
|
+
onInputMouseDown: onInternalInputMouseDown,
|
|
125
|
+
onInputChange,
|
|
126
|
+
onInputPaste,
|
|
127
|
+
onInputCompositionStart,
|
|
128
|
+
onInputCompositionEnd,
|
|
129
|
+
};
|
|
130
|
+
const selectNode = mode === 'multiple' || mode === 'tags' ? (React.createElement(MultipleSelector, Object.assign({}, props, sharedProps))) : (React.createElement(SingleSelector, Object.assign({}, props, sharedProps)));
|
|
131
|
+
return (React.createElement("div", { ref: domRef, className: `${prefixCls}-selector`, onClick: onClick, onMouseDown: onMouseDown }, selectNode));
|
|
132
|
+
};
|
|
133
|
+
const ForwardSelector = React.forwardRef(Selector);
|
|
134
|
+
ForwardSelector.displayName = 'Selector';
|
|
135
|
+
export default ForwardSelector;
|
|
136
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/Selector/index.tsx"],"names":[],"mappings":"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","sourcesContent":["/**\n * Cursor rule:\n * 1. Only `showSearch` enabled\n * 2. Only `open` is `true`\n * 3. When typing, set `open` to `true` which hit rule of 2\n *\n * Accessibility:\n * - https://www.w3.org/TR/wai-aria-practices/examples/combobox/aria1.1pattern/listbox-combo.html\n */\n\nimport * as React from 'react';\nimport { useRef } from 'react';\nimport KeyCode from 'rc-util/lib/KeyCode';\nimport type { ScrollTo } from 'rc-virtual-list/lib/List';\nimport MultipleSelector from './MultipleSelector';\nimport SingleSelector from './SingleSelector';\nimport useLock from '../hooks/useLock';\nimport type { CustomTagProps, DisplayValueType, Mode, RenderNode } from '../BaseSelect';\nimport { isValidateOpenKey } from '../utils/keyUtil';\n\nexport interface InnerSelectorProps {\n prefixCls: string;\n id: string;\n mode: Mode;\n title?: string;\n\n inputRef: React.Ref<HTMLInputElement | HTMLTextAreaElement>;\n placeholder?: React.ReactNode;\n disabled?: boolean;\n autoFocus?: boolean;\n autoComplete?: string;\n values: DisplayValueType[];\n showSearch?: boolean;\n searchValue: string;\n autoClearSearchValue?: boolean;\n activeDescendantId?: string;\n open: boolean;\n tabIndex?: number;\n maxLength?: number;\n\n onInputKeyDown: React.KeyboardEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputMouseDown: React.MouseEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputChange: React.ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputPaste: React.ClipboardEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputCompositionStart: React.CompositionEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputCompositionEnd: React.CompositionEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n}\n\nexport interface RefSelectorProps {\n focus: () => void;\n blur: () => void;\n scrollTo?: ScrollTo;\n}\n\nexport interface SelectorProps {\n id: string;\n prefixCls: string;\n showSearch?: boolean;\n open: boolean;\n /** Display in the Selector value, it's not same as `value` prop */\n values: DisplayValueType[];\n mode: Mode;\n searchValue: string;\n activeValue: string;\n autoClearSearchValue: boolean;\n inputElement: JSX.Element;\n maxLength?: number;\n\n autoFocus?: boolean;\n activeDescendantId?: string;\n tabIndex?: number;\n disabled?: boolean;\n placeholder?: React.ReactNode;\n removeIcon?: RenderNode;\n\n // Tags\n maxTagCount?: number | 'responsive';\n maxTagTextLength?: number;\n maxTagPlaceholder?: React.ReactNode | ((omittedValues: DisplayValueType[]) => React.ReactNode);\n tagRender?: (props: CustomTagProps) => React.ReactElement;\n\n /** Check if `tokenSeparators` contains `\\n` or `\\r\\n` */\n tokenWithEnter?: boolean;\n\n // Motion\n choiceTransitionName?: string;\n\n onToggleOpen: (open?: boolean) => void;\n /** `onSearch` returns go next step boolean to check if need do toggle open */\n onSearch: (searchText: string, fromTyping: boolean, isCompositing: boolean) => boolean;\n onSearchSubmit?: (searchText: string) => void;\n onRemove: (value: DisplayValueType) => void;\n onInputKeyDown?: React.KeyboardEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n\n /**\n * @private get real dom for trigger align.\n * This may be removed after React provides replacement of `findDOMNode`\n */\n domRef: React.Ref<HTMLDivElement>;\n}\n\nconst Selector: React.RefForwardingComponent<RefSelectorProps, SelectorProps> = (props, ref) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const compositionStatusRef = useRef<boolean>(false);\n\n const {\n prefixCls,\n open,\n mode,\n showSearch,\n tokenWithEnter,\n\n autoClearSearchValue,\n\n onSearch,\n onSearchSubmit,\n onToggleOpen,\n onInputKeyDown,\n\n domRef,\n } = props;\n\n // ======================= Ref =======================\n React.useImperativeHandle(ref, () => ({\n focus: () => {\n inputRef.current.focus();\n },\n blur: () => {\n inputRef.current.blur();\n },\n }));\n\n // ====================== Input ======================\n const [getInputMouseDown, setInputMouseDown] = useLock(0);\n\n const onInternalInputKeyDown: React.KeyboardEventHandler<HTMLInputElement> = (event) => {\n const { which } = event;\n\n if (which === KeyCode.UP || which === KeyCode.DOWN) {\n event.preventDefault();\n }\n\n if (onInputKeyDown) {\n onInputKeyDown(event);\n }\n\n if (which === KeyCode.ENTER && mode === 'tags' && !compositionStatusRef.current && !open) {\n // When menu isn't open, OptionList won't trigger a value change\n // So when enter is pressed, the tag's input value should be emitted here to let selector know\n onSearchSubmit?.((event.target as HTMLInputElement).value);\n }\n\n if (isValidateOpenKey(which)) {\n onToggleOpen(true);\n }\n };\n\n /**\n * We can not use `findDOMNode` sine it will get warning,\n * have to use timer to check if is input element.\n */\n const onInternalInputMouseDown: React.MouseEventHandler<HTMLInputElement> = () => {\n setInputMouseDown(true);\n };\n\n // When paste come, ignore next onChange\n const pastedTextRef = useRef<string>(null);\n\n const triggerOnSearch = (value: string) => {\n if (onSearch(value, true, compositionStatusRef.current) !== false) {\n onToggleOpen(true);\n }\n };\n\n const onInputCompositionStart = () => {\n compositionStatusRef.current = true;\n };\n\n const onInputCompositionEnd: React.CompositionEventHandler<HTMLInputElement> = (e) => {\n compositionStatusRef.current = false;\n\n // Trigger search again to support `tokenSeparators` with typewriting\n if (mode !== 'combobox') {\n triggerOnSearch((e.target as HTMLInputElement).value);\n }\n };\n\n const onInputChange: React.ChangeEventHandler<HTMLInputElement> = (event) => {\n let {\n target: { value },\n } = event;\n\n // Pasted text should replace back to origin content\n if (tokenWithEnter && pastedTextRef.current && /[\\r\\n]/.test(pastedTextRef.current)) {\n // CRLF will be treated as a single space for input element\n const replacedText = pastedTextRef.current\n .replace(/[\\r\\n]+$/, '')\n .replace(/\\r\\n/g, ' ')\n .replace(/[\\r\\n]/g, ' ');\n value = value.replace(replacedText, pastedTextRef.current);\n }\n\n pastedTextRef.current = null;\n\n triggerOnSearch(value);\n };\n\n const onInputPaste: React.ClipboardEventHandler = (e) => {\n const { clipboardData } = e;\n const value = clipboardData.getData('text');\n\n pastedTextRef.current = value;\n };\n\n const onClick = ({ target }) => {\n if (target !== inputRef.current) {\n // Should focus input if click the selector\n const isIE = (document.body.style as any).msTouchAction !== undefined;\n if (isIE) {\n setTimeout(() => {\n inputRef.current.focus();\n });\n } else {\n inputRef.current.focus();\n }\n }\n };\n\n const onMouseDown: React.MouseEventHandler<HTMLElement> = (event) => {\n const inputMouseDown = getInputMouseDown();\n\n // when mode is combobox, don't prevent default behavior\n // https://github.com/ant-design/ant-design/issues/37320\n if (event.target !== inputRef.current && !inputMouseDown && mode !== 'combobox') {\n event.preventDefault();\n }\n\n if ((mode !== 'combobox' && (!showSearch || !inputMouseDown)) || !open) {\n if (open && autoClearSearchValue !== false) {\n onSearch('', true, false);\n }\n onToggleOpen();\n }\n };\n\n // ================= Inner Selector ==================\n const sharedProps = {\n inputRef,\n onInputKeyDown: onInternalInputKeyDown,\n onInputMouseDown: onInternalInputMouseDown,\n onInputChange,\n onInputPaste,\n onInputCompositionStart,\n onInputCompositionEnd,\n };\n\n const selectNode =\n mode === 'multiple' || mode === 'tags' ? (\n <MultipleSelector {...props} {...sharedProps} />\n ) : (\n <SingleSelector {...props} {...sharedProps} />\n );\n\n return (\n <div\n ref={domRef}\n className={`${prefixCls}-selector`}\n onClick={onClick}\n onMouseDown={onMouseDown}\n >\n {selectNode}\n </div>\n );\n};\n\nconst ForwardSelector = React.forwardRef<RefSelectorProps, SelectorProps>(Selector);\nForwardSelector.displayName = 'Selector';\n\nexport default ForwardSelector;\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
const TransBtn = ({ className, customizeIcon, customizeIconProps, onMouseDown, onClick, children, }) => {
|
|
4
|
+
let icon;
|
|
5
|
+
if (typeof customizeIcon === 'function') {
|
|
6
|
+
icon = customizeIcon(customizeIconProps);
|
|
7
|
+
}
|
|
8
|
+
else {
|
|
9
|
+
icon = customizeIcon;
|
|
10
|
+
}
|
|
11
|
+
return (React.createElement("span", { className: className, onMouseDown: (event) => {
|
|
12
|
+
event.preventDefault();
|
|
13
|
+
if (onMouseDown) {
|
|
14
|
+
onMouseDown(event);
|
|
15
|
+
}
|
|
16
|
+
}, style: {
|
|
17
|
+
userSelect: 'none',
|
|
18
|
+
WebkitUserSelect: 'none',
|
|
19
|
+
}, unselectable: "on", onClick: onClick, "aria-hidden": true }, icon !== undefined ? (icon) : (React.createElement("span", { className: classNames(className.split(/\s+/).map((cls) => `${cls}-icon`)) }, children))));
|
|
20
|
+
};
|
|
21
|
+
export default TransBtn;
|
|
22
|
+
//# sourceMappingURL=TransBtn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TransBtn.js","sourceRoot":"","sources":["../../../src/tntd-select/rc-select/TransBtn.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,UAAU,MAAM,YAAY,CAAC;AAYpC,MAAM,QAAQ,GAA4B,CAAC,EACzC,SAAS,EACT,aAAa,EACb,kBAAkB,EAClB,WAAW,EACX,OAAO,EACP,QAAQ,GACT,EAAE,EAAE;IACH,IAAI,IAAqB,CAAC;IAE1B,IAAI,OAAO,aAAa,KAAK,UAAU,EAAE;QACvC,IAAI,GAAG,aAAa,CAAC,kBAAkB,CAAC,CAAC;KAC1C;SAAM;QACL,IAAI,GAAG,aAAa,CAAC;KACtB;IAED,OAAO,CACL,8BACE,SAAS,EAAE,SAAS,EACpB,WAAW,EAAE,CAAC,KAAK,EAAE,EAAE;YACrB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,WAAW,EAAE;gBACf,WAAW,CAAC,KAAK,CAAC,CAAC;aACpB;QACH,CAAC,EACD,KAAK,EAAE;YACL,UAAU,EAAE,MAAM;YAClB,gBAAgB,EAAE,MAAM;SACzB,EACD,YAAY,EAAC,IAAI,EACjB,OAAO,EAAE,OAAO,yBAGf,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CACpB,IAAI,CACL,CAAC,CAAC,CAAC,CACF,8BAAM,SAAS,EAAE,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,CAAC,CAAC,IAC5E,QAAQ,CACJ,CACR,CACI,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC","sourcesContent":["import * as React from 'react';\nimport classNames from 'classnames';\nimport type { RenderNode } from './BaseSelect';\n\nexport interface TransBtnProps {\n className: string;\n customizeIcon: RenderNode;\n customizeIconProps?: any;\n onMouseDown?: React.MouseEventHandler<HTMLSpanElement>;\n onClick?: React.MouseEventHandler<HTMLSpanElement>;\n children?: React.ReactNode;\n}\n\nconst TransBtn: React.FC<TransBtnProps> = ({\n className,\n customizeIcon,\n customizeIconProps,\n onMouseDown,\n onClick,\n children,\n}) => {\n let icon: React.ReactNode;\n\n if (typeof customizeIcon === 'function') {\n icon = customizeIcon(customizeIconProps);\n } else {\n icon = customizeIcon;\n }\n\n return (\n <span\n className={className}\n onMouseDown={(event) => {\n event.preventDefault();\n if (onMouseDown) {\n onMouseDown(event);\n }\n }}\n style={{\n userSelect: 'none',\n WebkitUserSelect: 'none',\n }}\n unselectable=\"on\"\n onClick={onClick}\n aria-hidden\n >\n {icon !== undefined ? (\n icon\n ) : (\n <span className={classNames(className.split(/\\s+/).map((cls) => `${cls}-icon`))}>\n {children}\n </span>\n )}\n </span>\n );\n};\n\nexport default TransBtn;\n"]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import TransBtn from '../TransBtn';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
export function useAllowClear(prefixCls, onClearMouseDown, displayValues, allowClear, clearIcon, disabled = false, mergedSearchValue, mode) {
|
|
4
|
+
const mergedClearIcon = React.useMemo(() => {
|
|
5
|
+
if (typeof allowClear === "object") {
|
|
6
|
+
return allowClear.clearIcon;
|
|
7
|
+
}
|
|
8
|
+
if (!!clearIcon)
|
|
9
|
+
return clearIcon;
|
|
10
|
+
}, [allowClear, clearIcon]);
|
|
11
|
+
const mergedAllowClear = React.useMemo(() => {
|
|
12
|
+
if (!disabled &&
|
|
13
|
+
!!allowClear &&
|
|
14
|
+
(displayValues.length || mergedSearchValue) &&
|
|
15
|
+
!(mode === 'combobox' && mergedSearchValue === '')) {
|
|
16
|
+
return true;
|
|
17
|
+
}
|
|
18
|
+
return false;
|
|
19
|
+
}, [allowClear, disabled, displayValues.length, mergedSearchValue, mode]);
|
|
20
|
+
return {
|
|
21
|
+
allowClear: mergedAllowClear,
|
|
22
|
+
clearIcon: (React.createElement(TransBtn, { className: `${prefixCls}-clear`, onMouseDown: onClearMouseDown, customizeIcon: mergedClearIcon }, "\u00D7"))
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=useAllowClear.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAllowClear.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/hooks/useAllowClear.tsx"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,aAAa,CAAC;AAGnC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,UAAU,aAAa,CACzB,SAAS,EACT,gBAAgB,EAChB,aAAiC,EACjC,UAAgD,EAChD,SAAqB,EACrB,QAAQ,GAAG,KAAK,EAChB,iBAA0B,EAC1B,IAAW;IAEX,MAAM,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACvC,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;YAChC,OAAO,UAAU,CAAC,SAAS,CAAC;SAC/B;QACD,IAAI,CAAC,CAAC,SAAS;YAAE,OAAO,SAAS,CAAC;IACtC,CAAC,EAAE,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC;IAG5B,MAAM,gBAAgB,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACxC,IACI,CAAC,QAAQ;YACT,CAAC,CAAC,UAAU;YACZ,CAAC,aAAa,CAAC,MAAM,IAAI,iBAAiB,CAAC;YAC3C,CAAC,CAAC,IAAI,KAAK,UAAU,IAAI,iBAAiB,KAAK,EAAE,CAAC,EACpD;YACE,OAAO,IAAI,CAAC;SACf;QACD,OAAO,KAAK,CAAC;IACjB,CAAC,EAAE,CAAC,UAAU,EAAE,QAAQ,EAAE,aAAa,CAAC,MAAM,EAAE,iBAAiB,EAAE,IAAI,CAAC,CAAC,CAAC;IAE1E,OAAO;QACH,UAAU,EAAE,gBAAgB;QAC5B,SAAS,EAAE,CACP,oBAAC,QAAQ,IACL,SAAS,EAAE,GAAG,SAAS,QAAQ,EAC/B,WAAW,EAAE,gBAAgB,EAC7B,aAAa,EAAE,eAAe,aAGvB,CACd;KACJ,CAAC;AACN,CAAC","sourcesContent":["import TransBtn from '../TransBtn';\nimport type { DisplayValueType, Mode } from '../interface';\nimport type { ReactNode } from 'react';\nimport React from 'react';\n\nexport function useAllowClear(\n prefixCls,\n onClearMouseDown,\n displayValues: DisplayValueType[],\n allowClear?: boolean | { clearIcon?: ReactNode },\n clearIcon?: ReactNode,\n disabled = false,\n mergedSearchValue?: string,\n mode?: Mode\n) {\n const mergedClearIcon = React.useMemo(() => {\n if (typeof allowClear === \"object\") {\n return allowClear.clearIcon;\n }\n if (!!clearIcon) return clearIcon;\n }, [allowClear, clearIcon]);\n\n\n const mergedAllowClear = React.useMemo(() => {\n if (\n !disabled &&\n !!allowClear &&\n (displayValues.length || mergedSearchValue) &&\n !(mode === 'combobox' && mergedSearchValue === '')\n ) {\n return true;\n }\n return false;\n }, [allowClear, disabled, displayValues.length, mergedSearchValue, mode]);\n\n return {\n allowClear: mergedAllowClear,\n clearIcon: (\n <TransBtn\n className={`${prefixCls}-clear`}\n onMouseDown={onClearMouseDown}\n customizeIcon={mergedClearIcon}\n >\n ×\n </TransBtn>\n )\n };\n}\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BaseSelect provide some parsed data into context.
|
|
3
|
+
* You can use this hooks to get them.
|
|
4
|
+
*/
|
|
5
|
+
import * as React from 'react';
|
|
6
|
+
export const BaseSelectContext = React.createContext(null);
|
|
7
|
+
export default function useBaseProps() {
|
|
8
|
+
return React.useContext(BaseSelectContext);
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=useBaseProps.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useBaseProps.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/hooks/useBaseProps.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAS/B,MAAM,CAAC,MAAM,iBAAiB,GAAG,KAAK,CAAC,aAAa,CAAyB,IAAI,CAAC,CAAC;AAEnF,MAAM,CAAC,OAAO,UAAU,YAAY;IAClC,OAAO,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;AAC7C,CAAC","sourcesContent":["/**\n * BaseSelect provide some parsed data into context.\n * You can use this hooks to get them.\n */\n\nimport * as React from 'react';\nimport type { BaseSelectProps } from '../BaseSelect';\n\nexport interface BaseSelectContextProps extends BaseSelectProps {\n triggerOpen: boolean;\n multiple: boolean;\n toggleOpen: (open?: boolean) => void;\n}\n\nexport const BaseSelectContext = React.createContext<BaseSelectContextProps>(null);\n\nexport default function useBaseProps() {\n return React.useContext(BaseSelectContext);\n}\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* Cache `value` related LabeledValue & options.
|
|
4
|
+
*/
|
|
5
|
+
export default (labeledValues, valueOptions) => {
|
|
6
|
+
const cacheRef = React.useRef({
|
|
7
|
+
values: new Map(),
|
|
8
|
+
options: new Map(),
|
|
9
|
+
});
|
|
10
|
+
const filledLabeledValues = React.useMemo(() => {
|
|
11
|
+
const { values: prevValueCache, options: prevOptionCache } = cacheRef.current;
|
|
12
|
+
// Fill label by cache
|
|
13
|
+
const patchedValues = labeledValues.map((item) => {
|
|
14
|
+
var _a;
|
|
15
|
+
if (item.label === undefined) {
|
|
16
|
+
return Object.assign(Object.assign({}, item), { label: (_a = prevValueCache.get(item.value)) === null || _a === void 0 ? void 0 : _a.label });
|
|
17
|
+
}
|
|
18
|
+
return item;
|
|
19
|
+
});
|
|
20
|
+
// Refresh cache
|
|
21
|
+
const valueCache = new Map();
|
|
22
|
+
const optionCache = new Map();
|
|
23
|
+
patchedValues.forEach((item) => {
|
|
24
|
+
valueCache.set(item.value, item);
|
|
25
|
+
optionCache.set(item.value, valueOptions.get(item.value) || prevOptionCache.get(item.value));
|
|
26
|
+
});
|
|
27
|
+
cacheRef.current.values = valueCache;
|
|
28
|
+
cacheRef.current.options = optionCache;
|
|
29
|
+
return patchedValues;
|
|
30
|
+
}, [labeledValues, valueOptions]);
|
|
31
|
+
const getOption = React.useCallback((val) => valueOptions.get(val) || cacheRef.current.options.get(val), [valueOptions]);
|
|
32
|
+
return [filledLabeledValues, getOption];
|
|
33
|
+
};
|
|
34
|
+
//# sourceMappingURL=useCache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useCache.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/hooks/useCache.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B;;GAEG;AACH,eAAe,CACb,aAAiC,EACjC,YAAkD,EACc,EAAE;IAClE,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC;QAC5B,MAAM,EAAE,IAAI,GAAG,EAAkC;QACjD,OAAO,EAAE,IAAI,GAAG,EAAmC;KACpD,CAAC,CAAC;IAEH,MAAM,mBAAmB,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QAC7C,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,OAAO,EAAE,eAAe,EAAE,GAAG,QAAQ,CAAC,OAAO,CAAC;QAE9E,sBAAsB;QACtB,MAAM,aAAa,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;;YAC/C,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE;gBAC5B,uCACK,IAAI,KACP,KAAK,EAAE,MAAA,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,0CAAE,KAAK,IAC5C;aACH;YAED,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;QAEH,gBAAgB;QAChB,MAAM,UAAU,GAAG,IAAI,GAAG,EAAkC,CAAC;QAC7D,MAAM,WAAW,GAAG,IAAI,GAAG,EAAmC,CAAC;QAE/D,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC7B,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YACjC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAC/F,CAAC,CAAC,CAAC;QAEH,QAAQ,CAAC,OAAO,CAAC,MAAM,GAAG,UAAU,CAAC;QACrC,QAAQ,CAAC,OAAO,CAAC,OAAO,GAAG,WAAW,CAAC;QAEvC,OAAO,aAAa,CAAC;IACvB,CAAC,EAAE,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC,CAAC;IAElC,MAAM,SAAS,GAAG,KAAK,CAAC,WAAW,CACjC,CAAC,GAAiB,EAAE,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EACjF,CAAC,YAAY,CAAC,CACf,CAAC;IAEF,OAAO,CAAC,mBAAmB,EAAE,SAAS,CAAC,CAAC;AAC1C,CAAC,CAAC","sourcesContent":["import * as React from 'react';\nimport type { RawValueType } from '../BaseSelect';\nimport type { DefaultOptionType, LabelInValueType } from '../Select';\n\n/**\n * Cache `value` related LabeledValue & options.\n */\nexport default (\n labeledValues: LabelInValueType[],\n valueOptions: Map<RawValueType, DefaultOptionType>,\n): [LabelInValueType[], (val: RawValueType) => DefaultOptionType] => {\n const cacheRef = React.useRef({\n values: new Map<RawValueType, LabelInValueType>(),\n options: new Map<RawValueType, DefaultOptionType>(),\n });\n\n const filledLabeledValues = React.useMemo(() => {\n const { values: prevValueCache, options: prevOptionCache } = cacheRef.current;\n\n // Fill label by cache\n const patchedValues = labeledValues.map((item) => {\n if (item.label === undefined) {\n return {\n ...item,\n label: prevValueCache.get(item.value)?.label,\n };\n }\n\n return item;\n });\n\n // Refresh cache\n const valueCache = new Map<RawValueType, LabelInValueType>();\n const optionCache = new Map<RawValueType, DefaultOptionType>();\n\n patchedValues.forEach((item) => {\n valueCache.set(item.value, item);\n optionCache.set(item.value, valueOptions.get(item.value) || prevOptionCache.get(item.value));\n });\n\n cacheRef.current.values = valueCache;\n cacheRef.current.options = optionCache;\n\n return patchedValues;\n }, [labeledValues, valueOptions]);\n\n const getOption = React.useCallback(\n (val: RawValueType) => valueOptions.get(val) || cacheRef.current.options.get(val),\n [valueOptions],\n );\n\n return [filledLabeledValues, getOption];\n};\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* Similar with `useLock`, but this hook will always execute last value.
|
|
4
|
+
* When set to `true`, it will keep `true` for a short time even if `false` is set.
|
|
5
|
+
*/
|
|
6
|
+
export default function useDelayReset(timeout = 10) {
|
|
7
|
+
const [bool, setBool] = React.useState(false);
|
|
8
|
+
const delayRef = React.useRef(null);
|
|
9
|
+
const cancelLatest = () => {
|
|
10
|
+
window.clearTimeout(delayRef.current);
|
|
11
|
+
};
|
|
12
|
+
React.useEffect(() => cancelLatest, []);
|
|
13
|
+
const delaySetBool = (value, callback) => {
|
|
14
|
+
cancelLatest();
|
|
15
|
+
delayRef.current = window.setTimeout(() => {
|
|
16
|
+
setBool(value);
|
|
17
|
+
if (callback) {
|
|
18
|
+
callback();
|
|
19
|
+
}
|
|
20
|
+
}, timeout);
|
|
21
|
+
};
|
|
22
|
+
return [bool, delaySetBool, cancelLatest];
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=useDelayReset.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDelayReset.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/hooks/useDelayReset.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B;;;GAGG;AACH,MAAM,CAAC,OAAO,UAAU,aAAa,CACnC,UAAkB,EAAE;IAEpB,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAU,KAAK,CAAC,CAAC;IACvD,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAS,IAAI,CAAC,CAAC;IAE5C,MAAM,YAAY,GAAG,GAAG,EAAE;QACxB,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC,CAAC;IAEF,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;IAExC,MAAM,YAAY,GAAG,CAAC,KAAc,EAAE,QAAoB,EAAE,EAAE;QAC5D,YAAY,EAAE,CAAC;QAEf,QAAQ,CAAC,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YACxC,OAAO,CAAC,KAAK,CAAC,CAAC;YACf,IAAI,QAAQ,EAAE;gBACZ,QAAQ,EAAE,CAAC;aACZ;QACH,CAAC,EAAE,OAAO,CAAC,CAAC;IACd,CAAC,CAAC;IAEF,OAAO,CAAC,IAAI,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC;AAC5C,CAAC","sourcesContent":["import * as React from 'react';\n\n/**\n * Similar with `useLock`, but this hook will always execute last value.\n * When set to `true`, it will keep `true` for a short time even if `false` is set.\n */\nexport default function useDelayReset(\n timeout: number = 10,\n): [boolean, (val: boolean, callback?: () => void) => void, () => void] {\n const [bool, setBool] = React.useState<boolean>(false);\n const delayRef = React.useRef<number>(null);\n\n const cancelLatest = () => {\n window.clearTimeout(delayRef.current);\n };\n\n React.useEffect(() => cancelLatest, []);\n\n const delaySetBool = (value: boolean, callback: () => void) => {\n cancelLatest();\n\n delayRef.current = window.setTimeout(() => {\n setBool(value);\n if (callback) {\n callback();\n }\n }, timeout);\n };\n\n return [bool, delaySetBool, cancelLatest];\n}\n"]}
|