Skip to content

Commit

Permalink
Fix Dev UI Theme switch
Browse files Browse the repository at this point in the history
Signed-off-by: Phillip Kruger <phillip.kruger@gmail.com>
  • Loading branch information
phillip-kruger committed Aug 6, 2024
1 parent b5231da commit 7d1b7eb
Show file tree
Hide file tree
Showing 3 changed files with 103 additions and 115 deletions.
2 changes: 1 addition & 1 deletion bom/dev-ui/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
<description>Dependency management for dev-ui. Importable by third party extension developers.</description>

<properties>
<vaadin.version>24.4.4</vaadin.version>
<vaadin.version>24.4.5</vaadin.version>
<lit.version>3.1.4</lit.version>
<lit-element.version>4.0.6</lit-element.version>
<lit-html.version>3.1.4</lit-html.version>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,22 +1,18 @@
import { LitElement, html, css } from 'lit';
import { RouterController } from 'router-controller';
import { StorageController } from 'storage-controller';
import { notifier } from 'notifier';
import { observeState } from 'lit-element-state';
import { themeState } from 'theme-state';
import { devuiState } from 'devui-state';
import '@vaadin/menu-bar';
import '@vaadin/tabs';
import '@vaadin/button';
import 'qwc/qwc-extension-link.js';

import './qwc-theme-switch.js';
/**
* This component represent the Dev UI Header
*/
export class QwcHeader extends observeState(LitElement) {

routerController = new RouterController(this);
storageControl = new StorageController(this);

static styles = css`
Expand All @@ -31,7 +27,7 @@ export class QwcHeader extends observeState(LitElement) {
display: flex;
justify-content: space-around;
align-items: center;
padding-right: 60px;
padding-right: 10px;
}
.logo-title {
Expand Down Expand Up @@ -88,13 +84,6 @@ export class QwcHeader extends observeState(LitElement) {
align-items: center;
}
.themeDropdown {
position: absolute;
right: 0px;
top: 10px;
z-index: 3;
}
.hidden {
display:none;
}
Expand All @@ -103,10 +92,7 @@ export class QwcHeader extends observeState(LitElement) {
static properties = {
_title: {state: true},
_subTitle: {state: true},
_rightSideNav: {state: true},
_selectedTheme: {state: true},
_themeOptions: {state: true},
_desktopTheme: {state: true}
_rightSideNav: {state: true}
};

constructor() {
Expand All @@ -115,45 +101,13 @@ export class QwcHeader extends observeState(LitElement) {
this._subTitle = null;
this._rightSideNav = "";

this._createThemeItems();
this._restoreThemePreference();
this._createThemeOptions();

window.addEventListener('vaadin-router-location-changed', (event) => {
this._updateHeader(event);
});
}

connectedCallback() {
super.connectedCallback();
// Get desktop theme setting
this._desktopTheme = "dark";
if(window.matchMedia){
if(window.matchMedia('(prefers-color-scheme: light)').matches){
this._desktopTheme = "light";
}

// Change theme setting when OS theme change
window.matchMedia('(prefers-color-scheme: light)').addEventListener('change', e => {
if(e.matches){
this._desktopTheme = "light";
}else{
this._desktopTheme = "dark";
}
this._changeToSelectedTheme();
});
}

this._changeToSelectedTheme();
}

_restoreThemePreference() {
const storedValue = this.storageControl.get("theme-preference");
if(storedValue){
this._selectedTheme = storedValue;
}else {
this._selectedTheme = "desktop";
}
}

render() {
Expand Down Expand Up @@ -197,71 +151,7 @@ export class QwcHeader extends observeState(LitElement) {
}

_renderThemeOptions(){
return html`<vaadin-menu-bar theme="tertiary-inline" class="themeDropdown"
.items="${this._themeOptions}"
@item-selected="${(e) => this._changeThemeOption(e)}">
</vaadin-menu-bar>`;
}

_changeThemeOption(e){
this._selectedTheme = e.detail.value.name;
this._createThemeOptions();
this._changeToSelectedTheme();
this.storageControl.set('theme-preference', this._selectedTheme);
}

_changeToSelectedTheme(){
if(this._selectedTheme === "desktop"){
themeState.changeTo(this._desktopTheme);
}else {
themeState.changeTo(this._selectedTheme);
}
}

_createThemeOptions(){

let selectedComponent = this._desktopThemeItem;
if(this._selectedTheme === "dark"){
selectedComponent = this._darkThemeItem;
}else if(this._selectedTheme === "light"){
selectedComponent = this._lightThemeItem;
}

this._themeOptions = [
{
component: selectedComponent,
children: [
{
component: this._darkThemeItem,
name: "dark"
},
{
component: this._lightThemeItem,
name: "light"
},
{
component: this._desktopThemeItem,
name: "desktop"
}
]
}

];
}

_createThemeItems() {
this._darkThemeItem = this._createThemeItem("moon", "dark");
this._lightThemeItem = this._createThemeItem("sun", "light");
this._desktopThemeItem = this._createThemeItem("desktop", "desktop");
}

_createThemeItem(iconName, ariaLabel) {
const item = document.createElement('vaadin-context-menu-item');
const icon = document.createElement('vaadin-icon');
item.setAttribute('aria-label', ariaLabel);
icon.setAttribute('icon', `font-awesome-solid:${iconName}`);
item.appendChild(icon);
return item;
return html`<qwc-theme-switch></qwc-theme-switch>`;
}

_updateHeader(event){
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
import { LitElement, html, css } from 'lit';
import { themeState } from 'theme-state';
import { StorageController } from 'storage-controller';
import '@vaadin/button';

/**
* Basic theme switch
*/
export class QwcThemeSwitch extends LitElement {
storageControl = new StorageController(this);

themes = [
{ id: 0, name: 'Desktop', icon: 'font-awesome-solid:desktop' },
{ id: 1, name: 'Light', icon: 'font-awesome-solid:sun' },
{ id: 2, name: 'Dark', icon: 'font-awesome-solid:moon' }
];

static styles = css`
.themeButton {
padding-left: 10px;
}
.button {
--vaadin-button-background: var(--lumo-base-color);
}
`;

static properties = {
_selectedThemeIndex: {state: true},
};

constructor() {
super();
this._restoreThemePreference();
}

connectedCallback() {
super.connectedCallback();
this._desktopTheme = "dark"; // default
if(window.matchMedia){
if(window.matchMedia('(prefers-color-scheme: light)').matches){
this._desktopTheme = "light";
}

// Change theme setting when OS theme change
window.matchMedia('(prefers-color-scheme: light)').addEventListener('change', e => {
if(e.matches){
this._desktopTheme = "light";
}else{
this._desktopTheme = "dark";
}
if(this._selectedThemeIndex===0){
this._changeToSelectedThemeIndex();
}
});
}

this._changeToSelectedThemeIndex();
}

render() {
let theme = this.themes[this._selectedThemeIndex];

return html`<div class="themeButton">
<vaadin-button theme="icon" aria-label="${theme.name}" title="${theme.name} theme" class="button" @click="${this._nextTheme}">
<vaadin-icon icon="${theme.icon}"></vaadin-icon>
</vaadin-button>
</div>`;
}

_nextTheme(e){
this._selectedThemeIndex = (this._selectedThemeIndex + 1) % this.themes.length;
this._changeToSelectedThemeIndex();
}

_changeToSelectedThemeIndex(){
let theme = this.themes[this._selectedThemeIndex];
this.storageControl.set('theme-preference', theme.id);

if(theme.id === 0){ // Desktop
themeState.changeTo(this._desktopTheme);
}else {
themeState.changeTo(theme.name.toLowerCase());
}

}

_restoreThemePreference() {
const storedValue = this.storageControl.get("theme-preference");
if(storedValue){
this._selectedThemeIndex = storedValue;
} else {
this._selectedThemeIndex = 0;
}
}


}
customElements.define('qwc-theme-switch', QwcThemeSwitch);

0 comments on commit 7d1b7eb

Please sign in to comment.