dash-ui-kit 1.0.94 → 2.1.0-dev

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 (201) hide show
  1. package/README.md +52 -0
  2. package/dist/react/components/accordion/index.cjs.js +193 -0
  3. package/dist/react/components/accordion/index.cjs.js.map +1 -0
  4. package/dist/react/components/accordion/index.esm.js +169 -0
  5. package/dist/react/components/accordion/index.esm.js.map +1 -0
  6. package/dist/react/components/avatar/index.cjs.js +39 -0
  7. package/dist/react/components/avatar/index.cjs.js.map +1 -0
  8. package/dist/react/components/avatar/index.esm.js +34 -0
  9. package/dist/react/components/avatar/index.esm.js.map +1 -0
  10. package/dist/react/components/badge/index.cjs.js +97 -0
  11. package/dist/react/components/badge/index.cjs.js.map +1 -0
  12. package/dist/react/components/badge/index.d.ts +10 -1
  13. package/dist/react/components/badge/index.esm.js +92 -0
  14. package/dist/react/components/badge/index.esm.js.map +1 -0
  15. package/dist/react/components/bigNumber/index.cjs.js +100 -0
  16. package/dist/react/components/bigNumber/index.cjs.js.map +1 -0
  17. package/dist/react/components/bigNumber/index.esm.js +95 -0
  18. package/dist/react/components/bigNumber/index.esm.js.map +1 -0
  19. package/dist/react/components/button/index.cjs.js +540 -0
  20. package/dist/react/components/button/index.cjs.js.map +1 -0
  21. package/dist/react/components/button/index.d.ts +7 -1
  22. package/dist/react/components/button/index.esm.js +535 -0
  23. package/dist/react/components/button/index.esm.js.map +1 -0
  24. package/dist/react/components/copyButton/index.cjs.js +95 -0
  25. package/dist/react/components/copyButton/index.cjs.js.map +1 -0
  26. package/dist/react/components/copyButton/index.esm.js +71 -0
  27. package/dist/react/components/copyButton/index.esm.js.map +1 -0
  28. package/dist/react/components/dashLogo/index.cjs.js +74 -0
  29. package/dist/react/components/dashLogo/index.cjs.js.map +1 -0
  30. package/dist/react/components/dashLogo/index.esm.js +69 -0
  31. package/dist/react/components/dashLogo/index.esm.js.map +1 -0
  32. package/dist/react/components/dateBlock/index.cjs.js +120 -0
  33. package/dist/react/components/dateBlock/index.cjs.js.map +1 -0
  34. package/dist/react/components/dateBlock/index.esm.js +115 -0
  35. package/dist/react/components/dateBlock/index.esm.js.map +1 -0
  36. package/dist/react/components/dialog/index.cjs.js +292 -0
  37. package/dist/react/components/dialog/index.cjs.js.map +1 -0
  38. package/dist/react/components/dialog/index.esm.js +270 -0
  39. package/dist/react/components/dialog/index.esm.js.map +1 -0
  40. package/dist/react/components/heading/index.cjs.js +65 -0
  41. package/dist/react/components/heading/index.cjs.js.map +1 -0
  42. package/dist/react/components/heading/index.d.ts +4 -1
  43. package/dist/react/components/heading/index.esm.js +63 -0
  44. package/dist/react/components/heading/index.esm.js.map +1 -0
  45. package/dist/react/components/icons/index.cjs.js +1173 -0
  46. package/dist/react/components/icons/index.cjs.js.map +1 -0
  47. package/dist/react/components/icons/index.d.ts +2 -0
  48. package/dist/react/components/icons/index.esm.js +1128 -0
  49. package/dist/react/components/icons/index.esm.js.map +1 -0
  50. package/dist/react/components/identifier/index.cjs.js +286 -0
  51. package/dist/react/components/identifier/index.cjs.js.map +1 -0
  52. package/dist/react/components/identifier/index.esm.js +282 -0
  53. package/dist/react/components/identifier/index.esm.js.map +1 -0
  54. package/dist/react/components/index.cjs.js +101 -0
  55. package/dist/react/components/index.cjs.js.map +1 -0
  56. package/dist/react/components/index.d.ts +1 -1
  57. package/dist/react/components/index.esm.js +29 -0
  58. package/dist/react/components/index.esm.js.map +1 -0
  59. package/dist/react/components/input/index.cjs.js +242 -0
  60. package/dist/react/components/input/index.cjs.js.map +1 -0
  61. package/dist/react/components/input/index.d.ts +4 -0
  62. package/dist/react/components/input/index.esm.js +237 -0
  63. package/dist/react/components/input/index.esm.js.map +1 -0
  64. package/dist/react/components/list/index.cjs.js +49 -0
  65. package/dist/react/components/list/index.cjs.js.map +1 -0
  66. package/dist/react/components/list/index.esm.js +47 -0
  67. package/dist/react/components/list/index.esm.js.map +1 -0
  68. package/dist/react/components/notActive/index.cjs.js +40 -0
  69. package/dist/react/components/notActive/index.cjs.js.map +1 -0
  70. package/dist/react/components/notActive/index.esm.js +38 -0
  71. package/dist/react/components/notActive/index.esm.js.map +1 -0
  72. package/dist/react/components/overlayMenu/index.cjs.js +469 -0
  73. package/dist/react/components/overlayMenu/index.cjs.js.map +1 -0
  74. package/dist/react/components/overlayMenu/index.d.ts +9 -10
  75. package/dist/react/components/overlayMenu/index.esm.js +464 -0
  76. package/dist/react/components/overlayMenu/index.esm.js.map +1 -0
  77. package/dist/react/components/overlaySelect/index.cjs.js +350 -0
  78. package/dist/react/components/overlaySelect/index.cjs.js.map +1 -0
  79. package/dist/react/components/overlaySelect/index.d.ts +4 -0
  80. package/dist/react/components/overlaySelect/index.esm.js +345 -0
  81. package/dist/react/components/overlaySelect/index.esm.js.map +1 -0
  82. package/dist/react/components/progressStepBar/index.cjs.js +54 -0
  83. package/dist/react/components/progressStepBar/index.cjs.js.map +1 -0
  84. package/dist/react/components/progressStepBar/index.d.ts +5 -2
  85. package/dist/react/components/progressStepBar/index.esm.js +52 -0
  86. package/dist/react/components/progressStepBar/index.esm.js.map +1 -0
  87. package/dist/react/components/select/index.cjs.js +241 -0
  88. package/dist/react/components/select/index.cjs.js.map +1 -0
  89. package/dist/react/components/select/index.d.ts +4 -0
  90. package/dist/react/components/select/index.esm.js +217 -0
  91. package/dist/react/components/select/index.esm.js.map +1 -0
  92. package/dist/react/components/switch/index.cjs.js +184 -0
  93. package/dist/react/components/switch/index.cjs.js.map +1 -0
  94. package/dist/react/components/switch/index.esm.js +179 -0
  95. package/dist/react/components/switch/index.esm.js.map +1 -0
  96. package/dist/react/components/tabs/index.cjs.js +178 -0
  97. package/dist/react/components/tabs/index.cjs.js.map +1 -0
  98. package/dist/react/components/tabs/index.esm.js +154 -0
  99. package/dist/react/components/tabs/index.esm.js.map +1 -0
  100. package/dist/react/components/text/index.cjs.js +126 -0
  101. package/dist/react/components/text/index.cjs.js.map +1 -0
  102. package/dist/react/components/text/index.d.ts +5 -0
  103. package/dist/react/components/text/index.esm.js +121 -0
  104. package/dist/react/components/text/index.esm.js.map +1 -0
  105. package/dist/react/components/textarea/index.cjs.js +260 -0
  106. package/dist/react/components/textarea/index.cjs.js.map +1 -0
  107. package/dist/react/components/textarea/index.d.ts +4 -0
  108. package/dist/react/components/textarea/index.esm.js +255 -0
  109. package/dist/react/components/textarea/index.esm.js.map +1 -0
  110. package/dist/react/components/timeDelta/index.cjs.js +93 -0
  111. package/dist/react/components/timeDelta/index.cjs.js.map +1 -0
  112. package/dist/react/components/timeDelta/index.d.ts +1 -1
  113. package/dist/react/components/timeDelta/index.esm.js +88 -0
  114. package/dist/react/components/timeDelta/index.esm.js.map +1 -0
  115. package/dist/react/components/transactionStatusIcon/index.cjs.js +59 -0
  116. package/dist/react/components/transactionStatusIcon/index.cjs.js.map +1 -0
  117. package/dist/react/components/transactionStatusIcon/index.esm.js +54 -0
  118. package/dist/react/components/transactionStatusIcon/index.esm.js.map +1 -0
  119. package/dist/react/components/valueCard/index.cjs.js +181 -0
  120. package/dist/react/components/valueCard/index.cjs.js.map +1 -0
  121. package/dist/react/components/valueCard/index.d.ts +5 -1
  122. package/dist/react/components/valueCard/index.esm.js +176 -0
  123. package/dist/react/components/valueCard/index.esm.js.map +1 -0
  124. package/dist/react/contexts/ThemeContext.cjs.js +79 -0
  125. package/dist/react/contexts/ThemeContext.cjs.js.map +1 -0
  126. package/dist/react/contexts/ThemeContext.esm.js +76 -0
  127. package/dist/react/contexts/ThemeContext.esm.js.map +1 -0
  128. package/dist/react/contexts/index.cjs.js +11 -0
  129. package/dist/react/contexts/index.cjs.js.map +1 -0
  130. package/dist/react/contexts/index.esm.js +4 -0
  131. package/dist/react/contexts/index.esm.js.map +1 -0
  132. package/dist/react/hooks/index.d.ts +1 -0
  133. package/dist/react/hooks/useColorScheme.cjs.js +25 -0
  134. package/dist/react/hooks/useColorScheme.cjs.js.map +1 -0
  135. package/dist/react/hooks/useColorScheme.d.ts +9 -0
  136. package/dist/react/hooks/useColorScheme.esm.js +23 -0
  137. package/dist/react/hooks/useColorScheme.esm.js.map +1 -0
  138. package/dist/react/hooks/useDebounce.cjs.js +83 -0
  139. package/dist/react/hooks/useDebounce.cjs.js.map +1 -0
  140. package/dist/react/hooks/useDebounce.esm.js +78 -0
  141. package/dist/react/hooks/useDebounce.esm.js.map +1 -0
  142. package/dist/react/index.cjs.js +99 -12833
  143. package/dist/react/index.cjs.js.map +1 -1
  144. package/dist/react/index.d.ts +1 -1
  145. package/dist/react/index.esm.js +27 -12747
  146. package/dist/react/index.esm.js.map +1 -1
  147. package/dist/react/shared/utils/datetime.cjs.js +59 -0
  148. package/dist/react/shared/utils/datetime.cjs.js.map +1 -0
  149. package/dist/react/shared/utils/datetime.esm.js +57 -0
  150. package/dist/react/shared/utils/datetime.esm.js.map +1 -0
  151. package/dist/react/utils/copyToClipboard.cjs.js +31 -0
  152. package/dist/react/utils/copyToClipboard.cjs.js.map +1 -0
  153. package/dist/react/utils/copyToClipboard.esm.js +26 -0
  154. package/dist/react/utils/copyToClipboard.esm.js.map +1 -0
  155. package/dist/react/utils/index.d.ts +1 -1
  156. package/dist/react-native/components/avatar/index.d.ts +26 -0
  157. package/dist/react-native/components/avatar/index.web.d.ts +24 -0
  158. package/dist/react-native/components/badge/index.d.ts +63 -0
  159. package/dist/react-native/components/bigNumber/index.d.ts +26 -0
  160. package/dist/react-native/components/button/index.d.ts +45 -0
  161. package/dist/react-native/components/copyButton/index.d.ts +22 -0
  162. package/dist/react-native/components/copyButton/index.web.d.ts +20 -0
  163. package/dist/react-native/components/dashLogo/index.d.ts +30 -0
  164. package/dist/react-native/components/heading/index.d.ts +25 -0
  165. package/dist/react-native/components/icons/index.d.ts +43 -0
  166. package/dist/react-native/components/identifier/index.d.ts +47 -0
  167. package/dist/react-native/components/index.d.ts +15 -0
  168. package/dist/react-native/components/input/index.d.ts +59 -0
  169. package/dist/react-native/components/notActive/index.d.ts +16 -0
  170. package/dist/react-native/components/tabs/index.d.ts +50 -0
  171. package/dist/react-native/components/text/index.d.ts +28 -0
  172. package/dist/react-native/components/transactionStatusIcon/index.d.ts +24 -0
  173. package/dist/react-native/components/valueCard/index.d.ts +47 -0
  174. package/dist/react-native/hooks/index.d.ts +1 -0
  175. package/dist/react-native/hooks/useDebounce.d.ts +43 -0
  176. package/dist/react-native/index.cjs.js +2882 -0
  177. package/dist/react-native/index.cjs.js.map +1 -0
  178. package/dist/react-native/index.d.ts +4 -0
  179. package/dist/react-native/index.esm.js +2833 -0
  180. package/dist/react-native/index.esm.js.map +1 -0
  181. package/dist/react-native/styles/index.d.ts +11 -0
  182. package/dist/react-native/styles/tokens.d.ts +308 -0
  183. package/dist/react-native/styles/utils.d.ts +65 -0
  184. package/dist/react-native/utils/clipboard.d.ts +27 -0
  185. package/dist/react-native/utils/index.d.ts +3 -0
  186. package/dist/react-native/utils/resolveColorScheme.d.ts +1 -0
  187. package/dist/react-native/utils/tw.d.ts +7 -0
  188. package/dist/shared/constants/colors.d.ts +25 -0
  189. package/dist/shared/constants/index.d.ts +2 -0
  190. package/dist/shared/constants/sizes.d.ts +49 -0
  191. package/dist/shared/index.cjs.js +171 -0
  192. package/dist/shared/index.cjs.js.map +1 -0
  193. package/dist/shared/index.d.ts +3 -0
  194. package/dist/shared/index.esm.js +161 -0
  195. package/dist/shared/index.esm.js.map +1 -0
  196. package/dist/shared/types/common.d.ts +33 -0
  197. package/dist/shared/types/index.d.ts +1 -0
  198. package/dist/shared/utils/index.d.ts +1 -0
  199. package/dist/styles.css +1 -1
  200. package/package.json +50 -8
  201. /package/dist/{react → shared}/utils/datetime.d.ts +0 -0
@@ -0,0 +1,345 @@
1
+ "use client";
2
+
3
+ import { __rest } from 'tslib';
4
+ import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
5
+ import { useState, useRef } from 'react';
6
+ import { cva } from 'class-variance-authority';
7
+ import { useTheme } from '../../contexts/ThemeContext.esm.js';
8
+ import { CrossIcon } from '../icons/index.esm.js';
9
+ import { useColorScheme } from '../../hooks/useColorScheme.esm.js';
10
+
11
+ const overlaySelectTrigger = cva('w-full transition-all font-inter appearance-none cursor-pointer relative text-[0.875rem] leading-[1.0625rem] inline-flex items-center justify-between', {
12
+ variants: {
13
+ theme: {
14
+ light: 'text-dash-primary-dark-blue',
15
+ dark: 'text-white'
16
+ },
17
+ colorScheme: {
18
+ default: '',
19
+ brand: '',
20
+ error: '',
21
+ success: '',
22
+ gray: '',
23
+ lightGray: ''
24
+ },
25
+ size: {
26
+ sm: 'dash-block-sm',
27
+ md: 'dash-block-md',
28
+ xl: 'dash-block-xl'
29
+ },
30
+ border: {
31
+ true: 'outline outline-1 outline-offset-[-1px]',
32
+ false: ''
33
+ },
34
+ disabled: {
35
+ false: '',
36
+ true: 'opacity-60 cursor-not-allowed'
37
+ },
38
+ filled: {
39
+ false: '',
40
+ true: ''
41
+ }
42
+ },
43
+ compoundVariants: [{
44
+ colorScheme: 'default',
45
+ border: true,
46
+ class: 'outline-[rgba(12,28,51,0.35)] focus:outline-[rgba(12,28,51,0.6)]'
47
+ }, {
48
+ colorScheme: 'brand',
49
+ border: true,
50
+ class: 'outline-dash-brand/30 focus:outline-dash-brand'
51
+ }, {
52
+ colorScheme: 'error',
53
+ border: true,
54
+ class: 'outline-red-500 focus:outline-red-500'
55
+ }, {
56
+ colorScheme: 'success',
57
+ border: true,
58
+ class: 'outline-green-500 focus:outline-green-500'
59
+ }, {
60
+ colorScheme: 'gray',
61
+ border: true,
62
+ theme: 'light',
63
+ class: 'outline-[rgba(12,28,51,0.20)] focus:outline-[rgba(12,28,51,0.35)]'
64
+ }, {
65
+ colorScheme: 'gray',
66
+ border: true,
67
+ theme: 'dark',
68
+ class: 'outline-gray-600/50 focus:outline-gray-500'
69
+ }, {
70
+ colorScheme: 'lightGray',
71
+ border: true,
72
+ theme: 'light',
73
+ class: 'outline-dash-primary-dark-blue/[0.05] focus:outline-dash-primary-dark-blue/[0.05]'
74
+ }, {
75
+ colorScheme: 'lightGray',
76
+ border: true,
77
+ theme: 'dark',
78
+ class: 'outline-dash-primary-dark-blue/[0.05] focus:outline-dash-primary-dark-blue/[0.05]'
79
+ }, {
80
+ colorScheme: 'gray',
81
+ border: false,
82
+ theme: 'light',
83
+ class: 'bg-[rgba(12,28,51,0.03)]'
84
+ }, {
85
+ colorScheme: 'gray',
86
+ border: false,
87
+ theme: 'dark',
88
+ class: 'bg-gray-700/20'
89
+ },
90
+ // New lightGray scheme using dash-primary-dark-blue with 3% base and 5% hover
91
+ {
92
+ colorScheme: 'lightGray',
93
+ border: false,
94
+ theme: 'light',
95
+ class: 'bg-dash-primary-dark-blue/[0.03] hover:bg-dash-primary-dark-blue/[0.05]'
96
+ }, {
97
+ colorScheme: 'lightGray',
98
+ border: false,
99
+ theme: 'dark',
100
+ class: 'bg-dash-primary-dark-blue/[0.03] hover:bg-dash-primary-dark-blue/[0.05]'
101
+ }, {
102
+ colorScheme: 'lightGray',
103
+ filled: true,
104
+ theme: 'light',
105
+ class: 'bg-dash-primary-dark-blue/[0.03] hover:bg-dash-primary-dark-blue/[0.05]'
106
+ }, {
107
+ colorScheme: 'lightGray',
108
+ filled: true,
109
+ theme: 'dark',
110
+ class: 'bg-dash-primary-dark-blue/[0.03] hover:bg-dash-primary-dark-blue/[0.05]'
111
+ },
112
+ // Default background when not filled
113
+ {
114
+ filled: false,
115
+ theme: 'light',
116
+ class: 'bg-white'
117
+ }, {
118
+ filled: false,
119
+ theme: 'dark',
120
+ class: 'bg-gray-800'
121
+ },
122
+ // Filled variants
123
+ {
124
+ colorScheme: 'default',
125
+ filled: true,
126
+ theme: 'light',
127
+ class: 'bg-white text-gray-900'
128
+ }, {
129
+ colorScheme: 'default',
130
+ filled: true,
131
+ theme: 'dark',
132
+ class: 'bg-gray-700 text-white'
133
+ }, {
134
+ colorScheme: 'brand',
135
+ filled: true,
136
+ theme: 'light',
137
+ class: 'bg-blue-50 text-blue-700'
138
+ }, {
139
+ colorScheme: 'brand',
140
+ filled: true,
141
+ theme: 'dark',
142
+ class: 'bg-blue-900/30 text-blue-300'
143
+ }, {
144
+ colorScheme: 'error',
145
+ filled: true,
146
+ theme: 'light',
147
+ class: 'bg-red-50 text-red-700'
148
+ }, {
149
+ colorScheme: 'error',
150
+ filled: true,
151
+ theme: 'dark',
152
+ class: 'bg-red-500/20 text-red-400'
153
+ }, {
154
+ colorScheme: 'success',
155
+ filled: true,
156
+ theme: 'light',
157
+ class: 'bg-green-50 text-green-700'
158
+ }, {
159
+ colorScheme: 'success',
160
+ filled: true,
161
+ theme: 'dark',
162
+ class: 'bg-green-500/20 text-green-400'
163
+ }, {
164
+ colorScheme: 'gray',
165
+ filled: true,
166
+ theme: 'light',
167
+ class: 'bg-gray-200 text-gray-800'
168
+ }, {
169
+ colorScheme: 'gray',
170
+ filled: true,
171
+ theme: 'dark',
172
+ class: 'bg-gray-600 text-gray-200'
173
+ }],
174
+ defaultVariants: {
175
+ theme: 'light',
176
+ colorScheme: 'default',
177
+ size: 'xl',
178
+ border: true,
179
+ disabled: false,
180
+ filled: false
181
+ }
182
+ });
183
+ const overlayContent = cva('absolute z-50 min-w-full overflow-hidden shadow-lg', {
184
+ variants: {
185
+ theme: {
186
+ light: 'bg-white border border-[rgba(12,28,51,0.05)]',
187
+ dark: 'bg-[rgba(255,255,255,0.15)] border border-[rgba(255,255,255,0.15)] backdrop-blur-[256px]'
188
+ },
189
+ size: {
190
+ sm: 'rounded-[0.625rem]',
191
+ md: 'rounded-[0.875rem]',
192
+ xl: 'rounded-[1rem]'
193
+ }
194
+ }
195
+ });
196
+ const overlayItem = cva('relative flex cursor-pointer select-none items-center outline-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 rounded-none', {
197
+ variants: {
198
+ theme: {
199
+ light: 'text-[#0C1C33] hover:bg-gray-50',
200
+ dark: 'text-white hover:bg-[rgba(255,255,255,0.1)]'
201
+ },
202
+ size: {
203
+ sm: 'dash-block-sm',
204
+ md: 'dash-block-md',
205
+ xl: 'dash-block-xl'
206
+ }
207
+ }
208
+ });
209
+ // Arrow icon
210
+ const ChevronDownIcon = ({
211
+ className
212
+ }) => jsx("svg", {
213
+ width: '15',
214
+ height: '15',
215
+ viewBox: '0 0 15 15',
216
+ fill: 'none',
217
+ xmlns: 'http://www.w3.org/2000/svg',
218
+ className: className,
219
+ children: jsx("path", {
220
+ d: 'm4.93179 5.43179c0.20081-0.20081 0.52632-0.20081 0.72713 0l2.34108 2.34108 2.34108-2.34108c0.20081-0.20081 0.52632-0.20081 0.72713 0s0.20081 0.52632 0 0.72713l-2.70455 2.70455c-0.20081 0.20081-0.52632 0.20081-0.72713 0l-2.70455-2.70455c-0.20081-0.20081-0.20081-0.52632 0-0.72713z',
221
+ fill: 'currentColor',
222
+ fillRule: 'evenodd',
223
+ clipRule: 'evenodd'
224
+ })
225
+ });
226
+ /**
227
+ * Overlay select component that opens above the trigger with overlay positioning.
228
+ * Simple select component without additional button functionality.
229
+ */
230
+ const OverlaySelect = _a => {
231
+ var _b;
232
+ var {
233
+ className = '',
234
+ colorScheme,
235
+ colorSchemeLight,
236
+ colorSchemeDark,
237
+ size,
238
+ error = false,
239
+ success = false,
240
+ border = true,
241
+ filled = false,
242
+ disabled = false,
243
+ options = [],
244
+ showArrow = true,
245
+ value,
246
+ defaultValue,
247
+ onValueChange,
248
+ placeholder = 'Select an option...',
249
+ name,
250
+ overlayLabel,
251
+ maxHeight = '200px'
252
+ } = _a;
253
+ __rest(_a, ["className", "colorScheme", "colorSchemeLight", "colorSchemeDark", "size", "error", "success", "border", "filled", "disabled", "options", "showArrow", "value", "defaultValue", "onValueChange", "placeholder", "name", "overlayLabel", "maxHeight"]);
254
+ const {
255
+ theme
256
+ } = useTheme();
257
+ const [isOpen, setIsOpen] = useState(false);
258
+ const triggerRef = useRef(null);
259
+ const effectiveColorScheme = (_b = useColorScheme(colorScheme, colorSchemeLight, colorSchemeDark)) !== null && _b !== void 0 ? _b : 'default';
260
+ // Determine color scheme based on state
261
+ let finalColorScheme = effectiveColorScheme;
262
+ if (error) finalColorScheme = 'error';else if (success) finalColorScheme = 'success';
263
+ const triggerClasses = overlaySelectTrigger({
264
+ theme,
265
+ colorScheme: finalColorScheme,
266
+ size,
267
+ border,
268
+ filled,
269
+ disabled
270
+ }) + ' ' + className;
271
+ const contentClasses = overlayContent({
272
+ theme,
273
+ size
274
+ });
275
+ const itemClasses = overlayItem({
276
+ theme,
277
+ size
278
+ });
279
+ const selectedOption = options.find(opt => opt.value === value);
280
+ const handleOptionClick = optionValue => {
281
+ onValueChange === null || onValueChange === void 0 ? void 0 : onValueChange(optionValue);
282
+ setIsOpen(false);
283
+ };
284
+ return jsxs("div", {
285
+ className: 'relative',
286
+ children: [jsxs("button", {
287
+ ref: triggerRef,
288
+ type: 'button',
289
+ className: triggerClasses,
290
+ onClick: () => !disabled && setIsOpen(!isOpen),
291
+ disabled: disabled,
292
+ name: name,
293
+ children: [jsx("div", {
294
+ className: 'w-full flex-1 text-left',
295
+ children: selectedOption ? selectedOption.content || selectedOption.label : jsx("span", {
296
+ className: theme === 'dark' ? 'text-gray-400' : 'text-gray-500',
297
+ children: placeholder
298
+ })
299
+ }), showArrow && jsx(ChevronDownIcon, {
300
+ className: `transition-transform ${isOpen ? 'rotate-180' : ''} ${size === 'sm' ? 'w-3 h-3' : 'w-4 h-4'}`
301
+ })]
302
+ }), isOpen && jsxs(Fragment, {
303
+ children: [jsx("div", {
304
+ className: 'fixed inset-0 z-40',
305
+ onClick: () => setIsOpen(false)
306
+ }), jsxs("div", {
307
+ className: `${contentClasses} top-0 left-0 right-0`,
308
+ style: {
309
+ maxHeight
310
+ },
311
+ children: [overlayLabel && jsxs("div", {
312
+ className: `${itemClasses} font-medium border-b rounded-b-none cursor-pointer ${theme === 'dark' ? 'border-[rgba(255,255,255,0.15)]' : 'border-[rgba(12,28,51,0.05)]'}`,
313
+ onClick: () => setIsOpen(false),
314
+ children: [jsx("div", {
315
+ className: 'w-full flex-1',
316
+ children: overlayLabel
317
+ }), jsx("div", {
318
+ className: 'flex items-center pl-1',
319
+ children: jsx(CrossIcon, {
320
+ size: 16,
321
+ color: theme === 'dark' ? '#FFFFFF' : '#0C1C33',
322
+ className: 'cursor-pointer'
323
+ })
324
+ })]
325
+ }), jsx("div", {
326
+ className: 'overflow-y-auto',
327
+ style: {
328
+ maxHeight: `calc(${maxHeight} - ${overlayLabel ? '50px' : '0px'})`
329
+ },
330
+ children: options.map((option, index) => jsx("div", {
331
+ className: `${itemClasses} ${option.disabled ? 'opacity-50 cursor-not-allowed' : ''} ${index < options.length - 1 ? `border-b ${theme === 'dark' ? 'border-[rgba(255,255,255,0.15)]' : 'border-[rgba(12,28,51,0.05)]'}` : ''}`,
332
+ onClick: () => !option.disabled && handleOptionClick(option.value),
333
+ children: jsx("div", {
334
+ className: 'w-full flex-1 text-left',
335
+ children: option.content || option.label
336
+ })
337
+ }, option.value))
338
+ })]
339
+ })]
340
+ })]
341
+ });
342
+ };
343
+
344
+ export { OverlaySelect, OverlaySelect as default };
345
+ //# sourceMappingURL=index.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.esm.js","sources":["../../../../src/react/components/overlaySelect/index.tsx"],"sourcesContent":["import React, { useState, useRef } from 'react'\nimport { cva, VariantProps } from 'class-variance-authority'\nimport { useTheme } from '../../contexts/ThemeContext'\nimport { CrossIcon } from '../icons'\nimport { useColorScheme } from '../../hooks/useColorScheme'\n\nconst overlaySelectTrigger = cva(\n 'w-full transition-all font-inter appearance-none cursor-pointer relative text-[0.875rem] leading-[1.0625rem] inline-flex items-center justify-between',\n {\n variants: {\n theme: {\n light: 'text-dash-primary-dark-blue',\n dark: 'text-white'\n },\n colorScheme: {\n default: '',\n brand: '',\n error: '',\n success: '',\n gray: '',\n lightGray: ''\n },\n size: {\n sm: 'dash-block-sm',\n md: 'dash-block-md',\n xl: 'dash-block-xl'\n },\n border: {\n true: 'outline outline-1 outline-offset-[-1px]',\n false: ''\n },\n disabled: {\n false: '',\n true: 'opacity-60 cursor-not-allowed'\n },\n filled: {\n false: '',\n true: ''\n }\n },\n compoundVariants: [\n {\n colorScheme: 'default',\n border: true,\n class: 'outline-[rgba(12,28,51,0.35)] focus:outline-[rgba(12,28,51,0.6)]'\n },\n {\n colorScheme: 'brand',\n border: true,\n class: 'outline-dash-brand/30 focus:outline-dash-brand'\n },\n {\n colorScheme: 'error',\n border: true,\n class: 'outline-red-500 focus:outline-red-500'\n },\n {\n colorScheme: 'success',\n border: true,\n class: 'outline-green-500 focus:outline-green-500'\n },\n {\n colorScheme: 'gray',\n border: true,\n theme: 'light',\n class: 'outline-[rgba(12,28,51,0.20)] focus:outline-[rgba(12,28,51,0.35)]'\n },\n {\n colorScheme: 'gray',\n border: true,\n theme: 'dark',\n class: 'outline-gray-600/50 focus:outline-gray-500'\n },\n {\n colorScheme: 'lightGray',\n border: true,\n theme: 'light',\n class: 'outline-dash-primary-dark-blue/[0.05] focus:outline-dash-primary-dark-blue/[0.05]'\n },\n {\n colorScheme: 'lightGray',\n border: true,\n theme: 'dark',\n class: 'outline-dash-primary-dark-blue/[0.05] focus:outline-dash-primary-dark-blue/[0.05]'\n },\n {\n colorScheme: 'gray',\n border: false,\n theme: 'light',\n class: 'bg-[rgba(12,28,51,0.03)]'\n },\n {\n colorScheme: 'gray',\n border: false,\n theme: 'dark',\n class: 'bg-gray-700/20'\n },\n // New lightGray scheme using dash-primary-dark-blue with 3% base and 5% hover\n {\n colorScheme: 'lightGray',\n border: false,\n theme: 'light',\n class: 'bg-dash-primary-dark-blue/[0.03] hover:bg-dash-primary-dark-blue/[0.05]'\n },\n {\n colorScheme: 'lightGray',\n border: false,\n theme: 'dark',\n class: 'bg-dash-primary-dark-blue/[0.03] hover:bg-dash-primary-dark-blue/[0.05]'\n },\n {\n colorScheme: 'lightGray',\n filled: true,\n theme: 'light',\n class: 'bg-dash-primary-dark-blue/[0.03] hover:bg-dash-primary-dark-blue/[0.05]'\n },\n {\n colorScheme: 'lightGray',\n filled: true,\n theme: 'dark',\n class: 'bg-dash-primary-dark-blue/[0.03] hover:bg-dash-primary-dark-blue/[0.05]'\n },\n // Default background when not filled\n {\n filled: false,\n theme: 'light',\n class: 'bg-white'\n },\n {\n filled: false,\n theme: 'dark',\n class: 'bg-gray-800'\n },\n // Filled variants\n {\n colorScheme: 'default',\n filled: true,\n theme: 'light',\n class: 'bg-white text-gray-900'\n },\n {\n colorScheme: 'default',\n filled: true,\n theme: 'dark',\n class: 'bg-gray-700 text-white'\n },\n {\n colorScheme: 'brand',\n filled: true,\n theme: 'light',\n class: 'bg-blue-50 text-blue-700'\n },\n {\n colorScheme: 'brand',\n filled: true,\n theme: 'dark',\n class: 'bg-blue-900/30 text-blue-300'\n },\n {\n colorScheme: 'error',\n filled: true,\n theme: 'light',\n class: 'bg-red-50 text-red-700'\n },\n {\n colorScheme: 'error',\n filled: true,\n theme: 'dark',\n class: 'bg-red-500/20 text-red-400'\n },\n {\n colorScheme: 'success',\n filled: true,\n theme: 'light',\n class: 'bg-green-50 text-green-700'\n },\n {\n colorScheme: 'success',\n filled: true,\n theme: 'dark',\n class: 'bg-green-500/20 text-green-400'\n },\n {\n colorScheme: 'gray',\n filled: true,\n theme: 'light',\n class: 'bg-gray-200 text-gray-800'\n },\n {\n colorScheme: 'gray',\n filled: true,\n theme: 'dark',\n class: 'bg-gray-600 text-gray-200'\n }\n ],\n defaultVariants: {\n theme: 'light',\n colorScheme: 'default',\n size: 'xl',\n border: true,\n disabled: false,\n filled: false\n }\n }\n)\n\nconst overlayContent = cva(\n 'absolute z-50 min-w-full overflow-hidden shadow-lg',\n {\n variants: {\n theme: {\n light: 'bg-white border border-[rgba(12,28,51,0.05)]',\n dark: 'bg-[rgba(255,255,255,0.15)] border border-[rgba(255,255,255,0.15)] backdrop-blur-[256px]'\n },\n size: {\n sm: 'rounded-[0.625rem]',\n md: 'rounded-[0.875rem]',\n xl: 'rounded-[1rem]'\n }\n }\n }\n)\n\nconst overlayItem = cva(\n 'relative flex cursor-pointer select-none items-center outline-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 rounded-none',\n {\n variants: {\n theme: {\n light: 'text-[#0C1C33] hover:bg-gray-50',\n dark: 'text-white hover:bg-[rgba(255,255,255,0.1)]'\n },\n size: {\n sm: 'dash-block-sm',\n md: 'dash-block-md',\n xl: 'dash-block-xl'\n }\n }\n }\n)\n\n\n\ntype OverlaySelectVariants = VariantProps<typeof overlaySelectTrigger>\n\nexport interface OverlaySelectOption {\n value: string\n label: string\n disabled?: boolean\n content?: React.ReactNode\n}\n\nexport interface OverlaySelectProps extends Omit<OverlaySelectVariants, 'theme' | 'disabled'> {\n className?: string\n error?: boolean\n success?: boolean\n border?: boolean\n filled?: boolean\n options?: OverlaySelectOption[]\n showArrow?: boolean\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n placeholder?: string\n disabled?: boolean\n name?: string\n overlayLabel?: string\n maxHeight?: string\n /** Color scheme override for light theme */\n colorSchemeLight?: 'default' | 'brand' | 'error' | 'success' | 'gray' | 'lightGray'\n /** Color scheme override for dark theme */\n colorSchemeDark?: 'default' | 'brand' | 'error' | 'success' | 'gray' | 'lightGray'\n}\n\n// Arrow icon\nconst ChevronDownIcon: React.FC<{ className?: string }> = ({ className }) => (\n <svg\n width='15'\n height='15'\n viewBox='0 0 15 15'\n fill='none'\n xmlns='http://www.w3.org/2000/svg'\n className={className}\n >\n <path\n d='m4.93179 5.43179c0.20081-0.20081 0.52632-0.20081 0.72713 0l2.34108 2.34108 2.34108-2.34108c0.20081-0.20081 0.52632-0.20081 0.72713 0s0.20081 0.52632 0 0.72713l-2.70455 2.70455c-0.20081 0.20081-0.52632 0.20081-0.72713 0l-2.70455-2.70455c-0.20081-0.20081-0.20081-0.52632 0-0.72713z'\n fill='currentColor'\n fillRule='evenodd'\n clipRule='evenodd'\n />\n </svg>\n)\n\n\n\n\n\n/**\n * Overlay select component that opens above the trigger with overlay positioning.\n * Simple select component without additional button functionality.\n */\nexport const OverlaySelect: React.FC<OverlaySelectProps> = ({\n className = '',\n colorScheme,\n colorSchemeLight,\n colorSchemeDark,\n size,\n error = false,\n success = false,\n border = true,\n filled = false,\n disabled = false,\n options = [],\n showArrow = true,\n value,\n defaultValue,\n onValueChange,\n placeholder = 'Select an option...',\n name,\n overlayLabel,\n maxHeight = '200px',\n ...props\n}) => {\n const { theme } = useTheme()\n const [isOpen, setIsOpen] = useState(false)\n const triggerRef = useRef<HTMLButtonElement>(null)\n\n const effectiveColorScheme = useColorScheme(colorScheme, colorSchemeLight, colorSchemeDark) ?? 'default'\n\n // Determine color scheme based on state\n let finalColorScheme: typeof effectiveColorScheme = effectiveColorScheme\n if (error) finalColorScheme = 'error'\n else if (success) finalColorScheme = 'success'\n\n const triggerClasses = overlaySelectTrigger({\n theme,\n colorScheme: finalColorScheme,\n size,\n border,\n filled,\n disabled\n }) + ' ' + className\n\n const contentClasses = overlayContent({ theme, size })\n const itemClasses = overlayItem({ theme, size })\n\n\n const selectedOption = options.find(opt => opt.value === value)\n\n const handleOptionClick = (optionValue: string) => {\n onValueChange?.(optionValue)\n setIsOpen(false)\n }\n\n\n\n return (\n <div className='relative'>\n <button\n ref={triggerRef}\n type='button'\n className={triggerClasses}\n onClick={() => !disabled && setIsOpen(!isOpen)}\n disabled={disabled}\n name={name}\n >\n <div className='w-full flex-1 text-left'>\n {selectedOption ? (\n selectedOption.content || selectedOption.label\n ) : (\n <span className={theme === 'dark' ? 'text-gray-400' : 'text-gray-500'}>\n {placeholder}\n </span>\n )}\n </div>\n {showArrow && (\n <ChevronDownIcon \n className={`transition-transform ${isOpen ? 'rotate-180' : ''} ${\n size === 'sm' ? 'w-3 h-3' : 'w-4 h-4'\n }`} \n />\n )}\n </button>\n\n {isOpen && (\n <>\n {/* Backdrop */}\n <div \n className='fixed inset-0 z-40' \n onClick={() => setIsOpen(false)}\n />\n \n {/* Overlay content */}\n <div\n className={`${contentClasses} top-0 left-0 right-0`}\n style={{ maxHeight }}\n >\n {/* Overlay label */}\n {overlayLabel && (\n <div \n className={`${itemClasses} font-medium border-b rounded-b-none cursor-pointer ${\n theme === 'dark' ? 'border-[rgba(255,255,255,0.15)]' : 'border-[rgba(12,28,51,0.05)]'\n }`}\n onClick={() => setIsOpen(false)}\n >\n <div className='w-full flex-1'>\n {overlayLabel}\n </div>\n <div className='flex items-center pl-1'>\n <CrossIcon\n size={16} \n color={theme === 'dark' ? '#FFFFFF' : '#0C1C33'}\n className='cursor-pointer'\n />\n </div>\n </div>\n )}\n \n {/* Options */}\n <div className='overflow-y-auto' style={{ maxHeight: `calc(${maxHeight} - ${overlayLabel ? '50px' : '0px'})` }}>\n {options.map((option, index) => (\n <div\n key={option.value}\n className={`${itemClasses} ${option.disabled ? 'opacity-50 cursor-not-allowed' : ''} ${\n index < options.length - 1 \n ? `border-b ${theme === 'dark' ? 'border-[rgba(255,255,255,0.15)]' : 'border-[rgba(12,28,51,0.05)]'}`\n : ''\n }`}\n onClick={() => !option.disabled && handleOptionClick(option.value)}\n >\n <div className='w-full flex-1 text-left'>\n {option.content || option.label}\n </div>\n </div>\n ))}\n </div>\n \n\n </div>\n </>\n )}\n </div>\n )\n}\n\nexport default OverlaySelect\n"],"names":["overlaySelectTrigger","cva","variants","theme","light","dark","colorScheme","default","brand","error","success","gray","lightGray","size","sm","md","xl","border","true","false","disabled","filled","compoundVariants","class","defaultVariants","overlayContent","overlayItem","ChevronDownIcon","className","_jsx","width","height","viewBox","fill","xmlns","d","fillRule","clipRule","OverlaySelect","_a","colorSchemeLight","colorSchemeDark","options","showArrow","value","defaultValue","onValueChange","placeholder","name","overlayLabel","maxHeight","__rest","useTheme","isOpen","setIsOpen","useState","triggerRef","useRef","effectiveColorScheme","_b","useColorScheme","finalColorScheme","triggerClasses","contentClasses","itemClasses","selectedOption","find","opt","handleOptionClick","optionValue","_jsxs","children","ref","type","onClick","content","label","style","CrossIcon","color","map","option","index","length"],"mappings":"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"}
@@ -0,0 +1,54 @@
1
+ "use client";
2
+
3
+ 'use strict';
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var ThemeContext = require('../../contexts/ThemeContext.cjs.js');
7
+ var useColorScheme = require('../../hooks/useColorScheme.cjs.js');
8
+
9
+ const colorConfig = {
10
+ blue: {
11
+ active: 'bg-[var(--color-dash-brand)]',
12
+ activeDark: 'bg-[var(--color-dash-brand-dim)]',
13
+ inactive: 'bg-[rgba(76,126,255,0.16)]',
14
+ inactiveDark: 'bg-gray-700'
15
+ },
16
+ red: {
17
+ active: 'bg-[var(--color-dash-red)]',
18
+ activeDark: 'bg-[var(--color-dash-red-75)]',
19
+ inactive: 'bg-[var(--color-dash-red-15)]',
20
+ inactiveDark: 'bg-gray-700'
21
+ },
22
+ orange: {
23
+ active: 'bg-[var(--color-dash-orange)]',
24
+ activeDark: 'bg-[var(--color-dash-orange-75)]',
25
+ inactive: 'bg-[var(--color-dash-orange-15)]',
26
+ inactiveDark: 'bg-gray-700'
27
+ }
28
+ };
29
+ function ProgressStepBar({
30
+ currentStep,
31
+ totalSteps,
32
+ className = '',
33
+ color,
34
+ colorLight,
35
+ colorDark
36
+ }) {
37
+ var _a;
38
+ const {
39
+ theme
40
+ } = ThemeContext.useTheme();
41
+ const effectiveColor = (_a = useColorScheme.useColorScheme(color, colorLight, colorDark)) !== null && _a !== void 0 ? _a : 'blue';
42
+ const colors = colorConfig[effectiveColor];
43
+ return jsxRuntime.jsx("div", {
44
+ className: `flex gap-2 w-full ${className}`,
45
+ children: Array.from({
46
+ length: totalSteps
47
+ }, (_, index) => jsxRuntime.jsx("div", {
48
+ className: `h-1.5 rounded-2xl flex-1 transition-colors ${index < currentStep ? theme === 'dark' ? colors.activeDark : colors.active : theme === 'dark' ? colors.inactiveDark : colors.inactive}`
49
+ }, index))
50
+ });
51
+ }
52
+
53
+ exports.ProgressStepBar = ProgressStepBar;
54
+ //# sourceMappingURL=index.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs.js","sources":["../../../../src/react/components/progressStepBar/index.tsx"],"sourcesContent":["import React from 'react'\nimport { useTheme } from '../../contexts/ThemeContext'\nimport { useColorScheme } from '../../hooks/useColorScheme'\n\ntype ProgressColor = 'blue' | 'red' | 'orange'\n\ninterface ProgressStepBarProps {\n currentStep: number\n totalSteps: number\n className?: string\n color?: ProgressColor\n colorLight?: ProgressColor\n colorDark?: ProgressColor\n}\n\nconst colorConfig = {\n blue: {\n active: 'bg-[var(--color-dash-brand)]',\n activeDark: 'bg-[var(--color-dash-brand-dim)]',\n inactive: 'bg-[rgba(76,126,255,0.16)]',\n inactiveDark: 'bg-gray-700',\n },\n red: {\n active: 'bg-[var(--color-dash-red)]',\n activeDark: 'bg-[var(--color-dash-red-75)]',\n inactive: 'bg-[var(--color-dash-red-15)]',\n inactiveDark: 'bg-gray-700',\n },\n orange: {\n active: 'bg-[var(--color-dash-orange)]',\n activeDark: 'bg-[var(--color-dash-orange-75)]',\n inactive: 'bg-[var(--color-dash-orange-15)]',\n inactiveDark: 'bg-gray-700',\n },\n}\n\nexport function ProgressStepBar({ \n currentStep, \n totalSteps, \n className = '',\n color,\n colorLight,\n colorDark\n}: ProgressStepBarProps): React.JSX.Element {\n const { theme } = useTheme()\n const effectiveColor = useColorScheme(color, colorLight, colorDark) ?? 'blue'\n const colors = colorConfig[effectiveColor]\n \n return (\n <div className={`flex gap-2 w-full ${className}`}>\n {Array.from({ length: totalSteps }, (_, index) => (\n <div\n key={index}\n className={`h-1.5 rounded-2xl flex-1 transition-colors ${\n index < currentStep \n ? theme === 'dark' \n ? colors.activeDark \n : colors.active\n : theme === 'dark' \n ? colors.inactiveDark \n : colors.inactive\n }`}\n />\n ))}\n </div>\n )\n}\n\nexport type { ProgressStepBarProps } "],"names":["colorConfig","blue","active","activeDark","inactive","inactiveDark","red","orange","ProgressStepBar","currentStep","totalSteps","className","color","colorLight","colorDark","theme","useTheme","effectiveColor","_a","useColorScheme","colors","_jsx","children","Array","from","length","_","index"],"mappings":";;;;;;;;AAeA,MAAMA,WAAW,GAAG;AAClBC,EAAAA,IAAI,EAAE;AACJC,IAAAA,MAAM,EAAE,8BAA8B;AACtCC,IAAAA,UAAU,EAAE,kCAAkC;AAC9CC,IAAAA,QAAQ,EAAE,4BAA4B;AACtCC,IAAAA,YAAY,EAAE;GACf;AACDC,EAAAA,GAAG,EAAE;AACHJ,IAAAA,MAAM,EAAE,4BAA4B;AACpCC,IAAAA,UAAU,EAAE,+BAA+B;AAC3CC,IAAAA,QAAQ,EAAE,+BAA+B;AACzCC,IAAAA,YAAY,EAAE;GACf;AACDE,EAAAA,MAAM,EAAE;AACNL,IAAAA,MAAM,EAAE,+BAA+B;AACvCC,IAAAA,UAAU,EAAE,kCAAkC;AAC9CC,IAAAA,QAAQ,EAAE,kCAAkC;AAC5CC,IAAAA,YAAY,EAAE;AACf;CACF;SAEeG,eAAeA,CAAC;EAC9BC,WAAW;EACXC,UAAU;AACVC,EAAAA,SAAS,GAAG,EAAE;EACdC,KAAK;EACLC,UAAU;AACVC,EAAAA;AACqB,CAAA,EAAA;;EACrB,MAAM;AAAEC,IAAAA;GAAO,GAAGC,qBAAQ,EAAE;EAC5B,MAAMC,cAAc,GAAG,CAAAC,EAAA,GAAAC,6BAAc,CAACP,KAAK,EAAEC,UAAU,EAAEC,SAAS,CAAC,MAAA,IAAA,IAAAI,EAAA,KAAA,MAAA,GAAAA,EAAA,GAAI,MAAM;AAC7E,EAAA,MAAME,MAAM,GAAGpB,WAAW,CAACiB,cAAc,CAAC;EAE1C,OACEI,cAAA,CAAA,KAAA,EAAA;IAAKV,SAAS,EAAE,CAAqBA,kBAAAA,EAAAA,SAAS,CAAE,CAAA;AAC7CW,IAAAA,QAAA,EAAAC,KAAK,CAACC,IAAI,CAAC;AAAEC,MAAAA,MAAM,EAAEf;KAAY,EAAE,CAACgB,CAAC,EAAEC,KAAK,KAC3CN,cAAA,CAAA,KAAA,EAAA;AAEEV,MAAAA,SAAS,EAAE,CAAA,2CAAA,EACTgB,KAAK,GAAGlB,WAAW,GACfM,KAAK,KAAK,MAAM,GACdK,MAAM,CAACjB,UAAU,GACjBiB,MAAM,CAAClB,MAAM,GACfa,KAAK,KAAK,MAAM,GACdK,MAAM,CAACf,YAAY,GACnBe,MAAM,CAAChB,QACf,CAAA;KAAE,EATGuB,KAAK,CAWb;AACG,GAAA,CAAA;AAEV;;;;"}
@@ -1,9 +1,12 @@
1
1
  import React from 'react';
2
+ type ProgressColor = 'blue' | 'red' | 'orange';
2
3
  interface ProgressStepBarProps {
3
4
  currentStep: number;
4
5
  totalSteps: number;
5
6
  className?: string;
6
- color?: 'blue' | 'red' | 'orange';
7
+ color?: ProgressColor;
8
+ colorLight?: ProgressColor;
9
+ colorDark?: ProgressColor;
7
10
  }
8
- export declare function ProgressStepBar({ currentStep, totalSteps, className, color }: ProgressStepBarProps): React.JSX.Element;
11
+ export declare function ProgressStepBar({ currentStep, totalSteps, className, color, colorLight, colorDark }: ProgressStepBarProps): React.JSX.Element;
9
12
  export type { ProgressStepBarProps };
@@ -0,0 +1,52 @@
1
+ "use client";
2
+
3
+ import { jsx } from 'react/jsx-runtime';
4
+ import { useTheme } from '../../contexts/ThemeContext.esm.js';
5
+ import { useColorScheme } from '../../hooks/useColorScheme.esm.js';
6
+
7
+ const colorConfig = {
8
+ blue: {
9
+ active: 'bg-[var(--color-dash-brand)]',
10
+ activeDark: 'bg-[var(--color-dash-brand-dim)]',
11
+ inactive: 'bg-[rgba(76,126,255,0.16)]',
12
+ inactiveDark: 'bg-gray-700'
13
+ },
14
+ red: {
15
+ active: 'bg-[var(--color-dash-red)]',
16
+ activeDark: 'bg-[var(--color-dash-red-75)]',
17
+ inactive: 'bg-[var(--color-dash-red-15)]',
18
+ inactiveDark: 'bg-gray-700'
19
+ },
20
+ orange: {
21
+ active: 'bg-[var(--color-dash-orange)]',
22
+ activeDark: 'bg-[var(--color-dash-orange-75)]',
23
+ inactive: 'bg-[var(--color-dash-orange-15)]',
24
+ inactiveDark: 'bg-gray-700'
25
+ }
26
+ };
27
+ function ProgressStepBar({
28
+ currentStep,
29
+ totalSteps,
30
+ className = '',
31
+ color,
32
+ colorLight,
33
+ colorDark
34
+ }) {
35
+ var _a;
36
+ const {
37
+ theme
38
+ } = useTheme();
39
+ const effectiveColor = (_a = useColorScheme(color, colorLight, colorDark)) !== null && _a !== void 0 ? _a : 'blue';
40
+ const colors = colorConfig[effectiveColor];
41
+ return jsx("div", {
42
+ className: `flex gap-2 w-full ${className}`,
43
+ children: Array.from({
44
+ length: totalSteps
45
+ }, (_, index) => jsx("div", {
46
+ className: `h-1.5 rounded-2xl flex-1 transition-colors ${index < currentStep ? theme === 'dark' ? colors.activeDark : colors.active : theme === 'dark' ? colors.inactiveDark : colors.inactive}`
47
+ }, index))
48
+ });
49
+ }
50
+
51
+ export { ProgressStepBar };
52
+ //# sourceMappingURL=index.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.esm.js","sources":["../../../../src/react/components/progressStepBar/index.tsx"],"sourcesContent":["import React from 'react'\nimport { useTheme } from '../../contexts/ThemeContext'\nimport { useColorScheme } from '../../hooks/useColorScheme'\n\ntype ProgressColor = 'blue' | 'red' | 'orange'\n\ninterface ProgressStepBarProps {\n currentStep: number\n totalSteps: number\n className?: string\n color?: ProgressColor\n colorLight?: ProgressColor\n colorDark?: ProgressColor\n}\n\nconst colorConfig = {\n blue: {\n active: 'bg-[var(--color-dash-brand)]',\n activeDark: 'bg-[var(--color-dash-brand-dim)]',\n inactive: 'bg-[rgba(76,126,255,0.16)]',\n inactiveDark: 'bg-gray-700',\n },\n red: {\n active: 'bg-[var(--color-dash-red)]',\n activeDark: 'bg-[var(--color-dash-red-75)]',\n inactive: 'bg-[var(--color-dash-red-15)]',\n inactiveDark: 'bg-gray-700',\n },\n orange: {\n active: 'bg-[var(--color-dash-orange)]',\n activeDark: 'bg-[var(--color-dash-orange-75)]',\n inactive: 'bg-[var(--color-dash-orange-15)]',\n inactiveDark: 'bg-gray-700',\n },\n}\n\nexport function ProgressStepBar({ \n currentStep, \n totalSteps, \n className = '',\n color,\n colorLight,\n colorDark\n}: ProgressStepBarProps): React.JSX.Element {\n const { theme } = useTheme()\n const effectiveColor = useColorScheme(color, colorLight, colorDark) ?? 'blue'\n const colors = colorConfig[effectiveColor]\n \n return (\n <div className={`flex gap-2 w-full ${className}`}>\n {Array.from({ length: totalSteps }, (_, index) => (\n <div\n key={index}\n className={`h-1.5 rounded-2xl flex-1 transition-colors ${\n index < currentStep \n ? theme === 'dark' \n ? colors.activeDark \n : colors.active\n : theme === 'dark' \n ? colors.inactiveDark \n : colors.inactive\n }`}\n />\n ))}\n </div>\n )\n}\n\nexport type { ProgressStepBarProps } "],"names":["colorConfig","blue","active","activeDark","inactive","inactiveDark","red","orange","ProgressStepBar","currentStep","totalSteps","className","color","colorLight","colorDark","theme","useTheme","effectiveColor","_a","useColorScheme","colors","_jsx","children","Array","from","length","_","index"],"mappings":";;;;;;AAeA,MAAMA,WAAW,GAAG;AAClBC,EAAAA,IAAI,EAAE;AACJC,IAAAA,MAAM,EAAE,8BAA8B;AACtCC,IAAAA,UAAU,EAAE,kCAAkC;AAC9CC,IAAAA,QAAQ,EAAE,4BAA4B;AACtCC,IAAAA,YAAY,EAAE;GACf;AACDC,EAAAA,GAAG,EAAE;AACHJ,IAAAA,MAAM,EAAE,4BAA4B;AACpCC,IAAAA,UAAU,EAAE,+BAA+B;AAC3CC,IAAAA,QAAQ,EAAE,+BAA+B;AACzCC,IAAAA,YAAY,EAAE;GACf;AACDE,EAAAA,MAAM,EAAE;AACNL,IAAAA,MAAM,EAAE,+BAA+B;AACvCC,IAAAA,UAAU,EAAE,kCAAkC;AAC9CC,IAAAA,QAAQ,EAAE,kCAAkC;AAC5CC,IAAAA,YAAY,EAAE;AACf;CACF;SAEeG,eAAeA,CAAC;EAC9BC,WAAW;EACXC,UAAU;AACVC,EAAAA,SAAS,GAAG,EAAE;EACdC,KAAK;EACLC,UAAU;AACVC,EAAAA;AACqB,CAAA,EAAA;;EACrB,MAAM;AAAEC,IAAAA;GAAO,GAAGC,QAAQ,EAAE;EAC5B,MAAMC,cAAc,GAAG,CAAAC,EAAA,GAAAC,cAAc,CAACP,KAAK,EAAEC,UAAU,EAAEC,SAAS,CAAC,MAAA,IAAA,IAAAI,EAAA,KAAA,MAAA,GAAAA,EAAA,GAAI,MAAM;AAC7E,EAAA,MAAME,MAAM,GAAGpB,WAAW,CAACiB,cAAc,CAAC;EAE1C,OACEI,GAAA,CAAA,KAAA,EAAA;IAAKV,SAAS,EAAE,CAAqBA,kBAAAA,EAAAA,SAAS,CAAE,CAAA;AAC7CW,IAAAA,QAAA,EAAAC,KAAK,CAACC,IAAI,CAAC;AAAEC,MAAAA,MAAM,EAAEf;KAAY,EAAE,CAACgB,CAAC,EAAEC,KAAK,KAC3CN,GAAA,CAAA,KAAA,EAAA;AAEEV,MAAAA,SAAS,EAAE,CAAA,2CAAA,EACTgB,KAAK,GAAGlB,WAAW,GACfM,KAAK,KAAK,MAAM,GACdK,MAAM,CAACjB,UAAU,GACjBiB,MAAM,CAAClB,MAAM,GACfa,KAAK,KAAK,MAAM,GACdK,MAAM,CAACf,YAAY,GACnBe,MAAM,CAAChB,QACf,CAAA;KAAE,EATGuB,KAAK,CAWb;AACG,GAAA,CAAA;AAEV;;;;"}