@shipfox/react-ui 0.13.0 → 0.15.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 (268) hide show
  1. package/.storybook/preview.tsx +7 -0
  2. package/.turbo/turbo-build.log +7 -7
  3. package/.turbo/turbo-check.log +2 -2
  4. package/.turbo/turbo-type.log +1 -1
  5. package/CHANGELOG.md +16 -0
  6. package/dist/components/avatar/avatar.js +1 -1
  7. package/dist/components/avatar/avatar.js.map +1 -1
  8. package/dist/components/button-group/button-group.d.ts +17 -0
  9. package/dist/components/button-group/button-group.d.ts.map +1 -0
  10. package/dist/components/button-group/button-group.js +74 -0
  11. package/dist/components/button-group/button-group.js.map +1 -0
  12. package/dist/components/button-group/button-group.stories.js +644 -0
  13. package/dist/components/button-group/button-group.stories.js.map +1 -0
  14. package/dist/components/button-group/index.d.ts +2 -0
  15. package/dist/components/button-group/index.d.ts.map +1 -0
  16. package/dist/components/button-group/index.js +3 -0
  17. package/dist/components/button-group/index.js.map +1 -0
  18. package/dist/components/code-block/code-block-footer.d.ts.map +1 -1
  19. package/dist/components/code-block/code-block-footer.js +13 -5
  20. package/dist/components/code-block/code-block-footer.js.map +1 -1
  21. package/dist/components/command/command.d.ts +28 -0
  22. package/dist/components/command/command.d.ts.map +1 -0
  23. package/dist/components/command/command.js +190 -0
  24. package/dist/components/command/command.js.map +1 -0
  25. package/dist/components/command/command.stories.js +228 -0
  26. package/dist/components/command/command.stories.js.map +1 -0
  27. package/dist/components/command/index.d.ts +2 -0
  28. package/dist/components/command/index.d.ts.map +1 -0
  29. package/dist/components/command/index.js +3 -0
  30. package/dist/components/command/index.js.map +1 -0
  31. package/dist/components/confetti/confetti.d.ts +21 -0
  32. package/dist/components/confetti/confetti.d.ts.map +1 -0
  33. package/dist/components/confetti/confetti.js +101 -0
  34. package/dist/components/confetti/confetti.js.map +1 -0
  35. package/dist/components/confetti/confetti.stories.js +41 -0
  36. package/dist/components/confetti/confetti.stories.js.map +1 -0
  37. package/dist/components/confetti/index.d.ts +2 -0
  38. package/dist/components/confetti/index.d.ts.map +1 -0
  39. package/dist/components/confetti/index.js +3 -0
  40. package/dist/components/confetti/index.js.map +1 -0
  41. package/dist/components/dashboard/components/analytics-content.d.ts +2 -0
  42. package/dist/components/dashboard/components/analytics-content.d.ts.map +1 -0
  43. package/dist/components/dashboard/components/analytics-content.js +180 -0
  44. package/dist/components/dashboard/components/analytics-content.js.map +1 -0
  45. package/dist/components/dashboard/components/animated-logo.d.ts +4 -0
  46. package/dist/components/dashboard/components/animated-logo.d.ts.map +1 -0
  47. package/dist/components/dashboard/components/animated-logo.js +23 -0
  48. package/dist/components/dashboard/components/animated-logo.js.map +1 -0
  49. package/dist/components/dashboard/components/complete-setup-button.d.ts +4 -0
  50. package/dist/components/dashboard/components/complete-setup-button.d.ts.map +1 -0
  51. package/dist/components/dashboard/components/complete-setup-button.js +28 -0
  52. package/dist/components/dashboard/components/complete-setup-button.js.map +1 -0
  53. package/dist/components/dashboard/components/jobs-content.d.ts +2 -0
  54. package/dist/components/dashboard/components/jobs-content.d.ts.map +1 -0
  55. package/dist/components/dashboard/components/jobs-content.js +69 -0
  56. package/dist/components/dashboard/components/jobs-content.js.map +1 -0
  57. package/dist/components/dashboard/components/mobile-menu.d.ts +2 -0
  58. package/dist/components/dashboard/components/mobile-menu.d.ts.map +1 -0
  59. package/dist/components/dashboard/components/mobile-menu.js +65 -0
  60. package/dist/components/dashboard/components/mobile-menu.js.map +1 -0
  61. package/dist/components/dashboard/components/organization-selector.d.ts +2 -0
  62. package/dist/components/dashboard/components/organization-selector.d.ts.map +1 -0
  63. package/dist/components/dashboard/components/organization-selector.js +92 -0
  64. package/dist/components/dashboard/components/organization-selector.js.map +1 -0
  65. package/dist/components/dashboard/components/top-menu.d.ts +5 -0
  66. package/dist/components/dashboard/components/top-menu.d.ts.map +1 -0
  67. package/dist/components/dashboard/components/top-menu.js +31 -0
  68. package/dist/components/dashboard/components/top-menu.js.map +1 -0
  69. package/dist/components/dashboard/components/topbar-button.d.ts +7 -0
  70. package/dist/components/dashboard/components/topbar-button.d.ts.map +1 -0
  71. package/dist/components/dashboard/components/topbar-button.js +18 -0
  72. package/dist/components/dashboard/components/topbar-button.js.map +1 -0
  73. package/dist/components/dashboard/components/topbar.d.ts +4 -0
  74. package/dist/components/dashboard/components/topbar.d.ts.map +1 -0
  75. package/dist/components/dashboard/components/topbar.js +62 -0
  76. package/dist/components/dashboard/components/topbar.js.map +1 -0
  77. package/dist/components/dashboard/components/user-profile.d.ts +2 -0
  78. package/dist/components/dashboard/components/user-profile.d.ts.map +1 -0
  79. package/dist/components/dashboard/components/user-profile.js +146 -0
  80. package/dist/components/dashboard/components/user-profile.js.map +1 -0
  81. package/dist/components/dashboard/dashboard.d.ts +2 -0
  82. package/dist/components/dashboard/dashboard.d.ts.map +1 -0
  83. package/dist/components/dashboard/dashboard.js +70 -0
  84. package/dist/components/dashboard/dashboard.js.map +1 -0
  85. package/dist/components/dashboard/dashboard.stories.js +23 -0
  86. package/dist/components/dashboard/dashboard.stories.js.map +1 -0
  87. package/dist/components/dashboard/index.d.ts +2 -0
  88. package/dist/components/dashboard/index.d.ts.map +1 -0
  89. package/dist/components/dashboard/index.js +3 -0
  90. package/dist/components/dashboard/index.js.map +1 -0
  91. package/dist/components/form/form.stories.js +6 -1
  92. package/dist/components/form/form.stories.js.map +1 -1
  93. package/dist/components/icon/icon.d.ts +3 -2
  94. package/dist/components/icon/icon.d.ts.map +1 -1
  95. package/dist/components/icon/icon.js +7 -2
  96. package/dist/components/icon/icon.js.map +1 -1
  97. package/dist/components/index.d.ts +9 -0
  98. package/dist/components/index.d.ts.map +1 -1
  99. package/dist/components/index.js +9 -0
  100. package/dist/components/index.js.map +1 -1
  101. package/dist/components/kbd/index.d.ts +2 -0
  102. package/dist/components/kbd/index.d.ts.map +1 -0
  103. package/dist/components/kbd/index.js +3 -0
  104. package/dist/components/kbd/index.js.map +1 -0
  105. package/dist/components/kbd/kbd.d.ts +7 -0
  106. package/dist/components/kbd/kbd.d.ts.map +1 -0
  107. package/dist/components/kbd/kbd.js +18 -0
  108. package/dist/components/kbd/kbd.js.map +1 -0
  109. package/dist/components/kbd/kbd.stories.js +119 -0
  110. package/dist/components/kbd/kbd.stories.js.map +1 -0
  111. package/dist/components/modal/modal.stories.js +227 -168
  112. package/dist/components/modal/modal.stories.js.map +1 -1
  113. package/dist/components/search/index.d.ts +7 -0
  114. package/dist/components/search/index.d.ts.map +1 -0
  115. package/dist/components/search/index.js +8 -0
  116. package/dist/components/search/index.js.map +1 -0
  117. package/dist/components/search/search-context.d.ts +11 -0
  118. package/dist/components/search/search-context.d.ts.map +1 -0
  119. package/dist/components/search/search-context.js +56 -0
  120. package/dist/components/search/search-context.js.map +1 -0
  121. package/dist/components/search/search-inline.d.ts +9 -0
  122. package/dist/components/search/search-inline.d.ts.map +1 -0
  123. package/dist/components/search/search-inline.js +85 -0
  124. package/dist/components/search/search-inline.js.map +1 -0
  125. package/dist/components/search/search-modal.d.ts +25 -0
  126. package/dist/components/search/search-modal.d.ts.map +1 -0
  127. package/dist/components/search/search-modal.js +162 -0
  128. package/dist/components/search/search-modal.js.map +1 -0
  129. package/dist/components/search/search-trigger.d.ts +9 -0
  130. package/dist/components/search/search-trigger.d.ts.map +1 -0
  131. package/dist/components/search/search-trigger.js +37 -0
  132. package/dist/components/search/search-trigger.js.map +1 -0
  133. package/dist/components/search/search-variants.d.ts +14 -0
  134. package/dist/components/search/search-variants.d.ts.map +1 -0
  135. package/dist/components/search/search-variants.js +90 -0
  136. package/dist/components/search/search-variants.js.map +1 -0
  137. package/dist/components/search/search.d.ts +11 -0
  138. package/dist/components/search/search.d.ts.map +1 -0
  139. package/dist/components/search/search.js +35 -0
  140. package/dist/components/search/search.js.map +1 -0
  141. package/dist/components/search/search.stories.js +630 -0
  142. package/dist/components/search/search.stories.js.map +1 -0
  143. package/dist/components/select/index.d.ts +2 -0
  144. package/dist/components/select/index.d.ts.map +1 -0
  145. package/dist/components/select/index.js +3 -0
  146. package/dist/components/select/index.js.map +1 -0
  147. package/dist/components/select/select.d.ts +25 -0
  148. package/dist/components/select/select.d.ts.map +1 -0
  149. package/dist/components/select/select.js +153 -0
  150. package/dist/components/select/select.js.map +1 -0
  151. package/dist/components/select/select.stories.js +393 -0
  152. package/dist/components/select/select.stories.js.map +1 -0
  153. package/dist/components/shiny-text/index.d.ts +2 -0
  154. package/dist/components/shiny-text/index.d.ts.map +1 -0
  155. package/dist/components/shiny-text/index.js +3 -0
  156. package/dist/components/shiny-text/index.js.map +1 -0
  157. package/dist/components/shiny-text/shiny-text.d.ts +10 -0
  158. package/dist/components/shiny-text/shiny-text.d.ts.map +1 -0
  159. package/dist/components/shiny-text/shiny-text.js +17 -0
  160. package/dist/components/shiny-text/shiny-text.js.map +1 -0
  161. package/dist/components/skeleton/index.d.ts +2 -0
  162. package/dist/components/skeleton/index.d.ts.map +1 -0
  163. package/dist/components/skeleton/index.js +3 -0
  164. package/dist/components/skeleton/index.js.map +1 -0
  165. package/dist/components/skeleton/skeleton.d.ts +5 -0
  166. package/dist/components/skeleton/skeleton.d.ts.map +1 -0
  167. package/dist/components/skeleton/skeleton.js +11 -0
  168. package/dist/components/skeleton/skeleton.js.map +1 -0
  169. package/dist/components/skeleton/skeleton.stories.js +345 -0
  170. package/dist/components/skeleton/skeleton.stories.js.map +1 -0
  171. package/dist/components/table/data-table.d.ts +70 -0
  172. package/dist/components/table/data-table.d.ts.map +1 -0
  173. package/dist/components/table/data-table.js +159 -0
  174. package/dist/components/table/data-table.js.map +1 -0
  175. package/dist/components/table/index.d.ts +6 -0
  176. package/dist/components/table/index.d.ts.map +1 -0
  177. package/dist/components/table/index.js +6 -0
  178. package/dist/components/table/index.js.map +1 -0
  179. package/dist/components/table/table-column-header.d.ts +79 -0
  180. package/dist/components/table/table-column-header.d.ts.map +1 -0
  181. package/dist/components/table/table-column-header.js +99 -0
  182. package/dist/components/table/table-column-header.js.map +1 -0
  183. package/dist/components/table/table-pagination.d.ts +53 -0
  184. package/dist/components/table/table-pagination.d.ts.map +1 -0
  185. package/dist/components/table/table-pagination.js +139 -0
  186. package/dist/components/table/table-pagination.js.map +1 -0
  187. package/dist/components/table/table.d.ts +11 -0
  188. package/dist/components/table/table.d.ts.map +1 -0
  189. package/dist/components/table/table.js +64 -0
  190. package/dist/components/table/table.js.map +1 -0
  191. package/dist/components/table/table.stories.columns.d.ts +24 -0
  192. package/dist/components/table/table.stories.columns.d.ts.map +1 -0
  193. package/dist/components/table/table.stories.columns.js +310 -0
  194. package/dist/components/table/table.stories.columns.js.map +1 -0
  195. package/dist/components/table/table.stories.components.d.ts +14 -0
  196. package/dist/components/table/table.stories.components.d.ts.map +1 -0
  197. package/dist/components/table/table.stories.components.js +107 -0
  198. package/dist/components/table/table.stories.components.js.map +1 -0
  199. package/dist/components/table/table.stories.data.d.ts +54 -0
  200. package/dist/components/table/table.stories.data.d.ts.map +1 -0
  201. package/dist/components/table/table.stories.data.js +122 -0
  202. package/dist/components/table/table.stories.data.js.map +1 -0
  203. package/dist/components/table/table.stories.js +302 -0
  204. package/dist/components/table/table.stories.js.map +1 -0
  205. package/dist/index.d.ts +1 -0
  206. package/dist/index.d.ts.map +1 -1
  207. package/dist/index.js +1 -0
  208. package/dist/index.js.map +1 -1
  209. package/dist/styles.css +1 -1
  210. package/index.css +79 -0
  211. package/package.json +6 -2
  212. package/src/components/avatar/avatar.tsx +1 -1
  213. package/src/components/button-group/button-group.stories.tsx +361 -0
  214. package/src/components/button-group/button-group.tsx +111 -0
  215. package/src/components/button-group/index.ts +1 -0
  216. package/src/components/code-block/code-block-footer.tsx +19 -2
  217. package/src/components/command/command.stories.tsx +133 -0
  218. package/src/components/command/command.tsx +265 -0
  219. package/src/components/command/index.ts +1 -0
  220. package/src/components/confetti/confetti.stories.tsx +38 -0
  221. package/src/components/confetti/confetti.tsx +140 -0
  222. package/src/components/confetti/index.ts +1 -0
  223. package/src/components/dashboard/components/analytics-content.tsx +102 -0
  224. package/src/components/dashboard/components/animated-logo.tsx +25 -0
  225. package/src/components/dashboard/components/complete-setup-button.tsx +30 -0
  226. package/src/components/dashboard/components/jobs-content.tsx +51 -0
  227. package/src/components/dashboard/components/mobile-menu.tsx +50 -0
  228. package/src/components/dashboard/components/organization-selector.tsx +51 -0
  229. package/src/components/dashboard/components/top-menu.tsx +26 -0
  230. package/src/components/dashboard/components/topbar-button.tsx +27 -0
  231. package/src/components/dashboard/components/topbar.tsx +40 -0
  232. package/src/components/dashboard/components/user-profile.tsx +90 -0
  233. package/src/components/dashboard/dashboard.stories.tsx +25 -0
  234. package/src/components/dashboard/dashboard.tsx +61 -0
  235. package/src/components/dashboard/index.ts +1 -0
  236. package/src/components/form/form.stories.tsx +5 -0
  237. package/src/components/icon/icon.tsx +7 -3
  238. package/src/components/index.ts +9 -0
  239. package/src/components/kbd/index.ts +1 -0
  240. package/src/components/kbd/kbd.stories.tsx +64 -0
  241. package/src/components/kbd/kbd.tsx +32 -0
  242. package/src/components/modal/modal.stories.tsx +58 -4
  243. package/src/components/search/index.ts +28 -0
  244. package/src/components/search/search-context.tsx +78 -0
  245. package/src/components/search/search-inline.tsx +107 -0
  246. package/src/components/search/search-modal.tsx +198 -0
  247. package/src/components/search/search-trigger.tsx +47 -0
  248. package/src/components/search/search-variants.ts +88 -0
  249. package/src/components/search/search.stories.tsx +392 -0
  250. package/src/components/search/search.tsx +47 -0
  251. package/src/components/select/index.ts +1 -0
  252. package/src/components/select/select.stories.tsx +207 -0
  253. package/src/components/select/select.tsx +220 -0
  254. package/src/components/shiny-text/index.ts +1 -0
  255. package/src/components/shiny-text/shiny-text.tsx +21 -0
  256. package/src/components/skeleton/index.ts +1 -0
  257. package/src/components/skeleton/skeleton.stories.tsx +178 -0
  258. package/src/components/skeleton/skeleton.tsx +14 -0
  259. package/src/components/table/data-table.tsx +254 -0
  260. package/src/components/table/index.ts +5 -0
  261. package/src/components/table/table-column-header.tsx +141 -0
  262. package/src/components/table/table-pagination.tsx +161 -0
  263. package/src/components/table/table.stories.columns.tsx +198 -0
  264. package/src/components/table/table.stories.components.tsx +104 -0
  265. package/src/components/table/table.stories.data.ts +117 -0
  266. package/src/components/table/table.stories.tsx +256 -0
  267. package/src/components/table/table.tsx +95 -0
  268. package/src/index.ts +1 -0
@@ -0,0 +1,644 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useState } from 'react';
3
+ import { Button } from '../button/index.js';
4
+ import { Icon } from '../icon/index.js';
5
+ import { Input } from '../input/index.js';
6
+ import { Popover, PopoverContent, PopoverTrigger } from '../popover/index.js';
7
+ import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '../select/index.js';
8
+ import { Textarea } from '../textarea/index.js';
9
+ import { Code, Header } from '../typography/index.js';
10
+ import { ButtonGroup, ButtonGroupSeparator, ButtonGroupText } from './button-group.js';
11
+ const meta = {
12
+ title: 'Components/ButtonGroup',
13
+ component: ButtonGroup,
14
+ tags: [
15
+ 'autodocs'
16
+ ],
17
+ parameters: {
18
+ docs: {
19
+ description: {
20
+ component: 'A container that groups related buttons together with consistent styling. Automatically styles Button, Input, Select, and Textarea children without requiring manual className overrides. Separators are recommended for visual hierarchy.'
21
+ }
22
+ }
23
+ },
24
+ argTypes: {
25
+ orientation: {
26
+ control: 'select',
27
+ options: [
28
+ 'horizontal',
29
+ 'vertical'
30
+ ],
31
+ description: 'The orientation of the button group',
32
+ defaultValue: 'horizontal'
33
+ }
34
+ }
35
+ };
36
+ export default meta;
37
+ function SelectExample() {
38
+ const [currency, setCurrency] = useState('$');
39
+ return /*#__PURE__*/ _jsxs("div", {
40
+ className: "inline-flex gap-8",
41
+ children: [
42
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
43
+ className: "w-280",
44
+ "aria-label": "Currency converter",
45
+ children: [
46
+ /*#__PURE__*/ _jsxs(Select, {
47
+ value: currency,
48
+ onValueChange: setCurrency,
49
+ children: [
50
+ /*#__PURE__*/ _jsx(SelectTrigger, {
51
+ className: "w-80 font-mono text-foreground-neutral-subtle",
52
+ "aria-label": "Select currency",
53
+ children: /*#__PURE__*/ _jsx(SelectValue, {})
54
+ }),
55
+ /*#__PURE__*/ _jsxs(SelectContent, {
56
+ align: "start",
57
+ children: [
58
+ /*#__PURE__*/ _jsx(SelectItem, {
59
+ value: "$",
60
+ children: "$ USD"
61
+ }),
62
+ /*#__PURE__*/ _jsx(SelectItem, {
63
+ value: "€",
64
+ children: "€ EUR"
65
+ }),
66
+ /*#__PURE__*/ _jsx(SelectItem, {
67
+ value: "£",
68
+ children: "£ GBP"
69
+ }),
70
+ /*#__PURE__*/ _jsx(SelectItem, {
71
+ value: "¥",
72
+ children: "¥ JPY"
73
+ })
74
+ ]
75
+ })
76
+ ]
77
+ }),
78
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
79
+ /*#__PURE__*/ _jsx(Input, {
80
+ placeholder: "10.00",
81
+ pattern: "[0-9]*",
82
+ "aria-label": "Amount"
83
+ })
84
+ ]
85
+ }),
86
+ /*#__PURE__*/ _jsx(ButtonGroup, {
87
+ "aria-label": "Send action",
88
+ children: /*#__PURE__*/ _jsx(Button, {
89
+ variant: "secondary",
90
+ "aria-label": "Send",
91
+ children: /*#__PURE__*/ _jsx(Icon, {
92
+ name: "arrowRightLine",
93
+ className: "size-16 text-foreground-neutral-subtle"
94
+ })
95
+ })
96
+ })
97
+ ]
98
+ });
99
+ }
100
+ function PopoverExample() {
101
+ const [open, setOpen] = useState(false);
102
+ return /*#__PURE__*/ _jsxs(ButtonGroup, {
103
+ "aria-label": "Copilot actions",
104
+ children: [
105
+ /*#__PURE__*/ _jsxs(ButtonGroupText, {
106
+ children: [
107
+ /*#__PURE__*/ _jsx(Icon, {
108
+ name: "sparklingLine",
109
+ className: "size-16"
110
+ }),
111
+ "Copilot"
112
+ ]
113
+ }),
114
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
115
+ /*#__PURE__*/ _jsxs(Popover, {
116
+ open: open,
117
+ onOpenChange: setOpen,
118
+ children: [
119
+ /*#__PURE__*/ _jsx(PopoverTrigger, {
120
+ asChild: true,
121
+ children: /*#__PURE__*/ _jsx(Button, {
122
+ variant: "secondary",
123
+ size: "sm",
124
+ className: "!text-foreground-neutral-subtle",
125
+ "aria-label": "Open Copilot options",
126
+ children: /*#__PURE__*/ _jsx(Icon, {
127
+ name: "arrowDownSLine",
128
+ className: "size-16"
129
+ })
130
+ })
131
+ }),
132
+ /*#__PURE__*/ _jsxs(PopoverContent, {
133
+ align: "end",
134
+ className: "w-320 p-0 rounded-12",
135
+ children: [
136
+ /*#__PURE__*/ _jsx("div", {
137
+ className: "px-16 py-12 border-b border-border-neutral-strong",
138
+ children: /*#__PURE__*/ _jsx(Header, {
139
+ variant: "h4",
140
+ className: "text-sm font-medium",
141
+ children: "Agent Tasks"
142
+ })
143
+ }),
144
+ /*#__PURE__*/ _jsxs("div", {
145
+ className: "p-16 flex flex-col gap-12",
146
+ children: [
147
+ /*#__PURE__*/ _jsx(Textarea, {
148
+ placeholder: "Describe your task in natural language.",
149
+ className: "min-h-80 resize-none",
150
+ "aria-label": "Task description"
151
+ }),
152
+ /*#__PURE__*/ _jsxs("div", {
153
+ className: "flex flex-col gap-8",
154
+ children: [
155
+ /*#__PURE__*/ _jsx(Code, {
156
+ variant: "label",
157
+ className: "font-medium text-foreground-neutral-base",
158
+ children: "Start a new task with Copilot"
159
+ }),
160
+ /*#__PURE__*/ _jsx(Code, {
161
+ variant: "paragraph",
162
+ className: "text-foreground-neutral-subtle text-xs",
163
+ children: "Describe your task in natural language. Copilot will work in the background and open a pull request for your review."
164
+ })
165
+ ]
166
+ })
167
+ ]
168
+ })
169
+ ]
170
+ })
171
+ ]
172
+ })
173
+ ]
174
+ });
175
+ }
176
+ export const Default = {
177
+ render: ()=>/*#__PURE__*/ _jsxs("div", {
178
+ className: "flex flex-col gap-24",
179
+ children: [
180
+ /*#__PURE__*/ _jsxs("div", {
181
+ className: "flex flex-col gap-8",
182
+ children: [
183
+ /*#__PURE__*/ _jsx(Code, {
184
+ variant: "label",
185
+ className: "text-foreground-neutral-subtle",
186
+ children: "Basic Button Group"
187
+ }),
188
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
189
+ "aria-label": "Text alignment",
190
+ children: [
191
+ /*#__PURE__*/ _jsx(Button, {
192
+ variant: "secondary",
193
+ size: "sm",
194
+ "aria-label": "Align left",
195
+ children: /*#__PURE__*/ _jsx(Icon, {
196
+ name: "rewindFill",
197
+ className: "size-14 text-foreground-neutral-subtle"
198
+ })
199
+ }),
200
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
201
+ /*#__PURE__*/ _jsx(Button, {
202
+ variant: "secondary",
203
+ size: "sm",
204
+ "aria-label": "Align center",
205
+ children: /*#__PURE__*/ _jsx(Icon, {
206
+ name: "playFill",
207
+ className: "size-14 text-foreground-neutral-subtle"
208
+ })
209
+ }),
210
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
211
+ /*#__PURE__*/ _jsx(Button, {
212
+ variant: "secondary",
213
+ size: "sm",
214
+ "aria-label": "Align right",
215
+ children: /*#__PURE__*/ _jsx(Icon, {
216
+ name: "speedFill",
217
+ className: "size-14 text-foreground-neutral-subtle"
218
+ })
219
+ })
220
+ ]
221
+ })
222
+ ]
223
+ }),
224
+ /*#__PURE__*/ _jsxs("div", {
225
+ className: "flex flex-col gap-12",
226
+ children: [
227
+ /*#__PURE__*/ _jsx(Code, {
228
+ variant: "label",
229
+ className: "text-foreground-neutral-subtle",
230
+ children: "Sizes"
231
+ }),
232
+ /*#__PURE__*/ _jsxs("div", {
233
+ className: "flex flex-col gap-8",
234
+ children: [
235
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
236
+ "aria-label": "Small buttons",
237
+ children: [
238
+ /*#__PURE__*/ _jsx(Button, {
239
+ variant: "secondary",
240
+ size: "sm",
241
+ "aria-label": "Cut",
242
+ children: /*#__PURE__*/ _jsx(Icon, {
243
+ name: "rewindFill",
244
+ className: "size-14 text-foreground-neutral-subtle"
245
+ })
246
+ }),
247
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
248
+ /*#__PURE__*/ _jsx(Button, {
249
+ variant: "secondary",
250
+ size: "sm",
251
+ "aria-label": "Copy",
252
+ children: /*#__PURE__*/ _jsx(Icon, {
253
+ name: "playFill",
254
+ className: "size-14 text-foreground-neutral-subtle"
255
+ })
256
+ }),
257
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
258
+ /*#__PURE__*/ _jsx(Button, {
259
+ variant: "secondary",
260
+ size: "sm",
261
+ "aria-label": "Paste",
262
+ children: /*#__PURE__*/ _jsx(Icon, {
263
+ name: "speedFill",
264
+ className: "size-14 text-foreground-neutral-subtle"
265
+ })
266
+ })
267
+ ]
268
+ }),
269
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
270
+ "aria-label": "Medium buttons",
271
+ children: [
272
+ /*#__PURE__*/ _jsx(Button, {
273
+ variant: "secondary",
274
+ size: "md",
275
+ "aria-label": "Cut",
276
+ children: /*#__PURE__*/ _jsx(Icon, {
277
+ name: "rewindFill",
278
+ className: "size-16 text-foreground-neutral-subtle"
279
+ })
280
+ }),
281
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
282
+ /*#__PURE__*/ _jsx(Button, {
283
+ variant: "secondary",
284
+ size: "md",
285
+ "aria-label": "Copy",
286
+ children: /*#__PURE__*/ _jsx(Icon, {
287
+ name: "playFill",
288
+ className: "size-16 text-foreground-neutral-subtle"
289
+ })
290
+ }),
291
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
292
+ /*#__PURE__*/ _jsx(Button, {
293
+ variant: "secondary",
294
+ size: "md",
295
+ "aria-label": "Paste",
296
+ children: /*#__PURE__*/ _jsx(Icon, {
297
+ name: "speedFill",
298
+ className: "size-16 text-foreground-neutral-subtle"
299
+ })
300
+ })
301
+ ]
302
+ }),
303
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
304
+ "aria-label": "Large buttons",
305
+ children: [
306
+ /*#__PURE__*/ _jsx(Button, {
307
+ variant: "secondary",
308
+ size: "lg",
309
+ "aria-label": "Cut",
310
+ children: /*#__PURE__*/ _jsx(Icon, {
311
+ name: "rewindFill",
312
+ className: "size-16 text-foreground-neutral-subtle"
313
+ })
314
+ }),
315
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
316
+ /*#__PURE__*/ _jsx(Button, {
317
+ variant: "secondary",
318
+ size: "lg",
319
+ "aria-label": "Copy",
320
+ children: /*#__PURE__*/ _jsx(Icon, {
321
+ name: "playFill",
322
+ className: "size-16 text-foreground-neutral-subtle"
323
+ })
324
+ }),
325
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
326
+ /*#__PURE__*/ _jsx(Button, {
327
+ variant: "secondary",
328
+ size: "lg",
329
+ "aria-label": "Paste",
330
+ children: /*#__PURE__*/ _jsx(Icon, {
331
+ name: "speedFill",
332
+ className: "size-16 text-foreground-neutral-subtle"
333
+ })
334
+ })
335
+ ]
336
+ })
337
+ ]
338
+ })
339
+ ]
340
+ }),
341
+ /*#__PURE__*/ _jsxs("div", {
342
+ className: "flex flex-col gap-8",
343
+ children: [
344
+ /*#__PURE__*/ _jsx(Code, {
345
+ variant: "label",
346
+ className: "text-foreground-neutral-subtle",
347
+ children: "Orientation"
348
+ }),
349
+ /*#__PURE__*/ _jsxs("div", {
350
+ className: "flex gap-24 items-start",
351
+ children: [
352
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
353
+ "aria-label": "Horizontal",
354
+ children: [
355
+ /*#__PURE__*/ _jsx(Button, {
356
+ variant: "secondary",
357
+ size: "sm",
358
+ "aria-label": "Zoom in",
359
+ children: /*#__PURE__*/ _jsx(Icon, {
360
+ name: "addLine",
361
+ className: "size-16 text-foreground-neutral-subtle"
362
+ })
363
+ }),
364
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
365
+ /*#__PURE__*/ _jsx(Button, {
366
+ variant: "secondary",
367
+ size: "sm",
368
+ "aria-label": "Zoom out",
369
+ children: /*#__PURE__*/ _jsx(Icon, {
370
+ name: "subtractLine",
371
+ className: "size-16 text-foreground-neutral-subtle"
372
+ })
373
+ })
374
+ ]
375
+ }),
376
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
377
+ orientation: "vertical",
378
+ className: "h-fit w-fit",
379
+ "aria-label": "Vertical",
380
+ children: [
381
+ /*#__PURE__*/ _jsx(Button, {
382
+ variant: "secondary",
383
+ size: "sm",
384
+ "aria-label": "Increase",
385
+ children: /*#__PURE__*/ _jsx(Icon, {
386
+ name: "addLine",
387
+ className: "size-16 text-foreground-neutral-subtle"
388
+ })
389
+ }),
390
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {
391
+ orientation: "horizontal"
392
+ }),
393
+ /*#__PURE__*/ _jsx(Button, {
394
+ variant: "secondary",
395
+ size: "sm",
396
+ "aria-label": "Decrease",
397
+ children: /*#__PURE__*/ _jsx(Icon, {
398
+ name: "subtractLine",
399
+ className: "size-16 text-foreground-neutral-subtle"
400
+ })
401
+ })
402
+ ]
403
+ })
404
+ ]
405
+ })
406
+ ]
407
+ }),
408
+ /*#__PURE__*/ _jsxs("div", {
409
+ className: "flex flex-col gap-8",
410
+ children: [
411
+ /*#__PURE__*/ _jsx(Code, {
412
+ variant: "label",
413
+ className: "text-foreground-neutral-subtle",
414
+ children: "Split Button"
415
+ }),
416
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
417
+ "aria-label": "Save actions",
418
+ children: [
419
+ /*#__PURE__*/ _jsx(Button, {
420
+ variant: "secondary",
421
+ size: "sm",
422
+ className: " !text-foreground-neutral-subtle",
423
+ children: "Save"
424
+ }),
425
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
426
+ /*#__PURE__*/ _jsx(Button, {
427
+ variant: "secondary",
428
+ size: "sm",
429
+ "aria-label": "More options",
430
+ children: /*#__PURE__*/ _jsx(Icon, {
431
+ name: "arrowDownSLine",
432
+ className: "size-16 text-foreground-neutral-subtle"
433
+ })
434
+ })
435
+ ]
436
+ })
437
+ ]
438
+ }),
439
+ /*#__PURE__*/ _jsxs("div", {
440
+ className: "flex flex-col gap-8",
441
+ children: [
442
+ /*#__PURE__*/ _jsx(Code, {
443
+ variant: "label",
444
+ className: "text-foreground-neutral-subtle",
445
+ children: "With Input"
446
+ }),
447
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
448
+ className: "w-320",
449
+ "aria-label": "Search",
450
+ children: [
451
+ /*#__PURE__*/ _jsx(Input, {
452
+ placeholder: "Search...",
453
+ "aria-label": "Search input"
454
+ }),
455
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
456
+ /*#__PURE__*/ _jsx(Button, {
457
+ variant: "secondary",
458
+ "aria-label": "Submit search",
459
+ children: /*#__PURE__*/ _jsx(Icon, {
460
+ name: "searchLine",
461
+ className: "size-16 text-foreground-neutral-subtle"
462
+ })
463
+ })
464
+ ]
465
+ })
466
+ ]
467
+ }),
468
+ /*#__PURE__*/ _jsxs("div", {
469
+ className: "flex flex-col gap-8",
470
+ children: [
471
+ /*#__PURE__*/ _jsx(Code, {
472
+ variant: "label",
473
+ className: "text-foreground-neutral-subtle",
474
+ children: "Quantity Selector"
475
+ }),
476
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
477
+ className: "w-280",
478
+ "aria-label": "Quantity selector",
479
+ children: [
480
+ /*#__PURE__*/ _jsx(Button, {
481
+ variant: "secondary",
482
+ "aria-label": "Decrease",
483
+ children: /*#__PURE__*/ _jsx(Icon, {
484
+ name: "subtractLine",
485
+ className: "size-16 text-foreground-neutral-subtle"
486
+ })
487
+ }),
488
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
489
+ /*#__PURE__*/ _jsx(Input, {
490
+ placeholder: "1",
491
+ className: "text-center",
492
+ "aria-label": "Quantity"
493
+ }),
494
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
495
+ /*#__PURE__*/ _jsx(Button, {
496
+ variant: "secondary",
497
+ "aria-label": "Increase",
498
+ children: /*#__PURE__*/ _jsx(Icon, {
499
+ name: "addLine",
500
+ className: "size-16 text-foreground-neutral-subtle"
501
+ })
502
+ })
503
+ ]
504
+ })
505
+ ]
506
+ }),
507
+ /*#__PURE__*/ _jsxs("div", {
508
+ className: "flex flex-col gap-8",
509
+ children: [
510
+ /*#__PURE__*/ _jsx(Code, {
511
+ variant: "label",
512
+ className: "text-foreground-neutral-subtle",
513
+ children: "With Select"
514
+ }),
515
+ /*#__PURE__*/ _jsx(SelectExample, {})
516
+ ]
517
+ }),
518
+ /*#__PURE__*/ _jsxs("div", {
519
+ className: "flex flex-col gap-8",
520
+ children: [
521
+ /*#__PURE__*/ _jsx(Code, {
522
+ variant: "label",
523
+ className: "text-foreground-neutral-subtle",
524
+ children: "With Popover"
525
+ }),
526
+ /*#__PURE__*/ _jsx(PopoverExample, {})
527
+ ]
528
+ }),
529
+ /*#__PURE__*/ _jsxs("div", {
530
+ className: "flex flex-col gap-8",
531
+ children: [
532
+ /*#__PURE__*/ _jsx(Code, {
533
+ variant: "label",
534
+ className: "text-foreground-neutral-subtle",
535
+ children: "Nested Groups"
536
+ }),
537
+ /*#__PURE__*/ _jsxs("div", {
538
+ className: "inline-flex gap-8",
539
+ children: [
540
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
541
+ "aria-label": "Page selection",
542
+ children: [
543
+ /*#__PURE__*/ _jsx(Button, {
544
+ variant: "transparent",
545
+ className: "w-42 !text-foreground-neutral-subtle",
546
+ "aria-label": "Page 1",
547
+ children: "1"
548
+ }),
549
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
550
+ /*#__PURE__*/ _jsx(Button, {
551
+ variant: "transparent",
552
+ className: "w-42 !text-foreground-neutral-subtle",
553
+ "aria-label": "Page 2",
554
+ children: "2"
555
+ }),
556
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
557
+ /*#__PURE__*/ _jsx(Button, {
558
+ variant: "transparent",
559
+ className: "w-42 !text-foreground-neutral-subtle",
560
+ "aria-label": "Page 3",
561
+ children: "3"
562
+ }),
563
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
564
+ /*#__PURE__*/ _jsx(Button, {
565
+ variant: "transparent",
566
+ className: "w-42 !text-foreground-neutral-subtle",
567
+ "aria-label": "Page 4",
568
+ children: "4"
569
+ }),
570
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
571
+ /*#__PURE__*/ _jsx(Button, {
572
+ variant: "transparent",
573
+ className: "w-42 !text-foreground-neutral-subtle",
574
+ "aria-label": "Page 5",
575
+ children: "5"
576
+ })
577
+ ]
578
+ }),
579
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
580
+ "aria-label": "Pagination controls",
581
+ children: [
582
+ /*#__PURE__*/ _jsx(Button, {
583
+ variant: "transparent",
584
+ "aria-label": "Previous page",
585
+ children: /*#__PURE__*/ _jsx(Icon, {
586
+ name: "arrowLeftSLine",
587
+ className: "size-16 text-foreground-neutral-subtle"
588
+ })
589
+ }),
590
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
591
+ /*#__PURE__*/ _jsx(Button, {
592
+ variant: "transparent",
593
+ "aria-label": "Next page",
594
+ children: /*#__PURE__*/ _jsx(Icon, {
595
+ name: "arrowRightSLine",
596
+ className: "size-16 text-foreground-neutral-subtle"
597
+ })
598
+ })
599
+ ]
600
+ })
601
+ ]
602
+ })
603
+ ]
604
+ }),
605
+ /*#__PURE__*/ _jsxs("div", {
606
+ className: "flex flex-col gap-8",
607
+ children: [
608
+ /*#__PURE__*/ _jsx(Code, {
609
+ variant: "label",
610
+ className: "text-foreground-neutral-subtle",
611
+ children: "Disabled State"
612
+ }),
613
+ /*#__PURE__*/ _jsxs(ButtonGroup, {
614
+ "aria-label": "Button group with disabled state",
615
+ children: [
616
+ /*#__PURE__*/ _jsx(Button, {
617
+ variant: "secondary",
618
+ size: "sm",
619
+ className: " !text-foreground-neutral-subtle",
620
+ children: "Enabled"
621
+ }),
622
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
623
+ /*#__PURE__*/ _jsx(Button, {
624
+ variant: "secondary",
625
+ size: "sm",
626
+ disabled: true,
627
+ children: "Disabled"
628
+ }),
629
+ /*#__PURE__*/ _jsx(ButtonGroupSeparator, {}),
630
+ /*#__PURE__*/ _jsx(Button, {
631
+ variant: "secondary",
632
+ size: "sm",
633
+ className: " !text-foreground-neutral-subtle",
634
+ children: "Enabled"
635
+ })
636
+ ]
637
+ })
638
+ ]
639
+ })
640
+ ]
641
+ })
642
+ };
643
+
644
+ //# sourceMappingURL=button-group.stories.js.map