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,83 @@
1
+ import { _seed } from "./_seed";
2
+ import { ContrastColor } from "./colors/_color_contrast";
3
+ import { LayerColor } from "./colors/_color_layer";
4
+ const _data = {
5
+ values: {
6
+ root: {
7
+ base: LayerColor.fromBack("#ffffff"),
8
+ accent: LayerColor.fromBack("#0077ffff"),
9
+ info: LayerColor.fromBack("#0000FF"),
10
+ success: LayerColor.fromBack("#00ff00"),
11
+ warning: LayerColor.fromBack("#ffa600ff"),
12
+ error: LayerColor.fromBack("#ff0000"),
13
+ },
14
+ hirarchy: ContrastColor.generate([], _seed),
15
+ },
16
+ selection: {
17
+ contrast: "normal",
18
+ mode: "dark",
19
+ scheme: "primary",
20
+ kind: "accent",
21
+ manner: "plain",
22
+ state: "neutral",
23
+ },
24
+ };
25
+ const _current = (t) => {
26
+ function parseColor(sc) {
27
+ var _a, _b, _c, _d, _e, _f, _g;
28
+ //if (isLayerColor(sc)) return sc;
29
+ if (!((_a = t.values) === null || _a === void 0 ? void 0 : _a.hirarchy)) {
30
+ throw new Error("ColorTheme: No hirarchy defined");
31
+ }
32
+ const mode = t.values.hirarchy[(_b = sc === null || sc === void 0 ? void 0 : sc.contrast) !== null && _b !== void 0 ? _b : "normal"];
33
+ const scheme = mode[(_c = sc === null || sc === void 0 ? void 0 : sc.mode) !== null && _c !== void 0 ? _c : "light"];
34
+ const kind = scheme[(_d = sc === null || sc === void 0 ? void 0 : sc.scheme) !== null && _d !== void 0 ? _d : "primary"];
35
+ const manner = kind[(_e = sc === null || sc === void 0 ? void 0 : sc.kind) !== null && _e !== void 0 ? _e : "accent"];
36
+ const state = manner[(_f = sc === null || sc === void 0 ? void 0 : sc.manner) !== null && _f !== void 0 ? _f : "flat"];
37
+ let color = state[(_g = sc === null || sc === void 0 ? void 0 : sc.state) !== null && _g !== void 0 ? _g : "neutral"];
38
+ if (!color || !LayerColor.is(manner)) {
39
+ color = manner["flat"]["neutral"];
40
+ }
41
+ if (!color || !LayerColor.is(color)) {
42
+ return LayerColor.fromBack("#ff00ff");
43
+ }
44
+ return color;
45
+ }
46
+ return Object.assign(Object.assign({}, t), { currentColor: parseColor(t.selection),
47
+ /** shorthand for color.selection.contrast == "highvis" */
48
+ isContrast: t.selection.contrast == "highvis",
49
+ /** shorthand for color.selection.mode == "dark" */
50
+ isDark: t.selection.mode == "dark" });
51
+ };
52
+ export const colorThemeData = {
53
+ seed: _seed,
54
+ _configType: _data,
55
+ compute: _current,
56
+ asCss: (c) => ({ color: c.currentColor.front.asCss() }),
57
+ asCssContext: (c) => {
58
+ var _a, _b;
59
+ return ({
60
+ front: c.currentColor.front.asCss(),
61
+ back: c.currentColor.back.asCss(),
62
+ border: (_b = (_a = c.currentColor.border) === null || _a === void 0 ? void 0 : _a.asCss()) !== null && _b !== void 0 ? _b : "transparent",
63
+ outline: c.values.root.accent.back.asCss(),
64
+ });
65
+ },
66
+ fromSeed: (seed) => {
67
+ var _a;
68
+ return {
69
+ values: {
70
+ root: {
71
+ base: LayerColor.fromBack(seed.base),
72
+ accent: LayerColor.fromBack(seed.accent),
73
+ info: LayerColor.fromBack(seed.info),
74
+ success: LayerColor.fromBack(seed.success),
75
+ warning: LayerColor.fromBack(seed.warning),
76
+ error: LayerColor.fromBack(seed.error),
77
+ },
78
+ hirarchy: ContrastColor.generate([], seed),
79
+ },
80
+ selection: (_a = seed.selection) !== null && _a !== void 0 ? _a : _data.selection,
81
+ };
82
+ },
83
+ };
@@ -0,0 +1,284 @@
1
+ import { LayerColor } from "./_color_layer";
2
+ import { ModeColor } from "./_color_mode";
3
+ import { ColorThemeSeed } from "./colors";
4
+ export declare const ContrastColor: {
5
+ is: (v: any) => v is import("./_colordef").ElbeColor<"contrast", {
6
+ normal: ModeColor;
7
+ highvis: ModeColor;
8
+ }, Omit<{
9
+ type: ["mode", ...string[]];
10
+ } & {
11
+ light: import("./_color_scheme").SchemeColor;
12
+ dark: import("./_color_scheme").SchemeColor;
13
+ } & Omit<{
14
+ type: ["state", ...string[]];
15
+ } & {
16
+ primary: import("./_color_kind").KindColor;
17
+ secondary: import("./_color_kind").KindColor;
18
+ inverse: import("./_color_kind").KindColor;
19
+ } & Omit<{
20
+ type: ["kind", ...string[]];
21
+ } & {
22
+ accent: import("./_color_manner").MannerColor;
23
+ info: import("./_color_manner").MannerColor;
24
+ success: import("./_color_manner").MannerColor;
25
+ warning: import("./_color_manner").MannerColor;
26
+ error: import("./_color_manner").MannerColor;
27
+ } & Omit<{
28
+ type: ["manner", ...string[]];
29
+ } & {
30
+ major: import("./_color_state").StateColor;
31
+ minor: import("./_color_state").StateColor;
32
+ flat: import("./_color_state").StateColor;
33
+ plain: import("./_color_state").StateColor;
34
+ } & Omit<{
35
+ type: ["state", ...string[]];
36
+ } & {
37
+ neutral: LayerColor;
38
+ hover: LayerColor;
39
+ active: LayerColor;
40
+ disabled: LayerColor;
41
+ } & Omit<{
42
+ type: ["layer", ...string[]];
43
+ } & {
44
+ back: import("./_color_rgba").RGBAColor;
45
+ front: import("./_color_rgba").RGBAColor;
46
+ border: import("./_color_rgba").RGBAColor;
47
+ } & Omit<{
48
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
49
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
50
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
51
+ desaturatedLayer: () => LayerColor;
52
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
53
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
54
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
55
+ } & {
56
+ type: ["rgba", ...string[]];
57
+ } & {
58
+ red: number;
59
+ green: number;
60
+ blue: number;
61
+ alpha: number;
62
+ } & Omit<{
63
+ asCss: () => string;
64
+ hex: () => string;
65
+ isDark: () => boolean;
66
+ luminance: () => number;
67
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
68
+ red: number;
69
+ green: number;
70
+ blue: number;
71
+ alpha: number;
72
+ }, Omit</*elided*/ any, "type">>;
73
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
74
+ red: number;
75
+ green: number;
76
+ blue: number;
77
+ alpha: number;
78
+ }, Omit</*elided*/ any, "type">>;
79
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
80
+ red: number;
81
+ green: number;
82
+ blue: number;
83
+ alpha: number;
84
+ }, Omit</*elided*/ any, "type">>;
85
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
86
+ red: number;
87
+ green: number;
88
+ blue: number;
89
+ alpha: number;
90
+ }, Omit</*elided*/ any, "type">>;
91
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
92
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
93
+ }, "type">, "type">, "type">, "type">, "type">, "type">, "type">, "type">>;
94
+ new: (data: {
95
+ normal: ModeColor;
96
+ highvis: ModeColor;
97
+ }) => import("./_colordef").ElbeColor<"contrast", {
98
+ normal: ModeColor;
99
+ highvis: ModeColor;
100
+ }, Omit<{
101
+ type: ["mode", ...string[]];
102
+ } & {
103
+ light: import("./_color_scheme").SchemeColor;
104
+ dark: import("./_color_scheme").SchemeColor;
105
+ } & Omit<{
106
+ type: ["state", ...string[]];
107
+ } & {
108
+ primary: import("./_color_kind").KindColor;
109
+ secondary: import("./_color_kind").KindColor;
110
+ inverse: import("./_color_kind").KindColor;
111
+ } & Omit<{
112
+ type: ["kind", ...string[]];
113
+ } & {
114
+ accent: import("./_color_manner").MannerColor;
115
+ info: import("./_color_manner").MannerColor;
116
+ success: import("./_color_manner").MannerColor;
117
+ warning: import("./_color_manner").MannerColor;
118
+ error: import("./_color_manner").MannerColor;
119
+ } & Omit<{
120
+ type: ["manner", ...string[]];
121
+ } & {
122
+ major: import("./_color_state").StateColor;
123
+ minor: import("./_color_state").StateColor;
124
+ flat: import("./_color_state").StateColor;
125
+ plain: import("./_color_state").StateColor;
126
+ } & Omit<{
127
+ type: ["state", ...string[]];
128
+ } & {
129
+ neutral: LayerColor;
130
+ hover: LayerColor;
131
+ active: LayerColor;
132
+ disabled: LayerColor;
133
+ } & Omit<{
134
+ type: ["layer", ...string[]];
135
+ } & {
136
+ back: import("./_color_rgba").RGBAColor;
137
+ front: import("./_color_rgba").RGBAColor;
138
+ border: import("./_color_rgba").RGBAColor;
139
+ } & Omit<{
140
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
141
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
142
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
143
+ desaturatedLayer: () => LayerColor;
144
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
145
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
146
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
147
+ } & {
148
+ type: ["rgba", ...string[]];
149
+ } & {
150
+ red: number;
151
+ green: number;
152
+ blue: number;
153
+ alpha: number;
154
+ } & Omit<{
155
+ asCss: () => string;
156
+ hex: () => string;
157
+ isDark: () => boolean;
158
+ luminance: () => number;
159
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
160
+ red: number;
161
+ green: number;
162
+ blue: number;
163
+ alpha: number;
164
+ }, Omit</*elided*/ any, "type">>;
165
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
166
+ red: number;
167
+ green: number;
168
+ blue: number;
169
+ alpha: number;
170
+ }, Omit</*elided*/ any, "type">>;
171
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
172
+ red: number;
173
+ green: number;
174
+ blue: number;
175
+ alpha: number;
176
+ }, Omit</*elided*/ any, "type">>;
177
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
178
+ red: number;
179
+ green: number;
180
+ blue: number;
181
+ alpha: number;
182
+ }, Omit</*elided*/ any, "type">>;
183
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
184
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
185
+ }, "type">, "type">, "type">, "type">, "type">, "type">, "type">, "type">>;
186
+ _typeHint: {
187
+ color: import("./_colordef").ElbeColor<"contrast", {
188
+ normal: ModeColor;
189
+ highvis: ModeColor;
190
+ }, Omit<{
191
+ type: ["mode", ...string[]];
192
+ } & {
193
+ light: import("./_color_scheme").SchemeColor;
194
+ dark: import("./_color_scheme").SchemeColor;
195
+ } & Omit<{
196
+ type: ["state", ...string[]];
197
+ } & {
198
+ primary: import("./_color_kind").KindColor;
199
+ secondary: import("./_color_kind").KindColor;
200
+ inverse: import("./_color_kind").KindColor;
201
+ } & Omit<{
202
+ type: ["kind", ...string[]];
203
+ } & {
204
+ accent: import("./_color_manner").MannerColor;
205
+ info: import("./_color_manner").MannerColor;
206
+ success: import("./_color_manner").MannerColor;
207
+ warning: import("./_color_manner").MannerColor;
208
+ error: import("./_color_manner").MannerColor;
209
+ } & Omit<{
210
+ type: ["manner", ...string[]];
211
+ } & {
212
+ major: import("./_color_state").StateColor;
213
+ minor: import("./_color_state").StateColor;
214
+ flat: import("./_color_state").StateColor;
215
+ plain: import("./_color_state").StateColor;
216
+ } & Omit<{
217
+ type: ["state", ...string[]];
218
+ } & {
219
+ neutral: LayerColor;
220
+ hover: LayerColor;
221
+ active: LayerColor;
222
+ disabled: LayerColor;
223
+ } & Omit<{
224
+ type: ["layer", ...string[]];
225
+ } & {
226
+ back: import("./_color_rgba").RGBAColor;
227
+ front: import("./_color_rgba").RGBAColor;
228
+ border: import("./_color_rgba").RGBAColor;
229
+ } & Omit<{
230
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
231
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
232
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
233
+ desaturatedLayer: () => LayerColor;
234
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
235
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
236
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
237
+ } & {
238
+ type: ["rgba", ...string[]];
239
+ } & {
240
+ red: number;
241
+ green: number;
242
+ blue: number;
243
+ alpha: number;
244
+ } & Omit<{
245
+ asCss: () => string;
246
+ hex: () => string;
247
+ isDark: () => boolean;
248
+ luminance: () => number;
249
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
250
+ red: number;
251
+ green: number;
252
+ blue: number;
253
+ alpha: number;
254
+ }, Omit</*elided*/ any, "type">>;
255
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
256
+ red: number;
257
+ green: number;
258
+ blue: number;
259
+ alpha: number;
260
+ }, Omit</*elided*/ any, "type">>;
261
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
262
+ red: number;
263
+ green: number;
264
+ blue: number;
265
+ alpha: number;
266
+ }, Omit</*elided*/ any, "type">>;
267
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
268
+ red: number;
269
+ green: number;
270
+ blue: number;
271
+ alpha: number;
272
+ }, Omit</*elided*/ any, "type">>;
273
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
274
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
275
+ }, "type">, "type">, "type">, "type">, "type">, "type">, "type">, "type">>;
276
+ data: {
277
+ normal: ModeColor;
278
+ highvis: ModeColor;
279
+ };
280
+ };
281
+ } & {
282
+ generate(path: string[], seed: ColorThemeSeed): ContrastColor;
283
+ };
284
+ export type ContrastColor = (typeof ContrastColor)["_typeHint"]["color"];
@@ -0,0 +1,17 @@
1
+ import { LayerColor } from "./_color_layer";
2
+ import { ModeColor } from "./_color_mode";
3
+ import { defineColor } from "./_colordef";
4
+ export const ContrastColor = defineColor({
5
+ type: "contrast",
6
+ static: {
7
+ generate(path, seed) {
8
+ const p = { path, base: LayerColor.asLayer(seed.base), seed };
9
+ return ContrastColor.new({
10
+ normal: ModeColor.generate(path, seed.contrast.normal(p)),
11
+ highvis: ModeColor.generate([...path, "highvis"], seed.contrast.highvis(p)),
12
+ });
13
+ },
14
+ },
15
+ parent: (data) => data.normal,
16
+ compute: (_) => ({}),
17
+ });
@@ -0,0 +1,242 @@
1
+ import { LayerColor } from "./_color_layer";
2
+ import { MannerColor } from "./_color_manner";
3
+ import { ColorThemeSeed } from "./colors";
4
+ export declare const KindColor: {
5
+ is: (v: any) => v is import("./_colordef").ElbeColor<"kind", {
6
+ accent: MannerColor;
7
+ info: MannerColor;
8
+ success: MannerColor;
9
+ warning: MannerColor;
10
+ error: MannerColor;
11
+ }, Omit<{
12
+ type: ["manner", ...string[]];
13
+ } & {
14
+ major: import("./_color_state").StateColor;
15
+ minor: import("./_color_state").StateColor;
16
+ flat: import("./_color_state").StateColor;
17
+ plain: import("./_color_state").StateColor;
18
+ } & Omit<{
19
+ type: ["state", ...string[]];
20
+ } & {
21
+ neutral: LayerColor;
22
+ hover: LayerColor;
23
+ active: LayerColor;
24
+ disabled: LayerColor;
25
+ } & Omit<{
26
+ type: ["layer", ...string[]];
27
+ } & {
28
+ back: import("./_color_rgba").RGBAColor;
29
+ front: import("./_color_rgba").RGBAColor;
30
+ border: import("./_color_rgba").RGBAColor;
31
+ } & Omit<{
32
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
33
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
34
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
35
+ desaturatedLayer: () => LayerColor;
36
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
37
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
38
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
39
+ } & {
40
+ type: ["rgba", ...string[]];
41
+ } & {
42
+ red: number;
43
+ green: number;
44
+ blue: number;
45
+ alpha: number;
46
+ } & Omit<{
47
+ asCss: () => string;
48
+ hex: () => string;
49
+ isDark: () => boolean;
50
+ luminance: () => number;
51
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
52
+ red: number;
53
+ green: number;
54
+ blue: number;
55
+ alpha: number;
56
+ }, Omit</*elided*/ any, "type">>;
57
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
58
+ red: number;
59
+ green: number;
60
+ blue: number;
61
+ alpha: number;
62
+ }, Omit</*elided*/ any, "type">>;
63
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
64
+ red: number;
65
+ green: number;
66
+ blue: number;
67
+ alpha: number;
68
+ }, Omit</*elided*/ any, "type">>;
69
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
70
+ red: number;
71
+ green: number;
72
+ blue: number;
73
+ alpha: number;
74
+ }, Omit</*elided*/ any, "type">>;
75
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
76
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
77
+ }, "type">, "type">, "type">, "type">, "type">>;
78
+ new: (data: {
79
+ accent: MannerColor;
80
+ info: MannerColor;
81
+ success: MannerColor;
82
+ warning: MannerColor;
83
+ error: MannerColor;
84
+ }) => import("./_colordef").ElbeColor<"kind", {
85
+ accent: MannerColor;
86
+ info: MannerColor;
87
+ success: MannerColor;
88
+ warning: MannerColor;
89
+ error: MannerColor;
90
+ }, Omit<{
91
+ type: ["manner", ...string[]];
92
+ } & {
93
+ major: import("./_color_state").StateColor;
94
+ minor: import("./_color_state").StateColor;
95
+ flat: import("./_color_state").StateColor;
96
+ plain: import("./_color_state").StateColor;
97
+ } & Omit<{
98
+ type: ["state", ...string[]];
99
+ } & {
100
+ neutral: LayerColor;
101
+ hover: LayerColor;
102
+ active: LayerColor;
103
+ disabled: LayerColor;
104
+ } & Omit<{
105
+ type: ["layer", ...string[]];
106
+ } & {
107
+ back: import("./_color_rgba").RGBAColor;
108
+ front: import("./_color_rgba").RGBAColor;
109
+ border: import("./_color_rgba").RGBAColor;
110
+ } & Omit<{
111
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
112
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
113
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
114
+ desaturatedLayer: () => LayerColor;
115
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
116
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
117
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
118
+ } & {
119
+ type: ["rgba", ...string[]];
120
+ } & {
121
+ red: number;
122
+ green: number;
123
+ blue: number;
124
+ alpha: number;
125
+ } & Omit<{
126
+ asCss: () => string;
127
+ hex: () => string;
128
+ isDark: () => boolean;
129
+ luminance: () => number;
130
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
131
+ red: number;
132
+ green: number;
133
+ blue: number;
134
+ alpha: number;
135
+ }, Omit</*elided*/ any, "type">>;
136
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
137
+ red: number;
138
+ green: number;
139
+ blue: number;
140
+ alpha: number;
141
+ }, Omit</*elided*/ any, "type">>;
142
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
143
+ red: number;
144
+ green: number;
145
+ blue: number;
146
+ alpha: number;
147
+ }, Omit</*elided*/ any, "type">>;
148
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
149
+ red: number;
150
+ green: number;
151
+ blue: number;
152
+ alpha: number;
153
+ }, Omit</*elided*/ any, "type">>;
154
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
155
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
156
+ }, "type">, "type">, "type">, "type">, "type">>;
157
+ _typeHint: {
158
+ color: import("./_colordef").ElbeColor<"kind", {
159
+ accent: MannerColor;
160
+ info: MannerColor;
161
+ success: MannerColor;
162
+ warning: MannerColor;
163
+ error: MannerColor;
164
+ }, Omit<{
165
+ type: ["manner", ...string[]];
166
+ } & {
167
+ major: import("./_color_state").StateColor;
168
+ minor: import("./_color_state").StateColor;
169
+ flat: import("./_color_state").StateColor;
170
+ plain: import("./_color_state").StateColor;
171
+ } & Omit<{
172
+ type: ["state", ...string[]];
173
+ } & {
174
+ neutral: LayerColor;
175
+ hover: LayerColor;
176
+ active: LayerColor;
177
+ disabled: LayerColor;
178
+ } & Omit<{
179
+ type: ["layer", ...string[]];
180
+ } & {
181
+ back: import("./_color_rgba").RGBAColor;
182
+ front: import("./_color_rgba").RGBAColor;
183
+ border: import("./_color_rgba").RGBAColor;
184
+ } & Omit<{
185
+ interLayer: (other: import("./_color_rgba").RGBAColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
186
+ interLayerLayer: (other: LayerColor, factor: number, factorFront?: number, factorBorder?: number) => LayerColor;
187
+ mirrorBrightnessLayer: (factor?: number, factorBack?: number, factorBorder?: number) => LayerColor;
188
+ desaturatedLayer: () => LayerColor;
189
+ withBack: (back: import("./_color_rgba").RGBAColor) => LayerColor;
190
+ withFront: (front: import("./_color_rgba").RGBAColor) => LayerColor;
191
+ withBorder: (border: import("./_color_rgba").RGBAColor) => LayerColor;
192
+ } & {
193
+ type: ["rgba", ...string[]];
194
+ } & {
195
+ red: number;
196
+ green: number;
197
+ blue: number;
198
+ alpha: number;
199
+ } & Omit<{
200
+ asCss: () => string;
201
+ hex: () => string;
202
+ isDark: () => boolean;
203
+ luminance: () => number;
204
+ desaturated: (f?: number) => import("./_colordef").ElbeColor<"rgba", {
205
+ red: number;
206
+ green: number;
207
+ blue: number;
208
+ alpha: number;
209
+ }, Omit</*elided*/ any, "type">>;
210
+ withAlpha: (alpha: number) => import("./_colordef").ElbeColor<"rgba", {
211
+ red: number;
212
+ green: number;
213
+ blue: number;
214
+ alpha: number;
215
+ }, Omit</*elided*/ any, "type">>;
216
+ inter: (other: import("./_color_rgba").RGBAColor, factor: number) => import("./_colordef").ElbeColor<"rgba", {
217
+ red: number;
218
+ green: number;
219
+ blue: number;
220
+ alpha: number;
221
+ }, Omit</*elided*/ any, "type">>;
222
+ mirrorBrightness: (factor?: number) => import("./_colordef").ElbeColor<"rgba", {
223
+ red: number;
224
+ green: number;
225
+ blue: number;
226
+ alpha: number;
227
+ }, Omit</*elided*/ any, "type">>;
228
+ hasWCAGContrast: (color: import("./_color_rgba").RGBAColor) => boolean;
229
+ contrastRatio: (color: import("./_color_rgba").RGBAColor) => number;
230
+ }, "type">, "type">, "type">, "type">, "type">>;
231
+ data: {
232
+ accent: MannerColor;
233
+ info: MannerColor;
234
+ success: MannerColor;
235
+ warning: MannerColor;
236
+ error: MannerColor;
237
+ };
238
+ };
239
+ } & {
240
+ generate(path: string[], seed: ColorThemeSeed, base: LayerColor): KindColor;
241
+ };
242
+ export type KindColor = (typeof KindColor)["_typeHint"]["color"];
@@ -0,0 +1,45 @@
1
+ import { LayerColor } from "./_color_layer";
2
+ import { MannerColor } from "./_color_manner";
3
+ import { defineColor } from "./_colordef";
4
+ export const KindColor = defineColor({
5
+ type: "kind",
6
+ static: {
7
+ generate(path, seed, base) {
8
+ return KindColor.new({
9
+ //plain: MannerColor.generate([...path, "plain"], seed, base),
10
+ accent: MannerColor.generate([...path, "accent"], seed, base, seed.kind.accent({
11
+ path,
12
+ seed,
13
+ base,
14
+ style: LayerColor.asLayer(seed.accent),
15
+ })),
16
+ info: MannerColor.generate([...path, "info"], seed, base, seed.kind.info({
17
+ path,
18
+ seed,
19
+ base,
20
+ style: LayerColor.asLayer(seed.info),
21
+ })),
22
+ success: MannerColor.generate([...path, "success"], seed, base, seed.kind.success({
23
+ path,
24
+ seed,
25
+ base,
26
+ style: LayerColor.asLayer(seed.success),
27
+ })),
28
+ warning: MannerColor.generate([...path, "warning"], seed, base, seed.kind.warning({
29
+ path,
30
+ seed,
31
+ base,
32
+ style: LayerColor.asLayer(seed.warning),
33
+ })),
34
+ error: MannerColor.generate([...path, "error"], seed, base, seed.kind.error({
35
+ path,
36
+ seed,
37
+ base,
38
+ style: LayerColor.asLayer(seed.error),
39
+ })),
40
+ });
41
+ },
42
+ },
43
+ parent: (data) => data.accent,
44
+ compute: (_) => ({}),
45
+ });