@discourser/design-system 0.9.3 → 0.9.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (268) hide show
  1. package/dist/components/AbsoluteCenter.d.ts +4 -0
  2. package/dist/components/AbsoluteCenter.d.ts.map +1 -0
  3. package/dist/components/Accordion.d.ts +12 -0
  4. package/dist/components/Accordion.d.ts.map +1 -0
  5. package/dist/components/Avatar.d.ts +17 -0
  6. package/dist/components/Avatar.d.ts.map +1 -0
  7. package/dist/components/Badge.d.ts +13 -0
  8. package/dist/components/Badge.d.ts.map +1 -0
  9. package/dist/components/Button.d.ts +39 -0
  10. package/dist/components/Button.d.ts.map +1 -0
  11. package/dist/components/Card.d.ts +17 -0
  12. package/dist/components/Card.d.ts.map +1 -0
  13. package/dist/components/Checkbox.d.ts +507 -0
  14. package/dist/components/Checkbox.d.ts.map +1 -0
  15. package/dist/components/CloseButton.d.ts +4 -0
  16. package/dist/components/CloseButton.d.ts.map +1 -0
  17. package/dist/components/Dialog.d.ts +16 -0
  18. package/dist/components/Dialog.d.ts.map +1 -0
  19. package/dist/components/Drawer.d.ts +17 -0
  20. package/dist/components/Drawer.d.ts.map +1 -0
  21. package/dist/components/Group.d.ts +4 -0
  22. package/dist/components/Group.d.ts.map +1 -0
  23. package/dist/components/Heading.d.ts +10 -0
  24. package/dist/components/Heading.d.ts.map +1 -0
  25. package/dist/components/Icon.d.ts +4 -0
  26. package/dist/components/Icon.d.ts.map +1 -0
  27. package/dist/components/IconButton.d.ts +5 -0
  28. package/dist/components/IconButton.d.ts.map +1 -0
  29. package/dist/components/Input.d.ts +5 -0
  30. package/dist/components/Input.d.ts.map +1 -0
  31. package/dist/components/InputAddon.d.ts +4 -0
  32. package/dist/components/InputAddon.d.ts.map +1 -0
  33. package/dist/components/InputGroup.d.ts +14 -0
  34. package/dist/components/InputGroup.d.ts.map +1 -0
  35. package/dist/components/Loader.d.ts +25 -0
  36. package/dist/components/Loader.d.ts.map +1 -0
  37. package/dist/components/Popover.d.ts +20 -0
  38. package/dist/components/Popover.d.ts.map +1 -0
  39. package/dist/components/Progress.d.ts +14 -0
  40. package/dist/components/Progress.d.ts.map +1 -0
  41. package/dist/components/RadioGroup.d.ts +14 -0
  42. package/dist/components/RadioGroup.d.ts.map +1 -0
  43. package/dist/components/Select.d.ts +26 -0
  44. package/dist/components/Select.d.ts.map +1 -0
  45. package/dist/components/Skeleton.d.ts +16 -0
  46. package/dist/components/Skeleton.d.ts.map +1 -0
  47. package/dist/components/Slider.d.ts +34 -0
  48. package/dist/components/Slider.d.ts.map +1 -0
  49. package/dist/components/Spinner.d.ts +4 -0
  50. package/dist/components/Spinner.d.ts.map +1 -0
  51. package/dist/components/Switch.d.ts +10 -0
  52. package/dist/components/Switch.d.ts.map +1 -0
  53. package/dist/components/Tabs.d.ts +11 -0
  54. package/dist/components/Tabs.d.ts.map +1 -0
  55. package/dist/components/Textarea.d.ts +5 -0
  56. package/dist/components/Textarea.d.ts.map +1 -0
  57. package/dist/components/Toast.d.ts +4 -0
  58. package/dist/components/Toast.d.ts.map +1 -0
  59. package/dist/components/Tooltip.d.ts +19 -0
  60. package/dist/components/Tooltip.d.ts.map +1 -0
  61. package/dist/components/index.d.ts +30 -0
  62. package/dist/components/index.d.ts.map +1 -0
  63. package/dist/contracts/design-language.contract.d.ts +175 -0
  64. package/dist/contracts/design-language.contract.d.ts.map +1 -0
  65. package/dist/index.d.ts +7 -21506
  66. package/dist/index.d.ts.map +1 -0
  67. package/dist/languages/index.d.ts +4 -0
  68. package/dist/languages/index.d.ts.map +1 -0
  69. package/dist/languages/material3.language.d.ts +9 -0
  70. package/dist/languages/material3.language.d.ts.map +1 -0
  71. package/dist/languages/transform.d.ts +98 -0
  72. package/dist/languages/transform.d.ts.map +1 -0
  73. package/dist/main.d.ts +2 -0
  74. package/dist/main.d.ts.map +1 -0
  75. package/dist/preset/colors/index.d.ts +1485 -0
  76. package/dist/preset/colors/index.d.ts.map +1 -0
  77. package/dist/preset/colors/m3-error.d.ts +295 -0
  78. package/dist/preset/colors/m3-error.d.ts.map +1 -0
  79. package/dist/preset/colors/m3-neutral.d.ts +301 -0
  80. package/dist/preset/colors/m3-neutral.d.ts.map +1 -0
  81. package/dist/preset/colors/m3-primary.d.ts +312 -0
  82. package/dist/preset/colors/m3-primary.d.ts.map +1 -0
  83. package/dist/preset/index.d.ts +3 -0
  84. package/dist/preset/index.d.ts.map +1 -0
  85. package/dist/preset/layer-styles.d.ts +6 -0
  86. package/dist/preset/layer-styles.d.ts.map +1 -0
  87. package/dist/preset/recipes/absolute-center.d.ts +2 -0
  88. package/dist/preset/recipes/absolute-center.d.ts.map +1 -0
  89. package/dist/preset/recipes/accordion.d.ts +2 -0
  90. package/dist/preset/recipes/accordion.d.ts.map +1 -0
  91. package/dist/preset/recipes/avatar.d.ts +2 -0
  92. package/dist/preset/recipes/avatar.d.ts.map +1 -0
  93. package/dist/preset/recipes/badge.d.ts +2 -0
  94. package/dist/preset/recipes/badge.d.ts.map +1 -0
  95. package/dist/preset/recipes/button.d.ts +2 -0
  96. package/dist/preset/recipes/button.d.ts.map +1 -0
  97. package/dist/preset/recipes/card.d.ts +2 -0
  98. package/dist/preset/recipes/card.d.ts.map +1 -0
  99. package/dist/preset/recipes/checkbox.d.ts +2 -0
  100. package/dist/preset/recipes/checkbox.d.ts.map +1 -0
  101. package/dist/preset/recipes/dialog.d.ts +2 -0
  102. package/dist/preset/recipes/dialog.d.ts.map +1 -0
  103. package/dist/preset/recipes/drawer.d.ts +2 -0
  104. package/dist/preset/recipes/drawer.d.ts.map +1 -0
  105. package/dist/preset/recipes/field.d.ts +2 -0
  106. package/dist/preset/recipes/field.d.ts.map +1 -0
  107. package/dist/preset/recipes/group.d.ts +2 -0
  108. package/dist/preset/recipes/group.d.ts.map +1 -0
  109. package/dist/preset/recipes/heading.d.ts +2 -0
  110. package/dist/preset/recipes/heading.d.ts.map +1 -0
  111. package/dist/preset/recipes/index.d.ts +28 -0
  112. package/dist/preset/recipes/index.d.ts.map +1 -0
  113. package/dist/preset/recipes/input-addon.d.ts +2 -0
  114. package/dist/preset/recipes/input-addon.d.ts.map +1 -0
  115. package/dist/preset/recipes/input-group.d.ts +2 -0
  116. package/dist/preset/recipes/input-group.d.ts.map +1 -0
  117. package/dist/preset/recipes/input.d.ts +114 -0
  118. package/dist/preset/recipes/input.d.ts.map +1 -0
  119. package/dist/preset/recipes/popover.d.ts +2 -0
  120. package/dist/preset/recipes/popover.d.ts.map +1 -0
  121. package/dist/preset/recipes/progress.d.ts +2 -0
  122. package/dist/preset/recipes/progress.d.ts.map +1 -0
  123. package/dist/preset/recipes/radio-group.d.ts +2 -0
  124. package/dist/preset/recipes/radio-group.d.ts.map +1 -0
  125. package/dist/preset/recipes/select.d.ts +2 -0
  126. package/dist/preset/recipes/select.d.ts.map +1 -0
  127. package/dist/preset/recipes/skeleton.d.ts +2 -0
  128. package/dist/preset/recipes/skeleton.d.ts.map +1 -0
  129. package/dist/preset/recipes/slider.d.ts +2 -0
  130. package/dist/preset/recipes/slider.d.ts.map +1 -0
  131. package/dist/preset/recipes/spinner.d.ts +2 -0
  132. package/dist/preset/recipes/spinner.d.ts.map +1 -0
  133. package/dist/preset/recipes/switch.d.ts +2 -0
  134. package/dist/preset/recipes/switch.d.ts.map +1 -0
  135. package/dist/preset/recipes/tabs.d.ts +2 -0
  136. package/dist/preset/recipes/tabs.d.ts.map +1 -0
  137. package/dist/preset/recipes/textarea.d.ts +2 -0
  138. package/dist/preset/recipes/textarea.d.ts.map +1 -0
  139. package/dist/preset/recipes/toast.d.ts +2 -0
  140. package/dist/preset/recipes/toast.d.ts.map +1 -0
  141. package/dist/preset/recipes/tooltip.d.ts +2 -0
  142. package/dist/preset/recipes/tooltip.d.ts.map +1 -0
  143. package/dist/preset/semantic-tokens.d.ts +197 -0
  144. package/dist/preset/semantic-tokens.d.ts.map +1 -0
  145. package/dist/preset/shadows.d.ts +49 -0
  146. package/dist/preset/shadows.d.ts.map +1 -0
  147. package/dist/preset/text-styles.d.ts +6 -0
  148. package/dist/preset/text-styles.d.ts.map +1 -0
  149. package/dist/recipes/button.recipe.d.ts +2 -0
  150. package/dist/recipes/button.recipe.d.ts.map +1 -0
  151. package/dist/recipes/card.recipe.d.ts +2 -0
  152. package/dist/recipes/card.recipe.d.ts.map +1 -0
  153. package/dist/recipes/dialog.recipe.d.ts +2 -0
  154. package/dist/recipes/dialog.recipe.d.ts.map +1 -0
  155. package/dist/recipes/icon-button.recipe.d.ts +2 -0
  156. package/dist/recipes/icon-button.recipe.d.ts.map +1 -0
  157. package/dist/recipes/index.d.ts +7 -0
  158. package/dist/recipes/index.d.ts.map +1 -0
  159. package/dist/recipes/input.recipe.d.ts +2 -0
  160. package/dist/recipes/input.recipe.d.ts.map +1 -0
  161. package/dist/recipes/switch.recipe.d.ts +2 -0
  162. package/dist/recipes/switch.recipe.d.ts.map +1 -0
  163. package/dist/stories/foundations/components/ColorSwatch.d.ts +21 -0
  164. package/dist/stories/foundations/components/ColorSwatch.d.ts.map +1 -0
  165. package/dist/stories/foundations/components/ElevationCard.d.ts +11 -0
  166. package/dist/stories/foundations/components/ElevationCard.d.ts.map +1 -0
  167. package/dist/stories/foundations/components/SpacingBox.d.ts +11 -0
  168. package/dist/stories/foundations/components/SpacingBox.d.ts.map +1 -0
  169. package/dist/stories/foundations/components/TypeSpecimen.d.ts +12 -0
  170. package/dist/stories/foundations/components/TypeSpecimen.d.ts.map +1 -0
  171. package/dist/utils/cn.d.ts +6 -0
  172. package/dist/utils/cn.d.ts.map +1 -0
  173. package/package.json +4 -2
  174. package/src/components/AbsoluteCenter.tsx +7 -0
  175. package/src/components/Accordion.tsx +27 -0
  176. package/src/components/Avatar.tsx +55 -0
  177. package/src/components/Badge.tsx +29 -0
  178. package/src/components/Button.tsx +116 -0
  179. package/src/components/Card.tsx +24 -0
  180. package/src/components/Checkbox.tsx +48 -0
  181. package/src/components/CloseButton.tsx +21 -0
  182. package/src/components/Dialog.tsx +25 -0
  183. package/src/components/Drawer.tsx +29 -0
  184. package/src/components/Group.tsx +7 -0
  185. package/src/components/Heading.tsx +9 -0
  186. package/src/components/Icon.tsx +6 -0
  187. package/src/components/IconButton.tsx +10 -0
  188. package/src/components/Input.tsx +7 -0
  189. package/src/components/InputAddon.tsx +7 -0
  190. package/src/components/InputGroup.tsx +44 -0
  191. package/src/components/Loader.tsx +71 -0
  192. package/src/components/Popover.tsx +34 -0
  193. package/src/components/Progress.tsx +19 -0
  194. package/src/components/RadioGroup.tsx +21 -0
  195. package/src/components/Select.tsx +70 -0
  196. package/src/components/Skeleton.tsx +37 -0
  197. package/src/components/Slider.tsx +156 -0
  198. package/src/components/Spinner.tsx +7 -0
  199. package/src/components/Switch.tsx +19 -0
  200. package/src/components/Tabs.tsx +17 -0
  201. package/src/components/Textarea.tsx +7 -0
  202. package/src/components/Toast.tsx +96 -0
  203. package/src/components/Tooltip.tsx +65 -0
  204. package/src/components/index.ts +48 -0
  205. package/src/contracts/design-language.contract.ts +198 -0
  206. package/src/global.css +4 -0
  207. package/src/index.ts +18 -0
  208. package/src/languages/index.ts +9 -0
  209. package/src/languages/material3.language.ts +379 -0
  210. package/src/languages/transform.ts +131 -0
  211. package/src/main.ts +33 -0
  212. package/src/preset/colors/index.ts +14 -0
  213. package/src/preset/colors/m3-error.ts +76 -0
  214. package/src/preset/colors/m3-neutral.ts +89 -0
  215. package/src/preset/colors/m3-primary.ts +107 -0
  216. package/src/preset/index.ts +189 -0
  217. package/src/preset/layer-styles.ts +14 -0
  218. package/src/preset/recipes/absolute-center.ts +37 -0
  219. package/src/preset/recipes/accordion.ts +92 -0
  220. package/src/preset/recipes/avatar.ts +152 -0
  221. package/src/preset/recipes/badge.ts +49 -0
  222. package/src/preset/recipes/button.ts +110 -0
  223. package/src/preset/recipes/card.ts +69 -0
  224. package/src/preset/recipes/checkbox.ts +109 -0
  225. package/src/preset/recipes/dialog.ts +157 -0
  226. package/src/preset/recipes/drawer.ts +203 -0
  227. package/src/preset/recipes/field.ts +40 -0
  228. package/src/preset/recipes/group.ts +77 -0
  229. package/src/preset/recipes/heading.ts +26 -0
  230. package/src/preset/recipes/index.ts +40 -0
  231. package/src/preset/recipes/input-addon.ts +42 -0
  232. package/src/preset/recipes/input-group.ts +66 -0
  233. package/src/preset/recipes/input.ts +87 -0
  234. package/src/preset/recipes/popover.ts +77 -0
  235. package/src/preset/recipes/progress.ts +120 -0
  236. package/src/preset/recipes/radio-group.ts +99 -0
  237. package/src/preset/recipes/select.ts +175 -0
  238. package/src/preset/recipes/skeleton.ts +64 -0
  239. package/src/preset/recipes/slider.ts +174 -0
  240. package/src/preset/recipes/spinner.ts +33 -0
  241. package/src/preset/recipes/switch.ts +136 -0
  242. package/src/preset/recipes/tabs.ts +177 -0
  243. package/src/preset/recipes/textarea.ts +82 -0
  244. package/src/preset/recipes/toast.ts +51 -0
  245. package/src/preset/recipes/tooltip.ts +38 -0
  246. package/src/preset/semantic-tokens.ts +75 -0
  247. package/src/preset/shadows.ts +50 -0
  248. package/src/preset/text-styles.ts +21 -0
  249. package/src/recipes/button.recipe.ts +120 -0
  250. package/src/recipes/card.recipe.ts +50 -0
  251. package/src/recipes/dialog.recipe.ts +130 -0
  252. package/src/recipes/icon-button.recipe.ts +96 -0
  253. package/src/recipes/index.ts +6 -0
  254. package/src/recipes/input.recipe.ts +93 -0
  255. package/src/recipes/switch.recipe.ts +117 -0
  256. package/src/stories/foundations/Colors.mdx +380 -0
  257. package/src/stories/foundations/Elevation.mdx +292 -0
  258. package/src/stories/foundations/Spacing.mdx +223 -0
  259. package/src/stories/foundations/Typography.mdx +264 -0
  260. package/src/stories/foundations/components/ColorSwatch.tsx +166 -0
  261. package/src/stories/foundations/components/ElevationCard.tsx +81 -0
  262. package/src/stories/foundations/components/SpacingBox.tsx +94 -0
  263. package/src/stories/foundations/components/TypeSpecimen.tsx +117 -0
  264. package/src/test/setup.ts +12 -0
  265. package/src/test/vitest.d.ts +29 -0
  266. package/src/utils/cn.ts +8 -0
  267. package/src/vite-env.d.ts +1 -0
  268. package/dist/index.d.cts +0 -21506
@@ -0,0 +1,175 @@
1
+ import { selectAnatomy } from '@ark-ui/react/anatomy'
2
+ import { defineSlotRecipe } from '@pandacss/dev'
3
+
4
+ export const select = defineSlotRecipe({
5
+ className: 'select',
6
+ slots: selectAnatomy.extendWith('indicatorGroup').keys(),
7
+ base: {
8
+ root: {
9
+ display: 'flex',
10
+ flexDirection: 'column',
11
+ gap: '1.5',
12
+ width: 'full',
13
+ },
14
+ content: {
15
+ background: 'gray.surface.bg',
16
+ borderRadius: 'l2',
17
+ boxShadow: 'md',
18
+ display: 'flex',
19
+ flexDirection: 'column',
20
+ maxH: 'min(var(--available-height), {sizes.96})',
21
+ minWidth: 'max(var(--reference-width), {sizes.40})',
22
+ outline: 0,
23
+ overflowY: 'auto',
24
+ zIndex: 'dropdown',
25
+ _open: {
26
+ animationStyle: 'slide-fade-in',
27
+ animationDuration: 'slow',
28
+ },
29
+ _closed: {
30
+ animationStyle: 'slide-fade-out',
31
+ animationDuration: 'fastest',
32
+ },
33
+ },
34
+ item: {
35
+ alignItems: 'center',
36
+ borderRadius: 'l1',
37
+ cursor: 'pointer',
38
+ display: 'flex',
39
+ justifyContent: 'space-between',
40
+ userSelect: 'none',
41
+ _hover: {
42
+ background: 'gray.surface.bg.hover',
43
+ },
44
+ _highlighted: {
45
+ background: 'gray.surface.bg.hover',
46
+ },
47
+ _selected: {},
48
+ _disabled: {
49
+ layerStyle: 'disabled',
50
+ },
51
+ },
52
+ indicatorGroup: {
53
+ display: 'flex',
54
+ alignItems: 'center',
55
+ gap: '1',
56
+ pointerEvents: 'none',
57
+ },
58
+ indicator: {
59
+ display: 'flex',
60
+ alignItems: 'center',
61
+ justifyContent: 'center',
62
+ color: { base: 'fg.subtle' },
63
+ },
64
+ itemGroupLabel: {
65
+ alignItems: 'flex-start',
66
+ color: 'fg.subtle',
67
+ display: 'flex',
68
+ flexDirection: 'column',
69
+ fontWeight: 'medium',
70
+ gap: '1px',
71
+ justifyContent: 'center',
72
+ _after: {
73
+ content: '""',
74
+ width: '100%',
75
+ height: '1px',
76
+ bg: 'gray.4',
77
+ },
78
+ },
79
+ itemIndicator: {
80
+ color: 'colorPalette.plain.fg',
81
+ },
82
+ label: {
83
+ fontWeight: 'medium',
84
+ userSelect: 'none',
85
+ textStyle: 'sm',
86
+ },
87
+ trigger: {
88
+ alignItems: 'center',
89
+ borderRadius: 'l2',
90
+ cursor: 'pointer',
91
+ display: 'flex',
92
+ justifyContent: 'space-between',
93
+ minWidth: '0',
94
+ outline: '0',
95
+ textAlign: 'start',
96
+ transition: 'common',
97
+ userSelect: 'none',
98
+ width: 'full',
99
+ _placeholderShown: {
100
+ color: 'fg.subtle',
101
+ },
102
+ _disabled: {
103
+ layerStyle: 'disabled',
104
+ },
105
+ },
106
+ valueText: {
107
+ overflow: 'hidden',
108
+ textOverflow: 'ellipsis',
109
+ whiteSpace: 'nowrap',
110
+ color: 'fg.default',
111
+ },
112
+ },
113
+ defaultVariants: {
114
+ size: 'md',
115
+ variant: 'outline',
116
+ },
117
+ variants: {
118
+ variant: {
119
+ outline: {
120
+ trigger: {
121
+ borderWidth: 'thin',
122
+ borderColor: 'gray.outline.border',
123
+
124
+ focusVisibleRing: 'inside',
125
+ },
126
+ },
127
+ surface: {
128
+ trigger: {
129
+ bg: 'gray.surface.bg',
130
+ borderWidth: 'thin',
131
+ borderColor: 'gray.surface.border',
132
+
133
+ focusVisibleRing: 'inside',
134
+ },
135
+ },
136
+ },
137
+ size: {
138
+ xs: {
139
+ content: { p: '1', gap: '0.5', textStyle: 'sm' },
140
+ item: { px: '1', minH: '8', gap: '2', _icon: { boxSize: '3.5' } },
141
+ itemGroup: { gap: '0.5' },
142
+ itemGroupLabel: { px: '1', height: '8' },
143
+ trigger: { px: '2', h: '8', textStyle: 'sm', gap: '2', _icon: { boxSize: '3.5' } },
144
+ },
145
+ sm: {
146
+ content: { p: '1', gap: '0.5', textStyle: 'sm' },
147
+ item: { px: '1.5', minH: '9', gap: '2', _icon: { boxSize: '4' } },
148
+ itemGroup: { gap: '0.5' },
149
+ itemGroupLabel: { px: '1.5', height: '9' },
150
+ trigger: { px: '2.5', h: '9', textStyle: 'sm', gap: '2', _icon: { boxSize: '4' } },
151
+ },
152
+ md: {
153
+ content: { p: '1', gap: '0.5', textStyle: 'md' },
154
+ item: { px: '2', minH: '10', gap: '2', _icon: { boxSize: '4' } },
155
+ itemGroup: { gap: '0.5' },
156
+ itemGroupLabel: { px: '2', height: '10' },
157
+ trigger: { px: '3', h: '10', textStyle: 'md', gap: '2', _icon: { boxSize: '4' } },
158
+ },
159
+ lg: {
160
+ content: { p: '1', gap: '0.5', textStyle: 'md' },
161
+ item: { px: '2.5', minH: '11', gap: '2', _icon: { boxSize: '4.5' } },
162
+ itemGroup: { gap: '0.5' },
163
+ itemGroupLabel: { px: '2.5', height: '11' },
164
+ trigger: { px: '3.5', h: '11', textStyle: 'md', gap: '2', _icon: { boxSize: '4.5' } },
165
+ },
166
+ xl: {
167
+ content: { p: '1', gap: '1', textStyle: 'lg' },
168
+ item: { px: '3', minH: '12', gap: '3', _icon: { boxSize: '5' } },
169
+ itemGroup: { gap: '1' },
170
+ itemGroupLabel: { px: '3', height: '12' },
171
+ trigger: { px: '4', h: '12', textStyle: 'lg', gap: '3', _icon: { boxSize: '5' } },
172
+ },
173
+ },
174
+ },
175
+ })
@@ -0,0 +1,64 @@
1
+ import { defineRecipe } from '@pandacss/dev'
2
+
3
+ export const skeleton = defineRecipe({
4
+ className: 'skeleton',
5
+ jsx: ['Skeleton', 'SkeletonCircle', 'SkeletonText'],
6
+ base: {},
7
+ variants: {
8
+ loading: {
9
+ true: {
10
+ borderRadius: 'l2',
11
+ boxShadow: 'none',
12
+ backgroundClip: 'padding-box',
13
+ cursor: 'default',
14
+ color: 'transparent',
15
+ pointerEvents: 'none',
16
+ userSelect: 'none',
17
+ flexShrink: '0',
18
+ '&::before, &::after, *': {
19
+ visibility: 'hidden',
20
+ },
21
+ },
22
+ false: {
23
+ background: 'unset',
24
+ animation: 'fade-in var(--fade-duration, 0.1s) ease-out !important',
25
+ },
26
+ },
27
+
28
+ circle: {
29
+ true: {
30
+ display: 'flex',
31
+ alignItems: 'center',
32
+ justifyContent: 'center',
33
+ flex: '0 0 auto',
34
+ borderRadius: '9999px',
35
+ },
36
+ },
37
+
38
+ variant: {
39
+ pulse: {
40
+ background: 'gray.subtle.bg.active',
41
+ animation: 'pulse',
42
+ animationDuration: 'var(--duration, 1.2s)',
43
+ },
44
+ shine: {
45
+ '--animate-from': '200%',
46
+ '--animate-to': '-200%',
47
+ '--start-color': 'colors.gray.subtle.bg',
48
+ '--end-color': 'colors.gray.subtle.bg.active',
49
+ backgroundImage:
50
+ 'linear-gradient(270deg,var(--start-color),var(--end-color),var(--end-color),var(--start-color))',
51
+ backgroundSize: '400% 100%',
52
+ animation: 'bg-position var(--duration, 5s) ease-in-out infinite',
53
+ },
54
+ none: {
55
+ animation: 'none',
56
+ },
57
+ },
58
+ },
59
+
60
+ defaultVariants: {
61
+ variant: 'pulse',
62
+ loading: true,
63
+ },
64
+ })
@@ -0,0 +1,174 @@
1
+ import { sliderAnatomy } from '@ark-ui/react/anatomy'
2
+ import { defineSlotRecipe } from '@pandacss/dev'
3
+
4
+ export const slider = defineSlotRecipe({
5
+ className: 'slider',
6
+ slots: sliderAnatomy.extendWith('markerIndicator').keys(),
7
+ base: {
8
+ root: {
9
+ display: 'flex',
10
+ flexDirection: 'column',
11
+ gap: '1',
12
+ textStyle: 'sm',
13
+ position: 'relative',
14
+ isolation: 'isolate',
15
+ touchAction: 'none',
16
+ width: 'full',
17
+ },
18
+ label: {
19
+ fontWeight: 'medium',
20
+ textStyle: 'sm',
21
+ },
22
+ control: {
23
+ display: 'inline-flex',
24
+ alignItems: 'center',
25
+ },
26
+ track: {
27
+ overflow: 'hidden',
28
+ borderRadius: 'full',
29
+ flex: '1',
30
+ },
31
+ range: {
32
+ width: 'inherit',
33
+ height: 'inherit',
34
+ },
35
+ markerGroup: {
36
+ position: 'absolute!',
37
+ zIndex: '1',
38
+ },
39
+ marker: {
40
+ display: 'flex',
41
+ alignItems: 'center',
42
+ gap: 'calc(var(--slider-thumb-size) / 2)',
43
+ color: 'fg.muted',
44
+ textStyle: 'xs',
45
+ },
46
+ markerIndicator: {
47
+ width: 'var(--slider-marker-size)',
48
+ height: 'var(--slider-marker-size)',
49
+ borderRadius: 'full',
50
+ bg: 'colorPalette.solid.fg',
51
+ },
52
+ thumb: {
53
+ width: 'var(--slider-thumb-size)',
54
+ height: 'var(--slider-thumb-size)',
55
+ display: 'flex',
56
+ alignItems: 'center',
57
+ justifyContent: 'center',
58
+ outline: 0,
59
+ zIndex: '2',
60
+ borderRadius: 'full',
61
+ _focusVisible: {
62
+ ring: '2px',
63
+ ringColor: 'colorPalette.solid',
64
+ ringOffset: '2px',
65
+ ringOffsetColor: 'bg',
66
+ },
67
+ },
68
+ },
69
+ defaultVariants: {
70
+ size: 'md',
71
+ variant: 'outline',
72
+ orientation: 'horizontal',
73
+ },
74
+ variants: {
75
+ size: {
76
+ sm: {
77
+ root: {
78
+ '--slider-thumb-size': 'sizes.5',
79
+ '--slider-track-size': 'sizes.2',
80
+ '--slider-marker-center': '{spacing.sm}',
81
+ '--slider-marker-size': 'sizes.1',
82
+ '--slider-marker-inset': '{spacing.xs}',
83
+ },
84
+ },
85
+ md: {
86
+ root: {
87
+ '--slider-thumb-size': 'sizes.5',
88
+ '--slider-track-size': 'sizes.2',
89
+ '--slider-marker-center': '{spacing.sm}',
90
+ '--slider-marker-size': 'sizes.1',
91
+ '--slider-marker-inset': '{spacing.xs}',
92
+ },
93
+ },
94
+ lg: {
95
+ root: {
96
+ '--slider-thumb-size': 'sizes.5',
97
+ '--slider-track-size': 'sizes.2',
98
+ '--slider-marker-center': '{spacing.sm}',
99
+ '--slider-marker-size': 'sizes.1',
100
+ '--slider-marker-inset': '{spacing.xs}',
101
+ },
102
+ },
103
+ },
104
+ variant: {
105
+ outline: {
106
+ thumb: {
107
+ bg: 'gray.surface.bg',
108
+ borderWidth: 'medium',
109
+ borderColor: 'colorPalette.solid.bg',
110
+ boxShadow: 'xs',
111
+ },
112
+ range: {
113
+ bg: 'colorPalette.solid.bg',
114
+ },
115
+ track: {
116
+ bg: 'border',
117
+ },
118
+ },
119
+ },
120
+ orientation: {
121
+ vertical: {
122
+ root: {
123
+ display: 'inline-flex',
124
+ },
125
+ control: {
126
+ flexDirection: 'column',
127
+ height: '100%',
128
+ minWidth: 'var(--slider-thumb-size)',
129
+ '&[data-has-mark-label]': {
130
+ marginEnd: '4',
131
+ },
132
+ },
133
+ track: {
134
+ width: 'var(--slider-track-size)',
135
+ },
136
+ thumb: {
137
+ left: '50%',
138
+ translate: '-50% 0',
139
+ },
140
+ markerGroup: {
141
+ insetStart: 'var(--slider-marker-center)',
142
+ insetBlock: 'var(--slider-marker-inset)',
143
+ },
144
+ marker: {
145
+ flexDirection: 'row',
146
+ },
147
+ },
148
+ horizontal: {
149
+ control: {
150
+ flexDirection: 'row',
151
+ width: '100%',
152
+ minHeight: 'var(--slider-thumb-size)',
153
+ '&[data-has-mark-label]': {
154
+ marginBottom: '4',
155
+ },
156
+ },
157
+ track: {
158
+ height: 'var(--slider-track-size)',
159
+ },
160
+ thumb: {
161
+ top: '50%',
162
+ translate: '0 -50%',
163
+ },
164
+ markerGroup: {
165
+ top: 'var(--slider-marker-center)',
166
+ insetInline: 'var(--slider-marker-inset)',
167
+ },
168
+ marker: {
169
+ flexDirection: 'column',
170
+ },
171
+ },
172
+ },
173
+ },
174
+ })
@@ -0,0 +1,33 @@
1
+ import { defineRecipe } from '@pandacss/dev'
2
+
3
+ export const spinner = defineRecipe({
4
+ className: 'spinner',
5
+ base: {
6
+ '--spinner-track-color': 'transparent',
7
+ animation: 'spin',
8
+ animationDuration: 'slowest',
9
+ borderBottomColor: 'var(--spinner-track-color)',
10
+ borderColor: 'currentColor',
11
+ borderInlineStartColor: 'var(--spinner-track-color)',
12
+ borderRadius: 'full',
13
+ borderStyle: 'solid',
14
+ borderWidth: 'medium',
15
+ display: 'inline-block',
16
+ height: 'var(--spinner-size)',
17
+ width: 'var(--spinner-size)',
18
+ },
19
+ defaultVariants: {
20
+ size: 'md',
21
+ },
22
+ variants: {
23
+ size: {
24
+ inherit: { '--spinner-size': '1em' },
25
+ xs: { '--spinner-size': 'sizes.3' },
26
+ sm: { '--spinner-size': 'sizes.4' },
27
+ md: { '--spinner-size': 'sizes.5' },
28
+ lg: { '--spinner-size': 'sizes.6' },
29
+ xl: { '--spinner-size': 'sizes.7' },
30
+ '2xl': { '--spinner-size': 'sizes.8' },
31
+ },
32
+ },
33
+ })
@@ -0,0 +1,136 @@
1
+ import { switchAnatomy } from '@ark-ui/react/anatomy';
2
+ import { defineSlotRecipe } from '@pandacss/dev';
3
+
4
+ export const switchRecipe = defineSlotRecipe({
5
+ className: 'switchComponent',
6
+ jsx: ['Switch', /Switch\.+/],
7
+ slots: switchAnatomy.extendWith('indicator').keys(),
8
+ base: {
9
+ root: {
10
+ display: 'inline-flex',
11
+ alignItems: 'center',
12
+ position: 'relative',
13
+ verticalAlign: 'middle',
14
+ '--switch-diff': 'calc(var(--switch-width) - var(--switch-height))',
15
+ '--switch-x': {
16
+ base: 'var(--switch-diff)',
17
+ _rtl: 'calc(var(--switch-diff) * -1)',
18
+ },
19
+ },
20
+ label: {
21
+ fontWeight: 'medium',
22
+ userSelect: 'none',
23
+ lineHeight: '1',
24
+ },
25
+ indicator: {
26
+ position: 'absolute',
27
+ height: 'var(--switch-height)',
28
+ width: 'var(--switch-height)',
29
+ fontSize: 'var(--switch-indicator-font-size)',
30
+ fontWeight: 'medium',
31
+ flexShrink: 0,
32
+ userSelect: 'none',
33
+ display: 'grid',
34
+ placeContent: 'center',
35
+ transition: 'inset-inline-start 0.12s ease',
36
+ insetInlineStart: 'calc(var(--switch-x) - {spacing.xxs})',
37
+ _checked: {
38
+ insetInlineStart: 'xxs',
39
+ },
40
+ },
41
+ control: {
42
+ display: 'inline-flex',
43
+ gap: 'sm',
44
+ flexShrink: 0,
45
+ justifyContent: 'flex-start',
46
+ cursor: 'pointer',
47
+ borderRadius: 'full',
48
+ position: 'relative',
49
+ width: 'var(--switch-width)',
50
+ height: 'var(--switch-height)',
51
+ transition: 'backgrounds',
52
+ focusVisibleRing: 'outside',
53
+ _disabled: {
54
+ layerStyle: 'disabled',
55
+ },
56
+ },
57
+ thumb: {
58
+ display: 'flex',
59
+ alignItems: 'center',
60
+ justifyContent: 'center',
61
+ flexShrink: 0,
62
+ transitionProperty: 'translate',
63
+ transitionDuration: 'fast',
64
+ borderRadius: 'inherit',
65
+ _checked: {
66
+ translate: 'var(--switch-x) 0',
67
+ },
68
+ },
69
+ },
70
+ defaultVariants: {
71
+ variant: 'solid',
72
+ size: 'md',
73
+ },
74
+ variants: {
75
+ variant: {
76
+ solid: {
77
+ control: {
78
+ borderRadius: 'full',
79
+ bg: 'neutral.subtle.bg',
80
+ focusVisibleRing: 'outside',
81
+ _checked: {
82
+ bg: 'colorPalette.solid.bg',
83
+ },
84
+ },
85
+ thumb: {
86
+ bg: 'white',
87
+ _checked: {
88
+ bg: 'colorPalette.solid.fg',
89
+ },
90
+ width: 'var(--switch-height)',
91
+ height: 'var(--switch-height)',
92
+ scale: '0.8',
93
+ boxShadow: 'xs',
94
+ },
95
+ },
96
+ },
97
+ size: {
98
+ xs: {
99
+ root: {
100
+ gap: '2',
101
+ '--switch-width': 'sizes.8',
102
+ '--switch-height': 'sizes.4',
103
+ '--switch-indicator-font-size': 'fontSizes.xs',
104
+ },
105
+ label: { fontSize: 'sm' },
106
+ },
107
+ sm: {
108
+ root: {
109
+ gap: '2',
110
+ '--switch-width': 'sizes.9',
111
+ '--switch-height': 'sizes.4.5',
112
+ '--switch-indicator-font-size': 'fontSizes.xs',
113
+ },
114
+ label: { fontSize: 'sm' },
115
+ },
116
+ md: {
117
+ root: {
118
+ gap: '3',
119
+ '--switch-width': 'sizes.10',
120
+ '--switch-height': 'sizes.5',
121
+ '--switch-indicator-font-size': 'fontSizes.sm',
122
+ },
123
+ label: { fontSize: 'md' },
124
+ },
125
+ lg: {
126
+ root: {
127
+ gap: '3',
128
+ '--switch-width': 'sizes.11',
129
+ '--switch-height': 'sizes.5.5',
130
+ '--switch-indicator-font-size': 'fontSizes.md',
131
+ },
132
+ label: { fontSize: 'lg' },
133
+ },
134
+ },
135
+ },
136
+ });