@zohodesk/components 1.0.0-alpha-269 → 1.0.0-alpha-271
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/README.md +16 -0
- package/es/Accordion/Accordion.js +3 -7
- package/es/Accordion/AccordionItem.js +2 -4
- package/es/Animation/Animation.js +3 -3
- package/es/AppContainer/AppContainer.js +5 -13
- package/es/AppContainer/AppContainer.module.css +2 -2
- package/es/Avatar/Avatar.js +11 -23
- package/es/Avatar/Avatar.module.css +18 -18
- package/es/AvatarTeam/AvatarTeam.js +3 -3
- package/es/AvatarTeam/AvatarTeam.module.css +35 -35
- package/es/Button/Button.js +3 -4
- package/es/Button/css/Button.module.css +70 -70
- package/es/Buttongroup/Buttongroup.js +3 -3
- package/es/Buttongroup/Buttongroup.module.css +15 -14
- package/es/Card/Card.js +10 -21
- package/es/CheckBox/CheckBox.js +3 -5
- package/es/CheckBox/CheckBox.module.css +15 -15
- package/es/DateTime/CalendarView.js +20 -32
- package/es/DateTime/DateTime.js +6 -67
- package/es/DateTime/DateTime.module.css +39 -39
- package/es/DateTime/DateTimePopupFooter.js +2 -4
- package/es/DateTime/DateTimePopupHeader.js +2 -8
- package/es/DateTime/DateWidget.js +35 -98
- package/es/DateTime/DateWidget.module.css +5 -5
- package/es/DateTime/DaysRow.js +2 -4
- package/es/DateTime/Time.js +2 -10
- package/es/DateTime/YearView.js +4 -28
- package/es/DateTime/YearView.module.css +15 -15
- package/es/DateTime/__tests__/CalendarView.spec.js +0 -1
- package/es/DateTime/__tests__/DateTime.spec.js +0 -1
- package/es/DateTime/__tests__/DateWidget.spec.js +3 -2
- package/es/DateTime/common.js +0 -3
- package/es/DateTime/constants.js +0 -1
- package/es/DateTime/dateFormatUtils/dateFormat.js +30 -63
- package/es/DateTime/dateFormatUtils/dateFormats.js +1 -0
- package/es/DateTime/dateFormatUtils/dayChange.js +4 -13
- package/es/DateTime/dateFormatUtils/index.js +2 -32
- package/es/DateTime/dateFormatUtils/monthChange.js +0 -8
- package/es/DateTime/dateFormatUtils/timeChange.js +6 -22
- package/es/DateTime/dateFormatUtils/yearChange.js +2 -11
- package/es/DateTime/objectUtils.js +20 -14
- package/es/DateTime/typeChecker.js +0 -3
- package/es/DateTime/validator.js +6 -58
- package/es/DropBox/DropBox.js +5 -9
- package/es/DropBox/DropBoxElement/DropBoxElement.js +8 -13
- package/es/DropBox/DropBoxElement/css/DropBoxElement.module.css +85 -79
- package/es/DropBox/DropBoxElement/css/cssJSLogic.js +5 -7
- package/es/DropBox/DropBoxElement/props/propTypes.js +1 -1
- package/es/DropBox/DropBoxElement/useDropboxPosCalc.js +0 -3
- package/es/DropBox/__tests__/DropBox.spec.js +2 -2
- package/es/DropBox/css/DropBox.module.css +6 -6
- package/es/DropBox/props/defaultProps.js +2 -1
- package/es/DropBox/props/propTypes.js +2 -1
- package/es/DropDown/DropDown.js +4 -8
- package/es/DropDown/DropDown.module.css +2 -2
- package/es/DropDown/DropDownHeading.js +5 -4
- package/es/DropDown/DropDownHeading.module.css +6 -6
- package/es/DropDown/DropDownItem.js +0 -6
- package/es/DropDown/DropDownItem.module.css +12 -12
- package/es/DropDown/DropDownSearch.js +0 -4
- package/es/DropDown/DropDownSearch.module.css +3 -3
- package/es/DropDown/DropDownSeparator.js +0 -1
- package/es/DropDown/DropDownSeparator.module.css +2 -2
- package/es/DropDown/__tests__/DropDown.spec.js +2 -1
- package/es/Heading/Heading.js +3 -2
- package/es/Heading/Heading.module.css +2 -2
- package/es/Label/Label.js +3 -2
- package/es/Label/Label.module.css +5 -5
- package/es/Layout/Box.js +0 -13
- package/es/Layout/Container.js +1 -12
- package/es/Layout/Layout.module.css +15 -15
- package/es/Layout/index.js +2 -1
- package/es/ListItem/ListContainer.js +3 -8
- package/es/ListItem/ListItem.js +3 -9
- package/es/ListItem/ListItem.module.css +38 -38
- package/es/ListItem/ListItemWithAvatar.js +3 -9
- package/es/ListItem/ListItemWithCheckBox.js +2 -7
- package/es/ListItem/ListItemWithIcon.js +3 -8
- package/es/ListItem/ListItemWithRadio.js +3 -7
- package/es/Modal/Modal.js +11 -28
- package/es/MultiSelect/AdvancedGroupMultiSelect.js +13 -89
- package/es/MultiSelect/AdvancedMultiSelect.js +9 -32
- package/es/MultiSelect/EmptyState.js +0 -2
- package/es/MultiSelect/MultiSelect.js +32 -99
- package/es/MultiSelect/MultiSelect.module.css +31 -31
- package/es/MultiSelect/MultiSelectHeader.js +0 -3
- package/es/MultiSelect/MultiSelectWithAvatar.js +6 -12
- package/es/MultiSelect/SelectedOptions.js +3 -6
- package/es/MultiSelect/SelectedOptions.module.css +5 -5
- package/es/MultiSelect/Suggestions.js +3 -7
- package/es/MultiSelect/__tests__/MultiSelect.spec.js +6 -4
- package/es/MultiSelect/props/propTypes.js +0 -2
- package/es/PopOver/PopOver.js +2 -18
- package/es/PopOver/__tests__/PopOver.spec.js +1 -2
- package/es/Popup/Popup.js +24 -77
- package/es/Popup/__tests__/Popup.spec.js +5 -17
- package/es/Popup/viewPort.js +4 -16
- package/es/Provider/IdProvider.js +5 -10
- package/es/Provider/LibraryContext.js +4 -6
- package/es/Provider/NumberGenerator/NumberGenerator.js +7 -21
- package/es/Provider/ZindexProvider.js +2 -9
- package/es/Radio/Radio.js +2 -4
- package/es/Radio/Radio.module.css +9 -9
- package/es/Responsive/CustomResponsive.js +18 -30
- package/es/Responsive/RefWrapper.js +7 -6
- package/es/Responsive/ResizeComponent.js +25 -35
- package/es/Responsive/ResizeObserver.js +6 -26
- package/es/Responsive/Responsive.js +20 -34
- package/es/Responsive/index.js +3 -1
- package/es/Responsive/sizeObservers.js +7 -28
- package/es/Responsive/utils/index.js +5 -7
- package/es/Responsive/utils/shallowCompare.js +2 -7
- package/es/Responsive/windowResizeObserver.js +0 -7
- package/es/ResponsiveDropBox/ResponsiveDropBox.js +0 -4
- package/es/ResponsiveDropBox/ResponsiveDropBox.module.css +2 -2
- package/es/Ribbon/Ribbon.js +2 -3
- package/es/Ribbon/Ribbon.module.css +48 -46
- package/es/RippleEffect/RippleEffect.js +3 -1
- package/es/Select/GroupSelect.js +14 -58
- package/es/Select/Select.js +33 -79
- package/es/Select/Select.module.css +23 -23
- package/es/Select/SelectWithAvatar.js +4 -17
- package/es/Select/SelectWithIcon.js +5 -46
- package/es/Select/__tests__/Select.spec.js +8 -6
- package/es/Select/props/propTypes.js +0 -1
- package/es/Stencils/Stencils.js +3 -3
- package/es/Stencils/Stencils.module.css +11 -11
- package/es/Switch/Switch.js +3 -5
- package/es/Switch/Switch.module.css +23 -23
- package/es/Tab/Tab.js +4 -4
- package/es/Tab/Tab.module.css +14 -14
- package/es/Tab/TabContent.js +0 -1
- package/es/Tab/TabContentWrapper.js +0 -2
- package/es/Tab/TabWrapper.js +2 -5
- package/es/Tab/Tabs.js +7 -54
- package/es/Tab/Tabs.module.css +30 -37
- package/es/Tab/__tests__/Tab.spec.js +3 -1
- package/es/Tab/__tests__/TabWrapper.spec.js +0 -1
- package/es/Tag/Tag.js +3 -6
- package/es/Tag/Tag.module.css +25 -25
- package/es/TextBox/TextBox.js +3 -15
- package/es/TextBox/TextBox.module.css +9 -9
- package/es/TextBox/__tests__/TextBox.spec.js +4 -1
- package/es/TextBoxIcon/TextBoxIcon.js +2 -9
- package/es/TextBoxIcon/TextBoxIcon.module.css +7 -7
- package/es/TextBoxIcon/__tests__/TextBoxIcon.spec.js +7 -2
- package/es/Textarea/Textarea.js +3 -12
- package/es/Textarea/Textarea.module.css +21 -21
- package/es/Textarea/__tests__/Textarea.spec.js +2 -2
- package/es/Tooltip/Tooltip.js +14 -58
- package/es/Tooltip/Tooltip.module.css +5 -5
- package/es/Tooltip/__tests__/Tooltip.spec.js +0 -5
- package/es/VelocityAnimation/VelocityAnimation/VelocityAnimation.js +2 -3
- package/es/VelocityAnimation/VelocityAnimationGroup/VelocityAnimationGroup.js +5 -7
- package/es/common/animation.module.css +8 -8
- package/es/common/avatarsizes.module.css +16 -16
- package/es/common/basicReset.module.css +3 -3
- package/es/common/common.module.css +24 -24
- package/es/common/customscroll.module.css +2 -2
- package/es/deprecated/AdvancedMultiSelect.module.css +18 -18
- package/es/deprecated/PortalLayer/PortalLayer.js +20 -25
- package/es/semantic/Button/Button.js +2 -3
- package/es/semantic/Button/semanticButton.module.css +1 -1
- package/es/utils/Common.js +13 -54
- package/es/utils/ContextOptimizer.js +5 -4
- package/es/utils/__tests__/debounce.spec.js +2 -2
- package/es/utils/constructFullName.js +0 -2
- package/es/utils/css/compileClassNames.js +0 -5
- package/es/utils/css/mergeStyle.js +7 -8
- package/es/utils/css/utils.js +0 -1
- package/es/utils/datetime/common.js +5 -16
- package/es/utils/debounce.js +1 -5
- package/es/utils/dropDownUtils.js +11 -68
- package/es/utils/getInitial.js +0 -4
- package/es/utils/shallowEqual.js +0 -6
- package/lib/Accordion/Accordion.js +18 -42
- package/lib/Accordion/AccordionItem.js +18 -40
- package/lib/Accordion/__tests__/Accordion.spec.js +0 -3
- package/lib/Accordion/index.js +0 -3
- package/lib/Accordion/props/propTypes.js +0 -3
- package/lib/Animation/Animation.js +18 -38
- package/lib/Animation/__tests__/Animation.spec.js +7 -11
- package/lib/Animation/props/propTypes.js +0 -3
- package/lib/AppContainer/AppContainer.js +21 -56
- package/lib/AppContainer/AppContainer.module.css +2 -2
- package/lib/AppContainer/props/propTypes.js +0 -3
- package/lib/Avatar/Avatar.js +38 -78
- package/lib/Avatar/Avatar.module.css +18 -18
- package/lib/Avatar/__tests__/Avatar.spec.js +0 -44
- package/lib/Avatar/props/propTypes.js +0 -3
- package/lib/AvatarTeam/AvatarTeam.js +30 -52
- package/lib/AvatarTeam/AvatarTeam.module.css +35 -35
- package/lib/AvatarTeam/__tests__/AvatarTeam.spec.js +0 -13
- package/lib/AvatarTeam/props/propTypes.js +0 -3
- package/lib/Button/Button.js +20 -31
- package/lib/Button/css/Button.module.css +70 -70
- package/lib/Button/css/cssJSLogic.js +17 -18
- package/lib/Button/index.js +0 -3
- package/lib/Button/props/defaultProps.js +0 -2
- package/lib/Button/props/propTypes.js +0 -3
- package/lib/Buttongroup/Buttongroup.js +12 -32
- package/lib/Buttongroup/Buttongroup.module.css +15 -14
- package/lib/Buttongroup/__test__/Buttongroup.spec.js +0 -10
- package/lib/Buttongroup/props/propTypes.js +0 -3
- package/lib/Card/Card.js +46 -102
- package/lib/Card/__tests__/Card.spec.js +1 -10
- package/lib/Card/index.js +0 -4
- package/lib/Card/props/propTypes.js +0 -3
- package/lib/CheckBox/CheckBox.js +47 -71
- package/lib/CheckBox/CheckBox.module.css +15 -15
- package/lib/CheckBox/__tests__/CheckBox.spec.js +0 -3
- package/lib/CheckBox/props/propTypes.js +0 -3
- package/lib/DateTime/CalendarView.js +42 -82
- package/lib/DateTime/DateTime.js +155 -239
- package/lib/DateTime/DateTime.module.css +39 -39
- package/lib/DateTime/DateTimePopupFooter.js +8 -31
- package/lib/DateTime/DateTimePopupHeader.js +17 -48
- package/lib/DateTime/DateWidget.js +250 -352
- package/lib/DateTime/DateWidget.module.css +5 -5
- package/lib/DateTime/DaysRow.js +5 -27
- package/lib/DateTime/Time.js +32 -73
- package/lib/DateTime/YearView.js +28 -77
- package/lib/DateTime/YearView.module.css +15 -15
- package/lib/DateTime/__tests__/CalendarView.spec.js +5 -13
- package/lib/DateTime/__tests__/DateTime.spec.js +37 -51
- package/lib/DateTime/__tests__/DateWidget.spec.js +8 -10
- package/lib/DateTime/common.js +0 -6
- package/lib/DateTime/constants.js +0 -1
- package/lib/DateTime/dateFormatUtils/dateFormat.js +122 -184
- package/lib/DateTime/dateFormatUtils/dateFormats.js +1 -0
- package/lib/DateTime/dateFormatUtils/dayChange.js +7 -14
- package/lib/DateTime/dateFormatUtils/index.js +16 -74
- package/lib/DateTime/dateFormatUtils/monthChange.js +9 -19
- package/lib/DateTime/dateFormatUtils/timeChange.js +22 -54
- package/lib/DateTime/dateFormatUtils/yearChange.js +11 -22
- package/lib/DateTime/index.js +0 -2
- package/lib/DateTime/objectUtils.js +20 -24
- package/lib/DateTime/props/propTypes.js +1 -11
- package/lib/DateTime/typeChecker.js +0 -4
- package/lib/DateTime/validator.js +10 -73
- package/lib/DropBox/DropBox.js +12 -36
- package/lib/DropBox/DropBoxElement/DropBoxElement.js +44 -63
- package/lib/DropBox/DropBoxElement/css/DropBoxElement.module.css +85 -79
- package/lib/DropBox/DropBoxElement/css/cssJSLogic.js +35 -42
- package/lib/DropBox/DropBoxElement/props/propTypes.js +1 -4
- package/lib/DropBox/DropBoxElement/useDropboxPosCalc.js +9 -14
- package/lib/DropBox/__tests__/DropBox.spec.js +4 -8
- package/lib/DropBox/css/DropBox.module.css +6 -6
- package/lib/DropBox/css/cssJSLogic.js +1 -3
- package/lib/DropBox/props/defaultProps.js +4 -8
- package/lib/DropBox/props/propTypes.js +4 -10
- package/lib/DropDown/DropDown.js +8 -52
- package/lib/DropDown/DropDown.module.css +2 -2
- package/lib/DropDown/DropDownHeading.js +20 -39
- package/lib/DropDown/DropDownHeading.module.css +6 -6
- package/lib/DropDown/DropDownItem.js +20 -42
- package/lib/DropDown/DropDownItem.module.css +12 -12
- package/lib/DropDown/DropDownSearch.js +17 -40
- package/lib/DropDown/DropDownSearch.module.css +3 -3
- package/lib/DropDown/DropDownSeparator.js +4 -24
- package/lib/DropDown/DropDownSeparator.module.css +2 -2
- package/lib/DropDown/__tests__/DropDown.spec.js +9 -15
- package/lib/DropDown/__tests__/DropDownItem.spec.js +4 -9
- package/lib/DropDown/__tests__/DropDownSearch.spec.js +0 -3
- package/lib/DropDown/index.js +0 -9
- package/lib/DropDown/props/propTypes.js +4 -6
- package/lib/Heading/Heading.js +15 -37
- package/lib/Heading/Heading.module.css +2 -2
- package/lib/Heading/props/propTypes.js +0 -3
- package/lib/Label/Label.js +19 -39
- package/lib/Label/Label.module.css +5 -5
- package/lib/Label/__tests__/Label.spec.js +1 -14
- package/lib/Label/props/propTypes.js +0 -3
- package/lib/Layout/Box.js +11 -31
- package/lib/Layout/Container.js +10 -29
- package/lib/Layout/Layout.module.css +15 -15
- package/lib/Layout/__tests__/Box.spec.js +49 -65
- package/lib/Layout/__tests__/Container.spec.js +50 -67
- package/lib/Layout/index.js +0 -3
- package/lib/Layout/props/propTypes.js +0 -3
- package/lib/Layout/utils.js +0 -10
- package/lib/ListItem/ListContainer.js +27 -48
- package/lib/ListItem/ListItem.js +45 -69
- package/lib/ListItem/ListItem.module.css +38 -38
- package/lib/ListItem/ListItemWithAvatar.js +48 -75
- package/lib/ListItem/ListItemWithCheckBox.js +39 -64
- package/lib/ListItem/ListItemWithIcon.js +44 -68
- package/lib/ListItem/ListItemWithRadio.js +41 -65
- package/lib/ListItem/index.js +0 -7
- package/lib/ListItem/props/propTypes.js +4 -6
- package/lib/Modal/Modal.js +10 -45
- package/lib/Modal/props/propTypes.js +0 -3
- package/lib/MultiSelect/AdvancedGroupMultiSelect.js +166 -294
- package/lib/MultiSelect/AdvancedMultiSelect.js +125 -202
- package/lib/MultiSelect/EmptyState.js +24 -45
- package/lib/MultiSelect/MultiSelect.js +206 -323
- package/lib/MultiSelect/MultiSelect.module.css +31 -31
- package/lib/MultiSelect/MultiSelectHeader.js +8 -30
- package/lib/MultiSelect/MultiSelectWithAvatar.js +63 -105
- package/lib/MultiSelect/SelectedOptions.js +17 -43
- package/lib/MultiSelect/SelectedOptions.module.css +5 -5
- package/lib/MultiSelect/Suggestions.js +32 -64
- package/lib/MultiSelect/__tests__/MultiSelect.spec.js +75 -86
- package/lib/MultiSelect/index.js +0 -5
- package/lib/MultiSelect/props/defaultProps.js +0 -2
- package/lib/MultiSelect/props/propTypes.js +0 -5
- package/lib/PopOver/PopOver.js +49 -95
- package/lib/PopOver/__tests__/PopOver.spec.js +1 -4
- package/lib/PopOver/index.js +0 -4
- package/lib/PopOver/props/propTypes.js +0 -3
- package/lib/Popup/Popup.js +81 -158
- package/lib/Popup/__tests__/Popup.spec.js +8 -43
- package/lib/Popup/viewPort.js +14 -28
- package/lib/Provider/AvatarSize.js +0 -4
- package/lib/Provider/Config.js +0 -2
- package/lib/Provider/CssProvider.js +0 -4
- package/lib/Provider/IdProvider.js +6 -17
- package/lib/Provider/LibraryContext.js +15 -35
- package/lib/Provider/LibraryContextInit.js +0 -4
- package/lib/Provider/NumberGenerator/NumberGenerator.js +15 -44
- package/lib/Provider/ZindexProvider.js +3 -15
- package/lib/Provider/index.js +0 -5
- package/lib/Radio/Radio.js +38 -61
- package/lib/Radio/Radio.module.css +9 -9
- package/lib/Radio/__tests__/Radiospec.js +5 -9
- package/lib/Radio/props/propTypes.js +0 -3
- package/lib/Responsive/CustomResponsive.js +29 -73
- package/lib/Responsive/RefWrapper.js +11 -17
- package/lib/Responsive/ResizeComponent.js +36 -62
- package/lib/Responsive/ResizeObserver.js +10 -24
- package/lib/Responsive/Responsive.js +30 -80
- package/lib/Responsive/index.js +0 -4
- package/lib/Responsive/props/propTypes.js +0 -3
- package/lib/Responsive/sizeObservers.js +17 -53
- package/lib/Responsive/utils/index.js +3 -11
- package/lib/Responsive/utils/shallowCompare.js +2 -11
- package/lib/Responsive/windowResizeObserver.js +0 -8
- package/lib/ResponsiveDropBox/ResponsiveDropBox.js +17 -45
- package/lib/ResponsiveDropBox/ResponsiveDropBox.module.css +2 -2
- package/lib/ResponsiveDropBox/props/propTypes.js +0 -3
- package/lib/Ribbon/Ribbon.js +13 -33
- package/lib/Ribbon/Ribbon.module.css +48 -46
- package/lib/Ribbon/__tests__/Ribbon.spec.js +0 -22
- package/lib/Ribbon/props/propTypes.js +0 -3
- package/lib/RippleEffect/RippleEffect.js +10 -18
- package/lib/RippleEffect/props/propTypes.js +0 -3
- package/lib/Select/GroupSelect.js +130 -229
- package/lib/Select/Select.js +209 -290
- package/lib/Select/Select.module.css +23 -23
- package/lib/Select/SelectWithAvatar.js +56 -102
- package/lib/Select/SelectWithIcon.js +76 -132
- package/lib/Select/__tests__/Select.spec.js +91 -133
- package/lib/Select/index.js +0 -5
- package/lib/Select/props/defaultProps.js +4 -5
- package/lib/Select/props/propTypes.js +0 -4
- package/lib/Stencils/Stencils.js +10 -29
- package/lib/Stencils/Stencils.module.css +11 -11
- package/lib/Stencils/__tests__/Stencils.spec.js +0 -12
- package/lib/Stencils/props/propTypes.js +0 -3
- package/lib/Switch/Switch.js +34 -57
- package/lib/Switch/Switch.module.css +23 -23
- package/lib/Switch/props/propTypes.js +0 -3
- package/lib/Tab/Tab.js +27 -40
- package/lib/Tab/Tab.module.css +14 -14
- package/lib/Tab/TabContent.js +5 -12
- package/lib/Tab/TabContentWrapper.js +6 -13
- package/lib/Tab/TabWrapper.js +19 -37
- package/lib/Tab/Tabs.js +91 -171
- package/lib/Tab/Tabs.module.css +30 -37
- package/lib/Tab/__tests__/Tab.spec.js +58 -67
- package/lib/Tab/__tests__/TabContent.spec.js +6 -10
- package/lib/Tab/__tests__/TabContentWrapper.spec.js +20 -28
- package/lib/Tab/__tests__/TabWrapper.spec.js +0 -12
- package/lib/Tab/__tests__/Tabs.spec.js +39 -53
- package/lib/Tab/index.js +0 -6
- package/lib/Tab/props/propTypes.js +0 -3
- package/lib/Tag/Tag.js +43 -72
- package/lib/Tag/Tag.module.css +25 -25
- package/lib/Tag/__tests__/Tag.spec.js +8 -14
- package/lib/Tag/props/propTypes.js +0 -3
- package/lib/TextBox/TextBox.js +59 -85
- package/lib/TextBox/TextBox.module.css +9 -9
- package/lib/TextBox/__tests__/TextBox.spec.js +4 -14
- package/lib/TextBox/props/propTypes.js +4 -6
- package/lib/TextBoxIcon/TextBoxIcon.js +52 -79
- package/lib/TextBoxIcon/TextBoxIcon.module.css +7 -7
- package/lib/TextBoxIcon/__tests__/TextBoxIcon.spec.js +5 -14
- package/lib/TextBoxIcon/props/propTypes.js +0 -3
- package/lib/Textarea/Textarea.js +29 -54
- package/lib/Textarea/Textarea.module.css +21 -21
- package/lib/Textarea/__tests__/Textarea.spec.js +2 -14
- package/lib/Textarea/props/propTypes.js +0 -3
- package/lib/Tooltip/Tooltip.js +31 -94
- package/lib/Tooltip/Tooltip.module.css +5 -5
- package/lib/Tooltip/__tests__/Tooltip.spec.js +3 -24
- package/lib/Tooltip/props/propTypes.js +0 -3
- package/lib/VelocityAnimation/VelocityAnimation/VelocityAnimation.js +16 -40
- package/lib/VelocityAnimation/VelocityAnimation/props/propTypes.js +0 -3
- package/lib/VelocityAnimation/VelocityAnimationGroup/VelocityAnimationGroup.js +25 -53
- package/lib/VelocityAnimation/VelocityAnimationGroup/props/propTypes.js +0 -3
- package/lib/VelocityAnimation/index.js +0 -3
- package/lib/common/animation.module.css +8 -8
- package/lib/common/avatarsizes.module.css +16 -16
- package/lib/common/basicReset.module.css +3 -3
- package/lib/common/common.module.css +24 -24
- package/lib/common/customscroll.module.css +2 -2
- package/lib/css.js +0 -40
- package/lib/deprecated/AdvancedMultiSelect.module.css +18 -18
- package/lib/deprecated/PortalLayer/PortalLayer.js +23 -46
- package/lib/deprecated/PortalLayer/props/propTypes.js +0 -3
- package/lib/index.js +0 -57
- package/lib/semantic/Button/Button.js +22 -42
- package/lib/semantic/Button/props/propTypes.js +0 -3
- package/lib/semantic/Button/semanticButton.module.css +1 -1
- package/lib/semantic/index.js +0 -2
- package/lib/utils/Common.js +25 -109
- package/lib/utils/ContextOptimizer.js +10 -16
- package/lib/utils/__tests__/constructFullName.spec.js +0 -1
- package/lib/utils/__tests__/debounce.spec.js +2 -3
- package/lib/utils/__tests__/getInitial.spec.js +0 -1
- package/lib/utils/constructFullName.js +4 -13
- package/lib/utils/css/compileClassNames.js +0 -6
- package/lib/utils/css/mergeStyle.js +8 -11
- package/lib/utils/css/utils.js +0 -8
- package/lib/utils/datetime/common.js +5 -32
- package/lib/utils/debounce.js +1 -6
- package/lib/utils/dropDownUtils.js +59 -175
- package/lib/utils/dummyFunction.js +0 -2
- package/lib/utils/getHTMLFontSize.js +0 -1
- package/lib/utils/getInitial.js +0 -6
- package/lib/utils/index.js +0 -4
- package/lib/utils/scrollTo.js +0 -2
- package/lib/utils/shallowEqual.js +0 -8
- package/package.json +1 -1
package/es/Select/GroupSelect.js
CHANGED
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
import React, { PureComponent } from 'react';
|
|
3
3
|
import { GroupSelect_defaultProps } from './props/defaultProps';
|
|
4
4
|
import { GroupSelect_propTypes } from './props/propTypes';
|
|
5
|
-
/**** Components ****/
|
|
6
5
|
|
|
6
|
+
/**** Components ****/
|
|
7
7
|
import Popup from '../Popup/Popup';
|
|
8
8
|
import TextBoxIcon from '../TextBoxIcon/TextBoxIcon';
|
|
9
9
|
import Textbox from '../TextBox/TextBox';
|
|
@@ -18,14 +18,13 @@ import { getUniqueId } from '../Provider/IdProvider';
|
|
|
18
18
|
import ResponsiveDropBox from '../ResponsiveDropBox/ResponsiveDropBox';
|
|
19
19
|
import { ResponsiveReceiver } from '../Responsive/CustomResponsive';
|
|
20
20
|
import style from './Select.module.css';
|
|
21
|
-
/**** Methods ****/
|
|
22
21
|
|
|
22
|
+
/**** Methods ****/
|
|
23
23
|
import { makeGetGroupSelectOptions, optionIdGrouping, makeGetGroupSelectFilterSuggestions, extractOptionId } from '../utils/dropDownUtils';
|
|
24
24
|
import { getIsEmptyValue, scrollTo, debounce, getSearchString, findScrollEnd } from '../utils/Common';
|
|
25
|
-
/* eslint-disable react/no-unused-prop-types */
|
|
26
25
|
|
|
26
|
+
/* eslint-disable react/no-unused-prop-types */
|
|
27
27
|
/* eslint-disable react/sort-prop-types */
|
|
28
|
-
|
|
29
28
|
/* eslint-disable react/forbid-component-props */
|
|
30
29
|
|
|
31
30
|
export class GroupSelectComponent extends PureComponent {
|
|
@@ -85,11 +84,9 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
85
84
|
};
|
|
86
85
|
this._isMounted = false;
|
|
87
86
|
}
|
|
88
|
-
|
|
89
87
|
componentDidMount() {
|
|
90
88
|
this._isMounted = true;
|
|
91
89
|
}
|
|
92
|
-
|
|
93
90
|
componentDidUpdate(prevProps) {
|
|
94
91
|
let {
|
|
95
92
|
groupedOptions,
|
|
@@ -109,7 +106,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
109
106
|
} = this;
|
|
110
107
|
let newOptionIds = allOptionIds;
|
|
111
108
|
let newSelectedId = selectedId;
|
|
112
|
-
|
|
113
109
|
if (groupedOptions !== prevProps.groupedOptions) {
|
|
114
110
|
let {
|
|
115
111
|
revampedGroups,
|
|
@@ -125,7 +121,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
125
121
|
allOptionIds
|
|
126
122
|
});
|
|
127
123
|
}
|
|
128
|
-
|
|
129
124
|
if (selectedOption !== prevProps.selectedOption) {
|
|
130
125
|
let {
|
|
131
126
|
selectedId,
|
|
@@ -137,14 +132,12 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
137
132
|
hoverIndex
|
|
138
133
|
});
|
|
139
134
|
}
|
|
140
|
-
|
|
141
135
|
let {
|
|
142
136
|
suggestionOptionIds
|
|
143
137
|
} = this.handleFilterSuggestions();
|
|
144
138
|
let hoverId = getIsEmptyValue(suggestionOptionIds[hoverIndex]) ? '' : suggestionOptionIds[hoverIndex];
|
|
145
139
|
let selSuggestion = this[`suggestion_${hoverId}`];
|
|
146
140
|
isPopupOpen && scrollTo(suggestionContainer, selSuggestion);
|
|
147
|
-
|
|
148
141
|
if (isPopupOpen !== prevProps.isPopupOpen) {
|
|
149
142
|
if (isPopupOpen) {
|
|
150
143
|
setTimeout(() => {
|
|
@@ -163,11 +156,9 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
163
156
|
}
|
|
164
157
|
}
|
|
165
158
|
}
|
|
166
|
-
|
|
167
159
|
componentWillUnmount() {
|
|
168
160
|
this._isMounted = false;
|
|
169
161
|
}
|
|
170
|
-
|
|
171
162
|
handleGetGroupSelectOptions(props) {
|
|
172
163
|
let {
|
|
173
164
|
groupedOptions
|
|
@@ -176,7 +167,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
176
167
|
groupedOptions
|
|
177
168
|
});
|
|
178
169
|
}
|
|
179
|
-
|
|
180
170
|
handleGetSelectedId(props, allOptionIds) {
|
|
181
171
|
let {
|
|
182
172
|
selectedOption,
|
|
@@ -188,23 +178,19 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
188
178
|
} = selectedOption;
|
|
189
179
|
let selectedId = optionIdGrouping(selected, groupId);
|
|
190
180
|
let selectedIdIndex = allOptionIds.indexOf(selectedId);
|
|
191
|
-
|
|
192
181
|
if (selectedIdIndex === -1) {
|
|
193
182
|
selectedIdIndex = 0;
|
|
194
|
-
|
|
195
183
|
if (isDefaultSelectValue) {
|
|
196
184
|
[selectedId] = allOptionIds;
|
|
197
185
|
} else {
|
|
198
186
|
selectedId = '';
|
|
199
187
|
}
|
|
200
188
|
}
|
|
201
|
-
|
|
202
189
|
return {
|
|
203
190
|
selectedId,
|
|
204
191
|
hoverIndex: selectedIdIndex
|
|
205
192
|
};
|
|
206
193
|
}
|
|
207
|
-
|
|
208
194
|
handleFilterSuggestions() {
|
|
209
195
|
let {
|
|
210
196
|
needSearch,
|
|
@@ -215,7 +201,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
215
201
|
searchStr = '',
|
|
216
202
|
allOptionIds
|
|
217
203
|
} = this.state;
|
|
218
|
-
|
|
219
204
|
if (needSearch && searchStr && searchStr.trim().length) {
|
|
220
205
|
searchStr = getSearchString(searchStr);
|
|
221
206
|
let {
|
|
@@ -231,13 +216,11 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
231
216
|
suggestionOptionIds
|
|
232
217
|
};
|
|
233
218
|
}
|
|
234
|
-
|
|
235
219
|
return {
|
|
236
220
|
suggestionGroups: revampedGroups,
|
|
237
221
|
suggestionOptionIds: allOptionIds
|
|
238
222
|
};
|
|
239
223
|
}
|
|
240
|
-
|
|
241
224
|
handleSearchOptions() {
|
|
242
225
|
let {
|
|
243
226
|
onSearch
|
|
@@ -247,7 +230,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
247
230
|
} = this.state;
|
|
248
231
|
searchStr && this.handleFetchOptions(onSearch, searchStr);
|
|
249
232
|
}
|
|
250
|
-
|
|
251
233
|
handleSearch(value) {
|
|
252
234
|
// let { value = '' } = e.target;
|
|
253
235
|
let {
|
|
@@ -270,7 +252,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
270
252
|
}
|
|
271
253
|
});
|
|
272
254
|
}
|
|
273
|
-
|
|
274
255
|
handleKeyDown(e) {
|
|
275
256
|
let {
|
|
276
257
|
isPopupOpen,
|
|
@@ -286,38 +267,33 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
286
267
|
let {
|
|
287
268
|
keyCode
|
|
288
269
|
} = e;
|
|
289
|
-
|
|
290
270
|
if (!isPopupOpen && !isPopupOpenOnEnter) {
|
|
291
271
|
onKeyDown && onKeyDown(e);
|
|
292
272
|
}
|
|
293
|
-
|
|
294
273
|
if (isPopupOpen && (keyCode === 38 || keyCode === 40) && e.preventDefault) {
|
|
295
274
|
e.preventDefault(); //prevent body scroll
|
|
296
275
|
} else if (!isPopupOpen && keyCode === 40) {
|
|
297
276
|
e.preventDefault(); //prevent body scroll
|
|
298
|
-
|
|
299
277
|
this.togglePopup(e);
|
|
300
278
|
}
|
|
301
|
-
|
|
302
279
|
if (keyCode === 38 && isPopupOpen && suggestionOptionIds.length) {
|
|
303
|
-
if (hoverIndex === 0) {
|
|
280
|
+
if (hoverIndex === 0) {
|
|
281
|
+
// hoverIndex = options.length - 1;
|
|
304
282
|
} else {
|
|
305
283
|
hoverIndex -= 1;
|
|
306
284
|
}
|
|
307
|
-
|
|
308
285
|
this.setState({
|
|
309
286
|
hoverIndex
|
|
310
287
|
});
|
|
311
288
|
} else if (keyCode === 40 && isPopupOpen && suggestionOptionIds.length) {
|
|
312
|
-
if (hoverIndex === suggestionOptionIds.length - 1) {
|
|
289
|
+
if (hoverIndex === suggestionOptionIds.length - 1) {
|
|
290
|
+
// hoverIndex = 0;
|
|
313
291
|
} else {
|
|
314
292
|
if (hoverIndex === suggestionOptionIds.length - 3) {
|
|
315
293
|
this.handleGetNextOptions();
|
|
316
294
|
}
|
|
317
|
-
|
|
318
295
|
hoverIndex += 1;
|
|
319
296
|
}
|
|
320
|
-
|
|
321
297
|
this.setState({
|
|
322
298
|
hoverIndex
|
|
323
299
|
});
|
|
@@ -328,7 +304,8 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
328
304
|
} else if (keyCode === 27) {
|
|
329
305
|
this.valueInput && this.valueInput.focus({
|
|
330
306
|
preventScroll: true
|
|
331
|
-
});
|
|
307
|
+
});
|
|
308
|
+
// this.handlePopupClose(e);
|
|
332
309
|
}
|
|
333
310
|
}
|
|
334
311
|
|
|
@@ -344,7 +321,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
344
321
|
hoverIndex: newHoverIndex
|
|
345
322
|
});
|
|
346
323
|
}
|
|
347
|
-
|
|
348
324
|
handleChange(id, value, index, e) {
|
|
349
325
|
e && e.preventDefault && e.preventDefault();
|
|
350
326
|
let {
|
|
@@ -358,13 +334,13 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
358
334
|
id: selected,
|
|
359
335
|
groupId
|
|
360
336
|
} = extractOptionId(id);
|
|
361
|
-
|
|
362
337
|
if (!getIsEmptyValue(id) && !isReadOnly) {
|
|
363
338
|
onChange && onChange({
|
|
364
339
|
groupId,
|
|
365
340
|
selected
|
|
366
341
|
}, normalizedAllOptions[id]);
|
|
367
|
-
this.handlePopupClose();
|
|
342
|
+
this.handlePopupClose();
|
|
343
|
+
// this.valueInput && this.valueInput.focus({preventScroll:true});
|
|
368
344
|
}
|
|
369
345
|
}
|
|
370
346
|
|
|
@@ -376,7 +352,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
376
352
|
} = this.props;
|
|
377
353
|
!isReadOnly && togglePopup(e, defaultDropBoxPosition ? `${defaultDropBoxPosition}Center` : null);
|
|
378
354
|
}
|
|
379
|
-
|
|
380
355
|
handlePopupClose(e) {
|
|
381
356
|
let {
|
|
382
357
|
closePopupOnly,
|
|
@@ -387,19 +362,15 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
387
362
|
});
|
|
388
363
|
isPopupOpen && closePopupOnly(e);
|
|
389
364
|
}
|
|
390
|
-
|
|
391
365
|
suggestionContainerRef(el) {
|
|
392
366
|
this.suggestionContainer = el;
|
|
393
367
|
}
|
|
394
|
-
|
|
395
368
|
suggestionItemRef(el, index, id) {
|
|
396
369
|
this[`suggestion_${id}`] = el;
|
|
397
370
|
}
|
|
398
|
-
|
|
399
371
|
searchInputRef(el) {
|
|
400
372
|
this.searchInput = el;
|
|
401
373
|
}
|
|
402
|
-
|
|
403
374
|
valueInputRef(el) {
|
|
404
375
|
let {
|
|
405
376
|
getRef
|
|
@@ -407,14 +378,12 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
407
378
|
this.valueInput = el;
|
|
408
379
|
getRef && getRef(el);
|
|
409
380
|
}
|
|
410
|
-
|
|
411
381
|
handleSelectFocus(e) {
|
|
412
382
|
let {
|
|
413
383
|
target
|
|
414
384
|
} = e || {};
|
|
415
385
|
target && target.setSelectionRange(target, 0);
|
|
416
386
|
}
|
|
417
|
-
|
|
418
387
|
handleClearSearch() {
|
|
419
388
|
this.handleSearch('');
|
|
420
389
|
setTimeout(() => {
|
|
@@ -423,7 +392,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
423
392
|
});
|
|
424
393
|
}, 1);
|
|
425
394
|
}
|
|
426
|
-
|
|
427
395
|
handleValueInputChange(e) {
|
|
428
396
|
let {
|
|
429
397
|
which
|
|
@@ -433,26 +401,22 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
433
401
|
isPopupOpen,
|
|
434
402
|
autoSelectOnType
|
|
435
403
|
} = this.props;
|
|
436
|
-
|
|
437
404
|
if (!isPopupOpen && autoSelectOnType) {
|
|
438
405
|
this.valueInputTypeString += (typeString || '').trim();
|
|
439
406
|
this.handleChangeOnType();
|
|
440
407
|
}
|
|
441
408
|
}
|
|
442
|
-
|
|
443
409
|
handleChangeOnType() {
|
|
444
410
|
let {
|
|
445
411
|
revampedGroups
|
|
446
412
|
} = this.state;
|
|
447
413
|
let typeString = this.valueInputTypeString;
|
|
448
414
|
this.valueInputTypeString = '';
|
|
449
|
-
|
|
450
415
|
let changeValue = () => {
|
|
451
416
|
let id = this.autoSelectSuggestions[this.autoSelectIndex];
|
|
452
417
|
let {
|
|
453
418
|
suggestionOptionIds
|
|
454
419
|
} = this.handleFilterSuggestions();
|
|
455
|
-
|
|
456
420
|
if (!getIsEmptyValue(id)) {
|
|
457
421
|
this.handleChange(id);
|
|
458
422
|
let hoverIndex = suggestionOptionIds.indexOf(id);
|
|
@@ -461,14 +425,12 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
461
425
|
});
|
|
462
426
|
}
|
|
463
427
|
};
|
|
464
|
-
|
|
465
428
|
if (typeString && typeString === this.valueInputSearchString) {
|
|
466
429
|
if (this.autoSelectIndex < this.autoSelectSuggestions.length - 1) {
|
|
467
430
|
this.autoSelectIndex += 1;
|
|
468
431
|
} else {
|
|
469
432
|
this.autoSelectIndex = 0;
|
|
470
433
|
}
|
|
471
|
-
|
|
472
434
|
changeValue();
|
|
473
435
|
} else if (typeString) {
|
|
474
436
|
this.valueInputSearchString = typeString;
|
|
@@ -485,13 +447,11 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
485
447
|
changeValue();
|
|
486
448
|
}
|
|
487
449
|
}
|
|
488
|
-
|
|
489
450
|
handleScroll(e) {
|
|
490
451
|
let ele = e.target;
|
|
491
452
|
let isScrollReachedBottom = findScrollEnd(ele);
|
|
492
453
|
isScrollReachedBottom && this.handleGetNextOptions();
|
|
493
454
|
}
|
|
494
|
-
|
|
495
455
|
handleFetchOptions(APICall) {
|
|
496
456
|
let searchStr = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
|
|
497
457
|
// let funcArgs = args.slice(1, args.length);
|
|
@@ -501,12 +461,10 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
501
461
|
let {
|
|
502
462
|
_isMounted
|
|
503
463
|
} = this;
|
|
504
|
-
|
|
505
464
|
if (!isFetchingOptions && APICall) {
|
|
506
465
|
this.setState({
|
|
507
466
|
isFetchingOptions: true
|
|
508
467
|
});
|
|
509
|
-
|
|
510
468
|
try {
|
|
511
469
|
return APICall(searchStr).then(() => {
|
|
512
470
|
_isMounted && this.setState({
|
|
@@ -524,7 +482,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
524
482
|
}
|
|
525
483
|
}
|
|
526
484
|
}
|
|
527
|
-
|
|
528
485
|
handleGetNextOptions() {
|
|
529
486
|
let {
|
|
530
487
|
isNextOptions,
|
|
@@ -535,7 +492,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
535
492
|
} = this.state;
|
|
536
493
|
isNextOptions && getNextOptions && this.handleFetchOptions(getNextOptions, searchStr);
|
|
537
494
|
}
|
|
538
|
-
|
|
539
495
|
responsiveFunc(_ref) {
|
|
540
496
|
let {
|
|
541
497
|
mediaQueryOR
|
|
@@ -546,7 +502,6 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
546
502
|
}])
|
|
547
503
|
};
|
|
548
504
|
}
|
|
549
|
-
|
|
550
505
|
render() {
|
|
551
506
|
let {
|
|
552
507
|
isDisabled,
|
|
@@ -782,14 +737,15 @@ export class GroupSelectComponent extends PureComponent {
|
|
|
782
737
|
}, /*#__PURE__*/React.createElement(Loader, null))), getFooter ? /*#__PURE__*/React.createElement(CardFooter, null, getFooter()) : null)));
|
|
783
738
|
}) : null);
|
|
784
739
|
}
|
|
785
|
-
|
|
786
740
|
}
|
|
787
741
|
GroupSelectComponent.propTypes = GroupSelect_propTypes;
|
|
788
742
|
GroupSelectComponent.defaultProps = GroupSelect_defaultProps;
|
|
789
743
|
GroupSelectComponent.displayName = 'GroupSelect';
|
|
790
744
|
let GroupSelect = Popup(GroupSelectComponent);
|
|
791
745
|
GroupSelect.defaultProps = GroupSelectComponent.defaultProps;
|
|
792
|
-
export default GroupSelect;
|
|
746
|
+
export default GroupSelect;
|
|
747
|
+
|
|
748
|
+
// if (__DOCS__) {
|
|
793
749
|
// GroupSelect.docs = {
|
|
794
750
|
// componentGroup: 'Form Elements',
|
|
795
751
|
// folderName: 'Style Guide'
|