@hashicorp/mds-react 0.9.2 → 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 (452) hide show
  1. package/components/accordion/index.d.ts +1 -1
  2. package/components/accordion/index.js +9 -0
  3. package/components/accordion/index.js.map +1 -0
  4. package/components/accordion/item/button.js +44 -0
  5. package/components/accordion/item/button.js.map +1 -0
  6. package/components/accordion/item/index.d.ts +1 -1
  7. package/components/accordion/item/index.js +59 -0
  8. package/components/accordion/item/index.js.map +1 -0
  9. package/components/accordion/style.module.scss.js +24 -0
  10. package/components/accordion/style.module.scss.js.map +1 -0
  11. package/components/alert/alert.module.scss.js +29 -0
  12. package/components/alert/alert.module.scss.js.map +1 -0
  13. package/components/alert/icon.d.ts +2 -2
  14. package/components/alert/icon.js +34 -0
  15. package/components/alert/icon.js.map +1 -0
  16. package/components/alert/index.d.ts +6 -6
  17. package/components/alert/index.js +97 -0
  18. package/components/alert/index.js.map +1 -0
  19. package/components/badge/index.d.ts +1 -1
  20. package/components/badge/index.js +50 -0
  21. package/components/badge/index.js.map +1 -0
  22. package/components/badge/style.module.scss.js +22 -0
  23. package/components/badge/style.module.scss.js.map +1 -0
  24. package/components/badge-count/index.d.ts +1 -1
  25. package/components/badge-count/index.js +29 -0
  26. package/components/badge-count/index.js.map +1 -0
  27. package/components/badge-count/style.module.scss.js +15 -0
  28. package/components/badge-count/style.module.scss.js.map +1 -0
  29. package/components/breadcrumbs/index.d.ts +2 -2
  30. package/components/breadcrumbs/index.js +38 -0
  31. package/components/breadcrumbs/index.js.map +1 -0
  32. package/components/breadcrumbs/item/index.d.ts +1 -1
  33. package/components/breadcrumbs/item/index.js +32 -0
  34. package/components/breadcrumbs/item/index.js.map +1 -0
  35. package/components/breadcrumbs/style.module.scss.js +27 -0
  36. package/components/breadcrumbs/style.module.scss.js.map +1 -0
  37. package/components/breadcrumbs/truncation-button/index.d.ts +1 -1
  38. package/components/breadcrumbs/truncation-button/index.js +25 -0
  39. package/components/breadcrumbs/truncation-button/index.js.map +1 -0
  40. package/components/breadcrumbs/types/index.d.ts +1 -1
  41. package/components/button/index.d.ts +4 -3
  42. package/components/button/index.js +119 -0
  43. package/components/button/index.js.map +1 -0
  44. package/components/button/styles.module.scss.js +32 -0
  45. package/components/button/styles.module.scss.js.map +1 -0
  46. package/components/card/card-thumbnail/card-thumbnail.module.css.js +8 -0
  47. package/components/card/card-thumbnail/card-thumbnail.module.css.js.map +1 -0
  48. package/components/card/card-thumbnail/index.d.ts +1 -1
  49. package/components/card/card-thumbnail/index.js +23 -0
  50. package/components/card/card-thumbnail/index.js.map +1 -0
  51. package/components/card/index.d.ts +3 -2
  52. package/components/card/index.js +160 -0
  53. package/components/card/index.js.map +1 -0
  54. package/components/card/styles.module.css.js +29 -0
  55. package/components/card/styles.module.css.js.map +1 -0
  56. package/components/card/types.d.ts +4 -3
  57. package/components/code-block/code-block.module.scss.js +34 -0
  58. package/components/code-block/code-block.module.scss.js.map +1 -0
  59. package/components/code-block/code-lines/index.d.ts +1 -8
  60. package/components/code-block/code-lines/index.js +59 -0
  61. package/components/code-block/code-lines/index.js.map +1 -0
  62. package/components/code-block/code-lines/utils/split-html-into-lines.d.ts +1 -1
  63. package/components/code-block/code-lines/utils/split-html-into-lines.js +19 -0
  64. package/components/code-block/code-lines/utils/split-html-into-lines.js.map +1 -0
  65. package/components/code-block/code-lines/utils/split-jsx-into-lines.d.ts +1 -1
  66. package/components/code-block/code-lines/utils/split-jsx-into-lines.js +31 -0
  67. package/components/code-block/code-lines/utils/split-jsx-into-lines.js.map +1 -0
  68. package/components/code-block/hidden-copy-content/index.d.ts +3 -3
  69. package/components/code-block/hidden-copy-content/index.js +13 -0
  70. package/components/code-block/hidden-copy-content/index.js.map +1 -0
  71. package/components/code-block/index.d.ts +1 -1
  72. package/components/code-block/index.js +88 -0
  73. package/components/code-block/index.js.map +1 -0
  74. package/components/code-block/utils/parse-highlighted-lines.js +39 -0
  75. package/components/code-block/utils/parse-highlighted-lines.js.map +1 -0
  76. package/components/code-block/utils/process-snippet.js +20 -0
  77. package/components/code-block/utils/process-snippet.js.map +1 -0
  78. package/components/code-block/utils/shellwords.js +33 -0
  79. package/components/code-block/utils/shellwords.js.map +1 -0
  80. package/components/combo-box-primitive/index.d.ts +1 -0
  81. package/components/combo-box-primitive/index.js +302 -0
  82. package/components/combo-box-primitive/index.js.map +1 -0
  83. package/components/dialog-primitive/dialog.module.scss.js +12 -0
  84. package/components/dialog-primitive/dialog.module.scss.js.map +1 -0
  85. package/components/dialog-primitive/index.d.ts +1 -1
  86. package/components/dialog-primitive/index.js +15 -0
  87. package/components/dialog-primitive/index.js.map +1 -0
  88. package/components/disclosure-primitive/index.d.ts +1 -2
  89. package/components/disclosure-primitive/index.js +57 -0
  90. package/components/disclosure-primitive/index.js.map +1 -0
  91. package/components/disclosure-primitive/styles.module.css.js +7 -0
  92. package/components/disclosure-primitive/styles.module.css.js.map +1 -0
  93. package/components/disclosure-primitive/use-disclosure-primitive.d.ts +2 -2
  94. package/components/disclosure-primitive/use-disclosure-primitive.js +17 -0
  95. package/components/disclosure-primitive/use-disclosure-primitive.js.map +1 -0
  96. package/components/dismiss-button/index.d.ts +1 -0
  97. package/components/dismiss-button/index.js +22 -0
  98. package/components/dismiss-button/index.js.map +1 -0
  99. package/components/dismiss-button/styles.module.scss.js +7 -0
  100. package/components/dismiss-button/styles.module.scss.js.map +1 -0
  101. package/components/dropdown/index.d.ts +6 -6
  102. package/components/dropdown/index.js +79 -0
  103. package/components/dropdown/index.js.map +1 -0
  104. package/components/dropdown/list-item/custom.d.ts +1 -1
  105. package/components/dropdown/list-item/custom.js +9 -0
  106. package/components/dropdown/list-item/custom.js.map +1 -0
  107. package/components/dropdown/list-item/index.d.ts +4 -4
  108. package/components/dropdown/list-item/index.js +14 -0
  109. package/components/dropdown/list-item/index.js.map +1 -0
  110. package/components/dropdown/list-item/interactive.d.ts +1 -1
  111. package/components/dropdown/list-item/interactive.js +49 -0
  112. package/components/dropdown/list-item/interactive.js.map +1 -0
  113. package/components/dropdown/list-item/separator.d.ts +1 -1
  114. package/components/dropdown/list-item/separator.js +17 -0
  115. package/components/dropdown/list-item/separator.js.map +1 -0
  116. package/components/dropdown/list-item/styles.module.css.js +26 -0
  117. package/components/dropdown/list-item/styles.module.css.js.map +1 -0
  118. package/components/dropdown/list-item/title.d.ts +1 -1
  119. package/components/dropdown/list-item/title.js +9 -0
  120. package/components/dropdown/list-item/title.js.map +1 -0
  121. package/components/dropdown/styles.module.css.js +24 -0
  122. package/components/dropdown/styles.module.css.js.map +1 -0
  123. package/components/dropdown/toggle-button/index.d.ts +2 -2
  124. package/components/dropdown/toggle-button/index.js +54 -0
  125. package/components/dropdown/toggle-button/index.js.map +1 -0
  126. package/components/dropdown/toggle-button/styles.module.scss.js +14 -0
  127. package/components/dropdown/toggle-button/styles.module.scss.js.map +1 -0
  128. package/components/flight-icon/flight-icon.module.css.js +12 -0
  129. package/components/flight-icon/flight-icon.module.css.js.map +1 -0
  130. package/components/flight-icon/index.d.ts +2 -2
  131. package/components/flight-icon/index.js +58 -0
  132. package/components/flight-icon/index.js.map +1 -0
  133. package/components/form/checkbox/form-checkbox.module.css.js +8 -0
  134. package/components/form/checkbox/form-checkbox.module.css.js.map +1 -0
  135. package/components/form/checkbox/index.d.ts +1 -1
  136. package/components/form/checkbox/index.js +109 -0
  137. package/components/form/checkbox/index.js.map +1 -0
  138. package/components/form/error/form-error.module.css.js +14 -0
  139. package/components/form/error/form-error.module.css.js.map +1 -0
  140. package/components/form/error/index.d.ts +1 -1
  141. package/components/form/error/index.js +22 -0
  142. package/components/form/error/index.js.map +1 -0
  143. package/components/form/field/form-field.module.css.js +17 -0
  144. package/components/form/field/form-field.module.css.js.map +1 -0
  145. package/components/form/field/index.d.ts +1 -1
  146. package/components/form/field/index.js +46 -0
  147. package/components/form/field/index.js.map +1 -0
  148. package/components/form/fieldset/form-fieldset.module.css.js +19 -0
  149. package/components/form/fieldset/form-fieldset.module.css.js.map +1 -0
  150. package/components/form/fieldset/index.d.ts +1 -1
  151. package/components/form/fieldset/index.js +65 -0
  152. package/components/form/fieldset/index.js.map +1 -0
  153. package/components/form/file-input/form-file-input.module.scss.js +7 -0
  154. package/components/form/file-input/form-file-input.module.scss.js.map +1 -0
  155. package/components/form/file-input/index.d.ts +1 -1
  156. package/components/form/file-input/index.js +68 -0
  157. package/components/form/file-input/index.js.map +1 -0
  158. package/components/form/helper-text/form-helper-text.module.css.js +7 -0
  159. package/components/form/helper-text/form-helper-text.module.css.js.map +1 -0
  160. package/components/form/helper-text/index.d.ts +1 -1
  161. package/components/form/helper-text/index.js +22 -0
  162. package/components/form/helper-text/index.js.map +1 -0
  163. package/components/form/indicator/form-indicator.module.css.js +8 -0
  164. package/components/form/indicator/form-indicator.module.css.js.map +1 -0
  165. package/components/form/indicator/index.js +23 -0
  166. package/components/form/indicator/index.js.map +1 -0
  167. package/components/form/label/form-label.module.css.js +10 -0
  168. package/components/form/label/form-label.module.css.js.map +1 -0
  169. package/components/form/label/index.d.ts +1 -1
  170. package/components/form/label/index.js +33 -0
  171. package/components/form/label/index.js.map +1 -0
  172. package/components/form/legend/form-legend.module.css.js +10 -0
  173. package/components/form/legend/form-legend.module.css.js.map +1 -0
  174. package/components/form/legend/index.d.ts +1 -1
  175. package/components/form/legend/index.js +19 -0
  176. package/components/form/legend/index.js.map +1 -0
  177. package/components/form/radio/form-radio.module.scss.js +8 -0
  178. package/components/form/radio/form-radio.module.scss.js.map +1 -0
  179. package/components/form/radio/index.d.ts +1 -1
  180. package/components/form/radio/index.js +100 -0
  181. package/components/form/radio/index.js.map +1 -0
  182. package/components/form/radio-card/description.js +10 -0
  183. package/components/form/radio-card/description.js.map +1 -0
  184. package/components/form/radio-card/form-radio-card.module.css.js +30 -0
  185. package/components/form/radio-card/form-radio-card.module.css.js.map +1 -0
  186. package/components/form/radio-card/group.d.ts +1 -1
  187. package/components/form/radio-card/group.js +31 -0
  188. package/components/form/radio-card/group.js.map +1 -0
  189. package/components/form/radio-card/index.d.ts +2 -2
  190. package/components/form/radio-card/index.js +67 -0
  191. package/components/form/radio-card/index.js.map +1 -0
  192. package/components/form/radio-card/label.js +10 -0
  193. package/components/form/radio-card/label.js.map +1 -0
  194. package/components/form/select/form-select.module.css.js +14 -0
  195. package/components/form/select/form-select.module.css.js.map +1 -0
  196. package/components/form/select/index.d.ts +1 -1
  197. package/components/form/select/index.js +79 -0
  198. package/components/form/select/index.js.map +1 -0
  199. package/components/form/super-select/form-super-select.module.css.js +22 -0
  200. package/components/form/super-select/form-super-select.module.css.js.map +1 -0
  201. package/components/form/super-select/index.d.ts +2 -2
  202. package/components/form/super-select/index.js +170 -0
  203. package/components/form/super-select/index.js.map +1 -0
  204. package/components/form/text-input/index.d.ts +1 -1
  205. package/components/form/text-input/index.js +91 -0
  206. package/components/form/text-input/index.js.map +1 -0
  207. package/components/form/text-input/styles.module.css.js +15 -0
  208. package/components/form/text-input/styles.module.css.js.map +1 -0
  209. package/components/form/textarea/form-textarea.module.css.js +14 -0
  210. package/components/form/textarea/form-textarea.module.css.js.map +1 -0
  211. package/components/form/textarea/index.d.ts +1 -1
  212. package/components/form/textarea/index.js +74 -0
  213. package/components/form/textarea/index.js.map +1 -0
  214. package/components/form/toggle/form-toggle.module.scss.js +12 -0
  215. package/components/form/toggle/form-toggle.module.scss.js.map +1 -0
  216. package/components/form/toggle/index.d.ts +1 -1
  217. package/components/form/toggle/index.js +102 -0
  218. package/components/form/toggle/index.js.map +1 -0
  219. package/components/hds/wrappers/tooltip.d.ts +3 -4
  220. package/components/hds/wrappers/tooltip.js +51 -0
  221. package/components/hds/wrappers/tooltip.js.map +1 -0
  222. package/components/icon-tile/index.d.ts +1 -1
  223. package/components/icon-tile/index.js +50 -0
  224. package/components/icon-tile/index.js.map +1 -0
  225. package/components/icon-tile/style.module.scss.js +29 -0
  226. package/components/icon-tile/style.module.scss.js.map +1 -0
  227. package/components/index.d.ts +1 -1
  228. package/components/index.js +116 -73
  229. package/components/index.js.map +1 -1
  230. package/components/inline-link/index.d.ts +1 -1
  231. package/components/inline-link/index.js +33 -0
  232. package/components/inline-link/index.js.map +1 -0
  233. package/components/inline-link/inline-link.module.css.js +11 -0
  234. package/components/inline-link/inline-link.module.css.js.map +1 -0
  235. package/components/interactive/index.d.ts +3 -4
  236. package/components/interactive/index.js +59 -0
  237. package/components/interactive/index.js.map +1 -0
  238. package/components/legacy-button/index.d.ts +3 -3
  239. package/components/legacy-button/index.js +65 -0
  240. package/components/legacy-button/index.js.map +1 -0
  241. package/components/legacy-button/types.d.ts +1 -1
  242. package/components/legacy-button/utils.d.ts +1 -1
  243. package/components/legacy-button/utils.js +39 -0
  244. package/components/legacy-button/utils.js.map +1 -0
  245. package/components/menu-primitive/index.d.ts +1 -1
  246. package/components/menu-primitive/index.js +68 -0
  247. package/components/menu-primitive/index.js.map +1 -0
  248. package/components/menu-primitive/styles.module.css.js +12 -0
  249. package/components/menu-primitive/styles.module.css.js.map +1 -0
  250. package/components/menu-primitive/use-menu-primitive.d.ts +2 -2
  251. package/components/menu-primitive/use-menu-primitive.js +17 -0
  252. package/components/menu-primitive/use-menu-primitive.js.map +1 -0
  253. package/components/modal/index.d.ts +1 -1
  254. package/components/modal/index.js +61 -0
  255. package/components/modal/index.js.map +1 -0
  256. package/components/modal/modal.module.css.js +8 -0
  257. package/components/modal/modal.module.css.js.map +1 -0
  258. package/components/modal/use-modal.d.ts +2 -2
  259. package/components/modal/use-modal.js +17 -0
  260. package/components/modal/use-modal.js.map +1 -0
  261. package/components/separator/index.d.ts +1 -1
  262. package/components/separator/index.js +15 -0
  263. package/components/separator/index.js.map +1 -0
  264. package/components/separator/separator.module.css.js +10 -0
  265. package/components/separator/separator.module.css.js.map +1 -0
  266. package/components/standalone-link/index.d.ts +2 -2
  267. package/components/standalone-link/index.js +54 -0
  268. package/components/standalone-link/index.js.map +1 -0
  269. package/components/standalone-link/styles.module.scss.js +17 -0
  270. package/components/standalone-link/styles.module.scss.js.map +1 -0
  271. package/components/table/index.d.ts +5 -5
  272. package/components/table/index.js +52 -0
  273. package/components/table/index.js.map +1 -0
  274. package/components/table/table.module.scss.js +33 -0
  275. package/components/table/table.module.scss.js.map +1 -0
  276. package/components/table/td.d.ts +2 -2
  277. package/components/table/td.js +28 -0
  278. package/components/table/td.js.map +1 -0
  279. package/components/table/th-button-tooltip.js +24 -0
  280. package/components/table/th-button-tooltip.js.map +1 -0
  281. package/components/table/th.d.ts +2 -2
  282. package/components/table/th.js +43 -0
  283. package/components/table/th.js.map +1 -0
  284. package/components/table/tr.d.ts +1 -1
  285. package/components/table/tr.js +9 -0
  286. package/components/table/tr.js.map +1 -0
  287. package/components/table/utils.js +28 -0
  288. package/components/table/utils.js.map +1 -0
  289. package/components/tabs/index.d.ts +3 -3
  290. package/components/tabs/index.js +117 -0
  291. package/components/tabs/index.js.map +1 -0
  292. package/components/tabs/tab-panel.d.ts +1 -1
  293. package/components/tabs/tab-panel.js +35 -0
  294. package/components/tabs/tab-panel.js.map +1 -0
  295. package/components/tabs/tab.d.ts +2 -2
  296. package/components/tabs/tab.js +70 -0
  297. package/components/tabs/tab.js.map +1 -0
  298. package/components/tabs/tabs.module.scss.js +22 -0
  299. package/components/tabs/tabs.module.scss.js.map +1 -0
  300. package/components/tabs/use-tabs-context.d.ts +2 -2
  301. package/components/tabs/use-tabs-context.js +16 -0
  302. package/components/tabs/use-tabs-context.js.map +1 -0
  303. package/components/text/index.d.ts +6 -6
  304. package/components/text/index.js +112 -0
  305. package/components/text/index.js.map +1 -0
  306. package/components/text/style.module.scss.js +9 -0
  307. package/components/text/style.module.scss.js.map +1 -0
  308. package/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.js +62 -0
  309. package/components/visualizations/bar-chart/horizontal-chart/dataset-value/index.js.map +1 -0
  310. package/components/visualizations/bar-chart/horizontal-chart/dataset-value/style.module.css.js +20 -0
  311. package/components/visualizations/bar-chart/horizontal-chart/dataset-value/style.module.css.js.map +1 -0
  312. package/components/visualizations/bar-chart/horizontal-chart/index.d.ts +1 -0
  313. package/components/visualizations/bar-chart/horizontal-chart/index.js +104 -0
  314. package/components/visualizations/bar-chart/horizontal-chart/index.js.map +1 -0
  315. package/components/visualizations/bar-chart/horizontal-chart/legend/index.js +13 -0
  316. package/components/visualizations/bar-chart/horizontal-chart/legend/index.js.map +1 -0
  317. package/components/visualizations/bar-chart/horizontal-chart/legend/style.module.css.js +14 -0
  318. package/components/visualizations/bar-chart/horizontal-chart/legend/style.module.css.js.map +1 -0
  319. package/components/visualizations/bar-chart/horizontal-chart/style.module.css.js +28 -0
  320. package/components/visualizations/bar-chart/horizontal-chart/style.module.css.js.map +1 -0
  321. package/components/visualizations/bar-chart/index.d.ts +1 -1
  322. package/components/visualizations/bar-chart/index.js +37 -0
  323. package/components/visualizations/bar-chart/index.js.map +1 -0
  324. package/components/visualizations/bar-chart/style.module.css.js +12 -0
  325. package/components/visualizations/bar-chart/style.module.css.js.map +1 -0
  326. package/components/visualizations/donut-chart/components/arc-tooltip/index.d.ts +2 -2
  327. package/components/visualizations/donut-chart/components/arc-tooltip/index.js +14 -0
  328. package/components/visualizations/donut-chart/components/arc-tooltip/index.js.map +1 -0
  329. package/components/visualizations/donut-chart/components/arc-tooltip/styles.module.css.js +10 -0
  330. package/components/visualizations/donut-chart/components/arc-tooltip/styles.module.css.js.map +1 -0
  331. package/components/visualizations/donut-chart/components/external-arc-label/index.d.ts +2 -2
  332. package/components/visualizations/donut-chart/components/external-arc-label/index.js +58 -0
  333. package/components/visualizations/donut-chart/components/external-arc-label/index.js.map +1 -0
  334. package/components/visualizations/donut-chart/components/external-arc-label/styles.module.css.js +16 -0
  335. package/components/visualizations/donut-chart/components/external-arc-label/styles.module.css.js.map +1 -0
  336. package/components/visualizations/donut-chart/components/internal-arc-label/index.d.ts +2 -2
  337. package/components/visualizations/donut-chart/components/internal-arc-label/index.js +42 -0
  338. package/components/visualizations/donut-chart/components/internal-arc-label/index.js.map +1 -0
  339. package/components/visualizations/donut-chart/components/internal-arc-label/styles.module.css.js +14 -0
  340. package/components/visualizations/donut-chart/components/internal-arc-label/styles.module.css.js.map +1 -0
  341. package/components/visualizations/donut-chart/index.d.ts +1 -1
  342. package/components/visualizations/donut-chart/index.js +90 -0
  343. package/components/visualizations/donut-chart/index.js.map +1 -0
  344. package/components/visualizations/donut-chart/styles.module.css.js +20 -0
  345. package/components/visualizations/donut-chart/styles.module.css.js.map +1 -0
  346. package/hooks/use-media-query/index.js +16 -0
  347. package/hooks/use-media-query/index.js.map +1 -0
  348. package/index.js +155 -101
  349. package/index.js.map +1 -1
  350. package/package.json +1 -1
  351. package/patterns/card/newsroom-card/index.d.ts +1 -1
  352. package/patterns/card/newsroom-card/index.js +26 -0
  353. package/patterns/card/newsroom-card/index.js.map +1 -0
  354. package/patterns/card/newsroom-card/style.module.css.js +8 -0
  355. package/patterns/card/newsroom-card/style.module.css.js.map +1 -0
  356. package/patterns/card/partner-card/index.d.ts +2 -2
  357. package/patterns/card/partner-card/index.js +42 -0
  358. package/patterns/card/partner-card/index.js.map +1 -0
  359. package/patterns/card/partner-card/style.module.css.js +12 -0
  360. package/patterns/card/partner-card/style.module.css.js.map +1 -0
  361. package/patterns/card/person-card/index.d.ts +1 -1
  362. package/patterns/card/person-card/index.js +52 -0
  363. package/patterns/card/person-card/index.js.map +1 -0
  364. package/patterns/card/person-card/style.module.css.js +12 -0
  365. package/patterns/card/person-card/style.module.css.js.map +1 -0
  366. package/patterns/card/primitives.d.ts +5 -5
  367. package/patterns/card/primitives.js +77 -0
  368. package/patterns/card/primitives.js.map +1 -0
  369. package/patterns/card/promo-card/index.d.ts +1 -1
  370. package/patterns/card/promo-card/index.js +36 -0
  371. package/patterns/card/promo-card/index.js.map +1 -0
  372. package/patterns/card/resource-card/index.d.ts +1 -1
  373. package/patterns/card/resource-card/index.js +26 -0
  374. package/patterns/card/resource-card/index.js.map +1 -0
  375. package/patterns/card/style.module.css.js +30 -0
  376. package/patterns/card/style.module.css.js.map +1 -0
  377. package/patterns/card/thumbnails/index.d.ts +1 -1
  378. package/patterns/card/thumbnails/index.js +25 -0
  379. package/patterns/card/thumbnails/index.js.map +1 -0
  380. package/patterns/card/types.d.ts +6 -6
  381. package/patterns/card/unified-card/index.d.ts +1 -1
  382. package/patterns/card/unified-card/index.js +37 -0
  383. package/patterns/card/unified-card/index.js.map +1 -0
  384. package/patterns/copy-button/clipboard.d.ts +1 -1
  385. package/patterns/copy-button/clipboard.js +78 -0
  386. package/patterns/copy-button/clipboard.js.map +1 -0
  387. package/patterns/copy-button/index.d.ts +1 -1
  388. package/patterns/copy-button/index.js +57 -0
  389. package/patterns/copy-button/index.js.map +1 -0
  390. package/patterns/copy-button/style.module.css.js +13 -0
  391. package/patterns/copy-button/style.module.css.js.map +1 -0
  392. package/patterns/index.js +32 -22
  393. package/patterns/index.js.map +1 -1
  394. package/patterns/layout/index.d.ts +20 -20
  395. package/patterns/layout/index.js +47 -0
  396. package/patterns/layout/index.js.map +1 -0
  397. package/patterns/layout/layout.module.css.js +20 -0
  398. package/patterns/layout/layout.module.css.js.map +1 -0
  399. package/patterns/product-badge/index.js +22 -0
  400. package/patterns/product-badge/index.js.map +1 -0
  401. package/patterns/product-badge/style.module.css.js +8 -0
  402. package/patterns/product-badge/style.module.css.js.map +1 -0
  403. package/patterns/product-logo/index.d.ts +15 -15
  404. package/patterns/product-logo/index.js +130 -0
  405. package/patterns/product-logo/index.js.map +1 -0
  406. package/patterns/product-logo/product-logo.module.css.js +13 -0
  407. package/patterns/product-logo/product-logo.module.css.js.map +1 -0
  408. package/patterns/related-content/index.d.ts +1 -1
  409. package/patterns/related-content/index.js +65 -0
  410. package/patterns/related-content/index.js.map +1 -0
  411. package/patterns/related-content/style.module.css.js +22 -0
  412. package/patterns/related-content/style.module.css.js.map +1 -0
  413. package/patterns/related-content/types.d.ts +1 -1
  414. package/style.css +1 -1
  415. package/styles/mixins/button.scss +1 -6
  416. package/utils/get-contrast-yiq.js +13 -0
  417. package/utils/get-contrast-yiq.js.map +1 -0
  418. package/utils/hooks/use-screen-size.js +10 -0
  419. package/utils/hooks/use-screen-size.js.map +1 -0
  420. package/utils/i18n/constants/index.js +98 -0
  421. package/utils/i18n/constants/index.js.map +1 -0
  422. package/utils/i18n/helpers/locale-provider.js +9 -0
  423. package/utils/i18n/helpers/locale-provider.js.map +1 -0
  424. package/utils/i18n/helpers/to-smart-sentence-case.js +12 -0
  425. package/utils/i18n/helpers/to-smart-sentence-case.js.map +1 -0
  426. package/utils/i18n/helpers/to-smart-title-case.js +10 -0
  427. package/utils/i18n/helpers/to-smart-title-case.js.map +1 -0
  428. package/utils/i18n/helpers/use-locale.js +14 -0
  429. package/utils/i18n/helpers/use-locale.js.map +1 -0
  430. package/utils/i18n/index.d.ts +1 -1
  431. package/utils/i18n/index.js +41 -0
  432. package/utils/i18n/index.js.map +1 -0
  433. package/utils/i18n/index2.js +33 -0
  434. package/utils/i18n/index2.js.map +1 -0
  435. package/utils/index.js +7 -7
  436. package/utils/make-normalizer/index.d.ts +6 -6
  437. package/utils/make-normalizer/index.js +34 -0
  438. package/utils/make-normalizer/index.js.map +1 -0
  439. package/utils/mds-context/index.d.ts +1 -1
  440. package/{index-DBjAbGt7.js → utils/mds-context/index.js} +20 -19
  441. package/utils/mds-context/index.js.map +1 -0
  442. package/index-B9mPJh9w.js +0 -579
  443. package/index-B9mPJh9w.js.map +0 -1
  444. package/index-BHBlMMNF.js +0 -16
  445. package/index-BHBlMMNF.js.map +0 -1
  446. package/index-C4GBbW3N.js +0 -3567
  447. package/index-C4GBbW3N.js.map +0 -1
  448. package/index-DBjAbGt7.js.map +0 -1
  449. package/index-WkGIywHj.js +0 -767
  450. package/index-WkGIywHj.js.map +0 -1
  451. package/use-screen-size-BOnkX_K-.js +0 -9
  452. package/use-screen-size-BOnkX_K-.js.map +0 -1
@@ -0,0 +1,32 @@
1
+ "use client";
2
+ import { jsx as e, jsxs as o, Fragment as d } from "react/jsx-runtime";
3
+ import { useMDSLink as h } from "../../../utils/mds-context/index.js";
4
+ import s from "../style.module.scss.js";
5
+ const i = ({ icon: r, text: n }) => /* @__PURE__ */ o(d, { children: [
6
+ r && /* @__PURE__ */ e("div", { className: s.icon, children: r }),
7
+ /* @__PURE__ */ e("span", { className: s.text, children: n })
8
+ ] }), f = ({
9
+ maxWidth: r,
10
+ current: n,
11
+ icon: t,
12
+ text: c,
13
+ url: l,
14
+ ...m
15
+ }) => {
16
+ const a = h();
17
+ return /* @__PURE__ */ e(
18
+ "li",
19
+ {
20
+ className: s.item,
21
+ style: {
22
+ ...r && { maxWidth: r }
23
+ },
24
+ ...m,
25
+ children: n ? /* @__PURE__ */ e("div", { className: s.current, children: /* @__PURE__ */ e(i, { icon: t, text: c }) }) : /* @__PURE__ */ e(a, { className: s.link, href: l, children: /* @__PURE__ */ e(i, { icon: t, text: c }) })
26
+ }
27
+ );
28
+ };
29
+ export {
30
+ f as Item
31
+ };
32
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/breadcrumbs/item/index.tsx"],"sourcesContent":["'use client'\n\nimport { useMDSLink } from '../../../utils/mds-context'\nimport type { BreadcrumbItemProps } from '../types'\nimport s from '../style.module.scss'\n\ninterface ItemContentProps {\n\ttext: string\n\t/**\n\t * Use to show an flight icon.\n\t */\n\ticon?: React.ReactNode\n}\n\nconst ItemContent = ({ icon, text }: ItemContentProps) => {\n\treturn (\n\t\t<>\n\t\t\t{icon && <div className={s.icon}>{icon}</div>}\n\n\t\t\t<span className={s.text}>{text}</span>\n\t\t</>\n\t)\n}\n\nexport const Item = ({\n\tmaxWidth,\n\tcurrent,\n\ticon,\n\ttext,\n\turl,\n\t...rest\n}: BreadcrumbItemProps) => {\n\tconst Link = useMDSLink()\n\n\treturn (\n\t\t<li\n\t\t\tclassName={s.item}\n\t\t\tstyle={{\n\t\t\t\t...(maxWidth && { maxWidth }),\n\t\t\t}}\n\t\t\t{...rest}\n\t\t>\n\t\t\t{current ? (\n\t\t\t\t<div className={s.current}>\n\t\t\t\t\t<ItemContent icon={icon} text={text} />\n\t\t\t\t</div>\n\t\t\t) : (\n\t\t\t\t<Link className={s.link} href={url}>\n\t\t\t\t\t<ItemContent icon={icon} text={text} />\n\t\t\t\t</Link>\n\t\t\t)}\n\t\t</li>\n\t)\n}\n"],"names":["text","jsxs","Fragment","icon","jsx","Item","maxWidth","current","url","rest","ItemContent","Link"],"mappings":";;;;AAeC,sBACC,MAAAA,QACE,gBAAAC,EAAQC,GAAC,EAAI,UAAW;AAAA,EAAcC,KAEtC,gBAAAC,EAAA,OAAK,EAAA,aAAoB,MAAA,UAAKD,EAAA,CAAA;AAAA,EAChC,gBAAAC,EAAA,QAAA,EAAA,WAAA,EAAA,MAAA,UAAAJ,EAAA,CAAA;AAEF,EAAA,CAAA,GAGCK,IAAA,CAAA;AAAA,EACA,UAAAC;AAAA,EACA,SAAAC;AAAA,EACA,MAAAJ;AAAA,EACA,MAAAH;AAAA,EACA,KAAAQ;AAAA,EACD,GAAAC;AACC,MAAA;AAEA,cACC;AAAA,SAAC,gBAAAL;AAAA,IAAA;AAAA,IAAA;AAAA,MAEA,WAAO,EAAA;AAAA,MAAA,OACF;AAAA,QACL,GAAAE,KAAA,EAAA,UAAAA,EAAA;AAAA,MACC;AAAA,MAEA,GAAAG;AAAA,MAOA,UAAAF,IAAA,gBAAAH,EAAA,OAAA,EAAA,WAAA,EAAA,SAAA,UAAA,gBAAAA,EAAAM,GAAA,EAAA,MAAAP,GAAA,MAAAH,EAAA,CAAA,EAAA,CAAA,IAAA,gBAAAI,EAAAO,GAAA,EAAA,WAAA,EAAA,MAAA,MAAAH,GAAA,UAAA,gBAAAJ,EAAAM,GAAA,EAAA,MAAAP,GAAA,MAAAH,EAAA,CAAA,EAAA,CAAA;AAAA,IAEF;AAAA,EAEF;;"}
@@ -0,0 +1,27 @@
1
+ const t = "breadcrumbs__qRWRC", n = "list__ex8fu", c = "sublist__sSjxU", s = "item__vAjEk", i = "truncation__Kmsae", o = "link__T7iXX", _ = "text__g0Z5V", r = "current__RtvDC", e = "icon__QZYpF", u = {
2
+ breadcrumbs: t,
3
+ list: n,
4
+ "items-can-wrap": "items-can-wrap__vfE8u",
5
+ sublist: c,
6
+ item: s,
7
+ truncation: i,
8
+ link: o,
9
+ text: _,
10
+ current: r,
11
+ icon: e,
12
+ "truncation-button": "truncation-button__3eNF8",
13
+ "truncation-content": "truncation-content__P-Vh1"
14
+ };
15
+ export {
16
+ t as breadcrumbs,
17
+ r as current,
18
+ u as default,
19
+ e as icon,
20
+ s as item,
21
+ o as link,
22
+ n as list,
23
+ c as sublist,
24
+ _ as text,
25
+ i as truncation
26
+ };
27
+ //# sourceMappingURL=style.module.scss.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"style.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;"}
@@ -1,3 +1,3 @@
1
1
  export declare const TruncationButton: ({ ariaLabel, }: {
2
- ariaLabel?: string;
2
+ ariaLabel?: string | undefined;
3
3
  }) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,25 @@
1
+ "use client";
2
+ import { jsx as o } from "react/jsx-runtime";
3
+ import { IconMoreHorizontal16 as e } from "@hashicorp/flight-icons/svg-react/more-horizontal-16";
4
+ import { useMenuPrimitive as i } from "../../menu-primitive/use-menu-primitive.js";
5
+ import a from "../style.module.scss.js";
6
+ const l = ({
7
+ ariaLabel: t = "show more"
8
+ }) => {
9
+ const { isOpen: n, onClickToggle: r } = i();
10
+ return /* @__PURE__ */ o(
11
+ "button",
12
+ {
13
+ type: "button",
14
+ className: a["truncation-button"],
15
+ "aria-label": t,
16
+ "aria-expanded": n,
17
+ onClick: r,
18
+ children: /* @__PURE__ */ o(e, {})
19
+ }
20
+ );
21
+ };
22
+ export {
23
+ l as TruncationButton
24
+ };
25
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/breadcrumbs/truncation-button/index.tsx"],"sourcesContent":["'use client'\n\nimport { IconMoreHorizontal16 } from '@hashicorp/flight-icons/svg-react/more-horizontal-16'\nimport { useMenuPrimitive } from '../../menu-primitive/use-menu-primitive'\nimport s from '../style.module.scss'\n\nexport const TruncationButton = ({\n\tariaLabel = 'show more',\n}: {\n\tariaLabel?: string\n}) => {\n\tconst { isOpen, onClickToggle } = useMenuPrimitive()\n\n\treturn (\n\t\t<button\n\t\t\ttype=\"button\"\n\t\t\tclassName={s['truncation-button']}\n\t\t\taria-label={ariaLabel}\n\t\t\taria-expanded={isOpen}\n\t\t\tonClick={onClickToggle}\n\t\t>\n\t\t\t<IconMoreHorizontal16 />\n\t\t</button>\n\t)\n}\n"],"names":["ariaLabel","useMenuPrimitive","jsx","s","isOpen","IconMoreHorizontal16"],"mappings":";;;;;AAMiC,UACpB,CAAA;AAAA,EACb,WAAAA,IAEM;AACL,MAAA;AAEA,sCACC,IAAAC,EAAA;AAAA,SAAC,gBAAAC;AAAA,IAAA;AAAA,IAAA;AAAA,MAEA,MAAA;AAAA,MACA,WAAAC,qBAAY;AAAA,MACZ,cAAAH;AAAA,MACA,iBAASI;AAAA,MAET;MAAsB,UAAA,gBAAAF,EAAAG,GAAA,CAAA,CAAA;AAAA,IACvB;AAAA,EAEF;;"}
@@ -1,4 +1,4 @@
1
- import type { HTMLAttributes, LiHTMLAttributes, ReactNode } from 'react';
1
+ import { HTMLAttributes, LiHTMLAttributes, ReactNode } from 'react';
2
2
  export interface BreadcrumbProps extends HTMLAttributes<HTMLElement> {
3
3
  /**
4
4
  * This controls if the Breadcrumb Items can wrap if they don’t fit within the container.
@@ -1,4 +1,5 @@
1
- import type { ForwardRefExoticComponent } from 'react';
1
+ import { ForwardRefExoticComponent } from 'react';
2
+ import { FlightIconName } from '../flight-icon';
2
3
  export declare const BUTTON_SIZES: readonly ["small", "medium", "large"];
3
4
  export type ButtonSize = (typeof BUTTON_SIZES)[number];
4
5
  export declare const BUTTON_ICON_POSITIONS: readonly ["leading", "trailing"];
@@ -12,7 +13,7 @@ interface ButtonPrimitiveProps {
12
13
  color?: LegacyButtonColor;
13
14
  isFullWidth?: boolean;
14
15
  isIconOnly?: boolean;
15
- icon?: string;
16
+ icon?: FlightIconName;
16
17
  iconPosition?: ButtonIconPosition;
17
18
  text?: string;
18
19
  href?: string;
@@ -27,5 +28,5 @@ interface ButtonPrimitiveProps {
27
28
  export interface ButtonProps extends Omit<ButtonPrimitiveProps, 'color'> {
28
29
  color?: ButtonColor;
29
30
  }
30
- export declare const Button: ForwardRefExoticComponent<ButtonProps & import("react").RefAttributes<HTMLButtonElement | HTMLAnchorElement>>;
31
+ export declare const Button: ForwardRefExoticComponent<ButtonProps & import('react').RefAttributes<HTMLButtonElement | HTMLAnchorElement>>;
31
32
  export {};
@@ -0,0 +1,119 @@
1
+ import { jsx as c, jsxs as I, Fragment as v } from "react/jsx-runtime";
2
+ import { forwardRef as d } from "react";
3
+ import y from "classnames";
4
+ import { Interactive as w } from "../interactive/index.js";
5
+ import { FlightIcon as b } from "../flight-icon/index.js";
6
+ import a from "./styles.module.scss.js";
7
+ const $ = ["small", "medium", "large"], j = ["leading", "trailing"], x = [
8
+ "primary",
9
+ "primary-black",
10
+ "primary-white",
11
+ "secondary",
12
+ // deprecated; maps to secondary-white
13
+ "secondary-high-contrast",
14
+ // alternates based on theme
15
+ "secondary-white",
16
+ "secondary-black",
17
+ "tertiary",
18
+ "critical",
19
+ "boundary",
20
+ "consul",
21
+ "nomad",
22
+ "packer",
23
+ "terraform",
24
+ "vagrant",
25
+ "vault",
26
+ "waypoint",
27
+ "hashicorp"
28
+ // alias to primary
29
+ ], B = {
30
+ primary: "primary",
31
+ "primary-black": "custom",
32
+ "primary-white": "custom",
33
+ secondary: "custom",
34
+ "secondary-high-contrast": "custom",
35
+ "secondary-white": "custom",
36
+ "secondary-black": "custom",
37
+ tertiary: "tertiary",
38
+ critical: "critical",
39
+ boundary: "custom",
40
+ consul: "custom",
41
+ nomad: "custom",
42
+ packer: "custom",
43
+ terraform: "custom",
44
+ vagrant: "custom",
45
+ vault: "custom",
46
+ waypoint: "custom",
47
+ hashicorp: "primary"
48
+ }, C = {
49
+ small: 12,
50
+ medium: 16,
51
+ large: 24
52
+ }, p = d(
53
+ ({
54
+ size: o = "medium",
55
+ color: s = "primary",
56
+ isFullWidth: m,
57
+ isIconOnly: i,
58
+ icon: r,
59
+ iconPosition: e = "leading",
60
+ text: t,
61
+ href: h,
62
+ isHrefExternal: g,
63
+ className: f,
64
+ locale: N,
65
+ ...u
66
+ }, O) => {
67
+ const n = i && !!r, l = r && /* @__PURE__ */ c(b, { name: r, size: C[o] });
68
+ return /* @__PURE__ */ c(
69
+ w,
70
+ {
71
+ className: y(
72
+ a.button,
73
+ a[`size-${o}`],
74
+ {
75
+ [a["width-full"]]: m,
76
+ [a["icon-only"]]: n
77
+ },
78
+ s !== "custom" && a[`color-${s}`],
79
+ f
80
+ ),
81
+ href: u.disabled ? "" : h,
82
+ isHrefExternal: g,
83
+ "aria-label": n ? t : void 0,
84
+ locale: N,
85
+ ...u,
86
+ ref: O,
87
+ children: n && r ? l : /* @__PURE__ */ I(v, { children: [
88
+ r && e === "leading" && l,
89
+ t ? /* @__PURE__ */ c("div", { className: a.text, children: t }) : null,
90
+ r && e === "trailing" && l
91
+ ] })
92
+ }
93
+ );
94
+ }
95
+ );
96
+ p.displayName = "ButtonPrimitive";
97
+ const T = d(({ color: o = "primary", className: s, ...m }, i) => {
98
+ const r = B[o], t = r === "custom" ? a[`color-${{
99
+ hashicorp: "primary",
100
+ secondary: "secondary-white"
101
+ }[o] ?? o}`] : void 0;
102
+ return /* @__PURE__ */ c(
103
+ p,
104
+ {
105
+ ...m,
106
+ color: r,
107
+ className: y(t, s),
108
+ ref: i
109
+ }
110
+ );
111
+ });
112
+ T.displayName = "Button";
113
+ export {
114
+ x as BUTTON_COLORS,
115
+ j as BUTTON_ICON_POSITIONS,
116
+ $ as BUTTON_SIZES,
117
+ T as Button
118
+ };
119
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../src/components/button/index.tsx"],"sourcesContent":["import type { ForwardRefExoticComponent } from 'react'\nimport { forwardRef } from 'react'\nimport classNames from 'classnames'\nimport { Interactive } from '../interactive'\nimport type { FlightIconName, FlightIconSize } from '../flight-icon'\nimport { FlightIcon } from '../flight-icon'\nimport s from './styles.module.scss'\n\nexport const BUTTON_SIZES = ['small', 'medium', 'large'] as const\nexport type ButtonSize = (typeof BUTTON_SIZES)[number]\n\nexport const BUTTON_ICON_POSITIONS = ['leading', 'trailing'] as const\nexport type ButtonIconPosition = (typeof BUTTON_ICON_POSITIONS)[number]\n\nexport const BUTTON_COLORS = [\n\t'primary',\n\t'primary-black',\n\t'primary-white',\n\t'secondary', // deprecated; maps to secondary-white\n\t'secondary-high-contrast', // alternates based on theme\n\t'secondary-white',\n\t'secondary-black',\n\t'tertiary',\n\t'critical',\n\t'boundary',\n\t'consul',\n\t'nomad',\n\t'packer',\n\t'terraform',\n\t'vagrant',\n\t'vault',\n\t'waypoint',\n\t'hashicorp', // alias to primary\n] as const\nexport type ButtonColor = (typeof BUTTON_COLORS)[number]\n\n// These are the only “real” colors our legacy button knows about\nconst LEGACY_COLORS = [\n\t'primary',\n\t'secondary',\n\t'tertiary',\n\t'critical',\n\t'custom',\n] as const\ntype LegacyButtonColor = (typeof LEGACY_COLORS)[number]\n\n// map HDS “super-set” colors down to our legacy ones\nconst COLOR_MAP: Record<ButtonColor, LegacyButtonColor> = {\n\tprimary: 'primary',\n\t'primary-black': 'custom',\n\t'primary-white': 'custom',\n\tsecondary: 'custom',\n\t'secondary-high-contrast': 'custom',\n\t'secondary-white': 'custom',\n\t'secondary-black': 'custom',\n\ttertiary: 'tertiary',\n\tcritical: 'critical',\n\tboundary: 'custom',\n\tconsul: 'custom',\n\tnomad: 'custom',\n\tpacker: 'custom',\n\tterraform: 'custom',\n\tvagrant: 'custom',\n\tvault: 'custom',\n\twaypoint: 'custom',\n\thashicorp: 'primary',\n}\n\ninterface ButtonPrimitiveProps {\n\tsize?: ButtonSize\n\tcolor?: LegacyButtonColor\n\tisFullWidth?: boolean\n\tisIconOnly?: boolean\n\ticon?: FlightIconName\n\ticonPosition?: ButtonIconPosition\n\ttext?: string\n\thref?: string\n\tisHrefExternal?: boolean\n\tonClick?: React.MouseEventHandler<HTMLButtonElement>\n\tclassName?: string\n\tlocale?: string\n\tdisabled?: boolean\n\tautoFocus?: boolean\n\ttype?: 'button' | 'submit' | 'reset'\n}\n\nconst ICON_SIZE_MAP = {\n\tsmall: 12,\n\tmedium: 16,\n\tlarge: 24,\n} as const satisfies Record<'small' | 'medium' | 'large', FlightIconSize>\n\nconst ButtonPrimitive = forwardRef<HTMLButtonElement, ButtonPrimitiveProps>(\n\t(\n\t\t{\n\t\t\tsize = 'medium',\n\t\t\tcolor = 'primary',\n\t\t\tisFullWidth,\n\t\t\tisIconOnly,\n\t\t\ticon,\n\t\t\ticonPosition = 'leading',\n\t\t\ttext,\n\t\t\thref,\n\t\t\tisHrefExternal,\n\t\t\tclassName,\n\t\t\tlocale,\n\t\t\t...rest\n\t\t},\n\t\tref\n\t) => {\n\t\tconst hasIcon = Boolean(icon)\n\t\tconst showIconOnly = isIconOnly && hasIcon\n\n\t\tconst iconElement = icon && (\n\t\t\t<FlightIcon name={icon} size={ICON_SIZE_MAP[size]} />\n\t\t)\n\n\t\treturn (\n\t\t\t<Interactive\n\t\t\t\tclassName={classNames(\n\t\t\t\t\ts.button,\n\t\t\t\t\ts[`size-${size}`],\n\t\t\t\t\t{\n\t\t\t\t\t\t[s['width-full']]: isFullWidth,\n\t\t\t\t\t\t[s['icon-only']]: showIconOnly,\n\t\t\t\t\t},\n\t\t\t\t\tcolor !== 'custom' && s[`color-${color}`],\n\t\t\t\t\tclassName\n\t\t\t\t)}\n\t\t\t\thref={rest.disabled ? '' : href}\n\t\t\t\tisHrefExternal={isHrefExternal}\n\t\t\t\taria-label={showIconOnly ? text : undefined}\n\t\t\t\tlocale={locale}\n\t\t\t\t{...rest}\n\t\t\t\tref={ref}\n\t\t\t>\n\t\t\t\t{showIconOnly && icon ? (\n\t\t\t\t\ticonElement\n\t\t\t\t) : (\n\t\t\t\t\t<>\n\t\t\t\t\t\t{icon && iconPosition === 'leading' && iconElement}\n\t\t\t\t\t\t{text ? <div className={s.text}>{text}</div> : null}\n\t\t\t\t\t\t{icon && iconPosition === 'trailing' && iconElement}\n\t\t\t\t\t</>\n\t\t\t\t)}\n\t\t\t</Interactive>\n\t\t)\n\t}\n)\nButtonPrimitive.displayName = 'ButtonPrimitive'\n\nexport interface ButtonProps extends Omit<ButtonPrimitiveProps, 'color'> {\n\tcolor?: ButtonColor\n}\n\nexport const Button = forwardRef<\n\tHTMLAnchorElement | HTMLButtonElement,\n\tButtonProps\n>(({ color = 'primary', className, ...rest }, ref) => {\n\tconst legacyColor = COLOR_MAP[color]\n\n\tconst remappedColors: Partial<Record<ButtonColor, ButtonColor>> = {\n\t\thashicorp: 'primary',\n\t\tsecondary: 'secondary-white',\n\t}\n\n\tconst customClass =\n\t\tlegacyColor === 'custom'\n\t\t\t? s[`color-${remappedColors[color] ?? color}`]\n\t\t\t: undefined\n\n\treturn (\n\t\t<ButtonPrimitive\n\t\t\t{...rest}\n\t\t\tcolor={legacyColor}\n\t\t\tclassName={classNames(customClass, className)}\n\t\t\tref={ref as ForwardRefExoticComponent<HTMLButtonElement>}\n\t\t/>\n\t)\n})\n\nButton.displayName = 'Button'\n"],"names":["BUTTON_SIZES","BUTTON_ICON_POSITIONS","BUTTON_COLORS","COLOR_MAP","ICON_SIZE_MAP","ButtonPrimitive","forwardRef","size","color","isFullWidth","isIconOnly","icon","iconPosition","text","href","isHrefExternal","className","locale","rest","ref","showIconOnly","iconElement","jsx","FlightIcon","Interactive","classNames","s","jsxs","Fragment","Button","legacyColor","customClass"],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ const o = "button__gOWvd", r = "text__KbKvH", c = {
2
+ button: o,
3
+ "width-full": "width-full__juTUO",
4
+ text: r,
5
+ "color-primary": "color-primary__rWbwp",
6
+ "color-secondary": "color-secondary__-5Q4d",
7
+ "color-tertiary": "color-tertiary__rw4Ww",
8
+ "color-critical": "color-critical__-8hXs",
9
+ "color-primary-white": "color-primary-white__2JDoz",
10
+ "color-primary-black": "color-primary-black__zTF4n",
11
+ "color-secondary-white": "color-secondary-white__AseI0",
12
+ "color-secondary-black": "color-secondary-black__b-umt",
13
+ "color-secondary-high-contrast": "color-secondary-high-contrast__3bxg3",
14
+ "color-boundary": "color-boundary__xJtzy",
15
+ "color-consul": "color-consul__5lFsa",
16
+ "color-nomad": "color-nomad__HGWXf",
17
+ "color-packer": "color-packer__vbRu0",
18
+ "color-terraform": "color-terraform__DQMD5",
19
+ "color-vagrant": "color-vagrant__iNokw",
20
+ "color-vault": "color-vault__Q6Qbm",
21
+ "color-waypoint": "color-waypoint__8j-Oi",
22
+ "size-small": "size-small__kT0Jp",
23
+ "icon-only": "icon-only__5c-is",
24
+ "size-medium": "size-medium__HxMcm",
25
+ "size-large": "size-large__MEpK3"
26
+ };
27
+ export {
28
+ o as button,
29
+ c as default,
30
+ r as text
31
+ };
32
+ //# sourceMappingURL=styles.module.scss.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,8 @@
1
+ const t = "thumbnail__f0mUs", a = {
2
+ thumbnail: t
3
+ };
4
+ export {
5
+ a as default,
6
+ t as thumbnail
7
+ };
8
+ //# sourceMappingURL=card-thumbnail.module.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"card-thumbnail.module.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;"}
@@ -1,2 +1,2 @@
1
- import type { CardThumbnailProps } from '../types';
1
+ import { CardThumbnailProps } from '../types';
2
2
  export declare const CardThumbnail: ({ alt, aspectRatio, src, }: CardThumbnailProps) => import("react/jsx-runtime").JSX.Element | null;
@@ -0,0 +1,23 @@
1
+ "use client";
2
+ import { jsx as e } from "react/jsx-runtime";
3
+ import { useMDSImage as l } from "../../../utils/mds-context/index.js";
4
+ import o from "./card-thumbnail.module.css.js";
5
+ const u = ({
6
+ alt: r,
7
+ aspectRatio: m,
8
+ src: t
9
+ }) => {
10
+ const i = l();
11
+ return t ? /* @__PURE__ */ e(
12
+ "div",
13
+ {
14
+ className: o.thumbnail,
15
+ style: { "--aspect-ratio": m },
16
+ children: /* @__PURE__ */ e(i, { fill: !0, alt: r, src: t })
17
+ }
18
+ ) : null;
19
+ };
20
+ export {
21
+ u as CardThumbnail
22
+ };
23
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/card/card-thumbnail/index.tsx"],"sourcesContent":["'use client'\n\nimport { useMDSImage } from '../../../utils/mds-context'\nimport type { CardThumbnailProps } from '../types'\nimport s from './card-thumbnail.module.css'\n\nexport const CardThumbnail = ({\n\talt,\n\taspectRatio,\n\tsrc,\n}: CardThumbnailProps) => {\n\tconst Image = useMDSImage()\n\treturn src ? (\n\t\t<div\n\t\t\tclassName={s.thumbnail}\n\t\t\tstyle={{ ['--aspect-ratio' as string]: aspectRatio }}\n\t\t>\n\t\t\t<Image fill alt={alt} src={src} />\n\t\t</div>\n\t) : null\n}\n"],"names":["CardThumbnail","alt","aspectRatio","src","Image","useMDSImage","jsx","s"],"mappings":";;;;AAM8B,MAC7BA,IAAA,CAAA;AAAA,EACA,KAAAC;AAAA,EACA,aAAAC;AAAA,EACD,KAAAC;AACC,MAAA;AACA,QAAAC,IAAOC,EAAA;AACN,SAACF,IAAA,gBAAAG;AAAA,IAAA;AAAA,IAAA;AAAA,MAEA,WAAUC,EAAA;AAAA,MAEV,OAAA,EAAA,kBAAAL,EAAO;AAAA,MAAyB,UAAA,gBAAAI,EAAAF,GAAA,EAAA,MAAA,IAAA,KAAAH,GAAA,KAAAE,EAAA,CAAA;AAAA;EAGnC,IAAA;;"}
@@ -1,3 +1,4 @@
1
- import type { CardProps } from './types';
2
- declare const Card: import("react").ForwardRefExoticComponent<CardProps & import("react").RefAttributes<HTMLDivElement>>;
1
+ import { CardContentProps, CardProps } from './types';
2
+ declare const Card: import('react').ForwardRefExoticComponent<CardProps & import('react').RefAttributes<HTMLDivElement>>;
3
+ export declare const CardContent: ({ badges, description, eyebrow, heading, thumbnail, subheading, cta, children, showArrow, }: CardContentProps) => import("react/jsx-runtime").JSX.Element;
3
4
  export { Card };
@@ -0,0 +1,160 @@
1
+ "use client";
2
+ import { jsxs as d, jsx as a, Fragment as v } from "react/jsx-runtime";
3
+ import { forwardRef as x } from "react";
4
+ import { CardThumbnail as k } from "./card-thumbnail/index.js";
5
+ import { useMDSLink as A } from "../../utils/mds-context/index.js";
6
+ import { Text as c } from "../text/index.js";
7
+ import f from "classnames";
8
+ import { Badge as E } from "../badge/index.js";
9
+ import { StandaloneLink as g } from "../standalone-link/index.js";
10
+ import { IconArrowRight24 as L } from "@hashicorp/flight-icons/svg-react/arrow-right-24";
11
+ import e from "./styles.module.css.js";
12
+ const h = x(
13
+ ({
14
+ children: r,
15
+ className: o,
16
+ content: i,
17
+ ctaLabel: t,
18
+ href: n,
19
+ standaloneLink: l,
20
+ isExternal: s,
21
+ onClickCapture: m,
22
+ "aria-label": p
23
+ }, b) => {
24
+ const w = A(), u = n && !t, N = s ? { target: "_blank", rel: "noopener noreferrer" } : {};
25
+ return /* @__PURE__ */ d(
26
+ "div",
27
+ {
28
+ ref: b,
29
+ className: f(
30
+ e.card,
31
+ { [e.interactive]: u },
32
+ o
33
+ ),
34
+ children: [
35
+ u && /* @__PURE__ */ a(
36
+ w,
37
+ {
38
+ href: n,
39
+ className: e.link,
40
+ draggable: "false",
41
+ onClickCapture: m,
42
+ "aria-label": p,
43
+ ...N
44
+ }
45
+ ),
46
+ i && /* @__PURE__ */ a(
47
+ P,
48
+ {
49
+ badges: i.badges,
50
+ description: i.description,
51
+ eyebrow: i.eyebrow,
52
+ heading: i.heading,
53
+ subheading: i.subheading,
54
+ thumbnail: i.thumbnail,
55
+ showArrow: i.showArrow && !!u,
56
+ cta: {
57
+ ctaLabel: t,
58
+ href: n,
59
+ standaloneLink: l,
60
+ onClickCapture: m,
61
+ isExternal: s
62
+ }
63
+ }
64
+ ),
65
+ r,
66
+ r && /* @__PURE__ */ a(
67
+ y,
68
+ {
69
+ ctaLabel: t,
70
+ href: n,
71
+ standaloneLink: l,
72
+ onClickCapture: m,
73
+ isExternal: s
74
+ }
75
+ )
76
+ ]
77
+ }
78
+ );
79
+ }
80
+ );
81
+ h.displayName = "Card";
82
+ const P = ({
83
+ badges: r,
84
+ description: o,
85
+ eyebrow: i,
86
+ heading: t,
87
+ thumbnail: n,
88
+ subheading: l,
89
+ cta: s,
90
+ children: m,
91
+ showArrow: p
92
+ }) => /* @__PURE__ */ d("div", { className: f(e.content, { [e["has-thumbnail"]]: n }), children: [
93
+ n && /* @__PURE__ */ a(k, { ...n }),
94
+ /* @__PURE__ */ d("div", { className: e.contentLockup, children: [
95
+ /* @__PURE__ */ a(B, { children: i }),
96
+ /* @__PURE__ */ a(z, { children: t }),
97
+ /* @__PURE__ */ a(D, { children: l }),
98
+ /* @__PURE__ */ a(T, { children: o }),
99
+ /* @__PURE__ */ a(j, { badges: r }),
100
+ s && /* @__PURE__ */ a(
101
+ y,
102
+ {
103
+ ctaLabel: s.ctaLabel,
104
+ href: s.href,
105
+ standaloneLink: s.standaloneLink,
106
+ isExternal: s.isExternal,
107
+ onClickCapture: s.onClickCapture
108
+ }
109
+ ),
110
+ p ? /* @__PURE__ */ a("div", { className: e.arrow, children: /* @__PURE__ */ a(L, {}) }) : null,
111
+ m
112
+ ] })
113
+ ] }), y = ({
114
+ href: r,
115
+ ctaLabel: o,
116
+ standaloneLink: i,
117
+ isExternal: t,
118
+ onClickCapture: n
119
+ }) => {
120
+ const l = r && !o;
121
+ if (i) {
122
+ const s = {
123
+ ...i,
124
+ icon: i.icon || "chevron-right",
125
+ iconPosition: i.iconPosition || "trailing"
126
+ };
127
+ return /* @__PURE__ */ a(g, { className: e.cta, ...s });
128
+ }
129
+ return r && !l && o ? /* @__PURE__ */ a(
130
+ g,
131
+ {
132
+ className: e.cta,
133
+ text: o,
134
+ href: r,
135
+ icon: "chevron-right",
136
+ iconPosition: "trailing",
137
+ color: "secondary",
138
+ onClickCapture: n,
139
+ isHrefExternal: t
140
+ }
141
+ ) : null;
142
+ }, B = ({ children: r }) => r ? Array.isArray(r) ? /* @__PURE__ */ a(S, { items: Array.from(r) }) : /* @__PURE__ */ a(C, { children: r }) : null, S = ({ items: r }) => /* @__PURE__ */ a("ul", { className: e.meta, children: r.map((o, i) => /* @__PURE__ */ d("li", { children: [
143
+ /* @__PURE__ */ a(C, { children: o }),
144
+ i < r.length - 1 ? /* @__PURE__ */ a("span", { className: e.metaSeparator, "aria-hidden": !0, children: "|" }) : null
145
+ ] }, o)) }), C = ({ children: r }) => r ? /* @__PURE__ */ a(c.Label, { color: "faint", weight: "medium", children: r }) : null, z = ({ children: r }) => r ? /* @__PURE__ */ a(
146
+ c.DisplayExpressive,
147
+ {
148
+ tag: "span",
149
+ size: "200",
150
+ weight: "semibold",
151
+ color: "strong",
152
+ children: r
153
+ }
154
+ ) : null, D = ({ children: r }) => r ? /* @__PURE__ */ a(c.Body, { tag: "span", size: "200", className: e.subheading, color: "primary", children: r }) : null, T = ({ children: r }) => r ? typeof r == "string" ? /* @__PURE__ */ a(c.Body, { tag: "span", size: "200", color: "primary", children: r }) : /* @__PURE__ */ a(v, { children: r }) : null, j = ({ badges: r }) => r && r.length > 0 ? /* @__PURE__ */ a("div", { className: e.badges, children: r.map((o) => /* @__PURE__ */ a(E, { ...o }, o.text)) }) : null;
155
+ h.displayName = "Card";
156
+ export {
157
+ h as Card,
158
+ P as CardContent
159
+ };
160
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../src/components/card/index.tsx"],"sourcesContent":["'use client'\n\nimport { forwardRef, type PropsWithChildren } from 'react'\nimport type { CardContentProps, CardProps, CardCtaProps } from './types'\nimport { CardThumbnail } from './card-thumbnail'\nimport { useMDSLink } from '../../utils/mds-context'\nimport { Text } from '../text'\nimport classNames from 'classnames'\nimport { Badge } from '../badge'\nimport { StandaloneLink } from '../standalone-link'\nimport { IconArrowRight24 } from '@hashicorp/flight-icons/svg-react/arrow-right-24'\nimport s from './styles.module.css'\n\nconst Card = forwardRef<HTMLDivElement, CardProps>(\n\t(\n\t\t{\n\t\t\tchildren,\n\t\t\tclassName,\n\t\t\tcontent,\n\t\t\tctaLabel,\n\t\t\thref,\n\t\t\tstandaloneLink,\n\t\t\tisExternal,\n\t\t\tonClickCapture,\n\t\t\t'aria-label': ariaLabel,\n\t\t},\n\t\tref\n\t) => {\n\t\tconst Link = useMDSLink()\n\n\t\tconst isCardLink = href && !ctaLabel\n\n\t\tconst linkProps = isExternal\n\t\t\t? { target: '_blank', rel: 'noopener noreferrer' }\n\t\t\t: {}\n\n\t\treturn (\n\t\t\t<div\n\t\t\t\tref={ref}\n\t\t\t\tclassName={classNames(\n\t\t\t\t\ts.card,\n\t\t\t\t\t{ [s.interactive]: isCardLink },\n\t\t\t\t\tclassName\n\t\t\t\t)}\n\t\t\t>\n\t\t\t\t{isCardLink && (\n\t\t\t\t\t<Link\n\t\t\t\t\t\thref={href}\n\t\t\t\t\t\tclassName={s.link}\n\t\t\t\t\t\tdraggable=\"false\"\n\t\t\t\t\t\tonClickCapture={onClickCapture}\n\t\t\t\t\t\taria-label={ariaLabel}\n\t\t\t\t\t\t{...linkProps}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t\t{content && (\n\t\t\t\t\t<CardContent\n\t\t\t\t\t\tbadges={content.badges}\n\t\t\t\t\t\tdescription={content.description}\n\t\t\t\t\t\teyebrow={content.eyebrow}\n\t\t\t\t\t\theading={content.heading}\n\t\t\t\t\t\tsubheading={content.subheading}\n\t\t\t\t\t\tthumbnail={content.thumbnail}\n\t\t\t\t\t\tshowArrow={content.showArrow && !!isCardLink}\n\t\t\t\t\t\tcta={{\n\t\t\t\t\t\t\tctaLabel,\n\t\t\t\t\t\t\thref,\n\t\t\t\t\t\t\tstandaloneLink,\n\t\t\t\t\t\t\tonClickCapture,\n\t\t\t\t\t\t\tisExternal,\n\t\t\t\t\t\t}}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t\t{children}\n\t\t\t\t{children && (\n\t\t\t\t\t<CardCta\n\t\t\t\t\t\tctaLabel={ctaLabel}\n\t\t\t\t\t\thref={href}\n\t\t\t\t\t\tstandaloneLink={standaloneLink}\n\t\t\t\t\t\tonClickCapture={onClickCapture}\n\t\t\t\t\t\tisExternal={isExternal}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t)\n\t}\n)\n\nCard.displayName = 'Card'\n\nexport const CardContent = ({\n\tbadges,\n\tdescription,\n\teyebrow,\n\theading,\n\tthumbnail,\n\tsubheading,\n\tcta,\n\tchildren,\n\tshowArrow,\n}: CardContentProps) => {\n\treturn (\n\t\t<div className={classNames(s.content, { [s['has-thumbnail']]: thumbnail })}>\n\t\t\t{thumbnail && <CardThumbnail {...thumbnail} />}\n\t\t\t<div className={s.contentLockup}>\n\t\t\t\t<CardEyebrow>{eyebrow}</CardEyebrow>\n\t\t\t\t<CardHeading>{heading}</CardHeading>\n\t\t\t\t<CardSubheading>{subheading}</CardSubheading>\n\t\t\t\t<CardDescription>{description}</CardDescription>\n\t\t\t\t<Badges badges={badges} />\n\t\t\t\t{cta && (\n\t\t\t\t\t<CardCta\n\t\t\t\t\t\tctaLabel={cta.ctaLabel}\n\t\t\t\t\t\thref={cta.href}\n\t\t\t\t\t\tstandaloneLink={cta.standaloneLink}\n\t\t\t\t\t\tisExternal={cta.isExternal}\n\t\t\t\t\t\tonClickCapture={cta.onClickCapture}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t\t{showArrow ? (\n\t\t\t\t\t<div className={s.arrow}>\n\t\t\t\t\t\t<IconArrowRight24 />\n\t\t\t\t\t</div>\n\t\t\t\t) : null}\n\t\t\t\t{children}\n\t\t\t</div>\n\t\t</div>\n\t)\n}\n\nconst CardCta = ({\n\thref,\n\tctaLabel,\n\tstandaloneLink,\n\tisExternal,\n\tonClickCapture,\n}: CardCtaProps) => {\n\tconst isCardLink = href && !ctaLabel\n\n\tif (standaloneLink) {\n\t\tconst standaloneLinkProps = {\n\t\t\t...standaloneLink,\n\t\t\ticon: standaloneLink.icon || 'chevron-right',\n\t\t\ticonPosition: standaloneLink.iconPosition || 'trailing',\n\t\t}\n\n\t\treturn <StandaloneLink className={s.cta} {...standaloneLinkProps} />\n\t}\n\n\tif (href && !isCardLink && ctaLabel) {\n\t\treturn (\n\t\t\t<StandaloneLink\n\t\t\t\tclassName={s.cta}\n\t\t\t\ttext={ctaLabel}\n\t\t\t\thref={href}\n\t\t\t\ticon=\"chevron-right\"\n\t\t\t\ticonPosition=\"trailing\"\n\t\t\t\tcolor=\"secondary\"\n\t\t\t\tonClickCapture={onClickCapture}\n\t\t\t\tisHrefExternal={isExternal}\n\t\t\t/>\n\t\t)\n\t}\n\n\treturn null\n}\n\nconst CardEyebrow = ({ children }: PropsWithChildren) => {\n\tif (!children) {\n\t\treturn null\n\t}\n\n\tif (Array.isArray(children)) {\n\t\treturn <CardEyebrowList items={Array.from(children)} />\n\t}\n\n\treturn <CardEyebrowText>{children}</CardEyebrowText>\n}\n\nconst CardEyebrowList = ({ items }: { items: string[] }) => (\n\t<ul className={s.meta}>\n\t\t{items.map((item, idx) => (\n\t\t\t<li key={item}>\n\t\t\t\t<CardEyebrowText>{item}</CardEyebrowText>\n\t\t\t\t{idx < items.length - 1 ? (\n\t\t\t\t\t<span className={s.metaSeparator} aria-hidden={true}>\n\t\t\t\t\t\t|\n\t\t\t\t\t</span>\n\t\t\t\t) : null}\n\t\t\t</li>\n\t\t))}\n\t</ul>\n)\n\nconst CardEyebrowText = ({ children }: PropsWithChildren) =>\n\tchildren ? (\n\t\t<Text.Label color=\"faint\" weight=\"medium\">\n\t\t\t{children}\n\t\t</Text.Label>\n\t) : null\n\nconst CardHeading = ({ children }: PropsWithChildren) =>\n\tchildren ? (\n\t\t<Text.DisplayExpressive\n\t\t\ttag=\"span\"\n\t\t\tsize=\"200\"\n\t\t\tweight=\"semibold\"\n\t\t\tcolor=\"strong\"\n\t\t>\n\t\t\t{children}\n\t\t</Text.DisplayExpressive>\n\t) : null\n\nconst CardSubheading = ({ children }: PropsWithChildren) =>\n\tchildren ? (\n\t\t<Text.Body tag=\"span\" size=\"200\" className={s.subheading} color=\"primary\">\n\t\t\t{children}\n\t\t</Text.Body>\n\t) : null\n\nconst CardDescription = ({ children }: PropsWithChildren) => {\n\tif (!children) {\n\t\treturn null\n\t}\n\n\tif (typeof children === 'string') {\n\t\treturn (\n\t\t\t<Text.Body tag=\"span\" size=\"200\" color=\"primary\">\n\t\t\t\t{children}\n\t\t\t</Text.Body>\n\t\t)\n\t}\n\n\treturn <>{children}</>\n}\n\nconst Badges = ({ badges }: { badges: CardContentProps['badges'] }) =>\n\tbadges && badges.length > 0 ? (\n\t\t<div className={s.badges}>\n\t\t\t{badges.map((badge) => (\n\t\t\t\t<Badge key={badge.text} {...badge} />\n\t\t\t))}\n\t\t</div>\n\t) : null\n\nCard.displayName = 'Card'\nexport { Card }\n"],"names":["Card","forwardRef","children","className","content","ctaLabel","href","standaloneLink","isExternal","onClickCapture","ariaLabel","ref","Link","useMDSLink","isCardLink","jsxs","classNames","s","jsx","linkProps","CardContent","CardCta","badges","description","eyebrow","heading","thumbnail","subheading","cta","showArrow","CardThumbnail","CardEyebrow","CardHeading","CardSubheading","CardDescription","IconArrowRight24","standaloneLinkProps","StandaloneLink","CardEyebrowList","CardEyebrowText","items","item","idx","Text","Fragment","Badges","badge","Badge"],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ const t = "card__HomZw", a = "interactive__Irpce", n = "arrow__qnBL7", c = "link__Dz3Nf", e = "cta__UfNG2", o = "content__SiycH", _ = "subheading__MM0J8", s = "contentLockup__08EYi", r = "badges__GrCpe", i = "meta__8eKyE", d = "metaSeparator__44API", m = {
2
+ card: t,
3
+ interactive: a,
4
+ arrow: n,
5
+ link: c,
6
+ cta: e,
7
+ content: o,
8
+ "has-thumbnail": "has-thumbnail__ftF14",
9
+ subheading: _,
10
+ contentLockup: s,
11
+ badges: r,
12
+ meta: i,
13
+ metaSeparator: d
14
+ };
15
+ export {
16
+ n as arrow,
17
+ r as badges,
18
+ t as card,
19
+ o as content,
20
+ s as contentLockup,
21
+ e as cta,
22
+ m as default,
23
+ a as interactive,
24
+ c as link,
25
+ i as meta,
26
+ d as metaSeparator,
27
+ _ as subheading
28
+ };
29
+ //# sourceMappingURL=styles.module.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.module.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;"}
@@ -1,6 +1,6 @@
1
- import type { BadgeProps } from '../badge';
2
- import type { ReactNode } from 'react';
3
- import type { StandaloneLinkProps } from '../standalone-link';
1
+ import { BadgeProps } from '../badge';
2
+ import { ReactNode } from 'react';
3
+ import { StandaloneLinkProps } from '../standalone-link';
4
4
  interface CardPropsBase {
5
5
  className?: string;
6
6
  ctaLabel?: string;
@@ -41,6 +41,7 @@ export interface CardContentProps {
41
41
  description?: React.ReactNode;
42
42
  thumbnail?: CardThumbnailProps;
43
43
  showArrow?: boolean;
44
+ children?: React.ReactNode;
44
45
  }
45
46
  export interface CardCtaProps {
46
47
  href?: string;
@@ -0,0 +1,34 @@
1
+ const e = "dark__aBMo7", n = "token__aGMSy", t = "title__nX-Ny", i = "description__-44hG", _ = "header__42Fek", a = "body__pLFmP", l = "code__J06se", o = {
2
+ "code-block": "code-block__dOm6M",
3
+ "line-highlight": "line-highlight__a84m6",
4
+ dark: e,
5
+ "language-css": "language-css__8iYaN",
6
+ token: n,
7
+ "language-javascript": "language-javascript__EWK5u",
8
+ "language-markup": "language-markup__E7NSA",
9
+ "language-html": "language-html__rLwMK",
10
+ "is-standalone": "is-standalone__WLWxy",
11
+ title: t,
12
+ description: i,
13
+ header: _,
14
+ body: a,
15
+ code: l,
16
+ "copy-button": "copy-button__nMsTD",
17
+ "line-highlight-first": "line-highlight-first__OMDUP",
18
+ "line-highlight-last": "line-highlight-last__qC6nm",
19
+ "line-numbers": "line-numbers__a9m-I",
20
+ "line-numbers-rows": "line-numbers-rows__MjGTO",
21
+ "line-of-code": "line-of-code__mDztA",
22
+ "line-number": "line-number__-g7V-"
23
+ };
24
+ export {
25
+ a as body,
26
+ l as code,
27
+ e as dark,
28
+ o as default,
29
+ i as description,
30
+ _ as header,
31
+ t as title,
32
+ n as token
33
+ };
34
+ //# sourceMappingURL=code-block.module.scss.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"code-block.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;"}