@brightspot/ui 1.10.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 (264) hide show
  1. package/dist/components/action-bar/ActionBar.d.ts +163 -0
  2. package/dist/components/action-bar/ActionBar.d.ts.map +1 -0
  3. package/dist/components/action-bar/ActionBar.js +479 -0
  4. package/dist/components/action-bar/ActionBar.js.map +1 -0
  5. package/dist/components/action-bar/ActionItem.d.ts +103 -0
  6. package/dist/components/action-bar/ActionItem.d.ts.map +1 -0
  7. package/dist/components/action-bar/ActionItem.js +237 -0
  8. package/dist/components/action-bar/ActionItem.js.map +1 -0
  9. package/dist/components/avatar/AvatarGroup.d.ts +3 -0
  10. package/dist/components/avatar/AvatarGroup.d.ts.map +1 -1
  11. package/dist/components/avatar/AvatarGroup.js +3 -0
  12. package/dist/components/avatar/AvatarGroup.js.map +1 -1
  13. package/dist/components/badge/Badge.d.ts +3 -1
  14. package/dist/components/badge/Badge.d.ts.map +1 -1
  15. package/dist/components/badge/Badge.js +2 -0
  16. package/dist/components/badge/Badge.js.map +1 -1
  17. package/dist/components/button-group/ButtonGroup.d.ts +138 -0
  18. package/dist/components/button-group/ButtonGroup.d.ts.map +1 -0
  19. package/dist/components/button-group/ButtonGroup.js +436 -0
  20. package/dist/components/button-group/ButtonGroup.js.map +1 -0
  21. package/dist/components/checkbox/Checkbox.d.ts +107 -0
  22. package/dist/components/checkbox/Checkbox.d.ts.map +1 -0
  23. package/dist/components/checkbox/Checkbox.js +224 -0
  24. package/dist/components/checkbox/Checkbox.js.map +1 -0
  25. package/dist/components/circular-progress/CircularProgress.d.ts +2 -2
  26. package/dist/components/circular-progress/CircularProgress.js +2 -2
  27. package/dist/components/copy-to-clipboard/CopyToClipboard.d.ts +7 -2
  28. package/dist/components/copy-to-clipboard/CopyToClipboard.d.ts.map +1 -1
  29. package/dist/components/copy-to-clipboard/CopyToClipboard.js +10 -5
  30. package/dist/components/copy-to-clipboard/CopyToClipboard.js.map +1 -1
  31. package/dist/components/dropdown/Dropdown.d.ts +8 -6
  32. package/dist/components/dropdown/Dropdown.d.ts.map +1 -1
  33. package/dist/components/dropdown/Dropdown.js +33 -22
  34. package/dist/components/dropdown/Dropdown.js.map +1 -1
  35. package/dist/components/dropdown/DropdownItem.d.ts +28 -7
  36. package/dist/components/dropdown/DropdownItem.d.ts.map +1 -1
  37. package/dist/components/dropdown/DropdownItem.js +41 -16
  38. package/dist/components/dropdown/DropdownItem.js.map +1 -1
  39. package/dist/components/dropdown/DropdownMenu.d.ts +6 -8
  40. package/dist/components/dropdown/DropdownMenu.d.ts.map +1 -1
  41. package/dist/components/dropdown/DropdownMenu.js +22 -37
  42. package/dist/components/dropdown/DropdownMenu.js.map +1 -1
  43. package/dist/components/empty-state/EmptyState.css +4 -0
  44. package/dist/components/empty-state/EmptyState.d.ts +103 -0
  45. package/dist/components/empty-state/EmptyState.d.ts.map +1 -0
  46. package/dist/components/empty-state/EmptyState.js +209 -0
  47. package/dist/components/empty-state/EmptyState.js.map +1 -0
  48. package/dist/components/icon/Icon.d.ts +23 -10
  49. package/dist/components/icon/Icon.d.ts.map +1 -1
  50. package/dist/components/icon/Icon.js +40 -9
  51. package/dist/components/icon/Icon.js.map +1 -1
  52. package/dist/components/icon-button/IconButton.d.ts +7 -21
  53. package/dist/components/icon-button/IconButton.d.ts.map +1 -1
  54. package/dist/components/icon-button/IconButton.js +12 -18
  55. package/dist/components/icon-button/IconButton.js.map +1 -1
  56. package/dist/components/linear-progress/LinearProgress.d.ts +2 -2
  57. package/dist/components/linear-progress/LinearProgress.js +2 -2
  58. package/dist/components/pagination/Pagination.d.ts +33 -4
  59. package/dist/components/pagination/Pagination.d.ts.map +1 -1
  60. package/dist/components/pagination/Pagination.js +88 -24
  61. package/dist/components/pagination/Pagination.js.map +1 -1
  62. package/dist/components/popover/Popover.d.ts +6 -0
  63. package/dist/components/popover/Popover.d.ts.map +1 -1
  64. package/dist/components/popover/Popover.js +6 -0
  65. package/dist/components/popover/Popover.js.map +1 -1
  66. package/dist/components/switch/Switch.d.ts +5 -1
  67. package/dist/components/switch/Switch.d.ts.map +1 -1
  68. package/dist/components/switch/Switch.js +10 -6
  69. package/dist/components/switch/Switch.js.map +1 -1
  70. package/dist/components/tabs/Tab.d.ts +108 -0
  71. package/dist/components/tabs/Tab.d.ts.map +1 -0
  72. package/dist/components/tabs/Tab.js +152 -0
  73. package/dist/components/tabs/Tab.js.map +1 -0
  74. package/dist/components/tabs/Tabs.d.ts +126 -0
  75. package/dist/components/tabs/Tabs.d.ts.map +1 -0
  76. package/dist/components/tabs/Tabs.js +390 -0
  77. package/dist/components/tabs/Tabs.js.map +1 -0
  78. package/dist/components/upload/Upload.d.ts +157 -0
  79. package/dist/components/upload/Upload.d.ts.map +1 -0
  80. package/dist/components/upload/Upload.js +538 -0
  81. package/dist/components/upload/Upload.js.map +1 -0
  82. package/dist/components/upload/UploadItem.d.ts +73 -0
  83. package/dist/components/upload/UploadItem.d.ts.map +1 -0
  84. package/dist/components/upload/UploadItem.js +180 -0
  85. package/dist/components/upload/UploadItem.js.map +1 -0
  86. package/dist/components/widget/Widget.d.ts +1 -6
  87. package/dist/components/widget/Widget.d.ts.map +1 -1
  88. package/dist/components/widget/Widget.js +1 -6
  89. package/dist/components/widget/Widget.js.map +1 -1
  90. package/dist/custom-elements.json +8445 -1989
  91. package/dist/storybook/assets/ActionBar.stories-DRIVI-W2.js +408 -0
  92. package/dist/storybook/assets/ActionItem.stories-5qlgxYNB.js +203 -0
  93. package/dist/storybook/assets/{Avatar.stories-B26mRkkZ.js → Avatar.stories-B3VkhRhP.js} +2 -2
  94. package/dist/storybook/assets/{AvatarGroup.stories-J7lVGsMY.js → AvatarGroup.stories-DOfim2NY.js} +5 -5
  95. package/dist/storybook/assets/{Badge.stories-BpTIV61M.js → Badge.stories-B04VNAcc.js} +2 -2
  96. package/dist/storybook/assets/{Button-Dg-fIrzT.js → Button-CILTcGRT.js} +1 -1
  97. package/dist/storybook/assets/{Button.stories-gPKRVbxk.js → Button.stories-CzWAltrX.js} +1 -1
  98. package/dist/storybook/assets/ButtonGroup.stories-1uAJf79o.js +588 -0
  99. package/dist/storybook/assets/{Celebrate.stories-DbY-sKEe.js → Celebrate.stories-BEqj0VnW.js} +7 -7
  100. package/dist/storybook/assets/Checkbox.stories-DXAGFS0M.js +141 -0
  101. package/dist/storybook/assets/{CircularProgress.stories-DeH5JYX_.js → CircularProgress.stories-D4rftw22.js} +7 -7
  102. package/dist/storybook/assets/{ClipboardMixin.stories-C-lZ4uuw.js → ClipboardMixin.stories-z2n2HWt1.js} +31 -28
  103. package/dist/storybook/assets/{Color-6BZIO3FS-Cu6zVIuG.js → Color-6BZIO3FS-C6KyMgZz.js} +1 -1
  104. package/dist/storybook/assets/{Colors.stories-D6XYMrTD.js → Colors.stories-CX-Ny3B_.js} +1 -1
  105. package/dist/storybook/assets/{CombinedEffects.stories-jFekKTYg.js → CombinedEffects.stories-BkqtiVHp.js} +33 -33
  106. package/dist/storybook/assets/{ComponentStatesMixin-g50hRCPT.js → ComponentStatesMixin-DLd0feFg.js} +1 -1
  107. package/dist/storybook/assets/{ComponentStatesMixin.stories-D3Q5pR38.js → ComponentStatesMixin.stories-D6Yc5Jgl.js} +3 -3
  108. package/dist/storybook/assets/{CopyToClipboard.stories-COZZ1VC2.js → CopyToClipboard.stories-B-omwDDJ.js} +16 -16
  109. package/dist/storybook/assets/{Debounce.stories-Dl10LAnx.js → Debounce.stories-B2vE5QIx.js} +9 -9
  110. package/dist/storybook/assets/{DocsRenderer-LL677BLK-CFLtMbUx.js → DocsRenderer-LL677BLK-DNUlRvMg.js} +3 -3
  111. package/dist/storybook/assets/{Dropdown.stories-Drwq-0Z2.js → Dropdown.stories-_bx4WDLr.js} +95 -68
  112. package/dist/storybook/assets/EmptyState.stories-CGMbmo77.js +318 -0
  113. package/dist/storybook/assets/{Events.stories-dODeR-g-.js → Events.stories-CkQYKcoZ.js} +1 -1
  114. package/dist/storybook/assets/{Heading.stories-CH7_-_q3.js → Heading.stories-BU5Do_od.js} +1 -1
  115. package/dist/storybook/assets/{HueRipple.stories-CH1Y739k.js → HueRipple.stories-Di2zmxo3.js} +11 -11
  116. package/dist/storybook/assets/Icon.stories-Dk4ZXhhJ.js +441 -0
  117. package/dist/storybook/assets/{IconButton.stories-DuzqvcnN.js → IconButton.stories-BSCiXPXa.js} +126 -146
  118. package/dist/storybook/assets/{LinearProgress.stories-C7IdnJd3.js → LinearProgress.stories-BGxPZuni.js} +7 -7
  119. package/dist/storybook/assets/Pagination.stories-z3Zq8b4f.js +252 -0
  120. package/dist/storybook/assets/{Popover.stories-Ca1F-wrI.js → Popover.stories-C9GxWcax.js} +33 -62
  121. package/dist/storybook/assets/ReadyMixin-CQw8N6P9.js +1 -0
  122. package/dist/storybook/assets/RovingTabindexMixin.stories-ByxLBi6m.js +192 -0
  123. package/dist/storybook/assets/{Rtc.stories-BVJc1vCA.js → Rtc.stories-DQJlCXWR.js} +3 -3
  124. package/dist/storybook/assets/ScrollShadow.stories-gjTIAbUA.js +17 -0
  125. package/dist/storybook/assets/{Switch.stories-BEEHP8mD.js → Switch.stories-BEeqPZiP.js} +21 -21
  126. package/dist/storybook/assets/Tab.stories-DpB3I-WZ.js +218 -0
  127. package/dist/storybook/assets/Tabs.stories-C6mG6Xi7.js +211 -0
  128. package/dist/storybook/assets/{Throttle.stories-C4xsYeAb.js → Throttle.stories-x9tpGeQh.js} +10 -10
  129. package/dist/storybook/assets/{Tooltip.stories-Ccm4AnSv.js → Tooltip.stories-CqcLqdmc.js} +2 -2
  130. package/dist/storybook/assets/Upload.stories-CMaAbCSH.js +447 -0
  131. package/dist/storybook/assets/UploadItem.stories-GB98L3JQ.js +167 -0
  132. package/dist/storybook/assets/{Welcome.stories-Degjk-M0.js → Welcome.stories-6h9cUZ7v.js} +1 -1
  133. package/dist/storybook/assets/{Widget.stories-OKnZ9sDs.js → Widget.stories-DiA1PR6Y.js} +13 -13
  134. package/dist/storybook/assets/{WithTooltip-65CFNBJE-CXL3TyJ2.js → WithTooltip-65CFNBJE-DTsHhBb_.js} +2 -2
  135. package/dist/storybook/assets/{blocks-DLdUKG_W.js → blocks-IXdn9TGW.js} +5 -5
  136. package/dist/storybook/assets/{formatter-EIJCOSYU-29NCxjfM.js → formatter-EIJCOSYU-Cum4J6N4.js} +1 -1
  137. package/dist/storybook/assets/if-defined-CgfCxQoV.js +1 -0
  138. package/dist/storybook/assets/iframe-BgFj0b5u.css +1 -0
  139. package/dist/storybook/assets/{iframe-BqvwP3or.js → iframe-Sf9RHZFu.js} +200 -200
  140. package/dist/storybook/assets/{index-BIyTv1BF.js → index-D605PvQH.js} +1 -1
  141. package/dist/storybook/assets/onFind-C41m8c_a.js +1 -0
  142. package/dist/storybook/assets/{onFind.stories-D64-QZqf.js → onFind.stories-MOTfGlJd.js} +53 -77
  143. package/dist/storybook/assets/{onRemove.stories-BICsnIJL.js → onRemove.stories-DX58Bf6f.js} +6 -10
  144. package/dist/storybook/assets/{onVisible.stories-DpDZP9_5.js → onVisible.stories-NNFeFeD8.js} +3 -3
  145. package/dist/storybook/assets/style-map-B99QiqCo.js +1 -0
  146. package/dist/storybook/assets/{syntaxhighlighter-ED5Y7EFY-Bz_DuQj8.js → syntaxhighlighter-ED5Y7EFY-BqQ-o9mS.js} +1 -1
  147. package/dist/storybook/box-illustration.svg +51 -0
  148. package/dist/storybook/cloud-illustration.svg +49 -0
  149. package/dist/storybook/docs-illustration.svg +92 -0
  150. package/dist/storybook/iframe.html +2 -2
  151. package/dist/storybook/index.json +1 -1
  152. package/dist/storybook/project.json +1 -1
  153. package/dist/tailwind-plugin-action-bar.d.ts +2 -0
  154. package/dist/tailwind-plugin-action-bar.d.ts.map +1 -0
  155. package/dist/tailwind-plugin-action-bar.js +120 -0
  156. package/dist/tailwind-plugin-action-bar.js.map +1 -0
  157. package/dist/tailwind-plugin-action-bar.ts +134 -0
  158. package/dist/tailwind-plugin-badge.js +5 -6
  159. package/dist/tailwind-plugin-badge.js.map +1 -1
  160. package/dist/tailwind-plugin-badge.ts +5 -6
  161. package/dist/tailwind-plugin-button-group.d.ts +2 -0
  162. package/dist/tailwind-plugin-button-group.d.ts.map +1 -0
  163. package/dist/tailwind-plugin-button-group.js +215 -0
  164. package/dist/tailwind-plugin-button-group.js.map +1 -0
  165. package/dist/tailwind-plugin-button-group.ts +238 -0
  166. package/dist/tailwind-plugin-button.js +2 -1
  167. package/dist/tailwind-plugin-button.js.map +1 -1
  168. package/dist/tailwind-plugin-button.ts +2 -1
  169. package/dist/tailwind-plugin-checkbox.d.ts +2 -0
  170. package/dist/tailwind-plugin-checkbox.d.ts.map +1 -0
  171. package/dist/tailwind-plugin-checkbox.js +246 -0
  172. package/dist/tailwind-plugin-checkbox.js.map +1 -0
  173. package/dist/tailwind-plugin-checkbox.ts +281 -0
  174. package/dist/tailwind-plugin-empty-state.d.ts +2 -0
  175. package/dist/tailwind-plugin-empty-state.d.ts.map +1 -0
  176. package/dist/tailwind-plugin-empty-state.js +113 -0
  177. package/dist/tailwind-plugin-empty-state.js.map +1 -0
  178. package/dist/tailwind-plugin-empty-state.ts +124 -0
  179. package/dist/tailwind-plugin-icon.js +122 -18
  180. package/dist/tailwind-plugin-icon.js.map +1 -1
  181. package/dist/tailwind-plugin-icon.ts +131 -18
  182. package/dist/tailwind-plugin-loader.js +3 -3
  183. package/dist/tailwind-plugin-loader.ts +3 -3
  184. package/dist/tailwind-plugin-pagination.js +13 -23
  185. package/dist/tailwind-plugin-pagination.js.map +1 -1
  186. package/dist/tailwind-plugin-pagination.ts +15 -25
  187. package/dist/tailwind-plugin-tabs.d.ts +2 -0
  188. package/dist/tailwind-plugin-tabs.d.ts.map +1 -0
  189. package/dist/tailwind-plugin-tabs.js +158 -0
  190. package/dist/tailwind-plugin-tabs.js.map +1 -0
  191. package/dist/tailwind-plugin-tabs.ts +169 -0
  192. package/dist/tailwind-plugin-upload.d.ts +2 -0
  193. package/dist/tailwind-plugin-upload.d.ts.map +1 -0
  194. package/dist/tailwind-plugin-upload.js +322 -0
  195. package/dist/tailwind-plugin-upload.js.map +1 -0
  196. package/dist/tailwind-plugin-upload.ts +362 -0
  197. package/dist/tailwind.config.d.ts.map +1 -1
  198. package/dist/tailwind.config.js +1 -0
  199. package/dist/tailwind.config.js.map +1 -1
  200. package/dist/tailwind.config.ts +1 -0
  201. package/dist/util/ClipboardMixin.d.ts +7 -2
  202. package/dist/util/ClipboardMixin.d.ts.map +1 -1
  203. package/dist/util/ClipboardMixin.js +15 -13
  204. package/dist/util/ClipboardMixin.js.map +1 -1
  205. package/dist/util/ComponentStatesMixin.d.ts +2 -1
  206. package/dist/util/ComponentStatesMixin.d.ts.map +1 -1
  207. package/dist/util/ComponentStatesMixin.js +4 -0
  208. package/dist/util/ComponentStatesMixin.js.map +1 -1
  209. package/dist/util/EventEmitterMixin.d.ts +58 -4
  210. package/dist/util/EventEmitterMixin.d.ts.map +1 -1
  211. package/dist/util/EventEmitterMixin.js +5 -2
  212. package/dist/util/EventEmitterMixin.js.map +1 -1
  213. package/dist/util/ProgressMixin.d.ts +9 -2
  214. package/dist/util/ProgressMixin.d.ts.map +1 -1
  215. package/dist/util/ProgressMixin.js +22 -18
  216. package/dist/util/ProgressMixin.js.map +1 -1
  217. package/dist/util/RovingTabindexMixin.d.ts +46 -0
  218. package/dist/util/RovingTabindexMixin.d.ts.map +1 -0
  219. package/dist/util/RovingTabindexMixin.js +83 -0
  220. package/dist/util/RovingTabindexMixin.js.map +1 -0
  221. package/dist/util/TetherLayout.d.ts.map +1 -1
  222. package/dist/util/TetherLayout.js +3 -0
  223. package/dist/util/TetherLayout.js.map +1 -1
  224. package/dist/util/TooltipMixin.d.ts.map +1 -1
  225. package/dist/util/TooltipMixin.js +5 -4
  226. package/dist/util/TooltipMixin.js.map +1 -1
  227. package/dist/util/upload.d.ts +53 -0
  228. package/dist/util/upload.d.ts.map +1 -0
  229. package/dist/util/upload.js +113 -0
  230. package/dist/util/upload.js.map +1 -0
  231. package/docs/components/ActionBar.md +77 -0
  232. package/docs/components/ActionItem.md +101 -0
  233. package/docs/components/Avatar.md +42 -12
  234. package/docs/components/AvatarGroup.md +4 -3
  235. package/docs/components/Badge.md +13 -1
  236. package/docs/components/ButtonGroup.md +91 -0
  237. package/docs/components/Checkbox.md +91 -0
  238. package/docs/components/CircularProgress.md +41 -12
  239. package/docs/components/CopyToClipboard.md +13 -11
  240. package/docs/components/Dropdown.md +51 -26
  241. package/docs/components/DropdownItem.md +44 -27
  242. package/docs/components/DropdownMenu.md +14 -14
  243. package/docs/components/EmptyState.md +75 -0
  244. package/docs/components/Icon.md +22 -14
  245. package/docs/components/IconButton.md +46 -21
  246. package/docs/components/LinearProgress.md +43 -4
  247. package/docs/components/Pagination.md +38 -34
  248. package/docs/components/Popover.md +16 -0
  249. package/docs/components/README.md +9 -0
  250. package/docs/components/Switch.md +21 -16
  251. package/docs/components/Tab.md +79 -0
  252. package/docs/components/Tabs.md +85 -0
  253. package/docs/components/Upload.md +112 -0
  254. package/docs/components/UploadItem.md +61 -0
  255. package/docs/components/Widget.md +12 -6
  256. package/package.json +4 -2
  257. package/dist/storybook/assets/Icon.stories-CPjM-jTU.js +0 -264
  258. package/dist/storybook/assets/Pagination.stories-C4cLjS_9.js +0 -272
  259. package/dist/storybook/assets/ReadyMixin-DNZ5dCsZ.js +0 -1
  260. package/dist/storybook/assets/ScrollShadow.stories-C3W5o9ZW.js +0 -17
  261. package/dist/storybook/assets/if-defined-BZFPaJjl.js +0 -1
  262. package/dist/storybook/assets/iframe-C5bIZMJ5.css +0 -1
  263. package/dist/storybook/assets/onFind-1l3EPW-I.js +0 -1
  264. package/dist/storybook/assets/style-map-CBrSnxRe.js +0 -1
@@ -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,
@@ -9,8 +9,7 @@ import plugin from 'tailwindcss/plugin';
9
9
  * btu-pagination-disabled - Disabled state
10
10
  * btu-pagination-loading - Loading state with dimmed controls
11
11
  * btu-pagination-nav - Inner nav wrapper
12
- * btu-pagination-size-changer - Page size select area
13
- * btu-pagination-select - Native select element
12
+ * btu-pagination-size-changer - Page size dropdown area
14
13
  * btu-pagination-total - "1-10 of 200" display
15
14
  * btu-pagination-controls - Button group container
16
15
  * btu-pagination-jumper - Slot area for custom jumper content
@@ -21,11 +20,9 @@ import plugin from 'tailwindcss/plugin';
21
20
  *
22
21
  * CSS Custom Properties:
23
22
  *
24
- * --pagination-color-background - Select background
23
+ * --pagination-color-background - Dropdown/button background
25
24
  * --pagination-color-foreground - Text/icon color
26
25
  */
27
- // Inline chevron-down SVG for select background
28
- const chevronDownSvg = `url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")`;
29
26
  module.exports = plugin(function ({ addComponents, config }) {
30
27
  const fontSize_sm = config('theme.fontSize.sm')?.[0] ?? '0.875rem';
31
28
  const fontSize_xs = config('theme.fontSize.xs')?.[0] ?? '0.75rem';
@@ -77,24 +74,6 @@ module.exports = plugin(function ({ addComponents, config }) {
77
74
  display: 'none',
78
75
  },
79
76
  },
80
- '.btu-pagination-select': {
81
- appearance: 'none',
82
- background: 'var(--pagination-color-background, var(--btu-theme-white, #fff))',
83
- border: '1px solid oklch(var(--btu-theme-gray-300))',
84
- borderRadius: '0.5rem',
85
- padding: '0.375rem 1.75rem 0.375rem 0.5rem',
86
- fontSize: fontSize_sm,
87
- color: 'inherit',
88
- cursor: 'pointer',
89
- backgroundImage: chevronDownSvg,
90
- backgroundRepeat: 'no-repeat',
91
- backgroundPosition: 'right 0.5rem center',
92
- backgroundSize: '1rem',
93
- '&:focus-visible': {
94
- outline: '2px solid oklch(var(--btu-theme-primary-400))',
95
- outlineOffset: '-1px',
96
- },
97
- },
98
77
  '.btu-pagination-total': {
99
78
  fontSize: fontSize_xs,
100
79
  color: 'oklch(var(--btu-theme-gray-500))',
@@ -147,6 +126,17 @@ module.exports = plugin(function ({ addComponents, config }) {
147
126
  borderRight: '1px solid oklch(var(--btu-theme-gray-200))',
148
127
  },
149
128
  },
129
+ // Dropdown integration: page size changer
130
+ '.btu-pagination-size-changer > btu-dropdown > .btu-button': {
131
+ '--button-color': 'var(--pagination-color-background, var(--btu-theme-white, #fff))',
132
+ '--button-text-color': 'var(--pagination-color-foreground, oklch(var(--btu-theme-gray-700)))',
133
+ },
134
+ // Dropdown integration: jumper (blends into button group)
135
+ '.btu-pagination-jumper > btu-dropdown > .btu-button': {
136
+ '--button-border-radius': '0',
137
+ '--button-color': 'var(--pagination-color-background, var(--btu-theme-white, #fff))',
138
+ '--button-text-color': 'var(--pagination-color-foreground, oklch(var(--btu-theme-gray-700)))',
139
+ },
150
140
  });
151
141
  });
152
142
  //# sourceMappingURL=tailwind-plugin-pagination.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tailwind-plugin-pagination.js","sourceRoot":"","sources":["../src/tailwind-plugin-pagination.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"tailwind-plugin-pagination.js","sourceRoot":"","sources":["../src/tailwind-plugin-pagination.ts"],"names":[],"mappings":"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"}
@@ -11,8 +11,7 @@ declare let module: any
11
11
  * btu-pagination-disabled - Disabled state
12
12
  * btu-pagination-loading - Loading state with dimmed controls
13
13
  * btu-pagination-nav - Inner nav wrapper
14
- * btu-pagination-size-changer - Page size select area
15
- * btu-pagination-select - Native select element
14
+ * btu-pagination-size-changer - Page size dropdown area
16
15
  * btu-pagination-total - "1-10 of 200" display
17
16
  * btu-pagination-controls - Button group container
18
17
  * btu-pagination-jumper - Slot area for custom jumper content
@@ -23,13 +22,10 @@ declare let module: any
23
22
  *
24
23
  * CSS Custom Properties:
25
24
  *
26
- * --pagination-color-background - Select background
25
+ * --pagination-color-background - Dropdown/button background
27
26
  * --pagination-color-foreground - Text/icon color
28
27
  */
29
28
 
30
- // Inline chevron-down SVG for select background
31
- const chevronDownSvg = `url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")`
32
-
33
29
  module.exports = plugin(function ({ addComponents, config }) {
34
30
  const fontSize_sm = config('theme.fontSize.sm')?.[0] ?? '0.875rem'
35
31
  const fontSize_xs = config('theme.fontSize.xs')?.[0] ?? '0.75rem'
@@ -88,25 +84,6 @@ module.exports = plugin(function ({ addComponents, config }) {
88
84
  },
89
85
  },
90
86
 
91
- '.btu-pagination-select': {
92
- appearance: 'none',
93
- background: 'var(--pagination-color-background, var(--btu-theme-white, #fff))',
94
- border: '1px solid oklch(var(--btu-theme-gray-300))',
95
- borderRadius: '0.5rem',
96
- padding: '0.375rem 1.75rem 0.375rem 0.5rem',
97
- fontSize: fontSize_sm,
98
- color: 'inherit',
99
- cursor: 'pointer',
100
- backgroundImage: chevronDownSvg,
101
- backgroundRepeat: 'no-repeat',
102
- backgroundPosition: 'right 0.5rem center',
103
- backgroundSize: '1rem',
104
- '&:focus-visible': {
105
- outline: '2px solid oklch(var(--btu-theme-primary-400))',
106
- outlineOffset: '-1px',
107
- },
108
- },
109
-
110
87
  '.btu-pagination-total': {
111
88
  fontSize: fontSize_xs,
112
89
  color: 'oklch(var(--btu-theme-gray-500))',
@@ -164,5 +141,18 @@ module.exports = plugin(function ({ addComponents, config }) {
164
141
  borderRight: '1px solid oklch(var(--btu-theme-gray-200))',
165
142
  },
166
143
  },
144
+
145
+ // Dropdown integration: page size changer
146
+ '.btu-pagination-size-changer > btu-dropdown > .btu-button': {
147
+ '--button-color': 'var(--pagination-color-background, var(--btu-theme-white, #fff))',
148
+ '--button-text-color': 'var(--pagination-color-foreground, oklch(var(--btu-theme-gray-700)))',
149
+ },
150
+
151
+ // Dropdown integration: jumper (blends into button group)
152
+ '.btu-pagination-jumper > btu-dropdown > .btu-button': {
153
+ '--button-border-radius': '0',
154
+ '--button-color': 'var(--pagination-color-background, var(--btu-theme-white, #fff))',
155
+ '--button-text-color': 'var(--pagination-color-foreground, oklch(var(--btu-theme-gray-700)))',
156
+ },
167
157
  })
168
158
  })
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=tailwind-plugin-tabs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tailwind-plugin-tabs.d.ts","sourceRoot":"","sources":["../src/tailwind-plugin-tabs.ts"],"names":[],"mappings":""}