@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,135 @@
|
|
|
1
|
+
import { Theme } from 'themes';
|
|
2
|
+
import { maxTagCountType, SelectStatus, VariantType } from './Select.types';
|
|
3
|
+
export declare const getSelectDefaultStyle: (status: SelectStatus, disabled: boolean, variant: VariantType, multiple: boolean, isHover: boolean, maxTagCount?: maxTagCountType) => {
|
|
4
|
+
wrapper: (theme: Theme) => {
|
|
5
|
+
readonly display: "inline-flex";
|
|
6
|
+
readonly flexDirection: "column";
|
|
7
|
+
readonly position: "relative";
|
|
8
|
+
readonly borderRadius: 4;
|
|
9
|
+
readonly border: string;
|
|
10
|
+
readonly outline: "none";
|
|
11
|
+
readonly height: 28 | "fit-content";
|
|
12
|
+
readonly boxSizing: "border-box";
|
|
13
|
+
readonly overflow: "hidden";
|
|
14
|
+
readonly justifyContent: "center";
|
|
15
|
+
readonly ":hover": {
|
|
16
|
+
readonly border: string;
|
|
17
|
+
};
|
|
18
|
+
readonly ":active, :focus, :focus-within, :focus-visible": {
|
|
19
|
+
readonly border: string;
|
|
20
|
+
readonly boxShadow: string;
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
body: (theme: Theme) => {
|
|
24
|
+
readonly display: "inline-flex";
|
|
25
|
+
readonly alignItems: "center";
|
|
26
|
+
readonly gap: 8;
|
|
27
|
+
readonly height: 28 | "fit-content";
|
|
28
|
+
readonly padding: string;
|
|
29
|
+
readonly borderRadius: 4;
|
|
30
|
+
readonly background: "#F0F0F0" | "#FFFFFF";
|
|
31
|
+
readonly boxSizing: "border-box";
|
|
32
|
+
readonly cursor: "pointer" | "not-allowed";
|
|
33
|
+
readonly overflow: "hidden";
|
|
34
|
+
readonly width: "100%";
|
|
35
|
+
readonly ".clean-button": {
|
|
36
|
+
readonly display: "none";
|
|
37
|
+
};
|
|
38
|
+
readonly ":hover": {
|
|
39
|
+
readonly ".clean-button": {
|
|
40
|
+
readonly display: "block" | "none";
|
|
41
|
+
};
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
prefixAndContent: (theme: Theme) => {
|
|
45
|
+
display: string;
|
|
46
|
+
alignItems: string;
|
|
47
|
+
gap: 4;
|
|
48
|
+
flex: string;
|
|
49
|
+
paddingLeft: number;
|
|
50
|
+
};
|
|
51
|
+
content: (theme: Theme) => {
|
|
52
|
+
readonly color: "#262626" | "#8C8C8C" | "#FF4D4F";
|
|
53
|
+
readonly overflow: "hidden";
|
|
54
|
+
readonly whiteSpace: "nowrap";
|
|
55
|
+
readonly textOverflow: "ellipsis";
|
|
56
|
+
readonly gap: 4;
|
|
57
|
+
readonly flexWrap: "nowrap" | "wrap";
|
|
58
|
+
readonly fontFamily: "Roboto";
|
|
59
|
+
readonly fontSize: 14;
|
|
60
|
+
readonly lineHeight: "20px";
|
|
61
|
+
readonly display: "flex";
|
|
62
|
+
readonly flex: "1 1 auto";
|
|
63
|
+
};
|
|
64
|
+
placeholder: (theme: Theme) => {
|
|
65
|
+
color: "#8C8C8C" | "#BFBFBF";
|
|
66
|
+
fontFamily: "Roboto";
|
|
67
|
+
fontSize: 14;
|
|
68
|
+
lineHeight: "20px";
|
|
69
|
+
};
|
|
70
|
+
prefix: (isIcon: boolean) => (theme: Theme) => {
|
|
71
|
+
color: "#8C8C8C" | "#BFBFBF" | "#FF4D4F";
|
|
72
|
+
fontFamily?: "Roboto" | undefined;
|
|
73
|
+
fontSize: 14 | 16;
|
|
74
|
+
lineHeight?: "20px" | undefined;
|
|
75
|
+
display: string;
|
|
76
|
+
justifyContent: string;
|
|
77
|
+
alineItems: string;
|
|
78
|
+
};
|
|
79
|
+
suffixIcon: (theme: Theme) => {
|
|
80
|
+
color: "#8C8C8C" | "#BFBFBF";
|
|
81
|
+
fontSize: 16;
|
|
82
|
+
display: string;
|
|
83
|
+
justifyContent: string;
|
|
84
|
+
alineItems: string;
|
|
85
|
+
};
|
|
86
|
+
cleanIcon: (theme: Theme) => {
|
|
87
|
+
readonly visibility: "hidden" | "visible";
|
|
88
|
+
readonly color: "#BFBFBF";
|
|
89
|
+
readonly fontSize: 16;
|
|
90
|
+
readonly ":hover": {
|
|
91
|
+
color: "#262626";
|
|
92
|
+
};
|
|
93
|
+
};
|
|
94
|
+
drawerIcon: (theme: Theme) => {
|
|
95
|
+
color: "#BFBFBF";
|
|
96
|
+
fontSize: 16;
|
|
97
|
+
":hover": {
|
|
98
|
+
color: "#262626";
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
searchInput: (theme: Theme) => {
|
|
102
|
+
color: "#262626" | "#8C8C8C";
|
|
103
|
+
maxWidth: string;
|
|
104
|
+
paddingLeft: number;
|
|
105
|
+
background: string;
|
|
106
|
+
"::placeholder": {
|
|
107
|
+
color: "#8C8C8C" | "#BFBFBF";
|
|
108
|
+
};
|
|
109
|
+
fontFamily: "Roboto";
|
|
110
|
+
fontSize: 14;
|
|
111
|
+
lineHeight: "20px";
|
|
112
|
+
border: string;
|
|
113
|
+
height: string;
|
|
114
|
+
outline: string;
|
|
115
|
+
};
|
|
116
|
+
tagsWrapper: (theme: Theme) => {
|
|
117
|
+
readonly display: "flex";
|
|
118
|
+
readonly gap: 4;
|
|
119
|
+
readonly flex: "1 1 auto";
|
|
120
|
+
readonly overflow: "hidden";
|
|
121
|
+
readonly position: "relative";
|
|
122
|
+
readonly maxHeight: "100%";
|
|
123
|
+
readonly flexWrap: "nowrap" | "wrap";
|
|
124
|
+
};
|
|
125
|
+
mainElements: (theme: Theme) => {
|
|
126
|
+
readonly display: "inline-flex";
|
|
127
|
+
readonly alignItems: "center";
|
|
128
|
+
readonly flexWrap: "nowrap" | "wrap";
|
|
129
|
+
readonly gap: 4;
|
|
130
|
+
readonly flex: "1 1 auto";
|
|
131
|
+
};
|
|
132
|
+
};
|
|
133
|
+
export declare const getSelectSearchInputWidthStyle: (isMultiple: boolean, isEmpty: boolean, lettersNumber: number) => {
|
|
134
|
+
width: number;
|
|
135
|
+
} | undefined;
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
import { getSelectTokens } from "./Select.tokens.js";
|
|
2
|
+
const cleanButtonSelector = ".clean-button";
|
|
3
|
+
const lettersWidthOfSearchInput = 7;
|
|
4
|
+
const iconStyles = (theme, disabled) => {
|
|
5
|
+
const selectTokens = getSelectTokens(theme);
|
|
6
|
+
return {
|
|
7
|
+
color: disabled ? selectTokens.selectTextDisabled : selectTokens.selectPlaceholder,
|
|
8
|
+
fontSize: theme.iconM,
|
|
9
|
+
display: "inline-flex",
|
|
10
|
+
justifyContent: "center",
|
|
11
|
+
alineItems: "center"
|
|
12
|
+
};
|
|
13
|
+
};
|
|
14
|
+
const getBorderColor = (selectTokens, isError) => {
|
|
15
|
+
if (isError) {
|
|
16
|
+
return selectTokens.selectBorderDanger;
|
|
17
|
+
}
|
|
18
|
+
return selectTokens.selectBorder;
|
|
19
|
+
};
|
|
20
|
+
const getBorder = (selectTokens, isError, variant) => {
|
|
21
|
+
if (variant === "borderless") {
|
|
22
|
+
return "none";
|
|
23
|
+
}
|
|
24
|
+
return `1px solid ${getBorderColor(selectTokens, isError)}`;
|
|
25
|
+
};
|
|
26
|
+
const getHoveredBorder = (selectTokens, disabled, isError) => {
|
|
27
|
+
if (isError) {
|
|
28
|
+
return selectTokens.selectBorderDangerHover;
|
|
29
|
+
}
|
|
30
|
+
if (disabled) {
|
|
31
|
+
return selectTokens.selectBorder;
|
|
32
|
+
}
|
|
33
|
+
return selectTokens.selectBorderHover;
|
|
34
|
+
};
|
|
35
|
+
const getActiveBorder = (selectTokens, disabled, isError) => {
|
|
36
|
+
if (isError) {
|
|
37
|
+
return selectTokens.selectBorderDanger;
|
|
38
|
+
}
|
|
39
|
+
if (disabled) {
|
|
40
|
+
return selectTokens.selectBorder;
|
|
41
|
+
}
|
|
42
|
+
return selectTokens.selectBorderActive;
|
|
43
|
+
};
|
|
44
|
+
const getLabelColor = (selectTokens, isError, variant, disabled) => {
|
|
45
|
+
if (disabled) {
|
|
46
|
+
return selectTokens.selectTextDisabled;
|
|
47
|
+
}
|
|
48
|
+
if (isError && variant === "borderless") {
|
|
49
|
+
return selectTokens.selectTextDanger;
|
|
50
|
+
}
|
|
51
|
+
return selectTokens.selectText;
|
|
52
|
+
};
|
|
53
|
+
const getBodyPadding = (selectTokens, isMultipleAndNotResponsive, multiple) => {
|
|
54
|
+
const verticalPadding = isMultipleAndNotResponsive ? selectTokens.selectPaddingVertical - 1 : selectTokens.selectPaddingVertical;
|
|
55
|
+
if (multiple) {
|
|
56
|
+
return `${verticalPadding}px ${selectTokens.selectPaddingHorizontal}px ${verticalPadding}px ${selectTokens.selectPaddingVertical}px`;
|
|
57
|
+
}
|
|
58
|
+
return `${verticalPadding}px ${selectTokens.selectPaddingHorizontal}px`;
|
|
59
|
+
};
|
|
60
|
+
const getIconStyles = (theme) => {
|
|
61
|
+
const selectTokens = getSelectTokens(theme);
|
|
62
|
+
return {
|
|
63
|
+
color: selectTokens.selectPlaceholder,
|
|
64
|
+
fontSize: theme.iconM,
|
|
65
|
+
":hover": {
|
|
66
|
+
color: selectTokens.selectText
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
};
|
|
70
|
+
const getSelectDefaultStyle = (status, disabled, variant, multiple, isHover, maxTagCount) => {
|
|
71
|
+
const isError = status === "error";
|
|
72
|
+
const isResponsive = maxTagCount === "responsive";
|
|
73
|
+
const isOutlined = variant === "outlined";
|
|
74
|
+
const isMultipleAndNotResponsive = multiple && !isResponsive;
|
|
75
|
+
return {
|
|
76
|
+
wrapper: (theme) => {
|
|
77
|
+
const selectTokens = getSelectTokens(theme);
|
|
78
|
+
return {
|
|
79
|
+
display: "inline-flex",
|
|
80
|
+
flexDirection: "column",
|
|
81
|
+
position: "relative",
|
|
82
|
+
borderRadius: theme.borderRadiusM,
|
|
83
|
+
border: getBorder(selectTokens, isError, variant),
|
|
84
|
+
outline: "none",
|
|
85
|
+
height: isMultipleAndNotResponsive ? "fit-content" : theme.controlHeightM,
|
|
86
|
+
boxSizing: "border-box",
|
|
87
|
+
overflow: "hidden",
|
|
88
|
+
justifyContent: "center",
|
|
89
|
+
":hover": {
|
|
90
|
+
border: isOutlined ? `1px solid ${getHoveredBorder(selectTokens, disabled, isError)}` : "none"
|
|
91
|
+
},
|
|
92
|
+
":active, :focus, :focus-within, :focus-visible": {
|
|
93
|
+
border: isOutlined ? `1px solid ${getActiveBorder(selectTokens, disabled, isError)}` : "none",
|
|
94
|
+
boxShadow: disabled ? "none" : `0px 0px 4px 0px ${theme.fieldFocused}`
|
|
95
|
+
}
|
|
96
|
+
};
|
|
97
|
+
},
|
|
98
|
+
body: (theme) => {
|
|
99
|
+
const selectTokens = getSelectTokens(theme);
|
|
100
|
+
return {
|
|
101
|
+
display: "inline-flex",
|
|
102
|
+
alignItems: "center",
|
|
103
|
+
gap: theme.marginM,
|
|
104
|
+
height: isResponsive ? theme.controlHeightM : "fit-content",
|
|
105
|
+
padding: getBodyPadding(selectTokens, isMultipleAndNotResponsive, multiple),
|
|
106
|
+
borderRadius: theme.borderRadiusM,
|
|
107
|
+
background: disabled && isOutlined ? selectTokens.selectBgDisabled : selectTokens.selectBg,
|
|
108
|
+
boxSizing: "border-box",
|
|
109
|
+
cursor: disabled ? "not-allowed" : "pointer",
|
|
110
|
+
overflow: "hidden",
|
|
111
|
+
width: "100%",
|
|
112
|
+
[cleanButtonSelector]: {
|
|
113
|
+
display: "none"
|
|
114
|
+
},
|
|
115
|
+
":hover": {
|
|
116
|
+
[cleanButtonSelector]: {
|
|
117
|
+
display: disabled ? "none" : "block"
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
},
|
|
122
|
+
prefixAndContent: (theme) => ({
|
|
123
|
+
display: "inline-flex",
|
|
124
|
+
alignItems: "center",
|
|
125
|
+
gap: theme.marginXS,
|
|
126
|
+
flex: "1 1 auto",
|
|
127
|
+
paddingLeft: multiple ? theme.x2 : 0
|
|
128
|
+
}),
|
|
129
|
+
content: (theme) => {
|
|
130
|
+
const selectTokens = getSelectTokens(theme);
|
|
131
|
+
return {
|
|
132
|
+
display: "flex",
|
|
133
|
+
flex: "1 1 auto",
|
|
134
|
+
...theme.typography.body2,
|
|
135
|
+
color: getLabelColor(selectTokens, isError, variant, disabled),
|
|
136
|
+
overflow: "hidden",
|
|
137
|
+
whiteSpace: "nowrap",
|
|
138
|
+
textOverflow: "ellipsis",
|
|
139
|
+
gap: theme.spaceXS,
|
|
140
|
+
flexWrap: isResponsive ? "nowrap" : "wrap"
|
|
141
|
+
};
|
|
142
|
+
},
|
|
143
|
+
placeholder: (theme) => {
|
|
144
|
+
const selectTokens = getSelectTokens(theme);
|
|
145
|
+
return {
|
|
146
|
+
...theme.typography.body2,
|
|
147
|
+
color: disabled ? selectTokens.selectTextDisabled : selectTokens.selectPlaceholder
|
|
148
|
+
};
|
|
149
|
+
},
|
|
150
|
+
prefix: (isIcon) => (theme) => {
|
|
151
|
+
const selectTokens = getSelectTokens(theme);
|
|
152
|
+
const iconStyle = iconStyles(theme, disabled);
|
|
153
|
+
return {
|
|
154
|
+
...iconStyle,
|
|
155
|
+
...!isIcon ? theme.typography.body2 : {},
|
|
156
|
+
color: isError ? selectTokens.selectTextDanger : iconStyle.color
|
|
157
|
+
};
|
|
158
|
+
},
|
|
159
|
+
suffixIcon: (theme) => iconStyles(theme, disabled),
|
|
160
|
+
cleanIcon: (theme) => ({
|
|
161
|
+
...getIconStyles(theme),
|
|
162
|
+
visibility: isHover ? "visible" : "hidden"
|
|
163
|
+
}),
|
|
164
|
+
drawerIcon: (theme) => getIconStyles(theme),
|
|
165
|
+
searchInput: (theme) => {
|
|
166
|
+
const selectTokens = getSelectTokens(theme);
|
|
167
|
+
return {
|
|
168
|
+
border: "none",
|
|
169
|
+
height: "100%",
|
|
170
|
+
outline: "none",
|
|
171
|
+
...theme.typography.body2,
|
|
172
|
+
color: disabled ? selectTokens.selectTextDisabled : selectTokens.selectText,
|
|
173
|
+
maxWidth: "80%",
|
|
174
|
+
paddingLeft: 0,
|
|
175
|
+
background: "inherit",
|
|
176
|
+
"::placeholder": {
|
|
177
|
+
color: disabled ? selectTokens.selectTextDisabled : selectTokens.selectPlaceholder
|
|
178
|
+
}
|
|
179
|
+
};
|
|
180
|
+
},
|
|
181
|
+
tagsWrapper: (theme) => ({
|
|
182
|
+
display: "flex",
|
|
183
|
+
gap: theme.spaceXS,
|
|
184
|
+
flex: "1 1 auto",
|
|
185
|
+
overflow: "hidden",
|
|
186
|
+
position: "relative",
|
|
187
|
+
maxHeight: "100%",
|
|
188
|
+
flexWrap: isResponsive ? "nowrap" : "wrap"
|
|
189
|
+
}),
|
|
190
|
+
mainElements: (theme) => ({
|
|
191
|
+
display: "inline-flex",
|
|
192
|
+
alignItems: "center",
|
|
193
|
+
flexWrap: isResponsive ? "nowrap" : "wrap",
|
|
194
|
+
gap: theme.spaceXS,
|
|
195
|
+
flex: "1 1 auto"
|
|
196
|
+
})
|
|
197
|
+
};
|
|
198
|
+
};
|
|
199
|
+
const getSelectSearchInputWidthStyle = (isMultiple, isEmpty, lettersNumber) => {
|
|
200
|
+
if (!isMultiple || isEmpty) {
|
|
201
|
+
return;
|
|
202
|
+
}
|
|
203
|
+
return {
|
|
204
|
+
width: lettersNumber * lettersWidthOfSearchInput
|
|
205
|
+
};
|
|
206
|
+
};
|
|
207
|
+
export {
|
|
208
|
+
getSelectDefaultStyle,
|
|
209
|
+
getSelectSearchInputWidthStyle
|
|
210
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Theme } from 'themes';
|
|
2
|
+
export declare const getSelectTokens: (theme: Theme) => {
|
|
3
|
+
selectBorder: "#D9D9D9";
|
|
4
|
+
selectBorderHover: "#50CCC4";
|
|
5
|
+
selectBorderActive: "#0CB3B3";
|
|
6
|
+
selectBorderDanger: "#FF4D4F";
|
|
7
|
+
selectBorderDangerHover: "#FF7875";
|
|
8
|
+
selectBg: "#FFFFFF";
|
|
9
|
+
selectBgDisabled: "#F0F0F0";
|
|
10
|
+
selectPlaceholder: "#BFBFBF";
|
|
11
|
+
selectText: "#262626";
|
|
12
|
+
selectTextDisabled: "#8C8C8C";
|
|
13
|
+
selectTextDanger: "#FF4D4F";
|
|
14
|
+
selectMultipleItemBorder: "#D9D9D9";
|
|
15
|
+
selectMultipleItemBg: "#F5F5F5";
|
|
16
|
+
selectMultipleItemBgDisabled: "#D9D9D9";
|
|
17
|
+
selectOptionText: "#262626";
|
|
18
|
+
selectOptionTextSelected: "#0CB3B3";
|
|
19
|
+
selectOptionTextDisabled: "#8C8C8C";
|
|
20
|
+
selectOptionBgHover: "#F5F5F5";
|
|
21
|
+
selectPaddingVertical: 4;
|
|
22
|
+
selectPaddingHorizontal: 12;
|
|
23
|
+
selectPaddingHorizontalTag: 4;
|
|
24
|
+
selectOptionPaddingVertical: 4;
|
|
25
|
+
selectOptionPaddingHorizontal: 8;
|
|
26
|
+
};
|
|
27
|
+
export type SelectTokensType = ReturnType<typeof getSelectTokens>;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
const getSelectTokens = (theme) => ({
|
|
2
|
+
selectBorder: theme.lineBorder,
|
|
3
|
+
selectBorderHover: theme.primaryHover,
|
|
4
|
+
selectBorderActive: theme.primaryBase,
|
|
5
|
+
selectBorderDanger: theme.dangerBase,
|
|
6
|
+
selectBorderDangerHover: theme.dangerHover,
|
|
7
|
+
selectBg: theme.bgContainer,
|
|
8
|
+
selectBgDisabled: theme.bgContainerDisabled,
|
|
9
|
+
selectPlaceholder: theme.textHint,
|
|
10
|
+
selectText: theme.textPrimary,
|
|
11
|
+
selectTextDisabled: theme.textDisabled,
|
|
12
|
+
selectTextDanger: theme.dangerBase,
|
|
13
|
+
selectMultipleItemBorder: theme.tagNeutralBorder,
|
|
14
|
+
selectMultipleItemBg: theme.tagNeutralBg,
|
|
15
|
+
selectMultipleItemBgDisabled: theme.bgContainerDisabledContrast,
|
|
16
|
+
selectOptionText: theme.textPrimary,
|
|
17
|
+
selectOptionTextSelected: theme.primaryBase,
|
|
18
|
+
selectOptionTextDisabled: theme.textDisabled,
|
|
19
|
+
selectOptionBgHover: theme.bgContainerHover,
|
|
20
|
+
selectPaddingVertical: theme.x1,
|
|
21
|
+
selectPaddingHorizontal: theme.x3,
|
|
22
|
+
selectPaddingHorizontalTag: theme.x1,
|
|
23
|
+
selectOptionPaddingVertical: theme.x1,
|
|
24
|
+
selectOptionPaddingHorizontal: theme.x2
|
|
25
|
+
});
|
|
26
|
+
export {
|
|
27
|
+
getSelectTokens
|
|
28
|
+
};
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { FocusEvent, KeyboardEvent, ReactNode } from 'react';
|
|
2
|
+
import { SelectOptionInterface, SelectOptionProps, SelectOptionValue } from './components/SelectOption/SelectOption.types';
|
|
3
|
+
import { Theme } from '../../themes';
|
|
4
|
+
import { Interpolation } from '@emotion/react';
|
|
5
|
+
import { DropdownMatchSelectWidthType, DropdownStyles } from './components/SelectOptionList/SelectOptionList.types';
|
|
6
|
+
import { NarrowedElement, ReferenceType } from '@floating-ui/react';
|
|
7
|
+
export type SelectStatus = "default" | "error";
|
|
8
|
+
export type VariantType = "outlined" | "borderless";
|
|
9
|
+
export type ModeType = "single" | "multiple";
|
|
10
|
+
export type maxTagCountType = number | "responsive";
|
|
11
|
+
export interface SelectStyles {
|
|
12
|
+
dropdownStyle?: DropdownStyles;
|
|
13
|
+
wrapper?: (theme: Theme) => Interpolation;
|
|
14
|
+
body?: (theme: Theme) => Interpolation;
|
|
15
|
+
prefixAndContent?: (theme: Theme) => Interpolation;
|
|
16
|
+
content?: (theme: Theme) => Interpolation;
|
|
17
|
+
placeholder?: (theme: Theme) => Interpolation;
|
|
18
|
+
prefix?: (theme: Theme) => Interpolation;
|
|
19
|
+
suffixIcon?: (theme: Theme) => Interpolation;
|
|
20
|
+
cleanIcon?: (theme: Theme) => Interpolation;
|
|
21
|
+
drawerIcon?: (theme: Theme) => Interpolation;
|
|
22
|
+
}
|
|
23
|
+
export interface SelectProps {
|
|
24
|
+
options?: SelectOptionInterface[];
|
|
25
|
+
mode?: ModeType;
|
|
26
|
+
variant?: VariantType;
|
|
27
|
+
defaultValue?: SelectOptionValue | SelectOptionValue[];
|
|
28
|
+
defaultOpen?: boolean;
|
|
29
|
+
value?: SelectOptionValue | SelectOptionValue[];
|
|
30
|
+
open?: boolean;
|
|
31
|
+
defaultActiveFirstOption?: boolean;
|
|
32
|
+
placeholder?: string;
|
|
33
|
+
dropdownMaxHeight?: number;
|
|
34
|
+
dropdownMinWidth?: number;
|
|
35
|
+
allowClear?: boolean;
|
|
36
|
+
autoFocus?: boolean;
|
|
37
|
+
prefix?: ReactNode;
|
|
38
|
+
suffixIcon?: ReactNode;
|
|
39
|
+
status?: SelectStatus;
|
|
40
|
+
disabled?: boolean;
|
|
41
|
+
dropdownPrompt?: string;
|
|
42
|
+
loading?: boolean;
|
|
43
|
+
dropdownClassName?: string;
|
|
44
|
+
dropdownMatchSelectWidth?: DropdownMatchSelectWidthType;
|
|
45
|
+
placement?: PlacementType;
|
|
46
|
+
virtual?: boolean;
|
|
47
|
+
emptyContent?: ReactNode;
|
|
48
|
+
showSearch?: boolean;
|
|
49
|
+
optionFilterProp?: string;
|
|
50
|
+
optionLabelProp?: string;
|
|
51
|
+
filterOption?: boolean | ((inputValue: string, option: SelectOptionInterface) => boolean);
|
|
52
|
+
searchValue?: string;
|
|
53
|
+
notFoundContent?: ReactNode;
|
|
54
|
+
drawer?: boolean;
|
|
55
|
+
filterSort?: (optionA: SelectOptionInterface, optionB: SelectOptionInterface, searchValue: string) => number;
|
|
56
|
+
styles?: SelectStyles;
|
|
57
|
+
autoClearSearchValue?: boolean;
|
|
58
|
+
maxTagCount?: maxTagCountType;
|
|
59
|
+
maxTagPlaceholder?: ((omittedValues: SelectOptionInterface[]) => ReactNode) | ReactNode;
|
|
60
|
+
maxTagTextLength?: number;
|
|
61
|
+
dropdownRender?: (originNode: ReactNode) => ReactNode;
|
|
62
|
+
optionRender?: (option: SelectOptionProps) => ReactNode;
|
|
63
|
+
labelRender?: (props: LabelInValueType) => ReactNode;
|
|
64
|
+
tagRender?: (label: string) => ReactNode;
|
|
65
|
+
onFocus?: (event: FocusEvent) => void;
|
|
66
|
+
onBlur?: (event: FocusEvent) => void;
|
|
67
|
+
onChange?: (value: SelectOptionValue[], option: SelectOptionInterface[]) => void;
|
|
68
|
+
onClear?: () => void;
|
|
69
|
+
onDropdownVisibleChange?: () => void;
|
|
70
|
+
onInputKeyDown?: (event: KeyboardEvent) => void;
|
|
71
|
+
onSelect?: (value: SelectOptionValue, option: SelectOptionInterface) => void;
|
|
72
|
+
getPopupContainer?: () => HTMLElement;
|
|
73
|
+
onSearch?: (searchValue: string) => void;
|
|
74
|
+
onDeselect?: (value: SelectOptionValue) => void;
|
|
75
|
+
}
|
|
76
|
+
export interface LabelInValueType {
|
|
77
|
+
label: ReactNode;
|
|
78
|
+
value: SelectOptionValue;
|
|
79
|
+
}
|
|
80
|
+
export interface Refs<RT extends ReferenceType = ReferenceType> {
|
|
81
|
+
reference: React.MutableRefObject<RT | null>;
|
|
82
|
+
floating: React.MutableRefObject<HTMLElement | null>;
|
|
83
|
+
domReference: React.MutableRefObject<NarrowedElement<RT> | null>;
|
|
84
|
+
setReference(node: RT | null): void;
|
|
85
|
+
setFloating(node: HTMLElement | null): void;
|
|
86
|
+
setPositionReference(node: RT | null): void;
|
|
87
|
+
}
|
|
88
|
+
export type PlacementType = "bottomLeft" | "bottomRight" | "topLeft" | "topRight";
|
|
89
|
+
export type UseSearchProps = Required<Pick<SelectProps, "options" | "optionFilterProp" | "filterOption">> & Pick<SelectProps, "onSearch" | "searchValue" | "filterSort">;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Placement } from '@floating-ui/react';
|
|
2
|
+
import { maxTagCountType, PlacementType } from './Select.types';
|
|
3
|
+
import { SelectOptionInterface, SelectOptionValue } from './components/SelectOption/SelectOption.types';
|
|
4
|
+
export declare const additionalElements: string[];
|
|
5
|
+
export declare const convertSelectPlacement: (placement: PlacementType) => Placement;
|
|
6
|
+
export declare const getNextOption: (currentIndex: number, options: SelectOptionInterface[], isDecrement?: boolean) => number | null;
|
|
7
|
+
export declare const isKeyOfObject: <T extends object>(obj: T, key: string | number | symbol) => key is keyof T;
|
|
8
|
+
export declare const getLabelByValue: (value: SelectOptionValue, optionsMap: Map<SelectOptionValue, SelectOptionInterface>, optionLabelProp: string) => string | undefined;
|
|
9
|
+
export declare const getLabel: (values: SelectOptionValue[], optionsMap: Map<SelectOptionValue, SelectOptionInterface>, optionLabelProp: string) => string[];
|
|
10
|
+
export declare const getVisibleLabels: (labels: string[], values: SelectOptionValue[], maxTagCount: maxTagCountType | undefined, isItemHidden: Map<string | number, boolean>) => string[];
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { isUndefined, isNumber } from "lodash-es";
|
|
2
|
+
const additionalElements = ["tag-placeholder", "search-input", "clean-button"];
|
|
3
|
+
const placementDictionary = {
|
|
4
|
+
bottomLeft: "bottom-start",
|
|
5
|
+
bottomRight: "bottom-end",
|
|
6
|
+
topLeft: "top-start",
|
|
7
|
+
topRight: "top-end"
|
|
8
|
+
};
|
|
9
|
+
const convertSelectPlacement = (placement) => {
|
|
10
|
+
return placementDictionary[placement];
|
|
11
|
+
};
|
|
12
|
+
const getNextOption = (currentIndex, options, isDecrement = false) => {
|
|
13
|
+
const nextIndex = isDecrement ? currentIndex - 1 : currentIndex + 1;
|
|
14
|
+
if (nextIndex < 0 || nextIndex >= options.length) {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
const nextOption = options[nextIndex];
|
|
18
|
+
if (!nextOption.disabled) {
|
|
19
|
+
return nextIndex;
|
|
20
|
+
}
|
|
21
|
+
return getNextOption(nextIndex, options, isDecrement);
|
|
22
|
+
};
|
|
23
|
+
const isKeyOfObject = (obj, key) => {
|
|
24
|
+
return key in obj;
|
|
25
|
+
};
|
|
26
|
+
const getLabelByValue = (value, optionsMap, optionLabelProp) => {
|
|
27
|
+
var _a;
|
|
28
|
+
const option = optionsMap.get(value);
|
|
29
|
+
if (isUndefined(option)) {
|
|
30
|
+
return void 0;
|
|
31
|
+
}
|
|
32
|
+
return isKeyOfObject(option, optionLabelProp) ? (_a = option[optionLabelProp]) == null ? void 0 : _a.toString() : void 0;
|
|
33
|
+
};
|
|
34
|
+
const getLabel = (values, optionsMap, optionLabelProp) => {
|
|
35
|
+
return values.map((value) => getLabelByValue(value, optionsMap, optionLabelProp) ?? value.toString());
|
|
36
|
+
};
|
|
37
|
+
const getVisibleLabels = (labels, values, maxTagCount, isItemHidden) => {
|
|
38
|
+
if (isUndefined(maxTagCount)) {
|
|
39
|
+
return labels;
|
|
40
|
+
}
|
|
41
|
+
if (isNumber(maxTagCount)) {
|
|
42
|
+
return labels.slice(0, maxTagCount);
|
|
43
|
+
}
|
|
44
|
+
return values.reduce((acc, value, index) => {
|
|
45
|
+
if (!isItemHidden.get(value)) {
|
|
46
|
+
return [...acc, labels[index]];
|
|
47
|
+
}
|
|
48
|
+
return acc;
|
|
49
|
+
}, []);
|
|
50
|
+
};
|
|
51
|
+
export {
|
|
52
|
+
additionalElements,
|
|
53
|
+
convertSelectPlacement,
|
|
54
|
+
getLabel,
|
|
55
|
+
getLabelByValue,
|
|
56
|
+
getNextOption,
|
|
57
|
+
getVisibleLabels,
|
|
58
|
+
isKeyOfObject
|
|
59
|
+
};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { memo } from "react";
|
|
3
|
+
import { CheckOutlined } from "@infomaximum/icons";
|
|
4
|
+
import { getSelectOptionStyle } from "./SelectOption.styles.js";
|
|
5
|
+
import { useTheme } from "../../../../hooks/useTheme/useTheme.js";
|
|
6
|
+
const SelectOption = memo(({
|
|
7
|
+
title,
|
|
8
|
+
value,
|
|
9
|
+
selected = false,
|
|
10
|
+
disabled = false,
|
|
11
|
+
icon,
|
|
12
|
+
index,
|
|
13
|
+
isSelecting,
|
|
14
|
+
mode,
|
|
15
|
+
setValue,
|
|
16
|
+
closeOptionList,
|
|
17
|
+
returnFocusToWrapper,
|
|
18
|
+
removeValue
|
|
19
|
+
}) => {
|
|
20
|
+
const theme = useTheme();
|
|
21
|
+
const selectOptionStyle = getSelectOptionStyle(selected, disabled, isSelecting);
|
|
22
|
+
const clickHandle = () => {
|
|
23
|
+
if (disabled) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
if (mode === "multiple") {
|
|
27
|
+
if (selected) {
|
|
28
|
+
removeValue(value);
|
|
29
|
+
} else {
|
|
30
|
+
setValue(value, index);
|
|
31
|
+
}
|
|
32
|
+
returnFocusToWrapper();
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
setValue(value, index);
|
|
36
|
+
closeOptionList();
|
|
37
|
+
returnFocusToWrapper();
|
|
38
|
+
};
|
|
39
|
+
const keyDownHandler = (e) => {
|
|
40
|
+
e.stopPropagation();
|
|
41
|
+
if (e.key === "Enter") {
|
|
42
|
+
clickHandle();
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
return /* @__PURE__ */ jsxs("div", { css: selectOptionStyle.wrapper(theme), onClick: clickHandle, onKeyDown: keyDownHandler, title, children: [
|
|
46
|
+
/* @__PURE__ */ jsxs("span", { css: selectOptionStyle.content(theme), children: [
|
|
47
|
+
icon && /* @__PURE__ */ jsx("span", { css: selectOptionStyle.icon(theme), children: icon }),
|
|
48
|
+
/* @__PURE__ */ jsx("span", { css: selectOptionStyle.text, children: title })
|
|
49
|
+
] }),
|
|
50
|
+
selected && /* @__PURE__ */ jsx("span", { css: selectOptionStyle.icon(theme), children: /* @__PURE__ */ jsx(CheckOutlined, {}) })
|
|
51
|
+
] });
|
|
52
|
+
});
|
|
53
|
+
export {
|
|
54
|
+
SelectOption
|
|
55
|
+
};
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { Theme } from 'themes';
|
|
2
|
+
export declare const getSelectOptionStyle: (selected: boolean, disabled: boolean, isSelecting: boolean) => {
|
|
3
|
+
wrapper: (theme: Theme) => {
|
|
4
|
+
readonly color: "#262626" | "#8C8C8C" | "#0CB3B3";
|
|
5
|
+
readonly height: 28;
|
|
6
|
+
readonly boxSizing: "border-box";
|
|
7
|
+
readonly transition: "background .2s, color .2s";
|
|
8
|
+
readonly cursor: "pointer" | "not-allowed";
|
|
9
|
+
readonly background: "#F5F5F5" | "unset";
|
|
10
|
+
readonly ":hover, :focus, focus-visible": {
|
|
11
|
+
readonly background: "#F5F5F5" | "unset";
|
|
12
|
+
readonly outline: "none";
|
|
13
|
+
};
|
|
14
|
+
readonly fontFamily: "Roboto";
|
|
15
|
+
readonly fontSize: 14;
|
|
16
|
+
readonly lineHeight: "20px";
|
|
17
|
+
readonly display: "flex";
|
|
18
|
+
readonly alignItems: "center";
|
|
19
|
+
readonly width: "100%";
|
|
20
|
+
readonly gap: 8;
|
|
21
|
+
readonly padding: "4px 8px";
|
|
22
|
+
readonly borderRadius: 4;
|
|
23
|
+
};
|
|
24
|
+
content: (theme: Theme) => {
|
|
25
|
+
readonly display: "inline-flex";
|
|
26
|
+
readonly gap: 4;
|
|
27
|
+
readonly width: string;
|
|
28
|
+
readonly flex: "1 1 auto";
|
|
29
|
+
readonly flexWrap: "nowrap";
|
|
30
|
+
};
|
|
31
|
+
text: {
|
|
32
|
+
display: string;
|
|
33
|
+
overflow: string;
|
|
34
|
+
whiteSpace: string;
|
|
35
|
+
textOverflow: string;
|
|
36
|
+
width: string;
|
|
37
|
+
};
|
|
38
|
+
icon: (theme: Theme) => {
|
|
39
|
+
fontSize: 16;
|
|
40
|
+
};
|
|
41
|
+
};
|