@opengovsg/oui 0.0.0-snapshot-20250314033410 → 0.0.0-snapshot-20250318052429

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 (59) hide show
  1. package/dist/cjs/banner/banner.cjs +1 -1
  2. package/dist/cjs/button/button.cjs +1 -1
  3. package/dist/cjs/combo-box/combo-box-fuzzy.cjs +52 -30
  4. package/dist/cjs/combo-box/combo-box-item.cjs +70 -0
  5. package/dist/cjs/combo-box/combo-box-variant-context.cjs +13 -0
  6. package/dist/cjs/combo-box/combo-box.cjs +46 -100
  7. package/dist/cjs/combo-box/index.cjs +5 -1
  8. package/dist/cjs/index.cjs +10 -1
  9. package/dist/cjs/select/index.cjs +5 -0
  10. package/dist/cjs/select/select-item.cjs +38 -26
  11. package/dist/cjs/select/select-variant-context.cjs +13 -0
  12. package/dist/cjs/select/select.cjs +6 -19
  13. package/dist/cjs/system/react-utils/context.cjs +1 -5
  14. package/dist/cjs/tag-field/tag-field-list.cjs +1 -0
  15. package/dist/cjs/tag-field/tag-field-trigger.cjs +1 -0
  16. package/dist/cjs/tag-field/tag-field.cjs +2 -2
  17. package/dist/cjs/text-area-field/text-area-field.cjs +1 -1
  18. package/dist/cjs/text-field/text-field.cjs +1 -1
  19. package/dist/esm/banner/banner.js +1 -1
  20. package/dist/esm/button/button.js +1 -1
  21. package/dist/esm/combo-box/combo-box-fuzzy.js +55 -33
  22. package/dist/esm/combo-box/combo-box-item.js +68 -0
  23. package/dist/esm/combo-box/combo-box-variant-context.js +10 -0
  24. package/dist/esm/combo-box/combo-box.js +48 -101
  25. package/dist/esm/combo-box/index.js +3 -1
  26. package/dist/esm/index.js +5 -1
  27. package/dist/esm/select/index.js +2 -0
  28. package/dist/esm/select/select-item.js +40 -28
  29. package/dist/esm/select/select-variant-context.js +10 -0
  30. package/dist/esm/select/select.js +8 -21
  31. package/dist/esm/system/react-utils/context.js +1 -5
  32. package/dist/esm/tag-field/tag-field-list.js +1 -0
  33. package/dist/esm/tag-field/tag-field-trigger.js +1 -0
  34. package/dist/esm/tag-field/tag-field.js +2 -2
  35. package/dist/esm/text-area-field/text-area-field.js +1 -1
  36. package/dist/esm/text-field/text-field.js +1 -1
  37. package/dist/types/combo-box/combo-box-fuzzy.d.ts +12 -4
  38. package/dist/types/combo-box/combo-box-fuzzy.d.ts.map +1 -1
  39. package/dist/types/combo-box/combo-box-item.d.ts +11 -0
  40. package/dist/types/combo-box/combo-box-item.d.ts.map +1 -0
  41. package/dist/types/combo-box/combo-box-variant-context.d.ts +4 -0
  42. package/dist/types/combo-box/combo-box-variant-context.d.ts.map +1 -0
  43. package/dist/types/combo-box/combo-box.d.ts +5 -21
  44. package/dist/types/combo-box/combo-box.d.ts.map +1 -1
  45. package/dist/types/combo-box/index.d.ts +2 -0
  46. package/dist/types/combo-box/index.d.ts.map +1 -1
  47. package/dist/types/select/index.d.ts +2 -0
  48. package/dist/types/select/index.d.ts.map +1 -1
  49. package/dist/types/select/select-item.d.ts +3 -3
  50. package/dist/types/select/select-item.d.ts.map +1 -1
  51. package/dist/types/select/select-variant-context.d.ts +4 -0
  52. package/dist/types/select/select-variant-context.d.ts.map +1 -0
  53. package/dist/types/select/select.d.ts +3 -10
  54. package/dist/types/select/select.d.ts.map +1 -1
  55. package/dist/types/system/react-utils/context.d.ts +1 -5
  56. package/dist/types/system/react-utils/context.d.ts.map +1 -1
  57. package/dist/types/tag-field/tag-field-list.d.ts.map +1 -1
  58. package/dist/types/tag-field/tag-field-trigger.d.ts.map +1 -1
  59. package/package.json +4 -4
@@ -6,11 +6,11 @@ var jsxRuntime = require('react/jsx-runtime');
6
6
  var react = require('react');
7
7
  var reactAriaComponents = require('react-aria-components');
8
8
  var ouiTheme = require('@opengovsg/oui-theme');
9
+ var button = require('../button/button.cjs');
10
+ var field = require('../field/field.cjs');
9
11
  var utils = require('../system/utils.cjs');
10
- var selectItem = require('./select-item.cjs');
12
+ var selectVariantContext = require('./select-variant-context.cjs');
11
13
  var chevronsUpDown = require('../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/chevrons-up-down.cjs');
12
- var field = require('../field/field.cjs');
13
- var button = require('../button/button.cjs');
14
14
 
15
15
  const calculateEstimatedRowHeight = (size) => {
16
16
  switch (size) {
@@ -26,7 +26,6 @@ function Select({
26
26
  label,
27
27
  description,
28
28
  classNames,
29
- itemClassNames,
30
29
  ...originalProps
31
30
  }) {
32
31
  const [_props, variantProps] = utils.mapPropsVariants(
@@ -43,7 +42,7 @@ function Select({
43
42
  ...listLayoutOptions
44
43
  });
45
44
  }, [listLayoutOptions, variantProps.size]);
46
- return /* @__PURE__ */ jsxRuntime.jsxs(
45
+ return /* @__PURE__ */ jsxRuntime.jsx(reactAriaComponents.Provider, { values: [[selectVariantContext.SelectVariantContext, variantProps]], children: /* @__PURE__ */ jsxRuntime.jsxs(
47
46
  reactAriaComponents.Select,
48
47
  {
49
48
  className: ouiTheme.composeRenderProps(
@@ -93,24 +92,12 @@ function Select({
93
92
  classNames?.list,
94
93
  (className, renderProps) => styles.list({ className, ...renderProps })
95
94
  ),
96
- children: (item) => {
97
- if (typeof children === "function") {
98
- return children(item);
99
- }
100
- return /* @__PURE__ */ jsxRuntime.jsx(
101
- selectItem.SelectItem,
102
- {
103
- classNames: itemClassNames,
104
- size: variantProps.size,
105
- children: item.textValue
106
- }
107
- );
108
- }
95
+ children
109
96
  }
110
97
  ) }) })
111
98
  ]
112
99
  }
113
- );
100
+ ) });
114
101
  }
115
102
 
116
103
  exports.Select = Select;
@@ -21,11 +21,7 @@ function createContext(options = {}) {
21
21
  }
22
22
  return context;
23
23
  }
24
- return [
25
- Context.Provider,
26
- useContext,
27
- Context
28
- ];
24
+ return [Context, useContext];
29
25
  }
30
26
 
31
27
  exports.createContext = createContext;
@@ -1,4 +1,5 @@
1
1
  "use strict";
2
+ "use client";
2
3
  'use strict';
3
4
 
4
5
  var jsxRuntime = require('react/jsx-runtime');
@@ -1,4 +1,5 @@
1
1
  "use strict";
2
+ "use client";
2
3
  'use strict';
3
4
 
4
5
  var jsxRuntime = require('react/jsx-runtime');
@@ -6,13 +6,13 @@ var jsxRuntime = require('react/jsx-runtime');
6
6
  var react = require('react');
7
7
  var reactAriaComponents = require('react-aria-components');
8
8
  var ouiTheme = require('@opengovsg/oui-theme');
9
+ var field = require('../field/field.cjs');
10
+ var input = require('../input/input.cjs');
9
11
  var tagFieldList = require('./tag-field-list.cjs');
10
12
  var tagFieldRoot = require('./tag-field-root.cjs');
11
13
  var tagFieldTagList = require('./tag-field-tag-list.cjs');
12
14
  var tagFieldTrigger = require('./tag-field-trigger.cjs');
13
15
  var chevronDown = require('../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/chevron-down.cjs');
14
- var field = require('../field/field.cjs');
15
- var input = require('../input/input.cjs');
16
16
 
17
17
  function TagField({
18
18
  classNames,
@@ -5,8 +5,8 @@
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
6
  var reactAriaComponents = require('react-aria-components');
7
7
  var ouiTheme = require('@opengovsg/oui-theme');
8
- var textArea = require('../text-area/text-area.cjs');
9
8
  var field = require('../field/field.cjs');
9
+ var textArea = require('../text-area/text-area.cjs');
10
10
 
11
11
  function TextAreaField({
12
12
  label,
@@ -5,8 +5,8 @@
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
6
  var reactAriaComponents = require('react-aria-components');
7
7
  var ouiTheme = require('@opengovsg/oui-theme');
8
- var input = require('../input/input.cjs');
9
8
  var field = require('../field/field.cjs');
9
+ var input = require('../input/input.cjs');
10
10
 
11
11
  function TextField({
12
12
  label,
@@ -5,9 +5,9 @@ import { useMemo, useRef } from 'react';
5
5
  import { useMessageFormatter, useDisclosure } from 'react-aria';
6
6
  import { useDisclosureState } from 'react-stately';
7
7
  import { bannerStyles } from '@opengovsg/oui-theme';
8
+ import { Button } from '../button/button.js';
8
9
  import CircleAlert from '../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/circle-alert.js';
9
10
  import Info from '../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/info.js';
10
- import { Button } from '../button/button.js';
11
11
  import X from '../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/x.js';
12
12
 
13
13
  const i18nStrings = {
@@ -5,9 +5,9 @@ import { forwardRef, useMemo } from 'react';
5
5
  import { chain } from '@react-aria/utils';
6
6
  import { Button as Button$1, composeRenderProps } from 'react-aria-components';
7
7
  import { buttonStyles } from '@opengovsg/oui-theme';
8
+ import { Ripple } from '../ripple/ripple.js';
8
9
  import { useRipple } from '../ripple/use-ripple.js';
9
10
  import { Spinner } from '../spinner/spinner.js';
10
- import { Ripple } from '../ripple/ripple.js';
11
11
 
12
12
  const Button = forwardRef(
13
13
  ({
@@ -1,10 +1,13 @@
1
1
  "use strict";
2
2
  "use client";
3
- import { jsx } from 'react/jsx-runtime';
3
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
4
4
  import { useDeferredValue, useMemo, useState, useCallback } from 'react';
5
5
  import fuzzysort from 'fuzzysort';
6
- import { comboBoxFuzzyHighlightedTextStyles } from '@opengovsg/oui-theme';
7
- import { ComboBox, ComboBoxItem } from './combo-box.js';
6
+ import { Text } from 'react-aria-components';
7
+ import { comboBoxStyles, comboBoxItemStyles, comboBoxFuzzyHighlightedTextStyles } from '@opengovsg/oui-theme';
8
+ import { mapPropsVariants } from '../system/utils.js';
9
+ import { ComboBox } from './combo-box.js';
10
+ import { ComboBoxItem } from './combo-box-item.js';
8
11
 
9
12
  function HighlightedText({
10
13
  result,
@@ -27,18 +30,24 @@ function HighlightedText({
27
30
  i
28
31
  ));
29
32
  }
30
- function ComboBoxFuzzy({
31
- items,
32
- itemClassNames,
33
- onSelectionChange: onSelectionChangeProp,
34
- onInputChange: onInputChangeProp,
35
- ...props
36
- }) {
37
- const deferredInputValue = useDeferredValue(props.inputValue);
33
+ function ComboBoxFuzzy(originalProps) {
34
+ const [_props, variantProps] = mapPropsVariants(
35
+ originalProps,
36
+ comboBoxStyles.variantKeys
37
+ );
38
+ const {
39
+ items,
40
+ itemClassNames,
41
+ onSelectionChange: onSelectionChangeProp,
42
+ onInputChange: onInputChangeProp,
43
+ inputValue,
44
+ ...props
45
+ } = _props;
46
+ const deferredInputValue = useDeferredValue(inputValue);
38
47
  const preparedItems = useMemo(() => {
39
48
  return items?.map((item) => ({
40
49
  ...item,
41
- prepared: fuzzysort.prepare(item.name)
50
+ prepared: fuzzysort.prepare(item.textValue)
42
51
  })) ?? [];
43
52
  }, [items]);
44
53
  const [filteredResults, setFilteredResults] = useState({ items, result: {} });
@@ -61,7 +70,7 @@ function ComboBoxFuzzy({
61
70
  }).reduce(
62
71
  (acc, result) => {
63
72
  acc.items.push(result.obj);
64
- acc.result[result.obj.name] = result;
73
+ acc.result[result.obj.textValue] = result;
65
74
  return acc;
66
75
  },
67
76
  { items: [], result: {} }
@@ -70,34 +79,47 @@ function ComboBoxFuzzy({
70
79
  },
71
80
  [onInputChangeProp, preparedItems]
72
81
  );
82
+ const comboboxItemStyles = comboBoxItemStyles(variantProps);
73
83
  return /* @__PURE__ */ jsx(
74
84
  ComboBox,
75
85
  {
76
86
  ...props,
87
+ inputValue,
77
88
  items: filteredResults.items,
78
89
  dependencies: [deferredInputValue],
79
90
  onSelectionChange,
80
91
  onInputChange,
81
- children: (item) => /* @__PURE__ */ jsx(
82
- ComboBoxItem,
83
- {
84
- classNames: itemClassNames,
85
- label: ({ isSelected, isFocused }) => /* @__PURE__ */ jsx(
86
- HighlightedText,
87
- {
88
- className: itemClassNames?.highlight,
89
- result: filteredResults.result?.[item.name],
90
- originalText: item.name,
91
- isSelected,
92
- isFocused
93
- }
94
- ),
95
- description: item.description,
96
- textValue: item.name,
97
- id: item.value
98
- },
99
- item.name
100
- )
92
+ children: (item) => /* @__PURE__ */ jsx(ComboBoxItem, { textValue: item.textValue, id: item.id, children: ({ isSelected, isFocused }) => /* @__PURE__ */ jsxs(Fragment, { children: [
93
+ /* @__PURE__ */ jsx(
94
+ Text,
95
+ {
96
+ className: comboboxItemStyles.label({
97
+ className: itemClassNames?.label
98
+ }),
99
+ slot: "label",
100
+ children: /* @__PURE__ */ jsx(
101
+ HighlightedText,
102
+ {
103
+ className: itemClassNames?.highlight,
104
+ result: filteredResults.result?.[item.textValue],
105
+ originalText: item.textValue,
106
+ isSelected,
107
+ isFocused
108
+ }
109
+ )
110
+ }
111
+ ),
112
+ item.description && /* @__PURE__ */ jsx(
113
+ Text,
114
+ {
115
+ className: comboboxItemStyles.description({
116
+ className: itemClassNames?.description
117
+ }),
118
+ slot: "description",
119
+ children: item.description
120
+ }
121
+ )
122
+ ] }) }, item.id)
101
123
  }
102
124
  );
103
125
  }
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ "use client";
3
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
4
+ import { useMemo } from 'react';
5
+ import { useContextProps, ListBoxItem, composeRenderProps, Text } from 'react-aria-components';
6
+ import { comboBoxItemStyles } from '@opengovsg/oui-theme';
7
+ import { forwardRef, mapPropsVariants } from '../system/utils.js';
8
+ import { ComboBoxVariantContext } from './combo-box-variant-context.js';
9
+
10
+ const ComboBoxItem = forwardRef(function ComboBoxItem2(originalProps, ref) {
11
+ [originalProps, ref] = useContextProps(
12
+ originalProps,
13
+ ref,
14
+ ComboBoxVariantContext
15
+ );
16
+ const [
17
+ { className, description, children, classNames, ...props },
18
+ variantProps
19
+ ] = mapPropsVariants(originalProps, comboBoxItemStyles.variantKeys);
20
+ const styles = comboBoxItemStyles(variantProps);
21
+ const defaultTextValue = useMemo(() => {
22
+ if (props.textValue) {
23
+ return props.textValue;
24
+ }
25
+ if (typeof children === "string") {
26
+ return children;
27
+ }
28
+ return void 0;
29
+ }, [children, props.textValue]);
30
+ return /* @__PURE__ */ jsx(
31
+ ListBoxItem,
32
+ {
33
+ textValue: defaultTextValue,
34
+ ...props,
35
+ className: composeRenderProps(
36
+ className ?? classNames?.container,
37
+ (className2, renderProps) => styles.container({ ...renderProps, className: className2 })
38
+ ),
39
+ children: (renderProps) => {
40
+ if (typeof children === "function") {
41
+ return children(renderProps);
42
+ }
43
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
44
+ /* @__PURE__ */ jsx(
45
+ Text,
46
+ {
47
+ className: styles.label({ className: classNames?.label }),
48
+ slot: "label",
49
+ children
50
+ }
51
+ ),
52
+ description && /* @__PURE__ */ jsx(
53
+ Text,
54
+ {
55
+ className: styles.description({
56
+ className: classNames?.description
57
+ }),
58
+ slot: "description",
59
+ children: description
60
+ }
61
+ )
62
+ ] });
63
+ }
64
+ }
65
+ );
66
+ });
67
+
68
+ export { ComboBoxItem };
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ "use client";
3
+ import { createContext } from '../system/react-utils/context.js';
4
+
5
+ const [ComboBoxVariantContext, useComboBoxVariantContext] = createContext({
6
+ name: "ComboBoxVariantContext",
7
+ strict: true
8
+ });
9
+
10
+ export { ComboBoxVariantContext, useComboBoxVariantContext };
@@ -3,9 +3,11 @@
3
3
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
4
4
  import { useMemo, useCallback } from 'react';
5
5
  import { useMessageFormatter } from 'react-aria';
6
- import { ListLayout, ComboBox as ComboBox$1, Input, Button, Virtualizer, Popover, ListBox, ListBoxItem, Text } from 'react-aria-components';
6
+ import { ListLayout, Provider, ComboBox as ComboBox$1, Input, Button, Popover, Virtualizer, ListBox } from 'react-aria-components';
7
7
  import { comboBoxItemStyles, cn, comboBoxStyles, composeTailwindRenderProps, composeRenderProps, comboBoxClearButtonStyles } from '@opengovsg/oui-theme';
8
8
  import { Label, FieldGroup, Description, FieldError } from '../field/field.js';
9
+ import { mapPropsVariants } from '../system/utils.js';
10
+ import { ComboBoxVariantContext } from './combo-box-variant-context.js';
9
11
  import ChevronUp from '../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/chevron-up.js';
10
12
  import ChevronDown from '../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/chevron-down.js';
11
13
  import X from '../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/dist/esm/icons/x.js';
@@ -54,38 +56,43 @@ function ComboBoxEmptyState({
54
56
  }
55
57
  );
56
58
  }
57
- function ComboBox({
58
- label,
59
- description,
60
- errorMessage,
61
- classNames,
62
- itemClassNames,
63
- size,
64
- listLayoutOptions,
65
- children,
66
- dependencies,
67
- onClear,
68
- renderEmptyState: renderEmptyStateProp,
69
- ...props
70
- }) {
59
+ function ComboBox(originalProps) {
71
60
  const formatMessage = useMessageFormatter(i18nStrings);
72
- const styles = comboBoxStyles({ size });
61
+ const [_props, variantProps] = mapPropsVariants(
62
+ originalProps,
63
+ comboBoxStyles.variantKeys
64
+ );
65
+ const {
66
+ label,
67
+ description,
68
+ errorMessage,
69
+ classNames,
70
+ listLayoutOptions,
71
+ children,
72
+ dependencies,
73
+ onClear,
74
+ renderEmptyState: renderEmptyStateProp,
75
+ ...props
76
+ } = _props;
77
+ const styles = comboBoxStyles(variantProps);
73
78
  const layout = useMemo(() => {
74
79
  return new ListLayout({
75
- estimatedRowHeight: calculateEstimatedRowHeight(size ?? "md"),
80
+ estimatedRowHeight: calculateEstimatedRowHeight(
81
+ variantProps.size ?? "md"
82
+ ),
76
83
  ...listLayoutOptions
77
84
  });
78
- }, [listLayoutOptions, size]);
85
+ }, [listLayoutOptions, variantProps.size]);
79
86
  const renderEmptyState = useCallback(
80
87
  (props2) => {
81
88
  if (renderEmptyStateProp) {
82
89
  return renderEmptyStateProp(props2);
83
90
  }
84
- return /* @__PURE__ */ jsx(ComboBoxEmptyState, { size, className: classNames?.emptyState });
91
+ return /* @__PURE__ */ jsx(ComboBoxEmptyState, { className: classNames?.emptyState });
85
92
  },
86
- [classNames?.emptyState, renderEmptyStateProp, size]
93
+ [classNames?.emptyState, renderEmptyStateProp]
87
94
  );
88
- return /* @__PURE__ */ jsx(
95
+ return /* @__PURE__ */ jsx(Provider, { values: [[ComboBoxVariantContext, variantProps]], children: /* @__PURE__ */ jsx(
89
96
  ComboBox$1,
90
97
  {
91
98
  className: composeTailwindRenderProps(
@@ -94,13 +101,14 @@ function ComboBox({
94
101
  ),
95
102
  shouldFocusWrap: true,
96
103
  allowsEmptyCollection: true,
104
+ isDisabled: variantProps.isDisabled,
97
105
  ...props,
98
106
  children: ({ isOpen, isDisabled: isComboBoxDisabled }) => /* @__PURE__ */ jsxs(Fragment, { children: [
99
107
  /* @__PURE__ */ jsx(
100
108
  Label,
101
109
  {
102
- size,
103
- className: styles.label({ className: classNames?.label, size }),
110
+ size: variantProps.size,
111
+ className: styles.label({ className: classNames?.label }),
104
112
  children: label
105
113
  }
106
114
  ),
@@ -108,12 +116,12 @@ function ComboBox({
108
116
  /* @__PURE__ */ jsxs(
109
117
  FieldGroup,
110
118
  {
119
+ isDisabled: isComboBoxDisabled,
111
120
  className: composeRenderProps(
112
121
  classNames?.group,
113
122
  (className, renderProps) => styles.group({
114
123
  ...renderProps,
115
124
  className,
116
- size,
117
125
  isClearable: !!onClear
118
126
  })
119
127
  ),
@@ -123,7 +131,7 @@ function ComboBox({
123
131
  {
124
132
  className: composeRenderProps(
125
133
  classNames?.field,
126
- (className, renderProps) => styles.field({ ...renderProps, className, size })
134
+ (className, renderProps) => styles.field({ ...renderProps, className })
127
135
  )
128
136
  }
129
137
  ),
@@ -132,22 +140,20 @@ function ComboBox({
132
140
  {
133
141
  className: composeRenderProps(
134
142
  classNames?.expandButton,
135
- (className, renderProps) => styles.expandButton({ ...renderProps, className, size })
143
+ (className, renderProps) => styles.expandButton({ ...renderProps, className })
136
144
  ),
137
145
  children: isOpen ? /* @__PURE__ */ jsx(
138
146
  ChevronUp,
139
147
  {
140
148
  className: styles.icon({
141
- className: classNames?.icon,
142
- size
149
+ className: classNames?.icon
143
150
  })
144
151
  }
145
152
  ) : /* @__PURE__ */ jsx(
146
153
  ChevronDown,
147
154
  {
148
155
  className: styles.icon({
149
- className: classNames?.icon,
150
- size
156
+ className: classNames?.icon
151
157
  })
152
158
  }
153
159
  )
@@ -166,35 +172,33 @@ function ComboBox({
166
172
  className: composeRenderProps(
167
173
  classNames?.clearButton,
168
174
  (className, renderProps) => comboBoxClearButtonStyles({
175
+ ...variantProps,
169
176
  ...renderProps,
170
177
  className,
171
- size,
172
- isInactive: !props.inputValue,
173
- isDisabled: renderProps.isDisabled
178
+ isInactive: !props.inputValue
174
179
  })
175
180
  ),
176
181
  children: /* @__PURE__ */ jsx(
177
182
  X,
178
183
  {
179
184
  className: styles.icon({
180
- className: classNames?.icon,
181
- size
185
+ className: classNames?.icon
182
186
  })
183
187
  }
184
188
  )
185
189
  }
186
190
  )
187
191
  ] }),
188
- description && /* @__PURE__ */ jsx(Description, { size, children: description }),
189
- /* @__PURE__ */ jsx(FieldError, { size, children: errorMessage }),
190
- /* @__PURE__ */ jsx(Virtualizer, { layout, children: /* @__PURE__ */ jsx(
192
+ description && /* @__PURE__ */ jsx(Description, { size: variantProps.size, children: description }),
193
+ /* @__PURE__ */ jsx(FieldError, { size: variantProps.size, children: errorMessage }),
194
+ /* @__PURE__ */ jsx(
191
195
  Popover,
192
196
  {
193
197
  className: composeRenderProps(
194
198
  classNames?.popover,
195
199
  (className, renderProps) => styles.popover({ ...renderProps, className })
196
200
  ),
197
- children: /* @__PURE__ */ jsx(
201
+ children: /* @__PURE__ */ jsx(Virtualizer, { layout, children: /* @__PURE__ */ jsx(
198
202
  ListBox,
199
203
  {
200
204
  className: composeRenderProps(
@@ -203,71 +207,14 @@ function ComboBox({
203
207
  ),
204
208
  dependencies,
205
209
  renderEmptyState,
206
- children: (item) => {
207
- if (children) {
208
- return children(item);
209
- }
210
- return /* @__PURE__ */ jsx(
211
- ComboBoxItem,
212
- {
213
- size,
214
- id: item.value,
215
- label: item.name,
216
- textValue: item.name,
217
- description: item.description,
218
- classNames: itemClassNames
219
- }
220
- );
221
- }
210
+ children
222
211
  }
223
- )
212
+ ) })
224
213
  }
225
- ) })
214
+ )
226
215
  ] })
227
216
  }
228
- );
229
- }
230
- function ComboBoxItem({
231
- className,
232
- size,
233
- description,
234
- label,
235
- classNames,
236
- ...props
237
- }) {
238
- const styles = comboBoxItemStyles({ size });
239
- return /* @__PURE__ */ jsx(
240
- ListBoxItem,
241
- {
242
- ...props,
243
- className: composeRenderProps(
244
- className ?? classNames?.container,
245
- (className2, renderProps) => styles.container({ ...renderProps, className: className2 })
246
- ),
247
- children: (renderProps) => {
248
- return /* @__PURE__ */ jsxs(Fragment, { children: [
249
- /* @__PURE__ */ jsx(
250
- Text,
251
- {
252
- className: styles.label({ className: classNames?.label }),
253
- slot: "label",
254
- children: typeof label === "function" ? label(renderProps) : label
255
- }
256
- ),
257
- description && /* @__PURE__ */ jsx(
258
- Text,
259
- {
260
- className: styles.description({
261
- className: classNames?.description
262
- }),
263
- slot: "description",
264
- children: typeof description === "function" ? description(renderProps) : description
265
- }
266
- )
267
- ] });
268
- }
269
- }
270
- );
217
+ ) });
271
218
  }
272
219
 
273
- export { ComboBox, ComboBoxEmptyState, ComboBoxItem };
220
+ export { ComboBox, ComboBoxEmptyState };
@@ -1,3 +1,5 @@
1
1
  "use strict";
2
- export { ComboBox, ComboBoxEmptyState, ComboBoxItem } from './combo-box.js';
2
+ export { ComboBox, ComboBoxEmptyState } from './combo-box.js';
3
3
  export { ComboBoxFuzzy } from './combo-box-fuzzy.js';
4
+ export { ComboBoxItem } from './combo-box-item.js';
5
+ export { ComboBoxVariantContext, useComboBoxVariantContext } from './combo-box-variant-context.js';
package/dist/esm/index.js CHANGED
@@ -13,8 +13,12 @@ export { TextField } from './text-field/text-field.js';
13
13
  export { Description, FieldError, FieldGroup, Label } from './field/field.js';
14
14
  export { TextArea } from './text-area/text-area.js';
15
15
  export { TextAreaField } from './text-area-field/text-area-field.js';
16
- export { ComboBox, ComboBoxEmptyState, ComboBoxItem } from './combo-box/combo-box.js';
16
+ export { ComboBox, ComboBoxEmptyState } from './combo-box/combo-box.js';
17
17
  export { ComboBoxFuzzy } from './combo-box/combo-box-fuzzy.js';
18
+ export { ComboBoxItem } from './combo-box/combo-box-item.js';
19
+ export { ComboBoxVariantContext, useComboBoxVariantContext } from './combo-box/combo-box-variant-context.js';
18
20
  export { Banner } from './banner/banner.js';
19
21
  export { TagField } from './tag-field/tag-field.js';
20
22
  export { Select } from './select/select.js';
23
+ export { SelectItem } from './select/select-item.js';
24
+ export { SelectVariantContext, useSelectVariantContext } from './select/select-variant-context.js';
@@ -1,2 +1,4 @@
1
1
  "use strict";
2
2
  export { Select } from './select.js';
3
+ export { SelectItem } from './select-item.js';
4
+ export { SelectVariantContext, useSelectVariantContext } from './select-variant-context.js';