@kaizen/components 0.0.0-canary-codemod-tsx-20241030002309 → 0.0.0-canary-icon-cdn-css-20241108011645

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.
Files changed (60) hide show
  1. package/codemods/README.md +1 -1
  2. package/dist/cjs/ButtonGroup/ButtonGroup.cjs +1 -1
  3. package/dist/cjs/Filter/Filter/Filter.cjs +4 -1
  4. package/dist/cjs/Filter/Filter/Filter.module.css.cjs +6 -0
  5. package/dist/cjs/Filter/FilterBar/FilterBar.cjs +4 -2
  6. package/dist/cjs/Filter/FilterBar/FilterBar.module.css.cjs +8 -0
  7. package/dist/cjs/Filter/FilterBar/subcomponents/FilterBarButton/FilterBarButton.cjs +9 -3
  8. package/dist/cjs/Filter/FilterBar/subcomponents/FilterBarButton/FilterBarButton.module.css.cjs +6 -0
  9. package/dist/cjs/Filter/FilterBar/subcomponents/FilterBarMultiSelect/FilterBarMultiSelect.cjs +7 -2
  10. package/dist/cjs/Filter/FilterBar/subcomponents/FilterBarMultiSelect/FilterBarMultiSelect.module.css.cjs +6 -0
  11. package/dist/cjs/Filter/FilterButton/FilterButton/FilterButton.cjs +1 -1
  12. package/dist/cjs/Filter/FilterButton/FilterButton/FilterButton.module.css.cjs +9 -0
  13. package/dist/cjs/Filter/FilterButton/FilterButtonRemovable/FilterButtonRemovable.cjs +5 -1
  14. package/dist/cjs/Filter/FilterButton/FilterButtonRemovable/FilterButtonRemovable.module.css.cjs +6 -0
  15. package/dist/cjs/Filter/FilterMultiSelect/FilterMultiSelect.cjs +5 -2
  16. package/dist/cjs/Filter/FilterMultiSelect/subcomponents/Trigger/RemovableFilterTrigger/RemovableFilterTrigger.cjs +4 -1
  17. package/dist/cjs/Filter/FilterMultiSelect/subcomponents/Trigger/RemovableFilterTrigger/RemovableFilterTrigger.module.css.cjs +6 -0
  18. package/dist/esm/ButtonGroup/ButtonGroup.mjs +1 -1
  19. package/dist/esm/Filter/Filter/Filter.mjs +3 -1
  20. package/dist/esm/Filter/Filter/Filter.module.css.mjs +4 -0
  21. package/dist/esm/Filter/FilterBar/FilterBar.mjs +4 -2
  22. package/dist/esm/Filter/FilterBar/FilterBar.module.css.mjs +6 -0
  23. package/dist/esm/Filter/FilterBar/subcomponents/FilterBarButton/FilterBarButton.mjs +8 -3
  24. package/dist/esm/Filter/FilterBar/subcomponents/FilterBarButton/FilterBarButton.module.css.mjs +4 -0
  25. package/dist/esm/Filter/FilterBar/subcomponents/FilterBarMultiSelect/FilterBarMultiSelect.mjs +7 -2
  26. package/dist/esm/Filter/FilterBar/subcomponents/FilterBarMultiSelect/FilterBarMultiSelect.module.css.mjs +4 -0
  27. package/dist/esm/Filter/FilterButton/FilterButton/FilterButton.mjs +1 -1
  28. package/dist/esm/Filter/FilterButton/FilterButton/FilterButton.module.css.mjs +7 -0
  29. package/dist/esm/Filter/FilterButton/FilterButtonRemovable/FilterButtonRemovable.mjs +4 -1
  30. package/dist/esm/Filter/FilterButton/FilterButtonRemovable/FilterButtonRemovable.module.css.mjs +4 -0
  31. package/dist/esm/Filter/FilterMultiSelect/FilterMultiSelect.mjs +5 -2
  32. package/dist/esm/Filter/FilterMultiSelect/subcomponents/Trigger/RemovableFilterTrigger/RemovableFilterTrigger.mjs +3 -1
  33. package/dist/esm/Filter/FilterMultiSelect/subcomponents/Trigger/RemovableFilterTrigger/RemovableFilterTrigger.module.css.mjs +4 -0
  34. package/dist/styles.css +148 -114
  35. package/dist/types/Filter/FilterMultiSelect/FilterMultiSelect.d.ts +2 -1
  36. package/package.json +11 -9
  37. package/src/ButtonGroup/ButtonGroup.tsx +4 -1
  38. package/src/Filter/Filter/Filter.module.css +5 -0
  39. package/src/Filter/Filter/Filter.tsx +6 -1
  40. package/src/Filter/FilterBar/FilterBar.module.css +23 -0
  41. package/src/Filter/FilterBar/FilterBar.tsx +15 -13
  42. package/src/Filter/FilterBar/_docs/FilterBar.stories.tsx +5 -0
  43. package/src/Filter/FilterBar/subcomponents/FilterBarButton/FilterBarButton.module.css +3 -0
  44. package/src/Filter/FilterBar/subcomponents/FilterBarButton/FilterBarButton.tsx +36 -18
  45. package/src/Filter/FilterBar/subcomponents/FilterBarMultiSelect/FilterBarMultiSelect.module.css +5 -0
  46. package/src/Filter/FilterBar/subcomponents/FilterBarMultiSelect/FilterBarMultiSelect.tsx +7 -1
  47. package/src/Filter/FilterButton/FilterButton/FilterButton.module.css +23 -0
  48. package/src/Filter/FilterButton/FilterButton/FilterButton.tsx +1 -1
  49. package/src/Filter/FilterButton/FilterButtonRemovable/FilterButtonRemovable.module.css +3 -0
  50. package/src/Filter/FilterButton/FilterButtonRemovable/FilterButtonRemovable.tsx +10 -1
  51. package/src/Filter/FilterButton/subcomponents/FilterButtonBase/FilterButtonBase.module.scss +2 -2
  52. package/src/Filter/FilterMultiSelect/FilterMultiSelect.tsx +3 -1
  53. package/src/Filter/FilterMultiSelect/subcomponents/Trigger/RemovableFilterTrigger/RemovableFilterTrigger.module.css +3 -0
  54. package/src/Filter/FilterMultiSelect/subcomponents/Trigger/RemovableFilterTrigger/RemovableFilterTrigger.tsx +6 -1
  55. package/dist/cjs/Filter/FilterBar/FilterBar.module.scss.cjs +0 -7
  56. package/dist/cjs/Filter/FilterButton/FilterButton/FilterButton.module.scss.cjs +0 -9
  57. package/dist/esm/Filter/FilterBar/FilterBar.module.scss.mjs +0 -5
  58. package/dist/esm/Filter/FilterButton/FilterButton/FilterButton.module.scss.mjs +0 -7
  59. package/src/Filter/FilterBar/FilterBar.module.scss +0 -19
  60. package/src/Filter/FilterButton/FilterButton/FilterButton.module.scss +0 -22
@@ -1,4 +1,5 @@
1
1
  import React, { forwardRef, useEffect } from "react"
2
+ import classnames from "classnames"
2
3
  import { FilterTriggerRef } from "~components/Filter/Filter"
3
4
  import { useFilterBarContext } from "~components/Filter/FilterBar/context/FilterBarContext"
4
5
  import {
@@ -7,6 +8,7 @@ import {
7
8
  FilterButtonRemovable,
8
9
  } from "~components/Filter/FilterButton"
9
10
  import { isRefObject } from "~components/utils/isRefObject"
11
+ import styles from "./FilterBarButton.module.css"
10
12
 
11
13
  export type FilterBarButtonProps = FilterButtonProps & {
12
14
  filterId: string
@@ -16,25 +18,41 @@ export type FilterBarButtonProps = FilterButtonProps & {
16
18
  export const FilterBarButton = forwardRef<
17
19
  FilterTriggerRef,
18
20
  FilterBarButtonProps
19
- >(({ filterId, isRemovable = false, ...props }, ref): JSX.Element => {
20
- const { hideFilter, focusId, setFocus } = useFilterBarContext()
21
+ >(
22
+ (
23
+ { filterId, isRemovable = false, classNameOverride, ...props },
24
+ ref
25
+ ): JSX.Element => {
26
+ const { hideFilter, focusId, setFocus } = useFilterBarContext()
21
27
 
22
- useEffect(() => {
23
- if (focusId === filterId && isRefObject(ref)) {
24
- ref?.current?.triggerRef?.current?.focus()
25
- setFocus(undefined)
26
- }
27
- }, [focusId])
28
+ useEffect(() => {
29
+ if (focusId === filterId && isRefObject(ref)) {
30
+ ref?.current?.triggerRef?.current?.focus()
31
+ setFocus(undefined)
32
+ }
33
+ }, [focusId])
28
34
 
29
- return isRemovable ? (
30
- <FilterButtonRemovable
31
- ref={ref}
32
- triggerButtonProps={props}
33
- removeButtonProps={{ onClick: () => hideFilter(filterId) }}
34
- />
35
- ) : (
36
- <FilterButton ref={ref} {...props} />
37
- )
38
- })
35
+ return isRemovable ? (
36
+ <FilterButtonRemovable
37
+ ref={ref}
38
+ triggerButtonProps={props}
39
+ removeButtonProps={{ onClick: () => hideFilter(filterId) }}
40
+ classNameOverride={classnames(
41
+ classNameOverride,
42
+ styles.filterBarButton
43
+ )}
44
+ />
45
+ ) : (
46
+ <FilterButton
47
+ ref={ref}
48
+ classNameOverride={classnames(
49
+ classNameOverride,
50
+ styles.filterBarButton
51
+ )}
52
+ {...props}
53
+ />
54
+ )
55
+ }
56
+ )
39
57
 
40
58
  FilterBarButton.displayName = "FilterBar.Button"
@@ -0,0 +1,5 @@
1
+ @media (width < 768px) {
2
+ .filterMultiSelect {
3
+ flex-basis: 100%;
4
+ }
5
+ }
@@ -8,6 +8,7 @@ import {
8
8
  } from "~components/Filter/FilterMultiSelect"
9
9
  import { useFilterBarContext } from "../../context/FilterBarContext"
10
10
  import { checkArraysMatch } from "../../utils/checkArraysMatch"
11
+ import styles from "./FilterBarMultiSelect.module.css"
11
12
 
12
13
  export type FilterBarMultiSelectProps = Omit<
13
14
  FilterMultiSelectProps,
@@ -97,6 +98,7 @@ export const FilterBarMultiSelect = ({
97
98
  items={items}
98
99
  isOpen={filterState.isOpen}
99
100
  onOpenChange={(open): void => setFilterOpenState(id, open)}
101
+ className={styles.filterMultiSelect}
100
102
  trigger={(): JSX.Element => {
101
103
  const triggerProps = {
102
104
  selectedOptionLabels: filterState.value
@@ -112,9 +114,13 @@ export const FilterBarMultiSelect = ({
112
114
  <FilterMultiSelect.RemovableTrigger
113
115
  {...triggerProps}
114
116
  onRemove={() => hideFilter(id)}
117
+ classNameOverride={styles.triggerButton}
115
118
  />
116
119
  ) : (
117
- <FilterMultiSelect.TriggerButton {...triggerProps} />
120
+ <FilterMultiSelect.TriggerButton
121
+ classNameOverride={styles.triggerButton}
122
+ {...triggerProps}
123
+ />
118
124
  )
119
125
  }}
120
126
  triggerRef={buttonRef}
@@ -0,0 +1,23 @@
1
+ .filterButton {
2
+ gap: var(--spacing-6);
3
+ justify-content: space-between;
4
+ }
5
+
6
+ @media (width < 768px) {
7
+ .filterButton {
8
+ flex-grow: 1;
9
+ }
10
+ }
11
+
12
+ .labelContainer {
13
+ display: inline-flex;
14
+ flex-wrap: wrap;
15
+ }
16
+
17
+ .hasSelectedValues {
18
+ font-weight: bold;
19
+ }
20
+
21
+ .labelSeparator {
22
+ margin-inline-end: var(--spacing-6);
23
+ }
@@ -7,7 +7,7 @@ import {
7
7
  FilterButtonBase,
8
8
  FilterButtonBaseProps,
9
9
  } from "../subcomponents/FilterButtonBase"
10
- import styles from "./FilterButton.module.scss"
10
+ import styles from "./FilterButton.module.css"
11
11
 
12
12
  export type FilterButtonProps = {
13
13
  label: string
@@ -0,0 +1,3 @@
1
+ .filterButtonBase {
2
+ height: 100%;
3
+ }
@@ -1,5 +1,6 @@
1
1
  import React, { forwardRef } from "react"
2
2
  import { useIntl } from "@cultureamp/i18n-react-intl"
3
+ import classnames from "classnames"
3
4
  import { ButtonGroup, ButtonGroupProps } from "~components/ButtonGroup"
4
5
  import { FilterTriggerRef } from "~components/Filter/Filter"
5
6
  import { Icon } from "~components/__future__/Icon"
@@ -11,6 +12,7 @@ import {
11
12
  FilterButtonBase,
12
13
  FilterButtonBaseProps,
13
14
  } from "../subcomponents/FilterButtonBase"
15
+ import styles from "./FilterButtonRemovable.module.css"
14
16
 
15
17
  export type FilterButtonRemovableProps = {
16
18
  triggerButtonProps: FilterButtonProps & DataAttributes
@@ -49,7 +51,14 @@ export const FilterButtonRemovable = forwardRef<
49
51
  <ButtonGroup {...restProps}>
50
52
  <FilterButton ref={ref} {...triggerButtonProps} />
51
53
  <Tooltip text={removeButtonLabel} display="inline-block" position="below">
52
- <FilterButtonBase ref={removeButtonRef} {...removeButtonProps}>
54
+ <FilterButtonBase
55
+ ref={removeButtonRef}
56
+ classNameOverride={classnames(
57
+ styles.filterButtonBase,
58
+ restProps.classNameOverride
59
+ )}
60
+ {...removeButtonProps}
61
+ >
53
62
  <Icon name="cancel" alt={removeButtonLabel} isFilled />
54
63
  </FilterButtonBase>
55
64
  </Tooltip>
@@ -13,7 +13,7 @@
13
13
  position: relative;
14
14
  display: inline-flex;
15
15
  align-items: center;
16
- height: 3rem; // 48px
16
+ min-height: 3rem; // 48px
17
17
  padding: $spacing-sm;
18
18
  border-width: 0;
19
19
  border-radius: $border-solid-border-radius;
@@ -24,7 +24,7 @@
24
24
  line-height: $typography-button-secondary-line-height;
25
25
  letter-spacing: $typography-button-secondary-letter-spacing;
26
26
  color: $color-blue-500;
27
- white-space: nowrap;
27
+ text-align: start;
28
28
 
29
29
  &:hover,
30
30
  &:active {
@@ -42,6 +42,7 @@ export type FilterMultiSelectProps = {
42
42
  trigger: (value?: MenuTriggerProviderContextType) => React.ReactNode
43
43
  children: (value?: SelectionProviderContextType) => React.ReactNode // the content of the menu
44
44
  triggerRef?: React.RefObject<HTMLButtonElement>
45
+ className?: string
45
46
  } & Omit<MenuPopupProps, "children"> &
46
47
  Omit<MenuTriggerProviderProps, "children"> &
47
48
  SelectionProps
@@ -62,6 +63,7 @@ export const FilterMultiSelect = ({
62
63
  selectionMode = "multiple",
63
64
  onSearchInputChange,
64
65
  triggerRef,
66
+ className,
65
67
  }: FilterMultiSelectProps): JSX.Element => {
66
68
  const menuTriggerProps = { isOpen, defaultOpen, onOpenChange, triggerRef }
67
69
  const menuPopupProps = { isLoading, loadingSkeleton }
@@ -83,7 +85,7 @@ export const FilterMultiSelect = ({
83
85
 
84
86
  return (
85
87
  <MenuTriggerProvider {...menuTriggerProps}>
86
- <div>
88
+ <div className={className}>
87
89
  <MenuTriggerConsumer>{trigger}</MenuTriggerConsumer>
88
90
  <MenuPopup {...menuPopupProps}>
89
91
  <SelectionProvider {...selectionProps}>
@@ -1,9 +1,11 @@
1
1
  import React, { useRef } from "react"
2
+ import classnames from "classnames"
2
3
  import { FilterTriggerRef } from "~components/Filter/Filter"
3
4
  import { FilterButtonRemovable } from "~components/Filter/FilterButton"
4
5
  import { useMenuTriggerContext } from "../../../context"
5
6
  import { getTruncatedLabels } from "../../../utils"
6
7
  import { FilterTriggerButtonProps } from "../FilterTriggerButton"
8
+ import styles from "./RemovableFilterTrigger.module.css"
7
9
 
8
10
  export type RemovableFilterTriggerProps = FilterTriggerButtonProps & {
9
11
  onRemove: () => void
@@ -22,7 +24,10 @@ export const RemovableFilterTrigger = ({
22
24
  return (
23
25
  <FilterButtonRemovable
24
26
  ref={ref}
25
- classNameOverride={classNameOverride}
27
+ classNameOverride={classnames(
28
+ styles.filterButtonRemovable,
29
+ classNameOverride
30
+ )}
26
31
  triggerButtonProps={{
27
32
  ...buttonProps,
28
33
  label,
@@ -1,7 +0,0 @@
1
- 'use strict';
2
-
3
- var styles = {
4
- "filterBar": "FilterBar-module_filterBar__ZhQLn",
5
- "filtersContainer": "FilterBar-module_filtersContainer__v6OJn"
6
- };
7
- module.exports = styles;
@@ -1,9 +0,0 @@
1
- 'use strict';
2
-
3
- var styles = {
4
- "filterButton": "FilterButton-module_filterButton__PEcAs",
5
- "labelContainer": "FilterButton-module_labelContainer__kJlE8",
6
- "hasSelectedValues": "FilterButton-module_hasSelectedValues__tc-XE",
7
- "labelSeparator": "FilterButton-module_labelSeparator__CmSqS"
8
- };
9
- module.exports = styles;
@@ -1,5 +0,0 @@
1
- var styles = {
2
- "filterBar": "FilterBar-module_filterBar__ZhQLn",
3
- "filtersContainer": "FilterBar-module_filtersContainer__v6OJn"
4
- };
5
- export { styles as default };
@@ -1,7 +0,0 @@
1
- var styles = {
2
- "filterButton": "FilterButton-module_filterButton__PEcAs",
3
- "labelContainer": "FilterButton-module_labelContainer__kJlE8",
4
- "hasSelectedValues": "FilterButton-module_hasSelectedValues__tc-XE",
5
- "labelSeparator": "FilterButton-module_labelSeparator__CmSqS"
6
- };
7
- export { styles as default };
@@ -1,19 +0,0 @@
1
- @import "~@kaizen/design-tokens/sass/border";
2
- @import "~@kaizen/design-tokens/sass/color";
3
- @import "~@kaizen/design-tokens/sass/shadow";
4
- @import "~@kaizen/design-tokens/sass/spacing";
5
-
6
- .filterBar {
7
- display: flex;
8
- padding: $spacing-8;
9
- box-shadow: $shadow-small-box-shadow;
10
- border-radius: $border-solid-border-radius;
11
- background-color: $color-white;
12
- }
13
-
14
- .filtersContainer {
15
- display: flex;
16
- flex-grow: 1;
17
- flex-wrap: wrap;
18
- gap: $spacing-8;
19
- }
@@ -1,22 +0,0 @@
1
- @import "~@kaizen/design-tokens/sass/spacing";
2
- @import "~@kaizen/design-tokens/sass/typography";
3
-
4
- .filterButton {
5
- gap: $spacing-xs;
6
- }
7
-
8
- .labelContainer {
9
- display: inline-flex;
10
- }
11
-
12
- .hasSelectedValues {
13
- font-weight: bold;
14
- }
15
-
16
- .labelSeparator {
17
- margin-inline-end: $spacing-xs;
18
-
19
- [dir="ltr"] [dir="rtl"] & {
20
- margin-right: 0;
21
- }
22
- }