@latty-ds/web 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 (228) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +106 -0
  3. package/custom-elements.json +8785 -0
  4. package/dist/base/index.d.ts +1 -0
  5. package/dist/base/index.js +35 -0
  6. package/dist/base/themeable-element.d.ts +20 -0
  7. package/dist/components/accordion/accordion.d.ts +82 -0
  8. package/dist/components/accordion/accordion.styles.d.ts +1 -0
  9. package/dist/components/accordion/accordion.types.d.ts +10 -0
  10. package/dist/components/accordion/index.d.ts +8 -0
  11. package/dist/components/accordion/index.js +468 -0
  12. package/dist/components/alert/alert.d.ts +51 -0
  13. package/dist/components/alert/alert.styles.d.ts +1 -0
  14. package/dist/components/alert/alert.types.d.ts +2 -0
  15. package/dist/components/alert/index.d.ts +2 -0
  16. package/dist/components/alert/index.js +746 -0
  17. package/dist/components/avatar/avatar.d.ts +27 -0
  18. package/dist/components/avatar/avatar.styles.d.ts +1 -0
  19. package/dist/components/avatar/avatar.types.d.ts +3 -0
  20. package/dist/components/avatar/index.d.ts +2 -0
  21. package/dist/components/avatar/index.js +222 -0
  22. package/dist/components/badge/badge.d.ts +29 -0
  23. package/dist/components/badge/badge.styles.d.ts +1 -0
  24. package/dist/components/badge/badge.types.d.ts +3 -0
  25. package/dist/components/badge/index.d.ts +2 -0
  26. package/dist/components/badge/index.js +277 -0
  27. package/dist/components/breadcrumb/breadcrumb.d.ts +53 -0
  28. package/dist/components/breadcrumb/breadcrumb.styles.d.ts +2 -0
  29. package/dist/components/breadcrumb/breadcrumb.types.d.ts +1 -0
  30. package/dist/components/breadcrumb/index.d.ts +2 -0
  31. package/dist/components/breadcrumb/index.js +166 -0
  32. package/dist/components/button/button.d.ts +111 -0
  33. package/dist/components/button/button.styles.d.ts +1 -0
  34. package/dist/components/button/button.types.d.ts +38 -0
  35. package/dist/components/button/index.d.ts +8 -0
  36. package/dist/components/button/index.js +466 -0
  37. package/dist/components/calendar/calendar.d.ts +84 -0
  38. package/dist/components/calendar/calendar.styles.d.ts +1 -0
  39. package/dist/components/calendar/calendar.types.d.ts +15 -0
  40. package/dist/components/calendar/index.d.ts +1 -0
  41. package/dist/components/calendar/index.js +958 -0
  42. package/dist/components/checkbox/checkbox.d.ts +113 -0
  43. package/dist/components/checkbox/checkbox.styles.d.ts +1 -0
  44. package/dist/components/checkbox/checkbox.types.d.ts +21 -0
  45. package/dist/components/checkbox/index.d.ts +8 -0
  46. package/dist/components/checkbox/index.js +320 -0
  47. package/dist/components/chip/chip.d.ts +35 -0
  48. package/dist/components/chip/chip.styles.d.ts +1 -0
  49. package/dist/components/chip/chip.types.d.ts +3 -0
  50. package/dist/components/chip/index.d.ts +2 -0
  51. package/dist/components/chip/index.js +282 -0
  52. package/dist/components/color-input/color-input.d.ts +55 -0
  53. package/dist/components/color-input/color-input.styles.d.ts +1 -0
  54. package/dist/components/color-input/color-input.types.d.ts +2 -0
  55. package/dist/components/color-input/index.d.ts +1 -0
  56. package/dist/components/color-input/index.js +489 -0
  57. package/dist/components/combobox/combobox.d.ts +59 -0
  58. package/dist/components/combobox/combobox.styles.d.ts +1 -0
  59. package/dist/components/combobox/combobox.types.d.ts +7 -0
  60. package/dist/components/combobox/index.d.ts +2 -0
  61. package/dist/components/combobox/index.js +1988 -0
  62. package/dist/components/date-input/date-input.d.ts +66 -0
  63. package/dist/components/date-input/date-input.styles.d.ts +1 -0
  64. package/dist/components/date-input/date-input.types.d.ts +3 -0
  65. package/dist/components/date-input/index.d.ts +2 -0
  66. package/dist/components/date-input/index.js +2863 -0
  67. package/dist/components/datepicker/datepicker.d.ts +52 -0
  68. package/dist/components/datepicker/datepicker.styles.d.ts +1 -0
  69. package/dist/components/datepicker/datepicker.types.d.ts +3 -0
  70. package/dist/components/datepicker/index.d.ts +2 -0
  71. package/dist/components/datepicker/index.js +416 -0
  72. package/dist/components/dialog/dialog.d.ts +114 -0
  73. package/dist/components/dialog/dialog.styles.d.ts +1 -0
  74. package/dist/components/dialog/dialog.types.d.ts +11 -0
  75. package/dist/components/dialog/index.d.ts +2 -0
  76. package/dist/components/dialog/index.js +920 -0
  77. package/dist/components/divider/divider.d.ts +35 -0
  78. package/dist/components/divider/divider.styles.d.ts +1 -0
  79. package/dist/components/divider/divider.types.d.ts +2 -0
  80. package/dist/components/divider/index.d.ts +2 -0
  81. package/dist/components/divider/index.js +149 -0
  82. package/dist/components/dropdown/dropdown-item.d.ts +24 -0
  83. package/dist/components/dropdown/dropdown-item.styles.d.ts +1 -0
  84. package/dist/components/dropdown/dropdown.d.ts +30 -0
  85. package/dist/components/dropdown/dropdown.styles.d.ts +1 -0
  86. package/dist/components/dropdown/dropdown.types.d.ts +1 -0
  87. package/dist/components/dropdown/index.d.ts +3 -0
  88. package/dist/components/dropdown/index.js +1791 -0
  89. package/dist/components/header/header.d.ts +19 -0
  90. package/dist/components/header/header.styles.d.ts +1 -0
  91. package/dist/components/header/header.types.d.ts +1 -0
  92. package/dist/components/header/index.d.ts +2 -0
  93. package/dist/components/header/index.js +104 -0
  94. package/dist/components/icon-button/icon-button.d.ts +52 -0
  95. package/dist/components/icon-button/icon-button.styles.d.ts +1 -0
  96. package/dist/components/icon-button/icon-button.types.d.ts +8 -0
  97. package/dist/components/icon-button/index.d.ts +1 -0
  98. package/dist/components/icon-button/index.js +342 -0
  99. package/dist/components/image/image.d.ts +26 -0
  100. package/dist/components/image/image.styles.d.ts +1 -0
  101. package/dist/components/image/image.types.d.ts +0 -0
  102. package/dist/components/image/index.d.ts +1 -0
  103. package/dist/components/image/index.js +105 -0
  104. package/dist/components/link/index.d.ts +1 -0
  105. package/dist/components/link/index.js +108 -0
  106. package/dist/components/link/link.d.ts +22 -0
  107. package/dist/components/link/link.styles.d.ts +1 -0
  108. package/dist/components/link/link.types.d.ts +1 -0
  109. package/dist/components/list/index.d.ts +9 -0
  110. package/dist/components/list/index.js +254 -0
  111. package/dist/components/list/list-item.d.ts +41 -0
  112. package/dist/components/list/list-item.styles.d.ts +1 -0
  113. package/dist/components/list/list.d.ts +85 -0
  114. package/dist/components/list/list.styles.d.ts +1 -0
  115. package/dist/components/list/list.types.d.ts +16 -0
  116. package/dist/components/nav/index.d.ts +3 -0
  117. package/dist/components/nav/index.js +345 -0
  118. package/dist/components/nav/nav-item.d.ts +73 -0
  119. package/dist/components/nav/nav.d.ts +49 -0
  120. package/dist/components/nav/nav.styles.d.ts +2 -0
  121. package/dist/components/nav/nav.types.d.ts +1 -0
  122. package/dist/components/pagination/index.d.ts +2 -0
  123. package/dist/components/pagination/index.js +210 -0
  124. package/dist/components/pagination/pagination.d.ts +34 -0
  125. package/dist/components/pagination/pagination.styles.d.ts +1 -0
  126. package/dist/components/pagination/pagination.types.d.ts +1 -0
  127. package/dist/components/progress/index.d.ts +2 -0
  128. package/dist/components/progress/index.js +167 -0
  129. package/dist/components/progress/progress.d.ts +44 -0
  130. package/dist/components/progress/progress.styles.d.ts +1 -0
  131. package/dist/components/progress/progress.types.d.ts +2 -0
  132. package/dist/components/radio/index.d.ts +8 -0
  133. package/dist/components/radio/index.js +294 -0
  134. package/dist/components/radio/radio.d.ts +96 -0
  135. package/dist/components/radio/radio.styles.d.ts +1 -0
  136. package/dist/components/radio/radio.types.d.ts +21 -0
  137. package/dist/components/radio-group/index.d.ts +8 -0
  138. package/dist/components/radio-group/index.js +384 -0
  139. package/dist/components/radio-group/radio-group.d.ts +100 -0
  140. package/dist/components/radio-group/radio-group.styles.d.ts +1 -0
  141. package/dist/components/radio-group/radio-group.types.d.ts +8 -0
  142. package/dist/components/select/index.d.ts +8 -0
  143. package/dist/components/select/index.js +2123 -0
  144. package/dist/components/select/select.d.ts +129 -0
  145. package/dist/components/select/select.styles.d.ts +1 -0
  146. package/dist/components/select/select.types.d.ts +37 -0
  147. package/dist/components/shared/backdrop.styles.d.ts +1 -0
  148. package/dist/components/shared/floating.d.ts +10 -0
  149. package/dist/components/sidepanel/index.d.ts +1 -0
  150. package/dist/components/sidepanel/index.js +768 -0
  151. package/dist/components/sidepanel/sidepanel.d.ts +48 -0
  152. package/dist/components/sidepanel/sidepanel.styles.d.ts +1 -0
  153. package/dist/components/sidepanel/sidepanel.types.d.ts +1 -0
  154. package/dist/components/skeleton/index.d.ts +2 -0
  155. package/dist/components/skeleton/index.js +129 -0
  156. package/dist/components/skeleton/skeleton.d.ts +39 -0
  157. package/dist/components/skeleton/skeleton.styles.d.ts +1 -0
  158. package/dist/components/skeleton/skeleton.types.d.ts +1 -0
  159. package/dist/components/slider/index.d.ts +2 -0
  160. package/dist/components/slider/index.js +635 -0
  161. package/dist/components/slider/slider.d.ts +33 -0
  162. package/dist/components/slider/slider.styles.d.ts +1 -0
  163. package/dist/components/slider/slider.types.d.ts +1 -0
  164. package/dist/components/snackbar/index.d.ts +2 -0
  165. package/dist/components/snackbar/index.js +358 -0
  166. package/dist/components/snackbar/snackbar.d.ts +63 -0
  167. package/dist/components/snackbar/snackbar.styles.d.ts +1 -0
  168. package/dist/components/snackbar/snackbar.types.d.ts +1 -0
  169. package/dist/components/spinner/index.d.ts +8 -0
  170. package/dist/components/spinner/index.js +131 -0
  171. package/dist/components/spinner/spineer.styles.d.ts +1 -0
  172. package/dist/components/spinner/spinner.d.ts +52 -0
  173. package/dist/components/spinner/spinner.types.d.ts +18 -0
  174. package/dist/components/surface/index.d.ts +8 -0
  175. package/dist/components/surface/index.js +128 -0
  176. package/dist/components/surface/surface.d.ts +48 -0
  177. package/dist/components/surface/surface.styles.d.ts +1 -0
  178. package/dist/components/surface/surface.types.d.ts +20 -0
  179. package/dist/components/switch/index.d.ts +8 -0
  180. package/dist/components/switch/index.js +293 -0
  181. package/dist/components/switch/switch.d.ts +90 -0
  182. package/dist/components/switch/switch.styles.d.ts +1 -0
  183. package/dist/components/switch/switch.types.d.ts +21 -0
  184. package/dist/components/tab/index.d.ts +9 -0
  185. package/dist/components/tab/index.js +252 -0
  186. package/dist/components/tab/tab-panel.d.ts +28 -0
  187. package/dist/components/tab/tab-panel.styles.d.ts +1 -0
  188. package/dist/components/tab/tab.d.ts +59 -0
  189. package/dist/components/tab/tab.styles.d.ts +1 -0
  190. package/dist/components/tab/tab.types.d.ts +7 -0
  191. package/dist/components/tab-group/index.d.ts +8 -0
  192. package/dist/components/tab-group/index.js +441 -0
  193. package/dist/components/tab-group/tab-group.d.ts +99 -0
  194. package/dist/components/tab-group/tab-group.styles.d.ts +1 -0
  195. package/dist/components/tab-group/tab-group.types.d.ts +11 -0
  196. package/dist/components/table/index.d.ts +2 -0
  197. package/dist/components/table/index.js +582 -0
  198. package/dist/components/table/table.d.ts +160 -0
  199. package/dist/components/table/table.styles.d.ts +1 -0
  200. package/dist/components/table/table.types.d.ts +106 -0
  201. package/dist/components/text/index.d.ts +1 -0
  202. package/dist/components/text/index.js +207 -0
  203. package/dist/components/text/text.d.ts +32 -0
  204. package/dist/components/text/text.styles.d.ts +1 -0
  205. package/dist/components/text/text.types.d.ts +2 -0
  206. package/dist/components/textfield/index.d.ts +8 -0
  207. package/dist/components/textfield/index.js +718 -0
  208. package/dist/components/textfield/textfield.d.ts +168 -0
  209. package/dist/components/textfield/textfield.styles.d.ts +1 -0
  210. package/dist/components/textfield/textfield.types.d.ts +40 -0
  211. package/dist/components/tooltip/index.d.ts +2 -0
  212. package/dist/components/tooltip/index.js +379 -0
  213. package/dist/components/tooltip/tooltip.d.ts +42 -0
  214. package/dist/components/tooltip/tooltip.styles.d.ts +1 -0
  215. package/dist/components/tooltip/tooltip.types.d.ts +1 -0
  216. package/dist/css/font-face.css +22 -0
  217. package/dist/css/latty.css +57 -0
  218. package/dist/fonts/HankenGrotesk-Variable.woff2 +0 -0
  219. package/dist/fonts/HankenGrotesk-VariableItalic.woff2 +0 -0
  220. package/dist/index.cjs +12739 -0
  221. package/dist/index.d.ts +101 -0
  222. package/dist/index.js +11406 -0
  223. package/dist/manifest.json +2396 -0
  224. package/dist/utils/click-outside.d.ts +22 -0
  225. package/dist/utils/color.d.ts +14 -0
  226. package/dist/utils/dispatch.d.ts +18 -0
  227. package/dist/utils/index.d.ts +3 -0
  228. package/package.json +231 -0
@@ -0,0 +1,635 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __decorateClass = (decorators, target, key, kind) => {
4
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
5
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
6
+ if (decorator = decorators[i])
7
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
8
+ if (kind && result) __defProp(target, key, result);
9
+ return result;
10
+ };
11
+
12
+ // src/components/slider/slider.ts
13
+ import { html as html3 } from "lit";
14
+
15
+ // src/base/themeable-element.ts
16
+ import { LitElement } from "lit";
17
+ import { property } from "lit/decorators.js";
18
+ var ThemeableElement = class extends LitElement {
19
+ willUpdate(changed) {
20
+ super.willUpdate(changed);
21
+ if (changed.has("theme")) {
22
+ this._syncThemeAttribute();
23
+ }
24
+ }
25
+ _syncThemeAttribute() {
26
+ if (this.theme === "dark" || this.theme === "light") {
27
+ this.setAttribute("data-theme", this.theme);
28
+ } else {
29
+ this.removeAttribute("data-theme");
30
+ }
31
+ }
32
+ };
33
+ __decorateClass([
34
+ property({ reflect: true })
35
+ ], ThemeableElement.prototype, "theme", 2);
36
+
37
+ // src/components/slider/slider.ts
38
+ import { customElement as customElement3, property as property4, query as query2 } from "lit/decorators.js";
39
+
40
+ // src/components/slider/slider.styles.ts
41
+ import { css } from "lit";
42
+ var sliderStyles = css`
43
+ :host {
44
+ display: block;
45
+ font-family: 'Hanken Grotesk', sans-serif;
46
+ width: 100%;
47
+ }
48
+
49
+ label {
50
+ color: var(--lt-text-default);
51
+ display: block;
52
+ margin-bottom: var(--lt-spacing-1);
53
+ user-select: none;
54
+ }
55
+
56
+ .track-wrap {
57
+ align-items: center;
58
+ display: flex;
59
+ width: 100%;
60
+ }
61
+
62
+ /* lt-tooltip fills the track-wrap so the input stays full-width */
63
+ .track-wrap lt-tooltip {
64
+ display: block;
65
+ width: 100%;
66
+ }
67
+
68
+ /* Position the tooltip above the thumb rather than the track center */
69
+ lt-tooltip::part(tooltip) {
70
+ left: var(--_thumb-left, 50%);
71
+ }
72
+
73
+ input[type='range'] {
74
+ appearance: none;
75
+ background: linear-gradient(
76
+ to right,
77
+ var(--lt-interactive-primary-bg) var(--lt-slider-fill, 0%),
78
+ var(--lt-border-strong) var(--lt-slider-fill, 0%)
79
+ );
80
+ border-radius: 9999px;
81
+ cursor: pointer;
82
+ display: block;
83
+ height: var(--lt-slider-track-height, 6px);
84
+ outline: none;
85
+ transition: background 0ms;
86
+ width: 100%;
87
+ }
88
+
89
+ input[type='range']:focus-visible {
90
+ outline: 3px solid var(--lt-border-focus);
91
+ outline-offset: 3px;
92
+ }
93
+
94
+ input[type='range']:hover:not(:disabled) {
95
+ --lt-interactive-primary-bg: var(--lt-interactive-primary-bg-hover);
96
+ }
97
+
98
+ input[type='range']:active:not(:disabled) {
99
+ --lt-interactive-primary-bg: var(--lt-interactive-primary-bg-active);
100
+ }
101
+
102
+ /* Thumb — WebKit */
103
+ input[type='range']::-webkit-slider-thumb {
104
+ appearance: none;
105
+ background: var(--lt-interactive-primary-bg);
106
+ border-radius: 50%;
107
+ border: 2px solid white;
108
+ box-shadow: 0 1px 4px rgba(0, 0, 0, 0.25);
109
+ cursor: pointer;
110
+ height: var(--lt-slider-thumb-size, 18px);
111
+ transition: transform 100ms ease;
112
+ width: var(--lt-slider-thumb-size, 18px);
113
+ }
114
+
115
+ input[type='range']::-webkit-slider-thumb:hover {
116
+ transform: scale(1.15);
117
+ }
118
+
119
+ input[type='range']:active::-webkit-slider-thumb {
120
+ transform: scale(1.05);
121
+ }
122
+
123
+ /* Thumb — Firefox */
124
+ input[type='range']::-moz-range-thumb {
125
+ appearance: none;
126
+ background: var(--lt-interactive-primary-bg);
127
+ border-radius: 50%;
128
+ border: 2px solid white;
129
+ box-shadow: 0 1px 4px rgba(0, 0, 0, 0.25);
130
+ cursor: pointer;
131
+ height: var(--lt-slider-thumb-size, 18px);
132
+ transition: transform 100ms ease;
133
+ width: var(--lt-slider-thumb-size, 18px);
134
+ }
135
+
136
+ /* Track — Firefox */
137
+ input[type='range']::-moz-range-track {
138
+ background: var(--lt-border-strong);
139
+ border-radius: 9999px;
140
+ height: var(--lt-slider-track-height, 6px);
141
+ }
142
+
143
+ input[type='range']::-moz-range-progress {
144
+ background: var(--lt-interactive-primary-bg);
145
+ border-radius: 9999px;
146
+ height: var(--lt-slider-track-height, 6px);
147
+ }
148
+
149
+ /* Sizes */
150
+ :host([size='sm']) {
151
+ --lt-slider-track-height: 4px;
152
+ --lt-slider-thumb-size: 14px;
153
+ }
154
+
155
+ :host([size='md']) {
156
+ --lt-slider-track-height: 6px;
157
+ --lt-slider-thumb-size: 18px;
158
+ }
159
+
160
+ :host([size='lg']) {
161
+ --lt-slider-track-height: 8px;
162
+ --lt-slider-thumb-size: 22px;
163
+ }
164
+
165
+ /* Disabled */
166
+ :host([disabled]) {
167
+ opacity: 0.5;
168
+ }
169
+
170
+ :host([disabled]) input[type='range'] {
171
+ cursor: not-allowed;
172
+ pointer-events: none;
173
+ }
174
+ `;
175
+
176
+ // src/components/tooltip/tooltip.ts
177
+ import { html as html2 } from "lit";
178
+ import { customElement as customElement2, property as property3, query } from "lit/decorators.js";
179
+ import { styleMap } from "lit/directives/style-map.js";
180
+
181
+ // src/components/tooltip/tooltip.styles.ts
182
+ import { css as css2 } from "lit";
183
+ var tooltipStyles = css2`
184
+ :host {
185
+ display: inline-block;
186
+ position: relative;
187
+ --lt-tooltip-offset: 8px;
188
+ }
189
+
190
+ .tooltip {
191
+ background: var(--lt-tooltip-bg, var(--lt-bg-inverse));
192
+ border-radius: 4px;
193
+ color: var(--lt-tooltip-color, var(--lt-text-inverse));
194
+ opacity: 0;
195
+ padding: var(--lt-spacing-1) var(--lt-spacing-2);
196
+ pointer-events: none;
197
+ position: absolute;
198
+ transition:
199
+ opacity 150ms ease,
200
+ visibility 150ms ease;
201
+ visibility: hidden;
202
+ white-space: nowrap;
203
+ z-index: 1000;
204
+ }
205
+
206
+ .arrow {
207
+ border: 5px solid transparent;
208
+ height: 0;
209
+ position: absolute;
210
+ width: 0;
211
+ }
212
+
213
+ :host(:hover) .tooltip,
214
+ :host(:focus-within) .tooltip {
215
+ opacity: 1;
216
+ visibility: visible;
217
+ }
218
+
219
+ :host([disabled]) .tooltip,
220
+ :host(:not([content])) .tooltip,
221
+ :host([content='']) .tooltip {
222
+ display: none;
223
+ }
224
+
225
+ /* ── Top (default) ──────────────────────────── */
226
+
227
+ :host(:not([placement])) .tooltip,
228
+ :host([placement='top']) .tooltip {
229
+ bottom: calc(100% + var(--lt-tooltip-offset));
230
+ left: 50%;
231
+ transform: translateX(-50%);
232
+ }
233
+
234
+ :host(:not([placement])) .arrow,
235
+ :host([placement='top']) .arrow {
236
+ border-top-color: var(--lt-tooltip-bg, var(--lt-color-neutral-900));
237
+ left: 50%;
238
+ top: 100%;
239
+ transform: translateX(-50%);
240
+ }
241
+
242
+ /* ── Bottom ─────────────────────────────────── */
243
+
244
+ :host([placement='bottom']) .tooltip {
245
+ left: 50%;
246
+ top: calc(100% + var(--lt-tooltip-offset));
247
+ transform: translateX(-50%);
248
+ }
249
+
250
+ :host([placement='bottom']) .arrow {
251
+ border-bottom-color: var(--lt-tooltip-bg, var(--lt-color-neutral-900));
252
+ bottom: 100%;
253
+ left: 50%;
254
+ transform: translateX(-50%);
255
+ }
256
+
257
+ /* ── Left ───────────────────────────────────── */
258
+
259
+ :host([placement='left']) .tooltip {
260
+ right: calc(100% + var(--lt-tooltip-offset));
261
+ top: 50%;
262
+ transform: translateY(-50%);
263
+ }
264
+
265
+ :host([placement='left']) .arrow {
266
+ border-left-color: var(--lt-tooltip-bg, var(--lt-color-neutral-900));
267
+ left: 100%;
268
+ top: 50%;
269
+ transform: translateY(-50%);
270
+ }
271
+
272
+ /* ── Right ──────────────────────────────────── */
273
+
274
+ :host([placement='right']) .tooltip {
275
+ left: calc(100% + var(--lt-tooltip-offset));
276
+ top: 50%;
277
+ transform: translateY(-50%);
278
+ }
279
+
280
+ :host([placement='right']) .arrow {
281
+ border-right-color: var(--lt-tooltip-bg, var(--lt-color-neutral-900));
282
+ right: 100%;
283
+ top: 50%;
284
+ transform: translateY(-50%);
285
+ }
286
+ `;
287
+
288
+ // src/utils/color.ts
289
+ var resolveColorValue = (value) => value.startsWith("--") ? `var(${value})` : value;
290
+
291
+ // src/components/text/text.ts
292
+ import { customElement, property as property2 } from "lit/decorators.js";
293
+ import { html, unsafeStatic } from "lit/static-html.js";
294
+
295
+ // src/components/text/text.styles.ts
296
+ import { css as css3 } from "lit";
297
+ var textStyles = css3`
298
+ :host {
299
+ display: block;
300
+ color: inherit;
301
+ }
302
+
303
+ /* Inline variants sit in text flow */
304
+ :host([variant='caption']),
305
+ :host([variant='overline']),
306
+ :host([variant='label']) {
307
+ display: inline;
308
+ }
309
+
310
+ [part='base'] {
311
+ margin: 0;
312
+ color: inherit;
313
+ font-family: var(--lt-typography-fontfamily);
314
+ }
315
+
316
+ /* ── Display ─────────────────────────────────────────────────────────── */
317
+
318
+ :host([variant='display-2xl']) [part='base'] {
319
+ font-size: clamp(2.5rem, 6vw, 4.5rem);
320
+ font-weight: var(--lt-text-weight, 200);
321
+ line-height: 1.1;
322
+ letter-spacing: -0.02em;
323
+ }
324
+
325
+ :host([variant='display-xl']) [part='base'] {
326
+ font-size: clamp(2rem, 5vw, 3.75rem);
327
+ font-weight: var(--lt-text-weight, 200);
328
+ line-height: 1.1;
329
+ letter-spacing: -0.02em;
330
+ }
331
+
332
+ :host([variant='display-lg']) [part='base'] {
333
+ font-size: clamp(2rem, 4vw, 3rem);
334
+ font-weight: var(--lt-text-weight, 200);
335
+ line-height: 1.15;
336
+ letter-spacing: -0.01em;
337
+ }
338
+
339
+ /* ── Headings ─────────────────────────────────────────────────────────── */
340
+
341
+ :host([variant='h1']) [part='base'] {
342
+ font-size: clamp(1.75rem, 2.5vw + 0.75rem, 2.5rem);
343
+ font-weight: var(--lt-text-weight, 600);
344
+ line-height: 1.2;
345
+ letter-spacing: -0.02em;
346
+ }
347
+
348
+ :host([variant='h2']) [part='base'] {
349
+ font-size: clamp(1.5rem, 2vw + 0.5rem, 2rem);
350
+ font-weight: var(--lt-text-weight, 600);
351
+ line-height: 1.25;
352
+ letter-spacing: -0.01em;
353
+ }
354
+
355
+ :host([variant='h3']) [part='base'] {
356
+ font-size: clamp(1.25rem, 1.5vw + 0.5rem, 1.5rem);
357
+ font-weight: var(--lt-text-weight, 600);
358
+ line-height: 1.3;
359
+ }
360
+
361
+ :host([variant='h4']) [part='base'] {
362
+ font-size: 1.25rem;
363
+ font-weight: var(--lt-text-weight, 600);
364
+ line-height: 1.35;
365
+ }
366
+
367
+ :host([variant='h5']) [part='base'] {
368
+ font-size: 1.125rem;
369
+ font-weight: var(--lt-text-weight, 600);
370
+ line-height: 1.4;
371
+ }
372
+
373
+ :host([variant='h6']) [part='base'] {
374
+ font-size: 1rem;
375
+ font-weight: var(--lt-text-weight, 600);
376
+ line-height: 1.4;
377
+ }
378
+
379
+ /* ── Body ─────────────────────────────────────────────────────────────── */
380
+
381
+ :host([variant='lead']) [part='base'] {
382
+ font-size: 1.25rem;
383
+ font-weight: var(--lt-text-weight, 400);
384
+ line-height: 1.6;
385
+ }
386
+
387
+ :host([variant='body']) [part='base'],
388
+ :host(:not([variant])) [part='base'] {
389
+ font-size: 1rem;
390
+ font-weight: var(--lt-text-weight, 400);
391
+ line-height: 1.6;
392
+ }
393
+
394
+ :host([variant='body-sm']) [part='base'] {
395
+ font-size: 0.875rem;
396
+ font-weight: var(--lt-text-weight, 400);
397
+ line-height: 1.6;
398
+ }
399
+
400
+ /* ── Inline ───────────────────────────────────────────────────────────── */
401
+
402
+ :host([variant='caption']) [part='base'] {
403
+ font-size: 0.75rem;
404
+ font-weight: var(--lt-text-weight, 400);
405
+ line-height: 1.5;
406
+ }
407
+
408
+ :host([variant='overline']) [part='base'] {
409
+ font-size: 0.6875rem;
410
+ font-weight: var(--lt-text-weight, 600);
411
+ line-height: 1.2;
412
+ letter-spacing: 0.08em;
413
+ text-transform: uppercase;
414
+ }
415
+
416
+ :host([variant='label']) [part='base'] {
417
+ font-size: 0.875rem;
418
+ font-weight: var(--lt-text-weight, 600);
419
+ line-height: 1.4;
420
+ }
421
+ `;
422
+
423
+ // src/components/text/text.ts
424
+ var VARIANT_TAG = {
425
+ "display-2xl": "p",
426
+ "display-xl": "p",
427
+ "display-lg": "p",
428
+ h1: "h1",
429
+ h2: "h2",
430
+ h3: "h3",
431
+ h4: "h4",
432
+ h5: "h5",
433
+ h6: "h6",
434
+ lead: "p",
435
+ body: "p",
436
+ "body-sm": "p",
437
+ caption: "span",
438
+ overline: "span",
439
+ label: "span"
440
+ };
441
+ var Text = class extends ThemeableElement {
442
+ constructor() {
443
+ super(...arguments);
444
+ this.variant = "body";
445
+ this.as = "";
446
+ }
447
+ render() {
448
+ const tag = unsafeStatic(this.as || VARIANT_TAG[this.variant] || "p");
449
+ return html`<${tag} part="base"><slot></slot></${tag}>`;
450
+ }
451
+ };
452
+ Text.styles = textStyles;
453
+ __decorateClass([
454
+ property2({ reflect: true })
455
+ ], Text.prototype, "variant", 2);
456
+ __decorateClass([
457
+ property2({ reflect: true })
458
+ ], Text.prototype, "as", 2);
459
+ Text = __decorateClass([
460
+ customElement("lt-text")
461
+ ], Text);
462
+
463
+ // src/components/tooltip/tooltip.ts
464
+ var _tooltipIdCounter = 0;
465
+ var Tooltip = class extends ThemeableElement {
466
+ constructor() {
467
+ super(...arguments);
468
+ this._tooltipId = `lt-tooltip-${++_tooltipIdCounter}`;
469
+ this.content = "";
470
+ this.placement = "top";
471
+ this.disabled = false;
472
+ this.background = "";
473
+ this.color = "";
474
+ }
475
+ firstUpdated() {
476
+ const trigger = this._slot?.assignedElements()[0];
477
+ if (trigger) {
478
+ trigger.setAttribute("aria-describedby", this._tooltipId);
479
+ }
480
+ }
481
+ render() {
482
+ const tooltipStyle = styleMap({
483
+ ...this.background ? { "--_tooltip-bg": resolveColorValue(this.background) } : {},
484
+ ...this.color ? { "--_tooltip-color": resolveColorValue(this.color) } : {}
485
+ });
486
+ return html2`
487
+ <slot></slot>
488
+ <div class="tooltip" id=${this._tooltipId} role="tooltip" part="tooltip" aria-hidden="true" style=${tooltipStyle}>
489
+ <lt-text variant="caption" as="span">${this.content}</lt-text>
490
+ <span class="arrow" part="arrow"></span>
491
+ </div>
492
+ `;
493
+ }
494
+ };
495
+ Tooltip.styles = tooltipStyles;
496
+ __decorateClass([
497
+ query("slot")
498
+ ], Tooltip.prototype, "_slot", 2);
499
+ __decorateClass([
500
+ property3({ reflect: true })
501
+ ], Tooltip.prototype, "content", 2);
502
+ __decorateClass([
503
+ property3({ reflect: true })
504
+ ], Tooltip.prototype, "placement", 2);
505
+ __decorateClass([
506
+ property3({ type: Boolean, reflect: true })
507
+ ], Tooltip.prototype, "disabled", 2);
508
+ __decorateClass([
509
+ property3({ reflect: true })
510
+ ], Tooltip.prototype, "background", 2);
511
+ __decorateClass([
512
+ property3({ reflect: true })
513
+ ], Tooltip.prototype, "color", 2);
514
+ Tooltip = __decorateClass([
515
+ customElement2("lt-tooltip")
516
+ ], Tooltip);
517
+
518
+ // src/components/slider/slider.ts
519
+ var Slider = class extends ThemeableElement {
520
+ constructor() {
521
+ super(...arguments);
522
+ this.size = "md";
523
+ this.disabled = false;
524
+ this.tooltip = false;
525
+ this.min = 0;
526
+ this.max = 100;
527
+ this.step = 1;
528
+ this.value = 0;
529
+ this.label = "";
530
+ this.name = "";
531
+ }
532
+ get _fillPercent() {
533
+ return (this.value - this.min) / (this.max - this.min) * 100;
534
+ }
535
+ _thumbSizePx() {
536
+ return { sm: 14, md: 18, lg: 22 }[this.size] ?? 18;
537
+ }
538
+ updated() {
539
+ const fill = this._fillPercent;
540
+ this.style.setProperty("--_fill", `${fill}%`);
541
+ const trackW = this.input?.offsetWidth ?? 0;
542
+ if (trackW) {
543
+ const thumbPx = this._thumbSizePx();
544
+ const centerPx = fill / 100 * (trackW - thumbPx) + thumbPx / 2;
545
+ this.style.setProperty("--_thumb-left", `${centerPx / trackW * 100}%`);
546
+ }
547
+ }
548
+ _onInput(e) {
549
+ e.stopPropagation();
550
+ const target = e.target;
551
+ this.value = Number(target.value);
552
+ this.dispatchEvent(
553
+ new CustomEvent("input", {
554
+ detail: { value: this.value },
555
+ bubbles: true,
556
+ composed: true
557
+ })
558
+ );
559
+ }
560
+ _onChange(e) {
561
+ e.stopPropagation();
562
+ const target = e.target;
563
+ this.value = Number(target.value);
564
+ this.dispatchEvent(
565
+ new CustomEvent("change", {
566
+ detail: { value: this.value },
567
+ bubbles: true,
568
+ composed: true
569
+ })
570
+ );
571
+ }
572
+ render() {
573
+ const input = html3`
574
+ <input
575
+ id="input"
576
+ type="range"
577
+ min=${this.min}
578
+ max=${this.max}
579
+ step=${this.step}
580
+ .value=${String(this.value)}
581
+ ?disabled=${this.disabled}
582
+ name=${this.name}
583
+ aria-label=${this.label || "slider"}
584
+ aria-valuemin=${this.min}
585
+ aria-valuemax=${this.max}
586
+ aria-valuenow=${this.value}
587
+ @input=${this._onInput}
588
+ @change=${this._onChange}
589
+ />
590
+ `;
591
+ return html3`
592
+ ${this.label ? html3`<label for="input"><lt-text variant="label" as="span">${this.label}</lt-text></label>` : ""}
593
+ <div class="track-wrap">
594
+ <lt-tooltip content=${String(this.value)} ?disabled=${!this.tooltip} placement="top"> ${input} </lt-tooltip>
595
+ </div>
596
+ `;
597
+ }
598
+ };
599
+ Slider.styles = sliderStyles;
600
+ __decorateClass([
601
+ property4({ reflect: true })
602
+ ], Slider.prototype, "size", 2);
603
+ __decorateClass([
604
+ property4({ type: Boolean, reflect: true })
605
+ ], Slider.prototype, "disabled", 2);
606
+ __decorateClass([
607
+ property4({ type: Boolean, reflect: true })
608
+ ], Slider.prototype, "tooltip", 2);
609
+ __decorateClass([
610
+ property4({ type: Number })
611
+ ], Slider.prototype, "min", 2);
612
+ __decorateClass([
613
+ property4({ type: Number })
614
+ ], Slider.prototype, "max", 2);
615
+ __decorateClass([
616
+ property4({ type: Number })
617
+ ], Slider.prototype, "step", 2);
618
+ __decorateClass([
619
+ property4({ type: Number })
620
+ ], Slider.prototype, "value", 2);
621
+ __decorateClass([
622
+ property4()
623
+ ], Slider.prototype, "label", 2);
624
+ __decorateClass([
625
+ property4()
626
+ ], Slider.prototype, "name", 2);
627
+ __decorateClass([
628
+ query2("input")
629
+ ], Slider.prototype, "input", 2);
630
+ Slider = __decorateClass([
631
+ customElement3("lt-slider")
632
+ ], Slider);
633
+ export {
634
+ Slider
635
+ };
@@ -0,0 +1,33 @@
1
+ import { ThemeableElement } from '../../base';
2
+ import type { SliderSize } from './slider.types';
3
+ import '../tooltip/tooltip';
4
+ import '../text/text';
5
+ /**
6
+ * A range slider component for selecting a numeric value within a range.
7
+ *
8
+ * @element lt-slider
9
+ * @fires {CustomEvent<{value: number}>} input - Dispatched on every value change while dragging
10
+ * @fires {CustomEvent<{value: number}>} change - Dispatched when the user commits a value (mouseup/keyup)
11
+ */
12
+ export declare class Slider extends ThemeableElement {
13
+ static styles: import("lit").CSSResult;
14
+ size: SliderSize;
15
+ disabled: boolean;
16
+ /** Show the current value in a tooltip above the thumb. */
17
+ tooltip: boolean;
18
+ min: number;
19
+ max: number;
20
+ step: number;
21
+ value: number;
22
+ /** Label displayed above the track */
23
+ label: string;
24
+ /** Name attribute for form submission */
25
+ name: string;
26
+ private input;
27
+ private get _fillPercent();
28
+ private _thumbSizePx;
29
+ updated(): void;
30
+ private _onInput;
31
+ private _onChange;
32
+ render(): import("lit").TemplateResult<1>;
33
+ }
@@ -0,0 +1 @@
1
+ export declare const sliderStyles: import("lit").CSSResult;
@@ -0,0 +1 @@
1
+ export type SliderSize = 'sm' | 'md' | 'lg';
@@ -0,0 +1,2 @@
1
+ export { Snackbar } from './snackbar';
2
+ export type { SnackbarVariant } from './snackbar.types';