@pathscale/ui 1.1.33 → 1.1.35

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 (260) hide show
  1. package/dist/components/badge/Badge.css +5 -5
  2. package/dist/components/badge/Badge.d.ts +1 -1
  3. package/dist/components/badge/Badge.js +1 -2
  4. package/dist/components/button/Button.css +10 -1
  5. package/dist/components/button/Button.d.ts +2 -0
  6. package/dist/components/button/Button.js +31 -6
  7. package/dist/components/button-group/ButtonGroup.css +117 -0
  8. package/dist/components/button-group/ButtonGroup.d.ts +23 -0
  9. package/dist/components/button-group/ButtonGroup.js +91 -0
  10. package/dist/components/button-group/context.d.ts +8 -0
  11. package/dist/components/button-group/context.js +3 -0
  12. package/dist/components/button-group/index.d.ts +1 -0
  13. package/dist/components/button-group/index.js +6 -0
  14. package/dist/components/card/Card.css +110 -0
  15. package/dist/components/card/Card.d.ts +26 -26
  16. package/dist/components/card/Card.js +131 -70
  17. package/dist/components/card/index.d.ts +1 -1
  18. package/dist/components/card/index.js +6 -1
  19. package/dist/components/checkbox/Checkbox.js +18 -4
  20. package/dist/components/checkbox-group/CheckboxGroup.css +10 -0
  21. package/dist/components/checkbox-group/CheckboxGroup.d.ts +18 -0
  22. package/dist/components/checkbox-group/CheckboxGroup.js +97 -0
  23. package/dist/components/checkbox-group/context.d.ts +11 -0
  24. package/dist/components/checkbox-group/context.js +3 -0
  25. package/dist/components/checkbox-group/index.d.ts +4 -0
  26. package/dist/components/checkbox-group/index.js +4 -0
  27. package/dist/components/chip/Chip.css +197 -0
  28. package/dist/components/chip/Chip.d.ts +25 -0
  29. package/dist/components/chip/Chip.js +142 -0
  30. package/dist/components/chip/index.d.ts +8 -0
  31. package/dist/components/chip/index.js +9 -0
  32. package/dist/components/close-button/CloseButton.css +81 -0
  33. package/dist/components/close-button/CloseButton.d.ts +14 -0
  34. package/dist/components/close-button/CloseButton.js +76 -0
  35. package/dist/components/close-button/index.d.ts +1 -0
  36. package/dist/components/close-button/index.js +3 -0
  37. package/dist/components/combo-box/ComboBox.css +344 -0
  38. package/dist/components/combo-box/ComboBox.d.ts +86 -0
  39. package/dist/components/combo-box/ComboBox.js +708 -0
  40. package/dist/components/combo-box/index.d.ts +1 -0
  41. package/dist/components/combo-box/index.js +10 -0
  42. package/dist/components/date-field/DateField.css +215 -0
  43. package/dist/components/date-field/DateField.d.ts +64 -0
  44. package/dist/components/date-field/DateField.js +341 -0
  45. package/dist/components/date-field/index.d.ts +1 -0
  46. package/dist/components/date-field/index.js +11 -0
  47. package/dist/components/description/Description.css +10 -0
  48. package/dist/components/description/Description.d.ts +11 -0
  49. package/dist/components/{form/Label.js → description/Description.js} +23 -14
  50. package/dist/components/description/index.d.ts +1 -0
  51. package/dist/components/description/index.js +5 -0
  52. package/dist/components/drawer/Drawer.css +15 -0
  53. package/dist/components/drawer/Drawer.d.ts +2 -0
  54. package/dist/components/drawer/Drawer.js +24 -16
  55. package/dist/components/error-message/ErrorMessage.css +20 -0
  56. package/dist/components/error-message/ErrorMessage.d.ts +11 -0
  57. package/dist/components/error-message/ErrorMessage.js +40 -0
  58. package/dist/components/error-message/index.d.ts +1 -0
  59. package/dist/components/error-message/index.js +5 -0
  60. package/dist/components/field-error/FieldError.css +27 -0
  61. package/dist/components/field-error/FieldError.d.ts +21 -0
  62. package/dist/components/field-error/FieldError.js +69 -0
  63. package/dist/components/field-error/index.d.ts +1 -0
  64. package/dist/components/field-error/index.js +5 -0
  65. package/dist/components/fieldset/Fieldset.css +30 -0
  66. package/dist/components/fieldset/Fieldset.d.ts +22 -9
  67. package/dist/components/fieldset/Fieldset.js +88 -44
  68. package/dist/components/fieldset/index.d.ts +1 -2
  69. package/dist/components/fieldset/index.js +7 -2
  70. package/dist/components/form/Form.css +5 -0
  71. package/dist/components/form/Form.d.ts +10 -16
  72. package/dist/components/form/Form.js +33 -16
  73. package/dist/components/form/index.d.ts +1 -4
  74. package/dist/components/form/index.js +3 -4
  75. package/dist/components/header/Header.css +13 -0
  76. package/dist/components/header/Header.d.ts +9 -0
  77. package/dist/components/{menu/MenuDetails.js → header/Header.js} +17 -20
  78. package/dist/components/header/index.d.ts +1 -0
  79. package/dist/components/header/index.js +5 -0
  80. package/dist/components/immersive-landing/components/FirefoxPWABanner.js +62 -68
  81. package/dist/components/immersive-landing/components/PWAInstallPrompt.js +58 -64
  82. package/dist/components/input/Input.css +3 -2
  83. package/dist/components/input/Input.d.ts +2 -2
  84. package/dist/components/input/Input.js +7 -7
  85. package/dist/components/input-group/InputGroup.css +172 -0
  86. package/dist/components/input-group/InputGroup.d.ts +44 -0
  87. package/dist/components/input-group/InputGroup.js +227 -0
  88. package/dist/components/input-group/index.d.ts +1 -0
  89. package/dist/components/input-group/index.js +9 -0
  90. package/dist/components/input-otp/InputOTP.css +170 -0
  91. package/dist/components/input-otp/InputOTP.d.ts +46 -0
  92. package/dist/components/input-otp/InputOTP.js +385 -0
  93. package/dist/components/input-otp/index.d.ts +1 -0
  94. package/dist/components/input-otp/index.js +11 -0
  95. package/dist/components/label/Label.css +30 -0
  96. package/dist/components/label/Label.d.ts +17 -0
  97. package/dist/components/label/Label.js +64 -0
  98. package/dist/components/label/index.d.ts +1 -0
  99. package/dist/components/label/index.js +5 -0
  100. package/dist/components/list-box/ListBox.css +148 -0
  101. package/dist/components/list-box/ListBox.d.ts +23 -0
  102. package/dist/components/list-box/ListBox.js +224 -0
  103. package/dist/components/list-box/ListBoxItem.d.ts +28 -0
  104. package/dist/components/list-box/ListBoxItem.js +231 -0
  105. package/dist/components/list-box/ListBoxSection.d.ts +11 -0
  106. package/dist/components/list-box/ListBoxSection.js +48 -0
  107. package/dist/components/list-box/context.d.ts +27 -0
  108. package/dist/components/list-box/context.js +3 -0
  109. package/dist/components/list-box/index.d.ts +17 -0
  110. package/dist/components/list-box/index.js +17 -0
  111. package/dist/components/menu/Menu.css +199 -0
  112. package/dist/components/menu/Menu.d.ts +32 -20
  113. package/dist/components/menu/Menu.js +213 -39
  114. package/dist/components/menu/MenuItem.d.ts +35 -5
  115. package/dist/components/menu/MenuItem.js +270 -19
  116. package/dist/components/menu/MenuSection.d.ts +11 -0
  117. package/dist/components/menu/MenuSection.js +48 -0
  118. package/dist/components/menu/context.d.ts +26 -0
  119. package/dist/components/menu/context.js +3 -0
  120. package/dist/components/menu/index.d.ts +4 -3
  121. package/dist/components/menu/index.js +11 -2
  122. package/dist/components/number-field/NumberField.css +198 -0
  123. package/dist/components/number-field/NumberField.d.ts +48 -0
  124. package/dist/components/number-field/NumberField.js +350 -0
  125. package/dist/components/number-field/index.d.ts +1 -0
  126. package/dist/components/number-field/index.js +9 -0
  127. package/dist/components/search-field/SearchField.css +183 -0
  128. package/dist/components/search-field/SearchField.d.ts +53 -0
  129. package/dist/components/search-field/SearchField.js +303 -0
  130. package/dist/components/search-field/index.d.ts +1 -0
  131. package/dist/components/search-field/index.js +9 -0
  132. package/dist/components/select/Select.css +16 -10
  133. package/dist/components/select/Select.d.ts +10 -2
  134. package/dist/components/select/Select.js +119 -33
  135. package/dist/components/separator/Separator.css +35 -0
  136. package/dist/components/separator/Separator.d.ts +12 -0
  137. package/dist/components/separator/Separator.js +57 -0
  138. package/dist/components/separator/index.d.ts +1 -0
  139. package/dist/components/separator/index.js +4 -0
  140. package/dist/components/sidenav/Sidenav.js +2 -2
  141. package/dist/components/surface/Surface.css +37 -0
  142. package/dist/components/surface/Surface.d.ts +12 -0
  143. package/dist/components/surface/Surface.js +41 -0
  144. package/dist/components/surface/index.d.ts +1 -0
  145. package/dist/components/surface/index.js +4 -0
  146. package/dist/components/table/hooks/index.d.ts +1 -9
  147. package/dist/components/table/hooks/index.js +1 -18
  148. package/dist/components/tag/Tag.css +121 -0
  149. package/dist/components/tag/Tag.d.ts +33 -0
  150. package/dist/components/tag/Tag.js +241 -0
  151. package/dist/components/tag/index.d.ts +1 -0
  152. package/dist/components/tag/index.js +6 -0
  153. package/dist/components/tag-group/TagGroup.css +22 -0
  154. package/dist/components/tag-group/TagGroup.d.ts +32 -0
  155. package/dist/components/tag-group/TagGroup.js +177 -0
  156. package/dist/components/tag-group/context.d.ts +15 -0
  157. package/dist/components/tag-group/context.js +3 -0
  158. package/dist/components/tag-group/index.d.ts +2 -0
  159. package/dist/components/tag-group/index.js +6 -0
  160. package/dist/components/text/Text.css +66 -0
  161. package/dist/components/text/Text.d.ts +17 -0
  162. package/dist/components/text/Text.js +46 -0
  163. package/dist/components/text/index.d.ts +1 -0
  164. package/dist/components/text/index.js +5 -0
  165. package/dist/components/text-area/TextArea.css +95 -0
  166. package/dist/components/text-area/TextArea.d.ts +19 -0
  167. package/dist/components/text-area/TextArea.js +64 -0
  168. package/dist/components/text-area/index.d.ts +1 -0
  169. package/dist/components/text-area/index.js +5 -0
  170. package/dist/components/text-field/TextField.css +33 -0
  171. package/dist/components/text-field/TextField.d.ts +34 -0
  172. package/dist/components/text-field/TextField.js +85 -0
  173. package/dist/components/text-field/index.d.ts +1 -0
  174. package/dist/components/text-field/index.js +7 -0
  175. package/dist/components/textarea/Textarea.d.ts +8 -13
  176. package/dist/components/textarea/Textarea.js +14 -45
  177. package/dist/components/textarea/index.d.ts +2 -1
  178. package/dist/components/textarea/index.js +4 -1
  179. package/dist/components/time-field/TimeField.css +215 -0
  180. package/dist/components/time-field/TimeField.d.ts +64 -0
  181. package/dist/components/time-field/TimeField.js +341 -0
  182. package/dist/components/time-field/index.d.ts +1 -0
  183. package/dist/components/time-field/index.js +11 -0
  184. package/dist/components/utils.d.ts +2 -2
  185. package/dist/components/utils.js +3 -17
  186. package/dist/hooks/form/index.d.ts +5 -0
  187. package/dist/hooks/form/index.js +12 -0
  188. package/dist/hooks/form/useField.d.ts +11 -0
  189. package/dist/hooks/form/useField.js +20 -0
  190. package/dist/hooks/form/useFieldError.d.ts +3 -0
  191. package/dist/hooks/form/useFieldError.js +3 -0
  192. package/dist/hooks/form/useFieldMeta.d.ts +20 -0
  193. package/dist/hooks/form/useFieldMeta.js +49 -0
  194. package/dist/hooks/form/useFieldProps.d.ts +10 -0
  195. package/dist/hooks/form/useFieldProps.js +51 -0
  196. package/dist/hooks/form/useForm.d.ts +27 -0
  197. package/dist/hooks/form/useForm.js +54 -0
  198. package/dist/hooks/form/utils.d.ts +4 -0
  199. package/dist/hooks/form/utils.js +30 -0
  200. package/dist/hooks/layout/index.d.ts +1 -0
  201. package/dist/hooks/layout/index.js +3 -0
  202. package/dist/hooks/layout/useDesktop.d.ts +1 -0
  203. package/dist/hooks/layout/useDesktop.js +17 -0
  204. package/dist/hooks/table/index.d.ts +9 -0
  205. package/dist/hooks/table/index.js +18 -0
  206. package/dist/index.d.ts +63 -7
  207. package/dist/index.js +145 -15
  208. package/dist/primitives/streaming/index.d.ts +2 -0
  209. package/dist/primitives/streaming/index.js +5 -0
  210. package/dist/primitives/streaming/useStreamingBuffer.d.ts +15 -0
  211. package/dist/primitives/streaming/useStreamingBuffer.js +115 -0
  212. package/dist/primitives/streaming/useStreamingSubscription.d.ts +27 -0
  213. package/dist/primitives/streaming/useStreamingSubscription.js +115 -0
  214. package/dist/styles/icons/generated-icons.css +1 -1
  215. package/package.json +1 -1
  216. package/dist/components/card/CardActions.d.ts +0 -4
  217. package/dist/components/card/CardActions.js +0 -15
  218. package/dist/components/card/CardBody.d.ts +0 -4
  219. package/dist/components/card/CardBody.js +0 -15
  220. package/dist/components/card/CardImage.d.ts +0 -3
  221. package/dist/components/card/CardImage.js +0 -10
  222. package/dist/components/card/CardTitle.d.ts +0 -6
  223. package/dist/components/card/CardTitle.js +0 -13
  224. package/dist/components/card/card.css +0 -171
  225. package/dist/components/form/FormBase.d.ts +0 -8
  226. package/dist/components/form/FormBase.js +0 -74
  227. package/dist/components/form/FormDropdown.d.ts +0 -25
  228. package/dist/components/form/FormDropdown.js +0 -139
  229. package/dist/components/form/FormField.d.ts +0 -14
  230. package/dist/components/form/FormField.js +0 -78
  231. package/dist/components/form/Label.d.ts +0 -7
  232. package/dist/components/form/NumberField.d.ts +0 -20
  233. package/dist/components/form/NumberField.js +0 -109
  234. package/dist/components/form/PasswordField.d.ts +0 -16
  235. package/dist/components/form/PasswordField.js +0 -113
  236. package/dist/components/form/ValidatedForm.d.ts +0 -26
  237. package/dist/components/form/ValidatedForm.js +0 -55
  238. package/dist/components/menu/MenuDetails.d.ts +0 -8
  239. package/dist/components/menu/MenuDropdown.d.ts +0 -12
  240. package/dist/components/menu/MenuDropdown.js +0 -48
  241. package/dist/components/menu/MenuTitle.d.ts +0 -8
  242. package/dist/components/menu/MenuTitle.js +0 -22
  243. package/dist/components/menu/menu.css +0 -364
  244. package/dist/components/textarea/textarea.css +0 -191
  245. /package/dist/{components/table/hooks → hooks/table}/helpers.d.ts +0 -0
  246. /package/dist/{components/table/hooks → hooks/table}/helpers.js +0 -0
  247. /package/dist/{components/table/hooks → hooks/table}/useAnchoredOverlayPosition.d.ts +0 -0
  248. /package/dist/{components/table/hooks → hooks/table}/useAnchoredOverlayPosition.js +0 -0
  249. /package/dist/{components/table/hooks → hooks/table}/useTableExpansion.d.ts +0 -0
  250. /package/dist/{components/table/hooks → hooks/table}/useTableExpansion.js +0 -0
  251. /package/dist/{components/table/hooks → hooks/table}/useTableFiltering.d.ts +0 -0
  252. /package/dist/{components/table/hooks → hooks/table}/useTableFiltering.js +0 -0
  253. /package/dist/{components/table/hooks → hooks/table}/useTableModel.d.ts +0 -0
  254. /package/dist/{components/table/hooks → hooks/table}/useTableModel.js +0 -0
  255. /package/dist/{components/table/hooks → hooks/table}/useTablePagination.d.ts +0 -0
  256. /package/dist/{components/table/hooks → hooks/table}/useTablePagination.js +0 -0
  257. /package/dist/{components/table/hooks → hooks/table}/useTableSelection.d.ts +0 -0
  258. /package/dist/{components/table/hooks → hooks/table}/useTableSelection.js +0 -0
  259. /package/dist/{components/table/hooks → hooks/table}/useTableSorting.d.ts +0 -0
  260. /package/dist/{components/table/hooks → hooks/table}/useTableSorting.js +0 -0
@@ -0,0 +1,344 @@
1
+ @layer components {
2
+ .combo-box {
3
+ --combobox-bg: var(--color-field, var(--color-base-100));
4
+ --combobox-bg-hover: var(--color-field-hover, var(--color-base-200));
5
+ --combobox-bg-focus: var(--color-field-focus, var(--color-base-100));
6
+ --combobox-border: var(--color-field-border, color-mix(in oklab, var(--color-base-content) 16%, transparent));
7
+ --combobox-border-hover: var(--color-field-border-hover, color-mix(in oklab, var(--color-base-content) 22%, transparent));
8
+ --combobox-border-focus: var(--color-field-border-focus, var(--color-accent));
9
+ --combobox-border-invalid: var(--color-field-border-invalid, var(--color-danger));
10
+ --combobox-fg: var(--color-field-foreground, var(--color-base-content));
11
+ --combobox-placeholder: var(--color-field-placeholder, color-mix(in oklab, var(--color-base-content) 45%, transparent));
12
+
13
+ position: relative;
14
+ display: flex;
15
+ flex-direction: column;
16
+ gap: 0.25rem;
17
+ width: fit-content;
18
+ }
19
+
20
+ .combo-box[data-invalid="true"] [data-slot="description"],
21
+ .combo-box[aria-invalid="true"] [data-slot="description"] {
22
+ display: none;
23
+ }
24
+
25
+ .combo-box [data-slot="label"] {
26
+ width: fit-content;
27
+ }
28
+
29
+ .combo-box [data-slot="description"] {
30
+ padding-inline: 0.25rem;
31
+ }
32
+
33
+ .combo-box--full-width {
34
+ width: 100%;
35
+ }
36
+
37
+ .combo-box__input-group {
38
+ position: relative;
39
+ isolation: isolate;
40
+ display: inline-flex;
41
+ align-items: center;
42
+ min-height: 2.25rem;
43
+ width: fit-content;
44
+ border-radius: var(--radius-field, 0.75rem);
45
+ border: var(--border-width-field, 1px) solid var(--combobox-border);
46
+ background-color: var(--combobox-bg);
47
+ color: var(--combobox-fg);
48
+ box-shadow:
49
+ 0 1px 0 color-mix(in oklab, var(--color-base-content) 8%, transparent),
50
+ 0 1px 0 color-mix(in oklab, var(--color-base-100) 60%, transparent) inset;
51
+ transition:
52
+ background-color 150ms var(--ease-smooth),
53
+ border-color 150ms var(--ease-smooth),
54
+ box-shadow 150ms var(--ease-out);
55
+ }
56
+
57
+ .combo-box__input-group--full-width,
58
+ .combo-box--full-width .combo-box__input-group {
59
+ width: 100%;
60
+ }
61
+
62
+ @media (prefers-reduced-motion: reduce) {
63
+ .combo-box__input-group {
64
+ transition: none;
65
+ }
66
+ }
67
+
68
+ @media (hover: hover) {
69
+ .combo-box__input-group:hover:not(:focus-within):not([data-disabled="true"]):not([data-invalid="true"]) {
70
+ background-color: var(--combobox-bg-hover);
71
+ border-color: var(--combobox-border-hover);
72
+ }
73
+ }
74
+
75
+ .combo-box__input-group:focus-within,
76
+ .combo-box__input-group[data-focus-within="true"] {
77
+ border-color: var(--combobox-border-focus);
78
+ background-color: var(--combobox-bg-focus);
79
+ box-shadow:
80
+ 0 0 0 3px color-mix(in oklab, var(--color-accent) 22%, transparent),
81
+ 0 1px 0 color-mix(in oklab, var(--color-accent) 24%, transparent);
82
+ }
83
+
84
+ .combo-box__input-group[data-invalid="true"] {
85
+ border-color: var(--combobox-border-invalid);
86
+ background-color: var(--combobox-bg-focus);
87
+ box-shadow:
88
+ 0 0 0 3px color-mix(in oklab, var(--color-danger) 20%, transparent),
89
+ 0 1px 0 color-mix(in oklab, var(--color-danger) 20%, transparent);
90
+ }
91
+
92
+ .combo-box__input-group[data-disabled="true"],
93
+ .combo-box__input-group[aria-disabled="true"] {
94
+ cursor: not-allowed;
95
+ background-color: var(--color-base-200);
96
+ color: color-mix(in oklab, var(--color-base-content) 45%, transparent);
97
+ opacity: var(--disabled-opacity, 0.6);
98
+ box-shadow: none;
99
+ }
100
+
101
+ .combo-box__input {
102
+ flex: 1;
103
+ min-width: 0;
104
+ border: 0;
105
+ background: transparent;
106
+ padding-block: 0.5rem;
107
+ padding-inline: 0.75rem;
108
+ padding-inline-end: 1.75rem;
109
+ font-size: 0.875rem;
110
+ line-height: 1.25rem;
111
+ color: inherit;
112
+ box-shadow: none;
113
+ outline: none;
114
+ }
115
+
116
+ .combo-box__input::placeholder {
117
+ color: var(--combobox-placeholder);
118
+ }
119
+
120
+ .combo-box__input:focus,
121
+ .combo-box__input:focus-visible {
122
+ outline: none;
123
+ }
124
+
125
+ .combo-box__input:disabled {
126
+ cursor: not-allowed;
127
+ }
128
+
129
+ .combo-box__trigger {
130
+ position: absolute;
131
+ inset-inline-end: 0;
132
+ top: 50%;
133
+ display: flex;
134
+ height: 100%;
135
+ width: 1.75rem;
136
+ transform: translateY(-50%);
137
+ align-items: center;
138
+ justify-content: center;
139
+ border: 0;
140
+ background: transparent;
141
+ color: var(--combobox-placeholder);
142
+ cursor: pointer;
143
+ outline: none;
144
+ transition:
145
+ color 150ms var(--ease-out),
146
+ opacity 150ms var(--ease-out);
147
+ }
148
+
149
+ @media (hover: hover) {
150
+ .combo-box__trigger:hover:not(:disabled):not([aria-disabled="true"]) {
151
+ color: var(--combobox-fg);
152
+ }
153
+ }
154
+
155
+ .combo-box__trigger:focus-visible,
156
+ .combo-box__trigger[data-focus-visible="true"] {
157
+ border-radius: 0.5rem;
158
+ outline: 2px solid var(--color-accent);
159
+ outline-offset: 2px;
160
+ }
161
+
162
+ .combo-box__trigger[data-open="true"] .combo-box__trigger-icon {
163
+ transform: rotate(180deg);
164
+ }
165
+
166
+ .combo-box__trigger:disabled,
167
+ .combo-box__trigger[aria-disabled="true"] {
168
+ cursor: not-allowed;
169
+ opacity: 0.5;
170
+ }
171
+
172
+ .combo-box__trigger-icon {
173
+ width: 1rem;
174
+ height: 1rem;
175
+ transition: transform 150ms var(--ease-out);
176
+ }
177
+
178
+ .combo-box__icon {
179
+ display: inline-flex;
180
+ align-items: center;
181
+ justify-content: center;
182
+ flex-shrink: 0;
183
+ width: 1rem;
184
+ height: 1rem;
185
+ pointer-events: none;
186
+ }
187
+
188
+ .combo-box__icon > * {
189
+ width: 100%;
190
+ height: 100%;
191
+ pointer-events: none;
192
+ }
193
+
194
+ .combo-box__popover {
195
+ position: absolute;
196
+ z-index: 80;
197
+ top: calc(100% + 0.375rem);
198
+ inset-inline-start: 0;
199
+ min-width: max(100%, 14rem);
200
+ max-width: min(30rem, calc(100vw - 2rem));
201
+ max-height: min(24rem, 70vh);
202
+ overflow-y: auto;
203
+ overscroll-behavior: contain;
204
+ border-radius: 1.5rem;
205
+ border: 1px solid color-mix(in oklch, var(--color-base-content) 8%, transparent);
206
+ background-color: var(--color-base-100);
207
+ box-shadow:
208
+ 0 20px 32px oklch(0% 0 0 / 0.16),
209
+ 0 8px 18px oklch(0% 0 0 / 0.1);
210
+ visibility: hidden;
211
+ opacity: 0;
212
+ transform: translateY(-4px) scale(0.98);
213
+ transform-origin: top;
214
+ pointer-events: none;
215
+ transition:
216
+ opacity 150ms cubic-bezier(0.22, 1, 0.36, 1),
217
+ transform 150ms cubic-bezier(0.22, 1, 0.36, 1),
218
+ visibility 150ms ease;
219
+ }
220
+
221
+ .combo-box__popover[data-open="true"] {
222
+ visibility: visible;
223
+ opacity: 1;
224
+ transform: translateY(0) scale(1);
225
+ pointer-events: auto;
226
+ }
227
+
228
+ .combo-box__list {
229
+ display: flex;
230
+ flex-direction: column;
231
+ gap: 0.125rem;
232
+ padding: 0.375rem;
233
+ outline: none;
234
+ }
235
+
236
+ .combo-box__empty {
237
+ padding: 0.5rem 0.625rem;
238
+ font-size: 0.875rem;
239
+ color: color-mix(in oklch, var(--color-base-content) 55%, transparent);
240
+ }
241
+
242
+ .combo-box__option {
243
+ display: flex;
244
+ min-height: 2.25rem;
245
+ width: 100%;
246
+ align-items: center;
247
+ justify-content: space-between;
248
+ gap: 0.75rem;
249
+ border: 0;
250
+ border-radius: 1rem;
251
+ background: transparent;
252
+ padding: 0.5rem 0.625rem;
253
+ text-align: start;
254
+ font-size: 0.875rem;
255
+ line-height: 1.2;
256
+ color: var(--color-base-content);
257
+ cursor: pointer;
258
+ outline: none;
259
+ transition:
260
+ background-color 150ms ease,
261
+ color 120ms ease,
262
+ transform 150ms ease,
263
+ opacity 120ms ease;
264
+ }
265
+
266
+ .combo-box__option-label {
267
+ min-width: 0;
268
+ flex: 1;
269
+ }
270
+
271
+ .combo-box__option-indicator {
272
+ display: inline-flex;
273
+ width: 1rem;
274
+ height: 1rem;
275
+ flex-shrink: 0;
276
+ align-items: center;
277
+ justify-content: center;
278
+ opacity: 0;
279
+ transform: scale(0.85);
280
+ transition:
281
+ opacity 120ms ease,
282
+ transform 150ms ease;
283
+ }
284
+
285
+ .combo-box__option[data-selected="true"] .combo-box__option-indicator {
286
+ opacity: 1;
287
+ transform: scale(1);
288
+ }
289
+
290
+ .combo-box__option[data-active="true"],
291
+ .combo-box__option:focus-visible {
292
+ background-color: var(--color-base-200);
293
+ }
294
+
295
+ @media (hover: hover) {
296
+ .combo-box__option:hover:not([data-disabled="true"]) {
297
+ background-color: var(--color-base-200);
298
+ }
299
+ }
300
+
301
+ .combo-box__option:active:not([data-disabled="true"]) {
302
+ transform: scale(0.99);
303
+ background-color: var(--color-base-300);
304
+ }
305
+
306
+ .combo-box__option[data-disabled="true"],
307
+ .combo-box__option[aria-disabled="true"] {
308
+ cursor: not-allowed;
309
+ opacity: 0.45;
310
+ }
311
+
312
+ .combo-box--secondary .combo-box__input-group {
313
+ border-color: transparent;
314
+ background-color: var(--color-base-200);
315
+ box-shadow: none;
316
+ }
317
+
318
+ @media (hover: hover) {
319
+ .combo-box--secondary .combo-box__input-group:hover:not(:focus-within):not([data-disabled="true"]):not(
320
+ [data-invalid="true"]
321
+ ) {
322
+ background-color: var(--color-base-300);
323
+ }
324
+ }
325
+
326
+ .combo-box--secondary .combo-box__input-group:focus-within,
327
+ .combo-box--secondary .combo-box__input-group[data-focus-within="true"] {
328
+ background-color: var(--color-base-200);
329
+ }
330
+
331
+ .combo-box--secondary .combo-box__input-group[data-invalid="true"] {
332
+ border-color: var(--combobox-border-invalid);
333
+ background-color: var(--color-base-200);
334
+ }
335
+
336
+ @media (prefers-reduced-motion: reduce) {
337
+ .combo-box__trigger-icon,
338
+ .combo-box__popover,
339
+ .combo-box__option,
340
+ .combo-box__option-indicator {
341
+ transition: none;
342
+ }
343
+ }
344
+ }
@@ -0,0 +1,86 @@
1
+ import "./ComboBox.css";
2
+ import { type Component, type JSX, type ParentComponent } from "solid-js";
3
+ import type { IComponentBaseProps } from "../types";
4
+ export type ComboBoxVariant = "primary" | "secondary";
5
+ export type ComboBoxMenuTrigger = "focus" | "input" | "manual";
6
+ export type ComboBoxKey = string | number;
7
+ export type ComboBoxItem = {
8
+ id?: ComboBoxKey;
9
+ key?: ComboBoxKey;
10
+ label?: string;
11
+ textValue?: string;
12
+ disabled?: boolean;
13
+ };
14
+ export type ComboBoxRootProps<T = ComboBoxItem> = Omit<JSX.HTMLAttributes<HTMLDivElement>, "children"> & IComponentBaseProps & {
15
+ children?: JSX.Element;
16
+ startIcon?: JSX.Element;
17
+ endIcon?: JSX.Element;
18
+ items?: readonly T[];
19
+ selectedKey?: ComboBoxKey | null;
20
+ defaultSelectedKey?: ComboBoxKey | null;
21
+ onSelectionChange?: (key: string | null) => void;
22
+ inputValue?: string;
23
+ defaultInputValue?: string;
24
+ onInputChange?: (value: string) => void;
25
+ isOpen?: boolean;
26
+ defaultOpen?: boolean;
27
+ onOpenChange?: (open: boolean) => void;
28
+ fullWidth?: boolean;
29
+ variant?: ComboBoxVariant;
30
+ menuTrigger?: ComboBoxMenuTrigger;
31
+ isDisabled?: boolean;
32
+ disabled?: boolean;
33
+ isInvalid?: boolean;
34
+ allowsCustomValue?: boolean;
35
+ placeholder?: string;
36
+ name?: string;
37
+ isRequired?: boolean;
38
+ required?: boolean;
39
+ defaultFilter?: (textValue: string, inputValue: string) => boolean;
40
+ itemKey?: (item: T, index: number) => ComboBoxKey;
41
+ itemTextValue?: (item: T, index: number) => string;
42
+ itemDisabled?: (item: T, index: number) => boolean;
43
+ };
44
+ export type ComboBoxInputGroupProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, "children"> & IComponentBaseProps & {
45
+ children?: JSX.Element;
46
+ };
47
+ export type ComboBoxInputProps = Omit<JSX.InputHTMLAttributes<HTMLInputElement>, "value" | "onInput" | "disabled"> & IComponentBaseProps & {
48
+ onInput?: JSX.EventHandlerUnion<HTMLInputElement, InputEvent>;
49
+ };
50
+ export type ComboBoxTriggerProps = Omit<JSX.ButtonHTMLAttributes<HTMLButtonElement>, "type" | "disabled"> & IComponentBaseProps & {
51
+ startIcon?: JSX.Element;
52
+ endIcon?: JSX.Element;
53
+ };
54
+ export type ComboBoxPopoverProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, "children"> & IComponentBaseProps & {
55
+ children?: JSX.Element;
56
+ };
57
+ export type ComboBoxListRenderItem = {
58
+ key: string;
59
+ textValue: string;
60
+ isSelected: boolean;
61
+ isActive: boolean;
62
+ isDisabled: boolean;
63
+ item: unknown;
64
+ };
65
+ export type ComboBoxListProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, "children"> & IComponentBaseProps & {
66
+ children?: JSX.Element | ((item: ComboBoxListRenderItem) => JSX.Element);
67
+ renderEmptyState?: () => JSX.Element;
68
+ endIcon?: JSX.Element;
69
+ };
70
+ declare const ComboBoxRoot: ParentComponent<ComboBoxRootProps>;
71
+ declare const ComboBoxInputGroup: ParentComponent<ComboBoxInputGroupProps>;
72
+ declare const ComboBoxInput: Component<ComboBoxInputProps>;
73
+ declare const ComboBoxTrigger: Component<ComboBoxTriggerProps>;
74
+ declare const ComboBoxPopover: ParentComponent<ComboBoxPopoverProps>;
75
+ declare const ComboBoxList: Component<ComboBoxListProps>;
76
+ declare const ComboBox: ParentComponent<ComboBoxRootProps<ComboBoxItem>> & {
77
+ Root: ParentComponent<ComboBoxRootProps<ComboBoxItem>>;
78
+ InputGroup: ParentComponent<ComboBoxInputGroupProps>;
79
+ Input: Component<ComboBoxInputProps>;
80
+ Trigger: Component<ComboBoxTriggerProps>;
81
+ Popover: ParentComponent<ComboBoxPopoverProps>;
82
+ List: Component<ComboBoxListProps>;
83
+ };
84
+ export default ComboBox;
85
+ export { ComboBox, ComboBoxRoot, ComboBoxInputGroup, ComboBoxInput, ComboBoxTrigger, ComboBoxPopover, ComboBoxList, };
86
+ export type { ComboBoxRootProps as ComboBoxProps };