mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-26 17:24:56 +00:00
* start custom theming adf * demo shell cleaning * login mdl cleaning * uploader mdl cleaning * prebuilt themes * theme picker in demo shell * clean custom colors and mdl * fix rebase errors * theming from color style guide * dev default theme orange purple * fix color accent inverted in picker * fix test and add colors classes * fix tag component theming issues * fix datatable theming * add theming guides
40 lines
887 B
TypeScript
40 lines
887 B
TypeScript
import {EventEmitter, Injectable} from '@angular/core';
|
|
|
|
export interface DocsSiteTheme {
|
|
href: string;
|
|
name: string;
|
|
accent: string;
|
|
primary: string;
|
|
isDark?: boolean;
|
|
isDefault?: boolean;
|
|
}
|
|
|
|
@Injectable()
|
|
export class ThemeStorage {
|
|
static storageKey = 'docs-theme-storage-current';
|
|
|
|
public onThemeUpdate: EventEmitter<DocsSiteTheme> = new EventEmitter<DocsSiteTheme>();
|
|
|
|
public storeTheme(theme: DocsSiteTheme) {
|
|
try {
|
|
window.localStorage[ThemeStorage.storageKey] = JSON.stringify(theme);
|
|
} catch (e) { }
|
|
|
|
this.onThemeUpdate.emit(theme);
|
|
}
|
|
|
|
public getStoredTheme(): DocsSiteTheme {
|
|
try {
|
|
return JSON.parse(window.localStorage[ThemeStorage.storageKey] || null);
|
|
} catch (e) {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
public clearStorage() {
|
|
try {
|
|
window.localStorage.removeItem(ThemeStorage.storageKey);
|
|
} catch (e) { }
|
|
}
|
|
}
|