@chayns-components/core 5.0.0-beta.998 → 5.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/api/theme/get.js.map +1 -1
- package/lib/cjs/components/accordion/Accordion.js +68 -40
- package/lib/cjs/components/accordion/Accordion.js.map +1 -1
- package/lib/cjs/components/accordion/Accordion.styles.js +31 -26
- package/lib/cjs/components/accordion/Accordion.styles.js.map +1 -1
- package/lib/cjs/components/accordion/accordion-body/AccordionBody.js +24 -13
- package/lib/cjs/components/accordion/accordion-body/AccordionBody.js.map +1 -1
- package/lib/cjs/components/accordion/accordion-body/AccordionBody.styles.js +4 -4
- package/lib/cjs/components/accordion/accordion-body/AccordionBody.styles.js.map +1 -1
- package/lib/cjs/components/accordion/accordion-content/AccordionContent.js +2 -6
- package/lib/cjs/components/accordion/accordion-content/AccordionContent.js.map +1 -1
- package/lib/cjs/components/accordion/accordion-content/AccordionContent.styles.js +2 -5
- package/lib/cjs/components/accordion/accordion-content/AccordionContent.styles.js.map +1 -1
- package/lib/cjs/components/accordion/accordion-group/AccordionGroup.js +17 -18
- package/lib/cjs/components/accordion/accordion-group/AccordionGroup.js.map +1 -1
- package/lib/cjs/components/accordion/accordion-head/AccordionHead.js +103 -59
- package/lib/cjs/components/accordion/accordion-head/AccordionHead.js.map +1 -1
- package/lib/cjs/components/accordion/accordion-head/AccordionHead.styles.js +22 -33
- package/lib/cjs/components/accordion/accordion-head/AccordionHead.styles.js.map +1 -1
- package/lib/cjs/components/amount-control/AmountControl.js +46 -87
- package/lib/cjs/components/amount-control/AmountControl.js.map +1 -1
- package/lib/cjs/components/amount-control/AmountControl.styles.js +27 -26
- package/lib/cjs/components/amount-control/AmountControl.styles.js.map +1 -1
- package/lib/cjs/components/animated-number/AnimatedNumber.js +48 -0
- package/lib/cjs/components/animated-number/AnimatedNumber.js.map +1 -0
- package/lib/cjs/components/area-provider/AreaContextProvider.js +11 -6
- package/lib/cjs/components/area-provider/AreaContextProvider.js.map +1 -1
- package/lib/cjs/components/badge/Badge.constants.js +18 -0
- package/lib/cjs/components/badge/Badge.constants.js.map +1 -0
- package/lib/cjs/components/badge/Badge.js +14 -9
- package/lib/cjs/components/badge/Badge.js.map +1 -1
- package/lib/cjs/components/badge/Badge.styles.js +37 -21
- package/lib/cjs/components/badge/Badge.styles.js.map +1 -1
- package/lib/cjs/components/badge/Badge.types.js +27 -0
- package/lib/cjs/components/badge/Badge.types.js.map +1 -0
- package/lib/cjs/components/button/Button.js +25 -23
- package/lib/cjs/components/button/Button.js.map +1 -1
- package/lib/cjs/components/button/Button.styles.js +12 -10
- package/lib/cjs/components/button/Button.styles.js.map +1 -1
- package/lib/cjs/components/button/Button.types.js +6 -0
- package/lib/cjs/components/button/Button.types.js.map +1 -0
- package/lib/cjs/components/button/wait-cursor/WaitCursor.styles.js +1 -2
- package/lib/cjs/components/button/wait-cursor/WaitCursor.styles.js.map +1 -1
- package/lib/cjs/components/checkbox/Checkbox.js +28 -8
- package/lib/cjs/components/checkbox/Checkbox.js.map +1 -1
- package/lib/cjs/components/checkbox/Checkbox.styles.js +29 -23
- package/lib/cjs/components/checkbox/Checkbox.styles.js.map +1 -1
- package/lib/cjs/components/color-scheme-provider/ColorSchemeProvider.js +37 -138
- package/lib/cjs/components/color-scheme-provider/ColorSchemeProvider.js.map +1 -1
- package/lib/cjs/components/color-scheme-provider/ColorSchemeProvider.styles.js +6 -0
- package/lib/cjs/components/color-scheme-provider/ColorSchemeProvider.styles.js.map +1 -1
- package/lib/cjs/components/color-scheme-provider/hooks/useChaynsTheme.js +141 -0
- package/lib/cjs/components/color-scheme-provider/hooks/useChaynsTheme.js.map +1 -0
- package/lib/cjs/components/color-scheme-provider/hooks/useDesignSettings.js +36 -0
- package/lib/cjs/components/color-scheme-provider/hooks/useDesignSettings.js.map +1 -0
- package/lib/cjs/components/color-scheme-provider/hooks/useParagraphFormat.js +24 -0
- package/lib/cjs/components/color-scheme-provider/hooks/useParagraphFormat.js.map +1 -0
- package/lib/cjs/components/combobox/ComboBox.js +166 -176
- package/lib/cjs/components/combobox/ComboBox.js.map +1 -1
- package/lib/cjs/components/combobox/ComboBox.styles.js +81 -66
- package/lib/cjs/components/combobox/ComboBox.styles.js.map +1 -1
- package/lib/cjs/components/combobox/combobox-item/ComboBoxItem.js +23 -20
- package/lib/cjs/components/combobox/combobox-item/ComboBoxItem.js.map +1 -1
- package/lib/cjs/components/combobox/combobox-item/ComboBoxItem.styles.js +15 -13
- package/lib/cjs/components/combobox/combobox-item/ComboBoxItem.styles.js.map +1 -1
- package/lib/cjs/components/content-card/ContentCard.js +2 -2
- package/lib/cjs/components/content-card/ContentCard.js.map +1 -1
- package/lib/cjs/components/content-card/ContentCard.styles.js +31 -4
- package/lib/cjs/components/content-card/ContentCard.styles.js.map +1 -1
- package/lib/cjs/components/context-menu/ContextMenu.js +104 -41
- package/lib/cjs/components/context-menu/ContextMenu.js.map +1 -1
- package/lib/cjs/components/context-menu/ContextMenu.styles.js +17 -2
- package/lib/cjs/components/context-menu/ContextMenu.styles.js.map +1 -1
- package/lib/cjs/components/context-menu/ContextMenu.types.js +31 -0
- package/lib/cjs/components/context-menu/ContextMenu.types.js.map +1 -0
- package/lib/cjs/components/context-menu/ContextMenu.utils.js +9 -0
- package/lib/cjs/components/context-menu/ContextMenu.utils.js.map +1 -0
- package/lib/cjs/components/context-menu/context-menu-content/ContextMenuContent.js +58 -25
- package/lib/cjs/components/context-menu/context-menu-content/ContextMenuContent.js.map +1 -1
- package/lib/cjs/components/context-menu/context-menu-content/ContextMenuContent.styles.js +64 -18
- package/lib/cjs/components/context-menu/context-menu-content/ContextMenuContent.styles.js.map +1 -1
- package/lib/cjs/components/dropdown-body-wrapper/DropdownBodyWrapper.js +151 -0
- package/lib/cjs/components/dropdown-body-wrapper/DropdownBodyWrapper.js.map +1 -0
- package/lib/cjs/components/dropdown-body-wrapper/DropdownBodyWrapper.styles.js +50 -0
- package/lib/cjs/components/dropdown-body-wrapper/DropdownBodyWrapper.styles.js.map +1 -0
- package/lib/cjs/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.js +106 -0
- package/lib/cjs/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.js.map +1 -0
- package/lib/cjs/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.styles.js +37 -0
- package/lib/cjs/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.styles.js.map +1 -0
- package/lib/cjs/components/expandable-content/ExpandableContent.js +10 -10
- package/lib/cjs/components/expandable-content/ExpandableContent.js.map +1 -1
- package/lib/cjs/components/expandable-content/ExpandableContent.styles.js +3 -5
- package/lib/cjs/components/expandable-content/ExpandableContent.styles.js.map +1 -1
- package/lib/cjs/components/file-input/FileInput.js +61 -137
- package/lib/cjs/components/file-input/FileInput.js.map +1 -1
- package/lib/cjs/components/file-input/FileInput.styles.js +3 -4
- package/lib/cjs/components/file-input/FileInput.styles.js.map +1 -1
- package/lib/cjs/components/file-list/FileList.js +34 -0
- package/lib/cjs/components/file-list/FileList.js.map +1 -0
- package/lib/cjs/components/{file-input/file-list/FileListItem.styles.js → file-list/FileList.styles.js} +3 -3
- package/lib/cjs/components/file-list/FileList.styles.js.map +1 -0
- package/lib/cjs/components/file-list/file-item/FileItem.js +40 -0
- package/lib/cjs/components/file-list/file-item/FileItem.js.map +1 -0
- package/lib/cjs/components/file-list/file-item/FileItem.styles.js +10 -0
- package/lib/cjs/components/file-list/file-item/FileItem.styles.js.map +1 -0
- package/lib/cjs/components/file-select/FileSelect.js +134 -0
- package/lib/cjs/components/file-select/FileSelect.js.map +1 -0
- package/lib/cjs/components/file-select/FileSelect.styles.js +52 -0
- package/lib/cjs/components/file-select/FileSelect.styles.js.map +1 -0
- package/lib/cjs/components/filter/Filter.js +223 -0
- package/lib/cjs/components/filter/Filter.js.map +1 -0
- package/lib/cjs/components/filter/Filter.styles.js +97 -0
- package/lib/cjs/components/filter/Filter.styles.js.map +1 -0
- package/lib/cjs/components/filter/filter-content/FIlterContent.js +88 -0
- package/lib/cjs/components/filter/filter-content/FIlterContent.js.map +1 -0
- package/lib/cjs/components/filter/filter-content/FilterContent.styles.js +36 -0
- package/lib/cjs/components/filter/filter-content/FilterContent.styles.js.map +1 -0
- package/lib/cjs/components/filter-buttons/FilterButtons.js +5 -4
- package/lib/cjs/components/filter-buttons/FilterButtons.js.map +1 -1
- package/lib/cjs/components/filter-buttons/filter-button/FilterButton.js +11 -5
- package/lib/cjs/components/filter-buttons/filter-button/FilterButton.js.map +1 -1
- package/lib/cjs/components/filter-buttons/filter-button/FilterButton.styles.js +13 -7
- package/lib/cjs/components/filter-buttons/filter-button/FilterButton.styles.js.map +1 -1
- package/lib/cjs/components/grid-image/GridImage.js +1 -2
- package/lib/cjs/components/grid-image/GridImage.js.map +1 -1
- package/lib/cjs/components/grouped-image/GroupedImage.js +74 -0
- package/lib/cjs/components/grouped-image/GroupedImage.js.map +1 -0
- package/lib/cjs/components/grouped-image/GroupedImage.styles.js +125 -0
- package/lib/cjs/components/grouped-image/GroupedImage.styles.js.map +1 -0
- package/lib/cjs/components/grouped-image/clip-paths/CareOfClipPath.js +34 -0
- package/lib/cjs/components/grouped-image/clip-paths/CareOfClipPath.js.map +1 -0
- package/lib/cjs/components/grouped-image/clip-paths/SecondImageClipPath.js +34 -0
- package/lib/cjs/components/grouped-image/clip-paths/SecondImageClipPath.js.map +1 -0
- package/lib/cjs/components/highlight-slider/HighlightSlider.js +49 -0
- package/lib/cjs/components/highlight-slider/HighlightSlider.js.map +1 -0
- package/lib/cjs/components/highlight-slider/HighlightSlider.styles.js +14 -0
- package/lib/cjs/components/highlight-slider/HighlightSlider.styles.js.map +1 -0
- package/lib/cjs/components/highlight-slider/highlight-slider-item/HighlightSliderItem.js +57 -0
- package/lib/cjs/components/highlight-slider/highlight-slider-item/HighlightSliderItem.js.map +1 -0
- package/lib/cjs/components/highlight-slider/highlight-slider-item/HighlightSliderItem.styles.js +36 -0
- package/lib/cjs/components/highlight-slider/highlight-slider-item/HighlightSliderItem.styles.js.map +1 -0
- package/lib/cjs/components/icon/Icon.js +11 -15
- package/lib/cjs/components/icon/Icon.js.map +1 -1
- package/lib/cjs/components/icon/Icon.styles.js +17 -4
- package/lib/cjs/components/icon/Icon.styles.js.map +1 -1
- package/lib/cjs/components/input/Input.js +40 -9
- package/lib/cjs/components/input/Input.js.map +1 -1
- package/lib/cjs/components/input/Input.styles.js +35 -14
- package/lib/cjs/components/input/Input.styles.js.map +1 -1
- package/lib/cjs/components/list/List.js +12 -13
- package/lib/cjs/components/list/List.js.map +1 -1
- package/lib/cjs/components/list/list-item/ListItem.js +90 -33
- package/lib/cjs/components/list/list-item/ListItem.js.map +1 -1
- package/lib/cjs/components/list/list-item/ListItem.styles.js +47 -16
- package/lib/cjs/components/list/list-item/ListItem.styles.js.map +1 -1
- package/lib/cjs/components/list/list-item/list-item-body/ListItemBody.js +5 -6
- package/lib/cjs/components/list/list-item/list-item-body/ListItemBody.js.map +1 -1
- package/lib/cjs/components/list/list-item/list-item-body/ListItemBody.styles.js +2 -2
- package/lib/cjs/components/list/list-item/list-item-body/ListItemBody.styles.js.map +1 -1
- package/lib/cjs/components/list/list-item/list-item-head/ListItemHead.js +99 -85
- package/lib/cjs/components/list/list-item/list-item-head/ListItemHead.js.map +1 -1
- package/lib/cjs/components/list/list-item/list-item-head/ListItemHead.styles.js +25 -88
- package/lib/cjs/components/list/list-item/list-item-head/ListItemHead.styles.js.map +1 -1
- package/lib/cjs/components/list/list-item/list-item-head/list-item-icon/ListItemIcon.styles.js +1 -2
- package/lib/cjs/components/list/list-item/list-item-head/list-item-icon/ListItemIcon.styles.js.map +1 -1
- package/lib/cjs/components/list/list-item/list-item-head/list-item-image/ListItemImage.js +17 -28
- package/lib/cjs/components/list/list-item/list-item-head/list-item-image/ListItemImage.js.map +1 -1
- package/lib/cjs/components/list/list-item/list-item-head/list-item-right-element/ListItemRightElement.js +42 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-right-element/ListItemRightElement.js.map +1 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-right-element/ListItemRightElement.styles.js +15 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-right-element/ListItemRightElement.styles.js.map +1 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.js +40 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.js.map +1 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.styles.js +40 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.styles.js.map +1 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-title/ListItemTitle.js +78 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-title/ListItemTitle.js.map +1 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-title/ListItemTitle.styles.js +59 -0
- package/lib/cjs/components/list/list-item/list-item-head/list-item-title/ListItemTitle.styles.js.map +1 -0
- package/lib/cjs/components/mention-finder/MentionFinder.js +258 -29
- package/lib/cjs/components/mention-finder/MentionFinder.js.map +1 -1
- package/lib/cjs/components/mention-finder/MentionFinder.styles.js +112 -7
- package/lib/cjs/components/mention-finder/MentionFinder.styles.js.map +1 -1
- package/lib/cjs/components/mention-finder/mention-finder-item/MentionFinderItem.js +2 -3
- package/lib/cjs/components/mention-finder/mention-finder-item/MentionFinderItem.js.map +1 -1
- package/lib/cjs/components/mention-finder/mention-finder-item/MentionFinderItem.styles.js +2 -8
- package/lib/cjs/components/mention-finder/mention-finder-item/MentionFinderItem.styles.js.map +1 -1
- package/lib/cjs/components/multi-action-button/MultiActionButton.js +177 -0
- package/lib/cjs/components/multi-action-button/MultiActionButton.js.map +1 -0
- package/lib/cjs/components/multi-action-button/MultiActionButton.styles.js +19 -0
- package/lib/cjs/components/multi-action-button/MultiActionButton.styles.js.map +1 -0
- package/lib/cjs/components/multi-action-button/MultiActionButton.types.js +45 -0
- package/lib/cjs/components/multi-action-button/MultiActionButton.types.js.map +1 -0
- package/lib/cjs/components/multi-action-button/action-button/ActionButton.js +94 -0
- package/lib/cjs/components/multi-action-button/action-button/ActionButton.js.map +1 -0
- package/lib/cjs/components/multi-action-button/action-button/ActionButton.styles.js +219 -0
- package/lib/cjs/components/multi-action-button/action-button/ActionButton.styles.js.map +1 -0
- package/lib/cjs/components/number-input/NumberInput.js +14 -8
- package/lib/cjs/components/number-input/NumberInput.js.map +1 -1
- package/lib/cjs/components/page-provider/PageProvider.js +22 -8
- package/lib/cjs/components/page-provider/PageProvider.js.map +1 -1
- package/lib/cjs/components/page-provider/PageProvider.styles.js +1 -17
- package/lib/cjs/components/page-provider/PageProvider.styles.js.map +1 -1
- package/lib/cjs/components/popup/Popup.js +91 -92
- package/lib/cjs/components/popup/Popup.js.map +1 -1
- package/lib/cjs/components/popup/Popup.styles.js +7 -2
- package/lib/cjs/components/popup/Popup.styles.js.map +1 -1
- package/lib/cjs/components/popup/popup-content-wrapper/PopupContentWrapper.js +13 -3
- package/lib/cjs/components/popup/popup-content-wrapper/PopupContentWrapper.js.map +1 -1
- package/lib/cjs/components/popup/popup-content-wrapper/PopupContentWrapper.styles.js +55 -10
- package/lib/cjs/components/popup/popup-content-wrapper/PopupContentWrapper.styles.js.map +1 -1
- package/lib/cjs/components/progress-bar/ProgressBar.js +29 -8
- package/lib/cjs/components/progress-bar/ProgressBar.js.map +1 -1
- package/lib/cjs/components/progress-bar/ProgressBar.styles.js +71 -15
- package/lib/cjs/components/progress-bar/ProgressBar.styles.js.map +1 -1
- package/lib/cjs/components/radio-button/RadioButton.js +42 -21
- package/lib/cjs/components/radio-button/RadioButton.js.map +1 -1
- package/lib/cjs/components/radio-button/RadioButton.styles.js +4 -7
- package/lib/cjs/components/radio-button/RadioButton.styles.js.map +1 -1
- package/lib/cjs/components/radio-button/radio-button-group/RadioButtonGroup.js +6 -10
- package/lib/cjs/components/radio-button/radio-button-group/RadioButtonGroup.js.map +1 -1
- package/lib/cjs/components/scroll-view/ScrollView.js +1 -2
- package/lib/cjs/components/scroll-view/ScrollView.js.map +1 -1
- package/lib/cjs/components/scroll-view/ScrollView.styles.js +1 -2
- package/lib/cjs/components/scroll-view/ScrollView.styles.js.map +1 -1
- package/lib/cjs/components/search-box/SearchBox.js +143 -155
- package/lib/cjs/components/search-box/SearchBox.js.map +1 -1
- package/lib/cjs/components/search-box/SearchBox.styles.js +10 -6
- package/lib/cjs/components/search-box/SearchBox.styles.js.map +1 -1
- package/lib/cjs/components/search-box/group-name/GroupName.styles.js +1 -2
- package/lib/cjs/components/search-box/group-name/GroupName.styles.js.map +1 -1
- package/lib/cjs/components/search-box/search-box-body/SearchBoxBody.js +20 -34
- package/lib/cjs/components/search-box/search-box-body/SearchBoxBody.js.map +1 -1
- package/lib/cjs/components/search-box/search-box-body/SearchBoxBody.styles.js +3 -22
- package/lib/cjs/components/search-box/search-box-body/SearchBoxBody.styles.js.map +1 -1
- package/lib/cjs/components/search-box/search-box-item/SearchBoxItem.js +10 -7
- package/lib/cjs/components/search-box/search-box-item/SearchBoxItem.js.map +1 -1
- package/lib/cjs/components/search-box/search-box-item/SearchBoxItem.styles.js +2 -3
- package/lib/cjs/components/search-box/search-box-item/SearchBoxItem.styles.js.map +1 -1
- package/lib/cjs/components/search-input/SearchInput.js +138 -27
- package/lib/cjs/components/search-input/SearchInput.js.map +1 -1
- package/lib/cjs/components/search-input/SearchInput.styles.js +40 -14
- package/lib/cjs/components/search-input/SearchInput.styles.js.map +1 -1
- package/lib/cjs/components/select-button/SelectButton.js +2 -3
- package/lib/cjs/components/select-button/SelectButton.js.map +1 -1
- package/lib/cjs/components/setup-wizard/SetupWizard.js +1 -2
- package/lib/cjs/components/setup-wizard/SetupWizard.js.map +1 -1
- package/lib/cjs/components/setup-wizard/setup-wizard-item/SetupWizardItem.js +1 -2
- package/lib/cjs/components/setup-wizard/setup-wizard-item/SetupWizardItem.js.map +1 -1
- package/lib/cjs/components/sharing-bar/SharingBar.js +3 -6
- package/lib/cjs/components/sharing-bar/SharingBar.js.map +1 -1
- package/lib/cjs/components/sharing-bar/SharingBar.styles.js +1 -0
- package/lib/cjs/components/sharing-bar/SharingBar.styles.js.map +1 -1
- package/lib/cjs/components/signature/Signature.js +1 -2
- package/lib/cjs/components/signature/Signature.js.map +1 -1
- package/lib/cjs/components/signature/Signature.styles.js +1 -2
- package/lib/cjs/components/signature/Signature.styles.js.map +1 -1
- package/lib/cjs/components/slider/Slider.js +166 -120
- package/lib/cjs/components/slider/Slider.js.map +1 -1
- package/lib/cjs/components/slider/Slider.styles.js +29 -18
- package/lib/cjs/components/slider/Slider.styles.js.map +1 -1
- package/lib/cjs/components/slider-button/SliderButton.js +92 -54
- package/lib/cjs/components/slider-button/SliderButton.js.map +1 -1
- package/lib/cjs/components/slider-button/SliderButton.styles.js +6 -9
- package/lib/cjs/components/slider-button/SliderButton.styles.js.map +1 -1
- package/lib/cjs/components/small-wait-cursor/SmallWaitCursor.js.map +1 -1
- package/lib/cjs/components/small-wait-cursor/SmallWaitCursor.styles.js +13 -12
- package/lib/cjs/components/small-wait-cursor/SmallWaitCursor.styles.js.map +1 -1
- package/lib/cjs/components/tag-input/TagInput.js +94 -65
- package/lib/cjs/components/tag-input/TagInput.js.map +1 -1
- package/lib/cjs/components/tag-input/TagInput.styles.js +11 -3
- package/lib/cjs/components/tag-input/TagInput.styles.js.map +1 -1
- package/lib/cjs/components/text-area/TextArea.js +3 -2
- package/lib/cjs/components/text-area/TextArea.js.map +1 -1
- package/lib/cjs/components/text-area/TextArea.styles.js +2 -2
- package/lib/cjs/components/text-area/TextArea.styles.js.map +1 -1
- package/lib/cjs/components/tooltip/Tooltip.js +19 -9
- package/lib/cjs/components/tooltip/Tooltip.js.map +1 -1
- package/lib/cjs/components/tooltip/Tooltip.styles.js +17 -7
- package/lib/cjs/components/tooltip/Tooltip.styles.js.map +1 -1
- package/lib/cjs/components/tooltip/tooltip-item/TooltipItem.js +6 -5
- package/lib/cjs/components/tooltip/tooltip-item/TooltipItem.js.map +1 -1
- package/lib/cjs/components/tooltip/tooltip-item/TooltipItem.styles.js +15 -2
- package/lib/cjs/components/tooltip/tooltip-item/TooltipItem.styles.js.map +1 -1
- package/lib/cjs/components/truncation/Truncation.js +12 -4
- package/lib/cjs/components/truncation/Truncation.js.map +1 -1
- package/lib/cjs/components/truncation/Truncation.styles.js +3 -4
- package/lib/cjs/components/truncation/Truncation.styles.js.map +1 -1
- package/lib/cjs/components/verification-badge/VerificationBadge.js +15 -0
- package/lib/cjs/components/verification-badge/VerificationBadge.js.map +1 -0
- package/lib/cjs/components/verification-badge/VerificationBadge.styles.js +10 -0
- package/lib/cjs/components/verification-badge/VerificationBadge.styles.js.map +1 -0
- package/lib/cjs/constants/list.js +11 -0
- package/lib/cjs/constants/list.js.map +1 -0
- package/lib/cjs/hooks/container.js +54 -0
- package/lib/cjs/hooks/container.js.map +1 -0
- package/lib/cjs/hooks/dropdown.js +151 -0
- package/lib/cjs/hooks/dropdown.js.map +1 -0
- package/lib/cjs/hooks/element.js +152 -0
- package/lib/cjs/hooks/element.js.map +1 -0
- package/lib/cjs/hooks/ref.js +28 -0
- package/lib/cjs/hooks/ref.js.map +1 -0
- package/lib/cjs/hooks/resize.js +45 -0
- package/lib/cjs/hooks/resize.js.map +1 -0
- package/lib/cjs/index.js +156 -16
- package/lib/cjs/index.js.map +1 -1
- package/lib/cjs/types/chayns.js +4 -0
- package/lib/cjs/types/contentCard.js +1 -0
- package/lib/cjs/types/contentCard.js.map +1 -1
- package/lib/cjs/types/contextMenu.js +0 -15
- package/lib/cjs/types/contextMenu.js.map +1 -1
- package/lib/cjs/types/dropdown.js +18 -0
- package/lib/cjs/types/dropdown.js.map +1 -0
- package/lib/cjs/types/file.js +4 -0
- package/lib/cjs/types/fileInput.js +4 -0
- package/lib/cjs/types/filter.js +15 -0
- package/lib/cjs/types/filter.js.map +1 -0
- package/lib/cjs/types/filterButtons.js.map +1 -1
- package/lib/cjs/types/general.js +6 -0
- package/lib/cjs/types/general.js.map +1 -0
- package/lib/cjs/types/global.d.js +2 -0
- package/lib/cjs/types/global.d.js.map +1 -0
- package/lib/cjs/types/list.js +4 -0
- package/lib/cjs/types/popup.js.map +1 -1
- package/lib/cjs/types/radioButton.js +4 -0
- package/lib/cjs/types/searchBox.js +4 -0
- package/lib/cjs/types/selectButton.js +4 -0
- package/lib/cjs/types/selectButton.js.map +1 -1
- package/lib/cjs/types/sharingBar.js +4 -0
- package/lib/cjs/types/signature.js +4 -0
- package/lib/cjs/types/slider-button.js +4 -0
- package/lib/cjs/types/tagInput.js +4 -0
- package/lib/cjs/types/tagInput.js.map +1 -1
- package/lib/cjs/types/tooltip.js +4 -0
- package/lib/cjs/utils/accordion.js +18 -4
- package/lib/cjs/utils/accordion.js.map +1 -1
- package/lib/cjs/utils/calculate.js +43 -14
- package/lib/cjs/utils/calculate.js.map +1 -1
- package/lib/cjs/utils/environment.js +10 -3
- package/lib/cjs/utils/environment.js.map +1 -1
- package/lib/cjs/utils/file.js.map +1 -1
- package/lib/cjs/utils/fileDialog.js +77 -3
- package/lib/cjs/utils/fileDialog.js.map +1 -1
- package/lib/cjs/utils/font.js +1 -14
- package/lib/cjs/utils/font.js.map +1 -1
- package/lib/cjs/utils/groupedImage.js +68 -0
- package/lib/cjs/utils/groupedImage.js.map +1 -0
- package/lib/cjs/utils/icon.js +9 -1
- package/lib/cjs/utils/icon.js.map +1 -1
- package/lib/cjs/utils/numberInput.js +3 -0
- package/lib/cjs/utils/numberInput.js.map +1 -1
- package/lib/cjs/utils/pageProvider.js +7 -2
- package/lib/cjs/utils/pageProvider.js.map +1 -1
- package/lib/cjs/utils/radioButton.js +1 -2
- package/lib/cjs/utils/radioButton.js.map +1 -1
- package/lib/cjs/utils/slider.js +8 -12
- package/lib/cjs/utils/slider.js.map +1 -1
- package/lib/cjs/utils/sliderButton.js.map +1 -1
- package/lib/cjs/utils/uploadFile.js +3 -1
- package/lib/cjs/utils/uploadFile.js.map +1 -1
- package/lib/esm/api/image/post.js +4 -5
- package/lib/esm/api/image/post.js.map +1 -1
- package/lib/esm/api/theme/get.js.map +1 -1
- package/lib/esm/api/video/post.js +3 -4
- package/lib/esm/api/video/post.js.map +1 -1
- package/lib/esm/components/accordion/Accordion.js +68 -40
- package/lib/esm/components/accordion/Accordion.js.map +1 -1
- package/lib/esm/components/accordion/Accordion.styles.js +61 -74
- package/lib/esm/components/accordion/Accordion.styles.js.map +1 -1
- package/lib/esm/components/accordion/accordion-body/AccordionBody.js +30 -19
- package/lib/esm/components/accordion/accordion-body/AccordionBody.js.map +1 -1
- package/lib/esm/components/accordion/accordion-body/AccordionBody.styles.js +11 -16
- package/lib/esm/components/accordion/accordion-body/AccordionBody.styles.js.map +1 -1
- package/lib/esm/components/accordion/accordion-content/AccordionContent.js +13 -21
- package/lib/esm/components/accordion/accordion-content/AccordionContent.js.map +1 -1
- package/lib/esm/components/accordion/accordion-content/AccordionContent.styles.js +17 -34
- package/lib/esm/components/accordion/accordion-content/AccordionContent.styles.js.map +1 -1
- package/lib/esm/components/accordion/accordion-group/AccordionGroup.js +10 -12
- package/lib/esm/components/accordion/accordion-group/AccordionGroup.js.map +1 -1
- package/lib/esm/components/accordion/accordion-head/AccordionHead.js +102 -58
- package/lib/esm/components/accordion/accordion-head/AccordionHead.js.map +1 -1
- package/lib/esm/components/accordion/accordion-head/AccordionHead.styles.js +57 -115
- package/lib/esm/components/accordion/accordion-head/AccordionHead.styles.js.map +1 -1
- package/lib/esm/components/accordion/accordion-intro/AccordionIntro.js +5 -8
- package/lib/esm/components/accordion/accordion-intro/AccordionIntro.js.map +1 -1
- package/lib/esm/components/accordion/accordion-item/AccordionItem.js +8 -14
- package/lib/esm/components/accordion/accordion-item/AccordionItem.js.map +1 -1
- package/lib/esm/components/accordion/accordion-item/AccordionItem.styles.js +9 -18
- package/lib/esm/components/accordion/accordion-item/AccordionItem.styles.js.map +1 -1
- package/lib/esm/components/amount-control/AmountControl.js +42 -83
- package/lib/esm/components/amount-control/AmountControl.js.map +1 -1
- package/lib/esm/components/amount-control/AmountControl.styles.js +54 -94
- package/lib/esm/components/amount-control/AmountControl.styles.js.map +1 -1
- package/lib/esm/components/animated-number/AnimatedNumber.js +40 -0
- package/lib/esm/components/animated-number/AnimatedNumber.js.map +1 -0
- package/lib/esm/components/area-provider/AreaContextProvider.js +13 -8
- package/lib/esm/components/area-provider/AreaContextProvider.js.map +1 -1
- package/lib/esm/components/badge/Badge.constants.js +12 -0
- package/lib/esm/components/badge/Badge.constants.js.map +1 -0
- package/lib/esm/components/badge/Badge.js +17 -12
- package/lib/esm/components/badge/Badge.js.map +1 -1
- package/lib/esm/components/badge/Badge.styles.js +39 -38
- package/lib/esm/components/badge/Badge.styles.js.map +1 -1
- package/lib/esm/components/badge/Badge.types.js +22 -0
- package/lib/esm/components/badge/Badge.types.js.map +1 -0
- package/lib/esm/components/button/Button.js +24 -22
- package/lib/esm/components/button/Button.js.map +1 -1
- package/lib/esm/components/button/Button.styles.js +30 -36
- package/lib/esm/components/button/Button.styles.js.map +1 -1
- package/lib/esm/components/button/Button.types.js +2 -0
- package/lib/esm/components/button/Button.types.js.map +1 -0
- package/lib/esm/components/button/wait-cursor/WaitCursor.js +9 -12
- package/lib/esm/components/button/wait-cursor/WaitCursor.js.map +1 -1
- package/lib/esm/components/button/wait-cursor/WaitCursor.styles.js +6 -12
- package/lib/esm/components/button/wait-cursor/WaitCursor.styles.js.map +1 -1
- package/lib/esm/components/checkbox/Checkbox.js +38 -19
- package/lib/esm/components/checkbox/Checkbox.js.map +1 -1
- package/lib/esm/components/checkbox/Checkbox.styles.js +71 -107
- package/lib/esm/components/checkbox/Checkbox.styles.js.map +1 -1
- package/lib/esm/components/color-scheme-provider/ColorSchemeProvider.js +42 -145
- package/lib/esm/components/color-scheme-provider/ColorSchemeProvider.js.map +1 -1
- package/lib/esm/components/color-scheme-provider/ColorSchemeProvider.styles.js +12 -9
- package/lib/esm/components/color-scheme-provider/ColorSchemeProvider.styles.js.map +1 -1
- package/lib/esm/components/color-scheme-provider/hooks/useChaynsTheme.js +134 -0
- package/lib/esm/components/color-scheme-provider/hooks/useChaynsTheme.js.map +1 -0
- package/lib/esm/components/color-scheme-provider/hooks/useDesignSettings.js +29 -0
- package/lib/esm/components/color-scheme-provider/hooks/useDesignSettings.js.map +1 -0
- package/lib/esm/components/color-scheme-provider/hooks/useParagraphFormat.js +17 -0
- package/lib/esm/components/color-scheme-provider/hooks/useParagraphFormat.js.map +1 -0
- package/lib/esm/components/combobox/ComboBox.js +189 -205
- package/lib/esm/components/combobox/ComboBox.js.map +1 -1
- package/lib/esm/components/combobox/ComboBox.styles.js +132 -179
- package/lib/esm/components/combobox/ComboBox.styles.js.map +1 -1
- package/lib/esm/components/combobox/combobox-item/ComboBoxItem.js +23 -20
- package/lib/esm/components/combobox/combobox-item/ComboBoxItem.js.map +1 -1
- package/lib/esm/components/combobox/combobox-item/ComboBoxItem.styles.js +47 -77
- package/lib/esm/components/combobox/combobox-item/ComboBoxItem.styles.js.map +1 -1
- package/lib/esm/components/content-card/ContentCard.js +6 -6
- package/lib/esm/components/content-card/ContentCard.js.map +1 -1
- package/lib/esm/components/content-card/ContentCard.styles.js +46 -28
- package/lib/esm/components/content-card/ContentCard.styles.js.map +1 -1
- package/lib/esm/components/context-menu/ContextMenu.js +98 -38
- package/lib/esm/components/context-menu/ContextMenu.js.map +1 -1
- package/lib/esm/components/context-menu/ContextMenu.styles.js +16 -1
- package/lib/esm/components/context-menu/ContextMenu.styles.js.map +1 -1
- package/lib/esm/components/context-menu/ContextMenu.types.js +29 -0
- package/lib/esm/components/context-menu/ContextMenu.types.js.map +1 -0
- package/lib/esm/components/context-menu/ContextMenu.utils.js +2 -0
- package/lib/esm/components/context-menu/ContextMenu.utils.js.map +1 -0
- package/lib/esm/components/context-menu/context-menu-content/ContextMenuContent.js +61 -34
- package/lib/esm/components/context-menu/context-menu-content/ContextMenuContent.js.map +1 -1
- package/lib/esm/components/context-menu/context-menu-content/ContextMenuContent.styles.js +67 -30
- package/lib/esm/components/context-menu/context-menu-content/ContextMenuContent.styles.js.map +1 -1
- package/lib/esm/components/dropdown-body-wrapper/DropdownBodyWrapper.js +143 -0
- package/lib/esm/components/dropdown-body-wrapper/DropdownBodyWrapper.js.map +1 -0
- package/lib/esm/components/dropdown-body-wrapper/DropdownBodyWrapper.styles.js +43 -0
- package/lib/esm/components/dropdown-body-wrapper/DropdownBodyWrapper.styles.js.map +1 -0
- package/lib/esm/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.js +99 -0
- package/lib/esm/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.js.map +1 -0
- package/lib/esm/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.styles.js +30 -0
- package/lib/esm/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.styles.js.map +1 -0
- package/lib/esm/components/expandable-content/ExpandableContent.js +17 -19
- package/lib/esm/components/expandable-content/ExpandableContent.js.map +1 -1
- package/lib/esm/components/expandable-content/ExpandableContent.styles.js +2 -7
- package/lib/esm/components/expandable-content/ExpandableContent.styles.js.map +1 -1
- package/lib/esm/components/file-input/FileInput.js +73 -150
- package/lib/esm/components/file-input/FileInput.js.map +1 -1
- package/lib/esm/components/file-input/FileInput.styles.js +22 -40
- package/lib/esm/components/file-input/FileInput.styles.js.map +1 -1
- package/lib/esm/components/file-list/FileList.js +26 -0
- package/lib/esm/components/file-list/FileList.js.map +1 -0
- package/lib/esm/components/file-list/FileList.styles.js +3 -0
- package/lib/esm/components/file-list/FileList.styles.js.map +1 -0
- package/lib/esm/components/file-list/file-item/FileItem.js +32 -0
- package/lib/esm/components/file-list/file-item/FileItem.js.map +1 -0
- package/lib/esm/components/file-list/file-item/FileItem.styles.js +3 -0
- package/lib/esm/components/file-list/file-item/FileItem.styles.js.map +1 -0
- package/lib/esm/components/file-select/FileSelect.js +126 -0
- package/lib/esm/components/file-select/FileSelect.js.map +1 -0
- package/lib/esm/components/file-select/FileSelect.styles.js +45 -0
- package/lib/esm/components/file-select/FileSelect.styles.js.map +1 -0
- package/lib/esm/components/filter/Filter.js +215 -0
- package/lib/esm/components/filter/Filter.js.map +1 -0
- package/lib/esm/components/filter/Filter.styles.js +90 -0
- package/lib/esm/components/filter/Filter.styles.js.map +1 -0
- package/lib/esm/components/filter/filter-content/FIlterContent.js +79 -0
- package/lib/esm/components/filter/filter-content/FIlterContent.js.map +1 -0
- package/lib/esm/components/filter/filter-content/FilterContent.styles.js +29 -0
- package/lib/esm/components/filter/filter-content/FilterContent.styles.js.map +1 -0
- package/lib/esm/components/filter-buttons/FilterButtons.js +18 -18
- package/lib/esm/components/filter-buttons/FilterButtons.js.map +1 -1
- package/lib/esm/components/filter-buttons/filter-button/FilterButton.js +21 -15
- package/lib/esm/components/filter-buttons/filter-button/FilterButton.js.map +1 -1
- package/lib/esm/components/filter-buttons/filter-button/FilterButton.styles.js +41 -61
- package/lib/esm/components/filter-buttons/filter-button/FilterButton.styles.js.map +1 -1
- package/lib/esm/components/grid-image/GridImage.js +7 -8
- package/lib/esm/components/grid-image/GridImage.js.map +1 -1
- package/lib/esm/components/grid-image/GridImage.styles.js +31 -61
- package/lib/esm/components/grid-image/GridImage.styles.js.map +1 -1
- package/lib/esm/components/grouped-image/GroupedImage.js +67 -0
- package/lib/esm/components/grouped-image/GroupedImage.js.map +1 -0
- package/lib/esm/components/grouped-image/GroupedImage.styles.js +118 -0
- package/lib/esm/components/grouped-image/GroupedImage.styles.js.map +1 -0
- package/lib/esm/components/grouped-image/clip-paths/CareOfClipPath.js +27 -0
- package/lib/esm/components/grouped-image/clip-paths/CareOfClipPath.js.map +1 -0
- package/lib/esm/components/grouped-image/clip-paths/SecondImageClipPath.js +27 -0
- package/lib/esm/components/grouped-image/clip-paths/SecondImageClipPath.js.map +1 -0
- package/lib/esm/components/highlight-slider/HighlightSlider.js +41 -0
- package/lib/esm/components/highlight-slider/HighlightSlider.js.map +1 -0
- package/lib/esm/components/highlight-slider/HighlightSlider.styles.js +7 -0
- package/lib/esm/components/highlight-slider/HighlightSlider.styles.js.map +1 -0
- package/lib/esm/components/highlight-slider/highlight-slider-item/HighlightSliderItem.js +50 -0
- package/lib/esm/components/highlight-slider/highlight-slider-item/HighlightSliderItem.js.map +1 -0
- package/lib/esm/components/highlight-slider/highlight-slider-item/HighlightSliderItem.styles.js +29 -0
- package/lib/esm/components/highlight-slider/highlight-slider-item/HighlightSliderItem.styles.js.map +1 -0
- package/lib/esm/components/icon/Icon.js +22 -27
- package/lib/esm/components/icon/Icon.js.map +1 -1
- package/lib/esm/components/icon/Icon.styles.js +45 -58
- package/lib/esm/components/icon/Icon.styles.js.map +1 -1
- package/lib/esm/components/input/Input.js +58 -30
- package/lib/esm/components/input/Input.js.map +1 -1
- package/lib/esm/components/input/Input.styles.js +78 -99
- package/lib/esm/components/input/Input.styles.js.map +1 -1
- package/lib/esm/components/list/List.js +8 -10
- package/lib/esm/components/list/List.js.map +1 -1
- package/lib/esm/components/list/list-item/ListItem.js +101 -44
- package/lib/esm/components/list/list-item/ListItem.js.map +1 -1
- package/lib/esm/components/list/list-item/ListItem.styles.js +71 -54
- package/lib/esm/components/list/list-item/ListItem.styles.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-body/ListItemBody.js +8 -9
- package/lib/esm/components/list/list-item/list-item-body/ListItemBody.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-body/ListItemBody.styles.js +1 -1
- package/lib/esm/components/list/list-item/list-item-body/ListItemBody.styles.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-content/ListItemContent.js +5 -8
- package/lib/esm/components/list/list-item/list-item-content/ListItemContent.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-content/ListItemContent.styles.js +3 -6
- package/lib/esm/components/list/list-item/list-item-content/ListItemContent.styles.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-head/ListItemHead.js +107 -94
- package/lib/esm/components/list/list-item/list-item-head/ListItemHead.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-head/ListItemHead.styles.js +36 -143
- package/lib/esm/components/list/list-item/list-item-head/ListItemHead.styles.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-head/list-item-icon/ListItemIcon.js +11 -14
- package/lib/esm/components/list/list-item/list-item-head/list-item-icon/ListItemIcon.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-head/list-item-icon/ListItemIcon.styles.js +13 -25
- package/lib/esm/components/list/list-item/list-item-head/list-item-icon/ListItemIcon.styles.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-head/list-item-image/ListItemImage.js +23 -34
- package/lib/esm/components/list/list-item/list-item-head/list-item-image/ListItemImage.js.map +1 -1
- package/lib/esm/components/list/list-item/list-item-head/list-item-right-element/ListItemRightElement.js +35 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-right-element/ListItemRightElement.js.map +1 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-right-element/ListItemRightElement.styles.js +8 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-right-element/ListItemRightElement.styles.js.map +1 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.js +33 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.js.map +1 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.styles.js +33 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.styles.js.map +1 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-title/ListItemTitle.js +70 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-title/ListItemTitle.js.map +1 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-title/ListItemTitle.styles.js +52 -0
- package/lib/esm/components/list/list-item/list-item-head/list-item-title/ListItemTitle.styles.js.map +1 -0
- package/lib/esm/components/mention-finder/MentionFinder.js +256 -34
- package/lib/esm/components/mention-finder/MentionFinder.js.map +1 -1
- package/lib/esm/components/mention-finder/MentionFinder.styles.js +120 -24
- package/lib/esm/components/mention-finder/MentionFinder.styles.js.map +1 -1
- package/lib/esm/components/mention-finder/mention-finder-item/MentionFinderItem.js +7 -8
- package/lib/esm/components/mention-finder/mention-finder-item/MentionFinderItem.js.map +1 -1
- package/lib/esm/components/mention-finder/mention-finder-item/MentionFinderItem.styles.js +21 -47
- package/lib/esm/components/mention-finder/mention-finder-item/MentionFinderItem.styles.js.map +1 -1
- package/lib/esm/components/multi-action-button/MultiActionButton.js +167 -0
- package/lib/esm/components/multi-action-button/MultiActionButton.js.map +1 -0
- package/lib/esm/components/multi-action-button/MultiActionButton.styles.js +12 -0
- package/lib/esm/components/multi-action-button/MultiActionButton.styles.js.map +1 -0
- package/lib/esm/components/multi-action-button/MultiActionButton.types.js +44 -0
- package/lib/esm/components/multi-action-button/MultiActionButton.types.js.map +1 -0
- package/lib/esm/components/multi-action-button/action-button/ActionButton.js +86 -0
- package/lib/esm/components/multi-action-button/action-button/ActionButton.js.map +1 -0
- package/lib/esm/components/multi-action-button/action-button/ActionButton.styles.js +212 -0
- package/lib/esm/components/multi-action-button/action-button/ActionButton.styles.js.map +1 -0
- package/lib/esm/components/number-input/NumberInput.js +28 -22
- package/lib/esm/components/number-input/NumberInput.js.map +1 -1
- package/lib/esm/components/page-provider/PageProvider.js +32 -18
- package/lib/esm/components/page-provider/PageProvider.js.map +1 -1
- package/lib/esm/components/page-provider/PageProvider.styles.js +8 -30
- package/lib/esm/components/page-provider/PageProvider.styles.js.map +1 -1
- package/lib/esm/components/popup/Popup.js +77 -78
- package/lib/esm/components/popup/Popup.js.map +1 -1
- package/lib/esm/components/popup/Popup.styles.js +13 -13
- package/lib/esm/components/popup/Popup.styles.js.map +1 -1
- package/lib/esm/components/popup/popup-content/PopupContent.js +3 -6
- package/lib/esm/components/popup/popup-content/PopupContent.js.map +1 -1
- package/lib/esm/components/popup/popup-content-wrapper/PopupContentWrapper.js +27 -21
- package/lib/esm/components/popup/popup-content-wrapper/PopupContentWrapper.js.map +1 -1
- package/lib/esm/components/popup/popup-content-wrapper/PopupContentWrapper.styles.js +60 -21
- package/lib/esm/components/popup/popup-content-wrapper/PopupContentWrapper.styles.js.map +1 -1
- package/lib/esm/components/progress-bar/ProgressBar.js +33 -12
- package/lib/esm/components/progress-bar/ProgressBar.js.map +1 -1
- package/lib/esm/components/progress-bar/ProgressBar.styles.js +72 -25
- package/lib/esm/components/progress-bar/ProgressBar.styles.js.map +1 -1
- package/lib/esm/components/radio-button/RadioButton.js +34 -14
- package/lib/esm/components/radio-button/RadioButton.js.map +1 -1
- package/lib/esm/components/radio-button/RadioButton.styles.js +37 -68
- package/lib/esm/components/radio-button/RadioButton.styles.js.map +1 -1
- package/lib/esm/components/radio-button/radio-button-group/RadioButtonGroup.js +12 -16
- package/lib/esm/components/radio-button/radio-button-group/RadioButtonGroup.js.map +1 -1
- package/lib/esm/components/scroll-view/ScrollView.js +9 -10
- package/lib/esm/components/scroll-view/ScrollView.js.map +1 -1
- package/lib/esm/components/scroll-view/ScrollView.styles.js +29 -50
- package/lib/esm/components/scroll-view/ScrollView.styles.js.map +1 -1
- package/lib/esm/components/search-box/SearchBox.js +208 -245
- package/lib/esm/components/search-box/SearchBox.js.map +1 -1
- package/lib/esm/components/search-box/SearchBox.styles.js +23 -33
- package/lib/esm/components/search-box/SearchBox.styles.js.map +1 -1
- package/lib/esm/components/search-box/group-name/GroupName.js +7 -10
- package/lib/esm/components/search-box/group-name/GroupName.js.map +1 -1
- package/lib/esm/components/search-box/group-name/GroupName.styles.js +10 -19
- package/lib/esm/components/search-box/group-name/GroupName.styles.js.map +1 -1
- package/lib/esm/components/search-box/search-box-body/SearchBoxBody.js +27 -41
- package/lib/esm/components/search-box/search-box-body/SearchBoxBody.js.map +1 -1
- package/lib/esm/components/search-box/search-box-body/SearchBoxBody.styles.js +24 -69
- package/lib/esm/components/search-box/search-box-body/SearchBoxBody.styles.js.map +1 -1
- package/lib/esm/components/search-box/search-box-item/SearchBoxItem.js +16 -13
- package/lib/esm/components/search-box/search-box-item/SearchBoxItem.js.map +1 -1
- package/lib/esm/components/search-box/search-box-item/SearchBoxItem.styles.js +20 -38
- package/lib/esm/components/search-box/search-box-item/SearchBoxItem.styles.js.map +1 -1
- package/lib/esm/components/search-input/SearchInput.js +129 -24
- package/lib/esm/components/search-input/SearchInput.js.map +1 -1
- package/lib/esm/components/search-input/SearchInput.styles.js +41 -21
- package/lib/esm/components/search-input/SearchInput.styles.js.map +1 -1
- package/lib/esm/components/select-button/SelectButton.js +23 -26
- package/lib/esm/components/select-button/SelectButton.js.map +1 -1
- package/lib/esm/components/setup-wizard/SetupWizard.js +4 -5
- package/lib/esm/components/setup-wizard/SetupWizard.js.map +1 -1
- package/lib/esm/components/setup-wizard/setup-wizard-item/SetupWizardItem.js +6 -7
- package/lib/esm/components/setup-wizard/setup-wizard-item/SetupWizardItem.js.map +1 -1
- package/lib/esm/components/sharing-bar/SharingBar.js +8 -11
- package/lib/esm/components/sharing-bar/SharingBar.js.map +1 -1
- package/lib/esm/components/sharing-bar/SharingBar.styles.js +4 -6
- package/lib/esm/components/sharing-bar/SharingBar.styles.js.map +1 -1
- package/lib/esm/components/signature/Signature.js +8 -9
- package/lib/esm/components/signature/Signature.js.map +1 -1
- package/lib/esm/components/signature/Signature.styles.js +4 -7
- package/lib/esm/components/signature/Signature.styles.js.map +1 -1
- package/lib/esm/components/slider/Slider.js +165 -122
- package/lib/esm/components/slider/Slider.js.map +1 -1
- package/lib/esm/components/slider/Slider.styles.js +64 -71
- package/lib/esm/components/slider/Slider.styles.js.map +1 -1
- package/lib/esm/components/slider-button/SliderButton.js +97 -80
- package/lib/esm/components/slider-button/SliderButton.js.map +1 -1
- package/lib/esm/components/slider-button/SliderButton.styles.js +36 -75
- package/lib/esm/components/slider-button/SliderButton.styles.js.map +1 -1
- package/lib/esm/components/small-wait-cursor/SmallWaitCursor.js +15 -18
- package/lib/esm/components/small-wait-cursor/SmallWaitCursor.js.map +1 -1
- package/lib/esm/components/small-wait-cursor/SmallWaitCursor.styles.js +33 -50
- package/lib/esm/components/small-wait-cursor/SmallWaitCursor.styles.js.map +1 -1
- package/lib/esm/components/tag-input/TagInput.js +93 -68
- package/lib/esm/components/tag-input/TagInput.js.map +1 -1
- package/lib/esm/components/tag-input/TagInput.styles.js +14 -12
- package/lib/esm/components/tag-input/TagInput.styles.js.map +1 -1
- package/lib/esm/components/text-area/TextArea.js +15 -14
- package/lib/esm/components/text-area/TextArea.js.map +1 -1
- package/lib/esm/components/text-area/TextArea.styles.js +34 -60
- package/lib/esm/components/text-area/TextArea.styles.js.map +1 -1
- package/lib/esm/components/tooltip/Tooltip.js +27 -17
- package/lib/esm/components/tooltip/Tooltip.js.map +1 -1
- package/lib/esm/components/tooltip/Tooltip.styles.js +20 -12
- package/lib/esm/components/tooltip/Tooltip.styles.js.map +1 -1
- package/lib/esm/components/tooltip/tooltip-item/TooltipItem.js +15 -16
- package/lib/esm/components/tooltip/tooltip-item/TooltipItem.js.map +1 -1
- package/lib/esm/components/tooltip/tooltip-item/TooltipItem.styles.js +27 -25
- package/lib/esm/components/tooltip/tooltip-item/TooltipItem.styles.js.map +1 -1
- package/lib/esm/components/truncation/Truncation.js +20 -12
- package/lib/esm/components/truncation/Truncation.js.map +1 -1
- package/lib/esm/components/truncation/Truncation.styles.js +4 -5
- package/lib/esm/components/truncation/Truncation.styles.js.map +1 -1
- package/lib/esm/components/verification-badge/VerificationBadge.js +8 -0
- package/lib/esm/components/verification-badge/VerificationBadge.js.map +1 -0
- package/lib/esm/components/verification-badge/VerificationBadge.styles.js +3 -0
- package/lib/esm/components/verification-badge/VerificationBadge.styles.js.map +1 -0
- package/lib/esm/constants/list.js +5 -0
- package/lib/esm/constants/list.js.map +1 -0
- package/lib/esm/hooks/container.js +47 -0
- package/lib/esm/hooks/container.js.map +1 -0
- package/lib/esm/hooks/dropdown.js +141 -0
- package/lib/esm/hooks/dropdown.js.map +1 -0
- package/lib/esm/hooks/element.js +140 -0
- package/lib/esm/hooks/element.js.map +1 -0
- package/lib/esm/hooks/ref.js +20 -0
- package/lib/esm/hooks/ref.js.map +1 -0
- package/lib/esm/hooks/resize.js +40 -0
- package/lib/esm/hooks/resize.js.map +1 -0
- package/lib/esm/index.js +21 -5
- package/lib/esm/index.js.map +1 -1
- package/lib/esm/types/chayns.js +1 -1
- package/lib/esm/types/contentCard.js +1 -0
- package/lib/esm/types/contentCard.js.map +1 -1
- package/lib/esm/types/contextMenu.js +0 -9
- package/lib/esm/types/contextMenu.js.map +1 -1
- package/lib/esm/types/dropdown.js +12 -0
- package/lib/esm/types/dropdown.js.map +1 -0
- package/lib/esm/types/file.js +1 -1
- package/lib/esm/types/fileInput.js +1 -1
- package/lib/esm/types/filter.js +9 -0
- package/lib/esm/types/filter.js.map +1 -0
- package/lib/esm/types/filterButtons.js.map +1 -1
- package/lib/esm/types/general.js +2 -0
- package/lib/esm/types/general.js.map +1 -0
- package/lib/esm/types/global.d.js +2 -0
- package/lib/esm/types/global.d.js.map +1 -0
- package/lib/esm/types/list.js +1 -1
- package/lib/esm/types/popup.js.map +1 -1
- package/lib/esm/types/radioButton.js +1 -1
- package/lib/esm/types/searchBox.js +1 -1
- package/lib/esm/types/selectButton.js +1 -1
- package/lib/esm/types/selectButton.js.map +1 -1
- package/lib/esm/types/sharingBar.js +1 -1
- package/lib/esm/types/signature.js +1 -1
- package/lib/esm/types/slider-button.js +1 -1
- package/lib/esm/types/tagInput.js +1 -1
- package/lib/esm/types/tagInput.js.map +1 -1
- package/lib/esm/types/tooltip.js +1 -1
- package/lib/esm/utils/accordion.js +24 -11
- package/lib/esm/utils/accordion.js.map +1 -1
- package/lib/esm/utils/amountControl.js +5 -6
- package/lib/esm/utils/amountControl.js.map +1 -1
- package/lib/esm/utils/calculate.js +50 -23
- package/lib/esm/utils/calculate.js.map +1 -1
- package/lib/esm/utils/debounce.js +6 -11
- package/lib/esm/utils/debounce.js.map +1 -1
- package/lib/esm/utils/environment.js +8 -1
- package/lib/esm/utils/environment.js.map +1 -1
- package/lib/esm/utils/file.js +12 -19
- package/lib/esm/utils/file.js.map +1 -1
- package/lib/esm/utils/fileDialog.js +138 -68
- package/lib/esm/utils/fileDialog.js.map +1 -1
- package/lib/esm/utils/font.js +5 -18
- package/lib/esm/utils/font.js.map +1 -1
- package/lib/esm/utils/groupedImage.js +60 -0
- package/lib/esm/utils/groupedImage.js.map +1 -0
- package/lib/esm/utils/icon.js +7 -0
- package/lib/esm/utils/icon.js.map +1 -1
- package/lib/esm/utils/isTobitEmployee.js +3 -4
- package/lib/esm/utils/isTobitEmployee.js.map +1 -1
- package/lib/esm/utils/numberInput.js +18 -18
- package/lib/esm/utils/numberInput.js.map +1 -1
- package/lib/esm/utils/pageProvider.js +7 -2
- package/lib/esm/utils/pageProvider.js.map +1 -1
- package/lib/esm/utils/searchBox.js +4 -5
- package/lib/esm/utils/searchBox.js.map +1 -1
- package/lib/esm/utils/slider.js +28 -36
- package/lib/esm/utils/slider.js.map +1 -1
- package/lib/esm/utils/sliderButton.js +9 -11
- package/lib/esm/utils/sliderButton.js.map +1 -1
- package/lib/esm/utils/uploadFile.js +7 -7
- package/lib/esm/utils/uploadFile.js.map +1 -1
- package/lib/types/api/theme/get.d.ts +3 -3
- package/lib/types/components/accordion/Accordion.d.ts +10 -1
- package/lib/types/components/accordion/Accordion.styles.d.ts +3 -264
- package/lib/types/components/accordion/accordion-body/AccordionBody.d.ts +4 -0
- package/lib/types/components/accordion/accordion-body/AccordionBody.styles.d.ts +3 -264
- package/lib/types/components/accordion/accordion-content/AccordionContent.styles.d.ts +1 -2
- package/lib/types/components/accordion/accordion-head/AccordionHead.d.ts +3 -2
- package/lib/types/components/accordion/accordion-head/AccordionHead.styles.d.ts +35 -2687
- package/lib/types/components/accordion/accordion-intro/AccordionIntro.styles.d.ts +1 -1
- package/lib/types/components/accordion/accordion-item/AccordionItem.styles.d.ts +1 -1
- package/lib/types/components/amount-control/AmountControl.d.ts +8 -4
- package/lib/types/components/amount-control/AmountControl.styles.d.ts +11 -279
- package/lib/types/components/animated-number/AnimatedNumber.d.ts +47 -0
- package/lib/types/components/area-provider/AreaContextProvider.d.ts +6 -1
- package/lib/types/components/badge/Badge.constants.d.ts +10 -0
- package/lib/types/components/badge/Badge.d.ts +2 -23
- package/lib/types/components/badge/Badge.styles.d.ts +7 -1
- package/lib/types/components/badge/Badge.types.d.ts +79 -0
- package/lib/types/components/button/Button.d.ts +2 -43
- package/lib/types/components/button/Button.styles.d.ts +11 -807
- package/lib/types/components/button/Button.types.d.ts +92 -0
- package/lib/types/components/button/wait-cursor/WaitCursor.styles.d.ts +3 -3
- package/lib/types/components/checkbox/Checkbox.styles.d.ts +9 -5
- package/lib/types/components/color-scheme-provider/ColorSchemeProvider.d.ts +9 -25
- package/lib/types/components/color-scheme-provider/ColorSchemeProvider.styles.d.ts +1 -1
- package/lib/types/components/color-scheme-provider/hooks/useChaynsTheme.d.ts +21 -0
- package/lib/types/components/color-scheme-provider/hooks/useDesignSettings.d.ts +9 -0
- package/lib/types/components/color-scheme-provider/hooks/useParagraphFormat.d.ts +2 -0
- package/lib/types/components/combobox/ComboBox.d.ts +36 -9
- package/lib/types/components/combobox/ComboBox.styles.d.ts +27 -281
- package/lib/types/components/combobox/combobox-item/ComboBoxItem.d.ts +2 -12
- package/lib/types/components/combobox/combobox-item/ComboBoxItem.styles.d.ts +9 -8
- package/lib/types/components/content-card/ContentCard.styles.d.ts +1 -1
- package/lib/types/components/context-menu/ContextMenu.d.ts +2 -57
- package/lib/types/components/context-menu/ContextMenu.styles.d.ts +7 -1
- package/lib/types/components/context-menu/ContextMenu.types.d.ts +147 -0
- package/lib/types/components/context-menu/ContextMenu.utils.d.ts +2 -0
- package/lib/types/components/context-menu/context-menu-content/ContextMenuContent.d.ts +8 -2
- package/lib/types/components/context-menu/context-menu-content/ContextMenuContent.styles.d.ts +16 -268
- package/lib/types/components/dropdown-body-wrapper/DropdownBodyWrapper.d.ts +56 -0
- package/lib/types/components/dropdown-body-wrapper/DropdownBodyWrapper.styles.d.ts +11 -0
- package/lib/types/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.d.ts +26 -0
- package/lib/types/components/dropdown-body-wrapper/delayed-dropdown-content/DelayedDropdownContent.styles.d.ts +11 -0
- package/lib/types/components/expandable-content/ExpandableContent.d.ts +4 -0
- package/lib/types/components/expandable-content/ExpandableContent.styles.d.ts +3 -268
- package/lib/types/components/file-input/FileInput.d.ts +11 -4
- package/lib/types/components/file-input/FileInput.styles.d.ts +9 -272
- package/lib/types/components/file-list/FileList.d.ts +19 -0
- package/lib/types/components/file-list/FileList.styles.d.ts +1 -0
- package/lib/types/components/file-list/file-item/FileItem.d.ts +7 -0
- package/lib/types/components/file-list/file-item/FileItem.styles.d.ts +1 -0
- package/lib/types/components/file-select/FileSelect.d.ts +50 -0
- package/lib/types/components/file-select/FileSelect.styles.d.ts +21 -0
- package/lib/types/components/filter/Filter.d.ts +19 -0
- package/lib/types/components/filter/Filter.styles.d.ts +24 -0
- package/lib/types/components/filter/filter-content/FIlterContent.d.ts +11 -0
- package/lib/types/components/filter/filter-content/FilterContent.styles.d.ts +11 -0
- package/lib/types/components/filter-buttons/FilterButtons.styles.d.ts +1 -1
- package/lib/types/components/filter-buttons/filter-button/FilterButton.d.ts +1 -0
- package/lib/types/components/filter-buttons/filter-button/FilterButton.styles.d.ts +9 -269
- package/lib/types/components/grid-image/GridImage.styles.d.ts +4 -4
- package/lib/types/components/grouped-image/GroupedImage.d.ts +41 -0
- package/lib/types/components/grouped-image/GroupedImage.styles.d.ts +24 -0
- package/lib/types/components/grouped-image/clip-paths/CareOfClipPath.d.ts +10 -0
- package/lib/types/components/grouped-image/clip-paths/SecondImageClipPath.d.ts +10 -0
- package/lib/types/components/highlight-slider/HighlightSlider.d.ts +26 -0
- package/lib/types/components/highlight-slider/HighlightSlider.styles.d.ts +1 -0
- package/lib/types/components/highlight-slider/highlight-slider-item/HighlightSliderItem.d.ts +16 -0
- package/lib/types/components/highlight-slider/highlight-slider-item/HighlightSliderItem.styles.d.ts +15 -0
- package/lib/types/components/icon/Icon.d.ts +67 -9
- package/lib/types/components/icon/Icon.styles.d.ts +6 -2
- package/lib/types/components/input/Input.d.ts +18 -4
- package/lib/types/components/input/Input.styles.d.ts +21 -803
- package/lib/types/components/list/list-item/ListItem.d.ts +52 -3
- package/lib/types/components/list/list-item/ListItem.styles.d.ts +9 -267
- package/lib/types/components/list/list-item/list-item-body/ListItemBody.d.ts +3 -2
- package/lib/types/components/list/list-item/list-item-body/ListItemBody.styles.d.ts +3 -266
- package/lib/types/components/list/list-item/list-item-content/ListItemContent.styles.d.ts +1 -1
- package/lib/types/components/list/list-item/list-item-head/ListItemHead.d.ts +9 -1
- package/lib/types/components/list/list-item/list-item-head/ListItemHead.styles.d.ts +11 -1081
- package/lib/types/components/list/list-item/list-item-head/list-item-icon/ListItemIcon.styles.d.ts +1 -1
- package/lib/types/components/list/list-item/list-item-head/list-item-image/ListItemImage.d.ts +5 -1
- package/lib/types/components/list/list-item/list-item-head/{list-item-right-elements/ListItemRightElements.d.ts → list-item-right-element/ListItemRightElement.d.ts} +3 -3
- package/lib/types/components/list/list-item/list-item-head/list-item-right-element/ListItemRightElement.styles.d.ts +1 -0
- package/lib/types/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.d.ts +9 -0
- package/lib/types/components/list/list-item/list-item-head/list-item-subtitle/ListItemSubtitle.styles.d.ts +8 -0
- package/lib/types/components/list/list-item/list-item-head/list-item-title/ListItemTitle.d.ts +13 -0
- package/lib/types/components/list/list-item/list-item-head/list-item-title/ListItemTitle.styles.d.ts +11 -0
- package/lib/types/components/mention-finder/MentionFinder.d.ts +14 -2
- package/lib/types/components/mention-finder/MentionFinder.styles.d.ts +20 -265
- package/lib/types/components/mention-finder/mention-finder-item/MentionFinderItem.styles.d.ts +5 -5
- package/lib/types/components/multi-action-button/MultiActionButton.d.ts +7 -0
- package/lib/types/components/multi-action-button/MultiActionButton.styles.d.ts +3 -0
- package/lib/types/components/multi-action-button/MultiActionButton.types.d.ts +183 -0
- package/lib/types/components/multi-action-button/action-button/ActionButton.d.ts +25 -0
- package/lib/types/components/multi-action-button/action-button/ActionButton.styles.d.ts +26 -0
- package/lib/types/components/number-input/NumberInput.d.ts +4 -0
- package/lib/types/components/page-provider/PageProvider.d.ts +34 -2
- package/lib/types/components/page-provider/PageProvider.styles.d.ts +1 -1
- package/lib/types/components/popup/Popup.d.ts +13 -1
- package/lib/types/components/popup/Popup.styles.d.ts +3 -2
- package/lib/types/components/popup/popup-content/PopupContent.styles.d.ts +1 -1
- package/lib/types/components/popup/popup-content-wrapper/PopupContentWrapper.d.ts +2 -0
- package/lib/types/components/popup/popup-content-wrapper/PopupContentWrapper.styles.d.ts +10 -264
- package/lib/types/components/progress-bar/ProgressBar.d.ts +22 -1
- package/lib/types/components/progress-bar/ProgressBar.styles.d.ts +30 -274
- package/lib/types/components/radio-button/RadioButton.d.ts +4 -0
- package/lib/types/components/radio-button/RadioButton.styles.d.ts +11 -272
- package/lib/types/components/radio-button/radio-button-group/RadioButtonGroup.d.ts +2 -2
- package/lib/types/components/scroll-view/ScrollView.styles.d.ts +1 -1
- package/lib/types/components/search-box/SearchBox.d.ts +38 -6
- package/lib/types/components/search-box/SearchBox.styles.d.ts +7 -267
- package/lib/types/components/search-box/group-name/GroupName.styles.d.ts +1 -1
- package/lib/types/components/search-box/search-box-body/SearchBoxBody.d.ts +1 -7
- package/lib/types/components/search-box/search-box-body/SearchBoxBody.styles.d.ts +4 -270
- package/lib/types/components/search-box/search-box-item/SearchBoxItem.d.ts +1 -0
- package/lib/types/components/search-box/search-box-item/SearchBoxItem.styles.d.ts +3 -3
- package/lib/types/components/search-input/SearchInput.d.ts +11 -3
- package/lib/types/components/search-input/SearchInput.styles.d.ts +13 -533
- package/lib/types/components/select-button/SelectButton.d.ts +2 -2
- package/lib/types/components/select-button/SelectButton.styles.d.ts +1 -1
- package/lib/types/components/setup-wizard/SetupWizard.d.ts +2 -2
- package/lib/types/components/setup-wizard/SetupWizard.styles.d.ts +1 -1
- package/lib/types/components/setup-wizard/setup-wizard-item/SetupWizardItem.styles.d.ts +1 -1
- package/lib/types/components/sharing-bar/SharingBar.d.ts +1 -5
- package/lib/types/components/sharing-bar/SharingBar.styles.d.ts +3 -3
- package/lib/types/components/signature/Signature.styles.d.ts +4 -4
- package/lib/types/components/slider/Slider.d.ts +106 -9
- package/lib/types/components/slider/Slider.styles.d.ts +17 -595
- package/lib/types/components/slider-button/SliderButton.d.ts +10 -6
- package/lib/types/components/slider-button/SliderButton.styles.d.ts +10 -270
- package/lib/types/components/small-wait-cursor/SmallWaitCursor.d.ts +23 -8
- package/lib/types/components/small-wait-cursor/SmallWaitCursor.styles.d.ts +6 -6
- package/lib/types/components/tag-input/TagInput.d.ts +32 -3
- package/lib/types/components/tag-input/TagInput.styles.d.ts +10 -6
- package/lib/types/components/text-area/TextArea.styles.d.ts +6 -6
- package/lib/types/components/tooltip/Tooltip.d.ts +13 -0
- package/lib/types/components/tooltip/Tooltip.styles.d.ts +3 -2
- package/lib/types/components/tooltip/tooltip-item/TooltipItem.d.ts +1 -0
- package/lib/types/components/tooltip/tooltip-item/TooltipItem.styles.d.ts +6 -5
- package/lib/types/components/truncation/Truncation.styles.d.ts +7 -270
- package/lib/types/components/verification-badge/VerificationBadge.d.ts +6 -0
- package/lib/types/components/verification-badge/VerificationBadge.styles.d.ts +1 -0
- package/lib/types/constants/list.d.ts +4 -0
- package/lib/types/hooks/container.d.ts +18 -0
- package/lib/types/hooks/dropdown.d.ts +46 -0
- package/lib/types/hooks/element.d.ts +17 -0
- package/lib/types/hooks/ref.d.ts +3 -0
- package/lib/types/hooks/resize.d.ts +6 -0
- package/lib/types/index.d.ts +31 -10
- package/lib/types/types/contentCard.d.ts +2 -1
- package/lib/types/types/contextMenu.d.ts +0 -8
- package/lib/types/types/dropdown.d.ts +26 -0
- package/lib/types/types/filter.d.ts +28 -0
- package/lib/types/types/filterButtons.d.ts +1 -0
- package/lib/types/types/general.d.ts +4 -0
- package/lib/types/types/popup.d.ts +2 -2
- package/lib/types/types/selectButton.d.ts +1 -1
- package/lib/types/types/tagInput.d.ts +2 -0
- package/lib/types/utils/calculate.d.ts +13 -3
- package/lib/types/utils/environment.d.ts +1 -1
- package/lib/types/utils/file.d.ts +3 -2
- package/lib/types/utils/font.d.ts +0 -1
- package/lib/types/utils/groupedImage.d.ts +11 -0
- package/lib/types/utils/icon.d.ts +1 -0
- package/lib/types/utils/numberInput.d.ts +1 -1
- package/lib/types/utils/pageProvider.d.ts +5 -1
- package/lib/types/utils/slider.d.ts +6 -5
- package/lib/types/utils/sliderButton.d.ts +1 -1
- package/package.json +20 -22
- package/lib/cjs/components/file-input/file-list/FileListItem.js +0 -36
- package/lib/cjs/components/file-input/file-list/FileListItem.js.map +0 -1
- package/lib/cjs/components/file-input/file-list/FileListItem.styles.js.map +0 -1
- package/lib/cjs/components/list/list-item/list-item-head/list-item-image/ListItemImage.styles.js +0 -47
- package/lib/cjs/components/list/list-item/list-item-head/list-item-image/ListItemImage.styles.js.map +0 -1
- package/lib/cjs/components/list/list-item/list-item-head/list-item-right-elements/ListItemRightElements.js +0 -58
- package/lib/cjs/components/list/list-item/list-item-head/list-item-right-elements/ListItemRightElements.js.map +0 -1
- package/lib/cjs/components/list/list-item/list-item-head/list-item-right-elements/ListItemRightElements.styles.js +0 -57
- package/lib/cjs/components/list/list-item/list-item-head/list-item-right-elements/ListItemRightElements.styles.js.map +0 -1
- package/lib/cjs/hooks/useElementSize.js +0 -28
- package/lib/cjs/hooks/useElementSize.js.map +0 -1
- package/lib/cjs/types/comboBox.js +0 -12
- package/lib/cjs/types/comboBox.js.map +0 -1
- package/lib/cjs/utils/checkBox.js +0 -29
- package/lib/cjs/utils/checkBox.js.map +0 -1
- package/lib/esm/components/file-input/file-list/FileListItem.js +0 -28
- package/lib/esm/components/file-input/file-list/FileListItem.js.map +0 -1
- package/lib/esm/components/file-input/file-list/FileListItem.styles.js +0 -3
- package/lib/esm/components/file-input/file-list/FileListItem.styles.js.map +0 -1
- package/lib/esm/components/list/list-item/list-item-head/list-item-image/ListItemImage.styles.js +0 -54
- package/lib/esm/components/list/list-item/list-item-head/list-item-image/ListItemImage.styles.js.map +0 -1
- package/lib/esm/components/list/list-item/list-item-head/list-item-right-elements/ListItemRightElements.js +0 -51
- package/lib/esm/components/list/list-item/list-item-head/list-item-right-elements/ListItemRightElements.js.map +0 -1
- package/lib/esm/components/list/list-item/list-item-head/list-item-right-elements/ListItemRightElements.styles.js +0 -56
- package/lib/esm/components/list/list-item/list-item-head/list-item-right-elements/ListItemRightElements.styles.js.map +0 -1
- package/lib/esm/hooks/useElementSize.js +0 -20
- package/lib/esm/hooks/useElementSize.js.map +0 -1
- package/lib/esm/types/comboBox.js +0 -6
- package/lib/esm/types/comboBox.js.map +0 -1
- package/lib/esm/utils/checkBox.js +0 -22
- package/lib/esm/utils/checkBox.js.map +0 -1
- package/lib/types/components/file-input/file-list/FileListItem.d.ts +0 -10
- package/lib/types/components/file-input/file-list/FileListItem.styles.d.ts +0 -1
- package/lib/types/components/list/list-item/list-item-head/list-item-image/ListItemImage.styles.d.ts +0 -13
- package/lib/types/components/list/list-item/list-item-head/list-item-right-elements/ListItemRightElements.styles.d.ts +0 -14
- package/lib/types/hooks/useElementSize.d.ts +0 -6
- package/lib/types/types/comboBox.d.ts +0 -4
- package/lib/types/utils/checkBox.d.ts +0 -1
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { AnimatePresence } from 'motion/react';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import Icon from '../../icon/Icon';
|
|
4
|
+
import { StyledActionButton, StyledActionContent, StyledIconSlot, StyledLabelWrapper, StyledSecondaryLabel } from './ActionButton.styles';
|
|
5
|
+
import { useTheme } from 'styled-components';
|
|
6
|
+
const LABEL_GAP = 6;
|
|
7
|
+
const LABEL_TRANSITION = {
|
|
8
|
+
duration: 0.3
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* Shared action button UI used by both primary and secondary actions.
|
|
12
|
+
* Keeps layout and animations consistent while isolating styling details.
|
|
13
|
+
*/
|
|
14
|
+
const ActionButton = ({
|
|
15
|
+
action,
|
|
16
|
+
actionType,
|
|
17
|
+
backgroundColor,
|
|
18
|
+
isCollapsed,
|
|
19
|
+
isDisabled,
|
|
20
|
+
isExpanded,
|
|
21
|
+
isHidden,
|
|
22
|
+
isShrunk,
|
|
23
|
+
isSolo,
|
|
24
|
+
onClick,
|
|
25
|
+
onMouseEnter,
|
|
26
|
+
onMouseLeave,
|
|
27
|
+
showLabel,
|
|
28
|
+
shouldUseContentWidth,
|
|
29
|
+
height
|
|
30
|
+
}) => {
|
|
31
|
+
const theme = useTheme();
|
|
32
|
+
const isPrimary = actionType === 'primary';
|
|
33
|
+
const isSecondary = actionType === 'secondary';
|
|
34
|
+
const actionColor = action.color ?? theme.text;
|
|
35
|
+
return /*#__PURE__*/React.createElement(StyledActionButton, {
|
|
36
|
+
disabled: isDisabled || action.isDisabled,
|
|
37
|
+
$backgroundColor: backgroundColor,
|
|
38
|
+
$isCollapsed: isCollapsed,
|
|
39
|
+
$isExpanded: isSecondary ? isExpanded : undefined,
|
|
40
|
+
$isHidden: isSecondary ? isHidden : undefined,
|
|
41
|
+
$isPrimary: isPrimary,
|
|
42
|
+
$isSecondary: isSecondary,
|
|
43
|
+
$isShrunk: isPrimary ? isShrunk : undefined,
|
|
44
|
+
$isSolo: isPrimary ? isSolo : undefined,
|
|
45
|
+
$pulseColors: action.status?.pulseColors,
|
|
46
|
+
$height: height,
|
|
47
|
+
$statusType: action.status?.type,
|
|
48
|
+
$shouldUseContentWidth: shouldUseContentWidth,
|
|
49
|
+
onClick: onClick,
|
|
50
|
+
onMouseEnter: onMouseEnter,
|
|
51
|
+
onMouseLeave: onMouseLeave,
|
|
52
|
+
type: "button"
|
|
53
|
+
}, /*#__PURE__*/React.createElement(StyledActionContent, null, /*#__PURE__*/React.createElement(StyledIconSlot, {
|
|
54
|
+
$height: height
|
|
55
|
+
}, typeof action.icon === 'string' ? /*#__PURE__*/React.createElement(Icon, {
|
|
56
|
+
icons: [action.icon],
|
|
57
|
+
color: actionColor,
|
|
58
|
+
size: 18
|
|
59
|
+
}) : action.icon), /*#__PURE__*/React.createElement(AnimatePresence, {
|
|
60
|
+
initial: false
|
|
61
|
+
}, showLabel && /*#__PURE__*/React.createElement(StyledLabelWrapper, {
|
|
62
|
+
animate: {
|
|
63
|
+
opacity: 1,
|
|
64
|
+
width: 'auto',
|
|
65
|
+
marginLeft: LABEL_GAP
|
|
66
|
+
},
|
|
67
|
+
exit: {
|
|
68
|
+
opacity: 0,
|
|
69
|
+
width: 0,
|
|
70
|
+
marginLeft: 0
|
|
71
|
+
},
|
|
72
|
+
initial: {
|
|
73
|
+
opacity: 0,
|
|
74
|
+
width: 0,
|
|
75
|
+
marginLeft: 0
|
|
76
|
+
},
|
|
77
|
+
transition: LABEL_TRANSITION
|
|
78
|
+
}, /*#__PURE__*/React.createElement(StyledSecondaryLabel, {
|
|
79
|
+
style: {
|
|
80
|
+
color: actionColor
|
|
81
|
+
}
|
|
82
|
+
}, action.label)))));
|
|
83
|
+
};
|
|
84
|
+
ActionButton.displayName = 'ActionButton';
|
|
85
|
+
export default ActionButton;
|
|
86
|
+
//# sourceMappingURL=ActionButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActionButton.js","names":["AnimatePresence","React","Icon","StyledActionButton","StyledActionContent","StyledIconSlot","StyledLabelWrapper","StyledSecondaryLabel","useTheme","LABEL_GAP","LABEL_TRANSITION","duration","ActionButton","action","actionType","backgroundColor","isCollapsed","isDisabled","isExpanded","isHidden","isShrunk","isSolo","onClick","onMouseEnter","onMouseLeave","showLabel","shouldUseContentWidth","height","theme","isPrimary","isSecondary","actionColor","color","text","createElement","disabled","$backgroundColor","$isCollapsed","$isExpanded","undefined","$isHidden","$isPrimary","$isSecondary","$isShrunk","$isSolo","$pulseColors","status","pulseColors","$height","$statusType","type","$shouldUseContentWidth","icon","icons","size","initial","animate","opacity","width","marginLeft","exit","transition","style","label","displayName"],"sources":["../../../../../src/components/multi-action-button/action-button/ActionButton.tsx"],"sourcesContent":["import { AnimatePresence } from 'motion/react';\nimport React, { FC, MouseEvent } from 'react';\nimport Icon from '../../icon/Icon';\nimport {\n StyledActionButton,\n StyledActionContent,\n StyledIconSlot,\n StyledLabelWrapper,\n StyledSecondaryLabel,\n} from './ActionButton.styles';\nimport type { MultiActionButtonAction } from '../MultiActionButton.types';\nimport { useTheme } from 'styled-components';\nimport type { Theme } from '../../color-scheme-provider/ColorSchemeProvider';\n\nconst LABEL_GAP = 6;\nconst LABEL_TRANSITION = { duration: 0.3 };\n\nexport type ActionButtonProps = {\n action: MultiActionButtonAction;\n actionType: 'primary' | 'secondary';\n backgroundColor?: string;\n isCollapsed: boolean;\n isDisabled: boolean;\n isExpanded?: boolean;\n isHidden?: boolean;\n isShrunk?: boolean;\n isSolo?: boolean;\n onClick?: (event: MouseEvent<HTMLButtonElement>) => void;\n onMouseEnter?: () => void;\n onMouseLeave?: () => void;\n showLabel: boolean;\n shouldUseContentWidth: boolean;\n height: number;\n};\n\n/**\n * Shared action button UI used by both primary and secondary actions.\n * Keeps layout and animations consistent while isolating styling details.\n */\nconst ActionButton: FC<ActionButtonProps> = ({\n action,\n actionType,\n backgroundColor,\n isCollapsed,\n isDisabled,\n isExpanded,\n isHidden,\n isShrunk,\n isSolo,\n onClick,\n onMouseEnter,\n onMouseLeave,\n showLabel,\n shouldUseContentWidth,\n height,\n}) => {\n const theme = useTheme() as Theme;\n\n const isPrimary = actionType === 'primary';\n const isSecondary = actionType === 'secondary';\n const actionColor = action.color ?? theme.text;\n\n return (\n <StyledActionButton\n disabled={isDisabled || action.isDisabled}\n $backgroundColor={backgroundColor}\n $isCollapsed={isCollapsed}\n $isExpanded={isSecondary ? isExpanded : undefined}\n $isHidden={isSecondary ? isHidden : undefined}\n $isPrimary={isPrimary}\n $isSecondary={isSecondary}\n $isShrunk={isPrimary ? isShrunk : undefined}\n $isSolo={isPrimary ? isSolo : undefined}\n $pulseColors={action.status?.pulseColors}\n $height={height}\n $statusType={action.status?.type}\n $shouldUseContentWidth={shouldUseContentWidth}\n onClick={onClick}\n onMouseEnter={onMouseEnter}\n onMouseLeave={onMouseLeave}\n type=\"button\"\n >\n <StyledActionContent>\n <StyledIconSlot $height={height}>\n {typeof action.icon === 'string' ? (\n <Icon icons={[action.icon]} color={actionColor} size={18} />\n ) : (\n action.icon\n )}\n </StyledIconSlot>\n <AnimatePresence initial={false}>\n {/* Animate width and margin to avoid layout jumps when labels mount/unmount. */}\n {showLabel && (\n <StyledLabelWrapper\n animate={{ opacity: 1, width: 'auto', marginLeft: LABEL_GAP }}\n exit={{ opacity: 0, width: 0, marginLeft: 0 }}\n initial={{ opacity: 0, width: 0, marginLeft: 0 }}\n transition={LABEL_TRANSITION}\n >\n <StyledSecondaryLabel style={{ color: actionColor }}>\n {action.label}\n </StyledSecondaryLabel>\n </StyledLabelWrapper>\n )}\n </AnimatePresence>\n </StyledActionContent>\n </StyledActionButton>\n );\n};\n\nActionButton.displayName = 'ActionButton';\n\nexport default ActionButton;\n"],"mappings":"AAAA,SAASA,eAAe,QAAQ,cAAc;AAC9C,OAAOC,KAAK,MAA0B,OAAO;AAC7C,OAAOC,IAAI,MAAM,iBAAiB;AAClC,SACIC,kBAAkB,EAClBC,mBAAmB,EACnBC,cAAc,EACdC,kBAAkB,EAClBC,oBAAoB,QACjB,uBAAuB;AAE9B,SAASC,QAAQ,QAAQ,mBAAmB;AAG5C,MAAMC,SAAS,GAAG,CAAC;AACnB,MAAMC,gBAAgB,GAAG;EAAEC,QAAQ,EAAE;AAAI,CAAC;AAoB1C;AACA;AACA;AACA;AACA,MAAMC,YAAmC,GAAGA,CAAC;EACzCC,MAAM;EACNC,UAAU;EACVC,eAAe;EACfC,WAAW;EACXC,UAAU;EACVC,UAAU;EACVC,QAAQ;EACRC,QAAQ;EACRC,MAAM;EACNC,OAAO;EACPC,YAAY;EACZC,YAAY;EACZC,SAAS;EACTC,qBAAqB;EACrBC;AACJ,CAAC,KAAK;EACF,MAAMC,KAAK,GAAGpB,QAAQ,CAAC,CAAU;EAEjC,MAAMqB,SAAS,GAAGf,UAAU,KAAK,SAAS;EAC1C,MAAMgB,WAAW,GAAGhB,UAAU,KAAK,WAAW;EAC9C,MAAMiB,WAAW,GAAGlB,MAAM,CAACmB,KAAK,IAAIJ,KAAK,CAACK,IAAI;EAE9C,oBACIhC,KAAA,CAAAiC,aAAA,CAAC/B,kBAAkB;IACfgC,QAAQ,EAAElB,UAAU,IAAIJ,MAAM,CAACI,UAAW;IAC1CmB,gBAAgB,EAAErB,eAAgB;IAClCsB,YAAY,EAAErB,WAAY;IAC1BsB,WAAW,EAAER,WAAW,GAAGZ,UAAU,GAAGqB,SAAU;IAClDC,SAAS,EAAEV,WAAW,GAAGX,QAAQ,GAAGoB,SAAU;IAC9CE,UAAU,EAAEZ,SAAU;IACtBa,YAAY,EAAEZ,WAAY;IAC1Ba,SAAS,EAAEd,SAAS,GAAGT,QAAQ,GAAGmB,SAAU;IAC5CK,OAAO,EAAEf,SAAS,GAAGR,MAAM,GAAGkB,SAAU;IACxCM,YAAY,EAAEhC,MAAM,CAACiC,MAAM,EAAEC,WAAY;IACzCC,OAAO,EAAErB,MAAO;IAChBsB,WAAW,EAAEpC,MAAM,CAACiC,MAAM,EAAEI,IAAK;IACjCC,sBAAsB,EAAEzB,qBAAsB;IAC9CJ,OAAO,EAAEA,OAAQ;IACjBC,YAAY,EAAEA,YAAa;IAC3BC,YAAY,EAAEA,YAAa;IAC3B0B,IAAI,EAAC;EAAQ,gBAEbjD,KAAA,CAAAiC,aAAA,CAAC9B,mBAAmB,qBAChBH,KAAA,CAAAiC,aAAA,CAAC7B,cAAc;IAAC2C,OAAO,EAAErB;EAAO,GAC3B,OAAOd,MAAM,CAACuC,IAAI,KAAK,QAAQ,gBAC5BnD,KAAA,CAAAiC,aAAA,CAAChC,IAAI;IAACmD,KAAK,EAAE,CAACxC,MAAM,CAACuC,IAAI,CAAE;IAACpB,KAAK,EAAED,WAAY;IAACuB,IAAI,EAAE;EAAG,CAAE,CAAC,GAE5DzC,MAAM,CAACuC,IAEC,CAAC,eACjBnD,KAAA,CAAAiC,aAAA,CAAClC,eAAe;IAACuD,OAAO,EAAE;EAAM,GAE3B9B,SAAS,iBACNxB,KAAA,CAAAiC,aAAA,CAAC5B,kBAAkB;IACfkD,OAAO,EAAE;MAAEC,OAAO,EAAE,CAAC;MAAEC,KAAK,EAAE,MAAM;MAAEC,UAAU,EAAElD;IAAU,CAAE;IAC9DmD,IAAI,EAAE;MAAEH,OAAO,EAAE,CAAC;MAAEC,KAAK,EAAE,CAAC;MAAEC,UAAU,EAAE;IAAE,CAAE;IAC9CJ,OAAO,EAAE;MAAEE,OAAO,EAAE,CAAC;MAAEC,KAAK,EAAE,CAAC;MAAEC,UAAU,EAAE;IAAE,CAAE;IACjDE,UAAU,EAAEnD;EAAiB,gBAE7BT,KAAA,CAAAiC,aAAA,CAAC3B,oBAAoB;IAACuD,KAAK,EAAE;MAAE9B,KAAK,EAAED;IAAY;EAAE,GAC/ClB,MAAM,CAACkD,KACU,CACN,CAEX,CACA,CACL,CAAC;AAE7B,CAAC;AAEDnD,YAAY,CAACoD,WAAW,GAAG,cAAc;AAEzC,eAAepD,YAAY","ignoreList":[]}
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
import { motion } from 'motion/react';
|
|
2
|
+
import styled, { css, keyframes } from 'styled-components';
|
|
3
|
+
import { MultiActionButtonStatusType } from '../MultiActionButton.types';
|
|
4
|
+
const pulse = (color1, color2) => keyframes`
|
|
5
|
+
0% {
|
|
6
|
+
background: ${color1};
|
|
7
|
+
}
|
|
8
|
+
50% {
|
|
9
|
+
background: ${color2};
|
|
10
|
+
}
|
|
11
|
+
100% {
|
|
12
|
+
background: ${color1};
|
|
13
|
+
}
|
|
14
|
+
`;
|
|
15
|
+
export const StyledActionButton = styled.button`
|
|
16
|
+
align-items: center;
|
|
17
|
+
border: none;
|
|
18
|
+
border-radius: ${({
|
|
19
|
+
$height
|
|
20
|
+
}) => $height / 2}px;
|
|
21
|
+
cursor: pointer;
|
|
22
|
+
display: inline-flex;
|
|
23
|
+
flex: 1 1 auto;
|
|
24
|
+
height: ${({
|
|
25
|
+
$height
|
|
26
|
+
}) => $height}px;
|
|
27
|
+
line-height: 22px;
|
|
28
|
+
min-height: ${({
|
|
29
|
+
$height
|
|
30
|
+
}) => $height}px;
|
|
31
|
+
overflow: hidden;
|
|
32
|
+
padding: 0;
|
|
33
|
+
position: relative;
|
|
34
|
+
transition:
|
|
35
|
+
background-color 0.2s ease,
|
|
36
|
+
border-radius 0.2s ease,
|
|
37
|
+
color 0.2s ease,
|
|
38
|
+
flex-grow 0.2s ease,
|
|
39
|
+
margin-left 0.2s ease,
|
|
40
|
+
opacity 0.2s ease,
|
|
41
|
+
padding 0.2s ease,
|
|
42
|
+
width 0.2s ease;
|
|
43
|
+
user-select: none;
|
|
44
|
+
white-space: nowrap;
|
|
45
|
+
|
|
46
|
+
background-color: ${({
|
|
47
|
+
$backgroundColor,
|
|
48
|
+
theme
|
|
49
|
+
}) => $backgroundColor || theme?.primary || '#000'};
|
|
50
|
+
color: #fff;
|
|
51
|
+
|
|
52
|
+
/* When width is content-driven, avoid flex stretching. */
|
|
53
|
+
${({
|
|
54
|
+
$shouldUseContentWidth
|
|
55
|
+
}) => $shouldUseContentWidth && css`
|
|
56
|
+
flex: 0 1 auto;
|
|
57
|
+
`}
|
|
58
|
+
|
|
59
|
+
/* Expanded secondary button when width is not content-driven. */
|
|
60
|
+
${({
|
|
61
|
+
$isExpanded,
|
|
62
|
+
$shouldUseContentWidth
|
|
63
|
+
}) => $isExpanded && !$shouldUseContentWidth && css`
|
|
64
|
+
flex: 1 1 auto;
|
|
65
|
+
min-width: 0;
|
|
66
|
+
`}
|
|
67
|
+
|
|
68
|
+
/* Collapsed state clamps to a fixed icon size. */
|
|
69
|
+
${props => props.$isCollapsed && css`
|
|
70
|
+
flex: 0 0 auto;
|
|
71
|
+
padding: 0;
|
|
72
|
+
width: ${props.$height}px;
|
|
73
|
+
`}
|
|
74
|
+
|
|
75
|
+
/* Primary action stretches unless content-driven. */
|
|
76
|
+
${({
|
|
77
|
+
$isPrimary,
|
|
78
|
+
$isCollapsed,
|
|
79
|
+
$shouldUseContentWidth
|
|
80
|
+
}) => $isPrimary && !$isCollapsed && !$shouldUseContentWidth && css`
|
|
81
|
+
flex: 1 1 auto;
|
|
82
|
+
min-width: 0;
|
|
83
|
+
`}
|
|
84
|
+
|
|
85
|
+
/* Shrink the primary action to icon size when secondary is expanded. */
|
|
86
|
+
${props => props.$isShrunk && !props.$shouldUseContentWidth && css`
|
|
87
|
+
flex: 0 0 auto;
|
|
88
|
+
padding: 0;
|
|
89
|
+
width: ${props.$height}px;
|
|
90
|
+
`}
|
|
91
|
+
|
|
92
|
+
/* Keep secondary icon-only when collapsed and not expanded. */
|
|
93
|
+
${props => props.$isSecondary && !props.$isExpanded && !props.$shouldUseContentWidth && css`
|
|
94
|
+
flex: 0 0 auto;
|
|
95
|
+
padding: 0;
|
|
96
|
+
width: ${props.$height}px;
|
|
97
|
+
`}
|
|
98
|
+
|
|
99
|
+
${({
|
|
100
|
+
$isSecondary
|
|
101
|
+
}) => $isSecondary && css`
|
|
102
|
+
margin-left: 2px;
|
|
103
|
+
`}
|
|
104
|
+
|
|
105
|
+
/* Fully hide the secondary action when the whole control is collapsed. */
|
|
106
|
+
${({
|
|
107
|
+
$isHidden
|
|
108
|
+
}) => $isHidden && css`
|
|
109
|
+
margin-left: 0;
|
|
110
|
+
opacity: 0;
|
|
111
|
+
pointer-events: none;
|
|
112
|
+
width: 0;
|
|
113
|
+
`}
|
|
114
|
+
|
|
115
|
+
/* Joining both buttons into a pill shape. */
|
|
116
|
+
${({
|
|
117
|
+
$isPrimary
|
|
118
|
+
}) => $isPrimary && css`
|
|
119
|
+
border-bottom-right-radius: 0;
|
|
120
|
+
border-top-right-radius: 0;
|
|
121
|
+
`}
|
|
122
|
+
|
|
123
|
+
${props => props.$isPrimary && props.$isCollapsed && css`
|
|
124
|
+
border-bottom-right-radius: ${props.$height / 2}px;
|
|
125
|
+
border-top-right-radius: ${props.$height / 2}px;
|
|
126
|
+
`}
|
|
127
|
+
|
|
128
|
+
${({
|
|
129
|
+
$isSecondary
|
|
130
|
+
}) => $isSecondary && css`
|
|
131
|
+
border-bottom-left-radius: 0;
|
|
132
|
+
border-top-left-radius: 0;
|
|
133
|
+
`}
|
|
134
|
+
|
|
135
|
+
${props => props.$isSolo && css`
|
|
136
|
+
border-radius: ${props.$height / 2}px;
|
|
137
|
+
`}
|
|
138
|
+
|
|
139
|
+
${props => props.$isCollapsed && css`
|
|
140
|
+
border-radius: ${props.$height / 2}px;
|
|
141
|
+
`}
|
|
142
|
+
|
|
143
|
+
/* Optional pulse overlay used by status. */
|
|
144
|
+
${({
|
|
145
|
+
$statusType,
|
|
146
|
+
$pulseColors
|
|
147
|
+
}) => $statusType === MultiActionButtonStatusType.Pulse && css`
|
|
148
|
+
overflow: hidden;
|
|
149
|
+
|
|
150
|
+
&::before {
|
|
151
|
+
animation: ${pulse($pulseColors?.[0] || '#A50000', $pulseColors?.[1] || '#630000')}
|
|
152
|
+
1.6s ease-in-out infinite;
|
|
153
|
+
border-radius: 3px;
|
|
154
|
+
content: '';
|
|
155
|
+
inset: 0;
|
|
156
|
+
pointer-events: none;
|
|
157
|
+
position: absolute;
|
|
158
|
+
}
|
|
159
|
+
`}
|
|
160
|
+
|
|
161
|
+
&:disabled {
|
|
162
|
+
cursor: default;
|
|
163
|
+
opacity: 0.5;
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
&:hover:not(:disabled) {
|
|
167
|
+
background-color: ${({
|
|
168
|
+
$backgroundColor,
|
|
169
|
+
theme
|
|
170
|
+
}) => `color-mix(in srgb, ${$backgroundColor || theme?.primary || '#000'} 85%, black)`};
|
|
171
|
+
}
|
|
172
|
+
`;
|
|
173
|
+
export const StyledActionContent = styled.span`
|
|
174
|
+
align-items: center;
|
|
175
|
+
display: inline-flex;
|
|
176
|
+
flex: 1 1 auto;
|
|
177
|
+
gap: 0;
|
|
178
|
+
min-width: 0;
|
|
179
|
+
position: relative;
|
|
180
|
+
z-index: 1;
|
|
181
|
+
`;
|
|
182
|
+
export const StyledIconSlot = styled.span`
|
|
183
|
+
align-items: center;
|
|
184
|
+
display: inline-flex;
|
|
185
|
+
flex: 0 0 auto;
|
|
186
|
+
height: ${({
|
|
187
|
+
$height
|
|
188
|
+
}) => $height}px;
|
|
189
|
+
justify-content: center;
|
|
190
|
+
width: ${({
|
|
191
|
+
$height
|
|
192
|
+
}) => $height}px;
|
|
193
|
+
`;
|
|
194
|
+
export const StyledLabelWrapper = styled(motion.span)`
|
|
195
|
+
/* The wrapper animates width/margin to avoid layout jumps. */
|
|
196
|
+
display: inline-flex;
|
|
197
|
+
flex: 1 1 auto;
|
|
198
|
+
min-width: 0;
|
|
199
|
+
overflow: hidden;
|
|
200
|
+
text-align: left;
|
|
201
|
+
`;
|
|
202
|
+
export const StyledSecondaryLabel = styled.span`
|
|
203
|
+
display: block;
|
|
204
|
+
flex: 1 1 auto;
|
|
205
|
+
min-width: 0;
|
|
206
|
+
max-width: 100%;
|
|
207
|
+
overflow: hidden;
|
|
208
|
+
padding-right: 18px;
|
|
209
|
+
text-overflow: ellipsis;
|
|
210
|
+
white-space: nowrap;
|
|
211
|
+
`;
|
|
212
|
+
//# sourceMappingURL=ActionButton.styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActionButton.styles.js","names":["motion","styled","css","keyframes","MultiActionButtonStatusType","pulse","color1","color2","StyledActionButton","button","$height","$backgroundColor","theme","primary","$shouldUseContentWidth","$isExpanded","props","$isCollapsed","$isPrimary","$isShrunk","$isSecondary","$isHidden","$isSolo","$statusType","$pulseColors","Pulse","StyledActionContent","span","StyledIconSlot","StyledLabelWrapper","StyledSecondaryLabel"],"sources":["../../../../../src/components/multi-action-button/action-button/ActionButton.styles.ts"],"sourcesContent":["import { motion } from 'motion/react';\nimport styled, { css, keyframes } from 'styled-components';\nimport type { WithTheme } from '../../color-scheme-provider/ColorSchemeProvider';\nimport { MultiActionButtonStatusType } from '../MultiActionButton.types';\n\ntype StyledActionButtonProps = WithTheme<{\n $backgroundColor?: string;\n $isCollapsed?: boolean;\n $isExpanded?: boolean;\n $isHidden?: boolean;\n $isPrimary?: boolean;\n $isSecondary?: boolean;\n $isShrunk?: boolean;\n $isSolo?: boolean;\n $pulseColors?: [string, string];\n $height: number;\n $statusType?: MultiActionButtonStatusType;\n $shouldUseContentWidth?: boolean;\n}>;\n\nconst pulse = (color1: string, color2: string) => keyframes`\n 0% {\n background: ${color1};\n }\n 50% {\n background: ${color2};\n }\n 100% {\n background: ${color1};\n }\n`;\n\nexport const StyledActionButton = styled.button<StyledActionButtonProps>`\n align-items: center;\n border: none;\n border-radius: ${({ $height }) => $height / 2}px;\n cursor: pointer;\n display: inline-flex;\n flex: 1 1 auto;\n height: ${({ $height }) => $height}px;\n line-height: 22px;\n min-height: ${({ $height }) => $height}px;\n overflow: hidden;\n padding: 0;\n position: relative;\n transition:\n background-color 0.2s ease,\n border-radius 0.2s ease,\n color 0.2s ease,\n flex-grow 0.2s ease,\n margin-left 0.2s ease,\n opacity 0.2s ease,\n padding 0.2s ease,\n width 0.2s ease;\n user-select: none;\n white-space: nowrap;\n\n background-color: ${({ $backgroundColor, theme }) =>\n $backgroundColor || theme?.primary || '#000'};\n color: #fff;\n\n /* When width is content-driven, avoid flex stretching. */\n ${({ $shouldUseContentWidth }) =>\n $shouldUseContentWidth &&\n css`\n flex: 0 1 auto;\n `}\n\n /* Expanded secondary button when width is not content-driven. */\n ${({ $isExpanded, $shouldUseContentWidth }) =>\n $isExpanded &&\n !$shouldUseContentWidth &&\n css`\n flex: 1 1 auto;\n min-width: 0;\n `}\n\n /* Collapsed state clamps to a fixed icon size. */\n ${(props) =>\n props.$isCollapsed &&\n css`\n flex: 0 0 auto;\n padding: 0;\n width: ${props.$height}px;\n `}\n\n /* Primary action stretches unless content-driven. */\n ${({ $isPrimary, $isCollapsed, $shouldUseContentWidth }) =>\n $isPrimary &&\n !$isCollapsed &&\n !$shouldUseContentWidth &&\n css`\n flex: 1 1 auto;\n min-width: 0;\n `}\n\n /* Shrink the primary action to icon size when secondary is expanded. */\n ${(props) =>\n props.$isShrunk &&\n !props.$shouldUseContentWidth &&\n css`\n flex: 0 0 auto;\n padding: 0;\n width: ${props.$height}px;\n `}\n\n /* Keep secondary icon-only when collapsed and not expanded. */\n ${(props) =>\n props.$isSecondary &&\n !props.$isExpanded &&\n !props.$shouldUseContentWidth &&\n css`\n flex: 0 0 auto;\n padding: 0;\n width: ${props.$height}px;\n `}\n\n ${({ $isSecondary }) =>\n $isSecondary &&\n css`\n margin-left: 2px;\n `}\n\n /* Fully hide the secondary action when the whole control is collapsed. */\n ${({ $isHidden }) =>\n $isHidden &&\n css`\n margin-left: 0;\n opacity: 0;\n pointer-events: none;\n width: 0;\n `}\n\n /* Joining both buttons into a pill shape. */\n ${({ $isPrimary }) =>\n $isPrimary &&\n css`\n border-bottom-right-radius: 0;\n border-top-right-radius: 0;\n `}\n\n ${(props) =>\n props.$isPrimary &&\n props.$isCollapsed &&\n css`\n border-bottom-right-radius: ${props.$height / 2}px;\n border-top-right-radius: ${props.$height / 2}px;\n `}\n\n ${({ $isSecondary }) =>\n $isSecondary &&\n css`\n border-bottom-left-radius: 0;\n border-top-left-radius: 0;\n `}\n\n ${(props) =>\n props.$isSolo &&\n css`\n border-radius: ${props.$height / 2}px;\n `}\n\n ${(props) =>\n props.$isCollapsed &&\n css`\n border-radius: ${props.$height / 2}px;\n `}\n\n /* Optional pulse overlay used by status. */\n ${({ $statusType, $pulseColors }) =>\n $statusType === MultiActionButtonStatusType.Pulse &&\n css`\n overflow: hidden;\n\n &::before {\n animation: ${pulse($pulseColors?.[0] || '#A50000', $pulseColors?.[1] || '#630000')}\n 1.6s ease-in-out infinite;\n border-radius: 3px;\n content: '';\n inset: 0;\n pointer-events: none;\n position: absolute;\n }\n `}\n\n &:disabled {\n cursor: default;\n opacity: 0.5;\n }\n\n &:hover:not(:disabled) {\n background-color: ${({ $backgroundColor, theme }) =>\n `color-mix(in srgb, ${$backgroundColor || theme?.primary || '#000'} 85%, black)`};\n }\n`;\n\nexport const StyledActionContent = styled.span`\n align-items: center;\n display: inline-flex;\n flex: 1 1 auto;\n gap: 0;\n min-width: 0;\n position: relative;\n z-index: 1;\n`;\n\nexport const StyledIconSlot = styled.span<{ $height: number }>`\n align-items: center;\n display: inline-flex;\n flex: 0 0 auto;\n height: ${({ $height }) => $height}px;\n justify-content: center;\n width: ${({ $height }) => $height}px;\n`;\n\nexport const StyledLabelWrapper = styled(motion.span)`\n /* The wrapper animates width/margin to avoid layout jumps. */\n display: inline-flex;\n flex: 1 1 auto;\n min-width: 0;\n overflow: hidden;\n text-align: left;\n`;\n\nexport const StyledSecondaryLabel = styled.span`\n display: block;\n flex: 1 1 auto;\n min-width: 0;\n max-width: 100%;\n overflow: hidden;\n padding-right: 18px;\n text-overflow: ellipsis;\n white-space: nowrap;\n`;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
import React, { useEffect, useState } from 'react';
|
|
1
|
+
import React, { useEffect, useRef, useState } from 'react';
|
|
2
2
|
import { NUMBER_CLEAR_REGEX } from '../../constants/numberInput';
|
|
3
3
|
import { formateNumber, isValidString, parseFloatWithDecimals } from '../../utils/numberInput';
|
|
4
4
|
import Input from '../input/Input';
|
|
5
|
-
const NumberInput =
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
5
|
+
const NumberInput = ({
|
|
6
|
+
isDecimalInput,
|
|
7
|
+
isMoneyInput,
|
|
8
|
+
isTimeInput,
|
|
9
|
+
isInvalid,
|
|
10
|
+
maxNumber = Infinity,
|
|
11
|
+
value,
|
|
12
|
+
shouldTriggerChangeOnFormat = true,
|
|
13
|
+
placeholder,
|
|
14
|
+
onBlur,
|
|
15
|
+
isDisabled,
|
|
16
|
+
onChange,
|
|
17
|
+
shouldShowOnlyBottomBorder,
|
|
18
|
+
minNumber = -Infinity
|
|
19
|
+
}) => {
|
|
20
20
|
// the plainText will be shown in the input, when it is in focus
|
|
21
21
|
const [plainText, setPlainText] = useState('');
|
|
22
22
|
// the formattedValue will be shown in the input, when it is not in focus
|
|
@@ -25,8 +25,10 @@ const NumberInput = _ref => {
|
|
|
25
25
|
const [shouldRemainPlaceholder, setShouldRemainPlaceholder] = useState(false);
|
|
26
26
|
const [isValueInvalid, setIsValueInvalid] = useState(false);
|
|
27
27
|
const localPlaceholder = placeholder ?? (isMoneyInput ? '€' : undefined);
|
|
28
|
+
const initialInputRef = useRef(true);
|
|
28
29
|
const onLocalChange = event => {
|
|
29
30
|
const newValue = event.target.value;
|
|
31
|
+
initialInputRef.current = false;
|
|
30
32
|
const sanitizedValueString = newValue
|
|
31
33
|
// Removes everything except numbers, commas and points
|
|
32
34
|
.replace(NUMBER_CLEAR_REGEX, '');
|
|
@@ -56,7 +58,7 @@ const NumberInput = _ref => {
|
|
|
56
58
|
}
|
|
57
59
|
};
|
|
58
60
|
const onLocalBlur = () => {
|
|
59
|
-
const sanitizedValue = plainText
|
|
61
|
+
const sanitizedValue = plainText;
|
|
60
62
|
let newIsInvalid = false;
|
|
61
63
|
let parsedNumber = null;
|
|
62
64
|
if (!isTimeInput) {
|
|
@@ -64,7 +66,7 @@ const NumberInput = _ref => {
|
|
|
64
66
|
stringValue: sanitizedValue.replace(',', '.').replaceAll(':', '').replace('€', ''),
|
|
65
67
|
decimals: isMoneyInput ? 2 : undefined
|
|
66
68
|
});
|
|
67
|
-
if (parsedNumber !== 0 && (parsedNumber > maxNumber || parsedNumber < minNumber)) {
|
|
69
|
+
if (parsedNumber && parsedNumber !== 0 && (parsedNumber > maxNumber || parsedNumber < minNumber)) {
|
|
68
70
|
newIsInvalid = true;
|
|
69
71
|
}
|
|
70
72
|
setIsValueInvalid(newIsInvalid);
|
|
@@ -77,14 +79,14 @@ const NumberInput = _ref => {
|
|
|
77
79
|
setFormattedValue(`${newStringValue} ${isMoneyInput ? '€' : ''}`);
|
|
78
80
|
setPlainText(newStringValue.replaceAll('.', ''));
|
|
79
81
|
setHasFocus(false);
|
|
80
|
-
if (typeof onChange === 'function') {
|
|
82
|
+
if (typeof onChange === 'function' && shouldTriggerChangeOnFormat) {
|
|
81
83
|
onChange(newStringValue.replaceAll('.', ''));
|
|
82
84
|
}
|
|
83
85
|
if (typeof onBlur === 'function') {
|
|
84
86
|
if (isTimeInput) {
|
|
85
87
|
onBlur(newStringValue, newIsInvalid);
|
|
86
88
|
} else {
|
|
87
|
-
onBlur(parsedNumber
|
|
89
|
+
onBlur(parsedNumber, newIsInvalid);
|
|
88
90
|
}
|
|
89
91
|
}
|
|
90
92
|
};
|
|
@@ -94,7 +96,7 @@ const NumberInput = _ref => {
|
|
|
94
96
|
setPlainText(formattedValue.replaceAll('.', '').replace('€', '').replaceAll(' ', ''));
|
|
95
97
|
|
|
96
98
|
// This will update the external state
|
|
97
|
-
if (typeof onChange === 'function') {
|
|
99
|
+
if (typeof onChange === 'function' && shouldTriggerChangeOnFormat) {
|
|
98
100
|
onChange(formattedValue.replaceAll('.', '').replace('€', '').replaceAll(' ', ''));
|
|
99
101
|
}
|
|
100
102
|
setIsValueInvalid(false);
|
|
@@ -112,7 +114,11 @@ const NumberInput = _ref => {
|
|
|
112
114
|
|
|
113
115
|
// checks, if a given number is invalid, if the input is not in focus
|
|
114
116
|
if (!hasFocus) {
|
|
115
|
-
|
|
117
|
+
if (parsedNumber === null && initialInputRef.current) {
|
|
118
|
+
setIsValueInvalid(false);
|
|
119
|
+
} else {
|
|
120
|
+
setIsValueInvalid(parsedNumber === null || parsedNumber > maxNumber || parsedNumber < minNumber);
|
|
121
|
+
}
|
|
116
122
|
}
|
|
117
123
|
}
|
|
118
124
|
setFormattedValue(plainText.length === 0 ? '' : `${formateNumber({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NumberInput.js","names":["React","useEffect","useState","NUMBER_CLEAR_REGEX","formateNumber","isValidString","parseFloatWithDecimals","Input","NumberInput","_ref","isDecimalInput","isMoneyInput","isTimeInput","isInvalid","maxNumber","Infinity","value","placeholder","onBlur","isDisabled","onChange","shouldShowOnlyBottomBorder","minNumber","plainText","setPlainText","formattedValue","setFormattedValue","hasFocus","setHasFocus","shouldRemainPlaceholder","setShouldRemainPlaceholder","isValueInvalid","setIsValueInvalid","localPlaceholder","undefined","onLocalChange","event","newValue","target","sanitizedValueString","replace","includes","length","valueToCheck","replaceAll","string","Number","match","onLocalBlur","sanitizedValue","newIsInvalid","parsedNumber","stringValue","decimals","newStringValue","number","onLocalFocus","createElement","inputMode","onFocus","shouldShowCenteredContent","displayName"],"sources":["../../../../src/components/number-input/NumberInput.tsx"],"sourcesContent":["import React, { ChangeEventHandler, FC, useEffect, useState } from 'react';\nimport { NUMBER_CLEAR_REGEX } from '../../constants/numberInput';\nimport { formateNumber, isValidString, parseFloatWithDecimals } from '../../utils/numberInput';\nimport Input from '../input/Input';\n\nexport type NumberInputProps = {\n /**\n * Applies rules for decimal input.\n * Enables the user to input one zero as number before the comma\n */\n isDecimalInput?: boolean;\n /**\n * Whether the input is disabled\n */\n isDisabled?: boolean;\n /**\n * Whether the value is invalid.\n */\n isInvalid?: boolean;\n /**\n * Applies rules for money input.\n * Rules: only two decimal places, one zero before the comma\n */\n isMoneyInput?: boolean;\n /**\n * Whether the value should be formatted as a time.\n */\n isTimeInput?: boolean;\n /**\n * Limits the number to this value\n */\n maxNumber?: number;\n /**\n * Limits the number to this value\n */\n minNumber?: number;\n /**\n * Callback function that is called when the input gets out of focus\n */\n onBlur?: (newNumber: number | string | null, isInvalid: boolean) => void;\n /**\n * Callback function that is called when the input changes\n * It will pass the text from the input\n */\n onChange?: (newValue: string) => void;\n /**\n * Placeholder for the input field\n */\n placeholder?: string;\n /**\n * Whether only the bottom border should be displayed\n */\n shouldShowOnlyBottomBorder?: boolean;\n /**\n * The value, that should be displayed in the input, when it is in focus.\n * You can also pass a stringified number as default value.\n * NOTE: If you pass a stringified number, it will be formatted to the selected format\n */\n value?: string;\n};\n\nconst NumberInput: FC<NumberInputProps> = ({\n isDecimalInput,\n isMoneyInput,\n isTimeInput,\n isInvalid,\n maxNumber = Infinity,\n value,\n placeholder,\n onBlur,\n isDisabled,\n onChange,\n shouldShowOnlyBottomBorder,\n minNumber = -Infinity,\n}) => {\n // the plainText will be shown in the input, when it is in focus\n const [plainText, setPlainText] = useState<string>('');\n // the formattedValue will be shown in the input, when it is not in focus\n const [formattedValue, setFormattedValue] = useState<string>('');\n const [hasFocus, setHasFocus] = useState<boolean>(false);\n const [shouldRemainPlaceholder, setShouldRemainPlaceholder] = useState<boolean>(false);\n\n const [isValueInvalid, setIsValueInvalid] = useState(false);\n const localPlaceholder = placeholder ?? (isMoneyInput ? '€' : undefined);\n\n const onLocalChange: ChangeEventHandler<HTMLInputElement> = (event) => {\n const newValue = event.target.value;\n\n const sanitizedValueString = newValue\n // Removes everything except numbers, commas and points\n .replace(NUMBER_CLEAR_REGEX, '');\n\n if (\n isTimeInput &&\n ((sanitizedValueString.includes(':') && sanitizedValueString.length > 5) ||\n (!sanitizedValueString.includes(':') && sanitizedValueString.length > 4))\n ) {\n return;\n }\n\n const valueToCheck = sanitizedValueString.replaceAll(',', '.');\n\n if (!isValidString({ string: valueToCheck, isMoneyInput, isDecimalInput, isTimeInput })) {\n return;\n }\n\n if (\n (maxNumber && Number(valueToCheck) > maxNumber) ||\n (minNumber && Number(valueToCheck) < minNumber)\n ) {\n return;\n }\n\n if (newValue.length === 1 && newValue.match(/^[0-9]+$/) === null) {\n setShouldRemainPlaceholder(true);\n } else {\n setShouldRemainPlaceholder(false);\n }\n\n setPlainText(sanitizedValueString.replaceAll('.', ','));\n\n if (typeof onChange === 'function') {\n onChange(sanitizedValueString.replaceAll('.', ','));\n }\n };\n\n const onLocalBlur = () => {\n const sanitizedValue = plainText.length === 0 ? '0' : plainText;\n let newIsInvalid = false;\n let parsedNumber = null;\n\n if (!isTimeInput) {\n parsedNumber = parseFloatWithDecimals({\n stringValue: sanitizedValue.replace(',', '.').replaceAll(':', '').replace('€', ''),\n decimals: isMoneyInput ? 2 : undefined,\n });\n\n if (parsedNumber !== 0 && (parsedNumber > maxNumber || parsedNumber < minNumber)) {\n newIsInvalid = true;\n }\n\n setIsValueInvalid(newIsInvalid);\n }\n\n const newStringValue =\n plainText.length === 0\n ? ''\n : formateNumber({\n number: isTimeInput ? sanitizedValue : parsedNumber,\n isMoneyInput,\n isTimeInput,\n });\n\n setFormattedValue(`${newStringValue} ${isMoneyInput ? '€' : ''}`);\n setPlainText(newStringValue.replaceAll('.', ''));\n setHasFocus(false);\n\n if (typeof onChange === 'function') {\n onChange(newStringValue.replaceAll('.', ''));\n }\n\n if (typeof onBlur === 'function') {\n if (isTimeInput) {\n onBlur(newStringValue, newIsInvalid);\n } else {\n onBlur(parsedNumber === 0 ? null : parsedNumber, newIsInvalid);\n }\n }\n };\n\n const onLocalFocus = () => {\n // formattedValue will be a number string with german number format (e.g. 1.000,00)\n // It will remove all dots, so that the user can type in the number\n setPlainText(formattedValue.replaceAll('.', '').replace('€', '').replaceAll(' ', ''));\n\n // This will update the external state\n if (typeof onChange === 'function') {\n onChange(formattedValue.replaceAll('.', '').replace('€', '').replaceAll(' ', ''));\n }\n\n setIsValueInvalid(false);\n setHasFocus(true);\n };\n\n // updates the formattedValue, when the value changes\n useEffect(() => {\n let parsedNumber = null;\n\n if (!isTimeInput) {\n parsedNumber = parseFloatWithDecimals({\n stringValue: plainText\n .replace(',', '.')\n .replaceAll(':', '')\n .replace('€', '')\n .replaceAll(' ', ''),\n decimals: isMoneyInput ? 2 : undefined,\n });\n\n // checks, if a given number is invalid, if the input is not in focus\n if (!hasFocus) {\n setIsValueInvalid(parsedNumber > maxNumber || parsedNumber < minNumber);\n }\n }\n\n setFormattedValue(\n plainText.length === 0\n ? ''\n : `${formateNumber({\n number: isTimeInput ? plainText : parsedNumber,\n isMoneyInput,\n isTimeInput,\n })}${isMoneyInput ? ' €' : ''}`,\n );\n }, [hasFocus, isMoneyInput, isTimeInput, maxNumber, minNumber, plainText]);\n\n useEffect(() => {\n if (typeof value === 'string') {\n setPlainText(value.replace('€', '').replaceAll(' ', ''));\n }\n }, [value]);\n\n return (\n <Input\n shouldRemainPlaceholder={shouldRemainPlaceholder}\n shouldShowOnlyBottomBorder={shouldShowOnlyBottomBorder}\n inputMode=\"decimal\"\n onChange={onLocalChange}\n value={hasFocus ? plainText : formattedValue}\n placeholder={localPlaceholder}\n onBlur={onLocalBlur}\n onFocus={onLocalFocus}\n isDisabled={isDisabled}\n isInvalid={typeof isInvalid === 'boolean' ? isInvalid : isValueInvalid}\n shouldShowCenteredContent={shouldShowOnlyBottomBorder}\n />\n );\n};\n\nNumberInput.displayName = 'NumberInput';\n\nexport default NumberInput;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"NumberInput.js","names":["React","useEffect","useRef","useState","NUMBER_CLEAR_REGEX","formateNumber","isValidString","parseFloatWithDecimals","Input","NumberInput","isDecimalInput","isMoneyInput","isTimeInput","isInvalid","maxNumber","Infinity","value","shouldTriggerChangeOnFormat","placeholder","onBlur","isDisabled","onChange","shouldShowOnlyBottomBorder","minNumber","plainText","setPlainText","formattedValue","setFormattedValue","hasFocus","setHasFocus","shouldRemainPlaceholder","setShouldRemainPlaceholder","isValueInvalid","setIsValueInvalid","localPlaceholder","undefined","initialInputRef","onLocalChange","event","newValue","target","current","sanitizedValueString","replace","includes","length","valueToCheck","replaceAll","string","Number","match","onLocalBlur","sanitizedValue","newIsInvalid","parsedNumber","stringValue","decimals","newStringValue","number","onLocalFocus","createElement","inputMode","onFocus","shouldShowCenteredContent","displayName"],"sources":["../../../../src/components/number-input/NumberInput.tsx"],"sourcesContent":["import React, { ChangeEventHandler, FC, useEffect, useRef, useState } from 'react';\nimport { NUMBER_CLEAR_REGEX } from '../../constants/numberInput';\nimport { formateNumber, isValidString, parseFloatWithDecimals } from '../../utils/numberInput';\nimport Input from '../input/Input';\n\nexport type NumberInputProps = {\n /**\n * Applies rules for decimal input.\n * Enables the user to input one zero as number before the comma\n */\n isDecimalInput?: boolean;\n /**\n * Whether the input is disabled\n */\n isDisabled?: boolean;\n /**\n * Whether the value is invalid.\n */\n isInvalid?: boolean;\n /**\n * Applies rules for money input.\n * Rules: only two decimal places, one zero before the comma\n */\n isMoneyInput?: boolean;\n /**\n * Whether the value should be formatted as a time.\n */\n isTimeInput?: boolean;\n /**\n * Limits the number to this value\n */\n maxNumber?: number;\n /**\n * Limits the number to this value\n */\n minNumber?: number;\n /**\n * Callback function that is called when the input gets out of focus\n */\n onBlur?: (newNumber: number | string | null, isInvalid: boolean) => void;\n /**\n * Callback function that is called when the input changes\n * It will pass the text from the input\n */\n onChange?: (newValue: string) => void;\n /**\n * Placeholder for the input field\n */\n placeholder?: string;\n /**\n * Whether only the bottom border should be displayed\n */\n shouldShowOnlyBottomBorder?: boolean;\n /**\n * Whether the onChange function should be triggert when the value is formatted on the focus or blur\n */\n shouldTriggerChangeOnFormat?: boolean;\n /**\n * The value, that should be displayed in the input, when it is in focus.\n * You can also pass a stringified number as default value.\n * NOTE: If you pass a stringified number, it will be formatted to the selected format\n */\n value?: string;\n};\n\nconst NumberInput: FC<NumberInputProps> = ({\n isDecimalInput,\n isMoneyInput,\n isTimeInput,\n isInvalid,\n maxNumber = Infinity,\n value,\n shouldTriggerChangeOnFormat = true,\n placeholder,\n onBlur,\n isDisabled,\n onChange,\n shouldShowOnlyBottomBorder,\n minNumber = -Infinity,\n}) => {\n // the plainText will be shown in the input, when it is in focus\n const [plainText, setPlainText] = useState<string>('');\n // the formattedValue will be shown in the input, when it is not in focus\n const [formattedValue, setFormattedValue] = useState<string>('');\n const [hasFocus, setHasFocus] = useState<boolean>(false);\n const [shouldRemainPlaceholder, setShouldRemainPlaceholder] = useState<boolean>(false);\n\n const [isValueInvalid, setIsValueInvalid] = useState(false);\n const localPlaceholder = placeholder ?? (isMoneyInput ? '€' : undefined);\n\n const initialInputRef = useRef(true);\n\n const onLocalChange: ChangeEventHandler<HTMLInputElement> = (event) => {\n const newValue = event.target.value;\n\n initialInputRef.current = false;\n\n const sanitizedValueString = newValue\n // Removes everything except numbers, commas and points\n .replace(NUMBER_CLEAR_REGEX, '');\n\n if (\n isTimeInput &&\n ((sanitizedValueString.includes(':') && sanitizedValueString.length > 5) ||\n (!sanitizedValueString.includes(':') && sanitizedValueString.length > 4))\n ) {\n return;\n }\n\n const valueToCheck = sanitizedValueString.replaceAll(',', '.');\n\n if (!isValidString({ string: valueToCheck, isMoneyInput, isDecimalInput, isTimeInput })) {\n return;\n }\n\n if (\n (maxNumber && Number(valueToCheck) > maxNumber) ||\n (minNumber && Number(valueToCheck) < minNumber)\n ) {\n return;\n }\n\n if (newValue.length === 1 && newValue.match(/^[0-9]+$/) === null) {\n setShouldRemainPlaceholder(true);\n } else {\n setShouldRemainPlaceholder(false);\n }\n\n setPlainText(sanitizedValueString.replaceAll('.', ','));\n\n if (typeof onChange === 'function') {\n onChange(sanitizedValueString.replaceAll('.', ','));\n }\n };\n\n const onLocalBlur = () => {\n const sanitizedValue = plainText;\n let newIsInvalid = false;\n let parsedNumber = null;\n\n if (!isTimeInput) {\n parsedNumber = parseFloatWithDecimals({\n stringValue: sanitizedValue.replace(',', '.').replaceAll(':', '').replace('€', ''),\n decimals: isMoneyInput ? 2 : undefined,\n });\n\n if (\n parsedNumber &&\n parsedNumber !== 0 &&\n (parsedNumber > maxNumber || parsedNumber < minNumber)\n ) {\n newIsInvalid = true;\n }\n\n setIsValueInvalid(newIsInvalid);\n }\n\n const newStringValue =\n plainText.length === 0\n ? ''\n : formateNumber({\n number: isTimeInput ? sanitizedValue : parsedNumber,\n isMoneyInput,\n isTimeInput,\n });\n\n setFormattedValue(`${newStringValue} ${isMoneyInput ? '€' : ''}`);\n setPlainText(newStringValue.replaceAll('.', ''));\n setHasFocus(false);\n\n if (typeof onChange === 'function' && shouldTriggerChangeOnFormat) {\n onChange(newStringValue.replaceAll('.', ''));\n }\n\n if (typeof onBlur === 'function') {\n if (isTimeInput) {\n onBlur(newStringValue, newIsInvalid);\n } else {\n onBlur(parsedNumber, newIsInvalid);\n }\n }\n };\n\n const onLocalFocus = () => {\n // formattedValue will be a number string with german number format (e.g. 1.000,00)\n // It will remove all dots, so that the user can type in the number\n setPlainText(formattedValue.replaceAll('.', '').replace('€', '').replaceAll(' ', ''));\n\n // This will update the external state\n if (typeof onChange === 'function' && shouldTriggerChangeOnFormat) {\n onChange(formattedValue.replaceAll('.', '').replace('€', '').replaceAll(' ', ''));\n }\n\n setIsValueInvalid(false);\n setHasFocus(true);\n };\n\n // updates the formattedValue, when the value changes\n useEffect(() => {\n let parsedNumber = null;\n\n if (!isTimeInput) {\n parsedNumber = parseFloatWithDecimals({\n stringValue: plainText\n .replace(',', '.')\n .replaceAll(':', '')\n .replace('€', '')\n .replaceAll(' ', ''),\n decimals: isMoneyInput ? 2 : undefined,\n });\n\n // checks, if a given number is invalid, if the input is not in focus\n if (!hasFocus) {\n if (parsedNumber === null && initialInputRef.current) {\n setIsValueInvalid(false);\n } else {\n setIsValueInvalid(\n parsedNumber === null ||\n parsedNumber > maxNumber ||\n parsedNumber < minNumber,\n );\n }\n }\n }\n\n setFormattedValue(\n plainText.length === 0\n ? ''\n : `${formateNumber({\n number: isTimeInput ? plainText : parsedNumber,\n isMoneyInput,\n isTimeInput,\n })}${isMoneyInput ? ' €' : ''}`,\n );\n }, [hasFocus, isMoneyInput, isTimeInput, maxNumber, minNumber, plainText]);\n\n useEffect(() => {\n if (typeof value === 'string') {\n setPlainText(value.replace('€', '').replaceAll(' ', ''));\n }\n }, [value]);\n\n return (\n <Input\n shouldRemainPlaceholder={shouldRemainPlaceholder}\n shouldShowOnlyBottomBorder={shouldShowOnlyBottomBorder}\n inputMode=\"decimal\"\n onChange={onLocalChange}\n value={hasFocus ? plainText : formattedValue}\n placeholder={localPlaceholder}\n onBlur={onLocalBlur}\n onFocus={onLocalFocus}\n isDisabled={isDisabled}\n isInvalid={typeof isInvalid === 'boolean' ? isInvalid : isValueInvalid}\n shouldShowCenteredContent={shouldShowOnlyBottomBorder}\n />\n );\n};\n\nNumberInput.displayName = 'NumberInput';\n\nexport default NumberInput;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,32 +1,46 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { RuntimeEnviroment, useEnvironment } from 'chayns-api';
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { createGlobalStyle } from 'styled-components';
|
|
4
4
|
import { useUsableHeight } from '../../utils/pageProvider';
|
|
5
5
|
import ColorSchemeProvider from '../color-scheme-provider/ColorSchemeProvider';
|
|
6
6
|
import { StyledPageProvider } from './PageProvider.styles';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Props for the PageProvider component.
|
|
10
|
+
* @description
|
|
11
|
+
* This interface defines the props that can be passed to the PageProvider component
|
|
12
|
+
* for controlling the layout and styling behavior.
|
|
13
|
+
* @example
|
|
14
|
+
* <PageProvider shouldRemovePadding={true}>
|
|
15
|
+
* {children}
|
|
16
|
+
* </PageProvider>
|
|
17
|
+
*/
|
|
18
|
+
|
|
7
19
|
const GlobalStyle = createGlobalStyle`
|
|
8
20
|
*, *::before, *::after {
|
|
9
21
|
box-sizing: border-box;
|
|
10
22
|
}
|
|
11
23
|
`;
|
|
12
|
-
const PageProvider =
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
24
|
+
const PageProvider = ({
|
|
25
|
+
children,
|
|
26
|
+
color,
|
|
27
|
+
colorMode,
|
|
28
|
+
secondaryColor,
|
|
29
|
+
siteId,
|
|
30
|
+
style = {},
|
|
31
|
+
shouldReduceUsableHeightByCoverHeight = false,
|
|
32
|
+
shouldRemovePadding = false,
|
|
33
|
+
shouldUseUsableHeight = false,
|
|
34
|
+
iconColor,
|
|
35
|
+
customVariables
|
|
36
|
+
}) => {
|
|
25
37
|
const {
|
|
26
38
|
runtimeEnvironment
|
|
27
|
-
} =
|
|
39
|
+
} = useEnvironment();
|
|
40
|
+
const usableHeight = useUsableHeight({
|
|
41
|
+
shouldReduceByCoverHeight: shouldReduceUsableHeightByCoverHeight
|
|
42
|
+
});
|
|
28
43
|
const shouldUsePadding = !shouldRemovePadding && ![RuntimeEnviroment.IntercomPlugin, RuntimeEnviroment.PagemakerPlugin, 6].includes(runtimeEnvironment);
|
|
29
|
-
const usableHeight = useUsableHeight();
|
|
30
44
|
return /*#__PURE__*/React.createElement(StyledPageProvider, {
|
|
31
45
|
className: "page-provider",
|
|
32
46
|
$shouldUsePadding: shouldUsePadding,
|
|
@@ -40,8 +54,8 @@ const PageProvider = _ref => {
|
|
|
40
54
|
...style,
|
|
41
55
|
height: '100%'
|
|
42
56
|
} : style,
|
|
43
|
-
|
|
44
|
-
|
|
57
|
+
customVariables: customVariables,
|
|
58
|
+
iconColor: iconColor
|
|
45
59
|
}, children), /*#__PURE__*/React.createElement(GlobalStyle, null));
|
|
46
60
|
};
|
|
47
61
|
PageProvider.displayName = 'PageProvider';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PageProvider.js","names":["
|
|
1
|
+
{"version":3,"file":"PageProvider.js","names":["RuntimeEnviroment","useEnvironment","React","createGlobalStyle","useUsableHeight","ColorSchemeProvider","StyledPageProvider","GlobalStyle","PageProvider","children","color","colorMode","secondaryColor","siteId","style","shouldReduceUsableHeightByCoverHeight","shouldRemovePadding","shouldUseUsableHeight","iconColor","customVariables","runtimeEnvironment","usableHeight","shouldReduceByCoverHeight","shouldUsePadding","IntercomPlugin","PagemakerPlugin","includes","createElement","className","$shouldUsePadding","$usableHeight","undefined","height","displayName"],"sources":["../../../../src/components/page-provider/PageProvider.tsx"],"sourcesContent":["import { RuntimeEnviroment, useEnvironment } from 'chayns-api';\nimport React, { FC } from 'react';\nimport { createGlobalStyle } from 'styled-components';\nimport { useUsableHeight } from '../../utils/pageProvider';\nimport ColorSchemeProvider, {\n type ColorSchemeProviderProps,\n} from '../color-scheme-provider/ColorSchemeProvider';\nimport { StyledPageProvider } from './PageProvider.styles';\n\n/**\n * Props for the PageProvider component.\n * @description\n * This interface defines the props that can be passed to the PageProvider component\n * for controlling the layout and styling behavior.\n * @example\n * <PageProvider shouldRemovePadding={true}>\n * {children}\n * </PageProvider>\n */\ninterface PageProviderProps extends ColorSchemeProviderProps {\n /**\n * Controls whether the usable height should be reduced by the cover height\n * @description\n * When true, the usable height will be reduced by the cover image height. This is useful\n * when the page should not be scrollable due to the cover image. The property has no effect\n * when `shouldUseUsableHeight` is false.\n * @default false\n * @optional\n */\n shouldReduceUsableHeightByCoverHeight?: boolean;\n /**\n * Controls whether padding should be removed from the page\n * @description\n * When true, the padding around the page content will be removed. This is useful when the\n * page should not have any padding, for example, when it is embedded in a pagemaker page.\n * @default false\n * @optional\n */\n shouldRemovePadding?: boolean;\n /**\n * Controls whether the component should use the calculated usable height\n * @description\n * When true, the page will cover the entire usable height of the screen. This means that\n * the viewport is not scrollable and the page takes up the full height not required by the\n * title or bottom bar. Optionally, the height of the cover image can be reduced by setting\n * `shouldReduceUsableHeightByCoverHeight` to true.\n * @default false\n * @optional\n */\n shouldUseUsableHeight?: boolean;\n}\n\nconst GlobalStyle = createGlobalStyle`\n *, *::before, *::after {\n box-sizing: border-box;\n }\n`;\n\nconst PageProvider: FC<PageProviderProps> = ({\n children,\n color,\n colorMode,\n secondaryColor,\n siteId,\n style = {},\n shouldReduceUsableHeightByCoverHeight = false,\n shouldRemovePadding = false,\n shouldUseUsableHeight = false,\n iconColor,\n customVariables,\n}) => {\n const { runtimeEnvironment } = useEnvironment();\n\n const usableHeight = useUsableHeight({\n shouldReduceByCoverHeight: shouldReduceUsableHeightByCoverHeight,\n });\n\n const shouldUsePadding =\n !shouldRemovePadding &&\n ![RuntimeEnviroment.IntercomPlugin, RuntimeEnviroment.PagemakerPlugin, 6].includes(\n runtimeEnvironment as number,\n );\n\n return (\n <StyledPageProvider\n className=\"page-provider\"\n $shouldUsePadding={shouldUsePadding}\n $usableHeight={shouldUseUsableHeight ? usableHeight : undefined}\n >\n <ColorSchemeProvider\n color={color}\n secondaryColor={secondaryColor}\n colorMode={colorMode}\n siteId={siteId}\n style={shouldUseUsableHeight ? { ...style, height: '100%' } : style}\n customVariables={customVariables}\n iconColor={iconColor}\n >\n {children}\n </ColorSchemeProvider>\n <GlobalStyle />\n </StyledPageProvider>\n );\n};\nPageProvider.displayName = 'PageProvider';\n\nexport default PageProvider;\n"],"mappings":"AAAA,SAASA,iBAAiB,EAAEC,cAAc,QAAQ,YAAY;AAC9D,OAAOC,KAAK,MAAc,OAAO;AACjC,SAASC,iBAAiB,QAAQ,mBAAmB;AACrD,SAASC,eAAe,QAAQ,0BAA0B;AAC1D,OAAOC,mBAAmB,MAEnB,8CAA8C;AACrD,SAASC,kBAAkB,QAAQ,uBAAuB;;AAE1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAkCA,MAAMC,WAAW,GAAGJ,iBAAiB;AACrC;AACA;AACA;AACA,CAAC;AAED,MAAMK,YAAmC,GAAGA,CAAC;EACzCC,QAAQ;EACRC,KAAK;EACLC,SAAS;EACTC,cAAc;EACdC,MAAM;EACNC,KAAK,GAAG,CAAC,CAAC;EACVC,qCAAqC,GAAG,KAAK;EAC7CC,mBAAmB,GAAG,KAAK;EAC3BC,qBAAqB,GAAG,KAAK;EAC7BC,SAAS;EACTC;AACJ,CAAC,KAAK;EACF,MAAM;IAAEC;EAAmB,CAAC,GAAGnB,cAAc,CAAC,CAAC;EAE/C,MAAMoB,YAAY,GAAGjB,eAAe,CAAC;IACjCkB,yBAAyB,EAAEP;EAC/B,CAAC,CAAC;EAEF,MAAMQ,gBAAgB,GAClB,CAACP,mBAAmB,IACpB,CAAC,CAAChB,iBAAiB,CAACwB,cAAc,EAAExB,iBAAiB,CAACyB,eAAe,EAAE,CAAC,CAAC,CAACC,QAAQ,CAC9EN,kBACJ,CAAC;EAEL,oBACIlB,KAAA,CAAAyB,aAAA,CAACrB,kBAAkB;IACfsB,SAAS,EAAC,eAAe;IACzBC,iBAAiB,EAAEN,gBAAiB;IACpCO,aAAa,EAAEb,qBAAqB,GAAGI,YAAY,GAAGU;EAAU,gBAEhE7B,KAAA,CAAAyB,aAAA,CAACtB,mBAAmB;IAChBK,KAAK,EAAEA,KAAM;IACbE,cAAc,EAAEA,cAAe;IAC/BD,SAAS,EAAEA,SAAU;IACrBE,MAAM,EAAEA,MAAO;IACfC,KAAK,EAAEG,qBAAqB,GAAG;MAAE,GAAGH,KAAK;MAAEkB,MAAM,EAAE;IAAO,CAAC,GAAGlB,KAAM;IACpEK,eAAe,EAAEA,eAAgB;IACjCD,SAAS,EAAEA;EAAU,GAEpBT,QACgB,CAAC,eACtBP,KAAA,CAAAyB,aAAA,CAACpB,WAAW,MAAE,CACE,CAAC;AAE7B,CAAC;AACDC,YAAY,CAACyB,WAAW,GAAG,cAAc;AAEzC,eAAezB,YAAY","ignoreList":[]}
|