@infomaximum/ui-kit 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/README.md +169 -0
- package/dist/components/Alert/Alert.d.ts +3 -0
- package/dist/components/Alert/Alert.js +67 -0
- package/dist/components/Alert/Alert.styles.d.ts +885 -0
- package/dist/components/Alert/Alert.styles.js +124 -0
- package/dist/components/Alert/Alert.tokens.d.ts +8 -0
- package/dist/components/Alert/Alert.tokens.js +10 -0
- package/dist/components/Alert/Alert.types.d.ts +26 -0
- package/dist/components/Alert/Alert.utils.d.ts +7 -0
- package/dist/components/Alert/Alert.utils.js +38 -0
- package/dist/components/Alert/index.d.ts +2 -0
- package/dist/components/Avatar/Avatar.d.ts +3 -0
- package/dist/components/Avatar/Avatar.js +23 -0
- package/dist/components/Avatar/Avatar.styles.d.ts +29 -0
- package/dist/components/Avatar/Avatar.styles.js +40 -0
- package/dist/components/Avatar/Avatar.tokens.d.ts +7 -0
- package/dist/components/Avatar/Avatar.tokens.js +8 -0
- package/dist/components/Avatar/Avatar.types.d.ts +11 -0
- package/dist/components/Avatar/index.d.ts +2 -0
- package/dist/components/BaseTooltip/BaseTooltip.d.ts +3 -0
- package/dist/components/BaseTooltip/BaseTooltip.js +87 -0
- package/dist/components/BaseTooltip/BaseTooltip.styles.d.ts +6 -0
- package/dist/components/BaseTooltip/BaseTooltip.styles.js +36 -0
- package/dist/components/BaseTooltip/BaseTooltip.types.d.ts +19 -0
- package/dist/components/BaseTooltip/BaseTooltip.utils.d.ts +12 -0
- package/dist/components/BaseTooltip/BaseTooltip.utils.js +101 -0
- package/dist/components/BaseTooltip/hooks/useShowTooltipController.d.ts +22 -0
- package/dist/components/BaseTooltip/hooks/useShowTooltipController.js +143 -0
- package/dist/components/Button/Button.d.ts +3 -0
- package/dist/components/Button/Button.js +56 -0
- package/dist/components/Button/Button.styles.d.ts +958 -0
- package/dist/components/Button/Button.styles.js +230 -0
- package/dist/components/Button/Button.tokens.d.ts +27 -0
- package/dist/components/Button/Button.tokens.js +29 -0
- package/dist/components/Button/Button.types.d.ts +31 -0
- package/dist/components/Button/Button.utils.d.ts +8 -0
- package/dist/components/Button/Button.utils.js +38 -0
- package/dist/components/Button/index.d.ts +2 -0
- package/dist/components/Checkbox/Checkbox.d.ts +3 -0
- package/dist/components/Checkbox/Checkbox.js +72 -0
- package/dist/components/Checkbox/Checkbox.styles.d.ts +46 -0
- package/dist/components/Checkbox/Checkbox.styles.js +85 -0
- package/dist/components/Checkbox/Checkbox.tokens.d.ts +13 -0
- package/dist/components/Checkbox/Checkbox.tokens.js +15 -0
- package/dist/components/Checkbox/Checkbox.types.d.ts +27 -0
- package/dist/components/Checkbox/components/Group/Group.d.ts +3 -0
- package/dist/components/Checkbox/components/Group/Group.js +67 -0
- package/dist/components/Checkbox/components/Group/Group.style.d.ts +6 -0
- package/dist/components/Checkbox/components/Group/Group.style.js +8 -0
- package/dist/components/Checkbox/components/Group/Group.type.d.ts +18 -0
- package/dist/components/Checkbox/components/Group/Group.utils.d.ts +6 -0
- package/dist/components/Checkbox/components/Group/Group.utils.js +6 -0
- package/dist/components/Checkbox/forStories/CheckAll/CheckAll.d.ts +2 -0
- package/dist/components/Checkbox/index.d.ts +4 -0
- package/dist/components/Checkbox/index.js +8 -0
- package/dist/components/ConfigProvider/ConfigProvider.d.ts +3 -0
- package/dist/components/ConfigProvider/ConfigProvider.js +17 -0
- package/dist/components/ConfigProvider/ConfigProvider.types.d.ts +5 -0
- package/dist/components/ConfigProvider/contexts/ConfigContext.d.ts +2 -0
- package/dist/components/ConfigProvider/contexts/ConfigContext.js +5 -0
- package/dist/components/ConfigProvider/contexts/ConfigContext.types.d.ts +6 -0
- package/dist/components/ConfigProvider/contexts/index.d.ts +1 -0
- package/dist/components/ConfigProvider/hooks/useConfig/index.d.ts +1 -0
- package/dist/components/ConfigProvider/hooks/useConfig/useConfig.d.ts +9 -0
- package/dist/components/ConfigProvider/hooks/useConfig/useConfig.js +17 -0
- package/dist/components/ConfigProvider/index.d.ts +3 -0
- package/dist/components/DatePicker/DatePicker.d.ts +4 -0
- package/dist/components/DatePicker/DatePicker.js +13 -0
- package/dist/components/DatePicker/DatePicker.types.d.ts +8 -0
- package/dist/components/DatePicker/DatePicker.utils.d.ts +8 -0
- package/dist/components/DatePicker/DatePicker.utils.js +13 -0
- package/dist/components/DatePicker/components/RangePicker/RangePicker.d.ts +4 -0
- package/dist/components/DatePicker/components/RangePicker/RangePicker.js +11 -0
- package/dist/components/DatePicker/components/RangePicker/RangePicker.types.d.ts +3 -0
- package/dist/components/DatePicker/index.d.ts +2 -0
- package/dist/components/Dropdown/Dropdown.d.ts +3 -0
- package/dist/components/Dropdown/Dropdown.js +78 -0
- package/dist/components/Dropdown/Dropdown.tokens.d.ts +13 -0
- package/dist/components/Dropdown/Dropdown.tokens.js +14 -0
- package/dist/components/Dropdown/Dropdown.types.d.ts +98 -0
- package/dist/components/Dropdown/Dropdown.types.js +30 -0
- package/dist/components/Dropdown/Dropdown.utils.d.ts +4 -0
- package/dist/components/Dropdown/Dropdown.utils.js +40 -0
- package/dist/components/Dropdown/components/Divider/Divider.d.ts +2 -0
- package/dist/components/Dropdown/components/Divider/Divider.js +11 -0
- package/dist/components/Dropdown/components/Divider/Divider.styles.d.ts +7 -0
- package/dist/components/Dropdown/components/Divider/Divider.styles.js +13 -0
- package/dist/components/Dropdown/components/Group/Group.d.ts +3 -0
- package/dist/components/Dropdown/components/Group/Group.js +37 -0
- package/dist/components/Dropdown/components/Group/Group.styles.d.ts +29 -0
- package/dist/components/Dropdown/components/Group/Group.styles.js +39 -0
- package/dist/components/Dropdown/components/Group/Group.types.d.ts +7 -0
- package/dist/components/Dropdown/components/Item/Item.d.ts +3 -0
- package/dist/components/Dropdown/components/Item/Item.js +55 -0
- package/dist/components/Dropdown/components/Item/Item.style.d.ts +51 -0
- package/dist/components/Dropdown/components/Item/Item.style.js +74 -0
- package/dist/components/Dropdown/components/Item/Item.types.d.ts +7 -0
- package/dist/components/Dropdown/components/Menu/Menu.d.ts +3 -0
- package/dist/components/Dropdown/components/Menu/Menu.js +78 -0
- package/dist/components/Dropdown/components/Menu/Menu.styles.d.ts +55 -0
- package/dist/components/Dropdown/components/Menu/Menu.styles.js +69 -0
- package/dist/components/Dropdown/components/Menu/Menu.types.d.ts +7 -0
- package/dist/components/Dropdown/components/SubMenu/SubMenu.d.ts +3 -0
- package/dist/components/Dropdown/components/SubMenu/SubMenu.js +131 -0
- package/dist/components/Dropdown/components/SubMenu/SubMenu.types.d.ts +6 -0
- package/dist/components/Dropdown/components/SubMenu/SubMenu.utils.d.ts +2 -0
- package/dist/components/Dropdown/components/SubMenu/SubMenu.utils.js +15 -0
- package/dist/components/Dropdown/contexts/dropdownContext.d.ts +22 -0
- package/dist/components/Dropdown/contexts/dropdownContext.js +5 -0
- package/dist/components/Dropdown/forStories/menusData.d.ts +9 -0
- package/dist/components/Dropdown/hooks/useFilter.d.ts +8 -0
- package/dist/components/Dropdown/hooks/useFilter.js +45 -0
- package/dist/components/Dropdown/hooks/useSelectedKeysController.d.ts +30 -0
- package/dist/components/Dropdown/hooks/useSelectedKeysController.js +58 -0
- package/dist/components/Dropdown/hooks/useStepSubMenus.d.ts +7 -0
- package/dist/components/Dropdown/hooks/useStepSubMenus.js +34 -0
- package/dist/components/Dropdown/hooks/useSubMenusController.d.ts +7 -0
- package/dist/components/Dropdown/hooks/useSubMenusController.js +30 -0
- package/dist/components/Dropdown/index.d.ts +2 -0
- package/dist/components/Input/Input.d.ts +3 -0
- package/dist/components/Input/Input.js +163 -0
- package/dist/components/Input/Input.styles.d.ts +184 -0
- package/dist/components/Input/Input.styles.js +138 -0
- package/dist/components/Input/Input.tokens.d.ts +18 -0
- package/dist/components/Input/Input.tokens.js +19 -0
- package/dist/components/Input/Input.types.d.ts +19 -0
- package/dist/components/Input/components/InputPassword/InputPassword.d.ts +2 -0
- package/dist/components/Input/components/InputPassword/InputPassword.js +51 -0
- package/dist/components/Input/components/InputPassword/InputPassword.styles.d.ts +10 -0
- package/dist/components/Input/components/InputPassword/InputPassword.styles.js +11 -0
- package/dist/components/Input/components/InputPassword/InputPassword.types.d.ts +11 -0
- package/dist/components/Input/components/InputTextArea/InputTextArea.d.ts +2 -0
- package/dist/components/Input/components/InputTextArea/InputTextArea.js +89 -0
- package/dist/components/Input/components/InputTextArea/InputTextArea.styles.d.ts +33 -0
- package/dist/components/Input/components/InputTextArea/InputTextArea.styles.js +13 -0
- package/dist/components/Input/components/InputTextArea/InputTextArea.types.d.ts +10 -0
- package/dist/components/Input/components/InputTextArea/InputTextArea.utils.d.ts +9 -0
- package/dist/components/Input/components/InputTextArea/InputTextArea.utils.js +105 -0
- package/dist/components/Input/hooks/useKeyboardEvents/index.d.ts +1 -0
- package/dist/components/Input/hooks/useKeyboardEvents/useKeyboardEvents.d.ts +7 -0
- package/dist/components/Input/hooks/useKeyboardEvents/useKeyboardEvents.js +43 -0
- package/dist/components/Input/hooks/useKeyboardEvents/useKeyboardEvents.types.d.ts +3 -0
- package/dist/components/Input/hooks/useMergeState/index.d.ts +1 -0
- package/dist/components/Input/hooks/useMergeState/useMergeState.d.ts +21 -0
- package/dist/components/Input/hooks/useMergeState/useMergeState.js +94 -0
- package/dist/components/Input/hooks/useRemovePasswordTimeout/index.d.ts +1 -0
- package/dist/components/Input/hooks/useRemovePasswordTimeout/useRemovePasswordTimeout.d.ts +4 -0
- package/dist/components/Input/hooks/useRemovePasswordTimeout/useRemovePasswordTimeout.js +49 -0
- package/dist/components/Input/hooks/useRemovePasswordTimeout/useRemovePasswordTimeout.types.d.ts +8 -0
- package/dist/components/Input/index.d.ts +2 -0
- package/dist/components/Input/utils/resolveOnChange/index.d.ts +1 -0
- package/dist/components/Input/utils/resolveOnChange/resolveOnChange.d.ts +3 -0
- package/dist/components/Input/utils/resolveOnChange/resolveOnChange.js +41 -0
- package/dist/components/InputNumber/InputNumber.d.ts +2 -0
- package/dist/components/InputNumber/InputNumber.js +189 -0
- package/dist/components/InputNumber/InputNumber.styles.d.ts +107 -0
- package/dist/components/InputNumber/InputNumber.styles.js +115 -0
- package/dist/components/InputNumber/InputNumber.tokens.d.ts +18 -0
- package/dist/components/InputNumber/InputNumber.tokens.js +19 -0
- package/dist/components/InputNumber/InputNumber.types.d.ts +41 -0
- package/dist/components/InputNumber/InputNumber.utils.d.ts +2 -0
- package/dist/components/InputNumber/InputNumber.utils.js +9 -0
- package/dist/components/InputNumber/components/StepController/StepController.d.ts +3 -0
- package/dist/components/InputNumber/components/StepController/StepController.js +26 -0
- package/dist/components/InputNumber/components/StepController/StepController.styles.d.ts +51 -0
- package/dist/components/InputNumber/components/StepController/StepController.styles.js +51 -0
- package/dist/components/InputNumber/components/StepController/StepController.types.d.ts +5 -0
- package/dist/components/InputNumber/hooks/useChangeValue/index.d.ts +1 -0
- package/dist/components/InputNumber/hooks/useChangeValue/useChangeValue.d.ts +9 -0
- package/dist/components/InputNumber/hooks/useChangeValue/useChangeValue.js +103 -0
- package/dist/components/InputNumber/hooks/useChangeValue/useChangeValue.types.d.ts +11 -0
- package/dist/components/InputNumber/hooks/useDecimalTools/index.d.ts +1 -0
- package/dist/components/InputNumber/hooks/useDecimalTools/useDecimalTools.d.ts +6 -0
- package/dist/components/InputNumber/hooks/useDecimalTools/useDecimalTools.js +59 -0
- package/dist/components/InputNumber/hooks/useDecimalTools/useDecimalTools.types.d.ts +6 -0
- package/dist/components/InputNumber/hooks/useFocusBlurEvents/index.d.ts +1 -0
- package/dist/components/InputNumber/hooks/useFocusBlurEvents/useFocusBlurEvents.d.ts +9 -0
- package/dist/components/InputNumber/hooks/useFocusBlurEvents/useFocusBlurEvents.js +35 -0
- package/dist/components/InputNumber/hooks/useFocusBlurEvents/useFocusBlurEvents.types.d.ts +7 -0
- package/dist/components/InputNumber/hooks/useKeyboardEvents/index.d.ts +1 -0
- package/dist/components/InputNumber/hooks/useKeyboardEvents/useKeyboardEvents.d.ts +6 -0
- package/dist/components/InputNumber/hooks/useKeyboardEvents/useKeyboardEvents.js +37 -0
- package/dist/components/InputNumber/hooks/useKeyboardEvents/useKeyboardEvents.types.d.ts +10 -0
- package/dist/components/InputNumber/hooks/useRange/index.d.ts +1 -0
- package/dist/components/InputNumber/hooks/useRange/useRange.d.ts +9 -0
- package/dist/components/InputNumber/hooks/useRange/useRange.js +36 -0
- package/dist/components/InputNumber/hooks/useRange/useRange.types.d.ts +7 -0
- package/dist/components/InputNumber/hooks/useStep/index.d.ts +1 -0
- package/dist/components/InputNumber/hooks/useStep/useStep.d.ts +6 -0
- package/dist/components/InputNumber/hooks/useStep/useStep.js +55 -0
- package/dist/components/InputNumber/hooks/useStep/useStep.types.d.ts +14 -0
- package/dist/components/InputNumber/hooks/useWheelEvents/index.d.ts +1 -0
- package/dist/components/InputNumber/hooks/useWheelEvents/useWheelEvents.d.ts +2 -0
- package/dist/components/InputNumber/hooks/useWheelEvents/useWheelEvents.js +27 -0
- package/dist/components/InputNumber/hooks/useWheelEvents/useWheelEvents.types.d.ts +9 -0
- package/dist/components/InputNumber/index.d.ts +2 -0
- package/dist/components/InputNumber/utils/BigIntDecimal.d.ts +27 -0
- package/dist/components/InputNumber/utils/BigIntDecimal.js +124 -0
- package/dist/components/InputNumber/utils/MiniDecimal.d.ts +3 -0
- package/dist/components/InputNumber/utils/MiniDecimal.js +42 -0
- package/dist/components/InputNumber/utils/NumberDecimal.d.ts +17 -0
- package/dist/components/InputNumber/utils/NumberDecimal.js +83 -0
- package/dist/components/InputNumber/utils/index.d.ts +4 -0
- package/dist/components/InputNumber/utils/interface.d.ts +13 -0
- package/dist/components/InputNumber/utils/numberUtil.d.ts +15 -0
- package/dist/components/InputNumber/utils/numberUtil.js +91 -0
- package/dist/components/InputNumber/utils/supportUtil.d.ts +1 -0
- package/dist/components/InputNumber/utils/supportUtil.js +6 -0
- package/dist/components/InternalPicker/config/docsStoriesLocale.d.ts +2 -0
- package/dist/components/InternalPicker/config/index.d.ts +2 -0
- package/dist/components/InternalPicker/config/types.d.ts +25 -0
- package/dist/components/InternalPicker/index.d.ts +4 -0
- package/dist/components/InternalPicker/pickers/RangePicker/RangePicker.d.ts +4 -0
- package/dist/components/InternalPicker/pickers/RangePicker/RangePicker.js +49 -0
- package/dist/components/InternalPicker/pickers/RangePicker/RangePicker.types.d.ts +8 -0
- package/dist/components/InternalPicker/pickers/RangePicker/RangePicker.utils.d.ts +3 -0
- package/dist/components/InternalPicker/pickers/RangePicker/RangePicker.utils.js +13 -0
- package/dist/components/InternalPicker/pickers/RangePicker/index.d.ts +2 -0
- package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.d.ts +4 -0
- package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.js +48 -0
- package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.types.d.ts +9 -0
- package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.utils.d.ts +21 -0
- package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.utils.js +102 -0
- package/dist/components/InternalPicker/pickers/SinglePicker/index.d.ts +3 -0
- package/dist/components/InternalPicker/pickers/hooks/useComponents/index.d.ts +1 -0
- package/dist/components/InternalPicker/pickers/hooks/useComponents/useComponents.d.ts +8 -0
- package/dist/components/InternalPicker/pickers/hooks/useComponents/useComponents.js +18 -0
- package/dist/components/InternalPicker/pickers/hooks/useComponents/useComponents.types.d.ts +5 -0
- package/dist/components/InternalPicker/pickers/index.d.ts +2 -0
- package/dist/components/InternalPicker/styles/DatePanel.styles.d.ts +963 -0
- package/dist/components/InternalPicker/styles/DatePanel.styles.js +234 -0
- package/dist/components/InternalPicker/styles/Popup.styles.d.ts +1042 -0
- package/dist/components/InternalPicker/styles/Popup.styles.js +73 -0
- package/dist/components/InternalPicker/styles/RangeSelector.styles.d.ts +130 -0
- package/dist/components/InternalPicker/styles/RangeSelector.styles.js +45 -0
- package/dist/components/InternalPicker/styles/SingleSelector.styles.d.ts +102 -0
- package/dist/components/InternalPicker/styles/SingleSelector.styles.js +117 -0
- package/dist/components/InternalPicker/styles/TimePanel.styles.d.ts +49 -0
- package/dist/components/InternalPicker/styles/TimePanel.styles.js +64 -0
- package/dist/components/InternalPicker/styles/common.styles.d.ts +1 -0
- package/dist/components/InternalPicker/styles/common.styles.js +4 -0
- package/dist/components/InternalPicker/styles/index.d.ts +4 -0
- package/dist/components/InternalPicker/tokens.d.ts +29 -0
- package/dist/components/InternalPicker/tokens.js +30 -0
- package/dist/components/Message/components/Message/Message.d.ts +3 -0
- package/dist/components/Message/components/Message/Message.js +49 -0
- package/dist/components/Message/components/Message/Message.styles.d.ts +47 -0
- package/dist/components/Message/components/Message/Message.styles.js +93 -0
- package/dist/components/Message/components/Message/Message.tokens.d.ts +8 -0
- package/dist/components/Message/components/Message/Message.tokens.js +10 -0
- package/dist/components/Message/components/Message/Message.types.d.ts +22 -0
- package/dist/components/Message/components/Message/Message.utils.d.ts +6 -0
- package/dist/components/Message/components/Message/Message.utils.js +22 -0
- package/dist/components/Message/components/MessageList/MessageList.d.ts +3 -0
- package/dist/components/Message/components/MessageList/MessageList.js +13 -0
- package/dist/components/Message/components/MessageList/MessageList.styles.d.ts +70 -0
- package/dist/components/Message/components/MessageList/MessageList.styles.js +63 -0
- package/dist/components/Message/components/MessageList/MessageList.types.d.ts +6 -0
- package/dist/components/Message/components/MessagesHolder/MessagesHolder.d.ts +3 -0
- package/dist/components/Message/components/MessagesHolder/MessagesHolder.js +23 -0
- package/dist/components/Message/components/MessagesHolder/MessagesHolder.types.d.ts +9 -0
- package/dist/components/Message/forStories/utils.d.ts +12 -0
- package/dist/components/Message/index.d.ts +2 -0
- package/dist/components/Message/message.d.ts +9 -0
- package/dist/components/Message/message.js +105 -0
- package/dist/components/Message/message.types.d.ts +32 -0
- package/dist/components/Message/message.utils.d.ts +3 -0
- package/dist/components/Message/message.utils.js +15 -0
- package/dist/components/Popconfirm/Popconfirm.d.ts +3 -0
- package/dist/components/Popconfirm/Popconfirm.tokens.d.ts +10 -0
- package/dist/components/Popconfirm/Popconfirm.types.d.ts +28 -0
- package/dist/components/Popconfirm/components/PopconfirmFloatingElement/PopconfirmFloatingElement.d.ts +3 -0
- package/dist/components/Popconfirm/components/PopconfirmFloatingElement/PopconfirmFloatingElement.styles.d.ts +55 -0
- package/dist/components/Popover/Popover.d.ts +3 -0
- package/dist/components/Popover/Popover.js +22 -0
- package/dist/components/Popover/Popover.tokens.d.ts +9 -0
- package/dist/components/Popover/Popover.tokens.js +11 -0
- package/dist/components/Popover/Popover.types.d.ts +13 -0
- package/dist/components/Popover/component/PopoverFloatingElement/PopoverFloatingElement.d.ts +3 -0
- package/dist/components/Popover/component/PopoverFloatingElement/PopoverFloatingElement.js +21 -0
- package/dist/components/Popover/component/PopoverFloatingElement/PopoverFloatingElement.styles.d.ts +32 -0
- package/dist/components/Popover/component/PopoverFloatingElement/PopoverFloatingElement.styles.js +38 -0
- package/dist/components/Popover/forStories/utils.d.ts +1 -0
- package/dist/components/Popover/index.d.ts +2 -0
- package/dist/components/Progress/Progress.d.ts +3 -0
- package/dist/components/Progress/Progress.js +28 -0
- package/dist/components/Progress/Progress.styles.d.ts +18 -0
- package/dist/components/Progress/Progress.styles.js +39 -0
- package/dist/components/Progress/Progress.tokens.d.ts +11 -0
- package/dist/components/Progress/Progress.tokens.js +12 -0
- package/dist/components/Progress/Progress.types.d.ts +8 -0
- package/dist/components/Progress/index.d.ts +2 -0
- package/dist/components/Radio/Radio.d.ts +3 -0
- package/dist/components/Radio/Radio.js +53 -0
- package/dist/components/Radio/Radio.styles.d.ts +66 -0
- package/dist/components/Radio/Radio.styles.js +72 -0
- package/dist/components/Radio/Radio.tokens.d.ts +16 -0
- package/dist/components/Radio/Radio.tokens.js +17 -0
- package/dist/components/Radio/Radio.types.d.ts +9 -0
- package/dist/components/Radio/components/RadioGroup/RadioGroup.d.ts +3 -0
- package/dist/components/Radio/components/RadioGroup/RadioGroup.js +58 -0
- package/dist/components/Radio/components/RadioGroup/RadioGroup.styles.d.ts +5 -0
- package/dist/components/Radio/components/RadioGroup/RadioGroup.styles.js +7 -0
- package/dist/components/Radio/components/RadioGroup/RadioGroup.types.d.ts +11 -0
- package/dist/components/Radio/components/RadioInternal/RadioInternal.d.ts +2 -0
- package/dist/components/Radio/components/RadioInternal/RadioInternal.js +52 -0
- package/dist/components/Radio/components/RadioInternal/RadioInternal.styles.d.ts +61 -0
- package/dist/components/Radio/components/RadioInternal/RadioInternal.styles.js +70 -0
- package/dist/components/Radio/components/RadioInternal/RadioInternal.types.d.ts +14 -0
- package/dist/components/Radio/contexts/RadioGroupContext.d.ts +4 -0
- package/dist/components/Radio/contexts/RadioGroupContext.js +5 -0
- package/dist/components/Radio/hooks/useMergeState/index.d.ts +1 -0
- package/dist/components/Radio/hooks/useMergeState/useMergeState.d.ts +21 -0
- package/dist/components/Radio/hooks/useMergeState/useMergeState.js +94 -0
- package/dist/components/Radio/index.d.ts +2 -0
- package/dist/components/Select/Select.d.ts +3 -0
- package/dist/components/Select/Select.js +305 -0
- package/dist/components/Select/Select.styles.d.ts +135 -0
- package/dist/components/Select/Select.styles.js +210 -0
- package/dist/components/Select/Select.tokens.d.ts +27 -0
- package/dist/components/Select/Select.tokens.js +28 -0
- package/dist/components/Select/Select.types.d.ts +89 -0
- package/dist/components/Select/Select.utils.d.ts +10 -0
- package/dist/components/Select/Select.utils.js +59 -0
- package/dist/components/Select/components/SelectOption/SelectOption.d.ts +3 -0
- package/dist/components/Select/components/SelectOption/SelectOption.js +55 -0
- package/dist/components/Select/components/SelectOption/SelectOption.styles.d.ts +41 -0
- package/dist/components/Select/components/SelectOption/SelectOption.styles.js +54 -0
- package/dist/components/Select/components/SelectOption/SelectOption.types.d.ts +22 -0
- package/dist/components/Select/components/SelectOptionList/SelectOptionList.d.ts +3 -0
- package/dist/components/Select/components/SelectOptionList/SelectOptionList.js +139 -0
- package/dist/components/Select/components/SelectOptionList/SelectOptionList.styles.d.ts +66 -0
- package/dist/components/Select/components/SelectOptionList/SelectOptionList.styles.js +85 -0
- package/dist/components/Select/components/SelectOptionList/SelectOptionList.types.d.ts +42 -0
- package/dist/components/Select/components/SelectOptionList/SelectOptionList.utils.d.ts +1 -0
- package/dist/components/Select/components/SelectOptionList/SelectOptionList.utils.js +4 -0
- package/dist/components/Select/components/SelectTag/SelectTag.d.ts +3 -0
- package/dist/components/Select/components/SelectTag/SelectTag.js +24 -0
- package/dist/components/Select/components/SelectTag/SelectTag.styles.d.ts +8 -0
- package/dist/components/Select/components/SelectTag/SelectTag.styles.js +23 -0
- package/dist/components/Select/components/SelectTag/SelectTag.types.d.ts +10 -0
- package/dist/components/Select/components/TagPlaceholder/TagPlaceholder.d.ts +4 -0
- package/dist/components/Select/components/TagPlaceholder/TagPlaceholder.js +13 -0
- package/dist/components/Select/components/TagPlaceholder/TagPlaceholder.styles.d.ts +5 -0
- package/dist/components/Select/components/TagPlaceholder/TagPlaceholder.styles.js +8 -0
- package/dist/components/Select/components/TagPlaceholder/TagPlaceholder.types.d.ts +3 -0
- package/dist/components/Select/forStories/dataForExamples.d.ts +20 -0
- package/dist/components/Select/hooks/useCurrentValue.d.ts +8 -0
- package/dist/components/Select/hooks/useCurrentValue.js +31 -0
- package/dist/components/Select/hooks/useDefaultCurrentValue.d.ts +3 -0
- package/dist/components/Select/hooks/useDefaultCurrentValue.js +14 -0
- package/dist/components/Select/hooks/useDefaultSelectIndex.d.ts +2 -0
- package/dist/components/Select/hooks/useDefaultSelectIndex.js +17 -0
- package/dist/components/Select/hooks/useHideElements.d.ts +5 -0
- package/dist/components/Select/hooks/useHideElements.js +60 -0
- package/dist/components/Select/hooks/useKeyControl.d.ts +7 -0
- package/dist/components/Select/hooks/useKeyControl.js +37 -0
- package/dist/components/Select/hooks/useSearch.d.ts +11 -0
- package/dist/components/Select/hooks/useSearch.js +55 -0
- package/dist/components/Select/index.d.ts +2 -0
- package/dist/components/Switch/Switch.d.ts +3 -0
- package/dist/components/Switch/Switch.js +68 -0
- package/dist/components/Switch/Switch.styles.d.ts +7 -0
- package/dist/components/Switch/Switch.styles.js +62 -0
- package/dist/components/Switch/Switch.tokens.d.ts +20 -0
- package/dist/components/Switch/Switch.tokens.js +22 -0
- package/dist/components/Switch/Switch.types.d.ts +24 -0
- package/dist/components/Switch/Switch.utils.d.ts +4 -0
- package/dist/components/Switch/Switch.utils.js +10 -0
- package/dist/components/Switch/index.d.ts +2 -0
- package/dist/components/Tag/Tag.d.ts +4 -0
- package/dist/components/Tag/Tag.js +42 -0
- package/dist/components/Tag/Tag.styles.d.ts +303 -0
- package/dist/components/Tag/Tag.styles.js +52 -0
- package/dist/components/Tag/Tag.types.d.ts +23 -0
- package/dist/components/Tag/Tag.utils.d.ts +86 -0
- package/dist/components/Tag/Tag.utils.js +90 -0
- package/dist/components/Tag/components/AddTagController/AddTagController.d.ts +3 -0
- package/dist/components/Tag/components/AddTagController/AddTagController.styles.d.ts +15 -0
- package/dist/components/Tag/components/AddTagController/AddTagController.types.d.ts +13 -0
- package/dist/components/Tag/components/AddTagController/forStories/utilsForStories.d.ts +3 -0
- package/dist/components/Tag/components/Checkable/Checkable.d.ts +4 -0
- package/dist/components/Tag/components/Checkable/Checkable.js +34 -0
- package/dist/components/Tag/components/Checkable/Checkable.styles.d.ts +30 -0
- package/dist/components/Tag/components/Checkable/Checkable.styles.js +35 -0
- package/dist/components/Tag/components/Checkable/Checkable.tokens.d.ts +10 -0
- package/dist/components/Tag/components/Checkable/Checkable.tokens.js +12 -0
- package/dist/components/Tag/components/Checkable/Checkable.types.d.ts +12 -0
- package/dist/components/Tag/index.d.ts +3 -0
- package/dist/components/TimePicker/TimePicker.d.ts +4 -0
- package/dist/components/TimePicker/TimePicker.js +13 -0
- package/dist/components/TimePicker/TimePicker.types.d.ts +8 -0
- package/dist/components/TimePicker/TimePicker.utils.d.ts +4 -0
- package/dist/components/TimePicker/TimePicker.utils.js +9 -0
- package/dist/components/TimePicker/components/RangePicker/RangePicker.d.ts +4 -0
- package/dist/components/TimePicker/components/RangePicker/RangePicker.js +11 -0
- package/dist/components/TimePicker/components/RangePicker/RangePicker.types.d.ts +3 -0
- package/dist/components/TimePicker/index.d.ts +2 -0
- package/dist/components/Tooltip/Tooltip.d.ts +3 -0
- package/dist/components/Tooltip/Tooltip.js +22 -0
- package/dist/components/Tooltip/Tooltip.tokens.d.ts +10 -0
- package/dist/components/Tooltip/Tooltip.tokens.js +12 -0
- package/dist/components/Tooltip/Tooltip.types.d.ts +12 -0
- package/dist/components/Tooltip/components/TooltipFloatingElement/TooltipFloatingElement.d.ts +3 -0
- package/dist/components/Tooltip/components/TooltipFloatingElement/TooltipFloatingElement.js +15 -0
- package/dist/components/Tooltip/components/TooltipFloatingElement/TooltipFloatingElement.styles.d.ts +15 -0
- package/dist/components/Tooltip/components/TooltipFloatingElement/TooltipFloatingElement.styles.js +19 -0
- package/dist/components/Tooltip/components/TooltipFloatingElement/TooltipFloatingElement.type.d.ts +6 -0
- package/dist/components/Tooltip/index.d.ts +2 -0
- package/dist/components/Upload/Upload.d.ts +3 -0
- package/dist/components/Upload/Upload.js +125 -0
- package/dist/components/Upload/Upload.styles.d.ts +31 -0
- package/dist/components/Upload/Upload.styles.js +32 -0
- package/dist/components/Upload/Upload.tokens.d.ts +16 -0
- package/dist/components/Upload/Upload.tokens.js +17 -0
- package/dist/components/Upload/Upload.types.d.ts +34 -0
- package/dist/components/Upload/components/Dragger/Dragger.d.ts +3 -0
- package/dist/components/Upload/components/Dragger/Dragger.js +29 -0
- package/dist/components/Upload/components/Dragger/Dragger.styles.d.ts +22 -0
- package/dist/components/Upload/components/Dragger/Dragger.styles.js +24 -0
- package/dist/components/Upload/components/Dragger/Dragger.types.d.ts +6 -0
- package/dist/components/Upload/components/InternalUpload/InternalUpload.d.ts +3 -0
- package/dist/components/Upload/components/InternalUpload/InternalUpload.js +91 -0
- package/dist/components/Upload/components/InternalUpload/InternalUpload.types.d.ts +9 -0
- package/dist/components/Upload/components/UploadList/UploadList.d.ts +3 -0
- package/dist/components/Upload/components/UploadList/UploadList.js +19 -0
- package/dist/components/Upload/components/UploadList/UploadList.styles.d.ts +9 -0
- package/dist/components/Upload/components/UploadList/UploadList.styles.js +11 -0
- package/dist/components/Upload/components/UploadList/UploadList.types.d.ts +8 -0
- package/dist/components/Upload/components/UploadListItem/UploadListItem.d.ts +3 -0
- package/dist/components/Upload/components/UploadListItem/UploadListItem.js +51 -0
- package/dist/components/Upload/components/UploadListItem/UploadListItem.styles.d.ts +70 -0
- package/dist/components/Upload/components/UploadListItem/UploadListItem.styles.js +73 -0
- package/dist/components/Upload/components/UploadListItem/UploadListItem.types.d.ts +4 -0
- package/dist/components/Upload/hooks/useDnd/useDnd.d.ts +8 -0
- package/dist/components/Upload/hooks/useDnd/useDnd.js +22 -0
- package/dist/components/Upload/hooks/useDnd/useDnd.types.d.ts +3 -0
- package/dist/components/Upload/index.d.ts +2 -0
- package/dist/components/Upload/utils/attrAccept.d.ts +1 -0
- package/dist/components/Upload/utils/attrAccept.js +38 -0
- package/dist/components/Upload/utils/file2obj.d.ts +6 -0
- package/dist/components/Upload/utils/file2obj.js +13 -0
- package/dist/components/Upload/utils/modifyFileList.d.ts +3 -0
- package/dist/components/Upload/utils/modifyFileList.js +24 -0
- package/dist/components/Upload/utils/uidGenerator.d.ts +1 -0
- package/dist/components/Upload/utils/uidGenerator.js +33 -0
- package/dist/configure/dayjs.d.ts +0 -0
- package/dist/configure/dayjs.js +4 -0
- package/dist/configure/index.d.ts +0 -0
- package/dist/contexts/themeContext.d.ts +354 -0
- package/dist/contexts/themeContext.js +6 -0
- package/dist/docComponents/Demonstration/Demonstration.d.ts +4 -0
- package/dist/docComponents/Demonstration/Demonstration.styles.d.ts +9 -0
- package/dist/docComponents/Demonstration/Demonstration.types.d.ts +5 -0
- package/dist/docComponents/Description/Description.d.ts +5 -0
- package/dist/docComponents/Description/Description.style.d.ts +26 -0
- package/dist/docComponents/Doc/Doc.d.ts +4 -0
- package/dist/docComponents/Doc/Doc.style.d.ts +13 -0
- package/dist/docComponents/Example/Example.d.ts +4 -0
- package/dist/docComponents/Example/Example.styles.d.ts +9 -0
- package/dist/hocs/withThemeProvider.d.ts +2 -0
- package/dist/hocs/withThemeProvider.js +11 -0
- package/dist/hooks/useDebounce.d.ts +3 -0
- package/dist/hooks/useDebounce.js +27 -0
- package/dist/hooks/useForceUpdate.d.ts +1 -0
- package/dist/hooks/useForceUpdate.js +9 -0
- package/dist/hooks/useLoadingDelay.d.ts +6 -0
- package/dist/hooks/useLoadingDelay.js +34 -0
- package/dist/hooks/usePrevious.d.ts +1 -0
- package/dist/hooks/usePrevious.js +11 -0
- package/dist/hooks/useResizeObserver.d.ts +1 -0
- package/dist/hooks/useResizeObserver.js +25 -0
- package/dist/hooks/useTheme/index.d.ts +1 -0
- package/dist/hooks/useTheme/useTheme.d.ts +354 -0
- package/dist/hooks/useTheme/useTheme.js +8 -0
- package/dist/icons/icons/LoadingOutlined.d.ts +3 -0
- package/dist/icons/icons/LoadingOutlined.js +9 -0
- package/dist/icons/icons/index.d.ts +1 -0
- package/dist/index.d.ts +40 -0
- package/dist/index.js +53 -0
- package/dist/providers/ThemeProvider/ThemeProvider.d.ts +3 -0
- package/dist/providers/ThemeProvider/ThemeProvider.js +11 -0
- package/dist/providers/ThemeProvider/ThemeProvider.types.d.ts +4 -0
- package/dist/providers/ThemeProvider/index.d.ts +2 -0
- package/dist/themes/baseTokens/baseColorTokens/baseColorTokens.d.ts +158 -0
- package/dist/themes/baseTokens/baseColorTokens/baseColorTokens.js +35 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/blueColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/blueColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/cyanColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/cyanColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/goldColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/goldColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/greenColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/greenColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/limeColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/limeColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/magentaColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/magentaColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/neutralColors.d.ts +18 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/neutralColors.js +21 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/orangeColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/orangeColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/purpleColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/purpleColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/redColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/redColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/thrushColor.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/thrushColor.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/transparentBlackColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/transparentBlackColors.js +16 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/transparentWhiteColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/transparentWhiteColors.js +16 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/volcanoColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/volcanoColors.js +15 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/yellowColors.d.ts +12 -0
- package/dist/themes/baseTokens/baseColorTokens/colorGroups/yellowColors.js +15 -0
- package/dist/themes/baseTokens/baseShadowTokens/baseShadowTokens.d.ts +5 -0
- package/dist/themes/baseTokens/baseShadowTokens/baseShadowTokens.js +9 -0
- package/dist/themes/baseTokens/baseSizeTokens/baseSizeTokens.d.ts +17 -0
- package/dist/themes/baseTokens/baseSizeTokens/baseSizeTokens.js +21 -0
- package/dist/themes/baseTokens/baseTypographyTokens/baseTypographyTokens.d.ts +42 -0
- package/dist/themes/baseTokens/baseTypographyTokens/baseTypographyTokens.js +49 -0
- package/dist/themes/baseTokens/const.d.ts +2 -0
- package/dist/themes/baseTokens/const.js +7 -0
- package/dist/themes/index.d.ts +4 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/PositiveColorTokens.d.ts +11 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/PositiveColorTokens.js +15 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/backgroundColorTokens.d.ts +25 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/backgroundColorTokens.js +29 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/controlShadowsTokens.d.ts +6 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/controlShadowsTokens.js +12 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/dangerColorTokens.d.ts +11 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/dangerColorTokens.js +15 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/infoColorTokens.d.ts +11 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/infoColorTokens.js +15 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/lineColorTokens.d.ts +8 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/lineColorTokens.js +12 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/primaryColorTokens.d.ts +11 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/primaryColorTokens.js +15 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/tagColorTokens.d.ts +40 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/tagColorTokens.js +44 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/textColorTokens.d.ts +19 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/textColorTokens.js +24 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/warningColorTokens.d.ts +11 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticBlocks/warningColorTokens.js +15 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticColorTokens.d.ts +116 -0
- package/dist/themes/semanticTokens/colorSemanticTokens/semanticColorTokens.js +25 -0
- package/dist/themes/semanticTokens/otherSemanticTokens/otherSemanticTokens.d.ts +4 -0
- package/dist/themes/semanticTokens/otherSemanticTokens/otherSemanticTokens.js +7 -0
- package/dist/themes/semanticTokens/otherSemanticTokens/semanticBlocks/opacityTokens.d.ts +5 -0
- package/dist/themes/semanticTokens/otherSemanticTokens/semanticBlocks/opacityTokens.js +8 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/borderRadiusSizeTokens.d.ts +6 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/borderRadiusSizeTokens.js +10 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/controlSizeTokens.d.ts +6 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/controlSizeTokens.js +10 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/iconSizeTokens.d.ts +9 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/iconSizeTokens.js +13 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/marginSizeTokens.d.ts +8 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/marginSizeTokens.js +12 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/paddingSizeTokens.d.ts +9 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/paddingSizeTokens.js +13 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/spaceSizeTokens.d.ts +8 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticBlocks/spaceSizeTokens.js +12 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticSizeTokens.d.ts +25 -0
- package/dist/themes/semanticTokens/sizeSemanticTokens/semanticSizeTokens.js +17 -0
- package/dist/themes/themes.d.ts +354 -0
- package/dist/themes/themes.js +9 -0
- package/dist/themes/themes.types.d.ts +4 -0
- package/dist/themes/themes.utils.d.ts +710 -0
- package/dist/themes/themes.utils.js +21 -0
- package/dist/types.d.ts +4 -0
- package/dist/utils/color/index.d.ts +5 -0
- package/dist/utils/color/index.js +47 -0
- package/dist/utils/color/types.d.ts +11 -0
- package/dist/utils/const/index.d.ts +1 -0
- package/dist/utils/const/index.js +4 -0
- package/dist/utils/consts.d.ts +2 -0
- package/dist/utils/consts.js +6 -0
- package/dist/utils/converters.d.ts +1 -0
- package/dist/utils/converters.js +5 -0
- package/dist/utils/index.d.ts +2 -0
- package/package.json +89 -0
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { forwardRef, useState, useEffect, memo } from "react";
|
|
3
|
+
import { EyeOutlined, EyeInvisibleOutlined } from "@infomaximum/icons";
|
|
4
|
+
import { Input } from "../../Input.js";
|
|
5
|
+
import { getInputTokens } from "../../Input.tokens.js";
|
|
6
|
+
import { getIconWrapperStyle } from "./InputPassword.styles.js";
|
|
7
|
+
import { useTheme } from "../../../../hooks/useTheme/useTheme.js";
|
|
8
|
+
const defaultSuffixIconRender = (visible) => visible ? /* @__PURE__ */ jsx(EyeOutlined, {}) : /* @__PURE__ */ jsx(EyeInvisibleOutlined, {});
|
|
9
|
+
const InputPasswordComponent = forwardRef((props, ref) => {
|
|
10
|
+
const {
|
|
11
|
+
visibilityToggle = true,
|
|
12
|
+
suffixIconRender = defaultSuffixIconRender,
|
|
13
|
+
...restProps
|
|
14
|
+
} = props;
|
|
15
|
+
const theme = useTheme();
|
|
16
|
+
const inputTokens = getInputTokens(theme);
|
|
17
|
+
const visibilityControlled = typeof visibilityToggle === "object" && visibilityToggle.visible !== void 0;
|
|
18
|
+
const [visible, setVisible] = useState(() => visibilityControlled ? visibilityToggle.visible : false);
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
if (visibilityControlled) {
|
|
21
|
+
setVisible(visibilityToggle.visible);
|
|
22
|
+
}
|
|
23
|
+
}, [visibilityControlled, visibilityToggle]);
|
|
24
|
+
const onVisibleChange = () => {
|
|
25
|
+
var _a;
|
|
26
|
+
if (props.disabled) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
const nextVisible = !visible;
|
|
30
|
+
setVisible(nextVisible);
|
|
31
|
+
if (typeof visibilityToggle === "object") {
|
|
32
|
+
(_a = visibilityToggle.onVisibleChange) == null ? void 0 : _a.call(visibilityToggle, nextVisible);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
const suffixIcon = (() => {
|
|
36
|
+
if (!visibilityToggle) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
const icon = suffixIconRender(visible);
|
|
40
|
+
return /* @__PURE__ */ jsx("span", { onClick: onVisibleChange, onMouseDown: (e) => {
|
|
41
|
+
e.preventDefault();
|
|
42
|
+
}, onMouseUp: (e) => {
|
|
43
|
+
e.preventDefault();
|
|
44
|
+
}, css: getIconWrapperStyle(inputTokens, props.disabled)(theme), children: icon }, "password-icon");
|
|
45
|
+
})();
|
|
46
|
+
return /* @__PURE__ */ jsx(Input, { ...restProps, ref, type: visible ? "text" : "password", suffix: suffixIcon });
|
|
47
|
+
});
|
|
48
|
+
const InputPassword = memo(InputPasswordComponent);
|
|
49
|
+
export {
|
|
50
|
+
InputPassword
|
|
51
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { InputTokens } from '../../Input.tokens';
|
|
2
|
+
import { Theme } from 'themes';
|
|
3
|
+
export declare const getIconWrapperStyle: (inputTokens: InputTokens, disabled: boolean | undefined) => (theme: Theme) => {
|
|
4
|
+
cursor: string;
|
|
5
|
+
display: string;
|
|
6
|
+
color: "#8C8C8C" | `rgba(${number}, ${number}, ${number}, 0.3)`;
|
|
7
|
+
":hover": {
|
|
8
|
+
color: `rgba(${number}, ${number}, ${number}, 0.7)` | undefined;
|
|
9
|
+
};
|
|
10
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
const getIconWrapperStyle = (inputTokens, disabled) => (theme) => ({
|
|
2
|
+
cursor: disabled ? "not-allowed" : "pointer",
|
|
3
|
+
display: "flex",
|
|
4
|
+
color: disabled ? inputTokens.inputTextDisabled : theme.transparentBlack30,
|
|
5
|
+
":hover": {
|
|
6
|
+
color: disabled ? void 0 : theme.transparentBlack70
|
|
7
|
+
}
|
|
8
|
+
});
|
|
9
|
+
export {
|
|
10
|
+
getIconWrapperStyle
|
|
11
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { InputProps } from '../../Input.types';
|
|
3
|
+
interface VisibilityToggle {
|
|
4
|
+
visible?: boolean;
|
|
5
|
+
onVisibleChange?: (visible: boolean) => void;
|
|
6
|
+
}
|
|
7
|
+
export interface InputPasswordProps extends Omit<InputProps, "suffix"> {
|
|
8
|
+
suffixIconRender?: (visible?: boolean) => ReactNode;
|
|
9
|
+
visibilityToggle?: boolean | VisibilityToggle;
|
|
10
|
+
}
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { forwardRef, useRef, useState, useEffect, useMemo, useLayoutEffect, memo } from "react";
|
|
3
|
+
import calculateAutoSizeStyle from "./InputTextArea.utils.js";
|
|
4
|
+
import { getTextareaStyle } from "./InputTextArea.styles.js";
|
|
5
|
+
import { getInputTokens } from "../../Input.tokens.js";
|
|
6
|
+
import { useMergeRefs } from "@floating-ui/react";
|
|
7
|
+
import { useTheme } from "../../../../hooks/useTheme/useTheme.js";
|
|
8
|
+
import { useMergedState } from "../../hooks/useMergeState/useMergeState.js";
|
|
9
|
+
const RESIZE_START = 0;
|
|
10
|
+
const RESIZE_MEASURING = 1;
|
|
11
|
+
const RESIZE_STABLE = 2;
|
|
12
|
+
const InputTextAreaComponent = forwardRef((props, ref) => {
|
|
13
|
+
const {
|
|
14
|
+
defaultValue,
|
|
15
|
+
value: valueProp,
|
|
16
|
+
status,
|
|
17
|
+
disabled,
|
|
18
|
+
autoSize,
|
|
19
|
+
style,
|
|
20
|
+
onChange,
|
|
21
|
+
...restProps
|
|
22
|
+
} = props;
|
|
23
|
+
const theme = useTheme();
|
|
24
|
+
const inputTokens = getInputTokens(theme);
|
|
25
|
+
const textAreaRef = useRef(null);
|
|
26
|
+
const mergedRef = useMergeRefs([textAreaRef, ref]);
|
|
27
|
+
const errorStatus = status === "error";
|
|
28
|
+
const needAutoSize = !!autoSize;
|
|
29
|
+
const [value, setValue] = useMergedState(defaultValue, {
|
|
30
|
+
value: valueProp
|
|
31
|
+
});
|
|
32
|
+
const [resizeState, setResizeState] = useState(RESIZE_STABLE);
|
|
33
|
+
const [autoSizeStyle, setAutoSizeStyle] = useState();
|
|
34
|
+
useEffect(() => {
|
|
35
|
+
if (!window.ResizeObserver || !textAreaRef.current || !autoSize) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const observer = new ResizeObserver((entries) => {
|
|
39
|
+
requestAnimationFrame(() => {
|
|
40
|
+
entries.forEach(() => {
|
|
41
|
+
startResize();
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
observer.observe(textAreaRef.current);
|
|
46
|
+
return () => observer.disconnect();
|
|
47
|
+
}, [autoSize]);
|
|
48
|
+
const startResize = () => {
|
|
49
|
+
setResizeState(RESIZE_START);
|
|
50
|
+
};
|
|
51
|
+
const [minRows, maxRows] = useMemo(() => {
|
|
52
|
+
if (autoSize && typeof autoSize === "object") {
|
|
53
|
+
return [autoSize.minRows, autoSize.maxRows];
|
|
54
|
+
}
|
|
55
|
+
return [];
|
|
56
|
+
}, [autoSize]);
|
|
57
|
+
useLayoutEffect(() => {
|
|
58
|
+
if (needAutoSize) {
|
|
59
|
+
startResize();
|
|
60
|
+
}
|
|
61
|
+
}, [value, minRows, maxRows, needAutoSize]);
|
|
62
|
+
useLayoutEffect(() => {
|
|
63
|
+
if (resizeState === RESIZE_START) {
|
|
64
|
+
setResizeState(RESIZE_MEASURING);
|
|
65
|
+
} else if (resizeState === RESIZE_MEASURING) {
|
|
66
|
+
const textareaStyles = calculateAutoSizeStyle(textAreaRef.current, false, minRows, maxRows);
|
|
67
|
+
setResizeState(RESIZE_STABLE);
|
|
68
|
+
setAutoSizeStyle(textareaStyles);
|
|
69
|
+
}
|
|
70
|
+
}, [maxRows, minRows, resizeState]);
|
|
71
|
+
const handleChange = (e) => {
|
|
72
|
+
setValue(e.target.value);
|
|
73
|
+
onChange == null ? void 0 : onChange(e);
|
|
74
|
+
};
|
|
75
|
+
const mergedAutoSizeStyle = needAutoSize ? autoSizeStyle : null;
|
|
76
|
+
const mergedStyle = {
|
|
77
|
+
...style,
|
|
78
|
+
...mergedAutoSizeStyle
|
|
79
|
+
};
|
|
80
|
+
if (resizeState === RESIZE_START || resizeState === RESIZE_MEASURING) {
|
|
81
|
+
mergedStyle.overflowY = "hidden";
|
|
82
|
+
mergedStyle.overflowX = "hidden";
|
|
83
|
+
}
|
|
84
|
+
return /* @__PURE__ */ jsx("textarea", { ...restProps, ref: mergedRef, style: mergedStyle, value, disabled, onChange: handleChange, css: getTextareaStyle(inputTokens, errorStatus, disabled)(theme) });
|
|
85
|
+
});
|
|
86
|
+
const InputTextArea = memo(InputTextAreaComponent);
|
|
87
|
+
export {
|
|
88
|
+
InputTextArea
|
|
89
|
+
};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { InputTokens } from '../../Input.tokens';
|
|
2
|
+
import { Theme } from 'themes';
|
|
3
|
+
export declare const getTextareaStyle: (inputTokens: InputTokens, errorStatus: boolean, disabled: boolean | undefined) => (theme: Theme) => {
|
|
4
|
+
readonly resize: "vertical";
|
|
5
|
+
readonly minHeight: 28;
|
|
6
|
+
readonly color: "#262626" | "#8C8C8C";
|
|
7
|
+
readonly "::placeholder": {
|
|
8
|
+
readonly color: "#BFBFBF" | "inherit";
|
|
9
|
+
};
|
|
10
|
+
readonly backgroundColor: "#F0F0F0" | "#FFFFFF";
|
|
11
|
+
readonly borderRadius: 4;
|
|
12
|
+
readonly borderWidth: 1;
|
|
13
|
+
readonly borderStyle: "solid";
|
|
14
|
+
readonly borderColor: "#D9D9D9" | "#FF4D4F";
|
|
15
|
+
readonly ":focus, :focus-within": {
|
|
16
|
+
readonly outline: "none";
|
|
17
|
+
readonly borderColor: "#FF4D4F" | "#0CB3B3";
|
|
18
|
+
readonly boxShadow: `0px 0px 4px 0px rgba(${number}, ${number}, ${number}, 0.5)`;
|
|
19
|
+
};
|
|
20
|
+
readonly ":hover": {
|
|
21
|
+
readonly borderColor: "#FF7875" | "#50CCC4" | undefined;
|
|
22
|
+
};
|
|
23
|
+
readonly fontFamily: "Roboto";
|
|
24
|
+
readonly fontSize: 14;
|
|
25
|
+
readonly lineHeight: "20px";
|
|
26
|
+
readonly position: "relative";
|
|
27
|
+
readonly boxSizing: "border-box";
|
|
28
|
+
readonly minWidth: 0;
|
|
29
|
+
readonly width: "100%";
|
|
30
|
+
readonly cursor: "not-allowed" | undefined;
|
|
31
|
+
readonly paddingInline: number;
|
|
32
|
+
readonly paddingBlock: number;
|
|
33
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { getSharedCommonStyle } from "../../Input.styles.js";
|
|
2
|
+
const getTextareaStyle = (inputTokens, errorStatus, disabled) => (theme) => ({
|
|
3
|
+
...getSharedCommonStyle(inputTokens, errorStatus, disabled, theme),
|
|
4
|
+
resize: "vertical",
|
|
5
|
+
minHeight: theme.controlHeightM,
|
|
6
|
+
color: disabled ? inputTokens.inputTextDisabled : inputTokens.inputText,
|
|
7
|
+
"::placeholder": {
|
|
8
|
+
color: disabled ? "inherit" : inputTokens.inputPlaceholder
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
export {
|
|
12
|
+
getTextareaStyle
|
|
13
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { TextareaHTMLAttributes } from 'react';
|
|
2
|
+
interface AutoSizeType {
|
|
3
|
+
minRows?: number;
|
|
4
|
+
maxRows?: number;
|
|
5
|
+
}
|
|
6
|
+
export interface InputTextAreaProps extends Pick<TextareaHTMLAttributes<HTMLTextAreaElement>, "id" | "name" | "autoFocus" | "placeholder" | "cols" | "rows" | "maxLength" | "disabled" | "readOnly" | "defaultValue" | "value" | "style" | "onChange" | "onBlur" | "onFocus"> {
|
|
7
|
+
status?: "error";
|
|
8
|
+
autoSize?: boolean | AutoSizeType;
|
|
9
|
+
}
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { CSSProperties } from 'react';
|
|
2
|
+
export interface NodeType {
|
|
3
|
+
sizingStyle: string;
|
|
4
|
+
paddingSize: number;
|
|
5
|
+
borderSize: number;
|
|
6
|
+
boxSizing: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function calculateNodeStyling(node: HTMLElement, useCache?: boolean): NodeType;
|
|
9
|
+
export default function calculateAutoSizeStyle(uiTextNode: HTMLTextAreaElement | null, useCache?: boolean, minRows?: number | null, maxRows?: number | null): CSSProperties;
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
const HIDDEN_TEXTAREA_STYLE = `
|
|
2
|
+
min-height:0 !important;
|
|
3
|
+
max-height:none !important;
|
|
4
|
+
height:0 !important;
|
|
5
|
+
visibility:hidden !important;
|
|
6
|
+
overflow:hidden !important;
|
|
7
|
+
position:absolute !important;
|
|
8
|
+
z-index:-1000 !important;
|
|
9
|
+
top:0 !important;
|
|
10
|
+
right:0 !important;
|
|
11
|
+
pointer-events: none !important;
|
|
12
|
+
`;
|
|
13
|
+
const SIZING_STYLE = ["letter-spacing", "line-height", "padding-top", "padding-bottom", "font-family", "font-weight", "font-size", "font-variant", "text-rendering", "text-transform", "width", "text-indent", "padding-left", "padding-right", "border-width", "box-sizing", "word-break", "white-space"];
|
|
14
|
+
const computedStyleCache = {};
|
|
15
|
+
let hiddenTextarea;
|
|
16
|
+
function calculateNodeStyling(node, useCache = false) {
|
|
17
|
+
const nodeRef = node.getAttribute("id") || node.getAttribute("data-reactid") || node.getAttribute("name");
|
|
18
|
+
if (useCache && computedStyleCache[nodeRef]) {
|
|
19
|
+
return computedStyleCache[nodeRef];
|
|
20
|
+
}
|
|
21
|
+
const style = window.getComputedStyle(node);
|
|
22
|
+
const boxSizing = style.getPropertyValue("box-sizing") || style.getPropertyValue("-moz-box-sizing") || style.getPropertyValue("-webkit-box-sizing");
|
|
23
|
+
const paddingSize = parseFloat(style.getPropertyValue("padding-bottom")) + parseFloat(style.getPropertyValue("padding-top"));
|
|
24
|
+
const borderSize = parseFloat(style.getPropertyValue("border-bottom-width")) + parseFloat(style.getPropertyValue("border-top-width"));
|
|
25
|
+
const sizingStyle = SIZING_STYLE.map((name) => `${name}:${style.getPropertyValue(name)}`).join(";");
|
|
26
|
+
const nodeInfo = {
|
|
27
|
+
sizingStyle,
|
|
28
|
+
paddingSize,
|
|
29
|
+
borderSize,
|
|
30
|
+
boxSizing
|
|
31
|
+
};
|
|
32
|
+
if (useCache && nodeRef) {
|
|
33
|
+
computedStyleCache[nodeRef] = nodeInfo;
|
|
34
|
+
}
|
|
35
|
+
return nodeInfo;
|
|
36
|
+
}
|
|
37
|
+
function calculateAutoSizeStyle(uiTextNode, useCache = false, minRows = null, maxRows = null) {
|
|
38
|
+
if (!uiTextNode) {
|
|
39
|
+
return {};
|
|
40
|
+
}
|
|
41
|
+
if (!hiddenTextarea) {
|
|
42
|
+
hiddenTextarea = document.createElement("textarea");
|
|
43
|
+
hiddenTextarea.setAttribute("tab-index", "-1");
|
|
44
|
+
hiddenTextarea.setAttribute("aria-hidden", "true");
|
|
45
|
+
hiddenTextarea.setAttribute("name", "hiddenTextarea");
|
|
46
|
+
document.body.appendChild(hiddenTextarea);
|
|
47
|
+
}
|
|
48
|
+
if (uiTextNode.getAttribute("wrap")) {
|
|
49
|
+
hiddenTextarea.setAttribute("wrap", uiTextNode.getAttribute("wrap"));
|
|
50
|
+
} else {
|
|
51
|
+
hiddenTextarea.removeAttribute("wrap");
|
|
52
|
+
}
|
|
53
|
+
const {
|
|
54
|
+
paddingSize,
|
|
55
|
+
borderSize,
|
|
56
|
+
boxSizing,
|
|
57
|
+
sizingStyle
|
|
58
|
+
} = calculateNodeStyling(uiTextNode, useCache);
|
|
59
|
+
hiddenTextarea.setAttribute("style", `${sizingStyle};${HIDDEN_TEXTAREA_STYLE}`);
|
|
60
|
+
hiddenTextarea.value = uiTextNode.value || uiTextNode.placeholder || "";
|
|
61
|
+
let minHeight = void 0;
|
|
62
|
+
let maxHeight = void 0;
|
|
63
|
+
let overflowY = void 0;
|
|
64
|
+
let height = hiddenTextarea.scrollHeight;
|
|
65
|
+
if (boxSizing === "border-box") {
|
|
66
|
+
height += borderSize;
|
|
67
|
+
} else if (boxSizing === "content-box") {
|
|
68
|
+
height -= paddingSize;
|
|
69
|
+
}
|
|
70
|
+
if (minRows !== null || maxRows !== null) {
|
|
71
|
+
hiddenTextarea.value = " ";
|
|
72
|
+
const singleRowHeight = hiddenTextarea.scrollHeight - paddingSize;
|
|
73
|
+
if (minRows !== null) {
|
|
74
|
+
minHeight = singleRowHeight * minRows;
|
|
75
|
+
if (boxSizing === "border-box") {
|
|
76
|
+
minHeight = minHeight + paddingSize + borderSize;
|
|
77
|
+
}
|
|
78
|
+
height = Math.max(minHeight, height);
|
|
79
|
+
}
|
|
80
|
+
if (maxRows !== null) {
|
|
81
|
+
maxHeight = singleRowHeight * maxRows;
|
|
82
|
+
if (boxSizing === "border-box") {
|
|
83
|
+
maxHeight = maxHeight + paddingSize + borderSize;
|
|
84
|
+
}
|
|
85
|
+
overflowY = height > maxHeight ? void 0 : "hidden";
|
|
86
|
+
height = Math.min(maxHeight, height);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
const style = {
|
|
90
|
+
height,
|
|
91
|
+
overflowY,
|
|
92
|
+
resize: "none"
|
|
93
|
+
};
|
|
94
|
+
if (minHeight) {
|
|
95
|
+
style.minHeight = minHeight;
|
|
96
|
+
}
|
|
97
|
+
if (maxHeight) {
|
|
98
|
+
style.maxHeight = maxHeight;
|
|
99
|
+
}
|
|
100
|
+
return style;
|
|
101
|
+
}
|
|
102
|
+
export {
|
|
103
|
+
calculateNodeStyling,
|
|
104
|
+
calculateAutoSizeStyle as default
|
|
105
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { useKeyboardEvents } from './useKeyboardEvents';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { FocusEventHandler, KeyboardEventHandler } from 'react';
|
|
2
|
+
import { UseKeyboardEvents } from './useKeyboardEvents.types';
|
|
3
|
+
export declare const useKeyboardEvents: (options?: UseKeyboardEvents) => {
|
|
4
|
+
onKeyDown: KeyboardEventHandler<HTMLInputElement>;
|
|
5
|
+
onKeyUp: KeyboardEventHandler<HTMLInputElement>;
|
|
6
|
+
onBlur: FocusEventHandler<HTMLInputElement>;
|
|
7
|
+
};
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { useRef, useEffect } from "react";
|
|
2
|
+
const useKeyboardEvents = (options) => {
|
|
3
|
+
const {
|
|
4
|
+
onPressEnter,
|
|
5
|
+
onKeyDown,
|
|
6
|
+
onKeyUp,
|
|
7
|
+
onBlur,
|
|
8
|
+
disabled
|
|
9
|
+
} = options;
|
|
10
|
+
const enterKeyLockRef = useRef(false);
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (enterKeyLockRef.current) {
|
|
13
|
+
enterKeyLockRef.current = false;
|
|
14
|
+
}
|
|
15
|
+
}, [disabled]);
|
|
16
|
+
const handleKeyDown = (e) => {
|
|
17
|
+
if (onPressEnter && e.key === "Enter" && !enterKeyLockRef.current) {
|
|
18
|
+
enterKeyLockRef.current = true;
|
|
19
|
+
onPressEnter(e);
|
|
20
|
+
}
|
|
21
|
+
onKeyDown == null ? void 0 : onKeyDown(e);
|
|
22
|
+
};
|
|
23
|
+
const handleKeyUp = (e) => {
|
|
24
|
+
if (e.key === "Enter") {
|
|
25
|
+
enterKeyLockRef.current = false;
|
|
26
|
+
}
|
|
27
|
+
onKeyUp == null ? void 0 : onKeyUp(e);
|
|
28
|
+
};
|
|
29
|
+
const handleBlur = (e) => {
|
|
30
|
+
if (enterKeyLockRef.current) {
|
|
31
|
+
enterKeyLockRef.current = false;
|
|
32
|
+
}
|
|
33
|
+
onBlur == null ? void 0 : onBlur(e);
|
|
34
|
+
};
|
|
35
|
+
return {
|
|
36
|
+
onKeyDown: handleKeyDown,
|
|
37
|
+
onKeyUp: handleKeyUp,
|
|
38
|
+
onBlur: handleBlur
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
export {
|
|
42
|
+
useKeyboardEvents
|
|
43
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { useMergedState } from './useMergeState';
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
type Updater1<T> = T | ((prevValue: T) => T);
|
|
3
|
+
export type SetState<T> = (nextValue: Updater1<T>,
|
|
4
|
+
/**
|
|
5
|
+
* Will not update state when destroyed.
|
|
6
|
+
* Developer should make sure this is safe to ignore.
|
|
7
|
+
*/
|
|
8
|
+
ignoreDestroy?: boolean) => void;
|
|
9
|
+
export declare const useLayoutUpdateEffect: typeof React.useEffect;
|
|
10
|
+
type Updater<T> = (updater: T | ((origin: T) => T), ignoreDestroy?: boolean) => void;
|
|
11
|
+
/**
|
|
12
|
+
* Similar to `useState` but will use props value if provided.
|
|
13
|
+
* Note that internal use rc-util `useState` hook.
|
|
14
|
+
*/
|
|
15
|
+
export declare function useMergedState<T, R = T>(defaultStateValue: T | (() => T), option?: {
|
|
16
|
+
defaultValue?: T | (() => T);
|
|
17
|
+
value?: T;
|
|
18
|
+
onChange?: (value: T, prevValue: T) => void;
|
|
19
|
+
postState?: (value: T) => T;
|
|
20
|
+
}): [R, Updater<T>];
|
|
21
|
+
export {};
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
function useSafeState(defaultValue) {
|
|
3
|
+
const destroyRef = React.useRef(false);
|
|
4
|
+
const [value, setValue] = React.useState(defaultValue);
|
|
5
|
+
React.useEffect(() => {
|
|
6
|
+
destroyRef.current = false;
|
|
7
|
+
return () => {
|
|
8
|
+
destroyRef.current = true;
|
|
9
|
+
};
|
|
10
|
+
}, []);
|
|
11
|
+
function safeSetState(updater, ignoreDestroy) {
|
|
12
|
+
if (ignoreDestroy && destroyRef.current) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
setValue(updater);
|
|
16
|
+
}
|
|
17
|
+
return [value, safeSetState];
|
|
18
|
+
}
|
|
19
|
+
function canUseDom() {
|
|
20
|
+
return !!(typeof window !== "undefined" && window.document && window.document.createElement);
|
|
21
|
+
}
|
|
22
|
+
function useEvent(callback) {
|
|
23
|
+
const fnRef = React.useRef();
|
|
24
|
+
fnRef.current = callback;
|
|
25
|
+
const memoFn = React.useCallback((...args) => {
|
|
26
|
+
var _a;
|
|
27
|
+
return (_a = fnRef.current) == null ? void 0 : _a.call(fnRef, ...args);
|
|
28
|
+
}, []);
|
|
29
|
+
return memoFn;
|
|
30
|
+
}
|
|
31
|
+
const useInternalLayoutEffect = process.env.NODE_ENV !== "test" && canUseDom() ? React.useLayoutEffect : React.useEffect;
|
|
32
|
+
const useLayoutEffect = (callback, deps) => {
|
|
33
|
+
const firstMountRef = React.useRef(true);
|
|
34
|
+
useInternalLayoutEffect(() => {
|
|
35
|
+
return callback(firstMountRef.current);
|
|
36
|
+
}, deps);
|
|
37
|
+
useInternalLayoutEffect(() => {
|
|
38
|
+
firstMountRef.current = false;
|
|
39
|
+
return () => {
|
|
40
|
+
firstMountRef.current = true;
|
|
41
|
+
};
|
|
42
|
+
}, []);
|
|
43
|
+
};
|
|
44
|
+
const useLayoutUpdateEffect = (callback, deps) => {
|
|
45
|
+
useLayoutEffect((firstMount) => {
|
|
46
|
+
if (!firstMount) {
|
|
47
|
+
return callback();
|
|
48
|
+
}
|
|
49
|
+
}, deps);
|
|
50
|
+
};
|
|
51
|
+
function hasValue(value) {
|
|
52
|
+
return value !== void 0;
|
|
53
|
+
}
|
|
54
|
+
function useMergedState(defaultStateValue, option) {
|
|
55
|
+
const {
|
|
56
|
+
defaultValue,
|
|
57
|
+
value,
|
|
58
|
+
onChange,
|
|
59
|
+
postState
|
|
60
|
+
} = option || {};
|
|
61
|
+
const [innerValue, setInnerValue] = useSafeState(() => {
|
|
62
|
+
if (hasValue(value)) {
|
|
63
|
+
return value;
|
|
64
|
+
} else if (hasValue(defaultValue)) {
|
|
65
|
+
return typeof defaultValue === "function" ? defaultValue() : defaultValue;
|
|
66
|
+
} else {
|
|
67
|
+
return typeof defaultStateValue === "function" ? defaultStateValue() : defaultStateValue;
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
const mergedValue = value !== void 0 ? value : innerValue;
|
|
71
|
+
const postMergedValue = postState ? postState(mergedValue) : mergedValue;
|
|
72
|
+
const onChangeFn = useEvent(onChange);
|
|
73
|
+
const [prevValue, setPrevValue] = useSafeState([mergedValue]);
|
|
74
|
+
useLayoutUpdateEffect(() => {
|
|
75
|
+
const prev = prevValue[0];
|
|
76
|
+
if (innerValue !== prev) {
|
|
77
|
+
onChangeFn(innerValue, prev);
|
|
78
|
+
}
|
|
79
|
+
}, [prevValue]);
|
|
80
|
+
useLayoutUpdateEffect(() => {
|
|
81
|
+
if (!hasValue(value)) {
|
|
82
|
+
setInnerValue(value);
|
|
83
|
+
}
|
|
84
|
+
}, [value]);
|
|
85
|
+
const triggerChange = useEvent((updater, ignoreDestroy) => {
|
|
86
|
+
setInnerValue(updater, ignoreDestroy);
|
|
87
|
+
setPrevValue([mergedValue], ignoreDestroy);
|
|
88
|
+
});
|
|
89
|
+
return [postMergedValue, triggerChange];
|
|
90
|
+
}
|
|
91
|
+
export {
|
|
92
|
+
useLayoutUpdateEffect,
|
|
93
|
+
useMergedState
|
|
94
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { useRemovePasswordTimeout } from './useRemovePasswordTimeout';
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { useRef, useCallback, useEffect } from "react";
|
|
2
|
+
import { usePrevious } from "../../../../hooks/usePrevious.js";
|
|
3
|
+
import { isUndefined } from "lodash-es";
|
|
4
|
+
const useRemovePasswordTimeout = (options) => {
|
|
5
|
+
const {
|
|
6
|
+
inputRef,
|
|
7
|
+
type,
|
|
8
|
+
triggerOnMount = true
|
|
9
|
+
} = options;
|
|
10
|
+
const prevType = usePrevious(type);
|
|
11
|
+
const removePasswordTimeoutRef = useRef([]);
|
|
12
|
+
const removePasswordTimeout = useCallback(() => {
|
|
13
|
+
removePasswordTimeoutRef.current.push(setTimeout(() => {
|
|
14
|
+
const input = inputRef.current;
|
|
15
|
+
if (!input) {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
if (input.getAttribute("type") === "password" && input.hasAttribute("value")) {
|
|
19
|
+
input.removeAttribute("value");
|
|
20
|
+
}
|
|
21
|
+
}));
|
|
22
|
+
}, [inputRef]);
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (triggerOnMount) {
|
|
25
|
+
removePasswordTimeout();
|
|
26
|
+
}
|
|
27
|
+
}, [removePasswordTimeout, triggerOnMount]);
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
const timers = removePasswordTimeoutRef.current;
|
|
30
|
+
return () => {
|
|
31
|
+
timers.forEach((timer) => {
|
|
32
|
+
if (timer) {
|
|
33
|
+
clearTimeout(timer);
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
};
|
|
37
|
+
}, []);
|
|
38
|
+
useEffect(() => {
|
|
39
|
+
if (!isUndefined(prevType) && prevType !== type && type === "password") {
|
|
40
|
+
removePasswordTimeout();
|
|
41
|
+
}
|
|
42
|
+
}, [prevType, removePasswordTimeout, type]);
|
|
43
|
+
return {
|
|
44
|
+
removePasswordTimeout
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
export {
|
|
48
|
+
useRemovePasswordTimeout
|
|
49
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { resolveOnChange } from './resolveOnChange';
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { InputProps } from '../../Input.types';
|
|
2
|
+
import { ChangeEvent, MouseEvent as ME } from 'react';
|
|
3
|
+
export declare const resolveOnChange: <T extends HTMLInputElement>(target: T | null, e: ChangeEvent<T> | ME<HTMLButtonElement, MouseEvent>, onChange: InputProps["onChange"], targetValue?: string) => void;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { emptyString } from "../../../../utils/const/index.js";
|
|
2
|
+
function cloneEvent(event, target, value) {
|
|
3
|
+
const currentTarget = target.cloneNode(true);
|
|
4
|
+
const newEvent = Object.create(event, {
|
|
5
|
+
target: {
|
|
6
|
+
value: currentTarget
|
|
7
|
+
},
|
|
8
|
+
currentTarget: {
|
|
9
|
+
value: currentTarget
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
currentTarget.value = value;
|
|
13
|
+
if (typeof target.selectionStart === "number" && typeof target.selectionEnd === "number") {
|
|
14
|
+
currentTarget.selectionStart = target.selectionStart;
|
|
15
|
+
currentTarget.selectionEnd = target.selectionEnd;
|
|
16
|
+
}
|
|
17
|
+
currentTarget.setSelectionRange = (...args) => {
|
|
18
|
+
target.setSelectionRange(...args);
|
|
19
|
+
};
|
|
20
|
+
return newEvent;
|
|
21
|
+
}
|
|
22
|
+
const resolveOnChange = (target, e, onChange, targetValue) => {
|
|
23
|
+
if (!onChange || !target) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
let event = e;
|
|
27
|
+
if (e.type === "click") {
|
|
28
|
+
event = cloneEvent(e, target, emptyString);
|
|
29
|
+
onChange(event);
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
if (target.type !== "file" && targetValue !== void 0) {
|
|
33
|
+
event = cloneEvent(e, target, targetValue);
|
|
34
|
+
onChange(event);
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
onChange(event);
|
|
38
|
+
};
|
|
39
|
+
export {
|
|
40
|
+
resolveOnChange
|
|
41
|
+
};
|