@chitrank2050/monoline-ui 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (237) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +313 -0
  3. package/chunk-2T2JZW4Z.js +2 -0
  4. package/chunk-2T2JZW4Z.js.map +1 -0
  5. package/chunk-37JB3ZNS.js +2 -0
  6. package/chunk-37JB3ZNS.js.map +1 -0
  7. package/chunk-3F6Z4CFV.js +2 -0
  8. package/chunk-3F6Z4CFV.js.map +1 -0
  9. package/chunk-5TIKYN5B.js +2 -0
  10. package/chunk-5TIKYN5B.js.map +1 -0
  11. package/chunk-6AEWSPAE.js +2 -0
  12. package/chunk-6AEWSPAE.js.map +1 -0
  13. package/chunk-7ANXAXP5.js +2 -0
  14. package/chunk-7ANXAXP5.js.map +1 -0
  15. package/chunk-7SDVYBBO.js +2 -0
  16. package/chunk-7SDVYBBO.js.map +1 -0
  17. package/chunk-7WJF6B6G.js +2 -0
  18. package/chunk-7WJF6B6G.js.map +1 -0
  19. package/chunk-A2LXX23X.js +2 -0
  20. package/chunk-A2LXX23X.js.map +1 -0
  21. package/chunk-AACTIVV7.js +2 -0
  22. package/chunk-AACTIVV7.js.map +1 -0
  23. package/chunk-B5P3RAN2.js +2 -0
  24. package/chunk-B5P3RAN2.js.map +1 -0
  25. package/chunk-COFALEVG.js +2 -0
  26. package/chunk-COFALEVG.js.map +1 -0
  27. package/chunk-D3E4G2RE.js +2 -0
  28. package/chunk-D3E4G2RE.js.map +1 -0
  29. package/chunk-DJT3EVR4.js +2 -0
  30. package/chunk-DJT3EVR4.js.map +1 -0
  31. package/chunk-EWKGYQOX.js +2 -0
  32. package/chunk-EWKGYQOX.js.map +1 -0
  33. package/chunk-FLUGXF5D.js +2 -0
  34. package/chunk-FLUGXF5D.js.map +1 -0
  35. package/chunk-GSWZL5C2.js +2 -0
  36. package/chunk-GSWZL5C2.js.map +1 -0
  37. package/chunk-H2CRII7X.js +2 -0
  38. package/chunk-H2CRII7X.js.map +1 -0
  39. package/chunk-IVTAW6SX.js +3 -0
  40. package/chunk-IVTAW6SX.js.map +1 -0
  41. package/chunk-JBOP2AJB.js +2 -0
  42. package/chunk-JBOP2AJB.js.map +1 -0
  43. package/chunk-JCKPCV2H.js +2 -0
  44. package/chunk-JCKPCV2H.js.map +1 -0
  45. package/chunk-K665XZ3N.js +2 -0
  46. package/chunk-K665XZ3N.js.map +1 -0
  47. package/chunk-K72EORST.js +2 -0
  48. package/chunk-K72EORST.js.map +1 -0
  49. package/chunk-KGLH6WI6.js +2 -0
  50. package/chunk-KGLH6WI6.js.map +1 -0
  51. package/chunk-LVMQ3ZM3.js +2 -0
  52. package/chunk-LVMQ3ZM3.js.map +1 -0
  53. package/chunk-N37GMCSK.js +2 -0
  54. package/chunk-N37GMCSK.js.map +1 -0
  55. package/chunk-NDHOUIOX.js +2 -0
  56. package/chunk-NDHOUIOX.js.map +1 -0
  57. package/chunk-NDTTLW56.js +2 -0
  58. package/chunk-NDTTLW56.js.map +1 -0
  59. package/chunk-O43OQHFN.js +2 -0
  60. package/chunk-O43OQHFN.js.map +1 -0
  61. package/chunk-QGG3J7OW.js +2 -0
  62. package/chunk-QGG3J7OW.js.map +1 -0
  63. package/chunk-QUG36ONS.js +2 -0
  64. package/chunk-QUG36ONS.js.map +1 -0
  65. package/chunk-R2YSVBHS.js +2 -0
  66. package/chunk-R2YSVBHS.js.map +1 -0
  67. package/chunk-TSOHITZ7.js +2 -0
  68. package/chunk-TSOHITZ7.js.map +1 -0
  69. package/chunk-V6PUPMAY.js +3 -0
  70. package/chunk-V6PUPMAY.js.map +1 -0
  71. package/chunk-VSATIFOR.js +2 -0
  72. package/chunk-VSATIFOR.js.map +1 -0
  73. package/chunk-XEB7C557.js +2 -0
  74. package/chunk-XEB7C557.js.map +1 -0
  75. package/chunk-Z7SIB4X6.js +2 -0
  76. package/chunk-Z7SIB4X6.js.map +1 -0
  77. package/chunk-ZOPV3BXO.js +2 -0
  78. package/chunk-ZOPV3BXO.js.map +1 -0
  79. package/chunk-ZU3HIOBU.js +2 -0
  80. package/chunk-ZU3HIOBU.js.map +1 -0
  81. package/components/action-rail/index.d.ts +18 -0
  82. package/components/action-rail/index.js +2 -0
  83. package/components/action-rail/index.js.map +1 -0
  84. package/components/avatar/avatar.css +47 -0
  85. package/components/avatar/index.d.ts +28 -0
  86. package/components/avatar/index.js +2 -0
  87. package/components/avatar/index.js.map +1 -0
  88. package/components/back-link/back-link.css +30 -0
  89. package/components/back-link/index.d.ts +18 -0
  90. package/components/back-link/index.js +2 -0
  91. package/components/back-link/index.js.map +1 -0
  92. package/components/badge/badge.css +27 -0
  93. package/components/badge/index.d.ts +26 -0
  94. package/components/badge/index.js +2 -0
  95. package/components/badge/index.js.map +1 -0
  96. package/components/button/button.css +238 -0
  97. package/components/button/index.d.ts +36 -0
  98. package/components/button/index.js +2 -0
  99. package/components/button/index.js.map +1 -0
  100. package/components/callout/callout.css +20 -0
  101. package/components/callout/index.d.ts +20 -0
  102. package/components/callout/index.js +2 -0
  103. package/components/callout/index.js.map +1 -0
  104. package/components/card/card.css +166 -0
  105. package/components/card/index.d.ts +112 -0
  106. package/components/card/index.js +2 -0
  107. package/components/card/index.js.map +1 -0
  108. package/components/code-block/code-block.css +23 -0
  109. package/components/code-block/index.d.ts +21 -0
  110. package/components/code-block/index.js +2 -0
  111. package/components/code-block/index.js.map +1 -0
  112. package/components/command-search/command-search.css +217 -0
  113. package/components/command-search/index.d.ts +73 -0
  114. package/components/command-search/index.js +2 -0
  115. package/components/command-search/index.js.map +1 -0
  116. package/components/container/container.css +41 -0
  117. package/components/container/index.d.ts +11 -0
  118. package/components/container/index.js +2 -0
  119. package/components/container/index.js.map +1 -0
  120. package/components/data-list/data-list.css +139 -0
  121. package/components/data-list/index.d.ts +45 -0
  122. package/components/data-list/index.js +2 -0
  123. package/components/data-list/index.js.map +1 -0
  124. package/components/editorial-line/index.d.ts +24 -0
  125. package/components/editorial-line/index.js +2 -0
  126. package/components/editorial-line/index.js.map +1 -0
  127. package/components/eyebrow/eyebrow.css +13 -0
  128. package/components/eyebrow/index.d.ts +17 -0
  129. package/components/eyebrow/index.js +2 -0
  130. package/components/eyebrow/index.js.map +1 -0
  131. package/components/footer/footer.css +201 -0
  132. package/components/footer/index.d.ts +66 -0
  133. package/components/footer/index.js +2 -0
  134. package/components/footer/index.js.map +1 -0
  135. package/components/input/index.d.ts +28 -0
  136. package/components/input/index.js +2 -0
  137. package/components/input/index.js.map +1 -0
  138. package/components/input/input.css +37 -0
  139. package/components/link-list/index.d.ts +47 -0
  140. package/components/link-list/index.js +2 -0
  141. package/components/link-list/index.js.map +1 -0
  142. package/components/link-list/link-list.css +208 -0
  143. package/components/media-frame/index.d.ts +31 -0
  144. package/components/media-frame/index.js +2 -0
  145. package/components/media-frame/index.js.map +1 -0
  146. package/components/media-frame/media-frame.css +86 -0
  147. package/components/meta-row/index.d.ts +22 -0
  148. package/components/meta-row/index.js +2 -0
  149. package/components/meta-row/index.js.map +1 -0
  150. package/components/metric/index.d.ts +22 -0
  151. package/components/metric/index.js +2 -0
  152. package/components/metric/index.js.map +1 -0
  153. package/components/navbar/index.d.ts +78 -0
  154. package/components/navbar/index.js +2 -0
  155. package/components/navbar/index.js.map +1 -0
  156. package/components/navbar/navbar.css +245 -0
  157. package/components/progress/index.d.ts +20 -0
  158. package/components/progress/index.js +2 -0
  159. package/components/progress/index.js.map +1 -0
  160. package/components/progress/progress.css +31 -0
  161. package/components/pull-quote/index.d.ts +18 -0
  162. package/components/pull-quote/index.js +2 -0
  163. package/components/pull-quote/index.js.map +1 -0
  164. package/components/rail/index.d.ts +28 -0
  165. package/components/rail/index.js +2 -0
  166. package/components/rail/index.js.map +1 -0
  167. package/components/rail/rail.css +118 -0
  168. package/components/resources-panel/index.d.ts +42 -0
  169. package/components/resources-panel/index.js +2 -0
  170. package/components/resources-panel/index.js.map +1 -0
  171. package/components/resources-panel/resources-panel.css +396 -0
  172. package/components/section-head/index.d.ts +24 -0
  173. package/components/section-head/index.js +2 -0
  174. package/components/section-head/index.js.map +1 -0
  175. package/components/segmented-control/index.d.ts +28 -0
  176. package/components/segmented-control/index.js +2 -0
  177. package/components/segmented-control/index.js.map +1 -0
  178. package/components/segmented-control/segmented-control.css +177 -0
  179. package/components/select/index.d.ts +65 -0
  180. package/components/select/index.js +2 -0
  181. package/components/select/index.js.map +1 -0
  182. package/components/select/select.css +298 -0
  183. package/components/skeleton/index.d.ts +19 -0
  184. package/components/skeleton/index.js +2 -0
  185. package/components/skeleton/index.js.map +1 -0
  186. package/components/skeleton/skeleton.css +13 -0
  187. package/components/status/index.d.ts +20 -0
  188. package/components/status/index.js +2 -0
  189. package/components/status/index.js.map +1 -0
  190. package/components/status/status.css +86 -0
  191. package/components/tag/index.d.ts +35 -0
  192. package/components/tag/index.js +2 -0
  193. package/components/tag/index.js.map +1 -0
  194. package/components/tag/tag.css +10 -0
  195. package/components/testimonial/index.d.ts +30 -0
  196. package/components/testimonial/index.js +2 -0
  197. package/components/testimonial/index.js.map +1 -0
  198. package/components/testimonial/testimonial.css +109 -0
  199. package/components/testimonial-grid/index.d.ts +12 -0
  200. package/components/testimonial-grid/index.js +2 -0
  201. package/components/testimonial-grid/index.js.map +1 -0
  202. package/components/testimonial-grid/testimonial-grid.css +58 -0
  203. package/components/theme-switcher/index.d.ts +24 -0
  204. package/components/theme-switcher/index.js +2 -0
  205. package/components/theme-switcher/index.js.map +1 -0
  206. package/components/theme-switcher/theme-switcher.css +130 -0
  207. package/components/toast/index.d.ts +20 -0
  208. package/components/toast/index.js +2 -0
  209. package/components/toast/index.js.map +1 -0
  210. package/components/toast/toast.css +22 -0
  211. package/components/toc/index.d.ts +27 -0
  212. package/components/toc/index.js +2 -0
  213. package/components/toc/index.js.map +1 -0
  214. package/components/toggle/index.d.ts +20 -0
  215. package/components/toggle/index.js +2 -0
  216. package/components/toggle/index.js.map +1 -0
  217. package/components/toggle/toggle.css +108 -0
  218. package/foundations/breakpoints.d.ts +12 -0
  219. package/foundations/breakpoints.js +2 -0
  220. package/foundations/breakpoints.js.map +1 -0
  221. package/foundations/use-breakpoint.d.ts +5 -0
  222. package/foundations/use-breakpoint.js +3 -0
  223. package/foundations/use-breakpoint.js.map +1 -0
  224. package/index.d.ts +42 -0
  225. package/index.js +2 -0
  226. package/index.js.map +1 -0
  227. package/lib/utils.d.ts +7 -0
  228. package/lib/utils.js +2 -0
  229. package/lib/utils.js.map +1 -0
  230. package/package.json +228 -0
  231. package/styles/theme/animations.css +206 -0
  232. package/styles/theme/base.css +75 -0
  233. package/styles/theme/tailwind.css +371 -0
  234. package/styles/theme/tokens.css +562 -0
  235. package/styles/theme/typography.css +108 -0
  236. package/styles/theme/utilities.css +281 -0
  237. package/styles/theme.css +68 -0
@@ -0,0 +1,177 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .ml-segmented {
5
+ --ml-segmented-padding: var(--ml-space-0-5);
6
+ --ml-segmented-radius: var(--radius-lg);
7
+ --ml-segmented-item-radius: var(--radius-md);
8
+ --ml-segmented-item-padding: var(--ml-space-1-5) var(--ml-space-3);
9
+ --ml-segmented-font-size: var(--text-xs);
10
+ --ml-segmented-gap: var(--ml-space-1-5);
11
+
12
+ position: relative;
13
+ display: inline-flex;
14
+ border: var(--border-thin) solid var(--border);
15
+ border-radius: var(--ml-segmented-radius);
16
+ padding: var(--ml-segmented-padding);
17
+ background: var(--surface-2);
18
+ z-index: 1;
19
+ }
20
+
21
+ .ml-segmented__indicator {
22
+ position: absolute;
23
+ top: var(--ml-segmented-padding);
24
+ bottom: var(--ml-segmented-padding);
25
+ border: var(--border-thin) solid var(--border);
26
+ border-radius: var(--ml-segmented-item-radius);
27
+ background: var(--surface-3);
28
+ box-shadow: var(--shadow-sm);
29
+ opacity: 0;
30
+ transform-origin: left center;
31
+ transition: opacity var(--duration-micro) var(--ease-out);
32
+ pointer-events: none;
33
+ z-index: 0;
34
+ }
35
+
36
+ .ml-segmented__item {
37
+ position: relative;
38
+ display: inline-flex;
39
+ align-items: center;
40
+ gap: var(--ml-segmented-gap);
41
+ border-radius: var(--ml-segmented-item-radius);
42
+ padding: var(--ml-segmented-item-padding);
43
+ border: var(--border-thin) solid transparent;
44
+ color: var(--text-muted);
45
+ font-size: var(--ml-segmented-font-size);
46
+ font-weight: 550;
47
+ cursor: pointer;
48
+ white-space: nowrap;
49
+ transition: color var(--duration-micro) var(--ease-out);
50
+ z-index: 2;
51
+ }
52
+
53
+ .ml-segmented__item:hover:not(:disabled) {
54
+ color: var(--primary);
55
+ }
56
+
57
+ .ml-segmented__item:focus-visible {
58
+ outline: none;
59
+ box-shadow: var(--focus-ring);
60
+ }
61
+
62
+ .ml-segmented__item:disabled {
63
+ cursor: not-allowed;
64
+ opacity: 0.45;
65
+ }
66
+
67
+ .ml-segmented__item[aria-checked="true"] {
68
+ color: var(--primary);
69
+ }
70
+
71
+ .ml-segmented__label {
72
+ display: inline-flex;
73
+ align-items: center;
74
+ }
75
+
76
+ .ml-segmented__badge {
77
+ font-size: var(--text-2xs);
78
+ color: inherit;
79
+ opacity: 0.55;
80
+ }
81
+
82
+ /* Default Sizing Variants */
83
+ .ml-segmented--sm {
84
+ --ml-segmented-padding: var(--ml-space-0-5);
85
+ --ml-segmented-radius: var(--radius-md);
86
+ --ml-segmented-item-radius: var(--radius-sm);
87
+ --ml-segmented-item-padding: var(--ml-space-1) var(--ml-space-2);
88
+ --ml-segmented-font-size: var(--text-2xs);
89
+ --ml-segmented-gap: var(--ml-space-1);
90
+ }
91
+
92
+ .ml-segmented--md {
93
+ --ml-segmented-padding: var(--ml-space-0-5);
94
+ --ml-segmented-radius: var(--radius-lg);
95
+ --ml-segmented-item-radius: var(--radius-md);
96
+ --ml-segmented-item-padding: var(--ml-space-1-5) var(--ml-space-3);
97
+ --ml-segmented-font-size: var(--text-xs);
98
+ --ml-segmented-gap: var(--ml-space-1-5);
99
+ }
100
+
101
+ .ml-segmented--lg {
102
+ --ml-segmented-padding: var(--ml-space-0-5);
103
+ --ml-segmented-radius: var(--radius-xl);
104
+ --ml-segmented-item-radius: var(--radius-lg);
105
+ --ml-segmented-item-padding: var(--ml-space-2) var(--ml-space-4);
106
+ --ml-segmented-font-size: var(--text-base);
107
+ --ml-segmented-gap: var(--ml-space-2);
108
+ }
109
+
110
+ /* Pill variant */
111
+ .ml-segmented--pill {
112
+ --ml-segmented-padding: var(--ml-space-1);
113
+ --ml-segmented-radius: var(--radius-pill);
114
+ --ml-segmented-item-radius: var(--radius-pill);
115
+ --ml-segmented-item-padding: var(--ml-space-2) var(--ml-space-5);
116
+ --ml-segmented-font-size: var(--text-2xs);
117
+ --ml-segmented-gap: var(--ml-space-1-5);
118
+
119
+ border-color: var(--border-strong);
120
+ background: var(--surface);
121
+ }
122
+
123
+ /* Pill Sizing Variants */
124
+ .ml-segmented--pill.ml-segmented--sm {
125
+ --ml-segmented-padding: var(--ml-space-1);
126
+ --ml-segmented-item-padding: var(--ml-space-1-5) var(--ml-space-3);
127
+ --ml-segmented-font-size: var(--text-3xs);
128
+ --ml-segmented-gap: var(--ml-space-1);
129
+ }
130
+
131
+ .ml-segmented--pill.ml-segmented--md {
132
+ --ml-segmented-padding: var(--ml-space-1);
133
+ --ml-segmented-item-padding: var(--ml-space-2) var(--ml-space-5);
134
+ --ml-segmented-font-size: var(--text-2xs);
135
+ --ml-segmented-gap: var(--ml-space-1-5);
136
+ }
137
+
138
+ .ml-segmented--pill.ml-segmented--lg {
139
+ --ml-segmented-padding: var(--ml-space-1-5);
140
+ --ml-segmented-item-padding: var(--ml-space-3) var(--ml-space-6);
141
+ --ml-segmented-font-size: var(--text-xs);
142
+ --ml-segmented-gap: var(--ml-space-2);
143
+ }
144
+
145
+ .ml-segmented--pill .ml-segmented__indicator {
146
+ border-color: transparent;
147
+ background: var(--primary);
148
+ box-shadow: none;
149
+ }
150
+
151
+ .ml-segmented--pill .ml-segmented__item {
152
+ font-weight: 650;
153
+ letter-spacing: var(--tracking-wide);
154
+ text-transform: uppercase;
155
+ color: var(--text-body);
156
+ opacity: 0.72;
157
+ }
158
+
159
+ .ml-segmented--pill .ml-segmented__item:hover:not(:disabled) {
160
+ color: var(--text-body);
161
+ opacity: 1;
162
+ }
163
+
164
+ .ml-segmented--pill .ml-segmented__item[aria-checked="true"] {
165
+ color: var(--primary-foreground);
166
+ opacity: 1;
167
+ }
168
+
169
+ .ml-segmented--pill
170
+ .ml-segmented__item[aria-checked="true"]:hover:not(:disabled) {
171
+ color: var(--primary-foreground);
172
+ }
173
+
174
+ .ml-segmented--pill .ml-segmented__badge {
175
+ opacity: 0.6;
176
+ }
177
+ }
@@ -0,0 +1,65 @@
1
+ import * as React$1 from 'react';
2
+
3
+ type SelectSize = "sm" | "md" | "lg";
4
+ type SelectVariant = "default" | "ghost";
5
+ interface SelectOption<T extends string = string> {
6
+ value: T;
7
+ label: string;
8
+ description?: string;
9
+ disabled?: boolean;
10
+ }
11
+ interface SelectRootProps<T extends string = string> extends Omit<React$1.ComponentProps<"div">, "onChange"> {
12
+ value: T;
13
+ onChange: (value: T) => void;
14
+ options: SelectOption<T>[];
15
+ size?: SelectSize;
16
+ variant?: SelectVariant;
17
+ label?: string;
18
+ placeholder?: string;
19
+ sheetLabel?: string;
20
+ open?: boolean;
21
+ defaultOpen?: boolean;
22
+ onOpenChange?: (open: boolean) => void;
23
+ children?: React$1.ReactNode;
24
+ }
25
+ interface SelectTriggerProps extends Omit<React$1.ComponentProps<"button">, "children"> {
26
+ children?: React$1.ReactNode;
27
+ }
28
+ type SelectValueProps = React$1.ComponentProps<"span">;
29
+ type SelectLabelProps = React$1.ComponentProps<"span">;
30
+ interface SelectContentProps extends React$1.ComponentProps<"div"> {
31
+ children?: React$1.ReactNode;
32
+ }
33
+ interface SelectItemProps extends Omit<React$1.ComponentProps<"button">, "value" | "children"> {
34
+ value: string;
35
+ description?: string;
36
+ children: React$1.ReactNode;
37
+ }
38
+
39
+ declare function SelectContent({ children, className, onKeyDown, ref, ...props }: SelectContentProps): React.ReactElement | null;
40
+
41
+ declare function SelectItem({ className, description, onClick, value, disabled, children, ref, ...props }: SelectItemProps): React.ReactElement;
42
+
43
+ declare function SelectLabel({ className, ref, ...props }: SelectLabelProps): React.ReactElement;
44
+
45
+ declare function SelectRoot<T extends string>({ children, className, defaultOpen, label, onChange, onOpenChange, open: openProp, options, placeholder, sheetLabel, size, variant, value, ref, ...props }: SelectRootProps<T>): React.ReactElement;
46
+
47
+ declare function SelectTrigger({ className, children, onClick, onKeyDown, ref, type, ...props }: SelectTriggerProps): React.ReactElement;
48
+
49
+ declare function SelectValue({ className, ref, ...props }: SelectValueProps): React.ReactElement;
50
+
51
+ /**
52
+ * @module Select
53
+ * Description for Select component.
54
+ */
55
+
56
+ declare const Select: typeof SelectRoot & {
57
+ displayName: string;
58
+ Trigger: typeof SelectTrigger;
59
+ Label: typeof SelectLabel;
60
+ Value: typeof SelectValue;
61
+ Content: typeof SelectContent;
62
+ Item: typeof SelectItem;
63
+ };
64
+
65
+ export { Select, type SelectContentProps, type SelectItemProps, type SelectLabelProps, type SelectOption, type SelectRootProps, type SelectSize, type SelectTriggerProps, type SelectValueProps, type SelectVariant };
@@ -0,0 +1,2 @@
1
+ export{a as Select}from'../../chunk-IVTAW6SX.js';import'../../chunk-KGLH6WI6.js';import'../../chunk-XEB7C557.js';import'../../chunk-AACTIVV7.js';//# sourceMappingURL=index.js.map
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"index.js"}
@@ -0,0 +1,298 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .ml-select {
5
+ --ml-select-trigger-height: var(--ml-space-9);
6
+ --ml-select-trigger-padding-x: var(--ml-space-4);
7
+ --ml-select-trigger-gap: var(--ml-space-2);
8
+ --ml-select-trigger-text: var(--text-sm);
9
+ --ml-select-caret-size: var(--ml-space-4);
10
+ --ml-select-check-size: var(--ml-space-4);
11
+ --ml-select-content-radius: var(--radius-lg);
12
+ --ml-select-sheet-radius: var(--radius-2xl);
13
+ --ml-select-content-shadow: var(--shadow-lg);
14
+ --ml-select-sheet-shadow: var(--shadow-xl);
15
+ }
16
+
17
+ .ml-select[data-size="sm"] {
18
+ --ml-select-trigger-height: var(--ml-space-8);
19
+ --ml-select-trigger-padding-x: var(--ml-space-3);
20
+ --ml-select-trigger-gap: var(--ml-space-1-5);
21
+ --ml-select-trigger-text: var(--text-xs);
22
+ --ml-select-caret-size: var(--ml-space-3);
23
+ --ml-select-check-size: var(--ml-space-3);
24
+ }
25
+
26
+ .ml-select[data-size="lg"] {
27
+ --ml-select-trigger-height: var(--ml-space-10);
28
+ --ml-select-trigger-padding-x: var(--ml-space-5);
29
+ --ml-select-trigger-text: var(--text-base);
30
+ --ml-select-caret-size: var(--ml-space-4);
31
+ --ml-select-check-size: var(--ml-space-5);
32
+ }
33
+
34
+ .ml-select__trigger {
35
+ display: inline-flex;
36
+ align-items: center;
37
+ justify-content: space-between;
38
+ gap: var(--ml-select-trigger-gap);
39
+ block-size: var(--ml-select-trigger-height);
40
+ max-inline-size: 100%;
41
+ padding-inline: var(--ml-select-trigger-padding-x);
42
+ font-size: var(--ml-select-trigger-text);
43
+ border-radius: var(--radius-md);
44
+ line-height: 1;
45
+ transition:
46
+ background-color var(--duration-micro) var(--ease-out),
47
+ border-color var(--duration-micro) var(--ease-out),
48
+ color var(--duration-micro) var(--ease-out),
49
+ box-shadow var(--duration-micro) var(--ease-out);
50
+ }
51
+
52
+ .ml-select[data-open="true"] .ml-select__trigger {
53
+ border-color: var(--border-strong);
54
+ box-shadow: var(--shadow-sm);
55
+ }
56
+
57
+ .ml-select__trigger-copy {
58
+ display: inline-flex;
59
+ min-inline-size: 0;
60
+ flex: 0 1 auto;
61
+ align-items: center;
62
+ gap: var(--ml-select-trigger-gap);
63
+ line-height: 1;
64
+ }
65
+
66
+ .ml-select__label {
67
+ color: var(--text-body);
68
+ opacity: 0.58;
69
+ }
70
+
71
+ .ml-select__caret {
72
+ display: inline-block;
73
+ inline-size: var(--ml-select-caret-size);
74
+ block-size: var(--ml-select-caret-size);
75
+ flex: 0 0 auto;
76
+ color: var(--text-muted);
77
+ transition:
78
+ transform var(--duration-short) var(--ease-out-expo),
79
+ color var(--duration-micro) var(--ease-out);
80
+ }
81
+
82
+ .ml-select__trigger:hover .ml-select__caret,
83
+ .ml-select__trigger[aria-expanded="true"] .ml-select__caret {
84
+ color: currentcolor;
85
+ }
86
+
87
+ .ml-select__content {
88
+ position: absolute;
89
+ top: calc(100% + var(--ml-space-1-5));
90
+ left: 0;
91
+ z-index: var(--z-dropdown);
92
+ width: max-content;
93
+ min-width: 100%;
94
+ max-width: min(22rem, calc(100vw - var(--ml-space-8)));
95
+ overflow: hidden;
96
+ border: var(--border-thin) solid var(--border-strong);
97
+ border-radius: var(--ml-select-content-radius);
98
+ background: var(--popover);
99
+ color: var(--popover-foreground);
100
+ box-shadow: var(--ml-select-content-shadow);
101
+ transform-origin: top left;
102
+ animation: ml-select-content-enter var(--duration-fast) var(--ease-out-expo);
103
+ }
104
+
105
+ .ml-select__list {
106
+ display: flex;
107
+ flex-direction: column;
108
+ gap: var(--ml-space-0-5);
109
+ padding: var(--ml-space-1);
110
+ }
111
+
112
+ .ml-select__mobile-layer {
113
+ isolation: isolate;
114
+ }
115
+
116
+ .ml-select__backdrop {
117
+ background: color-mix(in oklch, var(--background) 42%, transparent);
118
+ animation: ml-select-backdrop-enter var(--duration-fast) var(--ease-out);
119
+ }
120
+
121
+ .ml-select__sheet-stack {
122
+ display: grid;
123
+ grid-template-rows: minmax(0, 1fr) auto;
124
+ gap: var(--ml-space-2);
125
+ max-block-size: calc(100dvh - var(--ml-space-6));
126
+ }
127
+
128
+ .ml-select__sheet {
129
+ display: flex;
130
+ flex-direction: column;
131
+ min-block-size: 0;
132
+ max-block-size: min(78dvh, 36rem);
133
+ overflow: hidden;
134
+ border: var(--border-thin) solid var(--border-strong);
135
+ border-radius: var(--ml-select-sheet-radius);
136
+ background: var(--popover);
137
+ color: var(--popover-foreground);
138
+ box-shadow: var(--ml-select-sheet-shadow);
139
+ animation: ml-select-sheet-enter var(--duration-short) var(--ease-out-expo);
140
+ }
141
+
142
+ .ml-select__sheet-handle-wrap {
143
+ display: flex;
144
+ justify-content: center;
145
+ padding-block-start: var(--ml-space-3);
146
+ }
147
+
148
+ .ml-select__sheet-handle {
149
+ inline-size: var(--ml-space-10);
150
+ block-size: var(--ml-space-1);
151
+ border-radius: var(--radius-pill);
152
+ background: var(--border-strong);
153
+ }
154
+
155
+ .ml-select__sheet-label {
156
+ padding: var(--ml-space-4) var(--ml-space-5) var(--ml-space-2);
157
+ color: var(--text-muted);
158
+ font-family: var(--font-mono);
159
+ font-size: var(--text-3xs);
160
+ font-weight: 600;
161
+ letter-spacing: var(--tracking-eyebrow);
162
+ text-transform: uppercase;
163
+ }
164
+
165
+ .ml-select__sheet .ml-select__list {
166
+ min-block-size: 0;
167
+ flex: 1 1 auto;
168
+ gap: 0;
169
+ padding: 0 var(--ml-space-3) var(--ml-space-3);
170
+ overflow-y: auto;
171
+ }
172
+
173
+ .ml-select__sheet-cancel {
174
+ display: flex;
175
+ min-height: var(--ml-space-12);
176
+ width: 100%;
177
+ align-items: center;
178
+ justify-content: center;
179
+ border: var(--border-thin) solid var(--border-strong);
180
+ border-radius: var(--radius-xl);
181
+ background: var(--button);
182
+ color: var(--primary);
183
+ font-size: var(--text-sm);
184
+ font-weight: 600;
185
+ box-shadow: var(--shadow-lg);
186
+ transition:
187
+ background-color var(--duration-micro) var(--ease-out),
188
+ border-color var(--duration-micro) var(--ease-out),
189
+ color var(--duration-micro) var(--ease-out),
190
+ transform var(--duration-micro) var(--ease-out);
191
+ }
192
+
193
+ .ml-select__sheet-cancel:hover {
194
+ border-color: var(--border-strong);
195
+ background: var(--button-hover);
196
+ }
197
+
198
+ .ml-select__sheet-cancel:active {
199
+ opacity: 0.86;
200
+ }
201
+
202
+ .ml-select__item {
203
+ gap: var(--ml-space-3);
204
+ border: 0;
205
+ background: transparent;
206
+ color: var(--text-body);
207
+ transform: translate3d(0, 0, 0);
208
+ transition:
209
+ background-color var(--duration-micro) var(--ease-out),
210
+ color var(--duration-micro) var(--ease-out);
211
+ }
212
+
213
+ .ml-select__item:hover {
214
+ background: var(--button-hover);
215
+ color: var(--primary);
216
+ }
217
+
218
+ .ml-select__item:active {
219
+ background: var(--surface-3);
220
+ }
221
+
222
+ .ml-select__item[data-selected="true"] {
223
+ background: var(--surface-2);
224
+ color: var(--primary);
225
+ font-weight: 650;
226
+ }
227
+
228
+ .ml-select__item[data-mobile="true"] {
229
+ min-block-size: var(--ml-space-12);
230
+ border-radius: 0;
231
+ border-block-end: var(--border-thin) solid var(--border);
232
+ background: transparent;
233
+ }
234
+
235
+ .ml-select__item[data-mobile="true"]:hover {
236
+ background: var(--button-hover);
237
+ }
238
+
239
+ .ml-select__item[data-mobile="true"][data-selected="true"] {
240
+ background: var(--surface-2);
241
+ }
242
+
243
+ .ml-select__item[data-mobile="true"]:first-child {
244
+ border-start-start-radius: var(--radius-lg);
245
+ border-start-end-radius: var(--radius-lg);
246
+ }
247
+
248
+ .ml-select__item[data-mobile="true"]:last-child {
249
+ border-block-end: 0;
250
+ border-end-start-radius: var(--radius-lg);
251
+ border-end-end-radius: var(--radius-lg);
252
+ }
253
+
254
+ .ml-select__item:focus-visible {
255
+ outline: none;
256
+ box-shadow: var(--focus-ring);
257
+ }
258
+
259
+ .ml-select__check {
260
+ margin-block-start: 0;
261
+ inline-size: var(--ml-select-check-size);
262
+ block-size: var(--ml-select-check-size);
263
+ }
264
+
265
+ @keyframes ml-select-content-enter {
266
+ from {
267
+ opacity: 0;
268
+ transform: translate3d(0, -2px, 0);
269
+ }
270
+
271
+ to {
272
+ opacity: 1;
273
+ transform: translate3d(0, 0, 0);
274
+ }
275
+ }
276
+
277
+ @keyframes ml-select-sheet-enter {
278
+ from {
279
+ opacity: 0;
280
+ transform: translate3d(0, 8px, 0);
281
+ }
282
+
283
+ to {
284
+ opacity: 1;
285
+ transform: translate3d(0, 0, 0);
286
+ }
287
+ }
288
+
289
+ @keyframes ml-select-backdrop-enter {
290
+ from {
291
+ opacity: 0;
292
+ }
293
+
294
+ to {
295
+ opacity: 1;
296
+ }
297
+ }
298
+ }
@@ -0,0 +1,19 @@
1
+ import * as React$1 from 'react';
2
+
3
+ type SkeletonVariant = "rect" | "pill" | "circle";
4
+ interface SkeletonProps extends React$1.ComponentProps<"div"> {
5
+ variant?: SkeletonVariant;
6
+ }
7
+
8
+ declare function SkeletonRoot({ className, variant, ref, ...props }: SkeletonProps): React.ReactElement;
9
+
10
+ /**
11
+ * @module Skeleton
12
+ * Description for Skeleton component.
13
+ */
14
+
15
+ declare const Skeleton: typeof SkeletonRoot & {
16
+ displayName: string;
17
+ };
18
+
19
+ export { Skeleton, type SkeletonProps, type SkeletonVariant };
@@ -0,0 +1,2 @@
1
+ export{a as Skeleton}from'../../chunk-7WJF6B6G.js';import'../../chunk-AACTIVV7.js';//# sourceMappingURL=index.js.map
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"index.js"}
@@ -0,0 +1,13 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .ml-skeleton {
5
+ background: linear-gradient(
6
+ 90deg,
7
+ var(--surface-2) 0%,
8
+ var(--surface-3) 50%,
9
+ var(--surface-2) 100%
10
+ );
11
+ background-size: 12.5rem 100%;
12
+ }
13
+ }
@@ -0,0 +1,20 @@
1
+ import * as React$1 from 'react';
2
+
3
+ type StatusVariant = "accent" | "success" | "muted";
4
+ type StatusSize = "sm" | "md" | "lg";
5
+ interface StatusProps extends React$1.ComponentProps<"span"> {
6
+ variant?: StatusVariant;
7
+ size?: StatusSize;
8
+ animate?: boolean;
9
+ }
10
+
11
+ declare function StatusRoot({ className, variant, size, animate, children, ref, ...props }: StatusProps): React.ReactElement;
12
+
13
+ /**
14
+ * @module status
15
+ * Description for status component.
16
+ */
17
+
18
+ declare const Status: typeof StatusRoot;
19
+
20
+ export { Status, type StatusProps, type StatusSize, type StatusVariant };
@@ -0,0 +1,2 @@
1
+ export{a as Status}from'../../chunk-DJT3EVR4.js';import'../../chunk-AACTIVV7.js';//# sourceMappingURL=index.js.map
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"index.js"}
@@ -0,0 +1,86 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .ml-status {
5
+ letter-spacing: var(--tracking-eyebrow);
6
+ }
7
+
8
+ .ml-status [data-slot="status-dot"] {
9
+ position: relative;
10
+ }
11
+
12
+ .ml-status [data-slot="status-dot"][data-animate="true"]::after {
13
+ content: "";
14
+ position: absolute;
15
+ inset: 0;
16
+ border-radius: inherit;
17
+ border: var(--border-thin) solid currentcolor;
18
+ opacity: 0;
19
+ animation: ml-status-sonar 2.4s var(--ease-out) infinite;
20
+ }
21
+
22
+ .ml-status--accent {
23
+ border-color: var(--accent);
24
+ background: var(--accent-soft);
25
+ color: var(--accent);
26
+ }
27
+
28
+ .ml-status--accent [data-slot="status-dot"] {
29
+ background: var(--accent);
30
+ box-shadow: 0 0 0 var(--space-1) var(--accent-soft);
31
+ }
32
+
33
+ .ml-status--success {
34
+ border-color: var(--callout-tip-accent);
35
+ background: color-mix(in oklch, var(--callout-tip-accent) 12%, transparent);
36
+ color: var(--callout-tip-text);
37
+ }
38
+
39
+ .ml-status--success [data-slot="status-dot"] {
40
+ background: var(--callout-tip-accent);
41
+ }
42
+
43
+ .ml-status--muted {
44
+ border-color: var(--border-strong);
45
+ background: transparent;
46
+ color: var(--muted-foreground);
47
+ }
48
+
49
+ .ml-status--muted [data-slot="status-dot"] {
50
+ background: var(--muted-foreground);
51
+ }
52
+
53
+ @keyframes ml-status-sonar {
54
+ 0% {
55
+ transform: scale(1);
56
+ opacity: 0.5;
57
+ }
58
+
59
+ 65% {
60
+ opacity: 0.08;
61
+ }
62
+
63
+ 100% {
64
+ transform: scale(1.85);
65
+ opacity: 0;
66
+ }
67
+ }
68
+
69
+ .ml-status--sm {
70
+ gap: var(--ml-space-1-5);
71
+ padding: var(--ml-space-1) var(--ml-space-2);
72
+ font-size: var(--text-3xs);
73
+ }
74
+
75
+ .ml-status--md {
76
+ gap: var(--ml-space-2);
77
+ padding: var(--ml-space-1) var(--ml-space-3);
78
+ font-size: var(--text-3xs);
79
+ }
80
+
81
+ .ml-status--lg {
82
+ gap: var(--ml-space-2);
83
+ padding: var(--ml-space-2) var(--ml-space-4);
84
+ font-size: var(--text-xs);
85
+ }
86
+ }