stream-chat-angular 2.12.2 → 2.12.3

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.
@@ -1,2 +1,2 @@
1
- export const version = '2.12.2';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2Fzc2V0cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdmVyc2lvbiA9ICcyLjEyLjInO1xuIl19
1
+ export const version = '2.12.3';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2Fzc2V0cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdmVyc2lvbiA9ICcyLjEyLjMnO1xuIl19
@@ -25,12 +25,14 @@ export class ThemeService {
25
25
  '--white-smoke': '#13151b',
26
26
  '--white-snow': '#070a0d',
27
27
  };
28
+ this.variablesToDelete = [];
28
29
  this.theme$.subscribe((theme) => {
29
30
  const darkVariables = this.customDarkThemeVariables
30
31
  ? Object.assign(Object.assign({}, this.defaultDarkModeVariables), this.customDarkThemeVariables) : this.defaultDarkModeVariables;
31
32
  const lightVariables = this.customLightThemeVariables
32
33
  ? this.customLightThemeVariables
33
34
  : {};
35
+ this.variablesToDelete.forEach((variables) => this.deleteVariables(variables));
34
36
  if (theme === 'dark') {
35
37
  this.deleteVariables(lightVariables);
36
38
  this.setVariables(darkVariables);
@@ -46,16 +48,26 @@ export class ThemeService {
46
48
  }
47
49
  set customLightThemeVariables(variables) {
48
50
  const prevVariables = this.customLightThemeVariables;
49
- this.deleteVariables(prevVariables);
51
+ if (prevVariables) {
52
+ this.variablesToDelete.push(prevVariables);
53
+ }
50
54
  this._customLightThemeVariables = variables;
55
+ if (this.theme$.getValue() === 'light') {
56
+ this.theme$.next('light');
57
+ }
51
58
  }
52
59
  get customDarkThemeVariables() {
53
60
  return this._customDarkThemeVariables;
54
61
  }
55
62
  set customDarkThemeVariables(variables) {
56
63
  const prevVariables = this.customDarkThemeVariables;
57
- this.deleteVariables(prevVariables);
64
+ if (prevVariables) {
65
+ this.variablesToDelete.push(prevVariables);
66
+ }
58
67
  this._customDarkThemeVariables = variables;
68
+ if (this.theme$.getValue() === 'dark') {
69
+ this.theme$.next('dark');
70
+ }
59
71
  }
60
72
  deleteVariables(variables) {
61
73
  if (!variables) {
@@ -78,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
78
90
  providedIn: 'root',
79
91
  }]
80
92
  }], ctorParameters: function () { return []; } });
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi90aGVtZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFPdkMsTUFBTSxPQUFPLFlBQVk7SUEwQnZCO1FBekJBLFdBQU0sR0FBRyxJQUFJLGVBQWUsQ0FBUSxPQUFPLENBQUMsQ0FBQztRQUdyQyw2QkFBd0IsR0FBRztZQUNqQyxtQkFBbUIsRUFBRSxTQUFTO1lBQzlCLHFCQUFxQixFQUFFLFNBQVM7WUFDaEMsU0FBUyxFQUFFLFNBQVM7WUFDcEIsY0FBYyxFQUFFLFNBQVM7WUFDekIsVUFBVSxFQUFFLFNBQVM7WUFDckIscUJBQXFCLEVBQUUsU0FBUztZQUNoQyxlQUFlLEVBQUUsU0FBUztZQUMxQixRQUFRLEVBQUUsU0FBUztZQUNuQixrQkFBa0IsRUFBRSxTQUFTO1lBQzdCLGdCQUFnQixFQUFFLFNBQVM7WUFDM0IsZ0JBQWdCLEVBQUUsU0FBUztZQUMzQixXQUFXLEVBQUUsV0FBVztZQUN4QixnQkFBZ0IsRUFBRSxXQUFXO1lBQzdCLGVBQWUsRUFBRSxXQUFXO1lBQzVCLDZCQUE2QixFQUFFLFNBQVM7WUFDeEMsZUFBZSxFQUFFLGFBQWE7WUFDOUIsU0FBUyxFQUFFLFNBQVM7WUFDcEIsZUFBZSxFQUFFLFNBQVM7WUFDMUIsY0FBYyxFQUFFLFNBQVM7U0FDMUIsQ0FBQztRQUdBLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDOUIsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLHdCQUF3QjtnQkFDakQsQ0FBQyxpQ0FBTSxJQUFJLENBQUMsd0JBQXdCLEdBQUssSUFBSSxDQUFDLHdCQUF3QixFQUN0RSxDQUFDLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDO1lBQ2xDLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyx5QkFBeUI7Z0JBQ25ELENBQUMsQ0FBQyxJQUFJLENBQUMseUJBQXlCO2dCQUNoQyxDQUFDLENBQUMsRUFBRSxDQUFDO1lBQ1AsSUFBSSxLQUFLLEtBQUssTUFBTSxFQUFFO2dCQUNwQixJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxDQUFDO2dCQUNyQyxJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBQyxDQUFDO2FBQ2xDO2lCQUFNO2dCQUNMLElBQUksQ0FBQyxlQUFlLENBQUMsYUFBYSxDQUFDLENBQUM7Z0JBQ3BDLElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxDQUFDLENBQUM7YUFDbkM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxJQUFJLHlCQUF5QjtRQUMzQixPQUFPLElBQUksQ0FBQywwQkFBMEIsQ0FBQztJQUN6QyxDQUFDO0lBRUQsSUFBSSx5QkFBeUIsQ0FDM0IsU0FBZ0Q7UUFFaEQsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLHlCQUF5QixDQUFDO1FBQ3JELElBQUksQ0FBQyxlQUFlLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDcEMsSUFBSSxDQUFDLDBCQUEwQixHQUFHLFNBQVMsQ0FBQztJQUM5QyxDQUFDO0lBRUQsSUFBSSx3QkFBd0I7UUFDMUIsT0FBTyxJQUFJLENBQUMseUJBQXlCLENBQUM7SUFDeEMsQ0FBQztJQUVELElBQUksd0JBQXdCLENBQzFCLFNBQWdEO1FBRWhELE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyx3QkFBd0IsQ0FBQztRQUNwRCxJQUFJLENBQUMsZUFBZSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3BDLElBQUksQ0FBQyx5QkFBeUIsR0FBRyxTQUFTLENBQUM7SUFDN0MsQ0FBQztJQUVPLGVBQWUsQ0FBQyxTQUFnRDtRQUN0RSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ2QsT0FBTztTQUNSO1FBQ0QsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUNyQyxRQUFRLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUN0RCxDQUFDO0lBQ0osQ0FBQztJQUVPLFlBQVksQ0FBQyxTQUFnRDtRQUNuRSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ2QsT0FBTztTQUNSO1FBQ0QsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUNyQyxRQUFRLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUNoRSxDQUFDO0lBQ0osQ0FBQzs7eUdBcEZVLFlBQVk7NkdBQVosWUFBWSxjQUZYLE1BQU07MkZBRVAsWUFBWTtrQkFIeEIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuZXhwb3J0IHR5cGUgVGhlbWUgPSAnbGlnaHQnIHwgJ2RhcmsnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgVGhlbWVTZXJ2aWNlIHtcbiAgdGhlbWUkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxUaGVtZT4oJ2xpZ2h0Jyk7XG4gIHByaXZhdGUgX2N1c3RvbUxpZ2h0VGhlbWVWYXJpYWJsZXM6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH0gfCB1bmRlZmluZWQ7XG4gIHByaXZhdGUgX2N1c3RvbURhcmtUaGVtZVZhcmlhYmxlczogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSB8IHVuZGVmaW5lZDtcbiAgcHJpdmF0ZSBkZWZhdWx0RGFya01vZGVWYXJpYWJsZXMgPSB7XG4gICAgJy0tYmctZ3JhZGllbnQtZW5kJzogJyMxMDEyMTQnLFxuICAgICctLWJnLWdyYWRpZW50LXN0YXJ0JzogJyMwNzBhMGQnLFxuICAgICctLWJsYWNrJzogJyNmZmZmZmYnLFxuICAgICctLWJsdWUtYWxpY2UnOiAnIzAwMTkzZCcsXG4gICAgJy0tYm9yZGVyJzogJyMxNDE5MjQnLFxuICAgICctLWJ1dHRvbi1iYWNrZ3JvdW5kJzogJyNmZmZmZmYnLFxuICAgICctLWJ1dHRvbi10ZXh0JzogJyMwMDVmZmYnLFxuICAgICctLWdyZXknOiAnIzdhN2E3YScsXG4gICAgJy0tZ3JleS1nYWluc2Jvcm8nOiAnIzJkMmYyZicsXG4gICAgJy0tZ3JleS13aGlzcGVyJzogJyMxYzFlMjInLFxuICAgICctLW1vZGFsLXNoYWRvdyc6ICcjMDAwMDAwJyxcbiAgICAnLS1vdmVybGF5JzogJyMwMDAwMDA2NicsIC8vIDY2ID0gNDAlIG9wYWNpdHlcbiAgICAnLS1vdmVybGF5LWRhcmsnOiAnI2ZmZmZmZmNjJywgLy8gQ0MgPSA4MCUgb3BhY2l0eVxuICAgICctLXNoYWRvdy1pY29uJzogJyMwMDAwMDA4MCcsIC8vIDgwID0gNTAlIG9wYWNpdHlcbiAgICAnLS10YXJnZXRlZE1lc3NhZ2VCYWNrZ3JvdW5kJzogJyMzMDJkMjInLFxuICAgICctLXRyYW5zcGFyZW50JzogJ3RyYW5zcGFyZW50JyxcbiAgICAnLS13aGl0ZSc6ICcjMTAxNDE4JyxcbiAgICAnLS13aGl0ZS1zbW9rZSc6ICcjMTMxNTFiJyxcbiAgICAnLS13aGl0ZS1zbm93JzogJyMwNzBhMGQnLFxuICB9O1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMudGhlbWUkLnN1YnNjcmliZSgodGhlbWUpID0+IHtcbiAgICAgIGNvbnN0IGRhcmtWYXJpYWJsZXMgPSB0aGlzLmN1c3RvbURhcmtUaGVtZVZhcmlhYmxlc1xuICAgICAgICA/IHsgLi4udGhpcy5kZWZhdWx0RGFya01vZGVWYXJpYWJsZXMsIC4uLnRoaXMuY3VzdG9tRGFya1RoZW1lVmFyaWFibGVzIH1cbiAgICAgICAgOiB0aGlzLmRlZmF1bHREYXJrTW9kZVZhcmlhYmxlcztcbiAgICAgIGNvbnN0IGxpZ2h0VmFyaWFibGVzID0gdGhpcy5jdXN0b21MaWdodFRoZW1lVmFyaWFibGVzXG4gICAgICAgID8gdGhpcy5jdXN0b21MaWdodFRoZW1lVmFyaWFibGVzXG4gICAgICAgIDoge307XG4gICAgICBpZiAodGhlbWUgPT09ICdkYXJrJykge1xuICAgICAgICB0aGlzLmRlbGV0ZVZhcmlhYmxlcyhsaWdodFZhcmlhYmxlcyk7XG4gICAgICAgIHRoaXMuc2V0VmFyaWFibGVzKGRhcmtWYXJpYWJsZXMpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5kZWxldGVWYXJpYWJsZXMoZGFya1ZhcmlhYmxlcyk7XG4gICAgICAgIHRoaXMuc2V0VmFyaWFibGVzKGxpZ2h0VmFyaWFibGVzKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIGdldCBjdXN0b21MaWdodFRoZW1lVmFyaWFibGVzKCkge1xuICAgIHJldHVybiB0aGlzLl9jdXN0b21MaWdodFRoZW1lVmFyaWFibGVzO1xuICB9XG5cbiAgc2V0IGN1c3RvbUxpZ2h0VGhlbWVWYXJpYWJsZXMoXG4gICAgdmFyaWFibGVzOiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9IHwgdW5kZWZpbmVkXG4gICkge1xuICAgIGNvbnN0IHByZXZWYXJpYWJsZXMgPSB0aGlzLmN1c3RvbUxpZ2h0VGhlbWVWYXJpYWJsZXM7XG4gICAgdGhpcy5kZWxldGVWYXJpYWJsZXMocHJldlZhcmlhYmxlcyk7XG4gICAgdGhpcy5fY3VzdG9tTGlnaHRUaGVtZVZhcmlhYmxlcyA9IHZhcmlhYmxlcztcbiAgfVxuXG4gIGdldCBjdXN0b21EYXJrVGhlbWVWYXJpYWJsZXMoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2N1c3RvbURhcmtUaGVtZVZhcmlhYmxlcztcbiAgfVxuXG4gIHNldCBjdXN0b21EYXJrVGhlbWVWYXJpYWJsZXMoXG4gICAgdmFyaWFibGVzOiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9IHwgdW5kZWZpbmVkXG4gICkge1xuICAgIGNvbnN0IHByZXZWYXJpYWJsZXMgPSB0aGlzLmN1c3RvbURhcmtUaGVtZVZhcmlhYmxlcztcbiAgICB0aGlzLmRlbGV0ZVZhcmlhYmxlcyhwcmV2VmFyaWFibGVzKTtcbiAgICB0aGlzLl9jdXN0b21EYXJrVGhlbWVWYXJpYWJsZXMgPSB2YXJpYWJsZXM7XG4gIH1cblxuICBwcml2YXRlIGRlbGV0ZVZhcmlhYmxlcyh2YXJpYWJsZXM6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH0gfCB1bmRlZmluZWQpIHtcbiAgICBpZiAoIXZhcmlhYmxlcykge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBPYmplY3Qua2V5cyh2YXJpYWJsZXMpLmZvckVhY2goKGtleSkgPT5cbiAgICAgIGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5zdHlsZS5zZXRQcm9wZXJ0eShrZXksIG51bGwpXG4gICAgKTtcbiAgfVxuXG4gIHByaXZhdGUgc2V0VmFyaWFibGVzKHZhcmlhYmxlczogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSB8IHVuZGVmaW5lZCkge1xuICAgIGlmICghdmFyaWFibGVzKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIE9iamVjdC5rZXlzKHZhcmlhYmxlcykuZm9yRWFjaCgoa2V5KSA9PlxuICAgICAgZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KGtleSwgdmFyaWFibGVzW2tleV0pXG4gICAgKTtcbiAgfVxufVxuIl19
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\n\nexport type Theme = 'light' | 'dark';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ThemeService {\n  theme$ = new BehaviorSubject<Theme>('light');\n  private _customLightThemeVariables: { [key: string]: string } | undefined;\n  private _customDarkThemeVariables: { [key: string]: string } | undefined;\n  private defaultDarkModeVariables = {\n    '--bg-gradient-end': '#101214',\n    '--bg-gradient-start': '#070a0d',\n    '--black': '#ffffff',\n    '--blue-alice': '#00193d',\n    '--border': '#141924',\n    '--button-background': '#ffffff',\n    '--button-text': '#005fff',\n    '--grey': '#7a7a7a',\n    '--grey-gainsboro': '#2d2f2f',\n    '--grey-whisper': '#1c1e22',\n    '--modal-shadow': '#000000',\n    '--overlay': '#00000066', // 66 = 40% opacity\n    '--overlay-dark': '#ffffffcc', // CC = 80% opacity\n    '--shadow-icon': '#00000080', // 80 = 50% opacity\n    '--targetedMessageBackground': '#302d22',\n    '--transparent': 'transparent',\n    '--white': '#101418',\n    '--white-smoke': '#13151b',\n    '--white-snow': '#070a0d',\n  };\n  private variablesToDelete: { [key: string]: string }[] = [];\n\n  constructor() {\n    this.theme$.subscribe((theme) => {\n      const darkVariables = this.customDarkThemeVariables\n        ? { ...this.defaultDarkModeVariables, ...this.customDarkThemeVariables }\n        : this.defaultDarkModeVariables;\n      const lightVariables = this.customLightThemeVariables\n        ? this.customLightThemeVariables\n        : {};\n      this.variablesToDelete.forEach((variables) =>\n        this.deleteVariables(variables)\n      );\n      if (theme === 'dark') {\n        this.deleteVariables(lightVariables);\n        this.setVariables(darkVariables);\n      } else {\n        this.deleteVariables(darkVariables);\n        this.setVariables(lightVariables);\n      }\n    });\n  }\n\n  get customLightThemeVariables() {\n    return this._customLightThemeVariables;\n  }\n\n  set customLightThemeVariables(\n    variables: { [key: string]: string } | undefined\n  ) {\n    const prevVariables = this.customLightThemeVariables;\n    if (prevVariables) {\n      this.variablesToDelete.push(prevVariables);\n    }\n    this._customLightThemeVariables = variables;\n    if (this.theme$.getValue() === 'light') {\n      this.theme$.next('light');\n    }\n  }\n\n  get customDarkThemeVariables() {\n    return this._customDarkThemeVariables;\n  }\n\n  set customDarkThemeVariables(\n    variables: { [key: string]: string } | undefined\n  ) {\n    const prevVariables = this.customDarkThemeVariables;\n    if (prevVariables) {\n      this.variablesToDelete.push(prevVariables);\n    }\n    this._customDarkThemeVariables = variables;\n    if (this.theme$.getValue() === 'dark') {\n      this.theme$.next('dark');\n    }\n  }\n\n  private deleteVariables(variables: { [key: string]: string } | undefined) {\n    if (!variables) {\n      return;\n    }\n    Object.keys(variables).forEach((key) =>\n      document.documentElement.style.setProperty(key, null)\n    );\n  }\n\n  private setVariables(variables: { [key: string]: string } | undefined) {\n    if (!variables) {\n      return;\n    }\n    Object.keys(variables).forEach((key) =>\n      document.documentElement.style.setProperty(key, variables[key])\n    );\n  }\n}\n"]}
@@ -16,7 +16,7 @@ import transliterate from '@stream-io/transliterate';
16
16
  import * as i5 from 'angular-mentions';
17
17
  import { MentionModule } from 'angular-mentions';
18
18
 
19
- const version = '2.12.2';
19
+ const version = '2.12.3';
20
20
 
21
21
  class NotificationService {
22
22
  constructor() {
@@ -871,12 +871,14 @@ class ThemeService {
871
871
  '--white-smoke': '#13151b',
872
872
  '--white-snow': '#070a0d',
873
873
  };
874
+ this.variablesToDelete = [];
874
875
  this.theme$.subscribe((theme) => {
875
876
  const darkVariables = this.customDarkThemeVariables
876
877
  ? Object.assign(Object.assign({}, this.defaultDarkModeVariables), this.customDarkThemeVariables) : this.defaultDarkModeVariables;
877
878
  const lightVariables = this.customLightThemeVariables
878
879
  ? this.customLightThemeVariables
879
880
  : {};
881
+ this.variablesToDelete.forEach((variables) => this.deleteVariables(variables));
880
882
  if (theme === 'dark') {
881
883
  this.deleteVariables(lightVariables);
882
884
  this.setVariables(darkVariables);
@@ -892,16 +894,26 @@ class ThemeService {
892
894
  }
893
895
  set customLightThemeVariables(variables) {
894
896
  const prevVariables = this.customLightThemeVariables;
895
- this.deleteVariables(prevVariables);
897
+ if (prevVariables) {
898
+ this.variablesToDelete.push(prevVariables);
899
+ }
896
900
  this._customLightThemeVariables = variables;
901
+ if (this.theme$.getValue() === 'light') {
902
+ this.theme$.next('light');
903
+ }
897
904
  }
898
905
  get customDarkThemeVariables() {
899
906
  return this._customDarkThemeVariables;
900
907
  }
901
908
  set customDarkThemeVariables(variables) {
902
909
  const prevVariables = this.customDarkThemeVariables;
903
- this.deleteVariables(prevVariables);
910
+ if (prevVariables) {
911
+ this.variablesToDelete.push(prevVariables);
912
+ }
904
913
  this._customDarkThemeVariables = variables;
914
+ if (this.theme$.getValue() === 'dark') {
915
+ this.theme$.next('dark');
916
+ }
905
917
  }
906
918
  deleteVariables(variables) {
907
919
  if (!variables) {