elbe-ui 1.0.8 → 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 -10
  125. package/dist/ui/components/dialog.js +0 -35
  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,269 @@
1
+ import { LayerColor } from "./_color_layer";
2
+ import { SchemeColor } from "./_color_scheme";
3
+ import { ColorThemeSeed } from "./colors";
4
+ export declare const ModeColor: {
5
+ is: (v: any) => v is import("./_colordef").ElbeColor<"mode", {
6
+ light: SchemeColor;
7
+ dark: SchemeColor;
8
+ }, Omit<{
9
+ type: ["state", ...string[]];
10
+ } & {
11
+ primary: import("./_color_kind").KindColor;
12
+ secondary: import("./_color_kind").KindColor;
13
+ inverse: import("./_color_kind").KindColor;
14
+ } & Omit<{
15
+ type: ["kind", ...string[]];
16
+ } & {
17
+ accent: import("./_color_manner").MannerColor;
18
+ info: import("./_color_manner").MannerColor;
19
+ success: import("./_color_manner").MannerColor;
20
+ warning: import("./_color_manner").MannerColor;
21
+ error: import("./_color_manner").MannerColor;
22
+ } & Omit<{
23
+ type: ["manner", ...string[]];
24
+ } & {
25
+ major: import("./_color_state").StateColor;
26
+ minor: import("./_color_state").StateColor;
27
+ flat: import("./_color_state").StateColor;
28
+ plain: import("./_color_state").StateColor;
29
+ } & Omit<{
30
+ type: ["state", ...string[]];
31
+ } & {
32
+ neutral: LayerColor;
33
+ hover: LayerColor;
34
+ active: LayerColor;
35
+ disabled: LayerColor;
36
+ } & Omit<{
37
+ type: ["layer", ...string[]];
38
+ } & {
39
+ back: import("./_color_rgba").RGBAColor;
40
+ front: import("./_color_rgba").RGBAColor;
41
+ border: import("./_color_rgba").RGBAColor;
42
+ } & Omit<{
43
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
44
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
45
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
46
+ desaturatedLayer: () => LayerColor;
47
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
48
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
49
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
50
+ } & {
51
+ type: ["rgba", ...string[]];
52
+ } & {
53
+ red: number;
54
+ green: number;
55
+ blue: number;
56
+ alpha: number;
57
+ } & Omit<{
58
+ asCss: () => string;
59
+ hex: () => string;
60
+ isDark: () => boolean;
61
+ luminance: () => number;
62
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
63
+ red: number;
64
+ green: number;
65
+ blue: number;
66
+ alpha: number;
67
+ }, Omit</*elided*/ any, "type">>;
68
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
69
+ red: number;
70
+ green: number;
71
+ blue: number;
72
+ alpha: number;
73
+ }, Omit</*elided*/ any, "type">>;
74
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
75
+ red: number;
76
+ green: number;
77
+ blue: number;
78
+ alpha: number;
79
+ }, Omit</*elided*/ any, "type">>;
80
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
81
+ red: number;
82
+ green: number;
83
+ blue: number;
84
+ alpha: number;
85
+ }, Omit</*elided*/ any, "type">>;
86
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
87
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
88
+ }, "type">, "type">, "type">, "type">, "type">, "type">, "type">>;
89
+ new: (data: {
90
+ light: SchemeColor;
91
+ dark: SchemeColor;
92
+ }) => import("./_colordef").ElbeColor<"mode", {
93
+ light: SchemeColor;
94
+ dark: SchemeColor;
95
+ }, Omit<{
96
+ type: ["state", ...string[]];
97
+ } & {
98
+ primary: import("./_color_kind").KindColor;
99
+ secondary: import("./_color_kind").KindColor;
100
+ inverse: import("./_color_kind").KindColor;
101
+ } & Omit<{
102
+ type: ["kind", ...string[]];
103
+ } & {
104
+ accent: import("./_color_manner").MannerColor;
105
+ info: import("./_color_manner").MannerColor;
106
+ success: import("./_color_manner").MannerColor;
107
+ warning: import("./_color_manner").MannerColor;
108
+ error: import("./_color_manner").MannerColor;
109
+ } & Omit<{
110
+ type: ["manner", ...string[]];
111
+ } & {
112
+ major: import("./_color_state").StateColor;
113
+ minor: import("./_color_state").StateColor;
114
+ flat: import("./_color_state").StateColor;
115
+ plain: import("./_color_state").StateColor;
116
+ } & Omit<{
117
+ type: ["state", ...string[]];
118
+ } & {
119
+ neutral: LayerColor;
120
+ hover: LayerColor;
121
+ active: LayerColor;
122
+ disabled: LayerColor;
123
+ } & Omit<{
124
+ type: ["layer", ...string[]];
125
+ } & {
126
+ back: import("./_color_rgba").RGBAColor;
127
+ front: import("./_color_rgba").RGBAColor;
128
+ border: import("./_color_rgba").RGBAColor;
129
+ } & Omit<{
130
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
131
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
132
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
133
+ desaturatedLayer: () => LayerColor;
134
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
135
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
136
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
137
+ } & {
138
+ type: ["rgba", ...string[]];
139
+ } & {
140
+ red: number;
141
+ green: number;
142
+ blue: number;
143
+ alpha: number;
144
+ } & Omit<{
145
+ asCss: () => string;
146
+ hex: () => string;
147
+ isDark: () => boolean;
148
+ luminance: () => number;
149
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
150
+ red: number;
151
+ green: number;
152
+ blue: number;
153
+ alpha: number;
154
+ }, Omit</*elided*/ any, "type">>;
155
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
156
+ red: number;
157
+ green: number;
158
+ blue: number;
159
+ alpha: number;
160
+ }, Omit</*elided*/ any, "type">>;
161
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
162
+ red: number;
163
+ green: number;
164
+ blue: number;
165
+ alpha: number;
166
+ }, Omit</*elided*/ any, "type">>;
167
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
168
+ red: number;
169
+ green: number;
170
+ blue: number;
171
+ alpha: number;
172
+ }, Omit</*elided*/ any, "type">>;
173
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
174
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
175
+ }, "type">, "type">, "type">, "type">, "type">, "type">, "type">>;
176
+ _typeHint: {
177
+ color: import("./_colordef").ElbeColor<"mode", {
178
+ light: SchemeColor;
179
+ dark: SchemeColor;
180
+ }, Omit<{
181
+ type: ["state", ...string[]];
182
+ } & {
183
+ primary: import("./_color_kind").KindColor;
184
+ secondary: import("./_color_kind").KindColor;
185
+ inverse: import("./_color_kind").KindColor;
186
+ } & Omit<{
187
+ type: ["kind", ...string[]];
188
+ } & {
189
+ accent: import("./_color_manner").MannerColor;
190
+ info: import("./_color_manner").MannerColor;
191
+ success: import("./_color_manner").MannerColor;
192
+ warning: import("./_color_manner").MannerColor;
193
+ error: import("./_color_manner").MannerColor;
194
+ } & Omit<{
195
+ type: ["manner", ...string[]];
196
+ } & {
197
+ major: import("./_color_state").StateColor;
198
+ minor: import("./_color_state").StateColor;
199
+ flat: import("./_color_state").StateColor;
200
+ plain: import("./_color_state").StateColor;
201
+ } & Omit<{
202
+ type: ["state", ...string[]];
203
+ } & {
204
+ neutral: LayerColor;
205
+ hover: LayerColor;
206
+ active: LayerColor;
207
+ disabled: LayerColor;
208
+ } & Omit<{
209
+ type: ["layer", ...string[]];
210
+ } & {
211
+ back: import("./_color_rgba").RGBAColor;
212
+ front: import("./_color_rgba").RGBAColor;
213
+ border: import("./_color_rgba").RGBAColor;
214
+ } & Omit<{
215
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
216
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
217
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
218
+ desaturatedLayer: () => LayerColor;
219
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
220
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
221
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
222
+ } & {
223
+ type: ["rgba", ...string[]];
224
+ } & {
225
+ red: number;
226
+ green: number;
227
+ blue: number;
228
+ alpha: number;
229
+ } & Omit<{
230
+ asCss: () => string;
231
+ hex: () => string;
232
+ isDark: () => boolean;
233
+ luminance: () => number;
234
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
235
+ red: number;
236
+ green: number;
237
+ blue: number;
238
+ alpha: number;
239
+ }, Omit</*elided*/ any, "type">>;
240
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
241
+ red: number;
242
+ green: number;
243
+ blue: number;
244
+ alpha: number;
245
+ }, Omit</*elided*/ any, "type">>;
246
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
247
+ red: number;
248
+ green: number;
249
+ blue: number;
250
+ alpha: number;
251
+ }, Omit</*elided*/ any, "type">>;
252
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
253
+ red: number;
254
+ green: number;
255
+ blue: number;
256
+ alpha: number;
257
+ }, Omit</*elided*/ any, "type">>;
258
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
259
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
260
+ }, "type">, "type">, "type">, "type">, "type">, "type">, "type">>;
261
+ data: {
262
+ light: SchemeColor;
263
+ dark: SchemeColor;
264
+ };
265
+ };
266
+ } & {
267
+ generate(path: string[], seed: ColorThemeSeed): ModeColor;
268
+ };
269
+ export type ModeColor = (typeof ModeColor)["_typeHint"]["color"];
@@ -0,0 +1,16 @@
1
+ import { LayerColor } from "./_color_layer";
2
+ import { SchemeColor } from "./_color_scheme";
3
+ import { defineColor } from "./_colordef";
4
+ export const ModeColor = defineColor({
5
+ type: "mode",
6
+ static: {
7
+ generate(path, seed) {
8
+ return ModeColor.new({
9
+ light: SchemeColor.generate(path, seed, LayerColor.asLayer(seed.base)),
10
+ dark: SchemeColor.generate([...path, "dark"], seed, seed.mode.dark({ path, seed, base: LayerColor.asLayer(seed.base) })),
11
+ });
12
+ },
13
+ },
14
+ parent: (data) => data.light,
15
+ compute: (data) => ({}),
16
+ });
@@ -0,0 +1,166 @@
1
+ export declare const RGBAColor: {
2
+ is: (v: any) => v is import("./_colordef").ElbeColor<"rgba", {
3
+ red: number;
4
+ green: number;
5
+ blue: number;
6
+ alpha: number;
7
+ }, Omit<{
8
+ asCss: () => string;
9
+ hex: () => string;
10
+ isDark: () => boolean;
11
+ luminance: () => number;
12
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
13
+ red: number;
14
+ green: number;
15
+ blue: number;
16
+ alpha: number;
17
+ }, Omit</*elided*/ any, "type">>;
18
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
19
+ red: number;
20
+ green: number;
21
+ blue: number;
22
+ alpha: number;
23
+ }, Omit</*elided*/ any, "type">>;
24
+ inter: (other: RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
25
+ red: number;
26
+ green: number;
27
+ blue: number;
28
+ alpha: number;
29
+ }, Omit</*elided*/ any, "type">>;
30
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
31
+ red: number;
32
+ green: number;
33
+ blue: number;
34
+ alpha: number;
35
+ }, Omit</*elided*/ any, "type">>;
36
+ hasWCAGContrast: (color: RGBAColor) => boolean;
37
+ contrastRatio: (color: RGBAColor) => number;
38
+ }, "type">>;
39
+ new: (data: {
40
+ red: number;
41
+ green: number;
42
+ blue: number;
43
+ alpha: number;
44
+ }) => import("./_colordef").ElbeColor<"rgba", {
45
+ red: number;
46
+ green: number;
47
+ blue: number;
48
+ alpha: number;
49
+ }, Omit<{
50
+ asCss: () => string;
51
+ hex: () => string;
52
+ isDark: () => boolean;
53
+ luminance: () => number;
54
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
55
+ red: number;
56
+ green: number;
57
+ blue: number;
58
+ alpha: number;
59
+ }, Omit</*elided*/ any, "type">>;
60
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
61
+ red: number;
62
+ green: number;
63
+ blue: number;
64
+ alpha: number;
65
+ }, Omit</*elided*/ any, "type">>;
66
+ inter: (other: RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
67
+ red: number;
68
+ green: number;
69
+ blue: number;
70
+ alpha: number;
71
+ }, Omit</*elided*/ any, "type">>;
72
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
73
+ red: number;
74
+ green: number;
75
+ blue: number;
76
+ alpha: number;
77
+ }, Omit</*elided*/ any, "type">>;
78
+ hasWCAGContrast: (color: RGBAColor) => boolean;
79
+ contrastRatio: (color: RGBAColor) => number;
80
+ }, "type">>;
81
+ _typeHint: {
82
+ color: import("./_colordef").ElbeColor<"rgba", {
83
+ red: number;
84
+ green: number;
85
+ blue: number;
86
+ alpha: number;
87
+ }, Omit<{
88
+ asCss: () => string;
89
+ hex: () => string;
90
+ isDark: () => boolean;
91
+ luminance: () => number;
92
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
93
+ red: number;
94
+ green: number;
95
+ blue: number;
96
+ alpha: number;
97
+ }, Omit</*elided*/ any, "type">>;
98
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
99
+ red: number;
100
+ green: number;
101
+ blue: number;
102
+ alpha: number;
103
+ }, Omit</*elided*/ any, "type">>;
104
+ inter: (other: RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
105
+ red: number;
106
+ green: number;
107
+ blue: number;
108
+ alpha: number;
109
+ }, Omit</*elided*/ any, "type">>;
110
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
111
+ red: number;
112
+ green: number;
113
+ blue: number;
114
+ alpha: number;
115
+ }, Omit</*elided*/ any, "type">>;
116
+ hasWCAGContrast: (color: RGBAColor) => boolean;
117
+ contrastRatio: (color: RGBAColor) => number;
118
+ }, "type">>;
119
+ data: {
120
+ red: number;
121
+ green: number;
122
+ blue: number;
123
+ alpha: number;
124
+ };
125
+ };
126
+ } & {
127
+ rgba: (red: number, green: number, blue: number, alpha: number) => RGBAColor;
128
+ fromHex: (hex: string) => import("./_colordef").ElbeColor<"rgba", {
129
+ red: number;
130
+ green: number;
131
+ blue: number;
132
+ alpha: number;
133
+ }, Omit<{
134
+ asCss: () => string;
135
+ hex: () => string;
136
+ isDark: () => boolean;
137
+ luminance: () => number;
138
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
139
+ red: number;
140
+ green: number;
141
+ blue: number;
142
+ alpha: number;
143
+ }, Omit</*elided*/ any, "type">>;
144
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
145
+ red: number;
146
+ green: number;
147
+ blue: number;
148
+ alpha: number;
149
+ }, Omit</*elided*/ any, "type">>;
150
+ inter: (other: RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
151
+ red: number;
152
+ green: number;
153
+ blue: number;
154
+ alpha: number;
155
+ }, Omit</*elided*/ any, "type">>;
156
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
157
+ red: number;
158
+ green: number;
159
+ blue: number;
160
+ alpha: number;
161
+ }, Omit</*elided*/ any, "type">>;
162
+ hasWCAGContrast: (color: RGBAColor) => boolean;
163
+ contrastRatio: (color: RGBAColor) => number;
164
+ }, "type">>;
165
+ };
166
+ export type RGBAColor = (typeof RGBAColor)["_typeHint"]["color"];
@@ -0,0 +1,86 @@
1
+ import { hslToRgb, rgbToHsl } from "colors-convert";
2
+ import { clamp } from "../../../../..";
3
+ import { defineColor } from "./_colordef";
4
+ export const RGBAColor = defineColor({
5
+ type: "rgba",
6
+ static: {
7
+ rgba: (red, green, blue, alpha) => {
8
+ return RGBAColor.new({
9
+ red,
10
+ green,
11
+ blue,
12
+ alpha,
13
+ });
14
+ },
15
+ fromHex: (hex) => {
16
+ if (hex.startsWith("#") === false) {
17
+ throw new Error("Invalid hex color");
18
+ }
19
+ let r = 0, g = 0, b = 0, a = 1;
20
+ if (hex.length === 4) {
21
+ r = parseInt(hex[1] + hex[1], 16);
22
+ g = parseInt(hex[2] + hex[2], 16);
23
+ b = parseInt(hex[3] + hex[3], 16);
24
+ }
25
+ else {
26
+ r = parseInt(hex[1] + hex[2], 16);
27
+ g = parseInt(hex[3] + hex[4], 16);
28
+ b = parseInt(hex[5] + hex[6], 16);
29
+ }
30
+ return RGBAColor.rgba(r, g, b, a);
31
+ },
32
+ },
33
+ parent: (_) => ({}),
34
+ compute: (value) => {
35
+ function luminance() {
36
+ const [lr, lg, lb] = [value.red, value.green, value.blue].map((v) => {
37
+ v /= 255;
38
+ return v <= 0.03928 ? v / 12.92 : Math.pow((v + 0.055) / 1.055, 2.4);
39
+ });
40
+ return lr * 0.2126 + lg * 0.7152 + lb * 0.0722;
41
+ }
42
+ function desaturated(f = 1) {
43
+ const avg = (value.red + value.green + value.blue) / 3;
44
+ return RGBAColor.rgba(value.red + (avg - value.red) * f, value.green + (avg - value.green) * f, value.blue + (avg - value.blue) * f, value.alpha);
45
+ }
46
+ function withAlpha(alpha) {
47
+ return RGBAColor.new(Object.assign(Object.assign({}, value), { alpha }));
48
+ }
49
+ function inter(other, factor) {
50
+ return RGBAColor.rgba(value.red + (other.red - value.red) * factor, value.green + (other.green - value.green) * factor, value.blue + (other.blue - value.blue) * factor, value.alpha + (other.alpha - value.alpha) * factor);
51
+ }
52
+ function mirrorBrightness(factor = 1) {
53
+ const hsl = rgbToHsl({ r: value.red, g: value.green, b: value.blue });
54
+ const newL = (50 - hsl.l) * (factor * 2 - 1) + 50;
55
+ const rgb = hslToRgb(Object.assign(Object.assign({}, hsl), { l: clamp(newL, 0, 100), s: clamp(hsl.s, 0, 100) }));
56
+ return RGBAColor.rgba(rgb.r, rgb.g, rgb.b, value.alpha);
57
+ }
58
+ function hasWCAGContrast(color) {
59
+ return contrastRatio(color) >= 3;
60
+ }
61
+ function contrastRatio(color) {
62
+ const l1 = luminance();
63
+ const l2 = color.luminance();
64
+ return (Math.max(l1, l2) + 0.05) / (Math.min(l1, l2) + 0.05);
65
+ }
66
+ function hex() {
67
+ const c = [value.red, value.green, value.blue].map((v) => Math.round(v).toString(16).padStart(2, "0"));
68
+ const aHex = Math.round(value.alpha * 255)
69
+ .toString(16)
70
+ .padStart(2, "0");
71
+ return `#${c.join("")}${aHex}`;
72
+ }
73
+ return {
74
+ asCss: () => `rgba(${value.red}, ${value.green}, ${value.blue}, ${value.alpha})`,
75
+ hex,
76
+ isDark: () => luminance() < 0.5,
77
+ luminance,
78
+ desaturated,
79
+ withAlpha,
80
+ inter,
81
+ mirrorBrightness,
82
+ hasWCAGContrast,
83
+ contrastRatio,
84
+ };
85
+ },
86
+ });