@hashicorp/mds-react 0.9.3 → 0.9.4

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 (360) hide show
  1. package/components/accordion/index.js +9 -0
  2. package/components/accordion/index.js.map +1 -0
  3. package/components/accordion/item/button.js +44 -0
  4. package/components/accordion/item/button.js.map +1 -0
  5. package/components/accordion/item/index.js +59 -0
  6. package/components/accordion/item/index.js.map +1 -0
  7. package/components/accordion/style.module.scss.js +24 -0
  8. package/components/accordion/style.module.scss.js.map +1 -0
  9. package/components/alert/alert.module.scss.js +29 -0
  10. package/components/alert/alert.module.scss.js.map +1 -0
  11. package/components/alert/icon.js +34 -0
  12. package/components/alert/icon.js.map +1 -0
  13. package/components/alert/index.js +97 -0
  14. package/components/alert/index.js.map +1 -0
  15. package/components/badge/index.js +50 -0
  16. package/components/badge/index.js.map +1 -0
  17. package/components/badge/style.module.scss.js +22 -0
  18. package/components/badge/style.module.scss.js.map +1 -0
  19. package/components/badge-count/index.js +29 -0
  20. package/components/badge-count/index.js.map +1 -0
  21. package/components/badge-count/style.module.scss.js +15 -0
  22. package/components/badge-count/style.module.scss.js.map +1 -0
  23. package/components/breadcrumbs/index.js +38 -0
  24. package/components/breadcrumbs/index.js.map +1 -0
  25. package/components/breadcrumbs/item/index.js +32 -0
  26. package/components/breadcrumbs/item/index.js.map +1 -0
  27. package/components/breadcrumbs/style.module.scss.js +27 -0
  28. package/components/breadcrumbs/style.module.scss.js.map +1 -0
  29. package/components/breadcrumbs/truncation-button/index.js +25 -0
  30. package/components/breadcrumbs/truncation-button/index.js.map +1 -0
  31. package/components/button/index.d.ts +2 -1
  32. package/components/button/index.js +119 -0
  33. package/components/button/index.js.map +1 -0
  34. package/components/button/styles.module.scss.js +32 -0
  35. package/components/button/styles.module.scss.js.map +1 -0
  36. package/components/card/card-thumbnail/card-thumbnail.module.css.js +8 -0
  37. package/components/card/card-thumbnail/card-thumbnail.module.css.js.map +1 -0
  38. package/components/card/card-thumbnail/index.js +23 -0
  39. package/components/card/card-thumbnail/index.js.map +1 -0
  40. package/components/card/index.d.ts +2 -1
  41. package/components/card/index.js +160 -0
  42. package/components/card/index.js.map +1 -0
  43. package/components/card/styles.module.css.js +29 -0
  44. package/components/card/styles.module.css.js.map +1 -0
  45. package/components/card/types.d.ts +1 -0
  46. package/components/code-block/code-block.module.scss.js +34 -0
  47. package/components/code-block/code-block.module.scss.js.map +1 -0
  48. package/components/code-block/code-lines/index.js +59 -0
  49. package/components/code-block/code-lines/index.js.map +1 -0
  50. package/components/code-block/code-lines/utils/split-html-into-lines.js +19 -0
  51. package/components/code-block/code-lines/utils/split-html-into-lines.js.map +1 -0
  52. package/components/code-block/code-lines/utils/split-jsx-into-lines.js +31 -0
  53. package/components/code-block/code-lines/utils/split-jsx-into-lines.js.map +1 -0
  54. package/components/code-block/hidden-copy-content/index.js +13 -0
  55. package/components/code-block/hidden-copy-content/index.js.map +1 -0
  56. package/components/code-block/index.js +88 -0
  57. package/components/code-block/index.js.map +1 -0
  58. package/components/code-block/utils/parse-highlighted-lines.js +39 -0
  59. package/components/code-block/utils/parse-highlighted-lines.js.map +1 -0
  60. package/components/code-block/utils/process-snippet.js +20 -0
  61. package/components/code-block/utils/process-snippet.js.map +1 -0
  62. package/components/code-block/utils/shellwords.js +33 -0
  63. package/components/code-block/utils/shellwords.js.map +1 -0
  64. package/components/combo-box-primitive/index.js +302 -0
  65. package/components/combo-box-primitive/index.js.map +1 -0
  66. package/components/dialog-primitive/dialog.module.scss.js +12 -0
  67. package/components/dialog-primitive/dialog.module.scss.js.map +1 -0
  68. package/components/dialog-primitive/index.js +15 -0
  69. package/components/dialog-primitive/index.js.map +1 -0
  70. package/components/disclosure-primitive/index.js +57 -0
  71. package/components/disclosure-primitive/index.js.map +1 -0
  72. package/components/disclosure-primitive/styles.module.css.js +7 -0
  73. package/components/disclosure-primitive/styles.module.css.js.map +1 -0
  74. package/components/disclosure-primitive/use-disclosure-primitive.js +17 -0
  75. package/components/disclosure-primitive/use-disclosure-primitive.js.map +1 -0
  76. package/components/dismiss-button/index.js +22 -0
  77. package/components/dismiss-button/index.js.map +1 -0
  78. package/components/dismiss-button/styles.module.scss.js +7 -0
  79. package/components/dismiss-button/styles.module.scss.js.map +1 -0
  80. package/components/dropdown/index.js +79 -0
  81. package/components/dropdown/index.js.map +1 -0
  82. package/components/dropdown/list-item/custom.js +9 -0
  83. package/components/dropdown/list-item/custom.js.map +1 -0
  84. package/components/dropdown/list-item/index.js +14 -0
  85. package/components/dropdown/list-item/index.js.map +1 -0
  86. package/components/dropdown/list-item/interactive.js +49 -0
  87. package/components/dropdown/list-item/interactive.js.map +1 -0
  88. package/components/dropdown/list-item/separator.js +17 -0
  89. package/components/dropdown/list-item/separator.js.map +1 -0
  90. package/components/dropdown/list-item/styles.module.css.js +26 -0
  91. package/components/dropdown/list-item/styles.module.css.js.map +1 -0
  92. package/components/dropdown/list-item/title.js +9 -0
  93. package/components/dropdown/list-item/title.js.map +1 -0
  94. package/components/dropdown/styles.module.css.js +24 -0
  95. package/components/dropdown/styles.module.css.js.map +1 -0
  96. package/components/dropdown/toggle-button/index.js +54 -0
  97. package/components/dropdown/toggle-button/index.js.map +1 -0
  98. package/components/dropdown/toggle-button/styles.module.scss.js +14 -0
  99. package/components/dropdown/toggle-button/styles.module.scss.js.map +1 -0
  100. package/components/flight-icon/flight-icon.module.css.js +12 -0
  101. package/components/flight-icon/flight-icon.module.css.js.map +1 -0
  102. package/components/flight-icon/index.js +58 -0
  103. package/components/flight-icon/index.js.map +1 -0
  104. package/components/form/checkbox/form-checkbox.module.css.js +8 -0
  105. package/components/form/checkbox/form-checkbox.module.css.js.map +1 -0
  106. package/components/form/checkbox/index.js +109 -0
  107. package/components/form/checkbox/index.js.map +1 -0
  108. package/components/form/error/form-error.module.css.js +14 -0
  109. package/components/form/error/form-error.module.css.js.map +1 -0
  110. package/components/form/error/index.js +22 -0
  111. package/components/form/error/index.js.map +1 -0
  112. package/components/form/field/form-field.module.css.js +17 -0
  113. package/components/form/field/form-field.module.css.js.map +1 -0
  114. package/components/form/field/index.js +46 -0
  115. package/components/form/field/index.js.map +1 -0
  116. package/components/form/fieldset/form-fieldset.module.css.js +19 -0
  117. package/components/form/fieldset/form-fieldset.module.css.js.map +1 -0
  118. package/components/form/fieldset/index.js +65 -0
  119. package/components/form/fieldset/index.js.map +1 -0
  120. package/components/form/file-input/form-file-input.module.scss.js +7 -0
  121. package/components/form/file-input/form-file-input.module.scss.js.map +1 -0
  122. package/components/form/file-input/index.js +68 -0
  123. package/components/form/file-input/index.js.map +1 -0
  124. package/components/form/helper-text/form-helper-text.module.css.js +7 -0
  125. package/components/form/helper-text/form-helper-text.module.css.js.map +1 -0
  126. package/components/form/helper-text/index.js +22 -0
  127. package/components/form/helper-text/index.js.map +1 -0
  128. package/components/form/indicator/form-indicator.module.css.js +8 -0
  129. package/components/form/indicator/form-indicator.module.css.js.map +1 -0
  130. package/components/form/indicator/index.js +23 -0
  131. package/components/form/indicator/index.js.map +1 -0
  132. package/components/form/label/form-label.module.css.js +10 -0
  133. package/components/form/label/form-label.module.css.js.map +1 -0
  134. package/components/form/label/index.js +33 -0
  135. package/components/form/label/index.js.map +1 -0
  136. package/components/form/legend/form-legend.module.css.js +10 -0
  137. package/components/form/legend/form-legend.module.css.js.map +1 -0
  138. package/components/form/legend/index.js +19 -0
  139. package/components/form/legend/index.js.map +1 -0
  140. package/components/form/radio/form-radio.module.scss.js +8 -0
  141. package/components/form/radio/form-radio.module.scss.js.map +1 -0
  142. package/components/form/radio/index.js +100 -0
  143. package/components/form/radio/index.js.map +1 -0
  144. package/components/form/radio-card/description.js +10 -0
  145. package/components/form/radio-card/description.js.map +1 -0
  146. package/components/form/radio-card/form-radio-card.module.css.js +30 -0
  147. package/components/form/radio-card/form-radio-card.module.css.js.map +1 -0
  148. package/components/form/radio-card/group.js +31 -0
  149. package/components/form/radio-card/group.js.map +1 -0
  150. package/components/form/radio-card/index.js +67 -0
  151. package/components/form/radio-card/index.js.map +1 -0
  152. package/components/form/radio-card/label.js +10 -0
  153. package/components/form/radio-card/label.js.map +1 -0
  154. package/components/form/select/form-select.module.css.js +14 -0
  155. package/components/form/select/form-select.module.css.js.map +1 -0
  156. package/components/form/select/index.js +79 -0
  157. package/components/form/select/index.js.map +1 -0
  158. package/components/form/super-select/form-super-select.module.css.js +22 -0
  159. package/components/form/super-select/form-super-select.module.css.js.map +1 -0
  160. package/components/form/super-select/index.js +170 -0
  161. package/components/form/super-select/index.js.map +1 -0
  162. package/components/form/text-input/index.js +91 -0
  163. package/components/form/text-input/index.js.map +1 -0
  164. package/components/form/text-input/styles.module.css.js +15 -0
  165. package/components/form/text-input/styles.module.css.js.map +1 -0
  166. package/components/form/textarea/form-textarea.module.css.js +14 -0
  167. package/components/form/textarea/form-textarea.module.css.js.map +1 -0
  168. package/components/form/textarea/index.js +74 -0
  169. package/components/form/textarea/index.js.map +1 -0
  170. package/components/form/toggle/form-toggle.module.scss.js +12 -0
  171. package/components/form/toggle/form-toggle.module.scss.js.map +1 -0
  172. package/components/form/toggle/index.js +102 -0
  173. package/components/form/toggle/index.js.map +1 -0
  174. package/components/hds/wrappers/tooltip.js +51 -0
  175. package/components/hds/wrappers/tooltip.js.map +1 -0
  176. package/components/icon-tile/index.js +50 -0
  177. package/components/icon-tile/index.js.map +1 -0
  178. package/components/icon-tile/style.module.scss.js +29 -0
  179. package/components/icon-tile/style.module.scss.js.map +1 -0
  180. package/components/index.d.ts +1 -1
  181. package/components/index.js +116 -73
  182. package/components/index.js.map +1 -1
  183. package/components/inline-link/index.js +33 -0
  184. package/components/inline-link/index.js.map +1 -0
  185. package/components/inline-link/inline-link.module.css.js +11 -0
  186. package/components/inline-link/inline-link.module.css.js.map +1 -0
  187. package/components/interactive/index.js +59 -0
  188. package/components/interactive/index.js.map +1 -0
  189. package/components/legacy-button/index.js +65 -0
  190. package/components/legacy-button/index.js.map +1 -0
  191. package/components/legacy-button/utils.js +39 -0
  192. package/components/legacy-button/utils.js.map +1 -0
  193. package/components/menu-primitive/index.js +68 -0
  194. package/components/menu-primitive/index.js.map +1 -0
  195. package/components/menu-primitive/styles.module.css.js +12 -0
  196. package/components/menu-primitive/styles.module.css.js.map +1 -0
  197. package/components/menu-primitive/use-menu-primitive.js +17 -0
  198. package/components/menu-primitive/use-menu-primitive.js.map +1 -0
  199. package/components/modal/index.js +61 -0
  200. package/components/modal/index.js.map +1 -0
  201. package/components/modal/modal.module.css.js +8 -0
  202. package/components/modal/modal.module.css.js.map +1 -0
  203. package/components/modal/use-modal.js +17 -0
  204. package/components/modal/use-modal.js.map +1 -0
  205. package/components/separator/index.js +15 -0
  206. package/components/separator/index.js.map +1 -0
  207. package/components/separator/separator.module.css.js +10 -0
  208. package/components/separator/separator.module.css.js.map +1 -0
  209. package/components/standalone-link/index.js +54 -0
  210. package/components/standalone-link/index.js.map +1 -0
  211. package/components/standalone-link/styles.module.scss.js +17 -0
  212. package/components/standalone-link/styles.module.scss.js.map +1 -0
  213. package/components/table/index.js +52 -0
  214. package/components/table/index.js.map +1 -0
  215. package/components/table/table.module.scss.js +33 -0
  216. package/components/table/table.module.scss.js.map +1 -0
  217. package/components/table/td.js +28 -0
  218. package/components/table/td.js.map +1 -0
  219. package/components/table/th-button-tooltip.js +24 -0
  220. package/components/table/th-button-tooltip.js.map +1 -0
  221. package/components/table/th.js +43 -0
  222. package/components/table/th.js.map +1 -0
  223. package/components/table/tr.js +9 -0
  224. package/components/table/tr.js.map +1 -0
  225. package/components/table/utils.js +28 -0
  226. package/components/table/utils.js.map +1 -0
  227. package/components/tabs/index.js +117 -0
  228. package/components/tabs/index.js.map +1 -0
  229. package/components/tabs/tab-panel.js +35 -0
  230. package/components/tabs/tab-panel.js.map +1 -0
  231. package/components/tabs/tab.js +70 -0
  232. package/components/tabs/tab.js.map +1 -0
  233. package/components/tabs/tabs.module.scss.js +22 -0
  234. package/components/tabs/tabs.module.scss.js.map +1 -0
  235. package/components/tabs/use-tabs-context.js +16 -0
  236. package/components/tabs/use-tabs-context.js.map +1 -0
  237. package/components/text/index.js +112 -0
  238. package/components/text/index.js.map +1 -0
  239. package/components/text/style.module.scss.js +9 -0
  240. package/components/text/style.module.scss.js.map +1 -0
  241. package/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.js +62 -0
  242. package/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.js.map +1 -0
  243. package/components/visualizations/bar-chart/horizontal-chart/dataset-value/style.module.css.js +20 -0
  244. package/components/visualizations/bar-chart/horizontal-chart/dataset-value/style.module.css.js.map +1 -0
  245. package/components/visualizations/bar-chart/horizontal-chart/index.js +104 -0
  246. package/components/visualizations/bar-chart/horizontal-chart/index.js.map +1 -0
  247. package/components/visualizations/bar-chart/horizontal-chart/legend/index.js +13 -0
  248. package/components/visualizations/bar-chart/horizontal-chart/legend/index.js.map +1 -0
  249. package/components/visualizations/bar-chart/horizontal-chart/legend/style.module.css.js +14 -0
  250. package/components/visualizations/bar-chart/horizontal-chart/legend/style.module.css.js.map +1 -0
  251. package/components/visualizations/bar-chart/horizontal-chart/style.module.css.js +28 -0
  252. package/components/visualizations/bar-chart/horizontal-chart/style.module.css.js.map +1 -0
  253. package/components/visualizations/bar-chart/index.js +37 -0
  254. package/components/visualizations/bar-chart/index.js.map +1 -0
  255. package/components/visualizations/bar-chart/style.module.css.js +12 -0
  256. package/components/visualizations/bar-chart/style.module.css.js.map +1 -0
  257. package/components/visualizations/donut-chart/components/arc-tooltip/index.js +14 -0
  258. package/components/visualizations/donut-chart/components/arc-tooltip/index.js.map +1 -0
  259. package/components/visualizations/donut-chart/components/arc-tooltip/styles.module.css.js +10 -0
  260. package/components/visualizations/donut-chart/components/arc-tooltip/styles.module.css.js.map +1 -0
  261. package/components/visualizations/donut-chart/components/external-arc-label/index.js +58 -0
  262. package/components/visualizations/donut-chart/components/external-arc-label/index.js.map +1 -0
  263. package/components/visualizations/donut-chart/components/external-arc-label/styles.module.css.js +16 -0
  264. package/components/visualizations/donut-chart/components/external-arc-label/styles.module.css.js.map +1 -0
  265. package/components/visualizations/donut-chart/components/internal-arc-label/index.js +42 -0
  266. package/components/visualizations/donut-chart/components/internal-arc-label/index.js.map +1 -0
  267. package/components/visualizations/donut-chart/components/internal-arc-label/styles.module.css.js +14 -0
  268. package/components/visualizations/donut-chart/components/internal-arc-label/styles.module.css.js.map +1 -0
  269. package/components/visualizations/donut-chart/index.js +90 -0
  270. package/components/visualizations/donut-chart/index.js.map +1 -0
  271. package/components/visualizations/donut-chart/styles.module.css.js +20 -0
  272. package/components/visualizations/donut-chart/styles.module.css.js.map +1 -0
  273. package/hooks/use-media-query/index.js +16 -0
  274. package/hooks/use-media-query/index.js.map +1 -0
  275. package/index.js +155 -101
  276. package/index.js.map +1 -1
  277. package/package.json +1 -1
  278. package/patterns/card/newsroom-card/index.js +26 -0
  279. package/patterns/card/newsroom-card/index.js.map +1 -0
  280. package/patterns/card/newsroom-card/style.module.css.js +8 -0
  281. package/patterns/card/newsroom-card/style.module.css.js.map +1 -0
  282. package/patterns/card/partner-card/index.js +42 -0
  283. package/patterns/card/partner-card/index.js.map +1 -0
  284. package/patterns/card/partner-card/style.module.css.js +12 -0
  285. package/patterns/card/partner-card/style.module.css.js.map +1 -0
  286. package/patterns/card/person-card/index.js +52 -0
  287. package/patterns/card/person-card/index.js.map +1 -0
  288. package/patterns/card/person-card/style.module.css.js +12 -0
  289. package/patterns/card/person-card/style.module.css.js.map +1 -0
  290. package/patterns/card/primitives.js +77 -0
  291. package/patterns/card/primitives.js.map +1 -0
  292. package/patterns/card/promo-card/index.js +36 -0
  293. package/patterns/card/promo-card/index.js.map +1 -0
  294. package/patterns/card/resource-card/index.js +26 -0
  295. package/patterns/card/resource-card/index.js.map +1 -0
  296. package/patterns/card/style.module.css.js +30 -0
  297. package/patterns/card/style.module.css.js.map +1 -0
  298. package/patterns/card/thumbnails/index.js +25 -0
  299. package/patterns/card/thumbnails/index.js.map +1 -0
  300. package/patterns/card/unified-card/index.js +37 -0
  301. package/patterns/card/unified-card/index.js.map +1 -0
  302. package/patterns/copy-button/clipboard.js +78 -0
  303. package/patterns/copy-button/clipboard.js.map +1 -0
  304. package/patterns/copy-button/index.js +57 -0
  305. package/patterns/copy-button/index.js.map +1 -0
  306. package/patterns/copy-button/style.module.css.js +13 -0
  307. package/patterns/copy-button/style.module.css.js.map +1 -0
  308. package/patterns/index.js +32 -22
  309. package/patterns/index.js.map +1 -1
  310. package/patterns/layout/index.js +47 -0
  311. package/patterns/layout/index.js.map +1 -0
  312. package/patterns/layout/layout.module.css.js +20 -0
  313. package/patterns/layout/layout.module.css.js.map +1 -0
  314. package/patterns/product-badge/index.js +22 -0
  315. package/patterns/product-badge/index.js.map +1 -0
  316. package/patterns/product-badge/style.module.css.js +8 -0
  317. package/patterns/product-badge/style.module.css.js.map +1 -0
  318. package/patterns/product-logo/index.js +130 -0
  319. package/patterns/product-logo/index.js.map +1 -0
  320. package/patterns/product-logo/product-logo.module.css.js +13 -0
  321. package/patterns/product-logo/product-logo.module.css.js.map +1 -0
  322. package/patterns/related-content/index.js +65 -0
  323. package/patterns/related-content/index.js.map +1 -0
  324. package/patterns/related-content/style.module.css.js +22 -0
  325. package/patterns/related-content/style.module.css.js.map +1 -0
  326. package/style.css +1 -1
  327. package/utils/get-contrast-yiq.js +13 -0
  328. package/utils/get-contrast-yiq.js.map +1 -0
  329. package/utils/hooks/use-screen-size.js +10 -0
  330. package/utils/hooks/use-screen-size.js.map +1 -0
  331. package/utils/i18n/constants/index.js +98 -0
  332. package/utils/i18n/constants/index.js.map +1 -0
  333. package/utils/i18n/helpers/locale-provider.js +9 -0
  334. package/utils/i18n/helpers/locale-provider.js.map +1 -0
  335. package/utils/i18n/helpers/to-smart-sentence-case.js +12 -0
  336. package/utils/i18n/helpers/to-smart-sentence-case.js.map +1 -0
  337. package/utils/i18n/helpers/to-smart-title-case.js +10 -0
  338. package/utils/i18n/helpers/to-smart-title-case.js.map +1 -0
  339. package/utils/i18n/helpers/use-locale.js +14 -0
  340. package/utils/i18n/helpers/use-locale.js.map +1 -0
  341. package/utils/i18n/index.js +41 -0
  342. package/utils/i18n/index.js.map +1 -0
  343. package/utils/i18n/index2.js +33 -0
  344. package/utils/i18n/index2.js.map +1 -0
  345. package/utils/index.js +7 -7
  346. package/utils/make-normalizer/index.js +34 -0
  347. package/utils/make-normalizer/index.js.map +1 -0
  348. package/{index-DBjAbGt7.js → utils/mds-context/index.js} +20 -19
  349. package/utils/mds-context/index.js.map +1 -0
  350. package/index-B9mPJh9w.js +0 -579
  351. package/index-B9mPJh9w.js.map +0 -1
  352. package/index-BHBlMMNF.js +0 -16
  353. package/index-BHBlMMNF.js.map +0 -1
  354. package/index-C4GBbW3N.js +0 -3567
  355. package/index-C4GBbW3N.js.map +0 -1
  356. package/index-DBjAbGt7.js.map +0 -1
  357. package/index-WkGIywHj.js +0 -767
  358. package/index-WkGIywHj.js.map +0 -1
  359. package/use-screen-size-BOnkX_K-.js +0 -9
  360. package/use-screen-size-BOnkX_K-.js.map +0 -1
@@ -0,0 +1,170 @@
1
+ import { jsx as e, jsxs as m, Fragment as B } from "react/jsx-runtime";
2
+ import { useId as F } from "react";
3
+ import s from "classnames";
4
+ import { Field as L } from "../field/index.js";
5
+ import { FlightIcon as d } from "../../flight-icon/index.js";
6
+ import { ComboBox as l } from "../../combo-box-primitive/index.js";
7
+ import r from "./form-super-select.module.css.js";
8
+ const O = ({
9
+ children: i,
10
+ onChangeSelectedOption: t,
11
+ onChangeVFocusedOption: n
12
+ }) => /* @__PURE__ */ e(
13
+ l.Root,
14
+ {
15
+ onChangeSelectedOption: t,
16
+ onChangeVFocusedOption: n,
17
+ children: /* @__PURE__ */ e("div", { className: r.root, children: i })
18
+ }
19
+ ), R = ({ className: i }) => /* @__PURE__ */ e(l.Trigger, { className: s(r.trigger, i), children: /* @__PURE__ */ e(l.Value, {}) }), T = ({ children: i }) => /* @__PURE__ */ e(l.Popover, { className: r.popover, children: i }), j = ({
20
+ placeholder: i = "Search",
21
+ value: t,
22
+ onChange: n,
23
+ onBlur: c
24
+ }) => /* @__PURE__ */ e("div", { className: r["search-input-wrapper"], children: /* @__PURE__ */ e(
25
+ l.SearchInput,
26
+ {
27
+ placeholder: i,
28
+ value: t,
29
+ onChange: n,
30
+ onBlur: c
31
+ }
32
+ ) }), k = ({
33
+ label: i,
34
+ children: t,
35
+ className: n,
36
+ maxHeight: c,
37
+ onScroll: o
38
+ }) => /* @__PURE__ */ e(
39
+ l.List,
40
+ {
41
+ label: i,
42
+ className: s(r.list, n),
43
+ maxHeight: c,
44
+ onScroll: o,
45
+ children: t
46
+ }
47
+ ), C = ({
48
+ value: i,
49
+ label: t,
50
+ isLoading: n,
51
+ icon: c,
52
+ className: o,
53
+ trailingIcon: p
54
+ }) => /* @__PURE__ */ e(
55
+ l.Item,
56
+ {
57
+ value: i,
58
+ label: t,
59
+ className: s(r.option, o),
60
+ children: n ? /* @__PURE__ */ m("div", { className: r["interactive-loading-wrapper"], children: [
61
+ /* @__PURE__ */ e(
62
+ "div",
63
+ {
64
+ className: s(
65
+ r["interactive-icon"],
66
+ r["interactive-icon-leading"]
67
+ ),
68
+ children: /* @__PURE__ */ e(d, { name: "loading", isInlineBlock: !1 })
69
+ }
70
+ ),
71
+ /* @__PURE__ */ e("span", { className: r["option-text"], children: t })
72
+ ] }) : /* @__PURE__ */ m(B, { children: [
73
+ c && /* @__PURE__ */ e(
74
+ "span",
75
+ {
76
+ className: s(
77
+ r["interactive-icon"],
78
+ r["interactive-icon-leading"]
79
+ ),
80
+ children: /* @__PURE__ */ e(d, { name: c, isInlineBlock: !1 })
81
+ }
82
+ ),
83
+ /* @__PURE__ */ e("span", { className: r["option-text"], children: t }),
84
+ p && /* @__PURE__ */ e(
85
+ "span",
86
+ {
87
+ className: s(
88
+ r["interactive-icon"],
89
+ r["interactive-icon-trailing"]
90
+ ),
91
+ children: /* @__PURE__ */ e(d, { name: p, isInlineBlock: !1 })
92
+ }
93
+ )
94
+ ] })
95
+ }
96
+ ), a = Object.freeze({
97
+ Root: O,
98
+ Trigger: R,
99
+ Popover: T,
100
+ /**
101
+ * Note that this only acts as a view layer,
102
+ * it does not participate in the search logic.
103
+ * This is left for the consumer to implement.
104
+ */
105
+ SearchInput: j,
106
+ List: k,
107
+ Option: C
108
+ }), w = ({
109
+ label: i,
110
+ helperText: t,
111
+ error: n,
112
+ id: c,
113
+ searchProps: o,
114
+ options: p,
115
+ listLabel: h,
116
+ listHeight: S = "240px",
117
+ onScroll: g,
118
+ onChangeSelectedOption: v,
119
+ onChangeVFocusedOption: N,
120
+ onSearchBlur: f,
121
+ ...I
122
+ }) => {
123
+ const x = F();
124
+ return /* @__PURE__ */ e(
125
+ L,
126
+ {
127
+ label: i,
128
+ helperText: t,
129
+ error: n,
130
+ id: c ?? x,
131
+ layout: "vertical",
132
+ ...I,
133
+ children: /* @__PURE__ */ m(
134
+ a.Root,
135
+ {
136
+ onChangeSelectedOption: v,
137
+ onChangeVFocusedOption: N,
138
+ children: [
139
+ /* @__PURE__ */ e(a.Trigger, {}),
140
+ /* @__PURE__ */ m(a.Popover, { children: [
141
+ o && /* @__PURE__ */ e(
142
+ a.SearchInput,
143
+ {
144
+ placeholder: o.placeholder,
145
+ value: o.value,
146
+ onChange: o.onChange,
147
+ onBlur: f
148
+ }
149
+ ),
150
+ /* @__PURE__ */ e(
151
+ a.List,
152
+ {
153
+ label: h,
154
+ maxHeight: S,
155
+ onScroll: g,
156
+ children: p.map((u) => /* @__PURE__ */ e(a.Option, { ...u }, u.value))
157
+ }
158
+ )
159
+ ] })
160
+ ]
161
+ }
162
+ )
163
+ }
164
+ );
165
+ };
166
+ w.displayName = "SuperSelectField";
167
+ export {
168
+ w as SuperSelectField
169
+ };
170
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/form/super-select/index.tsx"],"sourcesContent":["import { useId } from 'react'\nimport classNames from 'classnames'\nimport { Field } from '../field'\nimport { FlightIcon } from '../../flight-icon'\nimport { ComboBox } from '../../combo-box-primitive'\nimport type {\n\tTComboBoxItem,\n\tComboBoxSearchInputProps,\n\tComboBoxListProps,\n} from '../../combo-box-primitive'\nimport type { FieldProps } from '../field'\nimport s from './form-super-select.module.css'\n\ntype SuperSelectRootProps = {\n\tchildren: React.ReactNode\n\tonChangeSelectedOption?: (option: TComboBoxItem) => void\n\tonChangeVFocusedOption?: (option: TComboBoxItem) => void\n}\n\nconst SuperSelectRoot = ({\n\tchildren,\n\tonChangeSelectedOption,\n\tonChangeVFocusedOption,\n}: SuperSelectRootProps) => {\n\treturn (\n\t\t<ComboBox.Root\n\t\t\tonChangeSelectedOption={onChangeSelectedOption}\n\t\t\tonChangeVFocusedOption={onChangeVFocusedOption}\n\t\t>\n\t\t\t<div className={s.root}>{children}</div>\n\t\t</ComboBox.Root>\n\t)\n}\n\ninterface SuperSelectTriggerProps {\n\tclassName?: string\n}\n\nconst SuperSelectTrigger = ({ className }: SuperSelectTriggerProps) => {\n\treturn (\n\t\t<ComboBox.Trigger className={classNames(s.trigger, className)}>\n\t\t\t<ComboBox.Value />\n\t\t</ComboBox.Trigger>\n\t)\n}\n\ntype SuperSelectPopoverProps = {\n\tchildren: React.ReactNode\n}\n\nconst SuperSelectPopover = ({ children }: SuperSelectPopoverProps) => {\n\treturn <ComboBox.Popover className={s.popover}>{children}</ComboBox.Popover>\n}\n\ntype SuperSelectSearchInputProps = ComboBoxSearchInputProps\n\nconst SuperSelectSearchInput = ({\n\tplaceholder = 'Search',\n\tvalue,\n\tonChange,\n\tonBlur,\n}: SuperSelectSearchInputProps) => {\n\treturn (\n\t\t<div className={s['search-input-wrapper']}>\n\t\t\t<ComboBox.SearchInput\n\t\t\t\tplaceholder={placeholder}\n\t\t\t\tvalue={value}\n\t\t\t\tonChange={onChange}\n\t\t\t\tonBlur={onBlur}\n\t\t\t/>\n\t\t</div>\n\t)\n}\n\ntype SuperSelectListProps = ComboBoxListProps\n\nconst SuperSelectList = ({\n\tlabel,\n\tchildren,\n\tclassName,\n\tmaxHeight,\n\tonScroll,\n}: SuperSelectListProps) => {\n\treturn (\n\t\t<ComboBox.List\n\t\t\tlabel={label}\n\t\t\tclassName={classNames(s.list, className)}\n\t\t\tmaxHeight={maxHeight}\n\t\t\tonScroll={onScroll}\n\t\t>\n\t\t\t{children}\n\t\t</ComboBox.List>\n\t)\n}\n\ninterface SuperSelectOptionProps extends TComboBoxItem {\n\tisLoading?: boolean\n\t/**\n\t * Leading icon. Acceptable value: any [icon](https://helios.hashicorp.design/icons/library) name.\n\t */\n\ticon?: string\n\t/**\n\t * Trailing icon. Acceptable value: any [icon](https://helios.hashicorp.design/icons/library) name.\n\t */\n\ttrailingIcon?: string\n\tclassName?: string\n}\n\nconst SuperSelectOption = ({\n\tvalue,\n\tlabel,\n\tisLoading,\n\ticon,\n\tclassName,\n\ttrailingIcon,\n}: SuperSelectOptionProps) => {\n\treturn (\n\t\t<ComboBox.Item\n\t\t\tvalue={value}\n\t\t\tlabel={label}\n\t\t\tclassName={classNames(s.option, className)}\n\t\t>\n\t\t\t{isLoading ? (\n\t\t\t\t<div className={s['interactive-loading-wrapper']}>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={classNames(\n\t\t\t\t\t\t\ts['interactive-icon'],\n\t\t\t\t\t\t\ts['interactive-icon-leading']\n\t\t\t\t\t\t)}\n\t\t\t\t\t>\n\t\t\t\t\t\t<FlightIcon name=\"loading\" isInlineBlock={false} />\n\t\t\t\t\t</div>\n\t\t\t\t\t<span className={s['option-text']}>{label}</span>\n\t\t\t\t</div>\n\t\t\t) : (\n\t\t\t\t<>\n\t\t\t\t\t{icon && (\n\t\t\t\t\t\t<span\n\t\t\t\t\t\t\tclassName={classNames(\n\t\t\t\t\t\t\t\ts['interactive-icon'],\n\t\t\t\t\t\t\t\ts['interactive-icon-leading']\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<FlightIcon name={icon} isInlineBlock={false} />\n\t\t\t\t\t\t</span>\n\t\t\t\t\t)}\n\t\t\t\t\t<span className={s['option-text']}>{label}</span>\n\t\t\t\t\t{trailingIcon && (\n\t\t\t\t\t\t<span\n\t\t\t\t\t\t\tclassName={classNames(\n\t\t\t\t\t\t\t\ts['interactive-icon'],\n\t\t\t\t\t\t\t\ts['interactive-icon-trailing']\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<FlightIcon name={trailingIcon} isInlineBlock={false} />\n\t\t\t\t\t\t</span>\n\t\t\t\t\t)}\n\t\t\t\t</>\n\t\t\t)}\n\t\t</ComboBox.Item>\n\t)\n}\n\ntype TSuperSelectOption = TComboBoxItem\n\nconst SuperSelect = Object.freeze({\n\tRoot: SuperSelectRoot,\n\tTrigger: SuperSelectTrigger,\n\tPopover: SuperSelectPopover,\n\t/**\n\t * Note that this only acts as a view layer,\n\t * it does not participate in the search logic.\n\t * This is left for the consumer to implement.\n\t */\n\tSearchInput: SuperSelectSearchInput,\n\tList: SuperSelectList,\n\tOption: SuperSelectOption,\n})\n\ninterface SuperSelectFieldProps\n\textends Omit<FieldProps, 'children' | 'id' | 'layout'> {\n\tid?: string\n\toptions: SuperSelectOptionProps[]\n\t/**\n\t * @default false\n\t */\n\tsearchProps?: SuperSelectSearchInputProps\n\t/**\n\t * Used for assistive technologies,\n\t * indicate the category of options you are presenting\n\t * eg. Schools | Languages | Countries\n\t */\n\tlistLabel: string\n\t/**\n\t * Is actually a `max-height` for the list.\n\t * Pass this when you have a lot of options and want to limit the height of the list.\n\t * @default `240px`\n\t */\n\tlistHeight?: `${number}em` | `${number}px` | `${number}%`\n\t/**\n\t * Callback for when the list is scrolled.\n\t * This is useful for implementing pagination, recommended for large lists.\n\t */\n\tonScroll?: (e: React.UIEvent<HTMLUListElement>) => void\n\tonChangeSelectedOption?: (option: SuperSelectOptionProps) => void\n\tonChangeVFocusedOption?: (option: SuperSelectOptionProps) => void\n\tonSearchBlur?: () => void\n}\n\n/**\n * Convenience component for using {@link SuperSelect}\n * with a {@link Field} component. This should cover most use cases\n * unless you need advanced patterns like pagination, async options, etc. outside of a form context.\n */\nconst SuperSelectField = ({\n\tlabel,\n\thelperText,\n\terror,\n\tid,\n\tsearchProps,\n\toptions,\n\tlistLabel,\n\tlistHeight = '240px',\n\tonScroll,\n\tonChangeSelectedOption,\n\tonChangeVFocusedOption,\n\tonSearchBlur,\n\t...rest\n}: SuperSelectFieldProps) => {\n\tconst genID = useId()\n\tconst fieldId = id ?? genID\n\n\treturn (\n\t\t<Field\n\t\t\tlabel={label}\n\t\t\thelperText={helperText}\n\t\t\terror={error}\n\t\t\tid={fieldId}\n\t\t\tlayout={'vertical'}\n\t\t\t{...rest}\n\t\t>\n\t\t\t<SuperSelect.Root\n\t\t\t\tonChangeSelectedOption={onChangeSelectedOption}\n\t\t\t\tonChangeVFocusedOption={onChangeVFocusedOption}\n\t\t\t>\n\t\t\t\t<SuperSelect.Trigger />\n\t\t\t\t<SuperSelect.Popover>\n\t\t\t\t\t{searchProps && (\n\t\t\t\t\t\t<SuperSelect.SearchInput\n\t\t\t\t\t\t\tplaceholder={searchProps.placeholder}\n\t\t\t\t\t\t\tvalue={searchProps.value}\n\t\t\t\t\t\t\tonChange={searchProps.onChange}\n\t\t\t\t\t\t\tonBlur={onSearchBlur}\n\t\t\t\t\t\t/>\n\t\t\t\t\t)}\n\t\t\t\t\t<SuperSelect.List\n\t\t\t\t\t\tlabel={listLabel}\n\t\t\t\t\t\tmaxHeight={listHeight}\n\t\t\t\t\t\tonScroll={onScroll}\n\t\t\t\t\t>\n\t\t\t\t\t\t{options.map((option) => (\n\t\t\t\t\t\t\t<SuperSelect.Option key={option.value} {...option} />\n\t\t\t\t\t\t))}\n\t\t\t\t\t</SuperSelect.List>\n\t\t\t\t</SuperSelect.Popover>\n\t\t\t</SuperSelect.Root>\n\t\t</Field>\n\t)\n}\n\nSuperSelectField.displayName = 'SuperSelectField'\n\nexport type {\n\tTSuperSelectOption,\n\tSuperSelectOptionProps,\n\tSuperSelectSearchInputProps,\n}\n\nexport { SuperSelectField }\n"],"names":["SuperSelectRoot","children","onChangeSelectedOption","onChangeVFocusedOption","jsx","ComboBox","s","SuperSelectTrigger","className","classNames","SuperSelectPopover","SuperSelectSearchInput","placeholder","value","onChange","onBlur","SuperSelectList","label","maxHeight","onScroll","SuperSelectOption","isLoading","icon","trailingIcon","jsxs","FlightIcon","Fragment","SuperSelect","SuperSelectField","helperText","error","id","searchProps","options","listLabel","listHeight","onSearchBlur","rest","genID","useId","Field","option"],"mappings":"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"}
@@ -0,0 +1,91 @@
1
+ import { jsx as c } from "react/jsx-runtime";
2
+ import g from "classnames";
3
+ import { useId as x } from "react";
4
+ import { Field as $ } from "../field/index.js";
5
+ import r from "./styles.module.css.js";
6
+ const f = ({
7
+ type: i,
8
+ isInvalid: n,
9
+ isLoading: d,
10
+ isRequired: o,
11
+ className: t,
12
+ id: e,
13
+ field: s,
14
+ size: a = "medium",
15
+ error: m,
16
+ ...p
17
+ }) => {
18
+ const u = x();
19
+ return /* @__PURE__ */ c(
20
+ "input",
21
+ {
22
+ id: e ?? u,
23
+ type: i,
24
+ className: g(
25
+ r["text-input"],
26
+ r[`size-${a}`],
27
+ {
28
+ [r.invalid]: n,
29
+ [r.loading]: d
30
+ },
31
+ t
32
+ ),
33
+ required: o,
34
+ "aria-describedby": `${m ? "error" : "helper-text"}-${e}`,
35
+ ...s,
36
+ ...p
37
+ }
38
+ );
39
+ };
40
+ f.displayName = "TextInputBase";
41
+ const b = ({
42
+ badgeText: i,
43
+ type: n = "text",
44
+ isInvalid: d,
45
+ isLoading: o,
46
+ isRequired: t,
47
+ isOptional: e,
48
+ id: s,
49
+ label: a,
50
+ helperText: m,
51
+ error: p,
52
+ field: u,
53
+ className: l,
54
+ size: y = "medium",
55
+ ...N
56
+ }) => {
57
+ const T = x(), I = s ?? T;
58
+ return /* @__PURE__ */ c(
59
+ $,
60
+ {
61
+ label: a,
62
+ badgeText: i,
63
+ helperText: m,
64
+ error: p,
65
+ isRequired: t,
66
+ isOptional: e,
67
+ id: I,
68
+ layout: "vertical",
69
+ className: l,
70
+ children: /* @__PURE__ */ c(
71
+ f,
72
+ {
73
+ id: I,
74
+ type: n,
75
+ isInvalid: d,
76
+ isLoading: o,
77
+ isRequired: t,
78
+ field: u,
79
+ size: y,
80
+ ...N
81
+ }
82
+ )
83
+ }
84
+ );
85
+ };
86
+ b.displayName = "TextInput";
87
+ export {
88
+ b as TextInput,
89
+ f as TextInputBase
90
+ };
91
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/form/text-input/index.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport type { HTMLInputTypeAttribute, HTMLProps, ReactNode } from 'react'\nimport { useId } from 'react'\nimport { Field } from '../field'\nimport s from './styles.module.css'\n\ninterface TextInputBaseProps {\n\t/**\n\t * Sets the native HTML `type` of the `<input>`.\n\t */\n\ttype?: HTMLInputTypeAttribute\n\n\t/**\n\t * Applies an “invalid” appearance to the control but doesn’t modify its logical validity.\n\t */\n\tisInvalid?: boolean\n\n\t/**\n\t * When true, it shows a loading indicator instead of a magnifying glass; only applicable when `type=\"search\"`.\n\t */\n\tisLoading?: boolean\n\tisRequired?: boolean\n\tclassName?: string\n\tid?: string\n\n\t/**\n\t * Can be used to supply any props that the native `<input>` element supports (such as `value`, `placeholder`, in addition to events like `onChange` and `onBlur`)\n\t */\n\tfield: HTMLProps<HTMLInputElement>\n\n\t/**\n\t * Sets the size of the input to match either medium Buttons or large Buttons.\n\t */\n\tsize?: 'medium' | 'large'\n\terror?: ReactNode\n\tdisabled?: boolean\n}\n\nconst TextInputBase = ({\n\ttype,\n\tisInvalid,\n\tisLoading,\n\tisRequired,\n\tclassName,\n\tid,\n\tfield,\n\tsize = 'medium',\n\terror,\n\t...rest\n}: TextInputBaseProps) => {\n\tconst generatedId = useId()\n\tconst inputId = id ?? generatedId\n\n\treturn (\n\t\t<input\n\t\t\tid={inputId}\n\t\t\ttype={type}\n\t\t\tclassName={classNames(\n\t\t\t\ts['text-input'],\n\t\t\t\ts[`size-${size}`],\n\t\t\t\t{\n\t\t\t\t\t[s['invalid']]: isInvalid,\n\t\t\t\t\t[s['loading']]: isLoading,\n\t\t\t\t},\n\t\t\t\tclassName\n\t\t\t)}\n\t\t\trequired={isRequired}\n\t\t\taria-describedby={`${error ? 'error' : 'helper-text'}-${id}`}\n\t\t\t{...field}\n\t\t\t{...rest}\n\t\t/>\n\t)\n}\n\nTextInputBase.displayName = 'TextInputBase'\n\ninterface TextInputProps {\n\t/**\n\t * When provided, appends a badge next to the label text.\n\t */\n\tbadgeText?: string\n\n\t/**\n\t * Sets the native HTML `type` of the `<input>`.\n\t */\n\ttype?: HTMLInputTypeAttribute\n\n\t/**\n\t * Applies an “invalid” appearance to the control but doesn’t modify its logical validity.\n\t */\n\tisInvalid?: boolean\n\n\t/**\n\t * When true, it shows a loading indicator instead of a magnifying glass; only applicable when `type=\"search\"`.\n\t */\n\tisLoading?: boolean\n\n\t/**\n\t * Appends a `Required` indicator next to the label text and sets the `required` attribute on the control when user input is required.\n\t */\n\tisRequired?: boolean\n\n\t/**\n\t * Appends an `Optional` indicator next to the label text when user input is optional.\n\t */\n\tisOptional?: boolean\n\n\t/**\n\t * Input control’s ID attribute.\n\t *\n\t * By default, the ID is automatically generated by the component. Use this argument to pass a custom ID.\n\t */\n\tid?: string\n\n\t/**\n\t * Container that renders its content inside the `<label>` element. The content can be a simple string or a `ReactNode`, in which case it inherits the text style.\n\t *\n\t * The `for` attribute of the label is automatically generated using the `controlId` value of the control.\n\t */\n\tlabel?: ReactNode\n\n\t/**\n\t * Container that renders its content inside the \"helper text\" block. The content can be a simple string or a `ReactNode`, in which case it inherits the text style.\n\t *\n\t * The `id` attribute of the message is automatically generated using the `controlId` value of the control.\n\t */\n\thelperText?: ReactNode\n\n\t/**\n\t * Container that renders its content inside the \"error\" block. The content can be a simple string or a `ReactNode`, in which case it inherits the text style.\n\t *\n\t * The `id` attribute of the error message is automatically generated using the `controlId` value of the control.\n\t */\n\terror?: ReactNode\n\n\t/**\n\t * Can be used to supply any props that the native `<input>` element supports (such as `value`, `placeholder`, in addition to events like `onChange` and `onBlur`)\n\t */\n\tfield: HTMLProps<HTMLInputElement>\n\tclassName?: string\n\n\t/**\n\t * Sets the size of the input to match either medium Buttons or large Buttons.\n\t */\n\tsize?: 'medium' | 'large'\n\tdisabled?: boolean\n}\n\nconst TextInput = ({\n\tbadgeText,\n\ttype = 'text',\n\tisInvalid,\n\tisLoading,\n\tisRequired,\n\tisOptional,\n\tid,\n\tlabel,\n\thelperText,\n\terror,\n\tfield,\n\tclassName,\n\tsize = 'medium',\n\t...rest\n}: TextInputProps) => {\n\tconst generatedId = useId()\n\tconst inputId = id ?? generatedId\n\n\treturn (\n\t\t<Field\n\t\t\tlabel={label}\n\t\t\tbadgeText={badgeText}\n\t\t\thelperText={helperText}\n\t\t\terror={error}\n\t\t\tisRequired={isRequired}\n\t\t\tisOptional={isOptional}\n\t\t\tid={inputId}\n\t\t\tlayout=\"vertical\"\n\t\t\tclassName={className}\n\t\t>\n\t\t\t<TextInputBase\n\t\t\t\tid={inputId}\n\t\t\t\ttype={type}\n\t\t\t\tisInvalid={isInvalid}\n\t\t\t\tisLoading={isLoading}\n\t\t\t\tisRequired={isRequired}\n\t\t\t\tfield={field}\n\t\t\t\tsize={size}\n\t\t\t\t{...rest}\n\t\t\t/>\n\t\t</Field>\n\t)\n}\n\nTextInput.displayName = 'TextInput'\n\nexport type { TextInputBaseProps, TextInputProps }\nexport { TextInputBase, TextInput }\n"],"names":["TextInputBase","type","isInvalid","isLoading","isRequired","className","id","field","size","error","rest","generatedId","useId","jsx","classNames","s","TextInput","badgeText","isOptional","label","helperText","inputId","Field"],"mappings":";;;;;AAsCA,MAAMA,IAAgB,CAAC;AAAA,EACtB,MAAAC;AAAA,EACA,WAAAC;AAAA,EACA,WAAAC;AAAA,EACA,YAAAC;AAAA,EACA,WAAAC;AAAA,EACA,IAAAC;AAAA,EACA,OAAAC;AAAA,EACA,MAAAC,IAAO;AAAA,EACP,OAAAC;AAAA,EACA,GAAGC;AACJ,MAA0B;AACzB,QAAMC,IAAcC,EAAA;AAGpB,SACC,gBAAAC;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,IAJcP,KAAMK;AAAA,MAKpB,MAAAV;AAAA,MACA,WAAWa;AAAA,QACVC,EAAE,YAAY;AAAA,QACdA,EAAE,QAAQP,CAAI,EAAE;AAAA,QAChB;AAAA,UACC,CAACO,EAAE,OAAU,GAAGb;AAAA,UAChB,CAACa,EAAE,OAAU,GAAGZ;AAAA,QAAA;AAAA,QAEjBE;AAAA,MAAA;AAAA,MAED,UAAUD;AAAA,MACV,oBAAkB,GAAGK,IAAQ,UAAU,aAAa,IAAIH,CAAE;AAAA,MACzD,GAAGC;AAAA,MACH,GAAGG;AAAA,IAAA;AAAA,EAAA;AAGP;AAEAV,EAAc,cAAc;AA0E5B,MAAMgB,IAAY,CAAC;AAAA,EAClB,WAAAC;AAAA,EACA,MAAAhB,IAAO;AAAA,EACP,WAAAC;AAAA,EACA,WAAAC;AAAA,EACA,YAAAC;AAAA,EACA,YAAAc;AAAA,EACA,IAAAZ;AAAA,EACA,OAAAa;AAAA,EACA,YAAAC;AAAA,EACA,OAAAX;AAAA,EACA,OAAAF;AAAA,EACA,WAAAF;AAAA,EACA,MAAAG,IAAO;AAAA,EACP,GAAGE;AACJ,MAAsB;AACrB,QAAMC,IAAcC,EAAA,GACdS,IAAUf,KAAMK;AAEtB,SACC,gBAAAE;AAAA,IAACS;AAAA,IAAA;AAAA,MACA,OAAAH;AAAA,MACA,WAAAF;AAAA,MACA,YAAAG;AAAA,MACA,OAAAX;AAAA,MACA,YAAAL;AAAA,MACA,YAAAc;AAAA,MACA,IAAIG;AAAA,MACJ,QAAO;AAAA,MACP,WAAAhB;AAAA,MAEA,UAAA,gBAAAQ;AAAA,QAACb;AAAA,QAAA;AAAA,UACA,IAAIqB;AAAA,UACJ,MAAApB;AAAA,UACA,WAAAC;AAAA,UACA,WAAAC;AAAA,UACA,YAAAC;AAAA,UACA,OAAAG;AAAA,UACA,MAAAC;AAAA,UACC,GAAGE;AAAA,QAAA;AAAA,MAAA;AAAA,IACL;AAAA,EAAA;AAGH;AAEAM,EAAU,cAAc;"}
@@ -0,0 +1,15 @@
1
+ const o = "invalid__rrYph", e = "loading__O7Vv0", i = {
2
+ "text-input": "text-input__Xudum mds-typography-font-weight-regular",
3
+ "mock-hover": "mock-hover__-ItMX",
4
+ "mock-focus": "mock-focus__S6jof",
5
+ invalid: o,
6
+ loading: e,
7
+ "size-medium": "size-medium__-UzIQ mds-typography-legacy-body-200",
8
+ "size-large": "size-large__Hceu2 mds-typography-legacy-body-300"
9
+ };
10
+ export {
11
+ i as default,
12
+ o as invalid,
13
+ e as loading
14
+ };
15
+ //# sourceMappingURL=styles.module.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.module.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;"}
@@ -0,0 +1,14 @@
1
+ const a = "textarea__3MZYV mds-typography-font-weight-regular", e = "invalid__Q80EM", t = "medium__G2gPs mds-typography-legacy-body-200", d = "large__0Y-7C mds-typography-legacy-body-300", o = {
2
+ textarea: a,
3
+ invalid: e,
4
+ medium: t,
5
+ large: d
6
+ };
7
+ export {
8
+ o as default,
9
+ e as invalid,
10
+ d as large,
11
+ t as medium,
12
+ a as textarea
13
+ };
14
+ //# sourceMappingURL=form-textarea.module.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-textarea.module.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,74 @@
1
+ import { jsx as s } from "react/jsx-runtime";
2
+ import f from "classnames";
3
+ import { useId as y } from "react";
4
+ import { Field as A } from "../field/index.js";
5
+ import m from "./form-textarea.module.css.js";
6
+ const F = ({
7
+ isInvalid: t,
8
+ isLoading: l,
9
+ className: e,
10
+ id: r,
11
+ field: a,
12
+ size: i,
13
+ error: o,
14
+ ...d
15
+ }) => /* @__PURE__ */ s(
16
+ "textarea",
17
+ {
18
+ id: r,
19
+ className: f(
20
+ m.textarea,
21
+ m[i],
22
+ {
23
+ [m.invalid]: t
24
+ },
25
+ e
26
+ ),
27
+ "aria-describedby": `${o ? "error" : "helper-text"}-${r}`,
28
+ ...a,
29
+ ...d
30
+ }
31
+ ), I = ({
32
+ isInvalid: t,
33
+ isLoading: l,
34
+ isRequired: e,
35
+ isOptional: r,
36
+ id: a,
37
+ label: i,
38
+ helperText: o,
39
+ error: d,
40
+ field: c,
41
+ size: p = "medium",
42
+ ...x
43
+ }) => {
44
+ const u = y(), n = a ?? u;
45
+ return /* @__PURE__ */ s(
46
+ A,
47
+ {
48
+ label: i,
49
+ helperText: o,
50
+ error: d,
51
+ isRequired: e,
52
+ isOptional: r,
53
+ id: n,
54
+ layout: "vertical",
55
+ children: /* @__PURE__ */ s(
56
+ F,
57
+ {
58
+ id: n,
59
+ isInvalid: t,
60
+ isLoading: l,
61
+ required: e,
62
+ field: c,
63
+ size: p,
64
+ ...x
65
+ }
66
+ )
67
+ }
68
+ );
69
+ };
70
+ I.displayName = "TextAreaField";
71
+ export {
72
+ I as TextAreaField
73
+ };
74
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/form/textarea/index.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport { useId } from 'react'\nimport { Field } from '../field'\nimport type { HTMLProps, ReactNode } from 'react'\nimport s from './form-textarea.module.css'\n\ninterface TextAreaBaseProps {\n\tisInvalid?: boolean\n\tisLoading?: boolean\n\trequired?: boolean\n\tclassName?: string\n\tid: string\n\tfield: HTMLProps<HTMLTextAreaElement>\n\tsize: 'medium' | 'large'\n\terror?: ReactNode\n\tdisabled?: boolean\n}\n\nconst TextAreaBase = ({\n\tisInvalid,\n\tisLoading,\n\tclassName,\n\tid,\n\tfield,\n\tsize,\n\terror,\n\t...rest\n}: TextAreaBaseProps) => {\n\treturn (\n\t\t<textarea\n\t\t\tid={id}\n\t\t\tclassName={classNames(\n\t\t\t\ts.textarea,\n\t\t\t\ts[size],\n\t\t\t\t{\n\t\t\t\t\t[s.invalid]: isInvalid,\n\t\t\t\t},\n\t\t\t\tclassName\n\t\t\t)}\n\t\t\taria-describedby={`${error ? 'error' : 'helper-text'}-${id}`}\n\t\t\t{...field}\n\t\t\t{...rest}\n\t\t/>\n\t)\n}\n\ninterface TextAreaFieldProps {\n\tisInvalid?: boolean\n\tisLoading?: boolean\n\tisRequired?: boolean\n\tisOptional?: boolean\n\tid?: string\n\tlabel?: ReactNode\n\thelperText?: ReactNode\n\terror?: ReactNode\n\tfield: HTMLProps<HTMLTextAreaElement>\n\tsize?: 'medium' | 'large'\n\tdisabled?: boolean\n}\n\nconst TextAreaField = ({\n\tisInvalid,\n\tisLoading,\n\tisRequired,\n\tisOptional,\n\tid,\n\tlabel,\n\thelperText,\n\terror,\n\tfield,\n\tsize = 'medium',\n\t...rest\n}: TextAreaFieldProps) => {\n\tconst generatedId = useId()\n\tconst inputId = id ?? generatedId\n\n\treturn (\n\t\t<Field\n\t\t\tlabel={label}\n\t\t\thelperText={helperText}\n\t\t\terror={error}\n\t\t\tisRequired={isRequired}\n\t\t\tisOptional={isOptional}\n\t\t\tid={inputId}\n\t\t\tlayout=\"vertical\"\n\t\t>\n\t\t\t<TextAreaBase\n\t\t\t\tid={inputId}\n\t\t\t\tisInvalid={isInvalid}\n\t\t\t\tisLoading={isLoading}\n\t\t\t\trequired={isRequired}\n\t\t\t\tfield={field}\n\t\t\t\tsize={size}\n\t\t\t\t{...rest}\n\t\t\t/>\n\t\t</Field>\n\t)\n}\n\nTextAreaField.displayName = 'TextAreaField'\n\nexport { TextAreaField }\n"],"names":["TextAreaBase","isInvalid","isLoading","className","id","field","size","error","rest","jsx","classNames","s","TextAreaField","isRequired","isOptional","label","helperText","generatedId","useId","inputId","Field"],"mappings":";;;;;AAkBA,MAAMA,IAAe,CAAC;AAAA,EACrB,WAAAC;AAAA,EACA,WAAAC;AAAA,EACA,WAAAC;AAAA,EACA,IAAAC;AAAA,EACA,OAAAC;AAAA,EACA,MAAAC;AAAA,EACA,OAAAC;AAAA,EACA,GAAGC;AACJ,MAEE,gBAAAC;AAAA,EAAC;AAAA,EAAA;AAAA,IACA,IAAAL;AAAA,IACA,WAAWM;AAAA,MACVC,EAAE;AAAA,MACFA,EAAEL,CAAI;AAAA,MACN;AAAA,QACC,CAACK,EAAE,OAAO,GAAGV;AAAA,MAAA;AAAA,MAEdE;AAAA,IAAA;AAAA,IAED,oBAAkB,GAAGI,IAAQ,UAAU,aAAa,IAAIH,CAAE;AAAA,IACzD,GAAGC;AAAA,IACH,GAAGG;AAAA,EAAA;AAAA,GAmBDI,IAAgB,CAAC;AAAA,EACtB,WAAAX;AAAA,EACA,WAAAC;AAAA,EACA,YAAAW;AAAA,EACA,YAAAC;AAAA,EACA,IAAAV;AAAA,EACA,OAAAW;AAAA,EACA,YAAAC;AAAA,EACA,OAAAT;AAAA,EACA,OAAAF;AAAA,EACA,MAAAC,IAAO;AAAA,EACP,GAAGE;AACJ,MAA0B;AACzB,QAAMS,IAAcC,EAAA,GACdC,IAAUf,KAAMa;AAEtB,SACC,gBAAAR;AAAA,IAACW;AAAA,IAAA;AAAA,MACA,OAAAL;AAAA,MACA,YAAAC;AAAA,MACA,OAAAT;AAAA,MACA,YAAAM;AAAA,MACA,YAAAC;AAAA,MACA,IAAIK;AAAA,MACJ,QAAO;AAAA,MAEP,UAAA,gBAAAV;AAAA,QAACT;AAAA,QAAA;AAAA,UACA,IAAImB;AAAA,UACJ,WAAAlB;AAAA,UACA,WAAAC;AAAA,UACA,UAAUW;AAAA,UACV,OAAAR;AAAA,UACA,MAAAC;AAAA,UACC,GAAGE;AAAA,QAAA;AAAA,MAAA;AAAA,IACL;AAAA,EAAA;AAGH;AAEAI,EAAc,cAAc;"}
@@ -0,0 +1,12 @@
1
+ const o = "toggle__PmDvt", t = "control__GLB77", c = "facade__-n7d2", a = {
2
+ toggle: o,
3
+ control: t,
4
+ facade: c
5
+ };
6
+ export {
7
+ t as control,
8
+ a as default,
9
+ c as facade,
10
+ o as toggle
11
+ };
12
+ //# sourceMappingURL=form-toggle.module.scss.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-toggle.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;"}
@@ -0,0 +1,102 @@
1
+ import { jsx as o, jsxs as F } from "react/jsx-runtime";
2
+ import { useId as p } from "react";
3
+ import { Field as I } from "../field/index.js";
4
+ import { Fieldset as x } from "../fieldset/index.js";
5
+ import g from "./form-toggle.module.scss.js";
6
+ const u = ({
7
+ id: e,
8
+ field: r,
9
+ toggleOnEnter: t,
10
+ testingKey: l,
11
+ error: a,
12
+ ...d
13
+ }) => {
14
+ const i = p(), c = e ?? i, n = (s) => {
15
+ s.key === "Enter" && (s.currentTarget.checked = !s.currentTarget.checked);
16
+ };
17
+ return /* @__PURE__ */ F("div", { className: g.toggle, children: [
18
+ /* @__PURE__ */ o(
19
+ "input",
20
+ {
21
+ id: c,
22
+ className: g.control,
23
+ type: "checkbox",
24
+ ...r,
25
+ ...d,
26
+ role: "switch",
27
+ "aria-describedby": `${a ? "error" : "helper-text"}-${e}`,
28
+ onKeyDown: t ? n : void 0,
29
+ "data-testid": l
30
+ }
31
+ ),
32
+ /* @__PURE__ */ o("div", { className: g.facade })
33
+ ] });
34
+ };
35
+ u.displayName = "ToggleBase";
36
+ const T = ({
37
+ isInvalid: e,
38
+ isRequired: r,
39
+ isOptional: t,
40
+ id: l,
41
+ label: a,
42
+ helperText: d,
43
+ error: i,
44
+ field: c,
45
+ className: n,
46
+ testingKey: s,
47
+ ...f
48
+ }) => {
49
+ const h = p(), m = l ?? h;
50
+ return /* @__PURE__ */ o(
51
+ I,
52
+ {
53
+ label: a,
54
+ helperText: d,
55
+ error: i,
56
+ isRequired: r,
57
+ isOptional: t,
58
+ id: m,
59
+ layout: "flag",
60
+ className: n,
61
+ children: /* @__PURE__ */ o(
62
+ u,
63
+ {
64
+ id: m,
65
+ field: c,
66
+ testingKey: s,
67
+ ...f
68
+ }
69
+ )
70
+ }
71
+ );
72
+ };
73
+ T.displayName = "ToggleField";
74
+ const y = ({
75
+ layout: e = "vertical",
76
+ legend: r,
77
+ isOptional: t,
78
+ isRequired: l,
79
+ children: a
80
+ }) => /* @__PURE__ */ o(
81
+ x,
82
+ {
83
+ layout: e,
84
+ legend: r,
85
+ isOptional: t,
86
+ isRequired: l,
87
+ children: a
88
+ }
89
+ );
90
+ y.displayName = "ToggleGroupRoot";
91
+ const N = (e) => /* @__PURE__ */ o(T, { ...e, className: e.className });
92
+ N.displayName = "ToggleGroupField";
93
+ const j = {
94
+ Root: y,
95
+ Field: N
96
+ };
97
+ export {
98
+ u as ToggleBase,
99
+ T as ToggleField,
100
+ j as ToggleGroup
101
+ };
102
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/form/toggle/index.tsx"],"sourcesContent":["import { useId } from 'react'\nimport type { ReactNode, HTMLProps, ComponentProps } from 'react'\nimport { Field } from '../field'\nimport { Fieldset } from '../fieldset'\nimport s from './form-toggle.module.scss'\n\ninterface ToggleBaseProps {\n\tid?: string\n\n\t/**\n\t * Can be used to supply any props that the native `<input>` element supports (such as `value`, `placeholder`, in addition to events like `onChange` and `onBlur`)\n\t */\n\tfield: HTMLProps<HTMLInputElement>\n\ttoggleOnEnter?: boolean\n\ttestingKey?: string\n\terror?: ReactNode\n}\n\nconst ToggleBase = ({\n\tid,\n\tfield,\n\ttoggleOnEnter,\n\ttestingKey,\n\terror,\n\t...rest\n}: ToggleBaseProps) => {\n\tconst generatedId = useId()\n\tconst inputId = id ?? generatedId\n\n\tconst handleEnterKey = (event: React.KeyboardEvent<HTMLInputElement>) => {\n\t\tif (event.key === 'Enter') {\n\t\t\tevent.currentTarget.checked = !event.currentTarget.checked\n\t\t}\n\t}\n\n\treturn (\n\t\t<div className={s.toggle}>\n\t\t\t<input\n\t\t\t\tid={inputId}\n\t\t\t\tclassName={s.control}\n\t\t\t\ttype=\"checkbox\"\n\t\t\t\t{...field}\n\t\t\t\t{...rest}\n\t\t\t\trole=\"switch\"\n\t\t\t\taria-describedby={`${error ? 'error' : 'helper-text'}-${id}`}\n\t\t\t\tonKeyDown={toggleOnEnter ? handleEnterKey : undefined}\n\t\t\t\tdata-testid={testingKey}\n\t\t\t/>\n\t\t\t<div className={s.facade}></div>\n\t\t</div>\n\t)\n}\n\nToggleBase.displayName = 'ToggleBase'\n\ninterface ToggleFieldProps {\n\t/**\n\t * Applies an “invalid” appearance to the control but doesn’t modify its logical validity.\n\t */\n\tisInvalid?: boolean\n\n\t/**\n\t * Appends a `Required` indicator next to the label text and sets the `required` attribute on the control when user input is required.\n\t */\n\tisRequired?: boolean\n\n\t/**\n\t * Appends an `Optional` indicator next to the label text when user input is optional.\n\t */\n\tisOptional?: boolean\n\n\t/**\n\t * Input control’s ID attribute.\n\t *\n\t * By default, the ID is automatically generated by the component. Use this argument to pass a custom ID.\n\t */\n\tid?: string\n\n\t/**\n\t * Container that renders its content inside the `<label>` element. The content can be a simple string or a `ReactNode`, in which case it inherits the text style.\n\t *\n\t * The `for` attribute of the label is automatically generated using the `controlId` value of the control.\n\t */\n\tlabel?: ReactNode\n\n\t/**\n\t * Container that renders its content inside the \"helper text\" block. The content can be a simple string or a `ReactNode`, in which case it inherits the text style.\n\t *\n\t * The `id` attribute of the message is automatically generated using the `controlId` value of the control.\n\t */\n\thelperText?: ReactNode\n\n\t/**\n\t * Container that renders its content inside the \"error\" block. The content can be a simple string or a `ReactNode`, in which case it inherits the text style.\n\t *\n\t * The `id` attribute of the error message is automatically generated using the `controlId` value of the control.\n\t */\n\terror?: ReactNode\n\n\t/**\n\t * Can be used to supply any props that the native `<input>` element supports (such as `value`, `placeholder`, in addition to events like `onChange` and `onBlur`)\n\t */\n\tfield: HTMLProps<HTMLInputElement>\n\tclassName?: string\n\ttestingKey?: string\n}\n\nconst ToggleField = ({\n\tisInvalid,\n\tisRequired,\n\tisOptional,\n\tid,\n\tlabel,\n\thelperText,\n\terror,\n\tfield,\n\tclassName,\n\ttestingKey,\n\t...rest\n}: ToggleFieldProps) => {\n\tconst generatedId = useId()\n\tconst inputId = id ?? generatedId\n\treturn (\n\t\t<Field\n\t\t\tlabel={label}\n\t\t\thelperText={helperText}\n\t\t\terror={error}\n\t\t\tisRequired={isRequired}\n\t\t\tisOptional={isOptional}\n\t\t\tid={inputId}\n\t\t\tlayout=\"flag\"\n\t\t\tclassName={className}\n\t\t>\n\t\t\t<ToggleBase\n\t\t\t\tid={inputId}\n\t\t\t\tfield={field}\n\t\t\t\ttestingKey={testingKey}\n\t\t\t\t{...rest}\n\t\t\t/>\n\t\t</Field>\n\t)\n}\n\nToggleField.displayName = 'ToggleField'\n\ninterface ToggleGroupProps extends ComponentProps<typeof Fieldset> {\n\tchildren: ReactNode\n}\n\nconst ToggleGroupRoot = ({\n\tlayout = 'vertical',\n\tlegend,\n\tisOptional,\n\tisRequired,\n\tchildren,\n}: ToggleGroupProps) => {\n\treturn (\n\t\t<Fieldset\n\t\t\tlayout={layout}\n\t\t\tlegend={legend}\n\t\t\tisOptional={isOptional}\n\t\t\tisRequired={isRequired}\n\t\t>\n\t\t\t{children}\n\t\t</Fieldset>\n\t)\n}\n\nToggleGroupRoot.displayName = 'ToggleGroupRoot'\n\nconst ToggleGroupField = (props: ToggleFieldProps) => {\n\treturn <ToggleField {...props} className={props.className} />\n}\n\nToggleGroupField.displayName = 'ToggleGroupField'\n\nconst ToggleGroup = {\n\tRoot: ToggleGroupRoot,\n\tField: ToggleGroupField,\n}\n\nexport { ToggleBase, ToggleField, ToggleGroup }\n"],"names":["ToggleBase","id","field","toggleOnEnter","testingKey","error","rest","generatedId","useId","inputId","handleEnterKey","event","jsxs","s","jsx","ToggleField","isInvalid","isRequired","isOptional","label","helperText","className","Field","ToggleGroupRoot","layout","legend","children","Fieldset","ToggleGroupField","props","ToggleGroup"],"mappings":";;;;;AAkBA,MAAMA,IAAa,CAAC;AAAA,EACnB,IAAAC;AAAA,EACA,OAAAC;AAAA,EACA,eAAAC;AAAA,EACA,YAAAC;AAAA,EACA,OAAAC;AAAA,EACA,GAAGC;AACJ,MAAuB;AACtB,QAAMC,IAAcC,EAAA,GACdC,IAAUR,KAAMM,GAEhBG,IAAiB,CAACC,MAAiD;AACxE,IAAIA,EAAM,QAAQ,YACjBA,EAAM,cAAc,UAAU,CAACA,EAAM,cAAc;AAAA,EAErD;AAEA,SACC,gBAAAC,EAAC,OAAA,EAAI,WAAWC,EAAE,QACjB,UAAA;AAAA,IAAA,gBAAAC;AAAA,MAAC;AAAA,MAAA;AAAA,QACA,IAAIL;AAAA,QACJ,WAAWI,EAAE;AAAA,QACb,MAAK;AAAA,QACJ,GAAGX;AAAA,QACH,GAAGI;AAAA,QACJ,MAAK;AAAA,QACL,oBAAkB,GAAGD,IAAQ,UAAU,aAAa,IAAIJ,CAAE;AAAA,QAC1D,WAAWE,IAAgBO,IAAiB;AAAA,QAC5C,eAAaN;AAAA,MAAA;AAAA,IAAA;AAAA,IAEd,gBAAAU,EAAC,OAAA,EAAI,WAAWD,EAAE,OAAA,CAAQ;AAAA,EAAA,GAC3B;AAEF;AAEAb,EAAW,cAAc;AAsDzB,MAAMe,IAAc,CAAC;AAAA,EACpB,WAAAC;AAAA,EACA,YAAAC;AAAA,EACA,YAAAC;AAAA,EACA,IAAAjB;AAAA,EACA,OAAAkB;AAAA,EACA,YAAAC;AAAA,EACA,OAAAf;AAAA,EACA,OAAAH;AAAA,EACA,WAAAmB;AAAA,EACA,YAAAjB;AAAA,EACA,GAAGE;AACJ,MAAwB;AACvB,QAAMC,IAAcC,EAAA,GACdC,IAAUR,KAAMM;AACtB,SACC,gBAAAO;AAAA,IAACQ;AAAA,IAAA;AAAA,MACA,OAAAH;AAAA,MACA,YAAAC;AAAA,MACA,OAAAf;AAAA,MACA,YAAAY;AAAA,MACA,YAAAC;AAAA,MACA,IAAIT;AAAA,MACJ,QAAO;AAAA,MACP,WAAAY;AAAA,MAEA,UAAA,gBAAAP;AAAA,QAACd;AAAA,QAAA;AAAA,UACA,IAAIS;AAAA,UACJ,OAAAP;AAAA,UACA,YAAAE;AAAA,UACC,GAAGE;AAAA,QAAA;AAAA,MAAA;AAAA,IACL;AAAA,EAAA;AAGH;AAEAS,EAAY,cAAc;AAM1B,MAAMQ,IAAkB,CAAC;AAAA,EACxB,QAAAC,IAAS;AAAA,EACT,QAAAC;AAAA,EACA,YAAAP;AAAA,EACA,YAAAD;AAAA,EACA,UAAAS;AACD,MAEE,gBAAAZ;AAAA,EAACa;AAAA,EAAA;AAAA,IACA,QAAAH;AAAA,IACA,QAAAC;AAAA,IACA,YAAAP;AAAA,IACA,YAAAD;AAAA,IAEC,UAAAS;AAAA,EAAA;AAAA;AAKJH,EAAgB,cAAc;AAE9B,MAAMK,IAAmB,CAACC,wBACjBd,GAAA,EAAa,GAAGc,GAAO,WAAWA,EAAM,WAAW;AAG5DD,EAAiB,cAAc;AAE/B,MAAME,IAAc;AAAA,EACnB,MAAMP;AAAA,EACN,OAAOK;AACR;"}
@@ -0,0 +1,51 @@
1
+ "use client";
2
+ import { jsx as i } from "react/jsx-runtime";
3
+ import s from "@tippyjs/react";
4
+ import { followCursor as d } from "tippy.js";
5
+ import "tippy.js/dist/svg-arrow.css";
6
+ const n = {
7
+ name: "hideOnEsc",
8
+ defaultValue: !0,
9
+ fn(e) {
10
+ function o(t) {
11
+ t.key === "Escape" && e.hide();
12
+ }
13
+ return {
14
+ onShow() {
15
+ document.addEventListener("keydown", o);
16
+ },
17
+ onHide() {
18
+ document.removeEventListener("keydown", o);
19
+ }
20
+ };
21
+ }
22
+ }, w = ({ options: e = {}, children: o, text: t }) => {
23
+ const r = e.followCursor !== void 0 ? [n, d] : [n];
24
+ return /* @__PURE__ */ i(
25
+ s,
26
+ {
27
+ theme: "hds",
28
+ arrow: `<svg
29
+ className="hds-tooltip-pointer"
30
+ width="16"
31
+ height="7"
32
+ viewBox="0 0 16 7"
33
+ xmlns="http://www.w3.org/2000/svg"
34
+ >
35
+ <path d="M0 7H16L9.11989 0.444571C8.49776 -0.148191 7.50224 -0.148191 6.88011 0.444572L0 7Z" />
36
+ </svg>`,
37
+ interactive: !0,
38
+ aria: {
39
+ content: "describedby"
40
+ },
41
+ plugins: r,
42
+ content: t,
43
+ ...e,
44
+ children: o
45
+ }
46
+ );
47
+ };
48
+ export {
49
+ w as Tooltip
50
+ };
51
+ //# sourceMappingURL=tooltip.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tooltip.js","sources":["../../../../src/components/hds/wrappers/tooltip.tsx"],"sourcesContent":["'use client'\n\nimport Tippy, { type TippyProps } from '@tippyjs/react'\nimport { followCursor, type Plugin } from 'tippy.js'\nimport type { ReactElement } from 'react'\nimport 'tippy.js/dist/svg-arrow.css'\n\nexport interface TooltipProps {\n\toptions?: TippyProps\n\tchildren: TippyProps['children']\n\ttext: string | ReactElement\n}\n\nexport interface HideOnEsc extends Plugin {\n\tname: 'hideOnEsc'\n\tdefaultValue: true\n}\n\nconst hideOnEsc = {\n\tname: 'hideOnEsc',\n\tdefaultValue: true,\n\tfn(instance: { hide: () => void }) {\n\t\tfunction onKeyDown(event: KeyboardEvent): void {\n\t\t\tif (event.key === 'Escape') {\n\t\t\t\tinstance.hide()\n\t\t\t}\n\t\t}\n\n\t\treturn {\n\t\t\tonShow() {\n\t\t\t\tdocument.addEventListener('keydown', onKeyDown)\n\t\t\t},\n\t\t\tonHide() {\n\t\t\t\tdocument.removeEventListener('keydown', onKeyDown)\n\t\t\t},\n\t\t}\n\t},\n}\n\nexport const Tooltip = ({ options = {}, children, text }: TooltipProps) => {\n\tconst plugins =\n\t\toptions.followCursor !== undefined ? [hideOnEsc, followCursor] : [hideOnEsc]\n\n\treturn (\n\t\t<Tippy\n\t\t\ttheme=\"hds\"\n\t\t\tarrow={`<svg\n\t\t\t\t\tclassName=\"hds-tooltip-pointer\"\n\t\t\t\t\twidth=\"16\"\n\t\t\t\t\theight=\"7\"\n\t\t\t\t\tviewBox=\"0 0 16 7\"\n\t\t\t\t\txmlns=\"http://www.w3.org/2000/svg\"\n\t\t\t\t>\n\t\t\t\t\t<path d=\"M0 7H16L9.11989 0.444571C8.49776 -0.148191 7.50224 -0.148191 6.88011 0.444572L0 7Z\" />\n\t\t\t\t</svg>`}\n\t\t\tinteractive\n\t\t\taria={{\n\t\t\t\tcontent: 'describedby',\n\t\t\t}}\n\t\t\tplugins={plugins}\n\t\t\tcontent={text}\n\t\t\t{...options}\n\t\t>\n\t\t\t{children}\n\t\t</Tippy>\n\t)\n}\n"],"names":["hideOnEsc","instance","onKeyDown","event","options","text","followCursor","jsx","Tippy","plugins","children"],"mappings":";;;;;AAkBkB,MACjBA,IAAM;AAAA,EACN,MAAA;AAAA,EACA,cAAmC;AAAA,EAClC,GAAAC,GAAS;AACR,aAAIC;AACH,MAAAC,EAAA,QAAc,YACfF,EAAA,KAAA;AAAA,IAGD;AAAO;MAEL;AACD,iBAAA,iBAAA,WAAAC,CAAA;AAAA,MACA;AAAA,MACC;AACD,iBAAA,oBAAA,WAAAA,CAAA;AAAA,MACD;AAAA,IACD;AAAA,EACD;AAEO,OACA,CAAA,EACL,SAAAE,qBAAyB,MAAAC,EAAA;AAE1B,cACC,iBAAA,SAAA,CAAAL,GAAAM,CAAA,IAAA,CAAAN,CAAA;AAAA,SAAC,gBAAAO;AAAA,IAAAC;AAAA,IAAA;AAAA,MAEA,OAAO;AAAA,MAAA,OAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAUP,aAAM;AAAA,MAAA;QAEN,SAAA;AAAA,MACA;AAAA,MACA,SAAAC;AAAA,MACC,SAAGJ;AAAA,MAEH,GAAAD;AAAA,MAAA,UAAAM;AAAA,IACF;AAAA,EAEF;;"}
@@ -0,0 +1,50 @@
1
+ import { jsxs as u, jsx as o } from "react/jsx-runtime";
2
+ import N from "classnames";
3
+ import { FlightIcon as t } from "../flight-icon/index.js";
4
+ import e from "./style.module.scss.js";
5
+ const f = {
6
+ small: 12,
7
+ medium: 16,
8
+ large: 16
9
+ }, h = ({
10
+ size: i = "medium",
11
+ logo: r,
12
+ icon: m,
13
+ iconSecondary: s,
14
+ color: n = "neutral",
15
+ ...a
16
+ }) => {
17
+ const c = r ? `${r}-color` : m;
18
+ if (c) {
19
+ const l = i === "small" ? 16 : 24, d = r ? "logo" : "icon", p = r || n;
20
+ return /* @__PURE__ */ u(
21
+ "div",
22
+ {
23
+ className: N(
24
+ e["icon-tile"],
25
+ e[`type-${d}`],
26
+ e[`size-${i}`],
27
+ e[`color-${p}`]
28
+ ),
29
+ "aria-hidden": "true",
30
+ ...a,
31
+ children: [
32
+ /* @__PURE__ */ o("div", { className: r ? e.logo : e.icon, children: /* @__PURE__ */ o(t, { name: c, size: l, stretched: !0 }) }),
33
+ s && /* @__PURE__ */ o("div", { className: e.extra, children: /* @__PURE__ */ o(
34
+ t,
35
+ {
36
+ name: s,
37
+ size: f[i],
38
+ color: "var(--mds-color-foreground-strong)"
39
+ }
40
+ ) })
41
+ ]
42
+ }
43
+ );
44
+ }
45
+ };
46
+ h.displayName = "IconTile";
47
+ export {
48
+ h as IconTile
49
+ };
50
+ //# sourceMappingURL=index.js.map