@brightspot/ui 1.11.0 → 3.0.0

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 (244) hide show
  1. package/dist/components/action-bar/ActionBar.d.ts +1 -1
  2. package/dist/components/action-bar/ActionBar.js +7 -7
  3. package/dist/components/action-bar/ActionBar.js.map +1 -1
  4. package/dist/components/action-bar/ActionItem.d.ts +5 -5
  5. package/dist/components/action-bar/ActionItem.d.ts.map +1 -1
  6. package/dist/components/action-bar/ActionItem.js +13 -13
  7. package/dist/components/action-bar/ActionItem.js.map +1 -1
  8. package/dist/components/avatar/AvatarGroup.d.ts +3 -0
  9. package/dist/components/avatar/AvatarGroup.d.ts.map +1 -1
  10. package/dist/components/avatar/AvatarGroup.js +3 -0
  11. package/dist/components/avatar/AvatarGroup.js.map +1 -1
  12. package/dist/components/badge/Badge.d.ts +3 -1
  13. package/dist/components/badge/Badge.d.ts.map +1 -1
  14. package/dist/components/badge/Badge.js +2 -0
  15. package/dist/components/badge/Badge.js.map +1 -1
  16. package/dist/components/button-group/ButtonGroup.d.ts +138 -0
  17. package/dist/components/button-group/ButtonGroup.d.ts.map +1 -0
  18. package/dist/components/button-group/ButtonGroup.js +436 -0
  19. package/dist/components/button-group/ButtonGroup.js.map +1 -0
  20. package/dist/components/checkbox/Checkbox.d.ts +107 -0
  21. package/dist/components/checkbox/Checkbox.d.ts.map +1 -0
  22. package/dist/components/checkbox/Checkbox.js +224 -0
  23. package/dist/components/checkbox/Checkbox.js.map +1 -0
  24. package/dist/components/circular-progress/CircularProgress.d.ts +2 -2
  25. package/dist/components/circular-progress/CircularProgress.js +2 -2
  26. package/dist/components/copy-to-clipboard/CopyToClipboard.d.ts +7 -2
  27. package/dist/components/copy-to-clipboard/CopyToClipboard.d.ts.map +1 -1
  28. package/dist/components/copy-to-clipboard/CopyToClipboard.js +10 -5
  29. package/dist/components/copy-to-clipboard/CopyToClipboard.js.map +1 -1
  30. package/dist/components/dropdown/Dropdown.d.ts +5 -5
  31. package/dist/components/dropdown/Dropdown.d.ts.map +1 -1
  32. package/dist/components/dropdown/Dropdown.js +11 -16
  33. package/dist/components/dropdown/Dropdown.js.map +1 -1
  34. package/dist/components/dropdown/DropdownItem.d.ts +14 -6
  35. package/dist/components/dropdown/DropdownItem.d.ts.map +1 -1
  36. package/dist/components/dropdown/DropdownItem.js +21 -15
  37. package/dist/components/dropdown/DropdownItem.js.map +1 -1
  38. package/dist/components/dropdown/DropdownMenu.d.ts +4 -4
  39. package/dist/components/dropdown/DropdownMenu.d.ts.map +1 -1
  40. package/dist/components/dropdown/DropdownMenu.js +6 -6
  41. package/dist/components/dropdown/DropdownMenu.js.map +1 -1
  42. package/dist/components/empty-state/EmptyState.css +4 -0
  43. package/dist/components/empty-state/EmptyState.d.ts +103 -0
  44. package/dist/components/empty-state/EmptyState.d.ts.map +1 -0
  45. package/dist/components/empty-state/EmptyState.js +209 -0
  46. package/dist/components/empty-state/EmptyState.js.map +1 -0
  47. package/dist/components/icon/Icon.d.ts +23 -10
  48. package/dist/components/icon/Icon.d.ts.map +1 -1
  49. package/dist/components/icon/Icon.js +40 -9
  50. package/dist/components/icon/Icon.js.map +1 -1
  51. package/dist/components/icon-button/IconButton.d.ts +7 -21
  52. package/dist/components/icon-button/IconButton.d.ts.map +1 -1
  53. package/dist/components/icon-button/IconButton.js +12 -18
  54. package/dist/components/icon-button/IconButton.js.map +1 -1
  55. package/dist/components/linear-progress/LinearProgress.d.ts +2 -2
  56. package/dist/components/linear-progress/LinearProgress.js +2 -2
  57. package/dist/components/pagination/Pagination.js +10 -10
  58. package/dist/components/popover/Popover.d.ts +6 -0
  59. package/dist/components/popover/Popover.d.ts.map +1 -1
  60. package/dist/components/popover/Popover.js +6 -0
  61. package/dist/components/popover/Popover.js.map +1 -1
  62. package/dist/components/switch/Switch.d.ts +5 -1
  63. package/dist/components/switch/Switch.d.ts.map +1 -1
  64. package/dist/components/switch/Switch.js +10 -6
  65. package/dist/components/switch/Switch.js.map +1 -1
  66. package/dist/components/tabs/Tab.d.ts +4 -4
  67. package/dist/components/tabs/Tab.d.ts.map +1 -1
  68. package/dist/components/tabs/Tab.js +5 -5
  69. package/dist/components/tabs/Tab.js.map +1 -1
  70. package/dist/components/tabs/Tabs.d.ts +3 -3
  71. package/dist/components/tabs/Tabs.d.ts.map +1 -1
  72. package/dist/components/tabs/Tabs.js +20 -20
  73. package/dist/components/tabs/Tabs.js.map +1 -1
  74. package/dist/components/upload/Upload.d.ts +157 -0
  75. package/dist/components/upload/Upload.d.ts.map +1 -0
  76. package/dist/components/upload/Upload.js +538 -0
  77. package/dist/components/upload/Upload.js.map +1 -0
  78. package/dist/components/upload/UploadItem.d.ts +73 -0
  79. package/dist/components/upload/UploadItem.d.ts.map +1 -0
  80. package/dist/components/upload/UploadItem.js +180 -0
  81. package/dist/components/upload/UploadItem.js.map +1 -0
  82. package/dist/components/widget/Widget.d.ts +1 -6
  83. package/dist/components/widget/Widget.d.ts.map +1 -1
  84. package/dist/components/widget/Widget.js +1 -6
  85. package/dist/components/widget/Widget.js.map +1 -1
  86. package/dist/custom-elements.json +7499 -2087
  87. package/dist/storybook/assets/{ActionBar.stories--nAeDC-G.js → ActionBar.stories-DRIVI-W2.js} +65 -65
  88. package/dist/storybook/assets/{ActionItem.stories-BHrGjk-P.js → ActionItem.stories-5qlgxYNB.js} +41 -41
  89. package/dist/storybook/assets/{Avatar.stories-Da-mRj6_.js → Avatar.stories-B3VkhRhP.js} +2 -2
  90. package/dist/storybook/assets/{AvatarGroup.stories-BQlaC_yl.js → AvatarGroup.stories-DOfim2NY.js} +5 -5
  91. package/dist/storybook/assets/{Badge.stories-DnVnOrnF.js → Badge.stories-B04VNAcc.js} +2 -2
  92. package/dist/storybook/assets/{Button-CFLAI1H9.js → Button-CILTcGRT.js} +1 -1
  93. package/dist/storybook/assets/{Button.stories-DxaBOjwv.js → Button.stories-CzWAltrX.js} +1 -1
  94. package/dist/storybook/assets/ButtonGroup.stories-1uAJf79o.js +588 -0
  95. package/dist/storybook/assets/{Celebrate.stories-CuMm15Nr.js → Celebrate.stories-BEqj0VnW.js} +7 -7
  96. package/dist/storybook/assets/Checkbox.stories-DXAGFS0M.js +141 -0
  97. package/dist/storybook/assets/{CircularProgress.stories-DRN8Mtvj.js → CircularProgress.stories-D4rftw22.js} +7 -7
  98. package/dist/storybook/assets/{ClipboardMixin.stories-DR7Ou2Av.js → ClipboardMixin.stories-z2n2HWt1.js} +31 -28
  99. package/dist/storybook/assets/{Color-6BZIO3FS-Die62Y0Z.js → Color-6BZIO3FS-C6KyMgZz.js} +1 -1
  100. package/dist/storybook/assets/{Colors.stories-bIq_ssbI.js → Colors.stories-CX-Ny3B_.js} +1 -1
  101. package/dist/storybook/assets/{CombinedEffects.stories-CtKzOUZn.js → CombinedEffects.stories-BkqtiVHp.js} +33 -33
  102. package/dist/storybook/assets/{ComponentStatesMixin-DMLCk9fE.js → ComponentStatesMixin-DLd0feFg.js} +1 -1
  103. package/dist/storybook/assets/{ComponentStatesMixin.stories-D8UI9o-d.js → ComponentStatesMixin.stories-D6Yc5Jgl.js} +3 -3
  104. package/dist/storybook/assets/{CopyToClipboard.stories-ti6CpJNp.js → CopyToClipboard.stories-B-omwDDJ.js} +16 -16
  105. package/dist/storybook/assets/{Debounce.stories-DzZUSvbk.js → Debounce.stories-B2vE5QIx.js} +9 -9
  106. package/dist/storybook/assets/{DocsRenderer-LL677BLK-CIRGv5IX.js → DocsRenderer-LL677BLK-DNUlRvMg.js} +3 -3
  107. package/dist/storybook/assets/{Dropdown.stories-Lt4cY0Re.js → Dropdown.stories-_bx4WDLr.js} +60 -60
  108. package/dist/storybook/assets/EmptyState.stories-CGMbmo77.js +318 -0
  109. package/dist/storybook/assets/{Events.stories-B1ddcgpT.js → Events.stories-CkQYKcoZ.js} +1 -1
  110. package/dist/storybook/assets/{Heading.stories-DI4w61cf.js → Heading.stories-BU5Do_od.js} +1 -1
  111. package/dist/storybook/assets/{HueRipple.stories-DjhoxxEw.js → HueRipple.stories-Di2zmxo3.js} +11 -11
  112. package/dist/storybook/assets/Icon.stories-Dk4ZXhhJ.js +441 -0
  113. package/dist/storybook/assets/{IconButton.stories-KjN28hfc.js → IconButton.stories-BSCiXPXa.js} +126 -146
  114. package/dist/storybook/assets/{LinearProgress.stories-DcIpdz6R.js → LinearProgress.stories-BGxPZuni.js} +7 -7
  115. package/dist/storybook/assets/{Pagination.stories-BBkLEwoP.js → Pagination.stories-z3Zq8b4f.js} +6 -6
  116. package/dist/storybook/assets/{Popover.stories-DLv48c2h.js → Popover.stories-C9GxWcax.js} +33 -62
  117. package/dist/storybook/assets/ReadyMixin-CQw8N6P9.js +1 -0
  118. package/dist/storybook/assets/{RovingTabindexMixin.stories-BWaFx9mu.js → RovingTabindexMixin.stories-ByxLBi6m.js} +6 -6
  119. package/dist/storybook/assets/{Rtc.stories-Ve7Bwo_l.js → Rtc.stories-DQJlCXWR.js} +3 -3
  120. package/dist/storybook/assets/{ScrollShadow.stories-C6XmrRLm.js → ScrollShadow.stories-gjTIAbUA.js} +2 -2
  121. package/dist/storybook/assets/{Switch.stories-Cf8WM1LG.js → Switch.stories-BEeqPZiP.js} +21 -21
  122. package/dist/storybook/assets/{Tab.stories-CEtdEtOx.js → Tab.stories-DpB3I-WZ.js} +33 -33
  123. package/dist/storybook/assets/{Tabs.stories-CIAO1bPO.js → Tabs.stories-C6mG6Xi7.js} +2 -2
  124. package/dist/storybook/assets/{Throttle.stories-BqxVIb-r.js → Throttle.stories-x9tpGeQh.js} +10 -10
  125. package/dist/storybook/assets/{Tooltip.stories-B6fw6875.js → Tooltip.stories-CqcLqdmc.js} +2 -2
  126. package/dist/storybook/assets/Upload.stories-CMaAbCSH.js +447 -0
  127. package/dist/storybook/assets/UploadItem.stories-GB98L3JQ.js +167 -0
  128. package/dist/storybook/assets/{Welcome.stories-CfJtSM19.js → Welcome.stories-6h9cUZ7v.js} +1 -1
  129. package/dist/storybook/assets/{Widget.stories-CiOho7lO.js → Widget.stories-DiA1PR6Y.js} +13 -13
  130. package/dist/storybook/assets/{WithTooltip-65CFNBJE-PGcopp73.js → WithTooltip-65CFNBJE-DTsHhBb_.js} +1 -1
  131. package/dist/storybook/assets/{blocks-dP2DwISI.js → blocks-IXdn9TGW.js} +5 -5
  132. package/dist/storybook/assets/{formatter-EIJCOSYU-CZSAC3tg.js → formatter-EIJCOSYU-Cum4J6N4.js} +1 -1
  133. package/dist/storybook/assets/if-defined-CgfCxQoV.js +1 -0
  134. package/dist/storybook/assets/iframe-BgFj0b5u.css +1 -0
  135. package/dist/storybook/assets/{iframe-DloIUNZz.js → iframe-Sf9RHZFu.js} +191 -191
  136. package/dist/storybook/assets/{index-DKF0ypu5.js → index-D605PvQH.js} +1 -1
  137. package/dist/storybook/assets/{onFind-C0l4Gew0.js → onFind-C41m8c_a.js} +1 -1
  138. package/dist/storybook/assets/{onFind.stories-DOTt9puO.js → onFind.stories-MOTfGlJd.js} +53 -77
  139. package/dist/storybook/assets/{onRemove.stories-CQ9ZC5dm.js → onRemove.stories-DX58Bf6f.js} +6 -10
  140. package/dist/storybook/assets/{onVisible.stories-Cbj5_Vz0.js → onVisible.stories-NNFeFeD8.js} +3 -3
  141. package/dist/storybook/assets/{style-map-DLXysq3r.js → style-map-B99QiqCo.js} +1 -1
  142. package/dist/storybook/assets/{syntaxhighlighter-ED5Y7EFY-Bjjbl9ca.js → syntaxhighlighter-ED5Y7EFY-BqQ-o9mS.js} +1 -1
  143. package/dist/storybook/box-illustration.svg +51 -0
  144. package/dist/storybook/cloud-illustration.svg +49 -0
  145. package/dist/storybook/docs-illustration.svg +92 -0
  146. package/dist/storybook/iframe.html +2 -2
  147. package/dist/storybook/index.json +1 -1
  148. package/dist/storybook/project.json +1 -1
  149. package/dist/tailwind-plugin-badge.js +1 -1
  150. package/dist/tailwind-plugin-badge.ts +1 -1
  151. package/dist/tailwind-plugin-button-group.d.ts +2 -0
  152. package/dist/tailwind-plugin-button-group.d.ts.map +1 -0
  153. package/dist/tailwind-plugin-button-group.js +215 -0
  154. package/dist/tailwind-plugin-button-group.js.map +1 -0
  155. package/dist/tailwind-plugin-button-group.ts +238 -0
  156. package/dist/tailwind-plugin-button.js +1 -1
  157. package/dist/tailwind-plugin-button.ts +1 -1
  158. package/dist/tailwind-plugin-checkbox.d.ts +2 -0
  159. package/dist/tailwind-plugin-checkbox.d.ts.map +1 -0
  160. package/dist/tailwind-plugin-checkbox.js +246 -0
  161. package/dist/tailwind-plugin-checkbox.js.map +1 -0
  162. package/dist/tailwind-plugin-checkbox.ts +281 -0
  163. package/dist/tailwind-plugin-empty-state.d.ts +2 -0
  164. package/dist/tailwind-plugin-empty-state.d.ts.map +1 -0
  165. package/dist/tailwind-plugin-empty-state.js +113 -0
  166. package/dist/tailwind-plugin-empty-state.js.map +1 -0
  167. package/dist/tailwind-plugin-empty-state.ts +124 -0
  168. package/dist/tailwind-plugin-icon.js +122 -18
  169. package/dist/tailwind-plugin-icon.js.map +1 -1
  170. package/dist/tailwind-plugin-icon.ts +131 -18
  171. package/dist/tailwind-plugin-loader.js +3 -3
  172. package/dist/tailwind-plugin-loader.ts +3 -3
  173. package/dist/tailwind-plugin-tabs.js +7 -0
  174. package/dist/tailwind-plugin-tabs.js.map +1 -1
  175. package/dist/tailwind-plugin-tabs.ts +7 -0
  176. package/dist/tailwind-plugin-upload.d.ts +2 -0
  177. package/dist/tailwind-plugin-upload.d.ts.map +1 -0
  178. package/dist/tailwind-plugin-upload.js +322 -0
  179. package/dist/tailwind-plugin-upload.js.map +1 -0
  180. package/dist/tailwind-plugin-upload.ts +362 -0
  181. package/dist/tailwind.config.d.ts.map +1 -1
  182. package/dist/tailwind.config.js +1 -0
  183. package/dist/tailwind.config.js.map +1 -1
  184. package/dist/tailwind.config.ts +1 -0
  185. package/dist/util/ClipboardMixin.d.ts +7 -2
  186. package/dist/util/ClipboardMixin.d.ts.map +1 -1
  187. package/dist/util/ClipboardMixin.js +15 -13
  188. package/dist/util/ClipboardMixin.js.map +1 -1
  189. package/dist/util/ComponentStatesMixin.d.ts +2 -1
  190. package/dist/util/ComponentStatesMixin.d.ts.map +1 -1
  191. package/dist/util/ComponentStatesMixin.js +4 -0
  192. package/dist/util/ComponentStatesMixin.js.map +1 -1
  193. package/dist/util/EventEmitterMixin.d.ts +42 -4
  194. package/dist/util/EventEmitterMixin.d.ts.map +1 -1
  195. package/dist/util/EventEmitterMixin.js +5 -2
  196. package/dist/util/EventEmitterMixin.js.map +1 -1
  197. package/dist/util/ProgressMixin.d.ts +9 -2
  198. package/dist/util/ProgressMixin.d.ts.map +1 -1
  199. package/dist/util/ProgressMixin.js +22 -18
  200. package/dist/util/ProgressMixin.js.map +1 -1
  201. package/dist/util/RovingTabindexMixin.d.ts +8 -0
  202. package/dist/util/RovingTabindexMixin.d.ts.map +1 -1
  203. package/dist/util/RovingTabindexMixin.js +8 -8
  204. package/dist/util/RovingTabindexMixin.js.map +1 -1
  205. package/dist/util/TetherLayout.d.ts.map +1 -1
  206. package/dist/util/TetherLayout.js +3 -0
  207. package/dist/util/TetherLayout.js.map +1 -1
  208. package/dist/util/TooltipMixin.d.ts.map +1 -1
  209. package/dist/util/TooltipMixin.js +5 -4
  210. package/dist/util/TooltipMixin.js.map +1 -1
  211. package/dist/util/upload.d.ts +53 -0
  212. package/dist/util/upload.d.ts.map +1 -0
  213. package/dist/util/upload.js +113 -0
  214. package/dist/util/upload.js.map +1 -0
  215. package/docs/components/ActionBar.md +6 -0
  216. package/docs/components/ActionItem.md +52 -27
  217. package/docs/components/Avatar.md +42 -12
  218. package/docs/components/AvatarGroup.md +4 -3
  219. package/docs/components/Badge.md +13 -1
  220. package/docs/components/ButtonGroup.md +91 -0
  221. package/docs/components/Checkbox.md +91 -0
  222. package/docs/components/CircularProgress.md +41 -12
  223. package/docs/components/CopyToClipboard.md +13 -11
  224. package/docs/components/Dropdown.md +44 -19
  225. package/docs/components/DropdownItem.md +39 -26
  226. package/docs/components/DropdownMenu.md +9 -9
  227. package/docs/components/EmptyState.md +75 -0
  228. package/docs/components/Icon.md +22 -14
  229. package/docs/components/IconButton.md +46 -21
  230. package/docs/components/LinearProgress.md +43 -4
  231. package/docs/components/Pagination.md +11 -10
  232. package/docs/components/Popover.md +16 -0
  233. package/docs/components/README.md +5 -0
  234. package/docs/components/Switch.md +21 -16
  235. package/docs/components/Tab.md +8 -2
  236. package/docs/components/Tabs.md +8 -0
  237. package/docs/components/Upload.md +112 -0
  238. package/docs/components/UploadItem.md +61 -0
  239. package/docs/components/Widget.md +12 -6
  240. package/package.json +4 -2
  241. package/dist/storybook/assets/Icon.stories-CpziAhae.js +0 -264
  242. package/dist/storybook/assets/ReadyMixin-Cw2Dfbu2.js +0 -1
  243. package/dist/storybook/assets/if-defined-B1RdczOE.js +0 -1
  244. package/dist/storybook/assets/iframe-bJgLXZKK.css +0 -1
@@ -0,0 +1,124 @@
1
+ import plugin from 'tailwindcss/plugin'
2
+ declare let module: any
3
+
4
+ /**
5
+ * Empty State component for displaying placeholder content when no data is available.
6
+ *
7
+ * Class Names:
8
+ *
9
+ * btu-empty-state - Base container styles
10
+ * btu-empty-state-sm - Small size variant
11
+ * btu-empty-state-md - Medium size variant
12
+ * btu-empty-state-lg - Large size variant
13
+ * btu-empty-state-graphic - Graphic container (icon, image, picture, or svg)
14
+ * btu-empty-state-content - Content wrapper (heading + description)
15
+ * btu-empty-state-title - Heading text
16
+ * btu-empty-state-description - Description text
17
+ * btu-empty-state-actions - Actions container; applied to an internal
18
+ * btu-button-group (variant="spaced"). The button-group provides display,
19
+ * flex-flow, and gap; this class only collapses the container when empty.
20
+ *
21
+ * Example Usage:
22
+ *
23
+ * <btu-empty-state class="btu-empty-state btu-empty-state-md">
24
+ * <div class="btu-empty-state-graphic">...</div>
25
+ * <div class="btu-empty-state-content">
26
+ * <h2 class="btu-empty-state-title">No items found</h2>
27
+ * <p class="btu-empty-state-description">Try adjusting your filters.</p>
28
+ * </div>
29
+ * <btu-button-group class="btu-empty-state-actions" variant="spaced">...</btu-button-group>
30
+ * </btu-empty-state>
31
+ */
32
+
33
+ module.exports = plugin(function ({ addComponents }) {
34
+ const className = '.btu-empty-state'
35
+
36
+ // Graphic sizes per variant (img/svg/picture). btu-icon children are sized by the
37
+ // component via the icon's own size prop.
38
+ const graphicSize = { sm: '118px', md: '128px', lg: '160px' } as const
39
+
40
+ const graphicChildren = (size: string) => ({
41
+ [`& ${className}-graphic > img, & ${className}-graphic > svg, & ${className}-graphic > picture`]: {
42
+ width: size,
43
+ height: size,
44
+ },
45
+ })
46
+
47
+ addComponents({
48
+ // Base container
49
+ [className]: {
50
+ containerType: 'inline-size',
51
+ display: 'flex',
52
+ flexDirection: 'column',
53
+ alignItems: 'center',
54
+ justifyContent: 'center',
55
+ textAlign: 'center',
56
+ padding: '2rem',
57
+ },
58
+
59
+ // Graphic container
60
+ [`${className}-graphic`]: {
61
+ display: 'flex',
62
+ alignItems: 'center',
63
+ justifyContent: 'center',
64
+ '&:empty': { display: 'none' },
65
+ '& > img, & > svg': {
66
+ objectFit: 'contain',
67
+ },
68
+ '& > picture': {
69
+ display: 'block',
70
+ },
71
+ '& > picture > img': {
72
+ width: '100%',
73
+ height: '100%',
74
+ objectFit: 'contain',
75
+ },
76
+ },
77
+
78
+ // Content wrapper (heading + description)
79
+ [`${className}-content`]: {
80
+ display: 'flex',
81
+ flexDirection: 'column',
82
+ maxWidth: 'var(--empty-state-max-width, min(75cqw, 360px))',
83
+ },
84
+
85
+ // Size variants (gap, description text, graphic size, content gap)
86
+ [`${className}-sm`]: {
87
+ gap: '1rem',
88
+ [`& ${className}-description`]: { fontSize: '0.875rem', lineHeight: '1.25rem' },
89
+ ...graphicChildren(graphicSize.sm),
90
+ [`& ${className}-content`]: { gap: '0.25rem' },
91
+ },
92
+ [`${className}-md`]: {
93
+ gap: '1.5rem',
94
+ [`& ${className}-description`]: { fontSize: '0.875rem', lineHeight: '1.25rem' },
95
+ ...graphicChildren(graphicSize.md),
96
+ [`& ${className}-content`]: { gap: '0.5rem' },
97
+ },
98
+ [`${className}-lg`]: {
99
+ gap: '1.5rem',
100
+ [`& ${className}-description`]: { fontSize: '1rem', lineHeight: '1.5rem' },
101
+ ...graphicChildren(graphicSize.lg),
102
+ [`& ${className}-content`]: { gap: '0.5rem' },
103
+ },
104
+
105
+ // Title
106
+ [`${className}-title`]: {
107
+ color: 'var(--empty-state-color-heading, oklch(var(--btu-theme-gray-900)))',
108
+ margin: '0',
109
+ },
110
+
111
+ // Description
112
+ [`${className}-description`]: {
113
+ color: 'var(--empty-state-color-description, oklch(var(--btu-theme-gray-500)))',
114
+ margin: '0',
115
+ },
116
+
117
+ // Actions container — applied to an internal btu-button-group. Layout, gap,
118
+ // and size propagation come from the button-group plugin; we only need to
119
+ // collapse the container when it has no children.
120
+ [`${className}-actions`]: {
121
+ '&:empty': { display: 'none' },
122
+ },
123
+ })
124
+ })
@@ -14,10 +14,12 @@ import { addNameSpaceXML, encodeSVG } from './util/svg.js';
14
14
  *
15
15
  * btu-icon - Establishes the standard icon styles and font.
16
16
  * btu-icon-{name-of-icon} - Sets the font glyph to the value of the icon you want.
17
- * btu-icon-[xs|sm|md|lg|xl|{arbitary value}] - Size of the icon.
18
- * btu-icon-gradient-[primary] - Gradient to use for the icon background.
17
+ * btu-icon-[xs|sm|md|lg|xl|{arbitrary value}] - Size of the icon.
18
+ * btu-icon-gradient-{color} - Gradient to use for the icon background (ai, primary, error, success, warning, gray, purple, rose, teal).
19
19
  * btu-icon-via-mask-{name of icon} - SVG mask to use given a specific icon name.
20
- * - exposes a custom property `--Icon-svg` data URI to set the mask.
20
+ * - exposes a custom property `--icon-svg` data URI to set the mask.
21
+ * btu-icon-emphasize - Tonal circle + ring behind the icon (derives from currentColor, defaults to primary).
22
+ * btu-icon-emphasize-pulse - Adds a one-shot ring spring animation to the emphasize circle.
21
23
  *
22
24
  * Usages:
23
25
  *
@@ -25,7 +27,7 @@ import { addNameSpaceXML, encodeSVG } from './util/svg.js';
25
27
  * > before:btu-icon before:btu-icon-heart
26
28
  *
27
29
  * A heart icon that is 2rem in size:
28
- * > before:btu-icon before:btu-icon-heart before:[--Icon-size:2rem]
30
+ * > before:btu-icon before:btu-icon-heart before:[--icon-size:2rem]
29
31
  * - or -
30
32
  * > before:btu-icon before:btu-icon-heart before:btu-icon-lg
31
33
  *
@@ -33,34 +35,33 @@ import { addNameSpaceXML, encodeSVG } from './util/svg.js';
33
35
  * > before:btu-icon-gradient-primary before:btu-icon-via-mask-heart
34
36
  */
35
37
  const svgs = {};
36
- const symbols = /[\r\n%#()<>?[\\\]^`{|}]/g;
37
38
  for (const [key, value] of Object.entries(LucideExports)) {
38
39
  if (typeof value === 'string') {
39
40
  svgs[key] = value;
40
41
  }
41
42
  }
42
- module.exports = plugin(function ({ addComponents, matchUtilities, theme }) {
43
- const size = 'var(--Icon-size)';
43
+ module.exports = plugin(function ({ addBase, addComponents, matchUtilities, theme }) {
44
+ const size = 'var(--icon-size)';
44
45
  const prefix = '.btu-icon-';
45
46
  Object.entries(svgs).forEach(([key, svg]) => {
46
47
  addComponents({
47
48
  [`${prefix}via-mask`]: {
48
49
  '--size': '1.25rem',
49
- mask: 'var(--mask-url, var(--Icon-svg, var(--compat-icon-via-mask))) center / contain no-repeat',
50
+ mask: 'var(--mask-url, var(--icon-svg, var(--compat-icon-via-mask))) center / contain no-repeat',
50
51
  'mask-mode': 'alpha',
51
52
  'aspect-ratio': '1',
52
- 'inline-size': 'var(--Icon-size, var(--size))',
53
- 'block-size': 'var(--Icon-size, var(--size))',
53
+ 'inline-size': 'var(--icon-size, var(--size))',
54
+ 'block-size': 'var(--icon-size, var(--size))',
54
55
  display: 'inline-block',
55
56
  },
56
57
  [`${prefix}via-mask-${pascalToKebab(key)}`]: {
57
58
  '--size': '1.25rem',
58
- '--Icon-svg': `url("data:image/svg+xml,${encodeSVG(addNameSpaceXML(svg))}")`,
59
- mask: 'var(--Icon-svg) center / contain no-repeat',
59
+ '--icon-svg': `url("data:image/svg+xml,${encodeSVG(addNameSpaceXML(svg))}")`,
60
+ mask: 'var(--icon-svg) center / contain no-repeat',
60
61
  'mask-mode': 'alpha',
61
62
  'aspect-ratio': '1',
62
- 'inline-size': 'var(--Icon-size, var(--size))',
63
- 'block-size': 'var(--Icon-size, var(--size))',
63
+ 'inline-size': 'var(--icon-size, var(--size))',
64
+ 'block-size': 'var(--icon-size, var(--size))',
64
65
  display: 'inline-block',
65
66
  },
66
67
  });
@@ -96,9 +97,9 @@ module.exports = plugin(function ({ addComponents, matchUtilities, theme }) {
96
97
  'background-image': value,
97
98
  'background-repeat': 'no-repeat',
98
99
  'background-position': 'center',
99
- 'background-size': 'var(--Icon-size, 1.5rem) var(--Icon-size, 1.5rem)',
100
- width: 'var(--Icon-size, 1.5rem)',
101
- height: 'var(--Icon-size, 1.5rem)',
100
+ 'background-size': 'var(--icon-size, 1.5rem) var(--icon-size, 1.5rem)',
101
+ width: 'var(--icon-size, 1.5rem)',
102
+ height: 'var(--icon-size, 1.5rem)',
102
103
  display: 'inline-block',
103
104
  }),
104
105
  }, {
@@ -116,9 +117,112 @@ module.exports = plugin(function ({ addComponents, matchUtilities, theme }) {
116
117
  });
117
118
  matchUtilities({
118
119
  'btu-icon': value => ({
119
- '--Icon-size': value,
120
+ '--icon-size': value,
120
121
  }),
121
122
  }, { values: theme('iconSize') });
123
+ /* ─── Emphasize: tonal circle + ring behind icon ─── */
124
+ function oklch(l, cMul, cMin) {
125
+ const chroma = cMin != null ? `max(calc(c * ${cMul}), ${cMin})` : `calc(c * ${cMul})`;
126
+ return `oklch(from currentColor ${l} ${chroma} h)`;
127
+ }
128
+ const lightColors = {
129
+ '--_ring-color': oklch(0.8, 0.5),
130
+ backgroundColor: oklch(0.93, 0.22),
131
+ borderColor: oklch(0.97, 0.1),
132
+ };
133
+ const darkColors = {
134
+ '--_ring-color': oklch(0.65, 1.5, 0.08),
135
+ backgroundColor: oklch(0.69, 1.6, 0.08),
136
+ borderColor: oklch(0.6, 1.4, 0.06),
137
+ };
138
+ const highContrastColors = {
139
+ '--_ring-color': oklch(0.75, 0.5),
140
+ backgroundColor: oklch(0.9, 0.35),
141
+ borderColor: oklch(0.95, 0.2),
142
+ };
143
+ /* Pulse ring animation keyframes (pseudo-element scale + fade) */
144
+ addBase({
145
+ '@keyframes btu-icon-ring-spring': {
146
+ '0%': { transform: 'scale(1)', opacity: '0.6' },
147
+ '35%': { transform: 'scale(var(--_ring-scale))', opacity: '0.4' },
148
+ '100%': { transform: 'scale(var(--_ring-scale))', opacity: '0' },
149
+ },
150
+ });
151
+ addComponents({
152
+ '.btu-icon-emphasize': {
153
+ position: 'relative',
154
+ display: 'inline-flex',
155
+ alignItems: 'center',
156
+ justifyContent: 'center',
157
+ borderRadius: '9999px',
158
+ borderStyle: 'solid',
159
+ color: 'oklch(var(--btu-theme-primary-600))',
160
+ ...lightColors,
161
+ },
162
+ /* Per-size circle dimensions (border width scales with size per Figma spec) */
163
+ '.btu-icon-emphasize.btu-icon-xs': {
164
+ width: '1.5rem',
165
+ height: '1.5rem',
166
+ borderWidth: '2px',
167
+ '--_ring-scale': '1.25',
168
+ },
169
+ '.btu-icon-emphasize.btu-icon-sm': {
170
+ width: '2rem',
171
+ height: '2rem',
172
+ borderWidth: '4px',
173
+ '--_ring-scale': '1.35',
174
+ },
175
+ '.btu-icon-emphasize.btu-icon-md': {
176
+ width: '2.25rem',
177
+ height: '2.25rem',
178
+ borderWidth: '6px',
179
+ '--_ring-scale': '1.4',
180
+ },
181
+ '.btu-icon-emphasize.btu-icon-lg': {
182
+ width: '3rem',
183
+ height: '3rem',
184
+ borderWidth: '8px',
185
+ '--_ring-scale': '1.45',
186
+ },
187
+ '.btu-icon-emphasize.btu-icon-xl': {
188
+ width: '3.5rem',
189
+ height: '3.5rem',
190
+ borderWidth: '10px',
191
+ '--_ring-scale': '1.5',
192
+ },
193
+ /* Pulse animation — pseudo-element ring that scales out and fades */
194
+ '.btu-icon-emphasize-pulse::before': {
195
+ content: '""',
196
+ position: 'absolute',
197
+ inset: '0',
198
+ borderRadius: '9999px',
199
+ backgroundColor: 'var(--_ring-color)',
200
+ opacity: '0',
201
+ animation: 'btu-icon-ring-spring 1200ms ease-out 200ms both',
202
+ pointerEvents: 'none',
203
+ },
204
+ /* ─── Dark mode ─── */
205
+ '.is-dark .btu-icon-emphasize': darkColors,
206
+ '.is-dark .btu-icon-emphasize svg': { color: 'oklch(0.95 0 0)' },
207
+ '@media (prefers-color-scheme: dark)': {
208
+ ':root:not([data-theme*=\'"appearance":"light"\']):not(.is-dark) .btu-icon-emphasize': darkColors,
209
+ ':root:not([data-theme*=\'"appearance":"light"\']):not(.is-dark) .btu-icon-emphasize svg': {
210
+ color: 'oklch(0.95 0 0)',
211
+ },
212
+ },
213
+ /* ─── High contrast ─── */
214
+ ':root.is-moreContrast .btu-icon-emphasize': highContrastColors,
215
+ '@media screen and (prefers-contrast: more) and (forced-colors: none)': {
216
+ ':root:not(.is-normalContrast) .btu-icon-emphasize': highContrastColors,
217
+ },
218
+ /* ─── Reduced motion ─── */
219
+ '@media (prefers-reduced-motion: reduce)': {
220
+ '.btu-icon-emphasize-pulse::before': {
221
+ animationDuration: '0.01ms',
222
+ animationDelay: '0ms',
223
+ },
224
+ },
225
+ });
122
226
  }, {
123
227
  theme: {
124
228
  iconSize: {
@@ -1 +1 @@
1
- {"version":3,"file":"tailwind-plugin-icon.js","sourceRoot":"","sources":["../src/tailwind-plugin-icon.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"tailwind-plugin-icon.js","sourceRoot":"","sources":["../src/tailwind-plugin-icon.ts"],"names":[],"mappings":"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"}
@@ -16,10 +16,12 @@ declare let module: any
16
16
  *
17
17
  * btu-icon - Establishes the standard icon styles and font.
18
18
  * btu-icon-{name-of-icon} - Sets the font glyph to the value of the icon you want.
19
- * btu-icon-[xs|sm|md|lg|xl|{arbitary value}] - Size of the icon.
20
- * btu-icon-gradient-[primary] - Gradient to use for the icon background.
19
+ * btu-icon-[xs|sm|md|lg|xl|{arbitrary value}] - Size of the icon.
20
+ * btu-icon-gradient-{color} - Gradient to use for the icon background (ai, primary, error, success, warning, gray, purple, rose, teal).
21
21
  * btu-icon-via-mask-{name of icon} - SVG mask to use given a specific icon name.
22
- * - exposes a custom property `--Icon-svg` data URI to set the mask.
22
+ * - exposes a custom property `--icon-svg` data URI to set the mask.
23
+ * btu-icon-emphasize - Tonal circle + ring behind the icon (derives from currentColor, defaults to primary).
24
+ * btu-icon-emphasize-pulse - Adds a one-shot ring spring animation to the emphasize circle.
23
25
  *
24
26
  * Usages:
25
27
  *
@@ -27,7 +29,7 @@ declare let module: any
27
29
  * > before:btu-icon before:btu-icon-heart
28
30
  *
29
31
  * A heart icon that is 2rem in size:
30
- * > before:btu-icon before:btu-icon-heart before:[--Icon-size:2rem]
32
+ * > before:btu-icon before:btu-icon-heart before:[--icon-size:2rem]
31
33
  * - or -
32
34
  * > before:btu-icon before:btu-icon-heart before:btu-icon-lg
33
35
  *
@@ -36,7 +38,6 @@ declare let module: any
36
38
  */
37
39
 
38
40
  const svgs: Record<string, string> = {}
39
- const symbols = /[\r\n%#()<>?[\\\]^`{|}]/g
40
41
  for (const [key, value] of Object.entries(LucideExports)) {
41
42
  if (typeof value === 'string') {
42
43
  svgs[key] = value
@@ -44,29 +45,29 @@ for (const [key, value] of Object.entries(LucideExports)) {
44
45
  }
45
46
 
46
47
  module.exports = plugin(
47
- function ({ addComponents, matchUtilities, theme }) {
48
- const size = 'var(--Icon-size)'
48
+ function ({ addBase, addComponents, matchUtilities, theme }) {
49
+ const size = 'var(--icon-size)'
49
50
  const prefix = '.btu-icon-'
50
51
 
51
52
  Object.entries(svgs).forEach(([key, svg]) => {
52
53
  addComponents({
53
54
  [`${prefix}via-mask`]: {
54
55
  '--size': '1.25rem',
55
- mask: 'var(--mask-url, var(--Icon-svg, var(--compat-icon-via-mask))) center / contain no-repeat',
56
+ mask: 'var(--mask-url, var(--icon-svg, var(--compat-icon-via-mask))) center / contain no-repeat',
56
57
  'mask-mode': 'alpha',
57
58
  'aspect-ratio': '1',
58
- 'inline-size': 'var(--Icon-size, var(--size))',
59
- 'block-size': 'var(--Icon-size, var(--size))',
59
+ 'inline-size': 'var(--icon-size, var(--size))',
60
+ 'block-size': 'var(--icon-size, var(--size))',
60
61
  display: 'inline-block',
61
62
  },
62
63
  [`${prefix}via-mask-${pascalToKebab(key)}`]: {
63
64
  '--size': '1.25rem',
64
- '--Icon-svg': `url("data:image/svg+xml,${encodeSVG(addNameSpaceXML(svg))}")`,
65
- mask: 'var(--Icon-svg) center / contain no-repeat',
65
+ '--icon-svg': `url("data:image/svg+xml,${encodeSVG(addNameSpaceXML(svg))}")`,
66
+ mask: 'var(--icon-svg) center / contain no-repeat',
66
67
  'mask-mode': 'alpha',
67
68
  'aspect-ratio': '1',
68
- 'inline-size': 'var(--Icon-size, var(--size))',
69
- 'block-size': 'var(--Icon-size, var(--size))',
69
+ 'inline-size': 'var(--icon-size, var(--size))',
70
+ 'block-size': 'var(--icon-size, var(--size))',
70
71
  display: 'inline-block',
71
72
  },
72
73
  })
@@ -107,9 +108,9 @@ module.exports = plugin(
107
108
  'background-image': value,
108
109
  'background-repeat': 'no-repeat',
109
110
  'background-position': 'center',
110
- 'background-size': 'var(--Icon-size, 1.5rem) var(--Icon-size, 1.5rem)',
111
- width: 'var(--Icon-size, 1.5rem)',
112
- height: 'var(--Icon-size, 1.5rem)',
111
+ 'background-size': 'var(--icon-size, 1.5rem) var(--icon-size, 1.5rem)',
112
+ width: 'var(--icon-size, 1.5rem)',
113
+ height: 'var(--icon-size, 1.5rem)',
113
114
  display: 'inline-block',
114
115
  }),
115
116
  },
@@ -130,11 +131,123 @@ module.exports = plugin(
130
131
  matchUtilities(
131
132
  {
132
133
  'btu-icon': value => ({
133
- '--Icon-size': value,
134
+ '--icon-size': value,
134
135
  }),
135
136
  },
136
137
  { values: theme('iconSize') },
137
138
  )
139
+
140
+ /* ─── Emphasize: tonal circle + ring behind icon ─── */
141
+ function oklch(l: number, cMul: number, cMin?: number): string {
142
+ const chroma = cMin != null ? `max(calc(c * ${cMul}), ${cMin})` : `calc(c * ${cMul})`
143
+ return `oklch(from currentColor ${l} ${chroma} h)`
144
+ }
145
+
146
+ const lightColors = {
147
+ '--_ring-color': oklch(0.8, 0.5),
148
+ backgroundColor: oklch(0.93, 0.22),
149
+ borderColor: oklch(0.97, 0.1),
150
+ }
151
+ const darkColors = {
152
+ '--_ring-color': oklch(0.65, 1.5, 0.08),
153
+ backgroundColor: oklch(0.69, 1.6, 0.08),
154
+ borderColor: oklch(0.6, 1.4, 0.06),
155
+ }
156
+ const highContrastColors = {
157
+ '--_ring-color': oklch(0.75, 0.5),
158
+ backgroundColor: oklch(0.9, 0.35),
159
+ borderColor: oklch(0.95, 0.2),
160
+ }
161
+
162
+ /* Pulse ring animation keyframes (pseudo-element scale + fade) */
163
+ addBase({
164
+ '@keyframes btu-icon-ring-spring': {
165
+ '0%': { transform: 'scale(1)', opacity: '0.6' },
166
+ '35%': { transform: 'scale(var(--_ring-scale))', opacity: '0.4' },
167
+ '100%': { transform: 'scale(var(--_ring-scale))', opacity: '0' },
168
+ },
169
+ })
170
+
171
+ addComponents({
172
+ '.btu-icon-emphasize': {
173
+ position: 'relative',
174
+ display: 'inline-flex',
175
+ alignItems: 'center',
176
+ justifyContent: 'center',
177
+ borderRadius: '9999px',
178
+ borderStyle: 'solid',
179
+ color: 'oklch(var(--btu-theme-primary-600))',
180
+ ...lightColors,
181
+ },
182
+
183
+ /* Per-size circle dimensions (border width scales with size per Figma spec) */
184
+ '.btu-icon-emphasize.btu-icon-xs': {
185
+ width: '1.5rem',
186
+ height: '1.5rem',
187
+ borderWidth: '2px',
188
+ '--_ring-scale': '1.25',
189
+ },
190
+ '.btu-icon-emphasize.btu-icon-sm': {
191
+ width: '2rem',
192
+ height: '2rem',
193
+ borderWidth: '4px',
194
+ '--_ring-scale': '1.35',
195
+ },
196
+ '.btu-icon-emphasize.btu-icon-md': {
197
+ width: '2.25rem',
198
+ height: '2.25rem',
199
+ borderWidth: '6px',
200
+ '--_ring-scale': '1.4',
201
+ },
202
+ '.btu-icon-emphasize.btu-icon-lg': {
203
+ width: '3rem',
204
+ height: '3rem',
205
+ borderWidth: '8px',
206
+ '--_ring-scale': '1.45',
207
+ },
208
+ '.btu-icon-emphasize.btu-icon-xl': {
209
+ width: '3.5rem',
210
+ height: '3.5rem',
211
+ borderWidth: '10px',
212
+ '--_ring-scale': '1.5',
213
+ },
214
+
215
+ /* Pulse animation — pseudo-element ring that scales out and fades */
216
+ '.btu-icon-emphasize-pulse::before': {
217
+ content: '""',
218
+ position: 'absolute',
219
+ inset: '0',
220
+ borderRadius: '9999px',
221
+ backgroundColor: 'var(--_ring-color)',
222
+ opacity: '0',
223
+ animation: 'btu-icon-ring-spring 1200ms ease-out 200ms both',
224
+ pointerEvents: 'none',
225
+ },
226
+
227
+ /* ─── Dark mode ─── */
228
+ '.is-dark .btu-icon-emphasize': darkColors,
229
+ '.is-dark .btu-icon-emphasize svg': { color: 'oklch(0.95 0 0)' },
230
+ '@media (prefers-color-scheme: dark)': {
231
+ ':root:not([data-theme*=\'"appearance":"light"\']):not(.is-dark) .btu-icon-emphasize': darkColors,
232
+ ':root:not([data-theme*=\'"appearance":"light"\']):not(.is-dark) .btu-icon-emphasize svg': {
233
+ color: 'oklch(0.95 0 0)',
234
+ },
235
+ },
236
+
237
+ /* ─── High contrast ─── */
238
+ ':root.is-moreContrast .btu-icon-emphasize': highContrastColors,
239
+ '@media screen and (prefers-contrast: more) and (forced-colors: none)': {
240
+ ':root:not(.is-normalContrast) .btu-icon-emphasize': highContrastColors,
241
+ },
242
+
243
+ /* ─── Reduced motion ─── */
244
+ '@media (prefers-reduced-motion: reduce)': {
245
+ '.btu-icon-emphasize-pulse::before': {
246
+ animationDuration: '0.01ms',
247
+ animationDelay: '0ms',
248
+ },
249
+ },
250
+ })
138
251
  },
139
252
  {
140
253
  theme: {
@@ -11,7 +11,7 @@ import plugin from 'tailwindcss/plugin';
11
11
  * Loaders come with light and dark styles.
12
12
  *
13
13
  * If you need to reference the loader size, you can do so with:
14
- * --Loader-size
14
+ * --loader-size
15
15
  *
16
16
  * Class Name: btu-loader
17
17
  *
@@ -20,10 +20,10 @@ import plugin from 'tailwindcss/plugin';
20
20
  */
21
21
  module.exports = plugin(function ({ addComponents, theme }) {
22
22
  const loader = {
23
- '--Loader-size': '2rem',
23
+ '--loader-size': '2rem',
24
24
  display: 'block',
25
25
  content: 'var(--tw-content)',
26
- '--tw-content': `url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 50 50%27%3E %3Cstyle%3E :root %7B --Loader-bg-color: oklch%28${encodeURIComponent(theme('colors.gray.light.200'))}%29; --Loader-fg-color: oklch%28${encodeURIComponent(theme('colors.primary.light.600'))}%29; --btu-theme-primary-hue: 264; %7D @media %28prefers-color-scheme: dark%29 %7B :root %7B --Loader-bg-color: oklch%28${encodeURIComponent(theme('colors.gray.dark.100'))}%29; --Loader-fg-color: oklch%28${encodeURIComponent(theme('colors.primary.dark.700'))}%29; %7D %7D @keyframes rotate%7B100%25%7Btransform:rotate%28360deg%29;%7D%7D @keyframes dash%7B0%25%7Bstroke-dasharray:1,200;stroke-dashoffset:0;%7D50%25%7Bstroke-dasharray:89,200;stroke-dashoffset:-35;%7D100%25%7Bstroke-dasharray:89,200;stroke-dashoffset:-124;%7D%7D svg %7Bwill-change:transform;position:relative;animation:rotate 1.6s linear infinite;%7D .Loader-bg %7Bwill-change:transform;fill:none;transform-origin:center;%7D .Loader-fg %7Bwill-change:transform;animation:dash 1s infinite ease-in-out;animation-fill-mode:both;fill:none;transform-origin:center;stroke-linecap:round;stroke-dasharray:1,200;stroke-dashoffset:0;%7D %3C/style%3E %3Ccircle cx=%2725%27 cy=%2725%27 r=%2720%27 stroke-width=%274%27 class=%27Loader-bg%27 stroke=%27var%28--Loader-bg-color%29%27/%3E %3Ccircle cx=%2725%27 cy=%2725%27 r=%2720%27 stroke-width=%274%27 class=%27Loader-fg%27 stroke=%27var%28--Loader-fg-color%29%27/%3E %3C/svg%3E")`,
26
+ '--tw-content': `url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 50 50%27%3E %3Cstyle%3E :root %7B --loader-bg-color: oklch%28${encodeURIComponent(theme('colors.gray.light.200'))}%29; --loader-fg-color: oklch%28${encodeURIComponent(theme('colors.primary.light.600'))}%29; --btu-theme-primary-hue: 264; %7D @media %28prefers-color-scheme: dark%29 %7B :root %7B --loader-bg-color: oklch%28${encodeURIComponent(theme('colors.gray.dark.100'))}%29; --loader-fg-color: oklch%28${encodeURIComponent(theme('colors.primary.dark.700'))}%29; %7D %7D @keyframes rotate%7B100%25%7Btransform:rotate%28360deg%29;%7D%7D @keyframes dash%7B0%25%7Bstroke-dasharray:1,200;stroke-dashoffset:0;%7D50%25%7Bstroke-dasharray:89,200;stroke-dashoffset:-35;%7D100%25%7Bstroke-dasharray:89,200;stroke-dashoffset:-124;%7D%7D svg %7Bwill-change:transform;position:relative;animation:rotate 1.6s linear infinite;%7D .Loader-bg %7Bwill-change:transform;fill:none;transform-origin:center;%7D .Loader-fg %7Bwill-change:transform;animation:dash 1s infinite ease-in-out;animation-fill-mode:both;fill:none;transform-origin:center;stroke-linecap:round;stroke-dasharray:1,200;stroke-dashoffset:0;%7D %3C/style%3E %3Ccircle cx=%2725%27 cy=%2725%27 r=%2720%27 stroke-width=%274%27 class=%27Loader-bg%27 stroke=%27var%28--loader-bg-color%29%27/%3E %3Ccircle cx=%2725%27 cy=%2725%27 r=%2720%27 stroke-width=%274%27 class=%27Loader-fg%27 stroke=%27var%28--loader-fg-color%29%27/%3E %3C/svg%3E")`,
27
27
  };
28
28
  addComponents({
29
29
  '.btu-loader': loader,
@@ -13,7 +13,7 @@ declare let module: any
13
13
  * Loaders come with light and dark styles.
14
14
  *
15
15
  * If you need to reference the loader size, you can do so with:
16
- * --Loader-size
16
+ * --loader-size
17
17
  *
18
18
  * Class Name: btu-loader
19
19
  *
@@ -23,10 +23,10 @@ declare let module: any
23
23
 
24
24
  module.exports = plugin(function ({ addComponents, theme }) {
25
25
  const loader = {
26
- '--Loader-size': '2rem',
26
+ '--loader-size': '2rem',
27
27
  display: 'block',
28
28
  content: 'var(--tw-content)',
29
- '--tw-content': `url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 50 50%27%3E %3Cstyle%3E :root %7B --Loader-bg-color: oklch%28${encodeURIComponent(theme('colors.gray.light.200'))}%29; --Loader-fg-color: oklch%28${encodeURIComponent(theme('colors.primary.light.600'))}%29; --btu-theme-primary-hue: 264; %7D @media %28prefers-color-scheme: dark%29 %7B :root %7B --Loader-bg-color: oklch%28${encodeURIComponent(theme('colors.gray.dark.100'))}%29; --Loader-fg-color: oklch%28${encodeURIComponent(theme('colors.primary.dark.700'))}%29; %7D %7D @keyframes rotate%7B100%25%7Btransform:rotate%28360deg%29;%7D%7D @keyframes dash%7B0%25%7Bstroke-dasharray:1,200;stroke-dashoffset:0;%7D50%25%7Bstroke-dasharray:89,200;stroke-dashoffset:-35;%7D100%25%7Bstroke-dasharray:89,200;stroke-dashoffset:-124;%7D%7D svg %7Bwill-change:transform;position:relative;animation:rotate 1.6s linear infinite;%7D .Loader-bg %7Bwill-change:transform;fill:none;transform-origin:center;%7D .Loader-fg %7Bwill-change:transform;animation:dash 1s infinite ease-in-out;animation-fill-mode:both;fill:none;transform-origin:center;stroke-linecap:round;stroke-dasharray:1,200;stroke-dashoffset:0;%7D %3C/style%3E %3Ccircle cx=%2725%27 cy=%2725%27 r=%2720%27 stroke-width=%274%27 class=%27Loader-bg%27 stroke=%27var%28--Loader-bg-color%29%27/%3E %3Ccircle cx=%2725%27 cy=%2725%27 r=%2720%27 stroke-width=%274%27 class=%27Loader-fg%27 stroke=%27var%28--Loader-fg-color%29%27/%3E %3C/svg%3E")`,
29
+ '--tw-content': `url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 50 50%27%3E %3Cstyle%3E :root %7B --loader-bg-color: oklch%28${encodeURIComponent(theme('colors.gray.light.200'))}%29; --loader-fg-color: oklch%28${encodeURIComponent(theme('colors.primary.light.600'))}%29; --btu-theme-primary-hue: 264; %7D @media %28prefers-color-scheme: dark%29 %7B :root %7B --loader-bg-color: oklch%28${encodeURIComponent(theme('colors.gray.dark.100'))}%29; --loader-fg-color: oklch%28${encodeURIComponent(theme('colors.primary.dark.700'))}%29; %7D %7D @keyframes rotate%7B100%25%7Btransform:rotate%28360deg%29;%7D%7D @keyframes dash%7B0%25%7Bstroke-dasharray:1,200;stroke-dashoffset:0;%7D50%25%7Bstroke-dasharray:89,200;stroke-dashoffset:-35;%7D100%25%7Bstroke-dasharray:89,200;stroke-dashoffset:-124;%7D%7D svg %7Bwill-change:transform;position:relative;animation:rotate 1.6s linear infinite;%7D .Loader-bg %7Bwill-change:transform;fill:none;transform-origin:center;%7D .Loader-fg %7Bwill-change:transform;animation:dash 1s infinite ease-in-out;animation-fill-mode:both;fill:none;transform-origin:center;stroke-linecap:round;stroke-dasharray:1,200;stroke-dashoffset:0;%7D %3C/style%3E %3Ccircle cx=%2725%27 cy=%2725%27 r=%2720%27 stroke-width=%274%27 class=%27Loader-bg%27 stroke=%27var%28--loader-bg-color%29%27/%3E %3Ccircle cx=%2725%27 cy=%2725%27 r=%2720%27 stroke-width=%274%27 class=%27Loader-fg%27 stroke=%27var%28--loader-fg-color%29%27/%3E %3C/svg%3E")`,
30
30
  }
31
31
  addComponents({
32
32
  '.btu-loader': loader,
@@ -1,5 +1,12 @@
1
1
  import plugin from 'tailwindcss/plugin';
2
2
  /**
3
+ * NOTE on btu-tab-button carve-out:
4
+ * `btu-tab-button` is a standalone button primitive, NOT composed from `btu-button-*`.
5
+ * This is intentional — tabs require a bottom-edge active-state indicator (::after)
6
+ * and a tab-specific height/padding model that the generic action-button anatomy
7
+ * cannot express. See `.ai/LESSONS-BUTTON-REUSE.md` §4. Do not "fix" this by
8
+ * migrating to btu-button; either extend btu-button with a new variant or leave as-is.
9
+ *
3
10
  * Tabs component styles.
4
11
  *
5
12
  * Class Names:
@@ -1 +1 @@
1
- {"version":3,"file":"tailwind-plugin-tabs.js","sourceRoot":"","sources":["../src/tailwind-plugin-tabs.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"tailwind-plugin-tabs.js","sourceRoot":"","sources":["../src/tailwind-plugin-tabs.ts"],"names":[],"mappings":"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"}
@@ -2,6 +2,13 @@ import plugin from 'tailwindcss/plugin'
2
2
  declare let module: any
3
3
 
4
4
  /**
5
+ * NOTE on btu-tab-button carve-out:
6
+ * `btu-tab-button` is a standalone button primitive, NOT composed from `btu-button-*`.
7
+ * This is intentional — tabs require a bottom-edge active-state indicator (::after)
8
+ * and a tab-specific height/padding model that the generic action-button anatomy
9
+ * cannot express. See `.ai/LESSONS-BUTTON-REUSE.md` §4. Do not "fix" this by
10
+ * migrating to btu-button; either extend btu-button with a new variant or leave as-is.
11
+ *
5
12
  * Tabs component styles.
6
13
  *
7
14
  * Class Names:
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=tailwind-plugin-upload.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tailwind-plugin-upload.d.ts","sourceRoot":"","sources":["../src/tailwind-plugin-upload.ts"],"names":[],"mappings":""}