diff options
author | Ferdinand Thiessen <opensource@fthiessen.de> | 2023-12-15 16:14:37 +0100 |
---|---|---|
committer | Ferdinand Thiessen <opensource@fthiessen.de> | 2023-12-19 11:33:15 +0100 |
commit | bb5523097f10bf380f7893070d5bd1c60109521d (patch) | |
tree | 0f8d4c6f23c2c73171e64795e826a036b2277b88 | |
parent | 8ff08d5a0ab60b560b39c9a5b8f397a09d9751b3 (diff) | |
download | nextcloud-server-bb5523097f10bf380f7893070d5bd1c60109521d.tar.gz nextcloud-server-bb5523097f10bf380f7893070d5bd1c60109521d.zip |
fix(theming): Adjust primary text color calculation to also work with high contrast themes
Signed-off-by: Ferdinand Thiessen <opensource@fthiessen.de>
-rw-r--r-- | apps/theming/css/default.css | 4 | ||||
-rw-r--r-- | apps/theming/lib/Themes/CommonThemeTrait.php | 7 | ||||
-rw-r--r-- | apps/theming/tests/Themes/AccessibleThemeTestCase.php | 12 |
3 files changed, 15 insertions, 8 deletions
diff --git a/apps/theming/css/default.css b/apps/theming/css/default.css index 4119d370f08..e9388e6ab60 100644 --- a/apps/theming/css/default.css +++ b/apps/theming/css/default.css @@ -77,9 +77,9 @@ --color-primary-light-text: #00293f; --color-primary-light-hover: #dbe4ea; --color-primary-element: #00679e; - --color-primary-element-hover: #1070a4; + --color-primary-element-hover: #005a8a; --color-primary-element-text: #ffffff; - --color-primary-element-text-dark: #f0f0f0; + --color-primary-element-text-dark: #f5f5f5; --color-primary-element-light: #e5eff5; --color-primary-element-light-hover: #dbe4ea; --color-primary-element-light-text: #00293f; diff --git a/apps/theming/lib/Themes/CommonThemeTrait.php b/apps/theming/lib/Themes/CommonThemeTrait.php index 38ca760db9f..85172f1e9bc 100644 --- a/apps/theming/lib/Themes/CommonThemeTrait.php +++ b/apps/theming/lib/Themes/CommonThemeTrait.php @@ -43,6 +43,7 @@ trait CommonThemeTrait { $colorPrimaryElement = $this->util->elementColor($this->primaryColor, $isBrightColor, $colorMainBackground); $colorPrimaryLight = $this->util->mix($colorPrimaryElement, $colorMainBackground, -80); $colorPrimaryElementLight = $this->util->mix($colorPrimaryElement, $colorMainBackground, -80); + $invertPrimaryTextColor = $this->util->invertTextColor($colorPrimaryElement); // primary related colours return [ @@ -66,10 +67,10 @@ trait CommonThemeTrait { // used for buttons, inputs... '--color-primary-element' => $colorPrimaryElement, - '--color-primary-element-hover' => $this->util->mix($colorPrimaryElement, $colorMainBackground, 87), - '--color-primary-element-text' => $this->util->invertTextColor($colorPrimaryElement) ? '#000000' : '#ffffff', + '--color-primary-element-hover' => $invertPrimaryTextColor ? $this->util->lighten($colorPrimaryElement, 4) : $this->util->darken($colorPrimaryElement, 4), + '--color-primary-element-text' => $invertPrimaryTextColor ? '#000000' : '#ffffff', // mostly used for disabled states - '--color-primary-element-text-dark' => $this->util->darken($this->util->invertTextColor($colorPrimaryElement) ? '#000000' : '#ffffff', 6), + '--color-primary-element-text-dark' => $invertPrimaryTextColor ? $this->util->lighten('#000000', 4) : $this->util->darken('#ffffff', 4), // used for hover/focus states '--color-primary-element-light' => $colorPrimaryElementLight, diff --git a/apps/theming/tests/Themes/AccessibleThemeTestCase.php b/apps/theming/tests/Themes/AccessibleThemeTestCase.php index 6c31506999d..29ad8cfaff2 100644 --- a/apps/theming/tests/Themes/AccessibleThemeTestCase.php +++ b/apps/theming/tests/Themes/AccessibleThemeTestCase.php @@ -47,7 +47,10 @@ class AccessibleThemeTestCase extends TestCase { 3.0, ], 'primary-element-text' => [ - ['--color-primary-element-text'], + [ + '--color-primary-element-text', + '--color-primary-element-text-dark', + ], [ '--color-primary-element', '--color-primary-element-hover', @@ -96,8 +99,11 @@ class AccessibleThemeTestCase extends TestCase { * @dataProvider dataAccessibilityPairs */ public function testAccessibilityOfVariables($mainColors, $backgroundColors, $minContrast) { - $this->assertNotNull($this->theme, 'You need to setup $this->theme in your setUp function'); - $this->assertNotNull($this->util, 'You need to setup $this->util in your setUp function'); + if (!isset($this->theme)) { + $this->markTestSkipped('You need to setup $this->theme in your setUp function'); + } elseif (!isset($this->util)) { + $this->markTestSkipped('You need to setup $this->util in your setUp function'); + } $variables = $this->theme->getCSSVariables(); |