@sproutsocial/racine 12.19.0 → 12.21.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/CHANGELOG.md +33 -0
- package/README.md +46 -44
- package/__flow__/Avatar/index.js +26 -26
- package/__flow__/Avatar/index.stories.js +8 -8
- package/__flow__/Avatar/index.test.js +13 -13
- package/__flow__/Badge/constants.js +14 -14
- package/__flow__/Badge/index.js +18 -18
- package/__flow__/Badge/index.stories.js +8 -8
- package/__flow__/Badge/index.test.js +43 -43
- package/__flow__/Badge/styles.js +13 -9
- package/__flow__/Banner/index.js +21 -21
- package/__flow__/Banner/index.stories.js +56 -68
- package/__flow__/Banner/index.test.js +32 -34
- package/__flow__/Banner/styles.js +4 -4
- package/__flow__/Box/index.js +4 -4
- package/__flow__/Box/index.stories.js +58 -51
- package/__flow__/Box/index.test.js +7 -7
- package/__flow__/Box/styles.js +6 -6
- package/__flow__/Breadcrumb/index.js +9 -13
- package/__flow__/Breadcrumb/index.stories.js +14 -14
- package/__flow__/Breadcrumb/index.test.js +20 -20
- package/__flow__/Breadcrumb/styles.js +5 -5
- package/__flow__/Button/index.js +23 -23
- package/__flow__/Button/index.stories.js +34 -34
- package/__flow__/Button/styles.js +11 -11
- package/__flow__/Card/index.js +7 -7
- package/__flow__/Card/index.stories.js +14 -14
- package/__flow__/Card/styles.js +7 -7
- package/__flow__/CharacterCounter/index.js +7 -7
- package/__flow__/CharacterCounter/index.stories.js +25 -26
- package/__flow__/CharacterCounter/index.test.js +11 -11
- package/__flow__/CharacterCounter/styles.js +3 -3
- package/__flow__/ChartLegend/index.js +7 -7
- package/__flow__/ChartLegend/index.stories.js +22 -22
- package/__flow__/ChartLegend/index.test.js +27 -27
- package/__flow__/ChartLegend/styles.js +7 -7
- package/__flow__/Checkbox/index.js +10 -10
- package/__flow__/Checkbox/index.stories.js +24 -24
- package/__flow__/Checkbox/index.test.js +25 -25
- package/__flow__/Checkbox/styles.js +27 -28
- package/__flow__/Collapsible/index.js +15 -15
- package/__flow__/Collapsible/index.stories.js +13 -13
- package/__flow__/Collapsible/index.test.js +27 -27
- package/__flow__/Collapsible/styles.js +5 -5
- package/__flow__/DatePicker/DateRangePicker.js +5 -8
- package/__flow__/DatePicker/DateRangePicker.stories.js +19 -19
- package/__flow__/DatePicker/DateRangePicker.test.js +21 -21
- package/__flow__/DatePicker/SingleDatePicker.js +6 -9
- package/__flow__/DatePicker/SingleDatePicker.stories.js +10 -10
- package/__flow__/DatePicker/SingleDatePicker.test.js +21 -23
- package/__flow__/DatePicker/StatefulDateRangePicker.js +6 -6
- package/__flow__/DatePicker/StatefulSingleDatePicker.js +3 -3
- package/__flow__/DatePicker/common.js +13 -13
- package/__flow__/DatePicker/index.js +3 -3
- package/__flow__/DatePicker/styles.js +42 -42
- package/__flow__/Drawer/SlideTransition.js +10 -10
- package/__flow__/Drawer/index.js +29 -29
- package/__flow__/Drawer/index.stories.js +58 -141
- package/__flow__/Drawer/index.test.js +28 -28
- package/__flow__/Drawer/styles.js +4 -4
- package/__flow__/EmptyState/index.js +5 -5
- package/__flow__/EmptyState/index.stories.js +10 -10
- package/__flow__/EmptyState/index.test.js +27 -27
- package/__flow__/EnumIllustrationNames.js +1 -1
- package/__flow__/Fieldset/index.js +14 -14
- package/__flow__/Fieldset/index.stories.js +19 -20
- package/__flow__/Fieldset/index.test.js +14 -14
- package/__flow__/Fieldset/styles.js +5 -5
- package/__flow__/FormField/index.js +14 -14
- package/__flow__/FormField/index.stories.js +31 -21
- package/__flow__/FormField/index.test.js +19 -19
- package/__flow__/Icon/deprecatedIcons.js +36 -36
- package/__flow__/Icon/index.js +17 -17
- package/__flow__/Icon/index.stories.js +62 -29
- package/__flow__/Icon/index.test.js +15 -15
- package/__flow__/Icon/styles.js +12 -23
- package/__flow__/IllustrationViewBoxes.js +1 -1
- package/__flow__/Image/index.js +6 -7
- package/__flow__/Image/index.stories.js +5 -5
- package/__flow__/Image/index.test.js +24 -24
- package/__flow__/Image/styles.js +6 -5
- package/__flow__/Indicator/index.js +7 -7
- package/__flow__/Indicator/index.stories.js +8 -14
- package/__flow__/Indicator/index.test.js +6 -6
- package/__flow__/Indicator/styles.js +6 -6
- package/__flow__/Input/index.js +37 -37
- package/__flow__/Input/index.stories.js +96 -189
- package/__flow__/Input/index.test.js +117 -117
- package/__flow__/Input/styles.js +13 -13
- package/__flow__/KeyboardKey/index.js +5 -5
- package/__flow__/KeyboardKey/index.stories.js +9 -12
- package/__flow__/KeyboardKey/index.test.js +7 -7
- package/__flow__/KeyboardKey/styles.js +4 -4
- package/__flow__/Label/index.js +6 -6
- package/__flow__/Label/index.stories.js +5 -7
- package/__flow__/Label/index.test.js +8 -8
- package/__flow__/Link/constants.js +4 -4
- package/__flow__/Link/index.js +11 -11
- package/__flow__/Link/index.stories.js +61 -102
- package/__flow__/Link/index.test.js +40 -40
- package/__flow__/Link/styles.js +6 -6
- package/__flow__/Listbox/index.js +16 -16
- package/__flow__/Listbox/index.stories.js +35 -35
- package/__flow__/Listbox/index.test.js +63 -65
- package/__flow__/Loader/index.js +12 -12
- package/__flow__/Loader/index.stories.js +10 -10
- package/__flow__/Loader/index.test.js +17 -17
- package/__flow__/Loader/styles.js +9 -13
- package/__flow__/LoaderButton/index.js +36 -18
- package/__flow__/LoaderButton/index.stories.js +35 -7
- package/__flow__/LoaderButton/index.test.js +15 -15
- package/__flow__/Menu/__snapshots__/index.test.js.snap +0 -9
- package/__flow__/Menu/constants.js +8 -8
- package/__flow__/Menu/descendants.js +89 -80
- package/__flow__/Menu/hooks.js +22 -22
- package/__flow__/Menu/index.flow.js +13 -13
- package/__flow__/Menu/index.js +56 -60
- package/__flow__/Menu/index.stories.js +19 -19
- package/__flow__/Menu/index.test.js +22 -22
- package/__flow__/Menu/names.js +4945 -4945
- package/__flow__/Menu/styles.js +5 -5
- package/__flow__/Message/index.js +33 -33
- package/__flow__/Message/index.stories.js +18 -13
- package/__flow__/Message/index.test.js +6 -6
- package/__flow__/Message/styles.js +15 -15
- package/__flow__/Modal/index.js +19 -19
- package/__flow__/Modal/index.stories.js +43 -43
- package/__flow__/Modal/index.test.js +29 -29
- package/__flow__/Modal/styles.js +27 -32
- package/__flow__/Numeral/index.js +22 -22
- package/__flow__/Numeral/index.stories.js +74 -74
- package/__flow__/Numeral/styles.js +3 -3
- package/__flow__/Numeral/tests/A11y.test.js +7 -7
- package/__flow__/Numeral/tests/abbreviate.test.js +40 -40
- package/__flow__/Numeral/tests/currency.test.js +24 -24
- package/__flow__/Numeral/tests/defaults.test.js +20 -20
- package/__flow__/Numeral/tests/invalid.test.js +9 -9
- package/__flow__/Numeral/tests/locale.test.js +38 -38
- package/__flow__/Numeral/tests/precision.test.js +76 -76
- package/__flow__/Numeral/tests/testNumeral.js +11 -11
- package/__flow__/Numeral/tests/zero.test.js +8 -8
- package/__flow__/OverflowList/index.flow.js +2 -2
- package/__flow__/OverflowList/index.js +12 -12
- package/__flow__/OverflowList/index.stories.js +10 -10
- package/__flow__/OverflowList/index.test.js +25 -25
- package/__flow__/OverflowList/styles.js +5 -5
- package/__flow__/PartnerLogo/TypePartnerNames.js +37 -37
- package/__flow__/PartnerLogo/index.js +21 -27
- package/__flow__/PartnerLogo/index.stories.js +52 -52
- package/__flow__/PartnerLogo/styles.js +12 -24
- package/__flow__/Popout/index.js +66 -67
- package/__flow__/Popout/index.stories.js +101 -82
- package/__flow__/Popout/index.test.js +43 -43
- package/__flow__/Popout/styles.js +4 -5
- package/__flow__/Portal/index.js +9 -9
- package/__flow__/Portal/index.stories.js +12 -12
- package/__flow__/Radio/index.js +4 -4
- package/__flow__/Radio/index.stories.js +11 -11
- package/__flow__/Radio/index.test.js +12 -12
- package/__flow__/Radio/styles.js +15 -16
- package/__flow__/SegmentedControl/index.js +7 -7
- package/__flow__/SegmentedControl/index.stories.js +7 -7
- package/__flow__/SegmentedControl/index.test.js +29 -29
- package/__flow__/SegmentedControl/styles.js +10 -9
- package/__flow__/Select/index.js +10 -10
- package/__flow__/Select/index.stories.js +33 -69
- package/__flow__/Select/index.test.js +14 -14
- package/__flow__/Select/styles.js +16 -16
- package/__flow__/Skeleton/index.js +4 -4
- package/__flow__/Skeleton/index.stories.js +5 -5
- package/__flow__/SpotIllustration/illustrationNames.js +118 -117
- package/__flow__/SpotIllustration/index.js +15 -11
- package/__flow__/SpotIllustration/index.stories.js +18 -18
- package/__flow__/SpotIllustration/spotIllustrations/molecule.svg +14 -0
- package/__flow__/Stack/index.js +43 -33
- package/__flow__/Stack/index.stories.js +41 -91
- package/__flow__/Stack/index.test.js +16 -7
- package/__flow__/Switch/index.js +8 -8
- package/__flow__/Switch/index.stories.js +5 -5
- package/__flow__/Switch/index.test.js +25 -29
- package/__flow__/Switch/styles.js +13 -9
- package/__flow__/Table/index.js +17 -17
- package/__flow__/Table/index.stories.js +99 -99
- package/__flow__/Table/index.test.js +32 -32
- package/__flow__/Table/styles.js +4 -4
- package/__flow__/TableCell/index.js +8 -7
- package/__flow__/TableCell/index.stories.js +20 -23
- package/__flow__/TableCell/index.test.js +11 -11
- package/__flow__/TableCell/styles.js +4 -5
- package/__flow__/TableHeaderCell/index.js +14 -14
- package/__flow__/TableHeaderCell/index.stories.js +35 -30
- package/__flow__/TableHeaderCell/index.test.js +11 -11
- package/__flow__/TableHeaderCell/styles.js +4 -4
- package/__flow__/TableRowAccordion/index.js +8 -8
- package/__flow__/TableRowAccordion/index.stories.js +36 -36
- package/__flow__/TableRowAccordion/index.test.js +28 -30
- package/__flow__/TableRowAccordion/styles.js +11 -7
- package/__flow__/Tabs/index.js +11 -11
- package/__flow__/Tabs/index.stories.js +28 -54
- package/__flow__/Tabs/index.test.js +54 -54
- package/__flow__/Tabs/styles.js +6 -7
- package/__flow__/Text/index.js +14 -14
- package/__flow__/Text/index.stories.js +84 -86
- package/__flow__/Text/index.test.js +29 -33
- package/__flow__/Text/styles.js +4 -4
- package/__flow__/Textarea/index.js +5 -5
- package/__flow__/Textarea/index.stories.js +54 -93
- package/__flow__/Textarea/index.test.js +30 -30
- package/__flow__/Textarea/styles.js +6 -6
- package/__flow__/ThemeProvider/index.js +4 -4
- package/__flow__/Toast/index.js +23 -23
- package/__flow__/Toast/index.stories.js +21 -21
- package/__flow__/Toast/styles.js +6 -6
- package/__flow__/ToggleHint/index.js +8 -8
- package/__flow__/ToggleHint/index.test.js +8 -8
- package/__flow__/ToggleHint/styles.js +8 -8
- package/__flow__/Token/index.js +10 -10
- package/__flow__/Token/index.stories.js +49 -54
- package/__flow__/Token/index.test.js +28 -28
- package/__flow__/Token/styles.js +11 -11
- package/__flow__/TokenInput/index.flow.js +1 -1
- package/__flow__/TokenInput/index.js +39 -39
- package/__flow__/TokenInput/index.stories.js +121 -128
- package/__flow__/TokenInput/styles.js +5 -5
- package/__flow__/TokenInput/tests/default/clicking.test.js +13 -13
- package/__flow__/TokenInput/tests/default/deleting.test.js +39 -39
- package/__flow__/TokenInput/tests/default/focusing.test.js +18 -18
- package/__flow__/TokenInput/tests/default/inputting.test.js +23 -23
- package/__flow__/TokenInput/tests/default/pasting.test.js +52 -52
- package/__flow__/TokenInput/tests/default/rendering.test.js +54 -54
- package/__flow__/TokenInput/util.js +4 -4
- package/__flow__/Tooltip/index.js +21 -21
- package/__flow__/Tooltip/index.stories.js +18 -18
- package/__flow__/Tooltip/index.test.js +54 -54
- package/__flow__/Tooltip/styles.js +4 -5
- package/__flow__/VisuallyHidden/index.js +3 -3
- package/__flow__/building-stories.stories.mdx +121 -0
- package/__flow__/dataviz/dataviz.stories.js +4 -4
- package/__flow__/dataviz/index.js +3 -3
- package/__flow__/index.js +72 -72
- package/__flow__/overview.stories.js +60 -0
- package/__flow__/setupTests.js +5 -5
- package/__flow__/systemProps/background.js +3 -3
- package/__flow__/systemProps/border.js +3 -3
- package/__flow__/systemProps/color.js +3 -3
- package/__flow__/systemProps/custom.js +3 -3
- package/__flow__/systemProps/flexbox.js +3 -3
- package/__flow__/systemProps/grid.js +3 -3
- package/__flow__/systemProps/index.js +14 -14
- package/__flow__/systemProps/layout.js +3 -3
- package/__flow__/systemProps/position.js +3 -3
- package/__flow__/systemProps/shadow.js +3 -3
- package/__flow__/systemProps/space.js +3 -7
- package/__flow__/systemProps/systemProps.js +14 -14
- package/__flow__/systemProps/tests/background.test.js +17 -17
- package/__flow__/systemProps/tests/border.test.js +61 -61
- package/__flow__/systemProps/tests/color.test.js +15 -15
- package/__flow__/systemProps/tests/custom.test.js +12 -12
- package/__flow__/systemProps/tests/flexbox.test.js +33 -33
- package/__flow__/systemProps/tests/grid.test.js +31 -31
- package/__flow__/systemProps/tests/layout.test.js +29 -29
- package/__flow__/systemProps/tests/position.test.js +19 -19
- package/__flow__/systemProps/tests/shadow.test.js +11 -11
- package/__flow__/systemProps/tests/space.test.js +11 -11
- package/__flow__/systemProps/tests/types.flow.js +18 -18
- package/__flow__/systemProps/tests/typography.test.js +21 -21
- package/__flow__/systemProps/tests/variant.test.js +9 -9
- package/__flow__/systemProps/types.flow.js +2 -2
- package/__flow__/systemProps/typography.js +4 -4
- package/__flow__/systemProps/variant.js +5 -5
- package/__flow__/themes/dark/dataviz-palette.js +21 -21
- package/__flow__/themes/dark/decorative-palettes.js +1 -1
- package/__flow__/themes/dark/theme.js +18 -18
- package/__flow__/themes/extendedThemes/README.md +1 -1
- package/__flow__/themes/extendedThemes/sproutTheme/dark/theme.js +16 -4
- package/__flow__/themes/extendedThemes/sproutTheme/index.js +2 -2
- package/__flow__/themes/extendedThemes/sproutTheme/light/theme.js +16 -4
- package/__flow__/themes/light/dataviz-palette.js +21 -21
- package/__flow__/themes/light/decorative-palettes.js +1 -1
- package/__flow__/themes/light/literal-colors.js +133 -133
- package/__flow__/themes/light/theme.js +53 -53
- package/__flow__/types/system-props.flow.js +5 -5
- package/__flow__/types/theme.colors.flow.js +2 -2
- package/__flow__/types/theme.flow.js +5 -5
- package/__flow__/utils/a11yTest.js +1 -1
- package/__flow__/utils/chartColors.js +1 -1
- package/__flow__/utils/constants.js +1 -1
- package/__flow__/utils/dataQaLabelQueries.js +2 -2
- package/__flow__/utils/hooks.js +17 -17
- package/__flow__/utils/index.js +4 -4
- package/__flow__/utils/innerText.js +9 -9
- package/__flow__/utils/mixins.js +6 -6
- package/__flow__/utils/react-testing-library.js +6 -6
- package/__flow__/utils/responsiveProps/index.js +3 -3
- package/__flow__/utils/responsiveProps/index.test.js +8 -8
- package/__flow__/utils/system-props.js +3 -3
- package/__flow__/utils/useInteractiveColor.js +5 -5
- package/__flow__/writing-good-stories.stories.mdx +3 -0
- package/bin/racine-codemod.js +12 -12
- package/codemods/__tests__/migrate-2.x-to-3.x.test.js +2 -2
- package/codemods/migrate-2.x-to-3.x.js +29 -30
- package/commonjs/Avatar/index.js +33 -53
- package/commonjs/Badge/constants.js +18 -15
- package/commonjs/Badge/index.js +14 -28
- package/commonjs/Badge/styles.js +3 -9
- package/commonjs/Banner/index.js +16 -37
- package/commonjs/Banner/styles.js +0 -5
- package/commonjs/Box/index.js +2 -9
- package/commonjs/Box/styles.js +0 -4
- package/commonjs/Breadcrumb/index.js +13 -29
- package/commonjs/Breadcrumb/styles.js +1 -4
- package/commonjs/Button/index.js +29 -43
- package/commonjs/Button/styles.js +6 -15
- package/commonjs/Card/index.js +16 -26
- package/commonjs/Card/styles.js +1 -5
- package/commonjs/CharacterCounter/index.js +6 -23
- package/commonjs/CharacterCounter/styles.js +0 -5
- package/commonjs/ChartLegend/index.js +5 -20
- package/commonjs/ChartLegend/styles.js +2 -11
- package/commonjs/Checkbox/index.js +30 -53
- package/commonjs/Checkbox/styles.js +14 -35
- package/commonjs/Collapsible/index.js +31 -54
- package/commonjs/Collapsible/styles.js +3 -6
- package/commonjs/DatePicker/DateRangePicker.js +4 -17
- package/commonjs/DatePicker/SingleDatePicker.js +3 -17
- package/commonjs/DatePicker/StatefulDateRangePicker.js +16 -31
- package/commonjs/DatePicker/StatefulSingleDatePicker.js +7 -20
- package/commonjs/DatePicker/common.js +8 -22
- package/commonjs/DatePicker/index.js +0 -5
- package/commonjs/DatePicker/styles.js +8 -25
- package/commonjs/Drawer/SlideTransition.js +8 -18
- package/commonjs/Drawer/index.js +51 -90
- package/commonjs/Drawer/styles.js +0 -8
- package/commonjs/EmptyState/index.js +8 -20
- package/commonjs/Fieldset/index.js +15 -32
- package/commonjs/Fieldset/styles.js +2 -7
- package/commonjs/FormField/index.js +19 -36
- package/commonjs/Icon/deprecatedIcons.js +36 -36
- package/commonjs/Icon/index.js +19 -37
- package/commonjs/Icon/styles.js +8 -19
- package/commonjs/IllustrationViewBoxes.js +1 -0
- package/commonjs/Image/index.js +13 -41
- package/commonjs/Image/styles.js +1 -7
- package/commonjs/Indicator/index.js +8 -26
- package/commonjs/Indicator/styles.js +1 -7
- package/commonjs/Input/index.js +80 -119
- package/commonjs/Input/styles.js +9 -19
- package/commonjs/KeyboardKey/index.js +3 -20
- package/commonjs/KeyboardKey/styles.js +0 -4
- package/commonjs/Label/index.js +7 -27
- package/commonjs/Link/constants.js +3 -4
- package/commonjs/Link/index.js +16 -28
- package/commonjs/Link/styles.js +1 -8
- package/commonjs/Listbox/index.js +15 -36
- package/commonjs/Loader/index.js +15 -31
- package/commonjs/Loader/styles.js +2 -13
- package/commonjs/LoaderButton/index.js +37 -39
- package/commonjs/Menu/constants.js +9 -8
- package/commonjs/Menu/descendants.js +70 -105
- package/commonjs/Menu/hooks.js +23 -41
- package/commonjs/Menu/index.flow.js +0 -7
- package/commonjs/Menu/index.js +94 -164
- package/commonjs/Menu/names.js +1 -1
- package/commonjs/Menu/styles.js +0 -6
- package/commonjs/Message/index.js +37 -70
- package/commonjs/Message/styles.js +9 -24
- package/commonjs/Modal/index.js +31 -54
- package/commonjs/Modal/styles.js +17 -36
- package/commonjs/Numeral/index.js +39 -67
- package/commonjs/Numeral/styles.js +0 -3
- package/commonjs/Numeral/tests/testNumeral.js +13 -31
- package/commonjs/OverflowList/index.flow.js +0 -2
- package/commonjs/OverflowList/index.js +27 -41
- package/commonjs/OverflowList/styles.js +0 -7
- package/commonjs/PartnerLogo/index.js +22 -37
- package/commonjs/PartnerLogo/styles.js +7 -17
- package/commonjs/Popout/index.js +95 -127
- package/commonjs/Popout/styles.js +0 -5
- package/commonjs/Portal/index.js +8 -31
- package/commonjs/Radio/index.js +18 -42
- package/commonjs/Radio/styles.js +9 -21
- package/commonjs/SegmentedControl/index.js +17 -37
- package/commonjs/SegmentedControl/styles.js +2 -12
- package/commonjs/Select/index.js +24 -47
- package/commonjs/Select/styles.js +12 -24
- package/commonjs/Skeleton/index.js +0 -5
- package/commonjs/SpotIllustration/illustrationNames.js +1 -1
- package/commonjs/SpotIllustration/index.js +5 -11
- package/commonjs/Stack/index.js +27 -42
- package/commonjs/Switch/index.js +17 -42
- package/commonjs/Switch/styles.js +3 -11
- package/commonjs/Table/index.js +26 -50
- package/commonjs/Table/styles.js +0 -4
- package/commonjs/TableCell/index.js +12 -30
- package/commonjs/TableCell/styles.js +0 -5
- package/commonjs/TableHeaderCell/index.js +27 -56
- package/commonjs/TableHeaderCell/styles.js +0 -6
- package/commonjs/TableRowAccordion/index.js +12 -37
- package/commonjs/TableRowAccordion/styles.js +2 -9
- package/commonjs/Tabs/index.js +16 -66
- package/commonjs/Tabs/styles.js +2 -11
- package/commonjs/Text/index.js +12 -25
- package/commonjs/Text/styles.js +1 -6
- package/commonjs/Textarea/index.js +31 -55
- package/commonjs/Textarea/styles.js +2 -9
- package/commonjs/ThemeProvider/index.js +1 -10
- package/commonjs/Toast/index.js +19 -42
- package/commonjs/Toast/styles.js +1 -7
- package/commonjs/ToggleHint/index.js +15 -39
- package/commonjs/ToggleHint/styles.js +2 -9
- package/commonjs/Token/index.js +15 -29
- package/commonjs/Token/styles.js +5 -12
- package/commonjs/TokenInput/index.js +70 -122
- package/commonjs/TokenInput/styles.js +1 -7
- package/commonjs/TokenInput/util.js +2 -7
- package/commonjs/Tooltip/index.js +40 -63
- package/commonjs/Tooltip/styles.js +1 -5
- package/commonjs/VisuallyHidden/index.js +0 -4
- package/commonjs/dataviz/index.js +0 -4
- package/commonjs/index.js +0 -129
- package/commonjs/systemProps/background.js +0 -1
- package/commonjs/systemProps/border.js +0 -1
- package/commonjs/systemProps/color.js +0 -1
- package/commonjs/systemProps/custom.js +0 -1
- package/commonjs/systemProps/flexbox.js +0 -1
- package/commonjs/systemProps/grid.js +0 -1
- package/commonjs/systemProps/index.js +0 -28
- package/commonjs/systemProps/layout.js +0 -1
- package/commonjs/systemProps/position.js +0 -1
- package/commonjs/systemProps/shadow.js +0 -1
- package/commonjs/systemProps/space.js +1 -2
- package/commonjs/systemProps/systemProps.js +0 -13
- package/commonjs/systemProps/tests/types.flow.js +25 -22
- package/commonjs/systemProps/typography.js +0 -1
- package/commonjs/systemProps/variant.js +2 -3
- package/commonjs/themes/dark/dataviz-palette.js +20 -22
- package/commonjs/themes/dark/decorative-palettes.js +0 -2
- package/commonjs/themes/dark/theme.js +15 -29
- package/commonjs/themes/extendedThemes/sproutTheme/dark/theme.js +14 -9
- package/commonjs/themes/extendedThemes/sproutTheme/index.js +0 -5
- package/commonjs/themes/extendedThemes/sproutTheme/light/theme.js +14 -9
- package/commonjs/themes/light/dataviz-palette.js +20 -22
- package/commonjs/themes/light/decorative-palettes.js +0 -2
- package/commonjs/themes/light/literal-colors.js +132 -134
- package/commonjs/themes/light/theme.js +45 -61
- package/commonjs/types/system-props.flow.js +1 -1
- package/commonjs/types/theme.colors.flow.js +0 -2
- package/commonjs/types/theme.flow.js +0 -1
- package/commonjs/utils/a11yTest.js +3 -10
- package/commonjs/utils/chartColors.js +0 -1
- package/commonjs/utils/constants.js +1 -1
- package/commonjs/utils/dataQaLabelQueries.js +12 -21
- package/commonjs/utils/hooks.js +39 -70
- package/commonjs/utils/index.js +2 -9
- package/commonjs/utils/innerText.js +10 -14
- package/commonjs/utils/mixins.js +2 -7
- package/commonjs/utils/react-testing-library.js +4 -26
- package/commonjs/utils/responsiveProps/index.js +1 -11
- package/commonjs/utils/system-props.js +2 -5
- package/commonjs/utils/useInteractiveColor.js +6 -8
- package/dist/illustration.svg +1 -1
- package/dist/illustrationList.js +1 -1
- package/dist/themes/dark/theme.scss +2 -2
- package/dist/themes/extendedThemes/sproutTheme/dark/theme.scss +26 -2
- package/dist/themes/extendedThemes/sproutTheme/light/theme.scss +26 -2
- package/dist/themes/light/theme.scss +2 -2
- package/lib/Avatar/index.js +40 -47
- package/lib/Badge/constants.js +19 -15
- package/lib/Badge/index.js +18 -25
- package/lib/Badge/styles.js +8 -6
- package/lib/Banner/index.js +20 -32
- package/lib/Banner/styles.js +3 -2
- package/lib/Box/index.js +4 -5
- package/lib/Box/styles.js +3 -2
- package/lib/Breadcrumb/index.js +19 -27
- package/lib/Breadcrumb/styles.js +3 -2
- package/lib/Button/index.js +31 -38
- package/lib/Button/styles.js +14 -11
- package/lib/Card/index.js +18 -24
- package/lib/Card/styles.js +5 -4
- package/lib/CharacterCounter/index.js +8 -20
- package/lib/CharacterCounter/styles.js +3 -2
- package/lib/ChartLegend/index.js +9 -17
- package/lib/ChartLegend/styles.js +5 -4
- package/lib/Checkbox/index.js +32 -51
- package/lib/Checkbox/styles.js +21 -26
- package/lib/Collapsible/index.js +36 -51
- package/lib/Collapsible/styles.js +6 -5
- package/lib/DatePicker/DateRangePicker.js +8 -14
- package/lib/DatePicker/SingleDatePicker.js +7 -13
- package/lib/DatePicker/StatefulDateRangePicker.js +19 -26
- package/lib/DatePicker/StatefulSingleDatePicker.js +9 -15
- package/lib/DatePicker/common.js +14 -13
- package/lib/DatePicker/index.js +2 -2
- package/lib/DatePicker/styles.js +12 -22
- package/lib/Drawer/SlideTransition.js +11 -14
- package/lib/Drawer/index.js +64 -88
- package/lib/Drawer/styles.js +4 -3
- package/lib/EmptyState/index.js +11 -17
- package/lib/Fieldset/index.js +19 -29
- package/lib/Fieldset/styles.js +5 -4
- package/lib/FormField/index.js +27 -33
- package/lib/Icon/deprecatedIcons.js +36 -36
- package/lib/Icon/index.js +25 -34
- package/lib/Icon/styles.js +12 -16
- package/lib/IllustrationViewBoxes.js +1 -0
- package/lib/Image/index.js +15 -38
- package/lib/Image/styles.js +4 -4
- package/lib/Indicator/index.js +11 -23
- package/lib/Indicator/styles.js +5 -5
- package/lib/Input/index.js +87 -115
- package/lib/Input/styles.js +13 -15
- package/lib/KeyboardKey/index.js +6 -17
- package/lib/KeyboardKey/styles.js +3 -2
- package/lib/Label/index.js +10 -24
- package/lib/Link/constants.js +5 -4
- package/lib/Link/index.js +18 -25
- package/lib/Link/styles.js +6 -5
- package/lib/Listbox/index.js +21 -29
- package/lib/Loader/index.js +17 -29
- package/lib/Loader/styles.js +6 -8
- package/lib/LoaderButton/index.js +45 -34
- package/lib/Menu/constants.js +10 -8
- package/lib/Menu/descendants.js +73 -94
- package/lib/Menu/hooks.js +28 -39
- package/lib/Menu/index.flow.js +6 -5
- package/lib/Menu/index.js +113 -150
- package/lib/Menu/names.js +1 -1
- package/lib/Menu/styles.js +4 -3
- package/lib/Message/index.js +42 -66
- package/lib/Message/styles.js +15 -23
- package/lib/Modal/index.js +38 -51
- package/lib/Modal/styles.js +23 -32
- package/lib/Numeral/index.js +45 -64
- package/lib/Numeral/styles.js +3 -2
- package/lib/Numeral/tests/testNumeral.js +17 -27
- package/lib/OverflowList/index.flow.js +2 -1
- package/lib/OverflowList/index.js +31 -38
- package/lib/OverflowList/styles.js +5 -4
- package/lib/PartnerLogo/index.js +26 -35
- package/lib/PartnerLogo/styles.js +11 -14
- package/lib/Popout/index.js +105 -121
- package/lib/Popout/styles.js +3 -3
- package/lib/Portal/index.js +11 -29
- package/lib/Radio/index.js +20 -40
- package/lib/Radio/styles.js +14 -14
- package/lib/SegmentedControl/index.js +21 -34
- package/lib/SegmentedControl/styles.js +7 -9
- package/lib/Select/index.js +27 -44
- package/lib/Select/styles.js +16 -20
- package/lib/Skeleton/index.js +7 -4
- package/lib/SpotIllustration/illustrationNames.js +2 -1
- package/lib/SpotIllustration/index.js +9 -10
- package/lib/Stack/index.js +31 -39
- package/lib/Switch/index.js +21 -39
- package/lib/Switch/styles.js +8 -7
- package/lib/Table/index.js +30 -40
- package/lib/Table/styles.js +3 -2
- package/lib/TableCell/index.js +14 -27
- package/lib/TableCell/styles.js +3 -3
- package/lib/TableHeaderCell/index.js +30 -52
- package/lib/TableHeaderCell/styles.js +3 -2
- package/lib/TableRowAccordion/index.js +16 -34
- package/lib/TableRowAccordion/styles.js +5 -3
- package/lib/Tabs/index.js +18 -63
- package/lib/Tabs/styles.js +6 -6
- package/lib/Text/index.js +15 -21
- package/lib/Text/styles.js +4 -3
- package/lib/Textarea/index.js +33 -53
- package/lib/Textarea/styles.js +6 -5
- package/lib/ThemeProvider/index.js +4 -7
- package/lib/Toast/index.js +26 -37
- package/lib/Toast/styles.js +5 -4
- package/lib/ToggleHint/index.js +18 -36
- package/lib/ToggleHint/styles.js +6 -5
- package/lib/Token/index.js +20 -26
- package/lib/Token/styles.js +10 -9
- package/lib/TokenInput/index.js +78 -118
- package/lib/TokenInput/styles.js +5 -4
- package/lib/TokenInput/util.js +5 -3
- package/lib/Tooltip/index.js +45 -60
- package/lib/Tooltip/styles.js +4 -4
- package/lib/VisuallyHidden/index.js +3 -2
- package/lib/dataviz/index.js +4 -3
- package/lib/index.js +66 -64
- package/lib/systemProps/background.js +3 -1
- package/lib/systemProps/border.js +3 -1
- package/lib/systemProps/color.js +3 -1
- package/lib/systemProps/custom.js +3 -1
- package/lib/systemProps/flexbox.js +3 -1
- package/lib/systemProps/grid.js +3 -1
- package/lib/systemProps/index.js +16 -14
- package/lib/systemProps/layout.js +3 -1
- package/lib/systemProps/position.js +3 -1
- package/lib/systemProps/shadow.js +3 -1
- package/lib/systemProps/space.js +2 -1
- package/lib/systemProps/systemProps.js +14 -13
- package/lib/systemProps/tests/types.flow.js +27 -22
- package/lib/systemProps/typography.js +3 -1
- package/lib/systemProps/variant.js +4 -3
- package/lib/themes/dark/dataviz-palette.js +23 -21
- package/lib/themes/dark/decorative-palettes.js +3 -1
- package/lib/themes/dark/theme.js +22 -25
- package/lib/themes/extendedThemes/sproutTheme/dark/theme.js +16 -7
- package/lib/themes/extendedThemes/sproutTheme/index.js +3 -2
- package/lib/themes/extendedThemes/sproutTheme/light/theme.js +16 -7
- package/lib/themes/light/dataviz-palette.js +23 -21
- package/lib/themes/light/decorative-palettes.js +3 -1
- package/lib/themes/light/literal-colors.js +135 -133
- package/lib/themes/light/theme.js +56 -57
- package/lib/types/system-props.flow.js +1 -1
- package/lib/types/theme.colors.flow.js +4 -2
- package/lib/types/theme.flow.js +3 -2
- package/lib/utils/a11yTest.js +5 -8
- package/lib/utils/chartColors.js +3 -1
- package/lib/utils/constants.js +3 -1
- package/lib/utils/dataQaLabelQueries.js +13 -21
- package/lib/utils/hooks.js +41 -64
- package/lib/utils/index.js +2 -5
- package/lib/utils/innerText.js +12 -14
- package/lib/utils/mixins.js +6 -5
- package/lib/utils/react-testing-library.js +10 -20
- package/lib/utils/responsiveProps/index.js +3 -8
- package/lib/utils/system-props.js +4 -3
- package/lib/utils/useInteractiveColor.js +10 -9
- package/package.json +6 -13
package/__flow__/Menu/styles.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
// @flow
|
|
2
|
-
import styled, {
|
|
3
|
-
import Box from
|
|
4
|
-
import type {
|
|
5
|
-
import type {
|
|
6
|
-
import {
|
|
2
|
+
import styled, {css} from 'styled-components';
|
|
3
|
+
import Box from '../Box';
|
|
4
|
+
import type {TypeMenuItemProps} from './index.flow';
|
|
5
|
+
import type {TypeTheme} from '../types/theme.flow';
|
|
6
|
+
import {disabled, focusRing} from '../utils/mixins';
|
|
7
7
|
|
|
8
8
|
export const MenuItemContainer = styled<
|
|
9
9
|
typeof Box,
|
|
@@ -1,33 +1,33 @@
|
|
|
1
1
|
// @flow
|
|
2
|
-
import * as React from
|
|
2
|
+
import * as React from 'react';
|
|
3
3
|
import Container, {
|
|
4
4
|
MessageBody,
|
|
5
5
|
MessageFooter,
|
|
6
6
|
MessageHeader,
|
|
7
7
|
MessageMeta,
|
|
8
|
-
} from
|
|
9
|
-
import Checkbox, {
|
|
10
|
-
import Button, {
|
|
11
|
-
import Avatar, {
|
|
8
|
+
} from './styles';
|
|
9
|
+
import Checkbox, {type TypeProps as TypeCheckboxProps} from '../Checkbox';
|
|
10
|
+
import Button, {type TypeProps as TypeButtonProps} from '../Button';
|
|
11
|
+
import Avatar, {type TypeProps as TypeAvatarProps} from '../Avatar';
|
|
12
12
|
|
|
13
13
|
const MESSAGE_DENSITIES = {
|
|
14
|
-
COMPACT:
|
|
15
|
-
CONDENSED:
|
|
16
|
-
SMALL:
|
|
17
|
-
LARGE:
|
|
14
|
+
COMPACT: 'compact', // Compact is deprecated. New applications should use condensed instead.
|
|
15
|
+
CONDENSED: 'condensed',
|
|
16
|
+
SMALL: 'small',
|
|
17
|
+
LARGE: 'large',
|
|
18
18
|
};
|
|
19
19
|
|
|
20
20
|
const avatarSizeMap = (density) => {
|
|
21
21
|
switch (density) {
|
|
22
22
|
case MESSAGE_DENSITIES.LARGE:
|
|
23
|
-
return
|
|
23
|
+
return '40px';
|
|
24
24
|
case MESSAGE_DENSITIES.COMPACT:
|
|
25
|
-
return
|
|
25
|
+
return '20px';
|
|
26
26
|
case MESSAGE_DENSITIES.CONDENSED:
|
|
27
|
-
return
|
|
27
|
+
return '24px';
|
|
28
28
|
case MESSAGE_DENSITIES.SMALL:
|
|
29
29
|
default:
|
|
30
|
-
return
|
|
30
|
+
return '32px';
|
|
31
31
|
}
|
|
32
32
|
};
|
|
33
33
|
|
|
@@ -37,7 +37,7 @@ export type TypeProps = {
|
|
|
37
37
|
/** Condensed, small, or large. */
|
|
38
38
|
density?: EnumDensities,
|
|
39
39
|
children: React.ChildrenArray<React.Element<any> | null>,
|
|
40
|
-
innerRef?: React.Ref<
|
|
40
|
+
innerRef?: React.Ref<'div'>,
|
|
41
41
|
borderColor?: string, // seeds borderColor tokens (enum when flow types are available)
|
|
42
42
|
bg?: string, // seeds color tokens (enum when flow types are available)
|
|
43
43
|
indentContent?: boolean,
|
|
@@ -47,23 +47,23 @@ export type TypeProps = {
|
|
|
47
47
|
// $FlowIssue Upgrade 0.111.1
|
|
48
48
|
const MessageContext = React.createContext({
|
|
49
49
|
density: MESSAGE_DENSITIES.SMALL,
|
|
50
|
-
borderColor:
|
|
51
|
-
bg:
|
|
50
|
+
borderColor: 'container.border.base',
|
|
51
|
+
bg: 'container.background.base',
|
|
52
52
|
indentContent: true,
|
|
53
53
|
});
|
|
54
54
|
|
|
55
55
|
const Message = ({
|
|
56
56
|
children,
|
|
57
57
|
density = MESSAGE_DENSITIES.SMALL,
|
|
58
|
-
borderColor =
|
|
59
|
-
bg =
|
|
58
|
+
borderColor = 'container.border.base',
|
|
59
|
+
bg = 'container.background.base',
|
|
60
60
|
indentContent = true,
|
|
61
61
|
innerRef,
|
|
62
62
|
qa,
|
|
63
63
|
...rest
|
|
64
64
|
}: TypeProps) => {
|
|
65
65
|
return (
|
|
66
|
-
<MessageContext.Provider value={{
|
|
66
|
+
<MessageContext.Provider value={{density, borderColor, indentContent}}>
|
|
67
67
|
<Container
|
|
68
68
|
borderColor={borderColor}
|
|
69
69
|
bg={bg}
|
|
@@ -81,7 +81,7 @@ const Message = ({
|
|
|
81
81
|
|
|
82
82
|
Message.Body = (props) => (
|
|
83
83
|
<MessageContext.Consumer>
|
|
84
|
-
{({
|
|
84
|
+
{({density, borderColor, indentContent}) => (
|
|
85
85
|
<MessageBody
|
|
86
86
|
data-qa-message-body
|
|
87
87
|
density={density}
|
|
@@ -92,20 +92,20 @@ Message.Body = (props) => (
|
|
|
92
92
|
)}
|
|
93
93
|
</MessageContext.Consumer>
|
|
94
94
|
);
|
|
95
|
-
Message.Body.displayName =
|
|
95
|
+
Message.Body.displayName = 'Message.Body';
|
|
96
96
|
|
|
97
97
|
Message.Header = (props) => (
|
|
98
98
|
<MessageContext.Consumer>
|
|
99
|
-
{({
|
|
99
|
+
{({density, borderColor}) => (
|
|
100
100
|
<MessageHeader density={density} borderColor={borderColor} {...props} />
|
|
101
101
|
)}
|
|
102
102
|
</MessageContext.Consumer>
|
|
103
103
|
);
|
|
104
|
-
Message.Header.displayName =
|
|
104
|
+
Message.Header.displayName = 'Message.Header';
|
|
105
105
|
|
|
106
106
|
Message.Footer = (props) => (
|
|
107
107
|
<MessageContext.Consumer>
|
|
108
|
-
{({
|
|
108
|
+
{({density, borderColor, indentContent}) => (
|
|
109
109
|
<MessageFooter
|
|
110
110
|
density={density}
|
|
111
111
|
borderColor={borderColor}
|
|
@@ -115,11 +115,11 @@ Message.Footer = (props) => (
|
|
|
115
115
|
)}
|
|
116
116
|
</MessageContext.Consumer>
|
|
117
117
|
);
|
|
118
|
-
Message.Footer.displayName =
|
|
118
|
+
Message.Footer.displayName = 'Message.Footer';
|
|
119
119
|
|
|
120
120
|
Message.Meta = (props) => (
|
|
121
121
|
<MessageContext.Consumer>
|
|
122
|
-
{({
|
|
122
|
+
{({density, borderColor, indentContent}) => (
|
|
123
123
|
<MessageMeta
|
|
124
124
|
density={density}
|
|
125
125
|
borderColor={borderColor}
|
|
@@ -129,29 +129,29 @@ Message.Meta = (props) => (
|
|
|
129
129
|
)}
|
|
130
130
|
</MessageContext.Consumer>
|
|
131
131
|
);
|
|
132
|
-
Message.Meta.displayName =
|
|
132
|
+
Message.Meta.displayName = 'Message.Meta';
|
|
133
133
|
|
|
134
134
|
Message.Button = (props: TypeButtonProps) => (
|
|
135
|
-
<Button {...props} appearance={props.appearance ||
|
|
135
|
+
<Button {...props} appearance={props.appearance || 'pill'} />
|
|
136
136
|
);
|
|
137
|
-
Message.Button.displayName =
|
|
137
|
+
Message.Button.displayName = 'Message.Button';
|
|
138
138
|
|
|
139
139
|
Message.Avatar = (props: TypeAvatarProps) => (
|
|
140
140
|
<MessageContext.Consumer>
|
|
141
|
-
{({
|
|
141
|
+
{({density}) => <Avatar size={avatarSizeMap(density)} {...props} />}
|
|
142
142
|
</MessageContext.Consumer>
|
|
143
143
|
);
|
|
144
|
-
Message.Avatar.displayName =
|
|
144
|
+
Message.Avatar.displayName = 'Message.Avatar';
|
|
145
145
|
|
|
146
146
|
Message.Checkbox = (props: TypeCheckboxProps) => (
|
|
147
147
|
<MessageContext.Consumer>
|
|
148
|
-
{({
|
|
148
|
+
{({density}) => (
|
|
149
149
|
// $FlowIssue - upgrade v0.112.0
|
|
150
150
|
<Checkbox appearance="pill" density={density} {...props} />
|
|
151
151
|
)}
|
|
152
152
|
</MessageContext.Consumer>
|
|
153
153
|
);
|
|
154
|
-
Message.Checkbox.displayName =
|
|
154
|
+
Message.Checkbox.displayName = 'Message.Checkbox';
|
|
155
155
|
|
|
156
156
|
Message.Context = MessageContext;
|
|
157
157
|
Message.DENSITIES = MESSAGE_DENSITIES;
|
|
@@ -1,20 +1,25 @@
|
|
|
1
1
|
// @flow
|
|
2
|
-
import React from
|
|
3
|
-
import Message, {
|
|
4
|
-
import Box from
|
|
5
|
-
import Icon from
|
|
6
|
-
import { select } from "@storybook/addon-knobs";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import Message, {type EnumDensities} from './index';
|
|
4
|
+
import Box from '../Box';
|
|
5
|
+
import Icon from '../Icon';
|
|
7
6
|
|
|
8
7
|
export default {
|
|
9
|
-
title:
|
|
8
|
+
title: 'Components/Message',
|
|
9
|
+
component: Message,
|
|
10
|
+
argTypes: {
|
|
11
|
+
density: {
|
|
12
|
+
options: ['condensed', 'compact', 'small', 'large'],
|
|
13
|
+
control: {type: 'select'},
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
args: {
|
|
17
|
+
density: 'condensed',
|
|
18
|
+
},
|
|
10
19
|
};
|
|
11
20
|
|
|
12
21
|
export const defaultStory = ({
|
|
13
|
-
density =
|
|
14
|
-
"Density",
|
|
15
|
-
["condensed", "compact", "small", "large"],
|
|
16
|
-
"condensed"
|
|
17
|
-
),
|
|
22
|
+
density = 'condensed',
|
|
18
23
|
}: {
|
|
19
24
|
density?: EnumDensities,
|
|
20
25
|
}) => (
|
|
@@ -22,7 +27,7 @@ export const defaultStory = ({
|
|
|
22
27
|
<Message.Header>
|
|
23
28
|
<Box display="flex" alignItems="center">
|
|
24
29
|
<Message.Avatar
|
|
25
|
-
mr={density ===
|
|
30
|
+
mr={density === 'condensed' || density === 'compact' ? 350 : 400}
|
|
26
31
|
appearance="leaf"
|
|
27
32
|
name="Chase McCoy"
|
|
28
33
|
/>
|
|
@@ -64,5 +69,5 @@ export const defaultStory = ({
|
|
|
64
69
|
);
|
|
65
70
|
|
|
66
71
|
defaultStory.story = {
|
|
67
|
-
name:
|
|
72
|
+
name: 'Default',
|
|
68
73
|
};
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
// @flow
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
2
|
+
import {render} from '../utils/react-testing-library';
|
|
3
|
+
import 'jest-styled-components';
|
|
4
|
+
import {defaultStory as defaultMessageStory} from './index.stories';
|
|
5
5
|
|
|
6
|
-
describe(
|
|
7
|
-
it(
|
|
8
|
-
const {
|
|
6
|
+
describe('Message', () => {
|
|
7
|
+
it('should render properly', async () => {
|
|
8
|
+
const {container, runA11yCheck} = render(defaultMessageStory({}));
|
|
9
9
|
expect(container).toBeTruthy();
|
|
10
10
|
await runA11yCheck();
|
|
11
11
|
});
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
//@flow
|
|
2
|
-
import {
|
|
3
|
-
import styled from
|
|
4
|
-
import Box from
|
|
5
|
-
import {
|
|
6
|
-
import Message from
|
|
7
|
-
import type {
|
|
8
|
-
import type {
|
|
2
|
+
import {memo} from 'react';
|
|
3
|
+
import styled from 'styled-components';
|
|
4
|
+
import Box from '../Box';
|
|
5
|
+
import {focusRing} from '../utils/mixins';
|
|
6
|
+
import Message from '../Message';
|
|
7
|
+
import type {TypeProps} from '../Message';
|
|
8
|
+
import type {TypeTheme} from '../types/theme.flow';
|
|
9
9
|
|
|
10
10
|
const Container = styled<typeof Box, TypeTheme, any>(Box)`
|
|
11
11
|
border-radius: ${(props) => props.theme.radii.outer};
|
|
@@ -16,7 +16,7 @@ const Container = styled<typeof Box, TypeTheme, any>(Box)`
|
|
|
16
16
|
${focusRing} transition: box-shadow 0.15s;
|
|
17
17
|
}
|
|
18
18
|
`;
|
|
19
|
-
Container.displayName =
|
|
19
|
+
Container.displayName = 'Message.Container';
|
|
20
20
|
|
|
21
21
|
// $FlowIssue Upgrade 0.111.1
|
|
22
22
|
export const MessageHeader = memo(styled(Box)`
|
|
@@ -45,25 +45,25 @@ const getContentPadding = (props) => {
|
|
|
45
45
|
switch (props.density) {
|
|
46
46
|
case Message.DENSITIES.LARGE: {
|
|
47
47
|
// 40 px avatar + 8px(message.header) + 16px(mr)
|
|
48
|
-
return
|
|
48
|
+
return '64px';
|
|
49
49
|
}
|
|
50
50
|
case Message.DENSITIES.COMPACT: {
|
|
51
51
|
// 20px avatar plus space.300 margin plus space.400 margin
|
|
52
|
-
return
|
|
52
|
+
return '40px';
|
|
53
53
|
}
|
|
54
54
|
case Message.DENSITIES.CONDENSED: {
|
|
55
55
|
// 24px avatar plus space.200 margin plus space.350 margin
|
|
56
|
-
return
|
|
56
|
+
return '40px';
|
|
57
57
|
}
|
|
58
58
|
case Message.DENSITIES.SMALL:
|
|
59
59
|
default: {
|
|
60
60
|
// 32px avatar plus space.300 margin plus space.400 margin
|
|
61
|
-
return
|
|
61
|
+
return '56px';
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
64
|
};
|
|
65
65
|
|
|
66
|
-
const messagePadding = ({
|
|
66
|
+
const messagePadding = ({density, theme}) => {
|
|
67
67
|
if (density === Message.DENSITIES.CONDENSED) {
|
|
68
68
|
return 0;
|
|
69
69
|
}
|
|
@@ -96,7 +96,7 @@ export const MessageFooter = styled<typeof Box, TypeTheme, TypeProps>(Box)`
|
|
|
96
96
|
justify-content: space-between;
|
|
97
97
|
align-items: center;
|
|
98
98
|
flex-wrap: ${(props) =>
|
|
99
|
-
props.density === Message.DENSITIES.CONDENSED ?
|
|
99
|
+
props.density === Message.DENSITIES.CONDENSED ? 'nowrap' : 'wrap'};
|
|
100
100
|
> :first-child {
|
|
101
101
|
margin-left: -${(props) => props.theme.space[350]};
|
|
102
102
|
}
|
|
@@ -119,7 +119,7 @@ export const MessageMeta = styled<typeof Box, TypeTheme, any>(Box)`
|
|
|
119
119
|
padding: ${(props) => props.theme.space[200]}
|
|
120
120
|
${(props) => props.theme.space[400]};
|
|
121
121
|
padding-left: ${(props) => getContentPadding(props)};
|
|
122
|
-
cursor: ${(props) => (props.onClick ?
|
|
122
|
+
cursor: ${(props) => (props.onClick ? 'pointer' : 'default')};
|
|
123
123
|
color: ${(props) => props.theme.colors.text.subtext};
|
|
124
124
|
&:focus {
|
|
125
125
|
${focusRing};
|
package/__flow__/Modal/index.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
// @flow
|
|
2
|
-
import * as React from
|
|
3
|
-
import {
|
|
4
|
-
import Box from
|
|
5
|
-
import Icon from
|
|
6
|
-
import Button from
|
|
7
|
-
import Text from
|
|
8
|
-
import {
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import {useContext} from 'react';
|
|
4
|
+
import Box from '../Box';
|
|
5
|
+
import Icon from '../Icon';
|
|
6
|
+
import Button from '../Button';
|
|
7
|
+
import Text from '../Text';
|
|
8
|
+
import {Container, Content, Header, Footer, Body} from './styles';
|
|
9
9
|
|
|
10
10
|
type TypeModalContext = $Shape<{
|
|
11
11
|
onClose: () => any,
|
|
@@ -25,7 +25,7 @@ type TypeModalHeaderProps = {
|
|
|
25
25
|
const ModalContext = React.createContext<TypeModalContext>({});
|
|
26
26
|
|
|
27
27
|
const ModalHeader = (props: TypeModalHeaderProps) => {
|
|
28
|
-
const {
|
|
28
|
+
const {title, subtitle, children, bordered, ...rest} = props;
|
|
29
29
|
|
|
30
30
|
return (
|
|
31
31
|
// $FlowIssue - upgrade v0.112.0
|
|
@@ -56,7 +56,7 @@ const ModalHeader = (props: TypeModalHeaderProps) => {
|
|
|
56
56
|
};
|
|
57
57
|
|
|
58
58
|
const ModalCloseButton = (props) => {
|
|
59
|
-
const {
|
|
59
|
+
const {onClose, closeButtonLabel} = useContext(ModalContext);
|
|
60
60
|
|
|
61
61
|
if (!onClose) return null;
|
|
62
62
|
|
|
@@ -78,7 +78,7 @@ const ModalFooter = (props: TypeModalFooterProps) => (
|
|
|
78
78
|
);
|
|
79
79
|
|
|
80
80
|
ModalFooter.defaultProps = {
|
|
81
|
-
bg:
|
|
81
|
+
bg: 'container.background.base',
|
|
82
82
|
};
|
|
83
83
|
|
|
84
84
|
type TypeModalContentProps = React.ElementProps<typeof Box> & {
|
|
@@ -87,8 +87,8 @@ type TypeModalContentProps = React.ElementProps<typeof Box> & {
|
|
|
87
87
|
|
|
88
88
|
const ModalContent = React.forwardRef(
|
|
89
89
|
// $FlowIssue - upgrade v0.112.0
|
|
90
|
-
({
|
|
91
|
-
const {
|
|
90
|
+
({children, ...rest}: TypeModalContentProps, ref) => {
|
|
91
|
+
const {label} = useContext(ModalContext);
|
|
92
92
|
return (
|
|
93
93
|
<Content data-qa-modal data-qa-label={label} ref={ref} {...rest}>
|
|
94
94
|
{children}
|
|
@@ -155,8 +155,8 @@ const Modal = (props: TypeModalProps) => {
|
|
|
155
155
|
width={width}
|
|
156
156
|
zIndex={zIndex}
|
|
157
157
|
data={{
|
|
158
|
-
|
|
159
|
-
|
|
158
|
+
'qa-modal': '',
|
|
159
|
+
'qa-modal-isopen': isOpen,
|
|
160
160
|
}}
|
|
161
161
|
// $FlowIssue - upgrade v0.112.0
|
|
162
162
|
{...rest}
|
|
@@ -183,13 +183,13 @@ Modal.Footer = ModalFooter;
|
|
|
183
183
|
Modal.Content = ModalContent;
|
|
184
184
|
Modal.CloseButton = ModalCloseButton;
|
|
185
185
|
|
|
186
|
-
Modal.Header.displayName =
|
|
187
|
-
Modal.Footer.displayName =
|
|
188
|
-
Modal.Content.displayName =
|
|
189
|
-
Modal.CloseButton.displayName =
|
|
186
|
+
Modal.Header.displayName = 'Modal.Header';
|
|
187
|
+
Modal.Footer.displayName = 'Modal.Footer';
|
|
188
|
+
Modal.Content.displayName = 'Modal.Content';
|
|
189
|
+
Modal.CloseButton.displayName = 'Modal.CloseButton';
|
|
190
190
|
|
|
191
191
|
Modal.defaultProps = {
|
|
192
|
-
width:
|
|
192
|
+
width: '800px',
|
|
193
193
|
zIndex: 6,
|
|
194
194
|
};
|
|
195
195
|
|
|
@@ -1,29 +1,29 @@
|
|
|
1
1
|
// @flow
|
|
2
|
-
import React from
|
|
3
|
-
import Component from
|
|
4
|
-
import Modal from
|
|
5
|
-
import Box from
|
|
6
|
-
import Button from
|
|
7
|
-
import Input from
|
|
8
|
-
import Text from
|
|
9
|
-
import FormField from
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import Component from '@reach/component-component';
|
|
4
|
+
import Modal from './';
|
|
5
|
+
import Box from '../Box';
|
|
6
|
+
import Button from '../Button';
|
|
7
|
+
import Input from '../Input';
|
|
8
|
+
import Text from '../Text';
|
|
9
|
+
import FormField from '../FormField';
|
|
10
10
|
|
|
11
11
|
export default {
|
|
12
|
-
title:
|
|
12
|
+
title: 'Components/Modal',
|
|
13
13
|
};
|
|
14
14
|
|
|
15
15
|
export const defaultStory = () => (
|
|
16
|
-
<Component initialState={{
|
|
17
|
-
{({
|
|
16
|
+
<Component initialState={{isOpen: false}}>
|
|
17
|
+
{({setState, state}) => (
|
|
18
18
|
<div>
|
|
19
|
-
<button onClick={() => setState({
|
|
19
|
+
<button onClick={() => setState({isOpen: !state.isOpen})}>
|
|
20
20
|
Open Modal
|
|
21
21
|
</button>
|
|
22
22
|
<Box height="2000px">Really tall box.</Box>
|
|
23
23
|
<Modal
|
|
24
24
|
appElementSelector="#root"
|
|
25
25
|
isOpen={state.isOpen}
|
|
26
|
-
onClose={() => setState({
|
|
26
|
+
onClose={() => setState({isOpen: !state.isOpen})}
|
|
27
27
|
closeButtonLabel="Close this dialog"
|
|
28
28
|
label="Example Modal"
|
|
29
29
|
>
|
|
@@ -71,14 +71,14 @@ export const defaultStory = () => (
|
|
|
71
71
|
);
|
|
72
72
|
|
|
73
73
|
defaultStory.story = {
|
|
74
|
-
name:
|
|
74
|
+
name: 'Default',
|
|
75
75
|
};
|
|
76
76
|
|
|
77
77
|
export const notCloseable = () => (
|
|
78
|
-
<Component initialState={{
|
|
79
|
-
{({
|
|
78
|
+
<Component initialState={{isOpen: false}}>
|
|
79
|
+
{({setState, state}) => (
|
|
80
80
|
<div>
|
|
81
|
-
<button onClick={() => setState({
|
|
81
|
+
<button onClick={() => setState({isOpen: !state.isOpen})}>
|
|
82
82
|
Open Modal
|
|
83
83
|
</button>
|
|
84
84
|
<Box height="2000px">Really tall box.</Box>
|
|
@@ -119,7 +119,7 @@ export const notCloseable = () => (
|
|
|
119
119
|
<Button
|
|
120
120
|
appearance="primary"
|
|
121
121
|
width={1}
|
|
122
|
-
onClick={() => setState({
|
|
122
|
+
onClick={() => setState({isOpen: !state.isOpen})}
|
|
123
123
|
>
|
|
124
124
|
Must click to close
|
|
125
125
|
</Button>
|
|
@@ -131,20 +131,20 @@ export const notCloseable = () => (
|
|
|
131
131
|
</Component>
|
|
132
132
|
);
|
|
133
133
|
notCloseable.story = {
|
|
134
|
-
name:
|
|
134
|
+
name: 'Not Closeable',
|
|
135
135
|
};
|
|
136
136
|
|
|
137
137
|
export const customHeader = () => (
|
|
138
|
-
<Component initialState={{
|
|
139
|
-
{({
|
|
138
|
+
<Component initialState={{isOpen: false}}>
|
|
139
|
+
{({setState, state}) => (
|
|
140
140
|
<div>
|
|
141
|
-
<button onClick={() => setState({
|
|
141
|
+
<button onClick={() => setState({isOpen: !state.isOpen})}>
|
|
142
142
|
Open Modal
|
|
143
143
|
</button>
|
|
144
144
|
<Modal
|
|
145
145
|
appElementSelector="#root"
|
|
146
146
|
isOpen={state.isOpen}
|
|
147
|
-
onClose={() => setState({
|
|
147
|
+
onClose={() => setState({isOpen: !state.isOpen})}
|
|
148
148
|
closeButtonLabel="Close this dialog"
|
|
149
149
|
label="Example Modal"
|
|
150
150
|
>
|
|
@@ -192,16 +192,16 @@ export const customHeader = () => (
|
|
|
192
192
|
</Component>
|
|
193
193
|
);
|
|
194
194
|
export const noFooter = () => (
|
|
195
|
-
<Component initialState={{
|
|
196
|
-
{({
|
|
195
|
+
<Component initialState={{isOpen: false}}>
|
|
196
|
+
{({setState, state}) => (
|
|
197
197
|
<div>
|
|
198
|
-
<button onClick={() => setState({
|
|
198
|
+
<button onClick={() => setState({isOpen: !state.isOpen})}>
|
|
199
199
|
Open Modal
|
|
200
200
|
</button>
|
|
201
201
|
<Modal
|
|
202
202
|
appElementSelector="#root"
|
|
203
203
|
isOpen={state.isOpen}
|
|
204
|
-
onClose={() => setState({
|
|
204
|
+
onClose={() => setState({isOpen: !state.isOpen})}
|
|
205
205
|
closeButtonLabel="Close this dialog"
|
|
206
206
|
label="Example Modal"
|
|
207
207
|
>
|
|
@@ -254,20 +254,20 @@ export const noFooter = () => (
|
|
|
254
254
|
</Component>
|
|
255
255
|
);
|
|
256
256
|
noFooter.story = {
|
|
257
|
-
name:
|
|
257
|
+
name: 'No footer',
|
|
258
258
|
};
|
|
259
259
|
|
|
260
260
|
export const noTitle = () => (
|
|
261
|
-
<Component initialState={{
|
|
262
|
-
{({
|
|
261
|
+
<Component initialState={{isOpen: false}}>
|
|
262
|
+
{({setState, state}) => (
|
|
263
263
|
<div>
|
|
264
|
-
<button onClick={() => setState({
|
|
264
|
+
<button onClick={() => setState({isOpen: !state.isOpen})}>
|
|
265
265
|
Open Modal
|
|
266
266
|
</button>
|
|
267
267
|
<Modal
|
|
268
268
|
appElementSelector="#root"
|
|
269
269
|
isOpen={state.isOpen}
|
|
270
|
-
onClose={() => setState({
|
|
270
|
+
onClose={() => setState({isOpen: !state.isOpen})}
|
|
271
271
|
closeButtonLabel="Close this dialog"
|
|
272
272
|
label="Example Modal"
|
|
273
273
|
>
|
|
@@ -312,21 +312,21 @@ export const noTitle = () => (
|
|
|
312
312
|
);
|
|
313
313
|
|
|
314
314
|
noTitle.story = {
|
|
315
|
-
name:
|
|
315
|
+
name: 'No title',
|
|
316
316
|
};
|
|
317
317
|
|
|
318
318
|
export const withForm = () => (
|
|
319
|
-
<Component initialState={{
|
|
320
|
-
{({
|
|
319
|
+
<Component initialState={{isOpen: false}}>
|
|
320
|
+
{({setState, state}) => (
|
|
321
321
|
<div>
|
|
322
|
-
<button onClick={() => setState({
|
|
322
|
+
<button onClick={() => setState({isOpen: !state.isOpen})}>
|
|
323
323
|
Open Modal
|
|
324
324
|
</button>
|
|
325
325
|
<Modal
|
|
326
326
|
width="500px"
|
|
327
327
|
appElementSelector="#root"
|
|
328
328
|
isOpen={state.isOpen}
|
|
329
|
-
onClose={() => setState({
|
|
329
|
+
onClose={() => setState({isOpen: !state.isOpen})}
|
|
330
330
|
closeButtonLabel="Close this dialog"
|
|
331
331
|
label="Example Modal"
|
|
332
332
|
>
|
|
@@ -362,14 +362,14 @@ export const withForm = () => (
|
|
|
362
362
|
);
|
|
363
363
|
|
|
364
364
|
withForm.story = {
|
|
365
|
-
name:
|
|
365
|
+
name: 'With Form',
|
|
366
366
|
};
|
|
367
367
|
|
|
368
368
|
export const customBackgroundColor = () => (
|
|
369
|
-
<Component initialState={{
|
|
370
|
-
{({
|
|
369
|
+
<Component initialState={{isOpen: false}}>
|
|
370
|
+
{({setState, state}) => (
|
|
371
371
|
<div>
|
|
372
|
-
<button onClick={() => setState({
|
|
372
|
+
<button onClick={() => setState({isOpen: !state.isOpen})}>
|
|
373
373
|
Open Modal
|
|
374
374
|
</button>
|
|
375
375
|
<Modal
|
|
@@ -377,7 +377,7 @@ export const customBackgroundColor = () => (
|
|
|
377
377
|
width="500px"
|
|
378
378
|
appElementSelector="#root"
|
|
379
379
|
isOpen={state.isOpen}
|
|
380
|
-
onClose={() => setState({
|
|
380
|
+
onClose={() => setState({isOpen: !state.isOpen})}
|
|
381
381
|
closeButtonLabel="Close this dialog"
|
|
382
382
|
label="Example Modal"
|
|
383
383
|
>
|
|
@@ -405,5 +405,5 @@ export const customBackgroundColor = () => (
|
|
|
405
405
|
);
|
|
406
406
|
|
|
407
407
|
customBackgroundColor.story = {
|
|
408
|
-
name:
|
|
408
|
+
name: 'Custom Background Color',
|
|
409
409
|
};
|