@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,746 @@
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/alert/alert.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/alert/alert.ts
38
+ import { customElement as customElement3, property as property4 } from "lit/decorators.js";
39
+ import { styleMap } from "lit/directives/style-map.js";
40
+
41
+ // src/components/alert/alert.styles.ts
42
+ import { css } from "lit";
43
+ var alertStyles = css`
44
+ :host {
45
+ display: block;
46
+ font-family: 'Hanken Grotesk', sans-serif;
47
+ opacity: 1;
48
+ transform: translateY(0);
49
+ transition:
50
+ opacity 200ms ease,
51
+ transform 200ms ease;
52
+
53
+ /* Default variant tokens — public props override first, then variant defaults */
54
+ --_bg-subtle: var(--lt-alert-bg, var(--lt-bg-neutral-subtle));
55
+ --_bg-solid: var(--lt-alert-bg, var(--lt-bg-inverse));
56
+ --_border: var(--lt-alert-border-color, var(--lt-border-strong));
57
+ --_color: var(--lt-alert-color, var(--lt-text-default));
58
+ --_color-solid: var(--lt-alert-color, var(--lt-text-inverse));
59
+ }
60
+
61
+ :host([dismissed]) {
62
+ opacity: 0;
63
+ transform: translateY(-4px);
64
+ }
65
+
66
+ /* ── Per-variant tokens ──────────────────────────────────── */
67
+
68
+ :host([variant='success']) {
69
+ --_bg-subtle: var(--lt-alert-bg, var(--lt-bg-success-subtle));
70
+ --_bg-solid: var(--lt-alert-bg, var(--lt-bg-success));
71
+ --_border: var(--lt-alert-border-color, var(--lt-border-success-strong));
72
+ --_color: var(--lt-alert-color, var(--lt-text-success));
73
+ --_color-solid: var(--lt-alert-color, var(--lt-text-on-success));
74
+ }
75
+
76
+ :host([variant='warning']) {
77
+ --_bg-subtle: var(--lt-alert-bg, var(--lt-bg-warning-subtle));
78
+ --_bg-solid: var(--lt-alert-bg, var(--lt-bg-warning));
79
+ --_border: var(--lt-alert-border-color, var(--lt-border-warning-strong));
80
+ --_color: var(--lt-alert-color, var(--lt-text-warning));
81
+ --_color-solid: var(--lt-alert-color, var(--lt-text-on-warning));
82
+ }
83
+
84
+ :host([variant='error']) {
85
+ --_bg-subtle: var(--lt-alert-bg, var(--lt-bg-error-subtle));
86
+ --_bg-solid: var(--lt-alert-bg, var(--lt-bg-error));
87
+ --_border: var(--lt-alert-border-color, var(--lt-border-error-strong));
88
+ --_color: var(--lt-alert-color, var(--lt-text-error));
89
+ --_color-solid: var(--lt-alert-color, var(--lt-text-on-error));
90
+ }
91
+
92
+ :host([variant='info']) {
93
+ --_bg-subtle: var(--lt-alert-bg, var(--lt-bg-info-subtle));
94
+ --_bg-solid: var(--lt-alert-bg, var(--lt-bg-info));
95
+ --_border: var(--lt-alert-border-color, var(--lt-border-info-strong));
96
+ --_color: var(--lt-alert-color, var(--lt-text-info));
97
+ --_color-solid: var(--lt-alert-color, var(--lt-text-on-info));
98
+ }
99
+
100
+ /* ── Layout ──────────────────────────────────────────────── */
101
+
102
+ .inner {
103
+ align-items: flex-start;
104
+ border-radius: var(--lt-border-radius);
105
+ display: flex;
106
+ gap: var(--lt-spacing-3);
107
+ padding: var(--lt-spacing-3) var(--lt-spacing-4);
108
+ }
109
+
110
+ /* ── Appearances ─────────────────────────────────────────── */
111
+
112
+ /* filled (default) — subtle tinted bg + full border */
113
+ :host([appearance='filled']) .inner,
114
+ :host(:not([appearance])) .inner {
115
+ background: var(--_bg-subtle);
116
+ border: 1px solid var(--_border);
117
+ color: var(--_color);
118
+ }
119
+
120
+ /* outlined — white bg + colored border */
121
+ :host([appearance='outlined']) .inner {
122
+ background: var(--lt-bg-default);
123
+ border: 1px solid var(--_border);
124
+ color: var(--_color);
125
+ }
126
+
127
+ /* solid — solid color bg, no border */
128
+ :host([appearance='solid']) .inner {
129
+ background: var(--_bg-solid);
130
+ border: none;
131
+ color: var(--_color-solid);
132
+ }
133
+
134
+ /* ── Icon ────────────────────────────────────────────────── */
135
+
136
+ .icon {
137
+ flex-shrink: 0;
138
+ font-size: 1.125rem;
139
+ margin-top: 1px;
140
+ }
141
+
142
+ /* ── Body ────────────────────────────────────────────────── */
143
+
144
+ .body {
145
+ flex: 1;
146
+ min-width: 0;
147
+ }
148
+
149
+ .title {
150
+ margin: 0 0 var(--lt-spacing-1);
151
+ }
152
+
153
+ .content {
154
+ font-size: 0.875rem;
155
+ line-height: 1.5;
156
+ }
157
+
158
+ .title + .content {
159
+ opacity: 0.8;
160
+ }
161
+
162
+ /* ── Close button ────────────────────────────────────────── */
163
+
164
+ .close {
165
+ flex-shrink: 0;
166
+ margin-top: 1px;
167
+ opacity: 0.7;
168
+ }
169
+
170
+ .close:hover {
171
+ opacity: 1;
172
+ }
173
+
174
+ :host([uppercase]) .title::part(base) {
175
+ font-variant-caps: small-caps;
176
+ letter-spacing: 0.05rem;
177
+ text-transform: lowercase;
178
+ }
179
+ `;
180
+
181
+ // src/utils/dispatch.ts
182
+ var dispatch = (host, name, detail, init) => host.dispatchEvent(new CustomEvent(name, { detail, bubbles: true, composed: true, ...init }));
183
+
184
+ // src/utils/color.ts
185
+ var resolveColorValue = (value) => value.startsWith("--") ? `var(${value})` : value;
186
+
187
+ // src/components/icon-button/icon-button.ts
188
+ import { html, nothing } from "lit";
189
+ import { customElement, property as property2 } from "lit/decorators.js";
190
+ import { ifDefined } from "lit/directives/if-defined.js";
191
+
192
+ // src/components/icon-button/icon-button.styles.ts
193
+ import { css as css2 } from "lit";
194
+ var iconButtonStyles = css2`
195
+ :host {
196
+ display: inline-flex;
197
+
198
+ /* Internal state props — set per variant/appearance below */
199
+ --_color: var(--lt-text-subtle);
200
+ --_bg: transparent;
201
+ --_border-color: transparent;
202
+ --_hover-bg: var(--lt-bg-subtle);
203
+ --_hover-color: var(--lt-text-default);
204
+ --_active-bg: var(--lt-bg-subtle);
205
+ }
206
+
207
+ [part='base'] {
208
+ align-items: center;
209
+ background: var(--lt-icon-button-bg, var(--_bg));
210
+ border-radius: var(--lt-border-radius);
211
+ border: 1px solid var(--lt-icon-button-border-color, var(--_border-color));
212
+ box-sizing: border-box;
213
+ color: var(--lt-icon-button-color, var(--_color));
214
+ cursor: pointer;
215
+ display: inline-flex;
216
+ justify-content: center;
217
+ padding: 0;
218
+ transition:
219
+ background-color 120ms ease,
220
+ border-color 120ms ease,
221
+ transform 50ms ease;
222
+ user-select: none;
223
+ }
224
+
225
+ [part='base']:hover:not([disabled]) {
226
+ background: var(--lt-icon-button-hover-bg, var(--_hover-bg));
227
+ color: var(--lt-icon-button-hover-color, var(--lt-icon-button-color, var(--_hover-color)));
228
+ }
229
+
230
+ [part='base']:active {
231
+ transform: translateY(1px);
232
+ }
233
+
234
+ [part='base']:active:not([disabled]) {
235
+ background: var(--lt-icon-button-hover-bg, var(--_active-bg));
236
+ }
237
+
238
+ [part='base']:focus-visible {
239
+ outline: 3px solid var(--lt-border-focus);
240
+ outline-offset: 2px;
241
+ }
242
+
243
+ [part='base'][disabled] {
244
+ cursor: not-allowed;
245
+ opacity: 0.5;
246
+ pointer-events: none;
247
+ transform: none;
248
+ }
249
+
250
+ a[part='base'] {
251
+ text-decoration: none;
252
+ color: inherit;
253
+ }
254
+
255
+ /* sizes */
256
+ :host([size='sm']) [part='base'] {
257
+ height: 28px;
258
+ width: 28px;
259
+ }
260
+
261
+ :host([size='md']) [part='base'] {
262
+ height: 36px;
263
+ width: 36px;
264
+ }
265
+
266
+ :host([size='lg']) [part='base'] {
267
+ height: 44px;
268
+ width: 44px;
269
+ }
270
+
271
+ /* ── ghost ────────────────────────────────────────────────── */
272
+ :host([appearance='ghost'][variant='primary']) {
273
+ --_color: var(--lt-text-primary);
274
+ --_hover-bg: var(--lt-bg-primary-subtle);
275
+ --_hover-color: var(--lt-text-primary);
276
+ --_active-bg: var(--lt-bg-primary-subtle);
277
+ }
278
+ :host([appearance='ghost'][variant='secondary']) {
279
+ --_color: var(--lt-text-secondary);
280
+ --_hover-bg: var(--lt-bg-secondary-subtle);
281
+ --_hover-color: var(--lt-text-secondary);
282
+ --_active-bg: var(--lt-bg-secondary-subtle);
283
+ }
284
+ :host([appearance='ghost'][variant='success']) {
285
+ --_color: var(--lt-text-success);
286
+ --_hover-bg: var(--lt-bg-success-subtle);
287
+ --_hover-color: var(--lt-text-success);
288
+ --_active-bg: var(--lt-bg-success-subtle);
289
+ }
290
+ :host([appearance='ghost'][variant='warning']) {
291
+ --_color: var(--lt-text-warning);
292
+ --_hover-bg: var(--lt-bg-warning-subtle);
293
+ --_hover-color: var(--lt-text-warning);
294
+ --_active-bg: var(--lt-bg-warning-subtle);
295
+ }
296
+ :host([appearance='ghost'][variant='error']) {
297
+ --_color: var(--lt-text-error);
298
+ --_hover-bg: var(--lt-bg-error-subtle);
299
+ --_hover-color: var(--lt-text-error);
300
+ --_active-bg: var(--lt-bg-error-subtle);
301
+ }
302
+ :host([appearance='ghost'][variant='info']) {
303
+ --_color: var(--lt-text-info);
304
+ --_hover-bg: var(--lt-bg-info-subtle);
305
+ --_hover-color: var(--lt-text-info);
306
+ --_active-bg: var(--lt-bg-info-subtle);
307
+ }
308
+
309
+ /* ── filled ───────────────────────────────────────────────── */
310
+ :host([appearance='filled'][variant='primary']) {
311
+ --_bg: var(--lt-interactive-primary-bg);
312
+ --_color: var(--lt-text-on-primary);
313
+ --_hover-bg: var(--lt-interactive-primary-bg-hover);
314
+ --_hover-color: var(--lt-text-on-primary);
315
+ --_active-bg: var(--lt-interactive-primary-bg-active);
316
+ }
317
+ :host([appearance='filled'][variant='secondary']) {
318
+ --_bg: var(--lt-interactive-secondary-bg);
319
+ --_color: var(--lt-text-on-secondary);
320
+ --_hover-bg: var(--lt-interactive-secondary-bg-hover);
321
+ --_hover-color: var(--lt-text-on-secondary);
322
+ --_active-bg: var(--lt-interactive-secondary-bg-active);
323
+ }
324
+ :host([appearance='filled'][variant='neutral']) {
325
+ --_bg: var(--lt-color-neutral-500);
326
+ --_color: var(--lt-color-neutral-50);
327
+ --_hover-bg: var(--lt-color-neutral-700);
328
+ --_hover-color: var(--lt-color-neutral-50);
329
+ --_active-bg: var(--lt-color-neutral-800);
330
+ }
331
+ :host([appearance='filled'][variant='success']) {
332
+ --_bg: var(--lt-interactive-success-bg);
333
+ --_color: var(--lt-text-on-success);
334
+ --_hover-bg: var(--lt-interactive-success-bg-hover);
335
+ --_hover-color: var(--lt-text-on-success);
336
+ --_active-bg: var(--lt-interactive-success-bg-active);
337
+ }
338
+ :host([appearance='filled'][variant='warning']) {
339
+ --_bg: var(--lt-interactive-warning-bg);
340
+ --_color: var(--lt-text-on-warning);
341
+ --_hover-bg: var(--lt-interactive-warning-bg-hover);
342
+ --_hover-color: var(--lt-text-on-warning);
343
+ --_active-bg: var(--lt-interactive-warning-bg-active);
344
+ }
345
+ :host([appearance='filled'][variant='error']) {
346
+ --_bg: var(--lt-interactive-error-bg);
347
+ --_color: var(--lt-text-on-error);
348
+ --_hover-bg: var(--lt-interactive-error-bg-hover);
349
+ --_hover-color: var(--lt-text-on-error);
350
+ --_active-bg: var(--lt-interactive-error-bg-active);
351
+ }
352
+ :host([appearance='filled'][variant='info']) {
353
+ --_bg: var(--lt-interactive-info-bg);
354
+ --_color: var(--lt-text-on-info);
355
+ --_hover-bg: var(--lt-interactive-info-bg-hover);
356
+ --_hover-color: var(--lt-text-on-info);
357
+ --_active-bg: var(--lt-interactive-info-bg-active);
358
+ }
359
+
360
+ /* ── outlined ─────────────────────────────────────────────── */
361
+ :host([appearance='outlined'][variant='primary']) {
362
+ --_color: var(--lt-text-primary);
363
+ --_border-color: var(--lt-border-primary-strong);
364
+ --_hover-bg: var(--lt-bg-primary-subtle);
365
+ --_hover-color: var(--lt-text-primary);
366
+ --_active-bg: var(--lt-bg-primary-subtle);
367
+ }
368
+ :host([appearance='outlined'][variant='secondary']) {
369
+ --_color: var(--lt-text-secondary);
370
+ --_border-color: var(--lt-border-secondary-strong);
371
+ --_hover-bg: var(--lt-bg-secondary-subtle);
372
+ --_hover-color: var(--lt-text-secondary);
373
+ --_active-bg: var(--lt-bg-secondary-subtle);
374
+ }
375
+ :host([appearance='outlined'][variant='neutral']) {
376
+ --_color: var(--lt-text-neutral);
377
+ --_border-color: var(--lt-border-strong);
378
+ --_hover-bg: var(--lt-bg-subtle);
379
+ --_hover-color: var(--lt-text-default);
380
+ --_active-bg: var(--lt-bg-subtle);
381
+ }
382
+ :host([appearance='outlined'][variant='success']) {
383
+ --_color: var(--lt-text-success);
384
+ --_border-color: var(--lt-border-success-strong);
385
+ --_hover-bg: var(--lt-bg-success-subtle);
386
+ --_hover-color: var(--lt-text-success);
387
+ --_active-bg: var(--lt-bg-success-subtle);
388
+ }
389
+ :host([appearance='outlined'][variant='warning']) {
390
+ --_color: var(--lt-text-warning);
391
+ --_border-color: var(--lt-border-warning-strong);
392
+ --_hover-bg: var(--lt-bg-warning-subtle);
393
+ --_hover-color: var(--lt-text-warning);
394
+ --_active-bg: var(--lt-bg-warning-subtle);
395
+ }
396
+ :host([appearance='outlined'][variant='error']) {
397
+ --_color: var(--lt-text-error);
398
+ --_border-color: var(--lt-border-error-strong);
399
+ --_hover-bg: var(--lt-bg-error-subtle);
400
+ --_hover-color: var(--lt-text-error);
401
+ --_active-bg: var(--lt-bg-error-subtle);
402
+ }
403
+ :host([appearance='outlined'][variant='info']) {
404
+ --_color: var(--lt-text-info);
405
+ --_border-color: var(--lt-border-info-strong);
406
+ --_hover-bg: var(--lt-bg-info-subtle);
407
+ --_hover-color: var(--lt-text-info);
408
+ --_active-bg: var(--lt-bg-info-subtle);
409
+ }
410
+
411
+ /* round shape */
412
+ :host([round]) [part='base'] {
413
+ border-radius: 50%;
414
+ }
415
+ `;
416
+
417
+ // src/components/icon-button/icon-button.ts
418
+ import "@latty-ds/icons";
419
+ var IconButton = class extends ThemeableElement {
420
+ constructor() {
421
+ super(...arguments);
422
+ this.icon = "";
423
+ this.label = "";
424
+ this.variant = "neutral";
425
+ this.appearance = "ghost";
426
+ this.size = "md";
427
+ this.disabled = false;
428
+ this.href = "";
429
+ this.target = "";
430
+ this.rel = "";
431
+ this.round = false;
432
+ }
433
+ _inner() {
434
+ return this.icon ? html`<lt-icon name=${this.icon}></lt-icon>` : html`<slot></slot>`;
435
+ }
436
+ render() {
437
+ const label = this.label || void 0;
438
+ if (this.href) {
439
+ const rel = this.rel || (this.target === "_blank" ? "noopener noreferrer" : void 0);
440
+ return html`
441
+ <a
442
+ part="base"
443
+ href=${this.href}
444
+ target=${ifDefined(this.target || void 0)}
445
+ rel=${ifDefined(rel)}
446
+ aria-label=${ifDefined(label)}
447
+ aria-disabled=${this.disabled ? "true" : nothing}
448
+ tabindex=${this.disabled ? "-1" : nothing}
449
+ >
450
+ ${this._inner()}
451
+ </a>
452
+ `;
453
+ }
454
+ return html`
455
+ <button part="base" ?disabled=${this.disabled} aria-label=${ifDefined(label)}>${this._inner()}</button>
456
+ `;
457
+ }
458
+ };
459
+ IconButton.styles = iconButtonStyles;
460
+ __decorateClass([
461
+ property2({ reflect: true })
462
+ ], IconButton.prototype, "icon", 2);
463
+ __decorateClass([
464
+ property2({ reflect: true })
465
+ ], IconButton.prototype, "label", 2);
466
+ __decorateClass([
467
+ property2({ reflect: true })
468
+ ], IconButton.prototype, "variant", 2);
469
+ __decorateClass([
470
+ property2({ reflect: true })
471
+ ], IconButton.prototype, "appearance", 2);
472
+ __decorateClass([
473
+ property2({ reflect: true })
474
+ ], IconButton.prototype, "size", 2);
475
+ __decorateClass([
476
+ property2({ type: Boolean, reflect: true })
477
+ ], IconButton.prototype, "disabled", 2);
478
+ __decorateClass([
479
+ property2()
480
+ ], IconButton.prototype, "href", 2);
481
+ __decorateClass([
482
+ property2()
483
+ ], IconButton.prototype, "target", 2);
484
+ __decorateClass([
485
+ property2()
486
+ ], IconButton.prototype, "rel", 2);
487
+ __decorateClass([
488
+ property2({ type: Boolean, reflect: true })
489
+ ], IconButton.prototype, "round", 2);
490
+ IconButton = __decorateClass([
491
+ customElement("lt-icon-button")
492
+ ], IconButton);
493
+
494
+ // src/components/text/text.ts
495
+ import { customElement as customElement2, property as property3 } from "lit/decorators.js";
496
+ import { html as html2, unsafeStatic } from "lit/static-html.js";
497
+
498
+ // src/components/text/text.styles.ts
499
+ import { css as css3 } from "lit";
500
+ var textStyles = css3`
501
+ :host {
502
+ display: block;
503
+ color: inherit;
504
+ }
505
+
506
+ /* Inline variants sit in text flow */
507
+ :host([variant='caption']),
508
+ :host([variant='overline']),
509
+ :host([variant='label']) {
510
+ display: inline;
511
+ }
512
+
513
+ [part='base'] {
514
+ margin: 0;
515
+ color: inherit;
516
+ font-family: var(--lt-typography-fontfamily);
517
+ }
518
+
519
+ /* ── Display ─────────────────────────────────────────────────────────── */
520
+
521
+ :host([variant='display-2xl']) [part='base'] {
522
+ font-size: clamp(2.5rem, 6vw, 4.5rem);
523
+ font-weight: var(--lt-text-weight, 200);
524
+ line-height: 1.1;
525
+ letter-spacing: -0.02em;
526
+ }
527
+
528
+ :host([variant='display-xl']) [part='base'] {
529
+ font-size: clamp(2rem, 5vw, 3.75rem);
530
+ font-weight: var(--lt-text-weight, 200);
531
+ line-height: 1.1;
532
+ letter-spacing: -0.02em;
533
+ }
534
+
535
+ :host([variant='display-lg']) [part='base'] {
536
+ font-size: clamp(2rem, 4vw, 3rem);
537
+ font-weight: var(--lt-text-weight, 200);
538
+ line-height: 1.15;
539
+ letter-spacing: -0.01em;
540
+ }
541
+
542
+ /* ── Headings ─────────────────────────────────────────────────────────── */
543
+
544
+ :host([variant='h1']) [part='base'] {
545
+ font-size: clamp(1.75rem, 2.5vw + 0.75rem, 2.5rem);
546
+ font-weight: var(--lt-text-weight, 600);
547
+ line-height: 1.2;
548
+ letter-spacing: -0.02em;
549
+ }
550
+
551
+ :host([variant='h2']) [part='base'] {
552
+ font-size: clamp(1.5rem, 2vw + 0.5rem, 2rem);
553
+ font-weight: var(--lt-text-weight, 600);
554
+ line-height: 1.25;
555
+ letter-spacing: -0.01em;
556
+ }
557
+
558
+ :host([variant='h3']) [part='base'] {
559
+ font-size: clamp(1.25rem, 1.5vw + 0.5rem, 1.5rem);
560
+ font-weight: var(--lt-text-weight, 600);
561
+ line-height: 1.3;
562
+ }
563
+
564
+ :host([variant='h4']) [part='base'] {
565
+ font-size: 1.25rem;
566
+ font-weight: var(--lt-text-weight, 600);
567
+ line-height: 1.35;
568
+ }
569
+
570
+ :host([variant='h5']) [part='base'] {
571
+ font-size: 1.125rem;
572
+ font-weight: var(--lt-text-weight, 600);
573
+ line-height: 1.4;
574
+ }
575
+
576
+ :host([variant='h6']) [part='base'] {
577
+ font-size: 1rem;
578
+ font-weight: var(--lt-text-weight, 600);
579
+ line-height: 1.4;
580
+ }
581
+
582
+ /* ── Body ─────────────────────────────────────────────────────────────── */
583
+
584
+ :host([variant='lead']) [part='base'] {
585
+ font-size: 1.25rem;
586
+ font-weight: var(--lt-text-weight, 400);
587
+ line-height: 1.6;
588
+ }
589
+
590
+ :host([variant='body']) [part='base'],
591
+ :host(:not([variant])) [part='base'] {
592
+ font-size: 1rem;
593
+ font-weight: var(--lt-text-weight, 400);
594
+ line-height: 1.6;
595
+ }
596
+
597
+ :host([variant='body-sm']) [part='base'] {
598
+ font-size: 0.875rem;
599
+ font-weight: var(--lt-text-weight, 400);
600
+ line-height: 1.6;
601
+ }
602
+
603
+ /* ── Inline ───────────────────────────────────────────────────────────── */
604
+
605
+ :host([variant='caption']) [part='base'] {
606
+ font-size: 0.75rem;
607
+ font-weight: var(--lt-text-weight, 400);
608
+ line-height: 1.5;
609
+ }
610
+
611
+ :host([variant='overline']) [part='base'] {
612
+ font-size: 0.6875rem;
613
+ font-weight: var(--lt-text-weight, 600);
614
+ line-height: 1.2;
615
+ letter-spacing: 0.08em;
616
+ text-transform: uppercase;
617
+ }
618
+
619
+ :host([variant='label']) [part='base'] {
620
+ font-size: 0.875rem;
621
+ font-weight: var(--lt-text-weight, 600);
622
+ line-height: 1.4;
623
+ }
624
+ `;
625
+
626
+ // src/components/text/text.ts
627
+ var VARIANT_TAG = {
628
+ "display-2xl": "p",
629
+ "display-xl": "p",
630
+ "display-lg": "p",
631
+ h1: "h1",
632
+ h2: "h2",
633
+ h3: "h3",
634
+ h4: "h4",
635
+ h5: "h5",
636
+ h6: "h6",
637
+ lead: "p",
638
+ body: "p",
639
+ "body-sm": "p",
640
+ caption: "span",
641
+ overline: "span",
642
+ label: "span"
643
+ };
644
+ var Text = class extends ThemeableElement {
645
+ constructor() {
646
+ super(...arguments);
647
+ this.variant = "body";
648
+ this.as = "";
649
+ }
650
+ render() {
651
+ const tag = unsafeStatic(this.as || VARIANT_TAG[this.variant] || "p");
652
+ return html2`<${tag} part="base"><slot></slot></${tag}>`;
653
+ }
654
+ };
655
+ Text.styles = textStyles;
656
+ __decorateClass([
657
+ property3({ reflect: true })
658
+ ], Text.prototype, "variant", 2);
659
+ __decorateClass([
660
+ property3({ reflect: true })
661
+ ], Text.prototype, "as", 2);
662
+ Text = __decorateClass([
663
+ customElement2("lt-text")
664
+ ], Text);
665
+
666
+ // src/components/alert/alert.ts
667
+ var Alert = class extends ThemeableElement {
668
+ constructor() {
669
+ super(...arguments);
670
+ this.variant = "default";
671
+ this.appearance = "filled";
672
+ this.title = "";
673
+ this.icon = "";
674
+ this.closable = false;
675
+ this.background = "";
676
+ this.uppercase = false;
677
+ }
678
+ _handleClose() {
679
+ const cancelled = !dispatch(this, "close", void 0, { cancelable: true });
680
+ if (cancelled) return;
681
+ this.setAttribute("dismissed", "");
682
+ setTimeout(() => this.remove(), 200);
683
+ }
684
+ get _resolvedIcon() {
685
+ if (this.icon === "none") return "";
686
+ if (this.icon) return this.icon;
687
+ if (this.variant === "default") return "";
688
+ return Alert._iconMap[this.variant] ?? "";
689
+ }
690
+ render() {
691
+ const iconName = this._resolvedIcon;
692
+ const bgStyle = styleMap(this.background ? { background: resolveColorValue(this.background) } : {});
693
+ return html3`
694
+ <div class="inner" part="base" role="alert" style=${bgStyle}>
695
+ ${iconName ? html3`<lt-icon class="icon" name=${iconName} part="icon"></lt-icon>` : ""}
696
+ <div class="body">
697
+ ${this.title ? html3`<lt-text variant="h6" as="p" class="title" part="title">${this.title}</lt-text>` : ""}
698
+ <div class="content" part="content"><slot></slot></div>
699
+ </div>
700
+ ${this.closable ? html3`<lt-icon-button
701
+ class="close"
702
+ part="close"
703
+ icon="xmark"
704
+ label="Dismiss"
705
+ size="sm"
706
+ @click=${this._handleClose}
707
+ ></lt-icon-button>` : ""}
708
+ </div>
709
+ `;
710
+ }
711
+ };
712
+ Alert.styles = alertStyles;
713
+ Alert._iconMap = {
714
+ default: "info-circle",
715
+ success: "check-circle",
716
+ warning: "warning-triangle",
717
+ error: "xmark-circle",
718
+ info: "info-circle"
719
+ };
720
+ __decorateClass([
721
+ property4({ reflect: true })
722
+ ], Alert.prototype, "variant", 2);
723
+ __decorateClass([
724
+ property4({ reflect: true })
725
+ ], Alert.prototype, "appearance", 2);
726
+ __decorateClass([
727
+ property4({ reflect: true })
728
+ ], Alert.prototype, "title", 2);
729
+ __decorateClass([
730
+ property4({ reflect: true })
731
+ ], Alert.prototype, "icon", 2);
732
+ __decorateClass([
733
+ property4({ type: Boolean, reflect: true })
734
+ ], Alert.prototype, "closable", 2);
735
+ __decorateClass([
736
+ property4({ reflect: true })
737
+ ], Alert.prototype, "background", 2);
738
+ __decorateClass([
739
+ property4({ type: Boolean, reflect: true })
740
+ ], Alert.prototype, "uppercase", 2);
741
+ Alert = __decorateClass([
742
+ customElement3("lt-alert")
743
+ ], Alert);
744
+ export {
745
+ Alert
746
+ };