@pathscale/ui 1.1.34 → 1.1.36

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 (314) hide show
  1. package/dist/components/breadcrumbs/Breadcrumbs.classes.d.ts +8 -0
  2. package/dist/components/breadcrumbs/Breadcrumbs.classes.js +13 -0
  3. package/dist/components/breadcrumbs/Breadcrumbs.js +8 -3
  4. package/dist/components/button/Button.classes.d.ts +27 -0
  5. package/dist/components/button/Button.classes.js +28 -0
  6. package/dist/components/button/Button.css +10 -1
  7. package/dist/components/button/Button.d.ts +6 -3
  8. package/dist/components/button/Button.js +37 -21
  9. package/dist/components/button-group/ButtonGroup.classes.d.ts +15 -0
  10. package/dist/components/button-group/ButtonGroup.classes.js +16 -0
  11. package/dist/components/button-group/ButtonGroup.css +117 -0
  12. package/dist/components/button-group/ButtonGroup.d.ts +23 -0
  13. package/dist/components/button-group/ButtonGroup.js +88 -0
  14. package/dist/components/button-group/context.d.ts +8 -0
  15. package/dist/components/button-group/context.js +3 -0
  16. package/dist/components/button-group/index.d.ts +1 -0
  17. package/dist/components/button-group/index.js +6 -0
  18. package/dist/components/card/Card.classes.d.ts +24 -0
  19. package/dist/components/card/Card.classes.js +25 -0
  20. package/dist/components/card/Card.css +110 -0
  21. package/dist/components/card/Card.d.ts +26 -26
  22. package/dist/components/card/Card.js +126 -70
  23. package/dist/components/card/index.d.ts +1 -1
  24. package/dist/components/card/index.js +6 -1
  25. package/dist/components/checkbox/Checkbox.js +18 -4
  26. package/dist/components/checkbox-group/CheckboxGroup.classes.d.ts +11 -0
  27. package/dist/components/checkbox-group/CheckboxGroup.classes.js +12 -0
  28. package/dist/components/checkbox-group/CheckboxGroup.css +10 -0
  29. package/dist/components/checkbox-group/CheckboxGroup.d.ts +18 -0
  30. package/dist/components/checkbox-group/CheckboxGroup.js +94 -0
  31. package/dist/components/checkbox-group/context.d.ts +11 -0
  32. package/dist/components/checkbox-group/context.js +3 -0
  33. package/dist/components/checkbox-group/index.d.ts +4 -0
  34. package/dist/components/checkbox-group/index.js +4 -0
  35. package/dist/components/chip/Chip.css +11 -9
  36. package/dist/components/chip/Chip.d.ts +2 -2
  37. package/dist/components/chip/Chip.js +38 -30
  38. package/dist/components/close-button/CloseButton.classes.d.ts +11 -0
  39. package/dist/components/close-button/CloseButton.classes.js +12 -0
  40. package/dist/components/close-button/CloseButton.css +81 -0
  41. package/dist/components/close-button/CloseButton.d.ts +14 -0
  42. package/dist/components/close-button/CloseButton.js +76 -0
  43. package/dist/components/close-button/index.d.ts +1 -0
  44. package/dist/components/close-button/index.js +3 -0
  45. package/dist/components/combo-box/ComboBox.classes.d.ts +42 -0
  46. package/dist/components/combo-box/ComboBox.classes.js +43 -0
  47. package/dist/components/combo-box/ComboBox.css +344 -0
  48. package/dist/components/combo-box/ComboBox.d.ts +86 -0
  49. package/dist/components/combo-box/ComboBox.js +725 -0
  50. package/dist/components/combo-box/index.d.ts +1 -0
  51. package/dist/components/combo-box/index.js +10 -0
  52. package/dist/components/date-field/DateField.classes.d.ts +37 -0
  53. package/dist/components/date-field/DateField.classes.js +38 -0
  54. package/dist/components/date-field/DateField.css +215 -0
  55. package/dist/components/date-field/DateField.d.ts +64 -0
  56. package/dist/components/date-field/DateField.js +334 -0
  57. package/dist/components/date-field/index.d.ts +1 -0
  58. package/dist/components/date-field/index.js +11 -0
  59. package/dist/components/description/Description.classes.d.ts +3 -0
  60. package/dist/components/description/Description.classes.js +4 -0
  61. package/dist/components/description/Description.css +10 -0
  62. package/dist/components/description/Description.d.ts +11 -0
  63. package/dist/components/description/Description.js +41 -0
  64. package/dist/components/description/index.d.ts +1 -0
  65. package/dist/components/description/index.js +5 -0
  66. package/dist/components/drawer/Drawer.css +15 -0
  67. package/dist/components/drawer/Drawer.d.ts +2 -0
  68. package/dist/components/drawer/Drawer.js +24 -16
  69. package/dist/components/error-message/ErrorMessage.classes.d.ts +3 -0
  70. package/dist/components/error-message/ErrorMessage.classes.js +4 -0
  71. package/dist/components/error-message/ErrorMessage.css +20 -0
  72. package/dist/components/error-message/ErrorMessage.d.ts +11 -0
  73. package/dist/components/error-message/ErrorMessage.js +41 -0
  74. package/dist/components/error-message/index.d.ts +1 -0
  75. package/dist/components/error-message/index.js +5 -0
  76. package/dist/components/field-error/FieldError.classes.d.ts +3 -0
  77. package/dist/components/field-error/FieldError.classes.js +4 -0
  78. package/dist/components/field-error/FieldError.css +27 -0
  79. package/dist/components/field-error/FieldError.d.ts +21 -0
  80. package/dist/components/field-error/FieldError.js +70 -0
  81. package/dist/components/field-error/index.d.ts +1 -0
  82. package/dist/components/field-error/index.js +5 -0
  83. package/dist/components/fieldset/Fieldset.classes.d.ts +14 -0
  84. package/dist/components/fieldset/Fieldset.classes.js +15 -0
  85. package/dist/components/fieldset/Fieldset.css +30 -0
  86. package/dist/components/fieldset/Fieldset.d.ts +22 -9
  87. package/dist/components/fieldset/Fieldset.js +89 -44
  88. package/dist/components/fieldset/index.d.ts +1 -2
  89. package/dist/components/fieldset/index.js +7 -2
  90. package/dist/components/form/Form.classes.d.ts +3 -0
  91. package/dist/components/form/Form.classes.js +4 -0
  92. package/dist/components/form/Form.css +5 -0
  93. package/dist/components/form/Form.d.ts +10 -16
  94. package/dist/components/form/Form.js +34 -16
  95. package/dist/components/form/index.d.ts +1 -4
  96. package/dist/components/form/index.js +3 -4
  97. package/dist/components/header/Header.classes.d.ts +3 -0
  98. package/dist/components/header/Header.classes.js +4 -0
  99. package/dist/components/header/Header.css +13 -0
  100. package/dist/components/header/Header.d.ts +9 -0
  101. package/dist/components/{form/Label.js → header/Header.js} +18 -14
  102. package/dist/components/header/index.d.ts +1 -0
  103. package/dist/components/header/index.js +5 -0
  104. package/dist/components/immersive-landing/components/FirefoxPWABanner.js +62 -68
  105. package/dist/components/immersive-landing/components/PWAInstallPrompt.js +58 -64
  106. package/dist/components/input/Input.css +3 -2
  107. package/dist/components/input/Input.d.ts +2 -2
  108. package/dist/components/input/Input.js +7 -7
  109. package/dist/components/input-group/InputGroup.classes.d.ts +21 -0
  110. package/dist/components/input-group/InputGroup.classes.js +22 -0
  111. package/dist/components/input-group/InputGroup.css +172 -0
  112. package/dist/components/input-group/InputGroup.d.ts +44 -0
  113. package/dist/components/input-group/InputGroup.js +224 -0
  114. package/dist/components/input-group/index.d.ts +1 -0
  115. package/dist/components/input-group/index.js +9 -0
  116. package/dist/components/input-otp/InputOTP.classes.d.ts +23 -0
  117. package/dist/components/input-otp/InputOTP.classes.js +24 -0
  118. package/dist/components/input-otp/InputOTP.css +170 -0
  119. package/dist/components/input-otp/InputOTP.d.ts +46 -0
  120. package/dist/components/input-otp/InputOTP.js +385 -0
  121. package/dist/components/input-otp/index.d.ts +1 -0
  122. package/dist/components/input-otp/index.js +11 -0
  123. package/dist/components/label/Label.classes.d.ts +8 -0
  124. package/dist/components/label/Label.classes.js +9 -0
  125. package/dist/components/label/Label.css +30 -0
  126. package/dist/components/label/Label.d.ts +17 -0
  127. package/dist/components/label/Label.js +60 -0
  128. package/dist/components/label/index.d.ts +1 -0
  129. package/dist/components/label/index.js +5 -0
  130. package/dist/components/list-box/ListBox.classes.d.ts +23 -0
  131. package/dist/components/list-box/ListBox.classes.js +24 -0
  132. package/dist/components/list-box/ListBox.css +148 -0
  133. package/dist/components/list-box/ListBox.d.ts +23 -0
  134. package/dist/components/list-box/ListBox.js +221 -0
  135. package/dist/components/list-box/ListBoxItem.d.ts +28 -0
  136. package/dist/components/list-box/ListBoxItem.js +228 -0
  137. package/dist/components/list-box/ListBoxSection.d.ts +11 -0
  138. package/dist/components/list-box/ListBoxSection.js +50 -0
  139. package/dist/components/list-box/context.d.ts +27 -0
  140. package/dist/components/list-box/context.js +3 -0
  141. package/dist/components/list-box/index.d.ts +17 -0
  142. package/dist/components/list-box/index.js +17 -0
  143. package/dist/components/menu/Menu.classes.d.ts +20 -0
  144. package/dist/components/menu/Menu.classes.js +21 -0
  145. package/dist/components/menu/Menu.css +199 -0
  146. package/dist/components/menu/Menu.d.ts +32 -20
  147. package/dist/components/menu/Menu.js +214 -39
  148. package/dist/components/menu/MenuItem.d.ts +35 -5
  149. package/dist/components/menu/MenuItem.js +267 -19
  150. package/dist/components/menu/MenuSection.d.ts +11 -0
  151. package/dist/components/menu/MenuSection.js +50 -0
  152. package/dist/components/menu/context.d.ts +26 -0
  153. package/dist/components/menu/context.js +3 -0
  154. package/dist/components/menu/index.d.ts +4 -3
  155. package/dist/components/menu/index.js +11 -2
  156. package/dist/components/navbar/Navbar.classes.d.ts +37 -0
  157. package/dist/components/navbar/Navbar.classes.js +41 -0
  158. package/dist/components/navbar/Navbar.js +2 -1
  159. package/dist/components/navbar/NavbarRow.js +3 -14
  160. package/dist/components/navbar/NavbarSection.js +2 -6
  161. package/dist/components/navbar/NavbarStack.js +2 -5
  162. package/dist/components/number-field/NumberField.classes.d.ts +27 -0
  163. package/dist/components/number-field/NumberField.classes.js +28 -0
  164. package/dist/components/number-field/NumberField.css +198 -0
  165. package/dist/components/number-field/NumberField.d.ts +48 -0
  166. package/dist/components/number-field/NumberField.js +347 -0
  167. package/dist/components/number-field/index.d.ts +1 -0
  168. package/dist/components/number-field/index.js +9 -0
  169. package/dist/components/search-field/SearchField.classes.d.ts +27 -0
  170. package/dist/components/search-field/SearchField.classes.js +28 -0
  171. package/dist/components/search-field/SearchField.css +183 -0
  172. package/dist/components/search-field/SearchField.d.ts +53 -0
  173. package/dist/components/search-field/SearchField.js +300 -0
  174. package/dist/components/search-field/index.d.ts +1 -0
  175. package/dist/components/search-field/index.js +9 -0
  176. package/dist/components/select/Select.css +16 -10
  177. package/dist/components/select/Select.d.ts +10 -2
  178. package/dist/components/select/Select.js +119 -33
  179. package/dist/components/separator/Separator.classes.d.ts +12 -0
  180. package/dist/components/separator/Separator.classes.js +13 -0
  181. package/dist/components/separator/Separator.css +35 -0
  182. package/dist/components/separator/Separator.d.ts +12 -0
  183. package/dist/components/separator/Separator.js +49 -0
  184. package/dist/components/separator/index.d.ts +1 -0
  185. package/dist/components/separator/index.js +4 -0
  186. package/dist/components/sidenav/Sidenav.js +2 -2
  187. package/dist/components/surface/Surface.classes.d.ts +9 -0
  188. package/dist/components/surface/Surface.classes.js +10 -0
  189. package/dist/components/surface/Surface.css +37 -0
  190. package/dist/components/surface/Surface.d.ts +12 -0
  191. package/dist/components/{menu/MenuDetails.js → surface/Surface.js} +19 -20
  192. package/dist/components/surface/index.d.ts +1 -0
  193. package/dist/components/surface/index.js +4 -0
  194. package/dist/components/table/hooks/index.d.ts +1 -9
  195. package/dist/components/table/hooks/index.js +1 -18
  196. package/dist/components/tag/Tag.classes.d.ts +20 -0
  197. package/dist/components/tag/Tag.classes.js +21 -0
  198. package/dist/components/tag/Tag.css +121 -0
  199. package/dist/components/tag/Tag.d.ts +33 -0
  200. package/dist/components/tag/Tag.js +235 -0
  201. package/dist/components/tag/index.d.ts +1 -0
  202. package/dist/components/tag/index.js +6 -0
  203. package/dist/components/tag-group/TagGroup.classes.d.ts +8 -0
  204. package/dist/components/tag-group/TagGroup.classes.js +9 -0
  205. package/dist/components/tag-group/TagGroup.css +22 -0
  206. package/dist/components/tag-group/TagGroup.d.ts +32 -0
  207. package/dist/components/tag-group/TagGroup.js +178 -0
  208. package/dist/components/tag-group/context.d.ts +15 -0
  209. package/dist/components/tag-group/context.js +3 -0
  210. package/dist/components/tag-group/index.d.ts +2 -0
  211. package/dist/components/tag-group/index.js +6 -0
  212. package/dist/components/text/Text.classes.d.ts +3 -0
  213. package/dist/components/text/Text.classes.js +4 -0
  214. package/dist/components/text/Text.css +66 -0
  215. package/dist/components/text/Text.d.ts +17 -0
  216. package/dist/components/text/Text.js +47 -0
  217. package/dist/components/text/index.d.ts +1 -0
  218. package/dist/components/text/index.js +5 -0
  219. package/dist/components/text-area/TextArea.classes.d.ts +10 -0
  220. package/dist/components/text-area/TextArea.classes.js +11 -0
  221. package/dist/components/text-area/TextArea.css +95 -0
  222. package/dist/components/text-area/TextArea.d.ts +19 -0
  223. package/dist/components/text-area/TextArea.js +61 -0
  224. package/dist/components/text-area/index.d.ts +1 -0
  225. package/dist/components/text-area/index.js +5 -0
  226. package/dist/components/text-field/TextField.classes.d.ts +10 -0
  227. package/dist/components/text-field/TextField.classes.js +11 -0
  228. package/dist/components/text-field/TextField.css +33 -0
  229. package/dist/components/text-field/TextField.d.ts +34 -0
  230. package/dist/components/text-field/TextField.js +82 -0
  231. package/dist/components/text-field/index.d.ts +1 -0
  232. package/dist/components/text-field/index.js +7 -0
  233. package/dist/components/textarea/Textarea.d.ts +8 -13
  234. package/dist/components/textarea/Textarea.js +14 -45
  235. package/dist/components/textarea/index.d.ts +2 -1
  236. package/dist/components/textarea/index.js +4 -1
  237. package/dist/components/time-field/TimeField.classes.d.ts +37 -0
  238. package/dist/components/time-field/TimeField.classes.js +38 -0
  239. package/dist/components/time-field/TimeField.css +215 -0
  240. package/dist/components/time-field/TimeField.d.ts +64 -0
  241. package/dist/components/time-field/TimeField.js +334 -0
  242. package/dist/components/time-field/index.d.ts +1 -0
  243. package/dist/components/time-field/index.js +11 -0
  244. package/dist/components/utils.d.ts +2 -2
  245. package/dist/components/utils.js +3 -17
  246. package/dist/hooks/form/index.d.ts +5 -0
  247. package/dist/hooks/form/index.js +12 -0
  248. package/dist/hooks/form/useField.d.ts +11 -0
  249. package/dist/hooks/form/useField.js +20 -0
  250. package/dist/hooks/form/useFieldError.d.ts +3 -0
  251. package/dist/hooks/form/useFieldError.js +3 -0
  252. package/dist/hooks/form/useFieldMeta.d.ts +20 -0
  253. package/dist/hooks/form/useFieldMeta.js +49 -0
  254. package/dist/hooks/form/useFieldProps.d.ts +10 -0
  255. package/dist/hooks/form/useFieldProps.js +51 -0
  256. package/dist/hooks/form/useForm.d.ts +27 -0
  257. package/dist/hooks/form/useForm.js +54 -0
  258. package/dist/hooks/form/utils.d.ts +4 -0
  259. package/dist/hooks/form/utils.js +30 -0
  260. package/dist/hooks/layout/index.d.ts +1 -0
  261. package/dist/hooks/layout/index.js +3 -0
  262. package/dist/hooks/layout/useDesktop.d.ts +1 -0
  263. package/dist/hooks/layout/useDesktop.js +17 -0
  264. package/dist/hooks/table/index.d.ts +9 -0
  265. package/dist/hooks/table/index.js +18 -0
  266. package/dist/index.d.ts +59 -7
  267. package/dist/index.js +140 -15
  268. package/dist/styles/icons/generated-icons.css +1 -1
  269. package/package.json +1 -1
  270. package/dist/components/card/CardActions.d.ts +0 -4
  271. package/dist/components/card/CardActions.js +0 -15
  272. package/dist/components/card/CardBody.d.ts +0 -4
  273. package/dist/components/card/CardBody.js +0 -15
  274. package/dist/components/card/CardImage.d.ts +0 -3
  275. package/dist/components/card/CardImage.js +0 -10
  276. package/dist/components/card/CardTitle.d.ts +0 -6
  277. package/dist/components/card/CardTitle.js +0 -13
  278. package/dist/components/card/card.css +0 -171
  279. package/dist/components/form/FormBase.d.ts +0 -8
  280. package/dist/components/form/FormBase.js +0 -74
  281. package/dist/components/form/FormDropdown.d.ts +0 -25
  282. package/dist/components/form/FormDropdown.js +0 -139
  283. package/dist/components/form/FormField.d.ts +0 -14
  284. package/dist/components/form/FormField.js +0 -78
  285. package/dist/components/form/Label.d.ts +0 -7
  286. package/dist/components/form/NumberField.d.ts +0 -20
  287. package/dist/components/form/NumberField.js +0 -109
  288. package/dist/components/form/PasswordField.d.ts +0 -16
  289. package/dist/components/form/PasswordField.js +0 -113
  290. package/dist/components/form/ValidatedForm.d.ts +0 -26
  291. package/dist/components/form/ValidatedForm.js +0 -55
  292. package/dist/components/menu/MenuDetails.d.ts +0 -8
  293. package/dist/components/menu/MenuDropdown.d.ts +0 -12
  294. package/dist/components/menu/MenuDropdown.js +0 -48
  295. package/dist/components/menu/MenuTitle.d.ts +0 -8
  296. package/dist/components/menu/MenuTitle.js +0 -22
  297. package/dist/components/menu/menu.css +0 -364
  298. package/dist/components/textarea/textarea.css +0 -191
  299. /package/dist/{components/table/hooks → hooks/table}/helpers.d.ts +0 -0
  300. /package/dist/{components/table/hooks → hooks/table}/helpers.js +0 -0
  301. /package/dist/{components/table/hooks → hooks/table}/useAnchoredOverlayPosition.d.ts +0 -0
  302. /package/dist/{components/table/hooks → hooks/table}/useAnchoredOverlayPosition.js +0 -0
  303. /package/dist/{components/table/hooks → hooks/table}/useTableExpansion.d.ts +0 -0
  304. /package/dist/{components/table/hooks → hooks/table}/useTableExpansion.js +0 -0
  305. /package/dist/{components/table/hooks → hooks/table}/useTableFiltering.d.ts +0 -0
  306. /package/dist/{components/table/hooks → hooks/table}/useTableFiltering.js +0 -0
  307. /package/dist/{components/table/hooks → hooks/table}/useTableModel.d.ts +0 -0
  308. /package/dist/{components/table/hooks → hooks/table}/useTableModel.js +0 -0
  309. /package/dist/{components/table/hooks → hooks/table}/useTablePagination.d.ts +0 -0
  310. /package/dist/{components/table/hooks → hooks/table}/useTablePagination.js +0 -0
  311. /package/dist/{components/table/hooks → hooks/table}/useTableSelection.d.ts +0 -0
  312. /package/dist/{components/table/hooks → hooks/table}/useTableSelection.js +0 -0
  313. /package/dist/{components/table/hooks → hooks/table}/useTableSorting.d.ts +0 -0
  314. /package/dist/{components/table/hooks → hooks/table}/useTableSorting.js +0 -0
@@ -0,0 +1,347 @@
1
+ import * as __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__ from "solid-js/web";
2
+ import "./NumberField.css";
3
+ import * as __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__ from "solid-js";
4
+ import * as __WEBPACK_EXTERNAL_MODULE_tailwind_merge_e05e3e95__ from "tailwind-merge";
5
+ import * as __WEBPACK_EXTERNAL_MODULE__NumberField_classes_js_abe73f12__ from "./NumberField.classes.js";
6
+ var _tmpl$ = /*#__PURE__*/ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.template)("<div>"), _tmpl$2 = /*#__PURE__*/ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.template)("<input>"), _tmpl$3 = /*#__PURE__*/ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.template)("<button>"), _tmpl$4 = /*#__PURE__*/ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.template)('<svg aria-hidden=true data-slot=number-field-increment-button-icon fill=none role=presentation viewBox="0 0 16 16"><path d="M8 3.25a.75.75 0 0 1 .75.75v3.25H12a.75.75 0 0 1 0 1.5H8.75V12a.75.75 0 0 1-1.5 0V8.75H4a.75.75 0 0 1 0-1.5h3.25V4A.75.75 0 0 1 8 3.25Z"fill=currentColor>'), _tmpl$5 = /*#__PURE__*/ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.template)('<svg aria-hidden=true data-slot=number-field-decrement-button-icon fill=none role=presentation viewBox="0 0 16 16"><path d="M4 7.25a.75.75 0 0 0 0 1.5h8a.75.75 0 0 0 0-1.5H4Z"fill=currentColor>');
7
+ const NumberFieldContext = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.createContext)();
8
+ const invokeEventHandler = (handler, event)=>{
9
+ if ("function" == typeof handler) return void handler(event);
10
+ if (Array.isArray(handler) && "function" == typeof handler[0]) handler[0](handler[1], event);
11
+ };
12
+ const toNumber = (value)=>{
13
+ const trimmedValue = value.trim();
14
+ if (!trimmedValue) return;
15
+ const parsedValue = Number(trimmedValue);
16
+ return Number.isFinite(parsedValue) ? parsedValue : void 0;
17
+ };
18
+ const clamp = (value, min, max)=>{
19
+ let clampedValue = value;
20
+ if (void 0 !== min && clampedValue < min) clampedValue = min;
21
+ if (void 0 !== max && clampedValue > max) clampedValue = max;
22
+ return clampedValue;
23
+ };
24
+ const formatNumber = (value)=>void 0 === value ? "" : `${value}`;
25
+ const NumberFieldRoot = (props)=>{
26
+ const [local, others] = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.splitProps)(props, [
27
+ "children",
28
+ "class",
29
+ "className",
30
+ "dataTheme",
31
+ "style",
32
+ "name",
33
+ "value",
34
+ "defaultValue",
35
+ "onChange",
36
+ "onBlur",
37
+ "min",
38
+ "max",
39
+ "step",
40
+ "fullWidth",
41
+ "variant",
42
+ "isDisabled",
43
+ "disabled",
44
+ "isInvalid"
45
+ ]);
46
+ const [internalValue, setInternalValue] = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.createSignal)(local.defaultValue);
47
+ const [inputValue, setInputValue] = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.createSignal)(formatNumber(local.defaultValue));
48
+ const isControlled = ()=>void 0 !== local.value;
49
+ const value = ()=>isControlled() ? local.value : internalValue();
50
+ const variant = ()=>local.variant ?? "primary";
51
+ const fullWidth = ()=>Boolean(local.fullWidth);
52
+ const isDisabled = ()=>Boolean(local.isDisabled) || Boolean(local.disabled);
53
+ const isInvalid = ()=>Boolean(local.isInvalid);
54
+ const step = ()=>local.step && Number.isFinite(local.step) ? local.step : 1;
55
+ const min = ()=>local.min;
56
+ const max = ()=>local.max;
57
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.createEffect)(()=>{
58
+ if (!isControlled()) return;
59
+ setInputValue(formatNumber(local.value));
60
+ });
61
+ const commitValue = (nextValue)=>{
62
+ if (!isControlled()) setInternalValue(nextValue);
63
+ setInputValue(formatNumber(nextValue));
64
+ local.onChange?.(nextValue);
65
+ };
66
+ const setFromInput = (nextValue)=>{
67
+ setInputValue(nextValue);
68
+ const parsedValue = toNumber(nextValue);
69
+ if ("" === nextValue.trim()) {
70
+ if (!isControlled()) setInternalValue(void 0);
71
+ local.onChange?.(void 0);
72
+ return;
73
+ }
74
+ if (void 0 === parsedValue) return;
75
+ const clampedValue = clamp(parsedValue, min(), max());
76
+ if (!isControlled()) setInternalValue(clampedValue);
77
+ local.onChange?.(clampedValue);
78
+ };
79
+ const adjustValue = (direction)=>{
80
+ if (isDisabled()) return;
81
+ const currentValue = toNumber(inputValue()) ?? value() ?? min() ?? (direction > 0 ? 0 : step() > 0 ? step() : 0);
82
+ const nextValue = clamp(currentValue + step() * direction, min(), max());
83
+ commitValue(nextValue);
84
+ };
85
+ const renderProps = ()=>({
86
+ value: value(),
87
+ isInvalid: isInvalid(),
88
+ isDisabled: isDisabled()
89
+ });
90
+ const contextValue = {
91
+ valueText: inputValue,
92
+ name: ()=>local.name,
93
+ variant,
94
+ fullWidth,
95
+ isDisabled,
96
+ isInvalid,
97
+ min,
98
+ max,
99
+ step,
100
+ onBlur: ()=>local.onBlur,
101
+ setFromInput,
102
+ increment: ()=>adjustValue(1),
103
+ decrement: ()=>adjustValue(-1)
104
+ };
105
+ return (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.createComponent)(NumberFieldContext.Provider, {
106
+ value: contextValue,
107
+ get children () {
108
+ var _el$ = _tmpl$();
109
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.spread)(_el$, (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.mergeProps)(others, {
110
+ get ["class"] () {
111
+ return (0, __WEBPACK_EXTERNAL_MODULE_tailwind_merge_e05e3e95__.twMerge)(__WEBPACK_EXTERNAL_MODULE__NumberField_classes_js_abe73f12__.CLASSES.Root.base, __WEBPACK_EXTERNAL_MODULE__NumberField_classes_js_abe73f12__.CLASSES.Root.variant[variant()], fullWidth() && __WEBPACK_EXTERNAL_MODULE__NumberField_classes_js_abe73f12__.CLASSES.Root.flag.fullWidth, local.class, local.className);
112
+ },
113
+ "data-slot": "number-field",
114
+ get ["data-invalid"] () {
115
+ return isInvalid() ? "true" : void 0;
116
+ },
117
+ get ["data-disabled"] () {
118
+ return isDisabled() ? "true" : void 0;
119
+ },
120
+ get ["aria-invalid"] () {
121
+ return isInvalid() ? "true" : void 0;
122
+ },
123
+ get ["aria-disabled"] () {
124
+ return isDisabled() ? "true" : void 0;
125
+ },
126
+ get ["data-theme"] () {
127
+ return local.dataTheme;
128
+ },
129
+ get style () {
130
+ return local.style;
131
+ }
132
+ }), false, true);
133
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.insert)(_el$, (()=>{
134
+ var _c$ = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.memo)(()=>"function" == typeof local.children);
135
+ return ()=>_c$() ? local.children(renderProps()) : (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.memo)(()=>!!local.children)() ? local.children : (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.createComponent)(NumberFieldGroup, {
136
+ get children () {
137
+ return [
138
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.createComponent)(NumberFieldDecrementButton, {}),
139
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.createComponent)(NumberFieldInput, {}),
140
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.createComponent)(NumberFieldIncrementButton, {})
141
+ ];
142
+ }
143
+ });
144
+ })());
145
+ return _el$;
146
+ }
147
+ });
148
+ };
149
+ const NumberFieldGroup = (props)=>{
150
+ const context = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.useContext)(NumberFieldContext);
151
+ const [local, others] = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.splitProps)(props, [
152
+ "children",
153
+ "class",
154
+ "className",
155
+ "dataTheme",
156
+ "style"
157
+ ]);
158
+ const renderProps = ()=>({
159
+ value: toNumber(context?.valueText() ?? ""),
160
+ isInvalid: context?.isInvalid() ?? false,
161
+ isDisabled: context?.isDisabled() ?? false
162
+ });
163
+ return (()=>{
164
+ var _el$2 = _tmpl$();
165
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.spread)(_el$2, (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.mergeProps)(others, {
166
+ get ["class"] () {
167
+ return (0, __WEBPACK_EXTERNAL_MODULE_tailwind_merge_e05e3e95__.twMerge)(__WEBPACK_EXTERNAL_MODULE__NumberField_classes_js_abe73f12__.CLASSES.Group.base, context?.fullWidth() && __WEBPACK_EXTERNAL_MODULE__NumberField_classes_js_abe73f12__.CLASSES.Group.flag.fullWidth, local.class, local.className);
168
+ },
169
+ "data-slot": "number-field-group",
170
+ get ["data-invalid"] () {
171
+ return context?.isInvalid() ? "true" : void 0;
172
+ },
173
+ get ["data-disabled"] () {
174
+ return context?.isDisabled() ? "true" : void 0;
175
+ },
176
+ get ["data-theme"] () {
177
+ return local.dataTheme;
178
+ },
179
+ get style () {
180
+ return local.style;
181
+ }
182
+ }), false, true);
183
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.insert)(_el$2, (()=>{
184
+ var _c$2 = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.memo)(()=>"function" == typeof local.children);
185
+ return ()=>_c$2() ? local.children(renderProps()) : local.children;
186
+ })());
187
+ return _el$2;
188
+ })();
189
+ };
190
+ const NumberFieldInput = (props)=>{
191
+ const context = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.useContext)(NumberFieldContext);
192
+ const [local, others] = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.splitProps)(props, [
193
+ "class",
194
+ "className",
195
+ "dataTheme",
196
+ "style",
197
+ "onInput",
198
+ "onBlur",
199
+ "name"
200
+ ]);
201
+ const handleInput = (event)=>{
202
+ invokeEventHandler(local.onInput, event);
203
+ if (event.defaultPrevented) return;
204
+ context?.setFromInput(event.currentTarget.value, event);
205
+ };
206
+ const handleBlur = (event)=>{
207
+ invokeEventHandler(local.onBlur, event);
208
+ invokeEventHandler(context?.onBlur(), event);
209
+ };
210
+ return (()=>{
211
+ var _el$3 = _tmpl$2();
212
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.spread)(_el$3, (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.mergeProps)(others, {
213
+ type: "text",
214
+ inputmode: "decimal",
215
+ get ["class"] () {
216
+ return (0, __WEBPACK_EXTERNAL_MODULE_tailwind_merge_e05e3e95__.twMerge)(__WEBPACK_EXTERNAL_MODULE__NumberField_classes_js_abe73f12__.CLASSES.Input.base, local.class, local.className);
217
+ },
218
+ "data-slot": "number-field-input",
219
+ get ["data-theme"] () {
220
+ return local.dataTheme;
221
+ },
222
+ get style () {
223
+ return local.style;
224
+ },
225
+ get name () {
226
+ return local.name ?? context?.name();
227
+ },
228
+ get value () {
229
+ return context?.valueText() ?? "";
230
+ },
231
+ get disabled () {
232
+ return context?.isDisabled();
233
+ },
234
+ get ["aria-invalid"] () {
235
+ return context?.isInvalid() ? "true" : void 0;
236
+ },
237
+ get ["aria-disabled"] () {
238
+ return context?.isDisabled() ? "true" : void 0;
239
+ },
240
+ get min () {
241
+ return context?.min();
242
+ },
243
+ get max () {
244
+ return context?.max();
245
+ },
246
+ get step () {
247
+ return context?.step();
248
+ },
249
+ onInput: handleInput,
250
+ onBlur: handleBlur
251
+ }), false, false);
252
+ return _el$3;
253
+ })();
254
+ };
255
+ const NumberFieldIncrementButton = (props)=>{
256
+ const context = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.useContext)(NumberFieldContext);
257
+ const [local, others] = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.splitProps)(props, [
258
+ "children",
259
+ "class",
260
+ "className",
261
+ "dataTheme",
262
+ "style",
263
+ "onClick"
264
+ ]);
265
+ const handleClick = (event)=>{
266
+ invokeEventHandler(local.onClick, event);
267
+ if (event.defaultPrevented) return;
268
+ context?.increment(event);
269
+ };
270
+ return (()=>{
271
+ var _el$4 = _tmpl$3();
272
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.spread)(_el$4, (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.mergeProps)(others, {
273
+ type: "button",
274
+ get ["class"] () {
275
+ return (0, __WEBPACK_EXTERNAL_MODULE_tailwind_merge_e05e3e95__.twMerge)(__WEBPACK_EXTERNAL_MODULE__NumberField_classes_js_abe73f12__.CLASSES.IncrementButton.base, local.class, local.className);
276
+ },
277
+ "data-slot": "number-field-increment-button",
278
+ get ["data-theme"] () {
279
+ return local.dataTheme;
280
+ },
281
+ get style () {
282
+ return local.style;
283
+ },
284
+ get disabled () {
285
+ return context?.isDisabled();
286
+ },
287
+ get ["aria-disabled"] () {
288
+ return context?.isDisabled() ? "true" : void 0;
289
+ },
290
+ slot: "increment",
291
+ onClick: handleClick
292
+ }), false, true);
293
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.insert)(_el$4, ()=>local.children ?? _tmpl$4());
294
+ return _el$4;
295
+ })();
296
+ };
297
+ const NumberFieldDecrementButton = (props)=>{
298
+ const context = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.useContext)(NumberFieldContext);
299
+ const [local, others] = (0, __WEBPACK_EXTERNAL_MODULE_solid_js_aeefcc6d__.splitProps)(props, [
300
+ "children",
301
+ "class",
302
+ "className",
303
+ "dataTheme",
304
+ "style",
305
+ "onClick"
306
+ ]);
307
+ const handleClick = (event)=>{
308
+ invokeEventHandler(local.onClick, event);
309
+ if (event.defaultPrevented) return;
310
+ context?.decrement(event);
311
+ };
312
+ return (()=>{
313
+ var _el$6 = _tmpl$3();
314
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.spread)(_el$6, (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.mergeProps)(others, {
315
+ type: "button",
316
+ get ["class"] () {
317
+ return (0, __WEBPACK_EXTERNAL_MODULE_tailwind_merge_e05e3e95__.twMerge)(__WEBPACK_EXTERNAL_MODULE__NumberField_classes_js_abe73f12__.CLASSES.DecrementButton.base, local.class, local.className);
318
+ },
319
+ "data-slot": "number-field-decrement-button",
320
+ get ["data-theme"] () {
321
+ return local.dataTheme;
322
+ },
323
+ get style () {
324
+ return local.style;
325
+ },
326
+ get disabled () {
327
+ return context?.isDisabled();
328
+ },
329
+ get ["aria-disabled"] () {
330
+ return context?.isDisabled() ? "true" : void 0;
331
+ },
332
+ slot: "decrement",
333
+ onClick: handleClick
334
+ }), false, true);
335
+ (0, __WEBPACK_EXTERNAL_MODULE_solid_js_web_35d951b7__.insert)(_el$6, ()=>local.children ?? _tmpl$5());
336
+ return _el$6;
337
+ })();
338
+ };
339
+ const NumberField_NumberField = Object.assign(NumberFieldRoot, {
340
+ Root: NumberFieldRoot,
341
+ Group: NumberFieldGroup,
342
+ Input: NumberFieldInput,
343
+ IncrementButton: NumberFieldIncrementButton,
344
+ DecrementButton: NumberFieldDecrementButton
345
+ });
346
+ const NumberField = NumberField_NumberField;
347
+ export { NumberField_NumberField as NumberField, NumberFieldDecrementButton, NumberFieldGroup, NumberFieldIncrementButton, NumberFieldInput, NumberFieldRoot, NumberField as default };
@@ -0,0 +1 @@
1
+ export { default, NumberField, NumberFieldRoot, NumberFieldGroup, NumberFieldInput, NumberFieldIncrementButton, NumberFieldDecrementButton, type NumberFieldProps, type NumberFieldRootProps, type NumberFieldGroupProps, type NumberFieldInputProps, type NumberFieldIncrementButtonProps, type NumberFieldDecrementButtonProps, type NumberFieldVariant, type NumberFieldRenderProps, } from "./NumberField";
@@ -0,0 +1,9 @@
1
+ import * as __WEBPACK_EXTERNAL_MODULE__NumberField_js_68db54de__ from "./NumberField.js";
2
+ var __webpack_exports__NumberField = __WEBPACK_EXTERNAL_MODULE__NumberField_js_68db54de__.NumberField;
3
+ var __webpack_exports__NumberFieldDecrementButton = __WEBPACK_EXTERNAL_MODULE__NumberField_js_68db54de__.NumberFieldDecrementButton;
4
+ var __webpack_exports__NumberFieldGroup = __WEBPACK_EXTERNAL_MODULE__NumberField_js_68db54de__.NumberFieldGroup;
5
+ var __webpack_exports__NumberFieldIncrementButton = __WEBPACK_EXTERNAL_MODULE__NumberField_js_68db54de__.NumberFieldIncrementButton;
6
+ var __webpack_exports__NumberFieldInput = __WEBPACK_EXTERNAL_MODULE__NumberField_js_68db54de__.NumberFieldInput;
7
+ var __webpack_exports__NumberFieldRoot = __WEBPACK_EXTERNAL_MODULE__NumberField_js_68db54de__.NumberFieldRoot;
8
+ var __webpack_exports__default = __WEBPACK_EXTERNAL_MODULE__NumberField_js_68db54de__["default"];
9
+ export { __webpack_exports__NumberField as NumberField, __webpack_exports__NumberFieldDecrementButton as NumberFieldDecrementButton, __webpack_exports__NumberFieldGroup as NumberFieldGroup, __webpack_exports__NumberFieldIncrementButton as NumberFieldIncrementButton, __webpack_exports__NumberFieldInput as NumberFieldInput, __webpack_exports__NumberFieldRoot as NumberFieldRoot, __webpack_exports__default as default };
@@ -0,0 +1,27 @@
1
+ export declare const CLASSES: {
2
+ readonly Root: {
3
+ readonly base: "search-field";
4
+ readonly variant: {
5
+ readonly primary: "search-field--primary";
6
+ readonly secondary: "search-field--secondary";
7
+ };
8
+ readonly flag: {
9
+ readonly fullWidth: "search-field--full-width";
10
+ };
11
+ };
12
+ readonly Group: {
13
+ readonly base: "search-field__group";
14
+ readonly flag: {
15
+ readonly fullWidth: "search-field__group--full-width";
16
+ };
17
+ };
18
+ readonly Input: {
19
+ readonly base: "search-field__input";
20
+ };
21
+ readonly SearchIcon: {
22
+ readonly base: "search-field__search-icon";
23
+ };
24
+ readonly ClearButton: {
25
+ readonly base: "search-field__clear-button";
26
+ };
27
+ };
@@ -0,0 +1,28 @@
1
+ const CLASSES = {
2
+ Root: {
3
+ base: "search-field",
4
+ variant: {
5
+ primary: "search-field--primary",
6
+ secondary: "search-field--secondary"
7
+ },
8
+ flag: {
9
+ fullWidth: "search-field--full-width"
10
+ }
11
+ },
12
+ Group: {
13
+ base: "search-field__group",
14
+ flag: {
15
+ fullWidth: "search-field__group--full-width"
16
+ }
17
+ },
18
+ Input: {
19
+ base: "search-field__input"
20
+ },
21
+ SearchIcon: {
22
+ base: "search-field__search-icon"
23
+ },
24
+ ClearButton: {
25
+ base: "search-field__clear-button"
26
+ }
27
+ };
28
+ export { CLASSES };
@@ -0,0 +1,183 @@
1
+ @layer components {
2
+ .search-field {
3
+ display: flex;
4
+ flex-direction: column;
5
+ gap: 0.25rem;
6
+ }
7
+
8
+ .search-field[data-invalid="true"] [data-slot="description"],
9
+ .search-field[aria-invalid="true"] [data-slot="description"] {
10
+ display: none;
11
+ }
12
+
13
+ .search-field [data-slot="label"] {
14
+ width: fit-content;
15
+ }
16
+
17
+ .search-field [data-slot="description"] {
18
+ padding-inline: 0.25rem;
19
+ }
20
+
21
+ .search-field[data-empty="true"] [data-slot="search-field-clear-button"] {
22
+ pointer-events: none;
23
+ opacity: 0;
24
+ }
25
+
26
+ .search-field__group {
27
+ position: relative;
28
+ display: inline-flex;
29
+ align-items: center;
30
+ height: 2.25rem;
31
+ overflow: hidden;
32
+ border-radius: var(--radius-field, 0.75rem);
33
+ border: var(--border-width-field, 1px) solid
34
+ var(--color-field-border, color-mix(in oklab, var(--color-base-content) 16%, transparent));
35
+ background-color: var(--color-field, var(--color-base-100));
36
+ color: var(--color-field-foreground, var(--color-base-content));
37
+ box-shadow:
38
+ 0 1px 0 color-mix(in oklab, var(--color-base-content) 8%, transparent),
39
+ 0 1px 0 color-mix(in oklab, var(--color-base-100) 60%, transparent) inset;
40
+ outline: none;
41
+ transition:
42
+ background-color 150ms var(--ease-smooth),
43
+ border-color 150ms var(--ease-smooth),
44
+ box-shadow 150ms var(--ease-out);
45
+ }
46
+
47
+ @media (prefers-reduced-motion: reduce) {
48
+ .search-field__group {
49
+ transition: none;
50
+ }
51
+ }
52
+
53
+ @media (hover: hover) {
54
+ .search-field__group:hover:not(:focus-within):not([data-disabled="true"]) {
55
+ background-color: var(--color-field-hover, var(--color-base-200));
56
+ border-color: var(--color-field-border-hover, color-mix(in oklab, var(--color-base-content) 22%, transparent));
57
+ }
58
+ }
59
+
60
+ .search-field__group:focus-within,
61
+ .search-field__group[data-focus-within="true"] {
62
+ border-color: var(--color-field-border-focus, var(--color-accent));
63
+ background-color: var(--color-field-focus, var(--color-base-100));
64
+ box-shadow:
65
+ 0 0 0 3px color-mix(in oklab, var(--color-accent) 22%, transparent),
66
+ 0 1px 0 color-mix(in oklab, var(--color-accent) 24%, transparent);
67
+ }
68
+
69
+ .search-field__group[data-invalid="true"] {
70
+ border-color: var(--color-field-border-invalid, var(--color-danger));
71
+ background-color: var(--color-field-focus, var(--color-base-100));
72
+ box-shadow:
73
+ 0 0 0 3px color-mix(in oklab, var(--color-danger) 20%, transparent),
74
+ 0 1px 0 color-mix(in oklab, var(--color-danger) 20%, transparent);
75
+ }
76
+
77
+ .search-field__group[data-disabled="true"],
78
+ .search-field__group[aria-disabled="true"] {
79
+ cursor: not-allowed;
80
+ background-color: var(--color-base-200);
81
+ color: color-mix(in oklab, var(--color-base-content) 45%, transparent);
82
+ opacity: var(--disabled-opacity, 0.6);
83
+ box-shadow: none;
84
+ }
85
+
86
+ .search-field__input {
87
+ flex: 1;
88
+ min-width: 0;
89
+ border: 0;
90
+ border-radius: 0;
91
+ background: transparent;
92
+ padding-block: 0.5rem;
93
+ padding-inline: 0.75rem;
94
+ font-size: 0.875rem;
95
+ line-height: 1.25rem;
96
+ color: inherit;
97
+ box-shadow: none;
98
+ outline: none;
99
+ }
100
+
101
+ .search-field__input::placeholder {
102
+ color: var(--color-field-placeholder, color-mix(in oklab, var(--color-base-content) 45%, transparent));
103
+ }
104
+
105
+ .search-field__input::-webkit-search-cancel-button,
106
+ .search-field__input::-webkit-search-decoration {
107
+ -webkit-appearance: none;
108
+ appearance: none;
109
+ }
110
+
111
+ .search-field__group:has([data-slot="search-field-search-icon"]) .search-field__input {
112
+ padding-inline-start: 0.5rem;
113
+ }
114
+
115
+ .search-field__group:has([slot="clear"]) .search-field__input {
116
+ padding-inline-end: 0.5rem;
117
+ }
118
+
119
+ .search-field__input:focus,
120
+ .search-field__input:focus-visible {
121
+ outline: none;
122
+ }
123
+
124
+ .search-field__search-icon {
125
+ display: inline-flex;
126
+ align-items: center;
127
+ justify-content: center;
128
+ margin-inline-start: 0.75rem;
129
+ margin-inline-end: 0;
130
+ flex-shrink: 0;
131
+ width: 1rem;
132
+ height: 1rem;
133
+ color: var(--color-field-placeholder, color-mix(in oklab, var(--color-base-content) 45%, transparent));
134
+ pointer-events: none;
135
+ }
136
+
137
+ .search-field__search-icon > * {
138
+ width: 100%;
139
+ height: 100%;
140
+ pointer-events: none;
141
+ }
142
+
143
+ .search-field__clear-button {
144
+ margin-inline-end: 0.5rem;
145
+ flex-shrink: 0;
146
+ width: 1.25rem;
147
+ height: 1.25rem;
148
+ }
149
+
150
+ .search-field__clear-button > * {
151
+ width: 0.75rem;
152
+ height: 0.75rem;
153
+ }
154
+
155
+ .search-field--secondary .search-field__group {
156
+ box-shadow: none;
157
+ background-color: var(--search-field-group-bg, var(--color-default, var(--color-base-200)));
158
+ }
159
+
160
+ @media (hover: hover) {
161
+ .search-field--secondary .search-field__group:hover:not(:focus-within):not([data-disabled="true"]) {
162
+ background-color: var(--search-field-group-bg-hover, var(--color-default-hover, var(--color-base-300)));
163
+ }
164
+ }
165
+
166
+ .search-field--secondary .search-field__group:focus-within,
167
+ .search-field--secondary .search-field__group[data-focus-within="true"] {
168
+ background-color: var(--search-field-group-bg-focus, var(--color-default, var(--color-base-200)));
169
+ }
170
+
171
+ .search-field--secondary .search-field__group[data-invalid="true"] {
172
+ border-color: var(--color-field-border-invalid, var(--color-danger));
173
+ background-color: var(--search-field-group-bg-focus, var(--color-default, var(--color-base-200)));
174
+ }
175
+
176
+ .search-field--full-width {
177
+ width: 100%;
178
+ }
179
+
180
+ .search-field__group--full-width {
181
+ width: 100%;
182
+ }
183
+ }
@@ -0,0 +1,53 @@
1
+ import "./SearchField.css";
2
+ import { type Component, type JSX, type ParentComponent } from "solid-js";
3
+ import { type CloseButtonProps } from "../close-button";
4
+ import type { IComponentBaseProps } from "../types";
5
+ export type SearchFieldVariant = "primary" | "secondary";
6
+ export type SearchFieldRenderProps = {
7
+ value: string;
8
+ isEmpty: boolean;
9
+ isInvalid: boolean;
10
+ isDisabled: boolean;
11
+ };
12
+ export type SearchFieldRootProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, "children" | "onChange" | "onBlur"> & IComponentBaseProps & {
13
+ children?: JSX.Element | ((props: SearchFieldRenderProps) => JSX.Element);
14
+ startIcon?: JSX.Element;
15
+ endIcon?: JSX.Element;
16
+ name?: string;
17
+ value?: string;
18
+ defaultValue?: string;
19
+ onChange?: (value: string) => void;
20
+ onBlur?: JSX.EventHandlerUnion<HTMLInputElement, FocusEvent>;
21
+ fullWidth?: boolean;
22
+ variant?: SearchFieldVariant;
23
+ isDisabled?: boolean;
24
+ disabled?: boolean;
25
+ isInvalid?: boolean;
26
+ };
27
+ export type SearchFieldGroupProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, "children"> & IComponentBaseProps & {
28
+ children?: JSX.Element | ((props: SearchFieldRenderProps) => JSX.Element);
29
+ };
30
+ export type SearchFieldInputProps = Omit<JSX.InputHTMLAttributes<HTMLInputElement>, "value" | "onInput" | "type"> & IComponentBaseProps & {
31
+ onInput?: JSX.EventHandlerUnion<HTMLInputElement, InputEvent>;
32
+ };
33
+ export type SearchFieldSearchIconProps = JSX.HTMLAttributes<HTMLSpanElement> & IComponentBaseProps & {
34
+ children?: JSX.Element;
35
+ };
36
+ export type SearchFieldClearButtonProps = Omit<CloseButtonProps, "onClick"> & IComponentBaseProps & {
37
+ onClick?: JSX.EventHandlerUnion<HTMLButtonElement, MouseEvent>;
38
+ };
39
+ declare const SearchFieldRoot: ParentComponent<SearchFieldRootProps>;
40
+ declare const SearchFieldGroup: ParentComponent<SearchFieldGroupProps>;
41
+ declare const SearchFieldInput: Component<SearchFieldInputProps>;
42
+ declare const SearchFieldSearchIcon: Component<SearchFieldSearchIconProps>;
43
+ declare const SearchFieldClearButton: Component<SearchFieldClearButtonProps>;
44
+ declare const SearchField: ParentComponent<SearchFieldRootProps> & {
45
+ Root: ParentComponent<SearchFieldRootProps>;
46
+ Group: ParentComponent<SearchFieldGroupProps>;
47
+ Input: Component<SearchFieldInputProps>;
48
+ SearchIcon: Component<SearchFieldSearchIconProps>;
49
+ ClearButton: Component<SearchFieldClearButtonProps>;
50
+ };
51
+ export default SearchField;
52
+ export { SearchField, SearchFieldRoot, SearchFieldGroup, SearchFieldInput, SearchFieldSearchIcon, SearchFieldClearButton, };
53
+ export type { SearchFieldRootProps as SearchFieldProps };