From 8f1ea5c3ef2f6c53049ee9d3bd42aa147ea1d1e9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pau=20Ferrer=20Oca=C3=B1a?= Date: Mon, 15 Mar 2021 18:30:31 +0100 Subject: [PATCH] MOBILE-3635 settings: Improve color scheme preference detection --- src/core/features/settings/lang.json | 3 +- .../settings/pages/general/general.html | 6 ++- .../settings/pages/general/general.ts | 12 ++---- .../settings/services/settings-helper.ts | 41 ++++++++++++++++++- src/theme/theme.base.scss | 14 +++++++ 5 files changed, 64 insertions(+), 12 deletions(-) diff --git a/src/core/features/settings/lang.json b/src/core/features/settings/lang.json index 96673bccc..9252a449f 100644 --- a/src/core/features/settings/lang.json +++ b/src/core/features/settings/lang.json @@ -6,7 +6,8 @@ "cannotsyncoffline": "Cannot synchronise offline.", "cannotsyncwithoutwifi": "Cannot synchronise because the current settings only allow to synchronise when connected to Wi-Fi. Please connect to a Wi-Fi network.", "colorscheme": "Color Scheme", - "colorscheme-auto": "Auto (based on system settings)", + "colorscheme-system": "System default", + "colorscheme-system-notice": "System default mode will depend on your device support.", "colorscheme-dark": "Dark", "colorscheme-light": "Light", "compilationinfo": "Compilation info", diff --git a/src/core/features/settings/pages/general/general.html b/src/core/features/settings/pages/general/general.html index d7689e890..5cd2ad929 100644 --- a/src/core/features/settings/pages/general/general.html +++ b/src/core/features/settings/pages/general/general.html @@ -32,7 +32,8 @@ - +

{{ 'core.settings.colorscheme' | translate }}

{{ 'core.settings.forcedsetting' | translate }}

@@ -43,6 +44,9 @@ {{ 'core.settings.colorscheme-' + scheme | translate }}
+ +

{{ 'core.settings.colorscheme-system-notice' | translate }}

+

{{ 'core.settings.enablerichtexteditor' | translate }}

diff --git a/src/core/features/settings/pages/general/general.ts b/src/core/features/settings/pages/general/general.ts index 9ac33264d..ff2270908 100644 --- a/src/core/features/settings/pages/general/general.ts +++ b/src/core/features/settings/pages/general/general.ts @@ -20,6 +20,7 @@ import { CoreLang } from '@services/lang'; import { CoreDomUtils } from '@services/utils/dom'; import { CorePushNotifications } from '@features/pushnotifications/services/pushnotifications'; import { CoreSettingsHelper, CoreColorScheme, CoreZoomLevel } from '../../services/settings-helper'; +import { CoreApp } from '@services/app'; /** * Page that displays the general settings. @@ -42,6 +43,7 @@ export class CoreSettingsGeneralPage { colorSchemes: CoreColorScheme[] = []; selectedScheme: CoreColorScheme = CoreColorScheme.LIGHT; colorSchemeDisabled = false; + isAndroid = false; constructor() { this.asyncInit(); @@ -72,14 +74,8 @@ export class CoreSettingsGeneralPage { this.colorSchemes.push(CoreColorScheme.LIGHT); this.selectedScheme = this.colorSchemes[0]; } else { - this.colorSchemes.push(CoreColorScheme.LIGHT); - this.colorSchemes.push(CoreColorScheme.DARK); - - if (window.matchMedia('(prefers-color-scheme: dark)').matches || - window.matchMedia('(prefers-color-scheme: light)').matches) { - this.colorSchemes.push(CoreColorScheme.AUTO); - } - + this.isAndroid = CoreApp.isAndroid(); + this.colorSchemes = CoreSettingsHelper.getAllowedColorSchemes(); this.selectedScheme = await CoreConfig.get(CoreConstants.SETTINGS_COLOR_SCHEME, CoreColorScheme.LIGHT); } } diff --git a/src/core/features/settings/services/settings-helper.ts b/src/core/features/settings/services/settings-helper.ts index 074433da2..6bbe6e12c 100644 --- a/src/core/features/settings/services/settings-helper.ts +++ b/src/core/features/settings/services/settings-helper.ts @@ -43,7 +43,7 @@ export interface CoreSiteSpaceUsage { * Constants to define color schemes. */ export const enum CoreColorScheme { - AUTO = 'auto', + SYSTEM = 'system', LIGHT = 'light', DARK = 'dark', } @@ -65,6 +65,7 @@ export class CoreSettingsHelperProvider { protected syncPromises: { [s: string]: Promise } = {}; protected prefersDark?: MediaQueryList; + protected colorSchemes: CoreColorScheme[] = []; constructor() { if (!CoreConstants.CONFIG.forceColorScheme) { @@ -404,13 +405,37 @@ export class CoreSettingsHelperProvider { document.documentElement.style.zoom = zoom + '%'; } + /** + * Get system allowed color schemes. + * + * @return Allowed color schemes. + */ + getAllowedColorSchemes(): CoreColorScheme[] { + if (this.colorSchemes.length > 0) { + return this.colorSchemes; + } + + if (!CoreConstants.CONFIG.forceColorScheme) { + this.colorSchemes.push(CoreColorScheme.LIGHT); + this.colorSchemes.push(CoreColorScheme.DARK); + + if (this.canIUsePrefersColorScheme()) { + this.colorSchemes.push(CoreColorScheme.SYSTEM); + } + } else { + this.colorSchemes = [CoreConstants.CONFIG.forceColorScheme]; + } + + return this.colorSchemes; + } + /** * Set body color scheme. * * @param colorScheme Name of the color scheme. */ setColorScheme(colorScheme: CoreColorScheme): void { - if (colorScheme == CoreColorScheme.AUTO && this.prefersDark) { + if (colorScheme == CoreColorScheme.SYSTEM && this.prefersDark) { // Listen for changes to the prefers-color-scheme media query. this.prefersDark.addEventListener('change', this.toggleDarkModeListener); @@ -423,6 +448,18 @@ export class CoreSettingsHelperProvider { } } + /** + * Check if device can detect color scheme system preference. + * https://caniuse.com/prefers-color-scheme + * + * @returns if the color scheme system preference is avalaible. + */ + canIUsePrefersColorScheme(): boolean { + // The following check will check browser support but system may differ from that. + // @todo Detect SO support to watch media query. + return window.matchMedia('(prefers-color-scheme)').media !== 'not all'; + } + /** * Listener function to toggle dark mode. * diff --git a/src/theme/theme.base.scss b/src/theme/theme.base.scss index 34ec0ce08..641e22700 100644 --- a/src/theme/theme.base.scss +++ b/src/theme/theme.base.scss @@ -52,6 +52,15 @@ ion-item.ion-text-wrap ion-label { } } +@each $color-name, $value in $colors { + $value: map-get($colors, $color-name); + $base: map-get($value, base); + + .text-#{$color-name}, + p.text-#{$color-name} { + color: $base; + } +} // Ionic toolbar. ion-toolbar ion-back-button, @@ -466,3 +475,8 @@ ion-button.core-button-select { display: none !important; } } + +// Hide virtual utilities. +.core-browser-copy-area { + display: none; +}