@makolabs/ripple 0.0.1 → 0.0.3

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 (144) hide show
  1. package/README.md +575 -8
  2. package/dist/adapters/storage/BaseAdapter.d.ts +20 -0
  3. package/dist/adapters/storage/BaseAdapter.js +171 -0
  4. package/dist/adapters/storage/S3Adapter.d.ts +21 -0
  5. package/dist/adapters/storage/S3Adapter.js +194 -0
  6. package/dist/adapters/storage/index.d.ts +3 -0
  7. package/dist/adapters/storage/index.js +3 -0
  8. package/dist/adapters/storage/types.d.ts +102 -0
  9. package/dist/adapters/storage/types.js +4 -0
  10. package/dist/button/Button.svelte +48 -0
  11. package/dist/button/Button.svelte.d.ts +4 -0
  12. package/dist/button/button.d.ts +113 -0
  13. package/dist/button/button.js +168 -0
  14. package/dist/charts/Chart.svelte +545 -0
  15. package/dist/charts/Chart.svelte.d.ts +4 -0
  16. package/dist/drawer/Drawer.svelte +224 -0
  17. package/dist/drawer/Drawer.svelte.d.ts +4 -0
  18. package/dist/drawer/drawer.d.ts +160 -0
  19. package/dist/drawer/drawer.js +80 -0
  20. package/dist/elements/accordion/Accordion.svelte +98 -0
  21. package/dist/elements/accordion/Accordion.svelte.d.ts +4 -0
  22. package/dist/elements/accordion/accordion.d.ts +227 -0
  23. package/dist/elements/accordion/accordion.js +138 -0
  24. package/dist/elements/alert/Alert.svelte +57 -0
  25. package/dist/elements/alert/Alert.svelte.d.ts +4 -0
  26. package/dist/elements/badge/Badge.svelte +43 -0
  27. package/dist/elements/badge/Badge.svelte.d.ts +4 -0
  28. package/dist/elements/badge/badge.d.ts +181 -0
  29. package/dist/elements/badge/badge.js +65 -0
  30. package/dist/elements/dropdown/Dropdown.svelte +234 -0
  31. package/dist/elements/dropdown/Dropdown.svelte.d.ts +4 -0
  32. package/dist/elements/dropdown/Select.svelte +333 -0
  33. package/dist/elements/dropdown/Select.svelte.d.ts +4 -0
  34. package/dist/elements/dropdown/dropdown.d.ts +251 -0
  35. package/dist/elements/dropdown/dropdown.js +95 -0
  36. package/dist/elements/dropdown/select.d.ts +200 -0
  37. package/dist/elements/dropdown/select.js +82 -0
  38. package/dist/elements/file-upload/FileUpload.svelte +135 -0
  39. package/dist/elements/file-upload/FileUpload.svelte.d.ts +4 -0
  40. package/dist/elements/file-upload/FilesPreview.svelte +93 -0
  41. package/dist/elements/file-upload/FilesPreview.svelte.d.ts +4 -0
  42. package/dist/elements/progress/Progress.svelte +145 -0
  43. package/dist/elements/progress/Progress.svelte.d.ts +4 -0
  44. package/dist/elements/timeline/Timeline.svelte +92 -0
  45. package/dist/elements/timeline/Timeline.svelte.d.ts +7 -0
  46. package/dist/file-browser/FileBrowser.svelte +877 -0
  47. package/dist/file-browser/FileBrowser.svelte.d.ts +14 -0
  48. package/dist/file-browser/index.d.ts +1 -0
  49. package/dist/file-browser/index.js +1 -0
  50. package/dist/filters/CompactFilters.svelte +147 -0
  51. package/dist/filters/CompactFilters.svelte.d.ts +4 -0
  52. package/dist/filters/index.d.ts +1 -0
  53. package/dist/filters/index.js +1 -0
  54. package/dist/forms/Checkbox.svelte +54 -0
  55. package/dist/forms/Checkbox.svelte.d.ts +4 -0
  56. package/dist/forms/DateRange.svelte +493 -0
  57. package/dist/forms/DateRange.svelte.d.ts +4 -0
  58. package/dist/forms/Form.svelte +39 -0
  59. package/dist/forms/Form.svelte.d.ts +4 -0
  60. package/dist/forms/Input.svelte +86 -0
  61. package/dist/forms/Input.svelte.d.ts +4 -0
  62. package/dist/forms/NumberInput.svelte +159 -0
  63. package/dist/forms/NumberInput.svelte.d.ts +4 -0
  64. package/dist/forms/RadioInputs.svelte +64 -0
  65. package/dist/forms/RadioInputs.svelte.d.ts +4 -0
  66. package/dist/forms/RadioPill.svelte +66 -0
  67. package/dist/forms/RadioPill.svelte.d.ts +4 -0
  68. package/dist/forms/Slider.svelte +342 -0
  69. package/dist/forms/Slider.svelte.d.ts +4 -0
  70. package/dist/forms/Tags.svelte +181 -0
  71. package/dist/forms/Tags.svelte.d.ts +4 -0
  72. package/dist/forms/Toggle.svelte +132 -0
  73. package/dist/forms/Toggle.svelte.d.ts +4 -0
  74. package/dist/forms/slider.d.ts +143 -0
  75. package/dist/forms/slider.js +62 -0
  76. package/dist/header/Breadcrumbs.svelte +73 -0
  77. package/dist/header/Breadcrumbs.svelte.d.ts +4 -0
  78. package/dist/header/PageHeader.svelte +68 -0
  79. package/dist/header/PageHeader.svelte.d.ts +4 -0
  80. package/dist/header/breadcrumbs.d.ts +226 -0
  81. package/dist/header/breadcrumbs.js +87 -0
  82. package/dist/helper/cls.d.ts +1 -0
  83. package/dist/helper/cls.js +4 -0
  84. package/dist/helper/date.d.ts +7 -0
  85. package/dist/helper/date.js +15 -0
  86. package/dist/helper/nav.svelte.d.ts +6 -0
  87. package/dist/helper/nav.svelte.js +23 -0
  88. package/dist/index.d.ts +856 -1
  89. package/dist/index.js +78 -1
  90. package/dist/layout/card/Card.svelte +41 -0
  91. package/dist/layout/card/Card.svelte.d.ts +4 -0
  92. package/dist/layout/card/MetricCard.svelte +64 -0
  93. package/dist/layout/card/MetricCard.svelte.d.ts +4 -0
  94. package/dist/layout/card/StatsCard.svelte +266 -0
  95. package/dist/layout/card/StatsCard.svelte.d.ts +4 -0
  96. package/dist/layout/card/card.d.ts +128 -0
  97. package/dist/layout/card/card.js +51 -0
  98. package/dist/layout/card/metric-card.d.ts +49 -0
  99. package/dist/layout/card/metric-card.js +10 -0
  100. package/dist/layout/card/stats-card.d.ts +191 -0
  101. package/dist/layout/card/stats-card.js +73 -0
  102. package/dist/layout/navbar/Navbar.svelte +206 -0
  103. package/dist/layout/navbar/Navbar.svelte.d.ts +4 -0
  104. package/dist/layout/navbar/navbar.d.ts +205 -0
  105. package/dist/layout/navbar/navbar.js +98 -0
  106. package/dist/layout/sidebar/NavGroup.svelte +91 -0
  107. package/dist/layout/sidebar/NavGroup.svelte.d.ts +4 -0
  108. package/dist/layout/sidebar/NavItem.svelte +29 -0
  109. package/dist/layout/sidebar/NavItem.svelte.d.ts +4 -0
  110. package/dist/layout/sidebar/Sidebar.svelte +193 -0
  111. package/dist/layout/sidebar/Sidebar.svelte.d.ts +4 -0
  112. package/dist/layout/table/Cells.svelte +111 -0
  113. package/dist/layout/table/Cells.svelte.d.ts +27 -0
  114. package/dist/layout/table/Table.svelte +790 -0
  115. package/dist/layout/table/Table.svelte.d.ts +4 -0
  116. package/dist/layout/table/table.d.ts +256 -0
  117. package/dist/layout/table/table.js +141 -0
  118. package/dist/layout/tabs/Tab.svelte +60 -0
  119. package/dist/layout/tabs/Tab.svelte.d.ts +4 -0
  120. package/dist/layout/tabs/TabContent.svelte +30 -0
  121. package/dist/layout/tabs/TabContent.svelte.d.ts +4 -0
  122. package/dist/layout/tabs/TabGroup.svelte +62 -0
  123. package/dist/layout/tabs/TabGroup.svelte.d.ts +4 -0
  124. package/dist/layout/tabs/tabs.d.ts +140 -0
  125. package/dist/layout/tabs/tabs.js +298 -0
  126. package/dist/modal/Modal.svelte +207 -0
  127. package/dist/modal/Modal.svelte.d.ts +4 -0
  128. package/dist/modal/modal.d.ts +211 -0
  129. package/dist/modal/modal.js +81 -0
  130. package/dist/sonner/sonner.svelte +13 -0
  131. package/dist/sonner/sonner.svelte.d.ts +4 -0
  132. package/dist/types/variants.d.ts +1 -0
  133. package/dist/types/variants.js +1 -0
  134. package/dist/utils/Portal.svelte +108 -0
  135. package/dist/utils/Portal.svelte.d.ts +8 -0
  136. package/dist/utils/dateUtils.d.ts +7 -0
  137. package/dist/utils/dateUtils.js +26 -0
  138. package/dist/variants.d.ts +30 -0
  139. package/dist/variants.js +36 -0
  140. package/package.json +39 -6
  141. package/dist/layout/Card.svelte +0 -179
  142. package/dist/layout/Card.svelte.d.ts +0 -208
  143. package/dist/layout/index.d.ts +0 -1
  144. package/dist/layout/index.js +0 -1
@@ -0,0 +1,251 @@
1
+ import { Size } from '../../variants.js';
2
+ export declare const dropdownMenu: import("tailwind-variants").TVReturnType<{
3
+ position: {
4
+ 'top-left': {
5
+ container: string;
6
+ };
7
+ 'top-right': {
8
+ container: string;
9
+ };
10
+ 'bottom-left': {
11
+ container: string;
12
+ };
13
+ 'bottom-right': {
14
+ container: string;
15
+ };
16
+ };
17
+ size: {
18
+ [Size.XS]: {
19
+ trigger: string;
20
+ item: string;
21
+ itemIcon: string;
22
+ header: string;
23
+ headerTitle: string;
24
+ headerSubtitle: string;
25
+ };
26
+ [Size.SM]: {
27
+ trigger: string;
28
+ item: string;
29
+ itemIcon: string;
30
+ header: string;
31
+ headerTitle: string;
32
+ headerSubtitle: string;
33
+ };
34
+ [Size.BASE]: {
35
+ trigger: string;
36
+ item: string;
37
+ itemIcon: string;
38
+ header: string;
39
+ headerTitle: string;
40
+ headerSubtitle: string;
41
+ };
42
+ [Size.LG]: {
43
+ trigger: string;
44
+ item: string;
45
+ itemIcon: string;
46
+ header: string;
47
+ headerTitle: string;
48
+ headerSubtitle: string;
49
+ };
50
+ [Size.XL]: {
51
+ trigger: string;
52
+ item: string;
53
+ itemIcon: string;
54
+ header: string;
55
+ headerTitle: string;
56
+ headerSubtitle: string;
57
+ };
58
+ [Size.XXL]: {
59
+ trigger: string;
60
+ item: string;
61
+ itemIcon: string;
62
+ header: string;
63
+ headerTitle: string;
64
+ headerSubtitle: string;
65
+ };
66
+ };
67
+ isOpen: {
68
+ true: {};
69
+ };
70
+ iconOnly: {
71
+ true: {
72
+ trigger: string;
73
+ };
74
+ };
75
+ }, {
76
+ base: string;
77
+ trigger: string;
78
+ container: string;
79
+ section: string;
80
+ header: string;
81
+ headerTitle: string;
82
+ headerSubtitle: string;
83
+ item: string;
84
+ itemIcon: string;
85
+ }, undefined, {
86
+ position: {
87
+ 'top-left': {
88
+ container: string;
89
+ };
90
+ 'top-right': {
91
+ container: string;
92
+ };
93
+ 'bottom-left': {
94
+ container: string;
95
+ };
96
+ 'bottom-right': {
97
+ container: string;
98
+ };
99
+ };
100
+ size: {
101
+ [Size.XS]: {
102
+ trigger: string;
103
+ item: string;
104
+ itemIcon: string;
105
+ header: string;
106
+ headerTitle: string;
107
+ headerSubtitle: string;
108
+ };
109
+ [Size.SM]: {
110
+ trigger: string;
111
+ item: string;
112
+ itemIcon: string;
113
+ header: string;
114
+ headerTitle: string;
115
+ headerSubtitle: string;
116
+ };
117
+ [Size.BASE]: {
118
+ trigger: string;
119
+ item: string;
120
+ itemIcon: string;
121
+ header: string;
122
+ headerTitle: string;
123
+ headerSubtitle: string;
124
+ };
125
+ [Size.LG]: {
126
+ trigger: string;
127
+ item: string;
128
+ itemIcon: string;
129
+ header: string;
130
+ headerTitle: string;
131
+ headerSubtitle: string;
132
+ };
133
+ [Size.XL]: {
134
+ trigger: string;
135
+ item: string;
136
+ itemIcon: string;
137
+ header: string;
138
+ headerTitle: string;
139
+ headerSubtitle: string;
140
+ };
141
+ [Size.XXL]: {
142
+ trigger: string;
143
+ item: string;
144
+ itemIcon: string;
145
+ header: string;
146
+ headerTitle: string;
147
+ headerSubtitle: string;
148
+ };
149
+ };
150
+ isOpen: {
151
+ true: {};
152
+ };
153
+ iconOnly: {
154
+ true: {
155
+ trigger: string;
156
+ };
157
+ };
158
+ }, {
159
+ base: string;
160
+ trigger: string;
161
+ container: string;
162
+ section: string;
163
+ header: string;
164
+ headerTitle: string;
165
+ headerSubtitle: string;
166
+ item: string;
167
+ itemIcon: string;
168
+ }, import("tailwind-variants").TVReturnType<{
169
+ position: {
170
+ 'top-left': {
171
+ container: string;
172
+ };
173
+ 'top-right': {
174
+ container: string;
175
+ };
176
+ 'bottom-left': {
177
+ container: string;
178
+ };
179
+ 'bottom-right': {
180
+ container: string;
181
+ };
182
+ };
183
+ size: {
184
+ [Size.XS]: {
185
+ trigger: string;
186
+ item: string;
187
+ itemIcon: string;
188
+ header: string;
189
+ headerTitle: string;
190
+ headerSubtitle: string;
191
+ };
192
+ [Size.SM]: {
193
+ trigger: string;
194
+ item: string;
195
+ itemIcon: string;
196
+ header: string;
197
+ headerTitle: string;
198
+ headerSubtitle: string;
199
+ };
200
+ [Size.BASE]: {
201
+ trigger: string;
202
+ item: string;
203
+ itemIcon: string;
204
+ header: string;
205
+ headerTitle: string;
206
+ headerSubtitle: string;
207
+ };
208
+ [Size.LG]: {
209
+ trigger: string;
210
+ item: string;
211
+ itemIcon: string;
212
+ header: string;
213
+ headerTitle: string;
214
+ headerSubtitle: string;
215
+ };
216
+ [Size.XL]: {
217
+ trigger: string;
218
+ item: string;
219
+ itemIcon: string;
220
+ header: string;
221
+ headerTitle: string;
222
+ headerSubtitle: string;
223
+ };
224
+ [Size.XXL]: {
225
+ trigger: string;
226
+ item: string;
227
+ itemIcon: string;
228
+ header: string;
229
+ headerTitle: string;
230
+ headerSubtitle: string;
231
+ };
232
+ };
233
+ isOpen: {
234
+ true: {};
235
+ };
236
+ iconOnly: {
237
+ true: {
238
+ trigger: string;
239
+ };
240
+ };
241
+ }, {
242
+ base: string;
243
+ trigger: string;
244
+ container: string;
245
+ section: string;
246
+ header: string;
247
+ headerTitle: string;
248
+ headerSubtitle: string;
249
+ item: string;
250
+ itemIcon: string;
251
+ }, undefined, unknown, unknown, undefined>>;
@@ -0,0 +1,95 @@
1
+ import { tv } from '../../helper/cls.js';
2
+ import { Size } from '../../variants.js';
3
+ export const dropdownMenu = tv({
4
+ slots: {
5
+ base: 'inline-block text-left',
6
+ trigger: 'inline-flex w-full justify-center items-center gap-x-1.5 rounded-md bg-white px-3 py-2 text-sm font-semibold text-default-900 shadow-xs ring-1 ring-inset ring-default-300 hover:bg-default-50 cursor-pointer disabled:opacity-50 disabled:cursor-not-allowed',
7
+ container: 'absolute z-50 mt-2 origin-top-right divide-y divide-default-100 rounded-md bg-white ring-1 ring-black/5 shadow-lg focus:outline-none',
8
+ section: 'py-1',
9
+ header: 'flex flex-col px-4 py-2 w-full items-start',
10
+ headerTitle: 'text-sm font-medium text-default-900',
11
+ headerSubtitle: 'text-sm text-default-500',
12
+ item: 'w-full group flex items-center px-4 py-2 text-sm text-default-700 hover:bg-default-100 hover:text-default-900 data-[active=true]:bg-default-100 data-[active=true]:text-default-900 disabled:opacity-50 disabled:cursor-not-allowed',
13
+ itemIcon: 'mr-3 size-5 text-default-400 group-hover:text-default-500 group-data-[active=true]:text-default-500'
14
+ },
15
+ variants: {
16
+ position: {
17
+ 'top-left': {
18
+ container: 'origin-bottom-left bottom-full left-0 mb-2'
19
+ },
20
+ 'top-right': {
21
+ container: 'origin-bottom-right bottom-full right-0 mb-2'
22
+ },
23
+ 'bottom-left': {
24
+ container: 'origin-top-left top-full left-0 mt-2'
25
+ },
26
+ 'bottom-right': {
27
+ container: 'origin-top-right top-full right-0 mt-2'
28
+ }
29
+ },
30
+ size: {
31
+ [Size.XS]: {
32
+ trigger: 'px-2 py-1 text-xs',
33
+ item: 'px-2.5 py-1 text-xs',
34
+ itemIcon: 'mr-1.5 size-3.5',
35
+ header: 'px-2.5 py-1.5',
36
+ headerTitle: 'text-xs',
37
+ headerSubtitle: 'text-xs'
38
+ },
39
+ [Size.SM]: {
40
+ trigger: 'px-2.5 py-1.5 text-xs',
41
+ item: 'px-3 py-1.5 text-xs',
42
+ itemIcon: 'mr-2 size-4',
43
+ header: 'px-3 py-2',
44
+ headerTitle: 'text-xs',
45
+ headerSubtitle: 'text-xs'
46
+ },
47
+ [Size.BASE]: {
48
+ trigger: 'px-3 py-2 text-sm',
49
+ item: 'px-4 py-2 text-sm',
50
+ itemIcon: 'mr-3 size-5',
51
+ header: 'px-4 py-3',
52
+ headerTitle: 'text-sm',
53
+ headerSubtitle: 'text-sm'
54
+ },
55
+ [Size.LG]: {
56
+ trigger: 'px-4 py-2.5 text-base',
57
+ item: 'px-5 py-2.5 text-base',
58
+ itemIcon: 'mr-3 size-6',
59
+ header: 'px-5 py-3.5',
60
+ headerTitle: 'text-base',
61
+ headerSubtitle: 'text-sm'
62
+ },
63
+ [Size.XL]: {
64
+ trigger: 'px-5 py-3 text-lg',
65
+ item: 'px-6 py-3 text-lg',
66
+ itemIcon: 'mr-3.5 size-7',
67
+ header: 'px-6 py-4',
68
+ headerTitle: 'text-lg',
69
+ headerSubtitle: 'text-base'
70
+ },
71
+ [Size.XXL]: {
72
+ trigger: 'px-6 py-3.5 text-xl',
73
+ item: 'px-7 py-3.5 text-xl',
74
+ itemIcon: 'mr-4 size-8',
75
+ header: 'px-7 py-5',
76
+ headerTitle: 'text-xl',
77
+ headerSubtitle: 'text-lg'
78
+ }
79
+ },
80
+ isOpen: {
81
+ true: {}
82
+ },
83
+ iconOnly: {
84
+ true: {
85
+ trigger: 'inline-flex justify-center items-center cursor-pointer disabled:opacity-50 disabled:cursor-not-allowed bg-transparent shadow-none ring-0 hover:bg-transparent'
86
+ }
87
+ }
88
+ },
89
+ defaultVariants: {
90
+ position: 'bottom-right',
91
+ size: Size.BASE,
92
+ isOpen: false,
93
+ iconOnly: false
94
+ }
95
+ });
@@ -0,0 +1,200 @@
1
+ import { Size } from '../../variants.js';
2
+ export declare const selectTV: import("tailwind-variants").TVReturnType<{
3
+ size: {
4
+ [Size.XS]: {
5
+ trigger: string;
6
+ triggerIcon: string;
7
+ container: string;
8
+ item: string;
9
+ base: string;
10
+ };
11
+ [Size.SM]: {
12
+ trigger: string;
13
+ triggerIcon: string;
14
+ container: string;
15
+ item: string;
16
+ base: string;
17
+ };
18
+ [Size.BASE]: {
19
+ trigger: string;
20
+ triggerIcon: string;
21
+ container: string;
22
+ item: string;
23
+ base: string;
24
+ };
25
+ [Size.LG]: {
26
+ trigger: string;
27
+ triggerIcon: string;
28
+ container: string;
29
+ item: string;
30
+ base: string;
31
+ };
32
+ [Size.XL]: {
33
+ trigger: string;
34
+ triggerIcon: string;
35
+ container: string;
36
+ item: string;
37
+ base: string;
38
+ };
39
+ [Size.XXL]: {
40
+ trigger: string;
41
+ triggerIcon: string;
42
+ container: string;
43
+ item: string;
44
+ base: string;
45
+ };
46
+ };
47
+ disabled: {
48
+ true: {
49
+ trigger: string;
50
+ container: string;
51
+ item: string;
52
+ };
53
+ };
54
+ multiple: {
55
+ true: {
56
+ trigger: string;
57
+ };
58
+ };
59
+ }, {
60
+ base: string;
61
+ trigger: string;
62
+ triggerIcon: string;
63
+ container: string;
64
+ searchInput: string;
65
+ list: string;
66
+ item: string;
67
+ emptyMessage: string;
68
+ }, undefined, {
69
+ size: {
70
+ [Size.XS]: {
71
+ trigger: string;
72
+ triggerIcon: string;
73
+ container: string;
74
+ item: string;
75
+ base: string;
76
+ };
77
+ [Size.SM]: {
78
+ trigger: string;
79
+ triggerIcon: string;
80
+ container: string;
81
+ item: string;
82
+ base: string;
83
+ };
84
+ [Size.BASE]: {
85
+ trigger: string;
86
+ triggerIcon: string;
87
+ container: string;
88
+ item: string;
89
+ base: string;
90
+ };
91
+ [Size.LG]: {
92
+ trigger: string;
93
+ triggerIcon: string;
94
+ container: string;
95
+ item: string;
96
+ base: string;
97
+ };
98
+ [Size.XL]: {
99
+ trigger: string;
100
+ triggerIcon: string;
101
+ container: string;
102
+ item: string;
103
+ base: string;
104
+ };
105
+ [Size.XXL]: {
106
+ trigger: string;
107
+ triggerIcon: string;
108
+ container: string;
109
+ item: string;
110
+ base: string;
111
+ };
112
+ };
113
+ disabled: {
114
+ true: {
115
+ trigger: string;
116
+ container: string;
117
+ item: string;
118
+ };
119
+ };
120
+ multiple: {
121
+ true: {
122
+ trigger: string;
123
+ };
124
+ };
125
+ }, {
126
+ base: string;
127
+ trigger: string;
128
+ triggerIcon: string;
129
+ container: string;
130
+ searchInput: string;
131
+ list: string;
132
+ item: string;
133
+ emptyMessage: string;
134
+ }, import("tailwind-variants").TVReturnType<{
135
+ size: {
136
+ [Size.XS]: {
137
+ trigger: string;
138
+ triggerIcon: string;
139
+ container: string;
140
+ item: string;
141
+ base: string;
142
+ };
143
+ [Size.SM]: {
144
+ trigger: string;
145
+ triggerIcon: string;
146
+ container: string;
147
+ item: string;
148
+ base: string;
149
+ };
150
+ [Size.BASE]: {
151
+ trigger: string;
152
+ triggerIcon: string;
153
+ container: string;
154
+ item: string;
155
+ base: string;
156
+ };
157
+ [Size.LG]: {
158
+ trigger: string;
159
+ triggerIcon: string;
160
+ container: string;
161
+ item: string;
162
+ base: string;
163
+ };
164
+ [Size.XL]: {
165
+ trigger: string;
166
+ triggerIcon: string;
167
+ container: string;
168
+ item: string;
169
+ base: string;
170
+ };
171
+ [Size.XXL]: {
172
+ trigger: string;
173
+ triggerIcon: string;
174
+ container: string;
175
+ item: string;
176
+ base: string;
177
+ };
178
+ };
179
+ disabled: {
180
+ true: {
181
+ trigger: string;
182
+ container: string;
183
+ item: string;
184
+ };
185
+ };
186
+ multiple: {
187
+ true: {
188
+ trigger: string;
189
+ };
190
+ };
191
+ }, {
192
+ base: string;
193
+ trigger: string;
194
+ triggerIcon: string;
195
+ container: string;
196
+ searchInput: string;
197
+ list: string;
198
+ item: string;
199
+ emptyMessage: string;
200
+ }, undefined, unknown, unknown, undefined>>;
@@ -0,0 +1,82 @@
1
+ import { tv } from 'tailwind-variants';
2
+ import { Size } from '../../variants.js';
3
+ export const selectTV = tv({
4
+ slots: {
5
+ base: '',
6
+ trigger: `relative flex items-center justify-between w-full text-left bg-white border
7
+ border-default-300 text-sm focus-within:outline-none focus-within:ring-2 focus-within:ring-offset-2 focus-within:border-primary-500 focus-within:ring-primary-500 rounded-lg shadow-xs cursor-pointer transition-colors hover:border-default-400`,
8
+ triggerIcon: 'transition-transform duration-200 text-default-500',
9
+ container: 'absolute z-50 w-full mt-1 bg-white overflow-clip border border-default-200 rounded-md shadow-sm origin-top-left top-full left-0 mt-2',
10
+ searchInput: 'flex items-center gap-x-3 w-full outline-none px-2 h-10 border-b border-b-default-200',
11
+ list: 'py-1 max-h-60 overflow-x-clip overflow-y-auto h-full',
12
+ item: `w-full px-3 py-2 text-sm text-left
13
+ data-[highlighted=true]:bg-default-100 data-[highlighted=true]:text-default-700
14
+ data-[selected=true]:bg-info-100 data-[selected=true]:text-info-500 data-[selected=true]:font-medium
15
+ data-[selected=true]:data-[highlighted=true]:bg-info-200 data-[selected=true]:data-[highlighted=true]:text-info-500
16
+ cursor-pointer disabled:opacity-50 disabled:cursor-not-allowed`,
17
+ emptyMessage: 'px-3 py-2 text-sm text-default-500'
18
+ },
19
+ variants: {
20
+ size: {
21
+ [Size.XS]: {
22
+ trigger: 'h-6 px-2 py-1 text-xs gap-1',
23
+ triggerIcon: 'h-3 w-3',
24
+ container: 'max-h-40',
25
+ item: 'px-2 py-1 text-xs',
26
+ base: 'w-24'
27
+ },
28
+ [Size.SM]: {
29
+ trigger: 'h-8 px-3 py-2 text-sm gap-1.5',
30
+ triggerIcon: 'h-3.5 w-3.5',
31
+ container: 'max-h-48',
32
+ item: 'px-2.5 py-1.5 text-xs',
33
+ base: 'w-32'
34
+ },
35
+ [Size.BASE]: {
36
+ trigger: 'h-10 px-3 py-2 text-base gap-2',
37
+ triggerIcon: 'h-4 w-4',
38
+ container: 'max-h-60',
39
+ item: 'px-3 py-2 text-sm',
40
+ base: 'w-40'
41
+ },
42
+ [Size.LG]: {
43
+ trigger: 'h-12 px-3 py-2 text-lg gap-2.5',
44
+ triggerIcon: 'h-5 w-5',
45
+ container: 'max-h-72',
46
+ item: 'px-4 py-2.5 text-base',
47
+ base: 'w-48'
48
+ },
49
+ [Size.XL]: {
50
+ trigger: 'h-12 px-5 py-3 text-lg gap-3',
51
+ triggerIcon: 'h-6 w-6',
52
+ container: 'max-h-80',
53
+ item: 'px-5 py-3 text-lg',
54
+ base: 'w-56'
55
+ },
56
+ [Size.XXL]: {
57
+ trigger: 'h-14 px-6 py-3.5 text-xl gap-4',
58
+ triggerIcon: 'h-7 w-7',
59
+ container: 'max-h-96',
60
+ item: 'px-6 py-3.5 text-xl',
61
+ base: 'w-64'
62
+ }
63
+ },
64
+ disabled: {
65
+ true: {
66
+ trigger: 'opacity-50 cursor-not-allowed hover:border-default-300',
67
+ container: 'pointer-events-none',
68
+ item: 'disabled:opacity-50 disabled:cursor-not-allowed disabled:hover:bg-transparent'
69
+ }
70
+ },
71
+ multiple: {
72
+ true: {
73
+ trigger: 'flex-wrap min-h-[2.5rem]'
74
+ }
75
+ }
76
+ },
77
+ defaultVariants: {
78
+ size: 'base',
79
+ disabled: false,
80
+ multiple: false
81
+ }
82
+ });