@tolle_/tolle-ui 18.2.6 → 18.2.7
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.
- package/esm2022/lib/theme.service.mjs +95 -119
- package/fesm2022/tolle-ui.mjs +93 -117
- package/fesm2022/tolle-ui.mjs.map +1 -1
- package/lib/button.component.d.ts +2 -2
- package/lib/theme.service.d.ts +4 -38
- package/lib/toggle.component.d.ts +1 -1
- package/package.json +1 -1
- package/theme.css +33 -0
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { Injectable, Inject, PLATFORM_ID, Optional } from '@angular/core';
|
|
2
2
|
import { DOCUMENT, isPlatformBrowser } from '@angular/common';
|
|
3
|
-
import { BehaviorSubject } from 'rxjs';
|
|
4
3
|
import { TOLLE_CONFIG } from './tolle-config';
|
|
4
|
+
import { BehaviorSubject } from 'rxjs';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class ThemeService {
|
|
7
7
|
document;
|
|
8
8
|
platformId;
|
|
9
9
|
config;
|
|
10
10
|
renderer;
|
|
11
|
-
|
|
12
|
-
isDark$ = this.
|
|
11
|
+
_isDark = new BehaviorSubject(false);
|
|
12
|
+
isDark$ = this._isDark.asObservable();
|
|
13
13
|
styleId = 'tolle-dynamic-theme';
|
|
14
14
|
constructor(document, platformId, config, rendererFactory) {
|
|
15
15
|
this.document = document;
|
|
@@ -26,130 +26,143 @@ export class ThemeService {
|
|
|
26
26
|
const savedPrimary = localStorage.getItem('tolle-primary-color');
|
|
27
27
|
const savedRadius = localStorage.getItem('tolle-radius');
|
|
28
28
|
const systemPrefersDark = window.matchMedia('(prefers-color-scheme: dark)').matches;
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
savedPrimary,
|
|
32
|
-
savedRadius,
|
|
33
|
-
config: this.config,
|
|
34
|
-
systemPrefersDark
|
|
35
|
-
});
|
|
36
|
-
// 1. Determine Dark/Light Mode
|
|
37
|
-
// Priority: Saved Theme > Config Default > System Preference
|
|
38
|
-
let shouldBeDark = systemPrefersDark; // Start with system
|
|
29
|
+
// Determine Dark/Light Mode
|
|
30
|
+
let shouldBeDark = systemPrefersDark;
|
|
39
31
|
if (savedTheme) {
|
|
40
|
-
// User has saved preference
|
|
41
32
|
shouldBeDark = savedTheme === 'dark';
|
|
42
33
|
}
|
|
43
34
|
else if (this.config?.darkByDefault !== undefined) {
|
|
44
|
-
// Use config default if no user preference
|
|
45
35
|
shouldBeDark = this.config.darkByDefault;
|
|
46
36
|
}
|
|
47
37
|
// Apply theme mode
|
|
48
38
|
if (shouldBeDark) {
|
|
49
|
-
this.enableDarkMode(false);
|
|
39
|
+
this.enableDarkMode(false);
|
|
50
40
|
}
|
|
51
41
|
else {
|
|
52
42
|
this.disableDarkMode(false);
|
|
53
43
|
}
|
|
54
|
-
//
|
|
55
|
-
// Priority: Saved Color > Config Color
|
|
44
|
+
// Apply Primary Color
|
|
56
45
|
if (savedPrimary) {
|
|
57
|
-
|
|
58
|
-
this.setPrimaryColor(savedPrimary, false); // Don't save again
|
|
46
|
+
this.setPrimaryColor(savedPrimary, false);
|
|
59
47
|
}
|
|
60
48
|
else if (this.config?.primaryColor) {
|
|
61
|
-
|
|
62
|
-
this.setPrimaryColor(this.config.primaryColor, false); // Save this as user preference
|
|
49
|
+
this.setPrimaryColor(this.config.primaryColor, false);
|
|
63
50
|
}
|
|
64
|
-
//
|
|
65
|
-
// Priority: Saved Radius > Config Radius
|
|
51
|
+
// Apply Radius
|
|
66
52
|
if (savedRadius) {
|
|
67
|
-
// User has saved radius preference
|
|
68
53
|
this.setRadius(savedRadius, false);
|
|
69
54
|
}
|
|
70
55
|
else if (this.config?.radius) {
|
|
71
|
-
// Use config default if no user preference
|
|
72
56
|
this.setRadius(this.config.radius, false);
|
|
73
57
|
}
|
|
74
|
-
// Save theme mode preference if it came from config or system
|
|
75
58
|
if (!savedTheme) {
|
|
76
59
|
localStorage.setItem('tolle-theme', shouldBeDark ? 'dark' : 'light');
|
|
77
60
|
}
|
|
78
61
|
}
|
|
79
|
-
/**
|
|
80
|
-
* Sets the border radius for all components
|
|
81
|
-
*/
|
|
82
62
|
setRadius(radius, persist = true) {
|
|
83
63
|
if (!isPlatformBrowser(this.platformId))
|
|
84
64
|
return;
|
|
85
65
|
const root = this.document.documentElement;
|
|
86
|
-
// Set the CSS variable
|
|
87
66
|
this.renderer.setStyle(root, '--radius', radius);
|
|
88
|
-
// Also update the dynamic styles to include radius calculations
|
|
89
67
|
this.updateRadiusInDynamicStyles(radius);
|
|
90
|
-
|
|
68
|
+
this.updateAllRadiusVariables(radius);
|
|
91
69
|
if (persist) {
|
|
92
70
|
localStorage.setItem('tolle-radius', radius);
|
|
93
71
|
}
|
|
94
72
|
}
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
73
|
+
updateAllRadiusVariables(baseRadius) {
|
|
74
|
+
const root = this.document.documentElement;
|
|
75
|
+
// Parse the radius to extract numeric value and unit
|
|
76
|
+
const radiusMatch = baseRadius.match(/^(\d*\.?\d+)([a-z]+|%)$/);
|
|
77
|
+
if (!radiusMatch) {
|
|
78
|
+
console.warn(`Invalid radius format: ${baseRadius}. Using default values.`);
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
const numericValue = parseFloat(radiusMatch[1]);
|
|
82
|
+
const unit = radiusMatch[2];
|
|
83
|
+
// Set all radius variables according to your CSS classes
|
|
84
|
+
this.renderer.setStyle(root, '--radius-sm', `${numericValue * 0.5}${unit}`);
|
|
85
|
+
this.renderer.setStyle(root, '--radius-md', `${numericValue}${unit}`);
|
|
86
|
+
this.renderer.setStyle(root, '--radius-lg', `${numericValue * 1.5}${unit}`);
|
|
87
|
+
this.renderer.setStyle(root, '--radius-xl', `${numericValue * 2}${unit}`);
|
|
88
|
+
this.renderer.setStyle(root, '--radius-2xl', `${numericValue * 3}${unit}`);
|
|
89
|
+
this.renderer.setStyle(root, '--radius-3xl', `${numericValue * 4}${unit}`);
|
|
90
|
+
this.renderer.setStyle(root, '--radius-full', '9999px');
|
|
91
|
+
}
|
|
98
92
|
updateRadiusInDynamicStyles(radius) {
|
|
99
93
|
const existingStyle = this.document.getElementById(this.styleId);
|
|
100
94
|
if (existingStyle) {
|
|
101
95
|
let css = existingStyle.textContent || '';
|
|
102
|
-
//
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
96
|
+
// Parse the radius to calculate derived values
|
|
97
|
+
const radiusMatch = radius.match(/^(\d*\.?\d+)([a-z]+|%)$/);
|
|
98
|
+
if (radiusMatch) {
|
|
99
|
+
const numericValue = parseFloat(radiusMatch[1]);
|
|
100
|
+
const unit = radiusMatch[2];
|
|
101
|
+
const derivedRadii = {
|
|
102
|
+
'--radius-sm': `${numericValue * 0.5}${unit}`,
|
|
103
|
+
'--radius-md': `${numericValue}${unit}`,
|
|
104
|
+
'--radius-lg': `${numericValue * 1.5}${unit}`,
|
|
105
|
+
'--radius-xl': `${numericValue * 2}${unit}`,
|
|
106
|
+
'--radius-2xl': `${numericValue * 3}${unit}`,
|
|
107
|
+
'--radius-3xl': `${numericValue * 4}${unit}`,
|
|
108
|
+
'--radius-full': '9999px'
|
|
109
|
+
};
|
|
110
|
+
// Update base radius
|
|
111
|
+
if (css.includes('--radius:')) {
|
|
112
|
+
css = css.replace(/--radius:[^;]+;/g, `--radius: ${radius};`);
|
|
116
113
|
}
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
114
|
+
// Update all derived radius variables
|
|
115
|
+
Object.entries(derivedRadii).forEach(([varName, value]) => {
|
|
116
|
+
if (css.includes(varName)) {
|
|
117
|
+
const regex = new RegExp(`${varName}:[^;]+;`, 'g');
|
|
118
|
+
css = css.replace(regex, `${varName}: ${value};`);
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
// Add the variable if it doesn't exist
|
|
122
|
+
css = css.replace(/:root\s*{/, `:root {\n ${varName}: ${value};`);
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
}
|
|
122
126
|
existingStyle.textContent = css;
|
|
123
127
|
}
|
|
124
128
|
}
|
|
125
|
-
/**
|
|
126
|
-
* Generates full primary color palette (50-900) based on base color
|
|
127
|
-
*/
|
|
128
129
|
generatePrimaryShades(baseColor) {
|
|
129
|
-
// Convert hex to RGB
|
|
130
130
|
const rgb = this.hexToRgb(baseColor);
|
|
131
131
|
const rgbString = rgb ? `${rgb.r} ${rgb.g} ${rgb.b}` : '37 99 235';
|
|
132
|
-
// Create lighter ring colors in RGB
|
|
133
132
|
const ringLight = this.lightenColor(baseColor, 40);
|
|
134
133
|
const ringLightRgb = this.hexToRgb(ringLight);
|
|
135
134
|
const ringLightRgbString = ringLightRgb ? `${ringLightRgb.r} ${ringLightRgb.g} ${ringLightRgb.b}` : '96 165 250';
|
|
136
135
|
const ringDark = this.lightenColor(baseColor, 20);
|
|
137
136
|
const ringDarkRgb = this.hexToRgb(ringDark);
|
|
138
137
|
const ringDarkRgbString = ringDarkRgb ? `${ringDarkRgb.r} ${ringDarkRgb.g} ${ringDarkRgb.b}` : '147 197 253';
|
|
139
|
-
// Get current radius or
|
|
138
|
+
// Get current radius or default
|
|
140
139
|
const root = this.document.documentElement;
|
|
141
140
|
const currentRadius = getComputedStyle(root).getPropertyValue('--radius').trim() || '0.5rem';
|
|
141
|
+
// Calculate all derived radius values
|
|
142
|
+
const radiusMatch = currentRadius.match(/^(\d*\.?\d+)([a-z]+|%)$/);
|
|
143
|
+
let radiusVariables = '';
|
|
144
|
+
if (radiusMatch) {
|
|
145
|
+
const numericValue = parseFloat(radiusMatch[1]);
|
|
146
|
+
const unit = radiusMatch[2];
|
|
147
|
+
radiusVariables = `
|
|
148
|
+
--radius: ${currentRadius};
|
|
149
|
+
--radius-sm: ${numericValue * 0.5}${unit};
|
|
150
|
+
--radius-md: ${numericValue}${unit};
|
|
151
|
+
--radius-lg: ${numericValue * 1.5}${unit};
|
|
152
|
+
--radius-xl: ${numericValue * 2}${unit};
|
|
153
|
+
--radius-2xl: ${numericValue * 3}${unit};
|
|
154
|
+
--radius-3xl: ${numericValue * 4}${unit};
|
|
155
|
+
--radius-full: 9999px;
|
|
156
|
+
`;
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
radiusVariables = `--radius: ${currentRadius};`;
|
|
160
|
+
}
|
|
142
161
|
const css = `
|
|
143
|
-
/* Override primary colors - this needs to come AFTER your main CSS */
|
|
144
162
|
:root {
|
|
145
|
-
/* Primary in RGB format for Tailwind opacity support */
|
|
146
163
|
--primary: ${rgbString};
|
|
147
164
|
--primary-foreground: ${this.getContrastColorRgb(baseColor)};
|
|
148
|
-
|
|
149
|
-
/* Radius */
|
|
150
|
-
--radius: ${currentRadius};
|
|
151
|
-
|
|
152
|
-
/* Primary shades for light mode */
|
|
165
|
+
${radiusVariables}
|
|
153
166
|
--primary-50: ${this.hexToRgbString(this.lightenColor(baseColor, 90))};
|
|
154
167
|
--primary-100: ${this.hexToRgbString(this.lightenColor(baseColor, 80))};
|
|
155
168
|
--primary-200: ${this.hexToRgbString(this.lightenColor(baseColor, 60))};
|
|
@@ -160,17 +173,13 @@ export class ThemeService {
|
|
|
160
173
|
--primary-700: ${this.hexToRgbString(this.darkenColor(baseColor, 40))};
|
|
161
174
|
--primary-800: ${this.hexToRgbString(this.darkenColor(baseColor, 60))};
|
|
162
175
|
--primary-900: ${this.hexToRgbString(this.darkenColor(baseColor, 80))};
|
|
163
|
-
|
|
164
|
-
/* Update ring color to be lighter */
|
|
165
176
|
--ring: ${ringLightRgbString};
|
|
166
177
|
}
|
|
167
178
|
|
|
168
179
|
.dark {
|
|
169
|
-
/* For dark mode, we keep the primary color but adjust shades */
|
|
170
180
|
--primary: ${rgbString};
|
|
171
181
|
--primary-foreground: ${this.getContrastColorRgb(baseColor)};
|
|
172
|
-
|
|
173
|
-
/* Dark mode shades */
|
|
182
|
+
${radiusVariables}
|
|
174
183
|
--primary-50: ${this.hexToRgbString(this.darkenColor(baseColor, 85))};
|
|
175
184
|
--primary-100: ${this.hexToRgbString(this.darkenColor(baseColor, 75))};
|
|
176
185
|
--primary-200: ${this.hexToRgbString(this.darkenColor(baseColor, 65))};
|
|
@@ -181,18 +190,12 @@ export class ThemeService {
|
|
|
181
190
|
--primary-700: ${this.hexToRgbString(this.lightenColor(baseColor, 35))};
|
|
182
191
|
--primary-800: ${this.hexToRgbString(this.lightenColor(baseColor, 50))};
|
|
183
192
|
--primary-900: ${this.hexToRgbString(this.lightenColor(baseColor, 65))};
|
|
184
|
-
|
|
185
|
-
/* Update ring color for dark mode - lighter variant */
|
|
186
193
|
--ring: ${ringDarkRgbString};
|
|
187
194
|
}
|
|
188
195
|
`;
|
|
189
196
|
this.injectDynamicStyles(css);
|
|
190
197
|
}
|
|
191
|
-
/**
|
|
192
|
-
* Convert hex color to RGB object
|
|
193
|
-
*/
|
|
194
198
|
hexToRgb(hex) {
|
|
195
|
-
// Remove # if present
|
|
196
199
|
const cleanedHex = hex.replace('#', '');
|
|
197
200
|
let r = 0, g = 0, b = 0;
|
|
198
201
|
if (cleanedHex.length === 3) {
|
|
@@ -209,38 +212,24 @@ export class ThemeService {
|
|
|
209
212
|
}
|
|
210
213
|
return null;
|
|
211
214
|
}
|
|
212
|
-
/**
|
|
213
|
-
* Convert hex to RGB string format for CSS (space-separated)
|
|
214
|
-
*/
|
|
215
215
|
hexToRgbString(hexColor) {
|
|
216
216
|
const rgb = this.hexToRgb(hexColor);
|
|
217
217
|
return rgb ? `${rgb.r} ${rgb.g} ${rgb.b}` : '37 99 235';
|
|
218
218
|
}
|
|
219
|
-
/**
|
|
220
|
-
* Get contrast color in RGB format
|
|
221
|
-
*/
|
|
222
219
|
getContrastColorRgb(hexColor) {
|
|
223
220
|
const contrast = this.getContrastColor(hexColor);
|
|
224
221
|
const rgb = this.hexToRgb(contrast);
|
|
225
222
|
return rgb ? `${rgb.r} ${rgb.g} ${rgb.b}` : '255 255 255';
|
|
226
223
|
}
|
|
227
|
-
/**
|
|
228
|
-
* Lighten a hex color by a percentage
|
|
229
|
-
*/
|
|
230
224
|
lightenColor(color, percent) {
|
|
231
225
|
const rgb = this.hexToRgb(color);
|
|
232
226
|
if (!rgb)
|
|
233
227
|
return color;
|
|
234
|
-
// Lighten by percentage
|
|
235
228
|
const r = Math.min(255, Math.floor(rgb.r + (255 - rgb.r) * (percent / 100)));
|
|
236
229
|
const g = Math.min(255, Math.floor(rgb.g + (255 - rgb.g) * (percent / 100)));
|
|
237
230
|
const b = Math.min(255, Math.floor(rgb.b + (255 - rgb.b) * (percent / 100)));
|
|
238
|
-
// Convert back to hex
|
|
239
231
|
return `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`;
|
|
240
232
|
}
|
|
241
|
-
/**
|
|
242
|
-
* Darken a hex color by a percentage
|
|
243
|
-
*/
|
|
244
233
|
darkenColor(color, percent) {
|
|
245
234
|
const rgb = this.hexToRgb(color);
|
|
246
235
|
if (!rgb)
|
|
@@ -251,16 +240,11 @@ export class ThemeService {
|
|
|
251
240
|
const b = Math.max(0, Math.floor(rgb.b * factor));
|
|
252
241
|
return `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;
|
|
253
242
|
}
|
|
254
|
-
/**
|
|
255
|
-
* Calculate contrast color (black or white) based on background color
|
|
256
|
-
*/
|
|
257
243
|
getContrastColor(hexColor) {
|
|
258
244
|
const rgb = this.hexToRgb(hexColor);
|
|
259
245
|
if (!rgb)
|
|
260
246
|
return '#ffffff';
|
|
261
|
-
// Calculate relative luminance
|
|
262
247
|
const luminance = (0.299 * rgb.r + 0.587 * rgb.g + 0.114 * rgb.b) / 255;
|
|
263
|
-
// Return black for light colors, white for dark colors
|
|
264
248
|
return luminance > 0.5 ? '#000000' : '#ffffff';
|
|
265
249
|
}
|
|
266
250
|
injectDynamicStyles(css) {
|
|
@@ -284,20 +268,19 @@ export class ThemeService {
|
|
|
284
268
|
if (saveToStorage) {
|
|
285
269
|
localStorage.setItem('tolle-theme', 'dark');
|
|
286
270
|
}
|
|
287
|
-
this.
|
|
271
|
+
this._isDark.next(true);
|
|
288
272
|
}
|
|
289
273
|
disableDarkMode(saveToStorage = true) {
|
|
290
274
|
this.renderer.removeClass(this.document.documentElement, 'dark');
|
|
291
275
|
if (saveToStorage) {
|
|
292
276
|
localStorage.setItem('tolle-theme', 'light');
|
|
293
277
|
}
|
|
294
|
-
this.
|
|
278
|
+
this._isDark.next(false);
|
|
295
279
|
}
|
|
296
280
|
setPrimaryColor(color, persist = true) {
|
|
297
281
|
if (!isPlatformBrowser(this.platformId))
|
|
298
282
|
return;
|
|
299
283
|
this.generatePrimaryShades(color);
|
|
300
|
-
// Also set inline for immediate update
|
|
301
284
|
const rgb = this.hexToRgb(color);
|
|
302
285
|
if (rgb) {
|
|
303
286
|
this.renderer.setStyle(this.document.documentElement, '--primary', `${rgb.r} ${rgb.g} ${rgb.b}`);
|
|
@@ -307,7 +290,10 @@ export class ThemeService {
|
|
|
307
290
|
}
|
|
308
291
|
}
|
|
309
292
|
get currentTheme() {
|
|
310
|
-
return this.
|
|
293
|
+
return this._isDark.getValue() ? 'dark' : 'light';
|
|
294
|
+
}
|
|
295
|
+
get isDark() {
|
|
296
|
+
return this._isDark.getValue();
|
|
311
297
|
}
|
|
312
298
|
get primaryColor() {
|
|
313
299
|
if (!isPlatformBrowser(this.platformId))
|
|
@@ -315,7 +301,6 @@ export class ThemeService {
|
|
|
315
301
|
const root = this.document.documentElement;
|
|
316
302
|
const cssValue = getComputedStyle(root).getPropertyValue('--primary').trim();
|
|
317
303
|
if (cssValue && cssValue !== '') {
|
|
318
|
-
// Convert RGB string back to hex for external use
|
|
319
304
|
const rgbParts = cssValue.split(' ').map(Number);
|
|
320
305
|
if (rgbParts.length === 3) {
|
|
321
306
|
return `#${rgbParts[0].toString(16).padStart(2, '0')}${rgbParts[1].toString(16).padStart(2, '0')}${rgbParts[2].toString(16).padStart(2, '0')}`;
|
|
@@ -323,22 +308,14 @@ export class ThemeService {
|
|
|
323
308
|
}
|
|
324
309
|
return localStorage.getItem('tolle-primary-color');
|
|
325
310
|
}
|
|
326
|
-
/**
|
|
327
|
-
* Reset to config defaults (clears user preferences)
|
|
328
|
-
*/
|
|
329
311
|
resetToConfigDefaults() {
|
|
330
312
|
if (!isPlatformBrowser(this.platformId))
|
|
331
313
|
return;
|
|
332
|
-
// Clear user preferences
|
|
333
314
|
localStorage.removeItem('tolle-theme');
|
|
334
315
|
localStorage.removeItem('tolle-primary-color');
|
|
335
316
|
localStorage.removeItem('tolle-radius');
|
|
336
|
-
// Re-initialize with config defaults
|
|
337
317
|
this.initializeTheme();
|
|
338
318
|
}
|
|
339
|
-
/**
|
|
340
|
-
* Get current user preferences
|
|
341
|
-
*/
|
|
342
319
|
getUserPreferences() {
|
|
343
320
|
if (!isPlatformBrowser(this.platformId))
|
|
344
321
|
return null;
|
|
@@ -348,16 +325,12 @@ export class ThemeService {
|
|
|
348
325
|
radius: localStorage.getItem('tolle-radius')
|
|
349
326
|
};
|
|
350
327
|
}
|
|
351
|
-
/**
|
|
352
|
-
* Clear all user preferences
|
|
353
|
-
*/
|
|
354
328
|
clearUserPreferences() {
|
|
355
329
|
if (!isPlatformBrowser(this.platformId))
|
|
356
330
|
return;
|
|
357
331
|
localStorage.removeItem('tolle-theme');
|
|
358
332
|
localStorage.removeItem('tolle-primary-color');
|
|
359
333
|
localStorage.removeItem('tolle-radius');
|
|
360
|
-
// Reset to system defaults (not config defaults)
|
|
361
334
|
const systemPrefersDark = window.matchMedia('(prefers-color-scheme: dark)').matches;
|
|
362
335
|
if (systemPrefersDark) {
|
|
363
336
|
this.enableDarkMode(false);
|
|
@@ -365,11 +338,14 @@ export class ThemeService {
|
|
|
365
338
|
else {
|
|
366
339
|
this.disableDarkMode(false);
|
|
367
340
|
}
|
|
368
|
-
// Remove CSS variables
|
|
369
341
|
const root = this.document.documentElement;
|
|
370
342
|
this.renderer.removeStyle(root, '--primary');
|
|
371
343
|
this.renderer.removeStyle(root, '--radius');
|
|
372
|
-
//
|
|
344
|
+
// Also remove all derived radius variables
|
|
345
|
+
['--radius-sm', '--radius-md', '--radius-lg', '--radius-xl', '--radius-2xl', '--radius-3xl', '--radius-full']
|
|
346
|
+
.forEach(varName => {
|
|
347
|
+
this.renderer.removeStyle(root, varName);
|
|
348
|
+
});
|
|
373
349
|
const existingStyle = this.document.getElementById(this.styleId);
|
|
374
350
|
if (existingStyle) {
|
|
375
351
|
existingStyle.remove();
|
|
@@ -384,7 +360,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
384
360
|
}], ctorParameters: () => [{ type: Document, decorators: [{
|
|
385
361
|
type: Inject,
|
|
386
362
|
args: [DOCUMENT]
|
|
387
|
-
}] }, { type:
|
|
363
|
+
}] }, { type: undefined, decorators: [{
|
|
388
364
|
type: Inject,
|
|
389
365
|
args: [PLATFORM_ID]
|
|
390
366
|
}] }, { type: undefined, decorators: [{
|
|
@@ -393,4 +369,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
393
369
|
type: Inject,
|
|
394
370
|
args: [TOLLE_CONFIG]
|
|
395
371
|
}] }, { type: i0.RendererFactory2 }] });
|
|
396
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.service.js","sourceRoot":"","sources":["../../../../projects/tolle/src/lib/theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, PLATFORM_ID, Optional, Renderer2, RendererFactory2 } from '@angular/core';\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport { BehaviorSubject } from 'rxjs';\nimport { TOLLE_CONFIG, TolleConfig } from './tolle-config';\n\n@Injectable({ providedIn: 'root' })\nexport class ThemeService {\n  private renderer: Renderer2;\n  private isDarkSubject = new BehaviorSubject<boolean>(false);\n  isDark$ = this.isDarkSubject.asObservable();\n  private styleId = 'tolle-dynamic-theme';\n\n  constructor(\n    @Inject(DOCUMENT) private document: Document,\n    @Inject(PLATFORM_ID) private platformId: Object,\n    @Optional() @Inject(TOLLE_CONFIG) private config: TolleConfig,\n    rendererFactory: RendererFactory2\n  ) {\n    this.renderer = rendererFactory.createRenderer(null, null);\n    this.initializeTheme();\n  }\n\n  private initializeTheme() {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    // LOGIC: User Saved Preferences > Config Defaults > System Preference\n    const savedTheme = localStorage.getItem('tolle-theme');\n    const savedPrimary = localStorage.getItem('tolle-primary-color');\n    const savedRadius = localStorage.getItem('tolle-radius');\n    const systemPrefersDark = window.matchMedia('(prefers-color-scheme: dark)').matches;\n\n    console.log('Theme initialization:', {\n      savedTheme,\n      savedPrimary,\n      savedRadius,\n      config: this.config,\n      systemPrefersDark\n    });\n\n    // 1. Determine Dark/Light Mode\n    // Priority: Saved Theme > Config Default > System Preference\n    let shouldBeDark = systemPrefersDark; // Start with system\n\n    if (savedTheme) {\n      // User has saved preference\n      shouldBeDark = savedTheme === 'dark';\n    } else if (this.config?.darkByDefault !== undefined) {\n      // Use config default if no user preference\n      shouldBeDark = this.config.darkByDefault;\n    }\n\n    // Apply theme mode\n    if (shouldBeDark) {\n      this.enableDarkMode(false); // Don't save, we'll save after checking all preferences\n    } else {\n      this.disableDarkMode(false);\n    }\n\n    // 2. Apply Primary Color\n    // Priority: Saved Color > Config Color\n    if (savedPrimary) {\n      // User has saved color preference\n      this.setPrimaryColor(savedPrimary, false); // Don't save again\n    } else if (this.config?.primaryColor) {\n      // Use config default if no user preference\n      this.setPrimaryColor(this.config.primaryColor, false); // Save this as user preference\n    }\n\n    // 3. Apply Radius\n    // Priority: Saved Radius > Config Radius\n    if (savedRadius) {\n      // User has saved radius preference\n      this.setRadius(savedRadius, false);\n    } else if (this.config?.radius) {\n      // Use config default if no user preference\n      this.setRadius(this.config.radius, false);\n    }\n\n    // Save theme mode preference if it came from config or system\n    if (!savedTheme) {\n      localStorage.setItem('tolle-theme', shouldBeDark ? 'dark' : 'light');\n    }\n  }\n  /**\n   * Sets the border radius for all components\n   */\n  setRadius(radius: string, persist = true) {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    const root = this.document.documentElement;\n\n    // Set the CSS variable\n    this.renderer.setStyle(root, '--radius', radius);\n\n    // Also update the dynamic styles to include radius calculations\n    this.updateRadiusInDynamicStyles(radius);\n\n    // Persist if needed\n    if (persist) {\n      localStorage.setItem('tolle-radius', radius);\n    }\n  }\n\n  /**\n   * Updates the radius calculations in dynamic styles\n   */\n  private updateRadiusInDynamicStyles(radius: string) {\n    const existingStyle = this.document.getElementById(this.styleId);\n\n    if (existingStyle) {\n      let css = existingStyle.textContent || '';\n\n      // Update or add radius calculations\n      if (css.includes('--radius:')) {\n        // Replace existing radius declarations\n        css = css.replace(/--radius:[^;]+;/g, `--radius: ${radius};`);\n      } else {\n        // Add radius to the beginning of :root\n        css = css.replace(/:root\\s*{/, `:root {\\n      --radius: ${radius};`);\n      }\n\n      // Update the calculated radius values in the CSS\n      const radiusCalcRegex = /calc\\(var\\(--radius[^)]+\\)/g;\n      css = css.replace(radiusCalcRegex, (match) => {\n        if (match.includes('- 2px')) {\n          return `calc(${radius} - 2px)`;\n        } else if (match.includes('- 4px')) {\n          return `calc(${radius} - 4px)`;\n        }\n        return match;\n      });\n\n      existingStyle.textContent = css;\n    }\n  }\n\n  /**\n   * Generates full primary color palette (50-900) based on base color\n   */\n  private generatePrimaryShades(baseColor: string) {\n    // Convert hex to RGB\n    const rgb = this.hexToRgb(baseColor);\n    const rgbString = rgb ? `${rgb.r} ${rgb.g} ${rgb.b}` : '37 99 235';\n\n    // Create lighter ring colors in RGB\n    const ringLight = this.lightenColor(baseColor, 40);\n    const ringLightRgb = this.hexToRgb(ringLight);\n    const ringLightRgbString = ringLightRgb ? `${ringLightRgb.r} ${ringLightRgb.g} ${ringLightRgb.b}` : '96 165 250';\n\n    const ringDark = this.lightenColor(baseColor, 20);\n    const ringDarkRgb = this.hexToRgb(ringDark);\n    const ringDarkRgbString = ringDarkRgb ? `${ringDarkRgb.r} ${ringDarkRgb.g} ${ringDarkRgb.b}` : '147 197 253';\n\n    // Get current radius or use default\n    const root = this.document.documentElement;\n    const currentRadius = getComputedStyle(root).getPropertyValue('--radius').trim() || '0.5rem';\n\n    const css = `\n      /* Override primary colors - this needs to come AFTER your main CSS */\n      :root {\n        /* Primary in RGB format for Tailwind opacity support */\n        --primary: ${rgbString};\n        --primary-foreground: ${this.getContrastColorRgb(baseColor)};\n\n        /* Radius */\n        --radius: ${currentRadius};\n\n        /* Primary shades for light mode */\n        --primary-50: ${this.hexToRgbString(this.lightenColor(baseColor, 90))};\n        --primary-100: ${this.hexToRgbString(this.lightenColor(baseColor, 80))};\n        --primary-200: ${this.hexToRgbString(this.lightenColor(baseColor, 60))};\n        --primary-300: ${this.hexToRgbString(this.lightenColor(baseColor, 40))};\n        --primary-400: ${this.hexToRgbString(this.lightenColor(baseColor, 20))};\n        --primary-500: ${rgbString};\n        --primary-600: ${this.hexToRgbString(this.darkenColor(baseColor, 20))};\n        --primary-700: ${this.hexToRgbString(this.darkenColor(baseColor, 40))};\n        --primary-800: ${this.hexToRgbString(this.darkenColor(baseColor, 60))};\n        --primary-900: ${this.hexToRgbString(this.darkenColor(baseColor, 80))};\n\n        /* Update ring color to be lighter */\n        --ring: ${ringLightRgbString};\n      }\n\n      .dark {\n        /* For dark mode, we keep the primary color but adjust shades */\n        --primary: ${rgbString};\n        --primary-foreground: ${this.getContrastColorRgb(baseColor)};\n\n        /* Dark mode shades */\n        --primary-50: ${this.hexToRgbString(this.darkenColor(baseColor, 85))};\n        --primary-100: ${this.hexToRgbString(this.darkenColor(baseColor, 75))};\n        --primary-200: ${this.hexToRgbString(this.darkenColor(baseColor, 65))};\n        --primary-300: ${this.hexToRgbString(this.darkenColor(baseColor, 55))};\n        --primary-400: ${this.hexToRgbString(this.darkenColor(baseColor, 45))};\n        --primary-500: ${rgbString};\n        --primary-600: ${this.hexToRgbString(this.lightenColor(baseColor, 20))};\n        --primary-700: ${this.hexToRgbString(this.lightenColor(baseColor, 35))};\n        --primary-800: ${this.hexToRgbString(this.lightenColor(baseColor, 50))};\n        --primary-900: ${this.hexToRgbString(this.lightenColor(baseColor, 65))};\n\n        /* Update ring color for dark mode - lighter variant */\n        --ring: ${ringDarkRgbString};\n      }\n    `;\n\n    this.injectDynamicStyles(css);\n  }\n\n  /**\n   * Convert hex color to RGB object\n   */\n  private hexToRgb(hex: string): { r: number, g: number, b: number } | null {\n    // Remove # if present\n    const cleanedHex = hex.replace('#', '');\n\n    let r = 0, g = 0, b = 0;\n\n    if (cleanedHex.length === 3) {\n      r = parseInt(cleanedHex[0] + cleanedHex[0], 16);\n      g = parseInt(cleanedHex[1] + cleanedHex[1], 16);\n      b = parseInt(cleanedHex[2] + cleanedHex[2], 16);\n      return { r, g, b };\n    }\n\n    if (cleanedHex.length === 6) {\n      r = parseInt(cleanedHex.substring(0, 2), 16);\n      g = parseInt(cleanedHex.substring(2, 4), 16);\n      b = parseInt(cleanedHex.substring(4, 6), 16);\n      return { r, g, b };\n    }\n\n    return null;\n  }\n\n  /**\n   * Convert hex to RGB string format for CSS (space-separated)\n   */\n  private hexToRgbString(hexColor: string): string {\n    const rgb = this.hexToRgb(hexColor);\n    return rgb ? `${rgb.r} ${rgb.g} ${rgb.b}` : '37 99 235';\n  }\n\n  /**\n   * Get contrast color in RGB format\n   */\n  private getContrastColorRgb(hexColor: string): string {\n    const contrast = this.getContrastColor(hexColor);\n    const rgb = this.hexToRgb(contrast);\n    return rgb ? `${rgb.r} ${rgb.g} ${rgb.b}` : '255 255 255';\n  }\n\n  /**\n   * Lighten a hex color by a percentage\n   */\n  private lightenColor(color: string, percent: number): string {\n    const rgb = this.hexToRgb(color);\n    if (!rgb) return color;\n\n    // Lighten by percentage\n    const r = Math.min(255, Math.floor(rgb.r + (255 - rgb.r) * (percent / 100)));\n    const g = Math.min(255, Math.floor(rgb.g + (255 - rgb.g) * (percent / 100)));\n    const b = Math.min(255, Math.floor(rgb.b + (255 - rgb.b) * (percent / 100)));\n\n    // Convert back to hex\n    return `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`;\n  }\n\n  /**\n   * Darken a hex color by a percentage\n   */\n  private darkenColor(color: string, percent: number): string {\n    const rgb = this.hexToRgb(color);\n    if (!rgb) return color;\n\n    const factor = 1 - (percent / 100);\n    const r = Math.max(0, Math.floor(rgb.r * factor));\n    const g = Math.max(0, Math.floor(rgb.g * factor));\n    const b = Math.max(0, Math.floor(rgb.b * factor));\n\n    return `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;\n  }\n\n  /**\n   * Calculate contrast color (black or white) based on background color\n   */\n  private getContrastColor(hexColor: string): string {\n    const rgb = this.hexToRgb(hexColor);\n    if (!rgb) return '#ffffff';\n\n    // Calculate relative luminance\n    const luminance = (0.299 * rgb.r + 0.587 * rgb.g + 0.114 * rgb.b) / 255;\n\n    // Return black for light colors, white for dark colors\n    return luminance > 0.5 ? '#000000' : '#ffffff';\n  }\n\n  private injectDynamicStyles(css: string) {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    const existingStyle = this.document.getElementById(this.styleId);\n    if (existingStyle) {\n      existingStyle.remove();\n    }\n\n    const styleElement = this.document.createElement('style');\n    styleElement.id = this.styleId;\n    styleElement.textContent = css;\n    this.renderer.appendChild(this.document.head, styleElement);\n  }\n\n  toggleTheme() {\n    const isCurrentlyDark = this.document.documentElement.classList.contains('dark');\n    isCurrentlyDark ? this.disableDarkMode() : this.enableDarkMode();\n  }\n\n  private enableDarkMode(saveToStorage = true) {\n    this.renderer.addClass(this.document.documentElement, 'dark');\n    if (saveToStorage) {\n      localStorage.setItem('tolle-theme', 'dark');\n    }\n    this.isDarkSubject.next(true);\n  }\n\n  private disableDarkMode(saveToStorage = true) {\n    this.renderer.removeClass(this.document.documentElement, 'dark');\n    if (saveToStorage) {\n      localStorage.setItem('tolle-theme', 'light');\n    }\n    this.isDarkSubject.next(false);\n  }\n  setPrimaryColor(color: string, persist = true) {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    this.generatePrimaryShades(color);\n\n    // Also set inline for immediate update\n    const rgb = this.hexToRgb(color);\n    if (rgb) {\n      this.renderer.setStyle(\n        this.document.documentElement,\n        '--primary',\n        `${rgb.r} ${rgb.g} ${rgb.b}`\n      );\n    }\n\n    if (persist) {\n      localStorage.setItem('tolle-primary-color', color);\n    }\n  }\n\n  get currentTheme(): 'dark' | 'light' {\n    return this.isDarkSubject.value ? 'dark' : 'light';\n  }\n\n  get primaryColor(): string | null {\n    if (!isPlatformBrowser(this.platformId)) return null;\n\n    const root = this.document.documentElement;\n    const cssValue = getComputedStyle(root).getPropertyValue('--primary').trim();\n\n    if (cssValue && cssValue !== '') {\n      // Convert RGB string back to hex for external use\n      const rgbParts = cssValue.split(' ').map(Number);\n      if (rgbParts.length === 3) {\n        return `#${rgbParts[0].toString(16).padStart(2, '0')}${rgbParts[1].toString(16).padStart(2, '0')}${rgbParts[2].toString(16).padStart(2, '0')}`;\n      }\n    }\n\n    return localStorage.getItem('tolle-primary-color');\n  }\n\n  /**\n   * Reset to config defaults (clears user preferences)\n   */\n  resetToConfigDefaults() {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    // Clear user preferences\n    localStorage.removeItem('tolle-theme');\n    localStorage.removeItem('tolle-primary-color');\n    localStorage.removeItem('tolle-radius');\n\n    // Re-initialize with config defaults\n    this.initializeTheme();\n  }\n\n  /**\n   * Get current user preferences\n   */\n  getUserPreferences() {\n    if (!isPlatformBrowser(this.platformId)) return null;\n\n    return {\n      theme: localStorage.getItem('tolle-theme'),\n      primaryColor: localStorage.getItem('tolle-primary-color'),\n      radius: localStorage.getItem('tolle-radius')\n    };\n  }\n\n  /**\n   * Clear all user preferences\n   */\n  clearUserPreferences() {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    localStorage.removeItem('tolle-theme');\n    localStorage.removeItem('tolle-primary-color');\n    localStorage.removeItem('tolle-radius');\n\n    // Reset to system defaults (not config defaults)\n    const systemPrefersDark = window.matchMedia('(prefers-color-scheme: dark)').matches;\n    if (systemPrefersDark) {\n      this.enableDarkMode(false);\n    } else {\n      this.disableDarkMode(false);\n    }\n\n    // Remove CSS variables\n    const root = this.document.documentElement;\n    this.renderer.removeStyle(root, '--primary');\n    this.renderer.removeStyle(root, '--radius');\n\n    // Clear dynamic styles\n    const existingStyle = this.document.getElementById(this.styleId);\n    if (existingStyle) {\n      existingStyle.remove();\n    }\n  }\n}\n"]}
|
|
372
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.service.js","sourceRoot":"","sources":["../../../../projects/tolle/src/lib/theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, PLATFORM_ID, Optional, Renderer2, RendererFactory2 } from '@angular/core';\nimport {DOCUMENT, isPlatformBrowser} from '@angular/common';\nimport { TOLLE_CONFIG, TolleConfig } from './tolle-config';\nimport { BehaviorSubject } from 'rxjs';\n\n@Injectable({ providedIn: 'root' })\nexport class ThemeService {\n  private renderer: Renderer2;\n  private _isDark = new BehaviorSubject<boolean>(false);\n  public isDark$ = this._isDark.asObservable();\n\n  private styleId = 'tolle-dynamic-theme';\n\n  constructor(\n    @Inject(DOCUMENT) private document: Document,\n    @Inject(PLATFORM_ID) private platformId: object,\n    @Optional() @Inject(TOLLE_CONFIG) private config: TolleConfig,\n    rendererFactory: RendererFactory2\n  ) {\n    this.renderer = rendererFactory.createRenderer(null, null);\n    this.initializeTheme();\n  }\n\n  private initializeTheme() {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    // LOGIC: User Saved Preferences > Config Defaults > System Preference\n    const savedTheme = localStorage.getItem('tolle-theme');\n    const savedPrimary = localStorage.getItem('tolle-primary-color');\n    const savedRadius = localStorage.getItem('tolle-radius');\n    const systemPrefersDark = window.matchMedia('(prefers-color-scheme: dark)').matches;\n\n    // Determine Dark/Light Mode\n    let shouldBeDark = systemPrefersDark;\n\n    if (savedTheme) {\n      shouldBeDark = savedTheme === 'dark';\n    } else if (this.config?.darkByDefault !== undefined) {\n      shouldBeDark = this.config.darkByDefault;\n    }\n\n    // Apply theme mode\n    if (shouldBeDark) {\n      this.enableDarkMode(false);\n    } else {\n      this.disableDarkMode(false);\n    }\n\n    // Apply Primary Color\n    if (savedPrimary) {\n      this.setPrimaryColor(savedPrimary, false);\n    } else if (this.config?.primaryColor) {\n      this.setPrimaryColor(this.config.primaryColor, false);\n    }\n\n    // Apply Radius\n    if (savedRadius) {\n      this.setRadius(savedRadius, false);\n    } else if (this.config?.radius) {\n      this.setRadius(this.config.radius, false);\n    }\n\n    if (!savedTheme) {\n      localStorage.setItem('tolle-theme', shouldBeDark ? 'dark' : 'light');\n    }\n  }\n\n  setRadius(radius: string, persist = true) {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    const root = this.document.documentElement;\n    this.renderer.setStyle(root, '--radius', radius);\n    this.updateRadiusInDynamicStyles(radius);\n    this.updateAllRadiusVariables(radius);\n\n    if (persist) {\n      localStorage.setItem('tolle-radius', radius);\n    }\n  }\n\n  private updateAllRadiusVariables(baseRadius: string) {\n    const root = this.document.documentElement;\n\n    // Parse the radius to extract numeric value and unit\n    const radiusMatch = baseRadius.match(/^(\\d*\\.?\\d+)([a-z]+|%)$/);\n    if (!radiusMatch) {\n      console.warn(`Invalid radius format: ${baseRadius}. Using default values.`);\n      return;\n    }\n\n    const numericValue = parseFloat(radiusMatch[1]);\n    const unit = radiusMatch[2];\n\n    // Set all radius variables according to your CSS classes\n    this.renderer.setStyle(root, '--radius-sm', `${numericValue * 0.5}${unit}`);\n    this.renderer.setStyle(root, '--radius-md', `${numericValue}${unit}`);\n    this.renderer.setStyle(root, '--radius-lg', `${numericValue * 1.5}${unit}`);\n    this.renderer.setStyle(root, '--radius-xl', `${numericValue * 2}${unit}`);\n    this.renderer.setStyle(root, '--radius-2xl', `${numericValue * 3}${unit}`);\n    this.renderer.setStyle(root, '--radius-3xl', `${numericValue * 4}${unit}`);\n    this.renderer.setStyle(root, '--radius-full', '9999px');\n  }\n\n  private updateRadiusInDynamicStyles(radius: string) {\n    const existingStyle = this.document.getElementById(this.styleId);\n\n    if (existingStyle) {\n      let css = existingStyle.textContent || '';\n\n      // Parse the radius to calculate derived values\n      const radiusMatch = radius.match(/^(\\d*\\.?\\d+)([a-z]+|%)$/);\n      if (radiusMatch) {\n        const numericValue = parseFloat(radiusMatch[1]);\n        const unit = radiusMatch[2];\n\n        const derivedRadii = {\n          '--radius-sm': `${numericValue * 0.5}${unit}`,\n          '--radius-md': `${numericValue}${unit}`,\n          '--radius-lg': `${numericValue * 1.5}${unit}`,\n          '--radius-xl': `${numericValue * 2}${unit}`,\n          '--radius-2xl': `${numericValue * 3}${unit}`,\n          '--radius-3xl': `${numericValue * 4}${unit}`,\n          '--radius-full': '9999px'\n        };\n\n        // Update base radius\n        if (css.includes('--radius:')) {\n          css = css.replace(/--radius:[^;]+;/g, `--radius: ${radius};`);\n        }\n\n        // Update all derived radius variables\n        Object.entries(derivedRadii).forEach(([varName, value]) => {\n          if (css.includes(varName)) {\n            const regex = new RegExp(`${varName}:[^;]+;`, 'g');\n            css = css.replace(regex, `${varName}: ${value};`);\n          } else {\n            // Add the variable if it doesn't exist\n            css = css.replace(/:root\\s*{/, `:root {\\n      ${varName}: ${value};`);\n          }\n        });\n      }\n\n      existingStyle.textContent = css;\n    }\n  }\n\n  private generatePrimaryShades(baseColor: string) {\n    const rgb = this.hexToRgb(baseColor);\n    const rgbString = rgb ? `${rgb.r} ${rgb.g} ${rgb.b}` : '37 99 235';\n\n    const ringLight = this.lightenColor(baseColor, 40);\n    const ringLightRgb = this.hexToRgb(ringLight);\n    const ringLightRgbString = ringLightRgb ? `${ringLightRgb.r} ${ringLightRgb.g} ${ringLightRgb.b}` : '96 165 250';\n\n    const ringDark = this.lightenColor(baseColor, 20);\n    const ringDarkRgb = this.hexToRgb(ringDark);\n    const ringDarkRgbString = ringDarkRgb ? `${ringDarkRgb.r} ${ringDarkRgb.g} ${ringDarkRgb.b}` : '147 197 253';\n\n    // Get current radius or default\n    const root = this.document.documentElement;\n    const currentRadius = getComputedStyle(root).getPropertyValue('--radius').trim() || '0.5rem';\n\n    // Calculate all derived radius values\n    const radiusMatch = currentRadius.match(/^(\\d*\\.?\\d+)([a-z]+|%)$/);\n    let radiusVariables = '';\n\n    if (radiusMatch) {\n      const numericValue = parseFloat(radiusMatch[1]);\n      const unit = radiusMatch[2];\n\n      radiusVariables = `\n        --radius: ${currentRadius};\n        --radius-sm: ${numericValue * 0.5}${unit};\n        --radius-md: ${numericValue}${unit};\n        --radius-lg: ${numericValue * 1.5}${unit};\n        --radius-xl: ${numericValue * 2}${unit};\n        --radius-2xl: ${numericValue * 3}${unit};\n        --radius-3xl: ${numericValue * 4}${unit};\n        --radius-full: 9999px;\n      `;\n    } else {\n      radiusVariables = `--radius: ${currentRadius};`;\n    }\n\n    const css = `\n      :root {\n        --primary: ${rgbString};\n        --primary-foreground: ${this.getContrastColorRgb(baseColor)};\n        ${radiusVariables}\n        --primary-50: ${this.hexToRgbString(this.lightenColor(baseColor, 90))};\n        --primary-100: ${this.hexToRgbString(this.lightenColor(baseColor, 80))};\n        --primary-200: ${this.hexToRgbString(this.lightenColor(baseColor, 60))};\n        --primary-300: ${this.hexToRgbString(this.lightenColor(baseColor, 40))};\n        --primary-400: ${this.hexToRgbString(this.lightenColor(baseColor, 20))};\n        --primary-500: ${rgbString};\n        --primary-600: ${this.hexToRgbString(this.darkenColor(baseColor, 20))};\n        --primary-700: ${this.hexToRgbString(this.darkenColor(baseColor, 40))};\n        --primary-800: ${this.hexToRgbString(this.darkenColor(baseColor, 60))};\n        --primary-900: ${this.hexToRgbString(this.darkenColor(baseColor, 80))};\n        --ring: ${ringLightRgbString};\n      }\n\n      .dark {\n        --primary: ${rgbString};\n        --primary-foreground: ${this.getContrastColorRgb(baseColor)};\n        ${radiusVariables}\n        --primary-50: ${this.hexToRgbString(this.darkenColor(baseColor, 85))};\n        --primary-100: ${this.hexToRgbString(this.darkenColor(baseColor, 75))};\n        --primary-200: ${this.hexToRgbString(this.darkenColor(baseColor, 65))};\n        --primary-300: ${this.hexToRgbString(this.darkenColor(baseColor, 55))};\n        --primary-400: ${this.hexToRgbString(this.darkenColor(baseColor, 45))};\n        --primary-500: ${rgbString};\n        --primary-600: ${this.hexToRgbString(this.lightenColor(baseColor, 20))};\n        --primary-700: ${this.hexToRgbString(this.lightenColor(baseColor, 35))};\n        --primary-800: ${this.hexToRgbString(this.lightenColor(baseColor, 50))};\n        --primary-900: ${this.hexToRgbString(this.lightenColor(baseColor, 65))};\n        --ring: ${ringDarkRgbString};\n      }\n    `;\n\n    this.injectDynamicStyles(css);\n  }\n\n  private hexToRgb(hex: string): { r: number, g: number, b: number } | null {\n    const cleanedHex = hex.replace('#', '');\n    let r = 0, g = 0, b = 0;\n\n    if (cleanedHex.length === 3) {\n      r = parseInt(cleanedHex[0] + cleanedHex[0], 16);\n      g = parseInt(cleanedHex[1] + cleanedHex[1], 16);\n      b = parseInt(cleanedHex[2] + cleanedHex[2], 16);\n      return { r, g, b };\n    }\n\n    if (cleanedHex.length === 6) {\n      r = parseInt(cleanedHex.substring(0, 2), 16);\n      g = parseInt(cleanedHex.substring(2, 4), 16);\n      b = parseInt(cleanedHex.substring(4, 6), 16);\n      return { r, g, b };\n    }\n\n    return null;\n  }\n\n  private hexToRgbString(hexColor: string): string {\n    const rgb = this.hexToRgb(hexColor);\n    return rgb ? `${rgb.r} ${rgb.g} ${rgb.b}` : '37 99 235';\n  }\n\n  private getContrastColorRgb(hexColor: string): string {\n    const contrast = this.getContrastColor(hexColor);\n    const rgb = this.hexToRgb(contrast);\n    return rgb ? `${rgb.r} ${rgb.g} ${rgb.b}` : '255 255 255';\n  }\n\n  private lightenColor(color: string, percent: number): string {\n    const rgb = this.hexToRgb(color);\n    if (!rgb) return color;\n\n    const r = Math.min(255, Math.floor(rgb.r + (255 - rgb.r) * (percent / 100)));\n    const g = Math.min(255, Math.floor(rgb.g + (255 - rgb.g) * (percent / 100)));\n    const b = Math.min(255, Math.floor(rgb.b + (255 - rgb.b) * (percent / 100)));\n\n    return `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`;\n  }\n\n  private darkenColor(color: string, percent: number): string {\n    const rgb = this.hexToRgb(color);\n    if (!rgb) return color;\n\n    const factor = 1 - (percent / 100);\n    const r = Math.max(0, Math.floor(rgb.r * factor));\n    const g = Math.max(0, Math.floor(rgb.g * factor));\n    const b = Math.max(0, Math.floor(rgb.b * factor));\n\n    return `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;\n  }\n\n  private getContrastColor(hexColor: string): string {\n    const rgb = this.hexToRgb(hexColor);\n    if (!rgb) return '#ffffff';\n\n    const luminance = (0.299 * rgb.r + 0.587 * rgb.g + 0.114 * rgb.b) / 255;\n    return luminance > 0.5 ? '#000000' : '#ffffff';\n  }\n\n  private injectDynamicStyles(css: string) {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    const existingStyle = this.document.getElementById(this.styleId);\n    if (existingStyle) {\n      existingStyle.remove();\n    }\n\n    const styleElement = this.document.createElement('style');\n    styleElement.id = this.styleId;\n    styleElement.textContent = css;\n    this.renderer.appendChild(this.document.head, styleElement);\n  }\n\n  toggleTheme() {\n    const isCurrentlyDark = this.document.documentElement.classList.contains('dark');\n    isCurrentlyDark ? this.disableDarkMode() : this.enableDarkMode();\n  }\n\n  private enableDarkMode(saveToStorage = true) {\n    this.renderer.addClass(this.document.documentElement, 'dark');\n    if (saveToStorage) {\n      localStorage.setItem('tolle-theme', 'dark');\n    }\n    this._isDark.next(true);\n  }\n\n  private disableDarkMode(saveToStorage = true) {\n    this.renderer.removeClass(this.document.documentElement, 'dark');\n    if (saveToStorage) {\n      localStorage.setItem('tolle-theme', 'light');\n    }\n    this._isDark.next(false);\n  }\n\n  setPrimaryColor(color: string, persist = true) {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    this.generatePrimaryShades(color);\n\n    const rgb = this.hexToRgb(color);\n    if (rgb) {\n      this.renderer.setStyle(\n        this.document.documentElement,\n        '--primary',\n        `${rgb.r} ${rgb.g} ${rgb.b}`\n      );\n    }\n\n    if (persist) {\n      localStorage.setItem('tolle-primary-color', color);\n    }\n  }\n\n  get currentTheme(): 'dark' | 'light' {\n    return this._isDark.getValue() ? 'dark' : 'light';\n  }\n\n  get isDark(): boolean {\n    return this._isDark.getValue();\n  }\n\n  get primaryColor(): string | null {\n    if (!isPlatformBrowser(this.platformId)) return null;\n\n    const root = this.document.documentElement;\n    const cssValue = getComputedStyle(root).getPropertyValue('--primary').trim();\n\n    if (cssValue && cssValue !== '') {\n      const rgbParts = cssValue.split(' ').map(Number);\n      if (rgbParts.length === 3) {\n        return `#${rgbParts[0].toString(16).padStart(2, '0')}${rgbParts[1].toString(16).padStart(2, '0')}${rgbParts[2].toString(16).padStart(2, '0')}`;\n      }\n    }\n\n    return localStorage.getItem('tolle-primary-color');\n  }\n\n  resetToConfigDefaults() {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    localStorage.removeItem('tolle-theme');\n    localStorage.removeItem('tolle-primary-color');\n    localStorage.removeItem('tolle-radius');\n\n    this.initializeTheme();\n  }\n\n  getUserPreferences() {\n    if (!isPlatformBrowser(this.platformId)) return null;\n\n    return {\n      theme: localStorage.getItem('tolle-theme'),\n      primaryColor: localStorage.getItem('tolle-primary-color'),\n      radius: localStorage.getItem('tolle-radius')\n    };\n  }\n\n  clearUserPreferences() {\n    if (!isPlatformBrowser(this.platformId)) return;\n\n    localStorage.removeItem('tolle-theme');\n    localStorage.removeItem('tolle-primary-color');\n    localStorage.removeItem('tolle-radius');\n\n    const systemPrefersDark = window.matchMedia('(prefers-color-scheme: dark)').matches;\n    if (systemPrefersDark) {\n      this.enableDarkMode(false);\n    } else {\n      this.disableDarkMode(false);\n    }\n\n    const root = this.document.documentElement;\n    this.renderer.removeStyle(root, '--primary');\n    this.renderer.removeStyle(root, '--radius');\n\n    // Also remove all derived radius variables\n    ['--radius-sm', '--radius-md', '--radius-lg', '--radius-xl', '--radius-2xl', '--radius-3xl', '--radius-full']\n      .forEach(varName => {\n        this.renderer.removeStyle(root, varName);\n      });\n\n    const existingStyle = this.document.getElementById(this.styleId);\n    if (existingStyle) {\n      existingStyle.remove();\n    }\n  }\n}\n"]}
|