From 551d435f898d764ec190fc445ca45c0c0eb4fdb7 Mon Sep 17 00:00:00 2001 From: Julius Härtl Date: Tue, 18 Aug 2020 14:11:02 +0200 Subject: Make it possible to define theme header styling per background MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Julius Härtl --- apps/dashboard/css/dashboard.scss | 71 ++++++++++++++++++++++ .../lib/Controller/DashboardController.php | 1 + apps/dashboard/lib/Service/BackgroundService.php | 1 + apps/dashboard/src/App.vue | 41 +++++++------ 4 files changed, 94 insertions(+), 20 deletions(-) create mode 100644 apps/dashboard/css/dashboard.scss diff --git a/apps/dashboard/css/dashboard.scss b/apps/dashboard/css/dashboard.scss new file mode 100644 index 00000000000..a320b3e3c99 --- /dev/null +++ b/apps/dashboard/css/dashboard.scss @@ -0,0 +1,71 @@ +// Show Dashboard background image beneath header +#body-user #header { + background-size: cover !important; + background-position: center 50% !important; + background-repeat: no-repeat !important; + background-attachment: fixed !important; +} + +#content { + padding-top: 0 !important; +} + +// Hide triangle indicators from navigation since they are out of place without the header bar +#appmenu li a.active::before, +#appmenu li:hover a::before, +#appmenu li:hover a.active::before, +#appmenu li a:focus::before { + display: none !important; +} + +$has-custom-logo: variable_exists('theming-logo-mime') and $theming-logo-mime != ''; + +body.dashboard-inverted:not(.dashboard-dark) { + // Do not invert the default logo + @if ($has-custom-logo == false) { + $image-logo: url(icon-color-path('logo', 'logo', #ffffff, 1, true)); + #header .logo { + background-image: $image-logo !important; + opacity: 1; + } + } + + #app-dashboard > h2 { + color: #fff; + } + #appmenu li span { + color: #fff; + } + #appmenu svg image { + filter: invert(0); + } + #appmenu .icon-more-white, + .header-right > div:not(#settings) > * { + filter: invert(1) hue-rotate(180deg); + } +} + +body.dashboard-dark:not(.dashboard-inverted) { + // invert the default logo + @if ($has-custom-logo == false) { + $image-logo: url(icon-color-path('logo', 'logo', #000000, 1, true)); + #header .logo { + background-image: $image-logo !important; + opacity: 1; + } + } + + #app-dashboard > h2 { + color: #000; + } + #appmenu li span { + color: #000; + } + #appmenu svg { + filter: invert(1) !important; + } + #appmenu .icon-more-white, + .header-right > div:not(#settings) > * { + filter: invert(1) hue-rotate(180deg); + } +} diff --git a/apps/dashboard/lib/Controller/DashboardController.php b/apps/dashboard/lib/Controller/DashboardController.php index 3f4c9fdbfa4..95656b260e8 100644 --- a/apps/dashboard/lib/Controller/DashboardController.php +++ b/apps/dashboard/lib/Controller/DashboardController.php @@ -87,6 +87,7 @@ class DashboardController extends Controller { * @return TemplateResponse */ public function index(): TemplateResponse { + \OCP\Util::addStyle('dashboard', 'dashboard'); $this->eventDispatcher->dispatchTyped(new LoadSidebar()); if (class_exists(LoadViewer::class)) { $this->eventDispatcher->dispatchTyped(new LoadViewer()); diff --git a/apps/dashboard/lib/Service/BackgroundService.php b/apps/dashboard/lib/Service/BackgroundService.php index 30e9d9fe3cb..4e154dd0170 100644 --- a/apps/dashboard/lib/Service/BackgroundService.php +++ b/apps/dashboard/lib/Service/BackgroundService.php @@ -47,6 +47,7 @@ class BackgroundService { 'bernie-cetonia-aurata-take-off-composition.jpg' => [ 'attribution' => '', 'attribution_url' => '', + 'theming' => self::THEMING_MODE_DARK, ], 'dejan-krsmanovic-ribbed-red-metal.jpg' => [ 'attribution' => '', diff --git a/apps/dashboard/src/App.vue b/apps/dashboard/src/App.vue index c59e4732373..a2cccfce3ff 100644 --- a/apps/dashboard/src/App.vue +++ b/apps/dashboard/src/App.vue @@ -4,8 +4,9 @@
+ :key="status"> +
+
{ this.timer = new Date() }, 30000) @@ -268,31 +272,26 @@ export default { updateBackground(data) { this.background = data.type === 'custom' || data.type === 'default' ? data.type : data.value this.version = data.version + this.updateGlobalStyles() + }, + updateGlobalStyles() { + if (window.OCA.Theming.inverted) { + document.body.classList.add('dashboard-inverted') + } + + const shippedBackgroundTheme = shippedBackgroundList[this.background] ? shippedBackgroundList[this.background].theming : 'light' + if (shippedBackgroundTheme === 'dark') { + document.body.classList.add('dashboard-dark') + } else { + document.body.classList.remove('dashboard-dark') + } }, }, }