elbe-ui 1.0.7 → 2.0.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 (141) hide show
  1. package/dist/elbe.css +150 -562
  2. package/dist/elbe.css.map +1 -1
  3. package/dist/index.d.ts +188 -46
  4. package/dist/index.js +8 -6
  5. package/dist/ui/app/app.d.ts +12 -0
  6. package/dist/ui/{components/layout/app_base.js → app/app.js} +24 -31
  7. package/dist/ui/app/app_ctxt.d.ts +35 -0
  8. package/dist/ui/app/app_ctxt.js +10 -0
  9. package/dist/ui/components/badge.d.ts +3 -3
  10. package/dist/ui/components/badge.js +16 -5
  11. package/dist/ui/components/banner.d.ts +3 -3
  12. package/dist/ui/components/banner.js +1 -1
  13. package/dist/ui/components/base/box.d.ts +82 -35
  14. package/dist/ui/components/base/box.js +56 -8
  15. package/dist/ui/components/base/card.d.ts +11 -12
  16. package/dist/ui/components/base/card.js +36 -19
  17. package/dist/ui/components/base/padded.d.ts +2 -4
  18. package/dist/ui/components/base/state_builder.d.ts +9 -0
  19. package/dist/ui/components/base/state_builder.js +33 -0
  20. package/dist/ui/components/button/button.d.ts +8 -6
  21. package/dist/ui/components/button/button.js +27 -16
  22. package/dist/ui/components/button/choose_button.d.ts +5 -3
  23. package/dist/ui/components/button/choose_button.js +9 -6
  24. package/dist/ui/components/button/icon_button.d.ts +6 -5
  25. package/dist/ui/components/button/icon_button.js +33 -23
  26. package/dist/ui/components/button/toggle_button.d.ts +5 -5
  27. package/dist/ui/components/button/toggle_button.js +13 -7
  28. package/dist/ui/components/dialog/dialog.d.ts +13 -0
  29. package/dist/ui/components/dialog/dialog.js +69 -0
  30. package/dist/ui/components/dialog/dialog_ctx.d.ts +34 -0
  31. package/dist/ui/components/dialog/dialog_ctx.js +44 -0
  32. package/dist/ui/components/dialog/dialogs/_alert.d.ts +7 -0
  33. package/dist/ui/components/dialog/dialogs/_alert.js +9 -0
  34. package/dist/ui/components/dialog/dialogs/_confirm.d.ts +9 -0
  35. package/dist/ui/components/dialog/dialogs/_confirm.js +21 -0
  36. package/dist/ui/components/error_view.js +3 -3
  37. package/dist/ui/components/footer.js +7 -7
  38. package/dist/ui/components/input/_labeled_input.d.ts +21 -0
  39. package/dist/ui/components/input/_labeled_input.js +21 -0
  40. package/dist/ui/components/input/checkbox.d.ts +4 -2
  41. package/dist/ui/components/input/checkbox.js +16 -8
  42. package/dist/ui/components/input/range.d.ts +5 -3
  43. package/dist/ui/components/input/range.js +20 -13
  44. package/dist/ui/components/input/select.d.ts +4 -3
  45. package/dist/ui/components/input/select.js +13 -40
  46. package/dist/ui/components/input/switch.d.ts +4 -2
  47. package/dist/ui/components/input/switch.js +30 -40
  48. package/dist/ui/components/input/text/input_field.d.ts +14 -19
  49. package/dist/ui/components/input/text/input_field.js +63 -61
  50. package/dist/ui/components/input/text/single_line.d.ts +11 -9
  51. package/dist/ui/components/input/text/single_line.js +15 -21
  52. package/dist/ui/components/layout/flex.d.ts +7 -3
  53. package/dist/ui/components/layout/flex.js +15 -12
  54. package/dist/ui/components/layout/header.d.ts +2 -2
  55. package/dist/ui/components/layout/header.js +25 -18
  56. package/dist/ui/components/layout/menu.js +74 -49
  57. package/dist/ui/components/layout/scroll.d.ts +1 -0
  58. package/dist/ui/components/layout/scroll.js +3 -1
  59. package/dist/ui/components/layout/toolbar.js +9 -6
  60. package/dist/ui/components/link.d.ts +4 -2
  61. package/dist/ui/components/link.js +24 -11
  62. package/dist/ui/components/progress_bar.d.ts +2 -2
  63. package/dist/ui/components/progress_bar.js +12 -9
  64. package/dist/ui/components/spinner.d.ts +2 -7
  65. package/dist/ui/components/spinner.js +15 -16
  66. package/dist/ui/components/text.d.ts +5 -6
  67. package/dist/ui/components/text.js +34 -21
  68. package/dist/ui/components/tooltip.d.ts +5 -0
  69. package/dist/ui/components/tooltip.js +48 -0
  70. package/dist/ui/theme/subthemes/_theme_geometry.d.ts +9 -0
  71. package/dist/ui/theme/subthemes/_theme_geometry.js +22 -0
  72. package/dist/ui/theme/subthemes/_theme_menu.d.ts +9 -0
  73. package/dist/ui/theme/subthemes/_theme_menu.js +12 -0
  74. package/dist/ui/theme/subthemes/_theme_motion.d.ts +9 -0
  75. package/dist/ui/theme/subthemes/_theme_motion.js +13 -0
  76. package/dist/ui/theme/subthemes/_theme_toast.d.ts +8 -0
  77. package/dist/ui/theme/subthemes/_theme_toast.js +11 -0
  78. package/dist/ui/theme/subthemes/_theme_type.d.ts +49 -0
  79. package/dist/ui/theme/subthemes/_theme_type.js +73 -0
  80. package/dist/ui/theme/subthemes/color/_seed.d.ts +2 -0
  81. package/dist/ui/theme/subthemes/color/_seed.js +105 -0
  82. package/dist/ui/theme/subthemes/color/_theme_color.d.ts +865 -0
  83. package/dist/ui/theme/subthemes/color/_theme_color.js +83 -0
  84. package/dist/ui/theme/subthemes/color/colors/_color_contrast.d.ts +284 -0
  85. package/dist/ui/theme/subthemes/color/colors/_color_contrast.js +17 -0
  86. package/dist/ui/theme/subthemes/color/colors/_color_kind.d.ts +242 -0
  87. package/dist/ui/theme/subthemes/color/colors/_color_kind.js +45 -0
  88. package/dist/ui/theme/subthemes/color/colors/_color_layer.d.ts +226 -0
  89. package/dist/ui/theme/subthemes/color/colors/_color_layer.js +95 -0
  90. package/dist/ui/theme/subthemes/color/colors/_color_manner.d.ts +280 -0
  91. package/dist/ui/theme/subthemes/color/colors/_color_manner.js +17 -0
  92. package/dist/ui/theme/subthemes/color/colors/_color_mode.d.ts +269 -0
  93. package/dist/ui/theme/subthemes/color/colors/_color_mode.js +16 -0
  94. package/dist/ui/theme/subthemes/color/colors/_color_rgba.d.ts +166 -0
  95. package/dist/ui/theme/subthemes/color/colors/_color_rgba.js +86 -0
  96. package/dist/ui/theme/subthemes/color/colors/_color_scheme.d.ts +256 -0
  97. package/dist/ui/theme/subthemes/color/colors/_color_scheme.js +17 -0
  98. package/dist/ui/theme/subthemes/color/colors/_color_state.d.ts +252 -0
  99. package/dist/ui/theme/subthemes/color/colors/_color_state.js +49 -0
  100. package/dist/ui/theme/subthemes/color/colors/_colordef.d.ts +22 -0
  101. package/dist/ui/theme/subthemes/color/colors/_colordef.js +34 -0
  102. package/dist/ui/theme/subthemes/color/colors/colors.d.ts +511 -0
  103. package/dist/ui/theme/subthemes/color/colors/colors.js +24 -0
  104. package/dist/ui/theme/theme.d.ts +984 -30
  105. package/dist/ui/theme/theme.js +14 -82
  106. package/dist/ui/theme/theme_context.d.ts +15 -17
  107. package/dist/ui/theme/theme_context.js +79 -18
  108. package/dist/ui/util/_util.d.ts +1 -0
  109. package/dist/ui/util/_util.js +3 -0
  110. package/dist/ui/util/error_view.js +3 -3
  111. package/dist/ui/util/merge_deep.d.ts +1 -0
  112. package/dist/ui/util/merge_deep.js +18 -0
  113. package/dist/ui/util/root.d.ts +17 -0
  114. package/dist/ui/util/root.js +23 -0
  115. package/dist/ui/util/toast/_toast.d.ts +5 -0
  116. package/dist/ui/util/toast/_toast.js +7 -0
  117. package/dist/ui/util/toast/toast_ctx.d.ts +28 -0
  118. package/dist/ui/util/toast/toast_ctx.js +62 -0
  119. package/dist/ui/util/toast/toast_legacy.d.ts +5 -0
  120. package/dist/ui/util/{toast.js → toast/toast_legacy.js} +4 -4
  121. package/dist/ui/util/util.d.ts +8 -0
  122. package/dist/ui/util/util.js +54 -1
  123. package/package.json +10 -8
  124. package/dist/ui/components/dialog.d.ts +0 -9
  125. package/dist/ui/components/dialog.js +0 -32
  126. package/dist/ui/components/layout/app_base.d.ts +0 -15
  127. package/dist/ui/components/layout/ctx_app_base.d.ts +0 -19
  128. package/dist/ui/components/layout/ctx_app_base.js +0 -12
  129. package/dist/ui/theme/color_theme.d.ts +0 -2
  130. package/dist/ui/theme/color_theme.js +0 -92
  131. package/dist/ui/theme/colors.d.ts +0 -133
  132. package/dist/ui/theme/colors.js +0 -309
  133. package/dist/ui/theme/geometry_theme.d.ts +0 -16
  134. package/dist/ui/theme/geometry_theme.js +0 -28
  135. package/dist/ui/theme/seed.d.ts +0 -53
  136. package/dist/ui/theme/seed.js +0 -4
  137. package/dist/ui/theme/type_theme.d.ts +0 -38
  138. package/dist/ui/theme/type_theme.js +0 -73
  139. package/dist/ui/util/confirm_dialog.d.ts +0 -10
  140. package/dist/ui/util/confirm_dialog.js +0 -46
  141. package/dist/ui/util/toast.d.ts +0 -5
@@ -0,0 +1,256 @@
1
+ import { KindColor } from "./_color_kind";
2
+ import { LayerColor } from "./_color_layer";
3
+ import { ColorThemeSeed } from "./colors";
4
+ export declare const SchemeColor: {
5
+ is: (v: any) => v is import("./_colordef").ElbeColor<"state", {
6
+ primary: KindColor;
7
+ secondary: KindColor;
8
+ inverse: KindColor;
9
+ }, Omit<{
10
+ type: ["kind", ...string[]];
11
+ } & {
12
+ accent: import("./_color_manner").MannerColor;
13
+ info: import("./_color_manner").MannerColor;
14
+ success: import("./_color_manner").MannerColor;
15
+ warning: import("./_color_manner").MannerColor;
16
+ error: import("./_color_manner").MannerColor;
17
+ } & Omit<{
18
+ type: ["manner", ...string[]];
19
+ } & {
20
+ major: import("./_color_state").StateColor;
21
+ minor: import("./_color_state").StateColor;
22
+ flat: import("./_color_state").StateColor;
23
+ plain: import("./_color_state").StateColor;
24
+ } & Omit<{
25
+ type: ["state", ...string[]];
26
+ } & {
27
+ neutral: LayerColor;
28
+ hover: LayerColor;
29
+ active: LayerColor;
30
+ disabled: LayerColor;
31
+ } & Omit<{
32
+ type: ["layer", ...string[]];
33
+ } & {
34
+ back: import("./_color_rgba").RGBAColor;
35
+ front: import("./_color_rgba").RGBAColor;
36
+ border: import("./_color_rgba").RGBAColor;
37
+ } & Omit<{
38
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
39
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
40
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
41
+ desaturatedLayer: () => LayerColor;
42
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
43
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
44
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
45
+ } & {
46
+ type: ["rgba", ...string[]];
47
+ } & {
48
+ red: number;
49
+ green: number;
50
+ blue: number;
51
+ alpha: number;
52
+ } & Omit<{
53
+ asCss: () => string;
54
+ hex: () => string;
55
+ isDark: () => boolean;
56
+ luminance: () => number;
57
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
58
+ red: number;
59
+ green: number;
60
+ blue: number;
61
+ alpha: number;
62
+ }, Omit</*elided*/ any, "type">>;
63
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
64
+ red: number;
65
+ green: number;
66
+ blue: number;
67
+ alpha: number;
68
+ }, Omit</*elided*/ any, "type">>;
69
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
70
+ red: number;
71
+ green: number;
72
+ blue: number;
73
+ alpha: number;
74
+ }, Omit</*elided*/ any, "type">>;
75
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
76
+ red: number;
77
+ green: number;
78
+ blue: number;
79
+ alpha: number;
80
+ }, Omit</*elided*/ any, "type">>;
81
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
82
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
83
+ }, "type">, "type">, "type">, "type">, "type">, "type">>;
84
+ new: (data: {
85
+ primary: KindColor;
86
+ secondary: KindColor;
87
+ inverse: KindColor;
88
+ }) => import("./_colordef").ElbeColor<"state", {
89
+ primary: KindColor;
90
+ secondary: KindColor;
91
+ inverse: KindColor;
92
+ }, Omit<{
93
+ type: ["kind", ...string[]];
94
+ } & {
95
+ accent: import("./_color_manner").MannerColor;
96
+ info: import("./_color_manner").MannerColor;
97
+ success: import("./_color_manner").MannerColor;
98
+ warning: import("./_color_manner").MannerColor;
99
+ error: import("./_color_manner").MannerColor;
100
+ } & Omit<{
101
+ type: ["manner", ...string[]];
102
+ } & {
103
+ major: import("./_color_state").StateColor;
104
+ minor: import("./_color_state").StateColor;
105
+ flat: import("./_color_state").StateColor;
106
+ plain: import("./_color_state").StateColor;
107
+ } & Omit<{
108
+ type: ["state", ...string[]];
109
+ } & {
110
+ neutral: LayerColor;
111
+ hover: LayerColor;
112
+ active: LayerColor;
113
+ disabled: LayerColor;
114
+ } & Omit<{
115
+ type: ["layer", ...string[]];
116
+ } & {
117
+ back: import("./_color_rgba").RGBAColor;
118
+ front: import("./_color_rgba").RGBAColor;
119
+ border: import("./_color_rgba").RGBAColor;
120
+ } & Omit<{
121
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
122
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
123
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
124
+ desaturatedLayer: () => LayerColor;
125
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
126
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
127
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
128
+ } & {
129
+ type: ["rgba", ...string[]];
130
+ } & {
131
+ red: number;
132
+ green: number;
133
+ blue: number;
134
+ alpha: number;
135
+ } & Omit<{
136
+ asCss: () => string;
137
+ hex: () => string;
138
+ isDark: () => boolean;
139
+ luminance: () => number;
140
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
141
+ red: number;
142
+ green: number;
143
+ blue: number;
144
+ alpha: number;
145
+ }, Omit</*elided*/ any, "type">>;
146
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
147
+ red: number;
148
+ green: number;
149
+ blue: number;
150
+ alpha: number;
151
+ }, Omit</*elided*/ any, "type">>;
152
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
153
+ red: number;
154
+ green: number;
155
+ blue: number;
156
+ alpha: number;
157
+ }, Omit</*elided*/ any, "type">>;
158
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
159
+ red: number;
160
+ green: number;
161
+ blue: number;
162
+ alpha: number;
163
+ }, Omit</*elided*/ any, "type">>;
164
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
165
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
166
+ }, "type">, "type">, "type">, "type">, "type">, "type">>;
167
+ _typeHint: {
168
+ color: import("./_colordef").ElbeColor<"state", {
169
+ primary: KindColor;
170
+ secondary: KindColor;
171
+ inverse: KindColor;
172
+ }, Omit<{
173
+ type: ["kind", ...string[]];
174
+ } & {
175
+ accent: import("./_color_manner").MannerColor;
176
+ info: import("./_color_manner").MannerColor;
177
+ success: import("./_color_manner").MannerColor;
178
+ warning: import("./_color_manner").MannerColor;
179
+ error: import("./_color_manner").MannerColor;
180
+ } & Omit<{
181
+ type: ["manner", ...string[]];
182
+ } & {
183
+ major: import("./_color_state").StateColor;
184
+ minor: import("./_color_state").StateColor;
185
+ flat: import("./_color_state").StateColor;
186
+ plain: import("./_color_state").StateColor;
187
+ } & Omit<{
188
+ type: ["state", ...string[]];
189
+ } & {
190
+ neutral: LayerColor;
191
+ hover: LayerColor;
192
+ active: LayerColor;
193
+ disabled: LayerColor;
194
+ } & Omit<{
195
+ type: ["layer", ...string[]];
196
+ } & {
197
+ back: import("./_color_rgba").RGBAColor;
198
+ front: import("./_color_rgba").RGBAColor;
199
+ border: import("./_color_rgba").RGBAColor;
200
+ } & Omit<{
201
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
202
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
203
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
204
+ desaturatedLayer: () => LayerColor;
205
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
206
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
207
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
208
+ } & {
209
+ type: ["rgba", ...string[]];
210
+ } & {
211
+ red: number;
212
+ green: number;
213
+ blue: number;
214
+ alpha: number;
215
+ } & Omit<{
216
+ asCss: () => string;
217
+ hex: () => string;
218
+ isDark: () => boolean;
219
+ luminance: () => number;
220
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
221
+ red: number;
222
+ green: number;
223
+ blue: number;
224
+ alpha: number;
225
+ }, Omit</*elided*/ any, "type">>;
226
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
227
+ red: number;
228
+ green: number;
229
+ blue: number;
230
+ alpha: number;
231
+ }, Omit</*elided*/ any, "type">>;
232
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
233
+ red: number;
234
+ green: number;
235
+ blue: number;
236
+ alpha: number;
237
+ }, Omit</*elided*/ any, "type">>;
238
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
239
+ red: number;
240
+ green: number;
241
+ blue: number;
242
+ alpha: number;
243
+ }, Omit</*elided*/ any, "type">>;
244
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
245
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
246
+ }, "type">, "type">, "type">, "type">, "type">, "type">>;
247
+ data: {
248
+ primary: KindColor;
249
+ secondary: KindColor;
250
+ inverse: KindColor;
251
+ };
252
+ };
253
+ } & {
254
+ generate(path: string[], seed: ColorThemeSeed, base: LayerColor): SchemeColor;
255
+ };
256
+ export type SchemeColor = (typeof SchemeColor)["_typeHint"]["color"];
@@ -0,0 +1,17 @@
1
+ import { KindColor } from "./_color_kind";
2
+ import { defineColor } from "./_colordef";
3
+ export const SchemeColor = defineColor({
4
+ type: "state",
5
+ static: {
6
+ generate(path, seed, base) {
7
+ const m = seed.scheme;
8
+ return SchemeColor.new({
9
+ primary: KindColor.generate([...path, "primary"], seed, m.primary({ path, seed, base })),
10
+ secondary: KindColor.generate([...path, "secondary"], seed, m.secondary({ path, seed, base })),
11
+ inverse: KindColor.generate([...path, "inverse"], seed, m.inverse({ path, seed, base })),
12
+ });
13
+ },
14
+ },
15
+ parent: (data) => data.primary,
16
+ compute: (_) => ({}),
17
+ });
@@ -0,0 +1,252 @@
1
+ import { LayerColor } from "./_color_layer";
2
+ import { ColorThemeSeed } from "./colors";
3
+ export declare const StateColor: {
4
+ is: (v: any) => v is import("./_colordef").ElbeColor<"state", {
5
+ neutral: LayerColor;
6
+ hover: LayerColor;
7
+ active: LayerColor;
8
+ disabled: LayerColor;
9
+ }, Omit<{
10
+ type: ["layer", ...string[]];
11
+ } & {
12
+ back: import("./_color_rgba").RGBAColor;
13
+ front: import("./_color_rgba").RGBAColor;
14
+ border: import("./_color_rgba").RGBAColor;
15
+ } & Omit<{
16
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
17
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
18
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
19
+ desaturatedLayer: () => LayerColor;
20
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
21
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
22
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
23
+ } & {
24
+ type: ["rgba", ...string[]];
25
+ } & {
26
+ red: number;
27
+ green: number;
28
+ blue: number;
29
+ alpha: number;
30
+ } & Omit<{
31
+ asCss: () => string;
32
+ hex: () => string;
33
+ isDark: () => boolean;
34
+ luminance: () => number;
35
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
36
+ red: number;
37
+ green: number;
38
+ blue: number;
39
+ alpha: number;
40
+ }, Omit</*elided*/ any, "type">>;
41
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
42
+ red: number;
43
+ green: number;
44
+ blue: number;
45
+ alpha: number;
46
+ }, Omit</*elided*/ any, "type">>;
47
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
48
+ red: number;
49
+ green: number;
50
+ blue: number;
51
+ alpha: number;
52
+ }, Omit</*elided*/ any, "type">>;
53
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
54
+ red: number;
55
+ green: number;
56
+ blue: number;
57
+ alpha: number;
58
+ }, Omit</*elided*/ any, "type">>;
59
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
60
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
61
+ }, "type">, "type">, "type">>;
62
+ new: (data: {
63
+ neutral: LayerColor;
64
+ hover: LayerColor;
65
+ active: LayerColor;
66
+ disabled: LayerColor;
67
+ }) => import("./_colordef").ElbeColor<"state", {
68
+ neutral: LayerColor;
69
+ hover: LayerColor;
70
+ active: LayerColor;
71
+ disabled: LayerColor;
72
+ }, Omit<{
73
+ type: ["layer", ...string[]];
74
+ } & {
75
+ back: import("./_color_rgba").RGBAColor;
76
+ front: import("./_color_rgba").RGBAColor;
77
+ border: import("./_color_rgba").RGBAColor;
78
+ } & Omit<{
79
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
80
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
81
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
82
+ desaturatedLayer: () => LayerColor;
83
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
84
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
85
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
86
+ } & {
87
+ type: ["rgba", ...string[]];
88
+ } & {
89
+ red: number;
90
+ green: number;
91
+ blue: number;
92
+ alpha: number;
93
+ } & Omit<{
94
+ asCss: () => string;
95
+ hex: () => string;
96
+ isDark: () => boolean;
97
+ luminance: () => number;
98
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
99
+ red: number;
100
+ green: number;
101
+ blue: number;
102
+ alpha: number;
103
+ }, Omit</*elided*/ any, "type">>;
104
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
105
+ red: number;
106
+ green: number;
107
+ blue: number;
108
+ alpha: number;
109
+ }, Omit</*elided*/ any, "type">>;
110
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
111
+ red: number;
112
+ green: number;
113
+ blue: number;
114
+ alpha: number;
115
+ }, Omit</*elided*/ any, "type">>;
116
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
117
+ red: number;
118
+ green: number;
119
+ blue: number;
120
+ alpha: number;
121
+ }, Omit</*elided*/ any, "type">>;
122
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
123
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
124
+ }, "type">, "type">, "type">>;
125
+ _typeHint: {
126
+ color: import("./_colordef").ElbeColor<"state", {
127
+ neutral: LayerColor;
128
+ hover: LayerColor;
129
+ active: LayerColor;
130
+ disabled: LayerColor;
131
+ }, Omit<{
132
+ type: ["layer", ...string[]];
133
+ } & {
134
+ back: import("./_color_rgba").RGBAColor;
135
+ front: import("./_color_rgba").RGBAColor;
136
+ border: import("./_color_rgba").RGBAColor;
137
+ } & Omit<{
138
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
139
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
140
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
141
+ desaturatedLayer: () => LayerColor;
142
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
143
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
144
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
145
+ } & {
146
+ type: ["rgba", ...string[]];
147
+ } & {
148
+ red: number;
149
+ green: number;
150
+ blue: number;
151
+ alpha: number;
152
+ } & Omit<{
153
+ asCss: () => string;
154
+ hex: () => string;
155
+ isDark: () => boolean;
156
+ luminance: () => number;
157
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
158
+ red: number;
159
+ green: number;
160
+ blue: number;
161
+ alpha: number;
162
+ }, Omit</*elided*/ any, "type">>;
163
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
164
+ red: number;
165
+ green: number;
166
+ blue: number;
167
+ alpha: number;
168
+ }, Omit</*elided*/ any, "type">>;
169
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
170
+ red: number;
171
+ green: number;
172
+ blue: number;
173
+ alpha: number;
174
+ }, Omit</*elided*/ any, "type">>;
175
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
176
+ red: number;
177
+ green: number;
178
+ blue: number;
179
+ alpha: number;
180
+ }, Omit</*elided*/ any, "type">>;
181
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
182
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
183
+ }, "type">, "type">, "type">>;
184
+ data: {
185
+ neutral: LayerColor;
186
+ hover: LayerColor;
187
+ active: LayerColor;
188
+ disabled: LayerColor;
189
+ };
190
+ };
191
+ } & {
192
+ generate(path: string[], seed: ColorThemeSeed, context: LayerColor, style: LayerColor, fromFront?: boolean): StateColor;
193
+ fromBack(back: string): import("./_colordef").ElbeColor<"state", {
194
+ neutral: LayerColor;
195
+ hover: LayerColor;
196
+ active: LayerColor;
197
+ disabled: LayerColor;
198
+ }, Omit<{
199
+ type: ["layer", ...string[]];
200
+ } & {
201
+ back: import("./_color_rgba").RGBAColor;
202
+ front: import("./_color_rgba").RGBAColor;
203
+ border: import("./_color_rgba").RGBAColor;
204
+ } & Omit<{
205
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
206
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
207
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
208
+ desaturatedLayer: () => LayerColor;
209
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
210
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
211
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
212
+ } & {
213
+ type: ["rgba", ...string[]];
214
+ } & {
215
+ red: number;
216
+ green: number;
217
+ blue: number;
218
+ alpha: number;
219
+ } & Omit<{
220
+ asCss: () => string;
221
+ hex: () => string;
222
+ isDark: () => boolean;
223
+ luminance: () => number;
224
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
225
+ red: number;
226
+ green: number;
227
+ blue: number;
228
+ alpha: number;
229
+ }, Omit</*elided*/ any, "type">>;
230
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
231
+ red: number;
232
+ green: number;
233
+ blue: number;
234
+ alpha: number;
235
+ }, Omit</*elided*/ any, "type">>;
236
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
237
+ red: number;
238
+ green: number;
239
+ blue: number;
240
+ alpha: number;
241
+ }, Omit</*elided*/ any, "type">>;
242
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
243
+ red: number;
244
+ green: number;
245
+ blue: number;
246
+ alpha: number;
247
+ }, Omit</*elided*/ any, "type">>;
248
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
249
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
250
+ }, "type">, "type">, "type">>;
251
+ };
252
+ export type StateColor = (typeof StateColor)["_typeHint"]["color"];
@@ -0,0 +1,49 @@
1
+ import { LayerColor } from "./_color_layer";
2
+ import { defineColor } from "./_colordef";
3
+ export const StateColor = defineColor({
4
+ type: "state",
5
+ static: {
6
+ generate(path, seed, context, style, fromFront) {
7
+ var _a, _b;
8
+ function _make(factor) {
9
+ const front = style.front;
10
+ return LayerColor.new({
11
+ back: (fromFront
12
+ ? context.back.inter(front, factor)
13
+ : style.back.inter(context.back.mirrorBrightness(), factor)).withAlpha(Math.max(style.back.alpha, 0.2)),
14
+ front,
15
+ border: style.border,
16
+ });
17
+ }
18
+ return StateColor.new({
19
+ neutral: style,
20
+ hover: (_a = _make(0.05)) !== null && _a !== void 0 ? _a : style,
21
+ active: (_b = _make(0.15)) !== null && _b !== void 0 ? _b : style,
22
+ disabled: path.includes("plain") || path.includes("flat")
23
+ ? style.interLayer(style.back, 0.35, 0.5, 0.35).desaturatedLayer()
24
+ : style.desaturatedLayer().mirrorBrightnessLayer(0.05),
25
+ });
26
+ },
27
+ fromBack(back) {
28
+ var _a, _b;
29
+ const style = LayerColor.fromBack(back);
30
+ function _make(factor) {
31
+ return LayerColor.new({
32
+ back: style.back
33
+ .inter(style.mirrorBrightness(), factor)
34
+ .withAlpha(Math.max(style.back.alpha, 0.2)),
35
+ front: style.front,
36
+ border: style.border,
37
+ });
38
+ }
39
+ return StateColor.new({
40
+ neutral: style,
41
+ hover: (_a = _make(0.05)) !== null && _a !== void 0 ? _a : style,
42
+ active: (_b = _make(0.15)) !== null && _b !== void 0 ? _b : style,
43
+ disabled: style.desaturatedLayer(),
44
+ });
45
+ },
46
+ },
47
+ parent: (data) => data.neutral,
48
+ compute: (_) => ({}),
49
+ });
@@ -0,0 +1,22 @@
1
+ export type ElbeColor<T extends string, Data extends Dict<any>, Computed extends Dict<any>> = {
2
+ type: [T, ...string[]];
3
+ } & Data & Computed;
4
+ export declare function defineColor<Name extends string, Data extends Dict<any>, Computed extends Dict<any>, Parent extends Dict<any>, T extends ElbeColor<Name, Data, Omit<Computed & Parent, "type">>, Static extends Dict<any> = {}>(p: {
5
+ type: Name;
6
+ static: Static;
7
+ compute: (data: Data) => Computed;
8
+ parent: (data: Data) => Parent;
9
+ }): {
10
+ is: (v: any) => v is T;
11
+ new: (data: Data) => T;
12
+ _typeHint: {
13
+ color: T;
14
+ data: Data;
15
+ };
16
+ } & Static;
17
+ export type ColorDataKeys<T extends {
18
+ _typeHint: {
19
+ data: Dict<any>;
20
+ };
21
+ }> = keyof T["_typeHint"]["data"];
22
+ export declare function withoutType<T extends Dict<any>>(obj: T): Omit<T, "type">;
@@ -0,0 +1,34 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ export function defineColor(p) {
13
+ function _new(data) {
14
+ var _a;
15
+ const comp = p.compute(data);
16
+ const parent = p.parent(data);
17
+ return Object.assign(Object.assign(Object.assign(Object.assign({}, data), comp), parent), { type: [p.type, ...((_a = parent.type) !== null && _a !== void 0 ? _a : [])] });
18
+ }
19
+ function is(v) {
20
+ return (v &&
21
+ typeof v === "object" &&
22
+ v.type &&
23
+ Array.isArray(v.type) &&
24
+ v.type.includes(p.type));
25
+ }
26
+ return Object.assign({ is, new: _new, _typeHint: {
27
+ color: undefined,
28
+ data: undefined,
29
+ } }, p.static);
30
+ }
31
+ export function withoutType(obj) {
32
+ const { type } = obj, rest = __rest(obj, ["type"]);
33
+ return rest;
34
+ }