@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.
- package/dist/components/action-bar/ActionBar.d.ts +1 -1
- package/dist/components/action-bar/ActionBar.js +7 -7
- package/dist/components/action-bar/ActionBar.js.map +1 -1
- package/dist/components/action-bar/ActionItem.d.ts +5 -5
- package/dist/components/action-bar/ActionItem.d.ts.map +1 -1
- package/dist/components/action-bar/ActionItem.js +13 -13
- package/dist/components/action-bar/ActionItem.js.map +1 -1
- package/dist/components/avatar/AvatarGroup.d.ts +3 -0
- package/dist/components/avatar/AvatarGroup.d.ts.map +1 -1
- package/dist/components/avatar/AvatarGroup.js +3 -0
- package/dist/components/avatar/AvatarGroup.js.map +1 -1
- package/dist/components/badge/Badge.d.ts +3 -1
- package/dist/components/badge/Badge.d.ts.map +1 -1
- package/dist/components/badge/Badge.js +2 -0
- package/dist/components/badge/Badge.js.map +1 -1
- package/dist/components/button-group/ButtonGroup.d.ts +138 -0
- package/dist/components/button-group/ButtonGroup.d.ts.map +1 -0
- package/dist/components/button-group/ButtonGroup.js +436 -0
- package/dist/components/button-group/ButtonGroup.js.map +1 -0
- package/dist/components/checkbox/Checkbox.d.ts +107 -0
- package/dist/components/checkbox/Checkbox.d.ts.map +1 -0
- package/dist/components/checkbox/Checkbox.js +224 -0
- package/dist/components/checkbox/Checkbox.js.map +1 -0
- package/dist/components/circular-progress/CircularProgress.d.ts +2 -2
- package/dist/components/circular-progress/CircularProgress.js +2 -2
- package/dist/components/copy-to-clipboard/CopyToClipboard.d.ts +7 -2
- package/dist/components/copy-to-clipboard/CopyToClipboard.d.ts.map +1 -1
- package/dist/components/copy-to-clipboard/CopyToClipboard.js +10 -5
- package/dist/components/copy-to-clipboard/CopyToClipboard.js.map +1 -1
- package/dist/components/dropdown/Dropdown.d.ts +5 -5
- package/dist/components/dropdown/Dropdown.d.ts.map +1 -1
- package/dist/components/dropdown/Dropdown.js +11 -16
- package/dist/components/dropdown/Dropdown.js.map +1 -1
- package/dist/components/dropdown/DropdownItem.d.ts +14 -6
- package/dist/components/dropdown/DropdownItem.d.ts.map +1 -1
- package/dist/components/dropdown/DropdownItem.js +21 -15
- package/dist/components/dropdown/DropdownItem.js.map +1 -1
- package/dist/components/dropdown/DropdownMenu.d.ts +4 -4
- package/dist/components/dropdown/DropdownMenu.d.ts.map +1 -1
- package/dist/components/dropdown/DropdownMenu.js +6 -6
- package/dist/components/dropdown/DropdownMenu.js.map +1 -1
- package/dist/components/empty-state/EmptyState.css +4 -0
- package/dist/components/empty-state/EmptyState.d.ts +103 -0
- package/dist/components/empty-state/EmptyState.d.ts.map +1 -0
- package/dist/components/empty-state/EmptyState.js +209 -0
- package/dist/components/empty-state/EmptyState.js.map +1 -0
- package/dist/components/icon/Icon.d.ts +23 -10
- package/dist/components/icon/Icon.d.ts.map +1 -1
- package/dist/components/icon/Icon.js +40 -9
- package/dist/components/icon/Icon.js.map +1 -1
- package/dist/components/icon-button/IconButton.d.ts +7 -21
- package/dist/components/icon-button/IconButton.d.ts.map +1 -1
- package/dist/components/icon-button/IconButton.js +12 -18
- package/dist/components/icon-button/IconButton.js.map +1 -1
- package/dist/components/linear-progress/LinearProgress.d.ts +2 -2
- package/dist/components/linear-progress/LinearProgress.js +2 -2
- package/dist/components/pagination/Pagination.js +10 -10
- package/dist/components/popover/Popover.d.ts +6 -0
- package/dist/components/popover/Popover.d.ts.map +1 -1
- package/dist/components/popover/Popover.js +6 -0
- package/dist/components/popover/Popover.js.map +1 -1
- package/dist/components/switch/Switch.d.ts +5 -1
- package/dist/components/switch/Switch.d.ts.map +1 -1
- package/dist/components/switch/Switch.js +10 -6
- package/dist/components/switch/Switch.js.map +1 -1
- package/dist/components/tabs/Tab.d.ts +4 -4
- package/dist/components/tabs/Tab.d.ts.map +1 -1
- package/dist/components/tabs/Tab.js +5 -5
- package/dist/components/tabs/Tab.js.map +1 -1
- package/dist/components/tabs/Tabs.d.ts +3 -3
- package/dist/components/tabs/Tabs.d.ts.map +1 -1
- package/dist/components/tabs/Tabs.js +20 -20
- package/dist/components/tabs/Tabs.js.map +1 -1
- package/dist/components/upload/Upload.d.ts +157 -0
- package/dist/components/upload/Upload.d.ts.map +1 -0
- package/dist/components/upload/Upload.js +538 -0
- package/dist/components/upload/Upload.js.map +1 -0
- package/dist/components/upload/UploadItem.d.ts +73 -0
- package/dist/components/upload/UploadItem.d.ts.map +1 -0
- package/dist/components/upload/UploadItem.js +180 -0
- package/dist/components/upload/UploadItem.js.map +1 -0
- package/dist/components/widget/Widget.d.ts +1 -6
- package/dist/components/widget/Widget.d.ts.map +1 -1
- package/dist/components/widget/Widget.js +1 -6
- package/dist/components/widget/Widget.js.map +1 -1
- package/dist/custom-elements.json +7499 -2087
- package/dist/storybook/assets/{ActionBar.stories--nAeDC-G.js → ActionBar.stories-DRIVI-W2.js} +65 -65
- package/dist/storybook/assets/{ActionItem.stories-BHrGjk-P.js → ActionItem.stories-5qlgxYNB.js} +41 -41
- package/dist/storybook/assets/{Avatar.stories-Da-mRj6_.js → Avatar.stories-B3VkhRhP.js} +2 -2
- package/dist/storybook/assets/{AvatarGroup.stories-BQlaC_yl.js → AvatarGroup.stories-DOfim2NY.js} +5 -5
- package/dist/storybook/assets/{Badge.stories-DnVnOrnF.js → Badge.stories-B04VNAcc.js} +2 -2
- package/dist/storybook/assets/{Button-CFLAI1H9.js → Button-CILTcGRT.js} +1 -1
- package/dist/storybook/assets/{Button.stories-DxaBOjwv.js → Button.stories-CzWAltrX.js} +1 -1
- package/dist/storybook/assets/ButtonGroup.stories-1uAJf79o.js +588 -0
- package/dist/storybook/assets/{Celebrate.stories-CuMm15Nr.js → Celebrate.stories-BEqj0VnW.js} +7 -7
- package/dist/storybook/assets/Checkbox.stories-DXAGFS0M.js +141 -0
- package/dist/storybook/assets/{CircularProgress.stories-DRN8Mtvj.js → CircularProgress.stories-D4rftw22.js} +7 -7
- package/dist/storybook/assets/{ClipboardMixin.stories-DR7Ou2Av.js → ClipboardMixin.stories-z2n2HWt1.js} +31 -28
- package/dist/storybook/assets/{Color-6BZIO3FS-Die62Y0Z.js → Color-6BZIO3FS-C6KyMgZz.js} +1 -1
- package/dist/storybook/assets/{Colors.stories-bIq_ssbI.js → Colors.stories-CX-Ny3B_.js} +1 -1
- package/dist/storybook/assets/{CombinedEffects.stories-CtKzOUZn.js → CombinedEffects.stories-BkqtiVHp.js} +33 -33
- package/dist/storybook/assets/{ComponentStatesMixin-DMLCk9fE.js → ComponentStatesMixin-DLd0feFg.js} +1 -1
- package/dist/storybook/assets/{ComponentStatesMixin.stories-D8UI9o-d.js → ComponentStatesMixin.stories-D6Yc5Jgl.js} +3 -3
- package/dist/storybook/assets/{CopyToClipboard.stories-ti6CpJNp.js → CopyToClipboard.stories-B-omwDDJ.js} +16 -16
- package/dist/storybook/assets/{Debounce.stories-DzZUSvbk.js → Debounce.stories-B2vE5QIx.js} +9 -9
- package/dist/storybook/assets/{DocsRenderer-LL677BLK-CIRGv5IX.js → DocsRenderer-LL677BLK-DNUlRvMg.js} +3 -3
- package/dist/storybook/assets/{Dropdown.stories-Lt4cY0Re.js → Dropdown.stories-_bx4WDLr.js} +60 -60
- package/dist/storybook/assets/EmptyState.stories-CGMbmo77.js +318 -0
- package/dist/storybook/assets/{Events.stories-B1ddcgpT.js → Events.stories-CkQYKcoZ.js} +1 -1
- package/dist/storybook/assets/{Heading.stories-DI4w61cf.js → Heading.stories-BU5Do_od.js} +1 -1
- package/dist/storybook/assets/{HueRipple.stories-DjhoxxEw.js → HueRipple.stories-Di2zmxo3.js} +11 -11
- package/dist/storybook/assets/Icon.stories-Dk4ZXhhJ.js +441 -0
- package/dist/storybook/assets/{IconButton.stories-KjN28hfc.js → IconButton.stories-BSCiXPXa.js} +126 -146
- package/dist/storybook/assets/{LinearProgress.stories-DcIpdz6R.js → LinearProgress.stories-BGxPZuni.js} +7 -7
- package/dist/storybook/assets/{Pagination.stories-BBkLEwoP.js → Pagination.stories-z3Zq8b4f.js} +6 -6
- package/dist/storybook/assets/{Popover.stories-DLv48c2h.js → Popover.stories-C9GxWcax.js} +33 -62
- package/dist/storybook/assets/ReadyMixin-CQw8N6P9.js +1 -0
- package/dist/storybook/assets/{RovingTabindexMixin.stories-BWaFx9mu.js → RovingTabindexMixin.stories-ByxLBi6m.js} +6 -6
- package/dist/storybook/assets/{Rtc.stories-Ve7Bwo_l.js → Rtc.stories-DQJlCXWR.js} +3 -3
- package/dist/storybook/assets/{ScrollShadow.stories-C6XmrRLm.js → ScrollShadow.stories-gjTIAbUA.js} +2 -2
- package/dist/storybook/assets/{Switch.stories-Cf8WM1LG.js → Switch.stories-BEeqPZiP.js} +21 -21
- package/dist/storybook/assets/{Tab.stories-CEtdEtOx.js → Tab.stories-DpB3I-WZ.js} +33 -33
- package/dist/storybook/assets/{Tabs.stories-CIAO1bPO.js → Tabs.stories-C6mG6Xi7.js} +2 -2
- package/dist/storybook/assets/{Throttle.stories-BqxVIb-r.js → Throttle.stories-x9tpGeQh.js} +10 -10
- package/dist/storybook/assets/{Tooltip.stories-B6fw6875.js → Tooltip.stories-CqcLqdmc.js} +2 -2
- package/dist/storybook/assets/Upload.stories-CMaAbCSH.js +447 -0
- package/dist/storybook/assets/UploadItem.stories-GB98L3JQ.js +167 -0
- package/dist/storybook/assets/{Welcome.stories-CfJtSM19.js → Welcome.stories-6h9cUZ7v.js} +1 -1
- package/dist/storybook/assets/{Widget.stories-CiOho7lO.js → Widget.stories-DiA1PR6Y.js} +13 -13
- package/dist/storybook/assets/{WithTooltip-65CFNBJE-PGcopp73.js → WithTooltip-65CFNBJE-DTsHhBb_.js} +1 -1
- package/dist/storybook/assets/{blocks-dP2DwISI.js → blocks-IXdn9TGW.js} +5 -5
- package/dist/storybook/assets/{formatter-EIJCOSYU-CZSAC3tg.js → formatter-EIJCOSYU-Cum4J6N4.js} +1 -1
- package/dist/storybook/assets/if-defined-CgfCxQoV.js +1 -0
- package/dist/storybook/assets/iframe-BgFj0b5u.css +1 -0
- package/dist/storybook/assets/{iframe-DloIUNZz.js → iframe-Sf9RHZFu.js} +191 -191
- package/dist/storybook/assets/{index-DKF0ypu5.js → index-D605PvQH.js} +1 -1
- package/dist/storybook/assets/{onFind-C0l4Gew0.js → onFind-C41m8c_a.js} +1 -1
- package/dist/storybook/assets/{onFind.stories-DOTt9puO.js → onFind.stories-MOTfGlJd.js} +53 -77
- package/dist/storybook/assets/{onRemove.stories-CQ9ZC5dm.js → onRemove.stories-DX58Bf6f.js} +6 -10
- package/dist/storybook/assets/{onVisible.stories-Cbj5_Vz0.js → onVisible.stories-NNFeFeD8.js} +3 -3
- package/dist/storybook/assets/{style-map-DLXysq3r.js → style-map-B99QiqCo.js} +1 -1
- package/dist/storybook/assets/{syntaxhighlighter-ED5Y7EFY-Bjjbl9ca.js → syntaxhighlighter-ED5Y7EFY-BqQ-o9mS.js} +1 -1
- package/dist/storybook/box-illustration.svg +51 -0
- package/dist/storybook/cloud-illustration.svg +49 -0
- package/dist/storybook/docs-illustration.svg +92 -0
- package/dist/storybook/iframe.html +2 -2
- package/dist/storybook/index.json +1 -1
- package/dist/storybook/project.json +1 -1
- package/dist/tailwind-plugin-badge.js +1 -1
- package/dist/tailwind-plugin-badge.ts +1 -1
- package/dist/tailwind-plugin-button-group.d.ts +2 -0
- package/dist/tailwind-plugin-button-group.d.ts.map +1 -0
- package/dist/tailwind-plugin-button-group.js +215 -0
- package/dist/tailwind-plugin-button-group.js.map +1 -0
- package/dist/tailwind-plugin-button-group.ts +238 -0
- package/dist/tailwind-plugin-button.js +1 -1
- package/dist/tailwind-plugin-button.ts +1 -1
- package/dist/tailwind-plugin-checkbox.d.ts +2 -0
- package/dist/tailwind-plugin-checkbox.d.ts.map +1 -0
- package/dist/tailwind-plugin-checkbox.js +246 -0
- package/dist/tailwind-plugin-checkbox.js.map +1 -0
- package/dist/tailwind-plugin-checkbox.ts +281 -0
- package/dist/tailwind-plugin-empty-state.d.ts +2 -0
- package/dist/tailwind-plugin-empty-state.d.ts.map +1 -0
- package/dist/tailwind-plugin-empty-state.js +113 -0
- package/dist/tailwind-plugin-empty-state.js.map +1 -0
- package/dist/tailwind-plugin-empty-state.ts +124 -0
- package/dist/tailwind-plugin-icon.js +122 -18
- package/dist/tailwind-plugin-icon.js.map +1 -1
- package/dist/tailwind-plugin-icon.ts +131 -18
- package/dist/tailwind-plugin-loader.js +3 -3
- package/dist/tailwind-plugin-loader.ts +3 -3
- package/dist/tailwind-plugin-tabs.js +7 -0
- package/dist/tailwind-plugin-tabs.js.map +1 -1
- package/dist/tailwind-plugin-tabs.ts +7 -0
- package/dist/tailwind-plugin-upload.d.ts +2 -0
- package/dist/tailwind-plugin-upload.d.ts.map +1 -0
- package/dist/tailwind-plugin-upload.js +322 -0
- package/dist/tailwind-plugin-upload.js.map +1 -0
- package/dist/tailwind-plugin-upload.ts +362 -0
- package/dist/tailwind.config.d.ts.map +1 -1
- package/dist/tailwind.config.js +1 -0
- package/dist/tailwind.config.js.map +1 -1
- package/dist/tailwind.config.ts +1 -0
- package/dist/util/ClipboardMixin.d.ts +7 -2
- package/dist/util/ClipboardMixin.d.ts.map +1 -1
- package/dist/util/ClipboardMixin.js +15 -13
- package/dist/util/ClipboardMixin.js.map +1 -1
- package/dist/util/ComponentStatesMixin.d.ts +2 -1
- package/dist/util/ComponentStatesMixin.d.ts.map +1 -1
- package/dist/util/ComponentStatesMixin.js +4 -0
- package/dist/util/ComponentStatesMixin.js.map +1 -1
- package/dist/util/EventEmitterMixin.d.ts +42 -4
- package/dist/util/EventEmitterMixin.d.ts.map +1 -1
- package/dist/util/EventEmitterMixin.js +5 -2
- package/dist/util/EventEmitterMixin.js.map +1 -1
- package/dist/util/ProgressMixin.d.ts +9 -2
- package/dist/util/ProgressMixin.d.ts.map +1 -1
- package/dist/util/ProgressMixin.js +22 -18
- package/dist/util/ProgressMixin.js.map +1 -1
- package/dist/util/RovingTabindexMixin.d.ts +8 -0
- package/dist/util/RovingTabindexMixin.d.ts.map +1 -1
- package/dist/util/RovingTabindexMixin.js +8 -8
- package/dist/util/RovingTabindexMixin.js.map +1 -1
- package/dist/util/TetherLayout.d.ts.map +1 -1
- package/dist/util/TetherLayout.js +3 -0
- package/dist/util/TetherLayout.js.map +1 -1
- package/dist/util/TooltipMixin.d.ts.map +1 -1
- package/dist/util/TooltipMixin.js +5 -4
- package/dist/util/TooltipMixin.js.map +1 -1
- package/dist/util/upload.d.ts +53 -0
- package/dist/util/upload.d.ts.map +1 -0
- package/dist/util/upload.js +113 -0
- package/dist/util/upload.js.map +1 -0
- package/docs/components/ActionBar.md +6 -0
- package/docs/components/ActionItem.md +52 -27
- package/docs/components/Avatar.md +42 -12
- package/docs/components/AvatarGroup.md +4 -3
- package/docs/components/Badge.md +13 -1
- package/docs/components/ButtonGroup.md +91 -0
- package/docs/components/Checkbox.md +91 -0
- package/docs/components/CircularProgress.md +41 -12
- package/docs/components/CopyToClipboard.md +13 -11
- package/docs/components/Dropdown.md +44 -19
- package/docs/components/DropdownItem.md +39 -26
- package/docs/components/DropdownMenu.md +9 -9
- package/docs/components/EmptyState.md +75 -0
- package/docs/components/Icon.md +22 -14
- package/docs/components/IconButton.md +46 -21
- package/docs/components/LinearProgress.md +43 -4
- package/docs/components/Pagination.md +11 -10
- package/docs/components/Popover.md +16 -0
- package/docs/components/README.md +5 -0
- package/docs/components/Switch.md +21 -16
- package/docs/components/Tab.md +8 -2
- package/docs/components/Tabs.md +8 -0
- package/docs/components/Upload.md +112 -0
- package/docs/components/UploadItem.md +61 -0
- package/docs/components/Widget.md +12 -6
- package/package.json +4 -2
- package/dist/storybook/assets/Icon.stories-CpziAhae.js +0 -264
- package/dist/storybook/assets/ReadyMixin-Cw2Dfbu2.js +0 -1
- package/dist/storybook/assets/if-defined-B1RdczOE.js +0 -1
- 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|{
|
|
18
|
-
* btu-icon-gradient-
|
|
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 `--
|
|
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:[--
|
|
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(--
|
|
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(--
|
|
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(--
|
|
53
|
-
'block-size': 'var(--
|
|
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
|
-
'--
|
|
59
|
-
mask: 'var(--
|
|
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(--
|
|
63
|
-
'block-size': 'var(--
|
|
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(--
|
|
100
|
-
width: 'var(--
|
|
101
|
-
height: 'var(--
|
|
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
|
-
'--
|
|
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":"AAAA,OAAO,KAAK,aAAa,MAAM,sCAAsC,CAAA;AACrE,OAAO,KAAK,MAAM,8BAA8B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAA;AACtE,OAAO,MAAM,MAAM,oBAAoB,CAAA;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAChD,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAG1D
|
|
1
|
+
{"version":3,"file":"tailwind-plugin-icon.js","sourceRoot":"","sources":["../src/tailwind-plugin-icon.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,aAAa,MAAM,sCAAsC,CAAA;AACrE,OAAO,KAAK,MAAM,8BAA8B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAA;AACtE,OAAO,MAAM,MAAM,oBAAoB,CAAA;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAChD,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAG1D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AAEH,MAAM,IAAI,GAA2B,EAAE,CAAA;AACvC,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;IACzD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAA;IACnB,CAAC;AACH,CAAC;AAED,MAAM,CAAC,OAAO,GAAG,MAAM,CACrB,UAAU,EAAE,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,KAAK,EAAE;IACzD,MAAM,IAAI,GAAG,kBAAkB,CAAA;IAC/B,MAAM,MAAM,GAAG,YAAY,CAAA;IAE3B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC1C,aAAa,CAAC;YACZ,CAAC,GAAG,MAAM,UAAU,CAAC,EAAE;gBACrB,QAAQ,EAAE,SAAS;gBACnB,IAAI,EAAE,0FAA0F;gBAChG,WAAW,EAAE,OAAO;gBACpB,cAAc,EAAE,GAAG;gBACnB,aAAa,EAAE,+BAA+B;gBAC9C,YAAY,EAAE,+BAA+B;gBAC7C,OAAO,EAAE,cAAc;aACxB;YACD,CAAC,GAAG,MAAM,YAAY,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;gBAC3C,QAAQ,EAAE,SAAS;gBACnB,YAAY,EAAE,2BAA2B,SAAS,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,IAAI;gBAC5E,IAAI,EAAE,4CAA4C;gBAClD,WAAW,EAAE,OAAO;gBACpB,cAAc,EAAE,GAAG;gBACnB,aAAa,EAAE,+BAA+B;gBAC9C,YAAY,EAAE,+BAA+B;gBAC7C,OAAO,EAAE,cAAc;aACxB;SACF,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,aAAa,CAAC;QACZ,WAAW,EAAE;YACX,aAAa,EAAE,KAAK,CAAC,mBAAmB,CAAC;YACzC,SAAS,EAAE,KAAK;YAChB,OAAO,EAAE,aAAa;YACtB,uBAAuB,EAAE,UAAU;YACnC,yBAAyB,EAAE,WAAW;YACtC,wBAAwB,EAAE,aAAa;YACvC,WAAW,EAAE,IAAI;YACjB,YAAY,EAAE,QAAQ;YACtB,aAAa,EAAE,QAAQ;YACvB,gBAAgB,EAAE,QAAQ;YAC1B,aAAa,EAAE,IAAI;YACnB,gBAAgB,EAAE,MAAM;YACxB,aAAa,EAAE,QAAQ;YACvB,WAAW,EAAE,QAAQ;YACrB,gBAAgB,EAAE,KAAK;SACxB;KACF,CAAC,CAAA;IAEF,aAAa,CACX,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;QAChC,OAAO;YACL,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;gBACnB,cAAc,EAAE,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,GAAG;aAC5C;SACF,CAAA;IACH,CAAC,CAAC,CACH,CAAA;IACD,cAAc,CACZ;QACE,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,CAAC;YAC7B,kBAAkB,EAAE,KAAK;YACzB,mBAAmB,EAAE,WAAW;YAChC,qBAAqB,EAAE,QAAQ;YAC/B,iBAAiB,EAAE,mDAAmD;YACtE,KAAK,EAAE,0BAA0B;YACjC,MAAM,EAAE,0BAA0B;YAClC,OAAO,EAAE,cAAc;SACxB,CAAC;KACH,EACD;QACE,MAAM,EAAE;YACN,EAAE,EAAE,oCAAoC;YACxC,KAAK,EAAE,uCAAuC;YAC9C,IAAI,EAAE,sCAAsC;YAC5C,OAAO,EAAE,yCAAyC;YAClD,MAAM,EAAE,wCAAwC;YAChD,IAAI,EAAE,sCAAsC;YAC5C,OAAO,EAAE,yCAAyC;YAClD,IAAI,EAAE,sCAAsC;YAC5C,OAAO,EAAE,yCAAyC;SACnD;KACF,CACF,CAAA;IACD,cAAc,CACZ;QACE,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,CAAC;YACpB,aAAa,EAAE,KAAK;SACrB,CAAC;KACH,EACD,EAAE,MAAM,EAAE,KAAK,CAAC,UAAU,CAAC,EAAE,CAC9B,CAAA;IAED,wDAAwD;IACxD,SAAS,KAAK,CAAC,CAAS,EAAE,IAAY,EAAE,IAAa;QACnD,MAAM,MAAM,GAAG,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,gBAAgB,IAAI,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,YAAY,IAAI,GAAG,CAAA;QACrF,OAAO,2BAA2B,CAAC,IAAI,MAAM,KAAK,CAAA;IACpD,CAAC;IAED,MAAM,WAAW,GAAG;QAClB,eAAe,EAAE,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;QAChC,eAAe,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC;QAClC,WAAW,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC;KAC9B,CAAA;IACD,MAAM,UAAU,GAAG;QACjB,eAAe,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,CAAC;QACvC,eAAe,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,CAAC;QACvC,WAAW,EAAE,KAAK,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC;KACnC,CAAA;IACD,MAAM,kBAAkB,GAAG;QACzB,eAAe,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC;QACjC,eAAe,EAAE,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC;QACjC,WAAW,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC;KAC9B,CAAA;IAED,kEAAkE;IAClE,OAAO,CAAC;QACN,iCAAiC,EAAE;YACjC,IAAI,EAAE,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,KAAK,EAAE;YAC/C,KAAK,EAAE,EAAE,SAAS,EAAE,2BAA2B,EAAE,OAAO,EAAE,KAAK,EAAE;YACjE,MAAM,EAAE,EAAE,SAAS,EAAE,2BAA2B,EAAE,OAAO,EAAE,GAAG,EAAE;SACjE;KACF,CAAC,CAAA;IAEF,aAAa,CAAC;QACZ,qBAAqB,EAAE;YACrB,QAAQ,EAAE,UAAU;YACpB,OAAO,EAAE,aAAa;YACtB,UAAU,EAAE,QAAQ;YACpB,cAAc,EAAE,QAAQ;YACxB,YAAY,EAAE,QAAQ;YACtB,WAAW,EAAE,OAAO;YACpB,KAAK,EAAE,qCAAqC;YAC5C,GAAG,WAAW;SACf;QAED,+EAA+E;QAC/E,iCAAiC,EAAE;YACjC,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE,QAAQ;YAChB,WAAW,EAAE,KAAK;YAClB,eAAe,EAAE,MAAM;SACxB;QACD,iCAAiC,EAAE;YACjC,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,WAAW,EAAE,KAAK;YAClB,eAAe,EAAE,MAAM;SACxB;QACD,iCAAiC,EAAE;YACjC,KAAK,EAAE,SAAS;YAChB,MAAM,EAAE,SAAS;YACjB,WAAW,EAAE,KAAK;YAClB,eAAe,EAAE,KAAK;SACvB;QACD,iCAAiC,EAAE;YACjC,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,WAAW,EAAE,KAAK;YAClB,eAAe,EAAE,MAAM;SACxB;QACD,iCAAiC,EAAE;YACjC,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE,QAAQ;YAChB,WAAW,EAAE,MAAM;YACnB,eAAe,EAAE,KAAK;SACvB;QAED,qEAAqE;QACrE,mCAAmC,EAAE;YACnC,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,UAAU;YACpB,KAAK,EAAE,GAAG;YACV,YAAY,EAAE,QAAQ;YACtB,eAAe,EAAE,oBAAoB;YACrC,OAAO,EAAE,GAAG;YACZ,SAAS,EAAE,iDAAiD;YAC5D,aAAa,EAAE,MAAM;SACtB;QAED,uBAAuB;QACvB,8BAA8B,EAAE,UAAU;QAC1C,kCAAkC,EAAE,EAAE,KAAK,EAAE,iBAAiB,EAAE;QAChE,qCAAqC,EAAE;YACrC,qFAAqF,EAAE,UAAU;YACjG,yFAAyF,EAAE;gBACzF,KAAK,EAAE,iBAAiB;aACzB;SACF;QAED,2BAA2B;QAC3B,2CAA2C,EAAE,kBAAkB;QAC/D,sEAAsE,EAAE;YACtE,mDAAmD,EAAE,kBAAkB;SACxE;QAED,4BAA4B;QAC5B,yCAAyC,EAAE;YACzC,mCAAmC,EAAE;gBACnC,iBAAiB,EAAE,QAAQ;gBAC3B,cAAc,EAAE,KAAK;aACtB;SACF;KACF,CAAC,CAAA;AACJ,CAAC,EACD;IACE,KAAK,EAAE;QACL,QAAQ,EAAE;YACR,OAAO,EAAE,SAAS;YAClB,EAAE,EAAE,SAAS;YACb,EAAE,EAAE,MAAM;YACV,EAAE,EAAE,SAAS;YACb,EAAE,EAAE,QAAQ;YACZ,EAAE,EAAE,SAAS;SACd;KACF;CACF,CACF,CAAA"}
|
|
@@ -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|{
|
|
20
|
-
* btu-icon-gradient-
|
|
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 `--
|
|
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:[--
|
|
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(--
|
|
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(--
|
|
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(--
|
|
59
|
-
'block-size': 'var(--
|
|
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
|
-
'--
|
|
65
|
-
mask: 'var(--
|
|
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(--
|
|
69
|
-
'block-size': 'var(--
|
|
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(--
|
|
111
|
-
width: 'var(--
|
|
112
|
-
height: 'var(--
|
|
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
|
-
'--
|
|
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
|
-
* --
|
|
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
|
-
'--
|
|
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 --
|
|
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
|
-
* --
|
|
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
|
-
'--
|
|
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 --
|
|
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":"AAAA,OAAO,MAAM,MAAM,oBAAoB,CAAA;AAGvC
|
|
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 @@
|
|
|
1
|
+
{"version":3,"file":"tailwind-plugin-upload.d.ts","sourceRoot":"","sources":["../src/tailwind-plugin-upload.ts"],"names":[],"mappings":""}
|