mirror of
https://github.com/nextcloud/server.git
synced 2026-06-13 18:50:47 -04:00
Merge pull request #36348 from nextcloud/bugfix/noid/fix-primary-color-usage-in-emails-and-federation
Fix primary color usage in emails and federation
This commit is contained in:
commit
de415fbb15
5 changed files with 53 additions and 30 deletions
|
|
@ -1,4 +1,7 @@
|
|||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
/**
|
||||
* @copyright Copyright (c) 2017 Arthur Schiwon <blizzz@arthur-schiwon.de>
|
||||
*
|
||||
|
|
@ -29,7 +32,7 @@ namespace OCA\FederatedFileSharing\Settings;
|
|||
use OCA\FederatedFileSharing\FederatedShareProvider;
|
||||
use OCP\AppFramework\Http\TemplateResponse;
|
||||
use OCP\AppFramework\Services\IInitialState;
|
||||
use OCP\IL10N;
|
||||
use OCP\Defaults;
|
||||
use OCP\IUserSession;
|
||||
use OCP\IURLGenerator;
|
||||
use OCP\Settings\ISettings;
|
||||
|
|
@ -37,22 +40,19 @@ use OCP\Settings\ISettings;
|
|||
class Personal implements ISettings {
|
||||
private FederatedShareProvider $federatedShareProvider;
|
||||
private IUserSession $userSession;
|
||||
private IL10N $l;
|
||||
private \OC_Defaults $defaults;
|
||||
private Defaults $defaults;
|
||||
private IInitialState $initialState;
|
||||
private IURLGenerator $urlGenerator;
|
||||
|
||||
public function __construct(
|
||||
FederatedShareProvider $federatedShareProvider, #
|
||||
FederatedShareProvider $federatedShareProvider,
|
||||
IUserSession $userSession,
|
||||
IL10N $l,
|
||||
\OC_Defaults $defaults,
|
||||
Defaults $defaults,
|
||||
IInitialState $initialState,
|
||||
IURLGenerator $urlGenerator
|
||||
) {
|
||||
$this->federatedShareProvider = $federatedShareProvider;
|
||||
$this->userSession = $userSession;
|
||||
$this->l = $l;
|
||||
$this->defaults = $defaults;
|
||||
$this->initialState = $initialState;
|
||||
$this->urlGenerator = $urlGenerator;
|
||||
|
|
@ -62,35 +62,25 @@ class Personal implements ISettings {
|
|||
* @return TemplateResponse returns the instance with all parameters set, ready to be rendered
|
||||
* @since 9.1
|
||||
*/
|
||||
public function getForm() {
|
||||
public function getForm(): TemplateResponse {
|
||||
$cloudID = $this->userSession->getUser()->getCloudId();
|
||||
$url = 'https://nextcloud.com/sharing#' . $cloudID;
|
||||
|
||||
$parameters = [
|
||||
'message_with_URL' => $this->l->t('Share with me through my #Nextcloud Federated Cloud ID, see %s', [$url]),
|
||||
'message_without_URL' => $this->l->t('Share with me through my #Nextcloud Federated Cloud ID', [$cloudID]),
|
||||
'logoPath' => $this->defaults->getLogo(),
|
||||
'reference' => $url,
|
||||
'cloudId' => $cloudID,
|
||||
'color' => $this->defaults->getColorPrimary(),
|
||||
'textColor' => "#ffffff",
|
||||
];
|
||||
|
||||
$this->initialState->provideInitialState('color', $this->defaults->getColorPrimary());
|
||||
$this->initialState->provideInitialState('textColor', '#fffff');
|
||||
$this->initialState->provideInitialState('color', $this->defaults->getDefaultColorPrimary());
|
||||
$this->initialState->provideInitialState('textColor', $this->defaults->getDefaultTextColorPrimary());
|
||||
$this->initialState->provideInitialState('logoPath', $this->defaults->getLogo());
|
||||
$this->initialState->provideInitialState('reference', $url);
|
||||
$this->initialState->provideInitialState('cloudId', $cloudID);
|
||||
$this->initialState->provideInitialState('docUrlFederated', $this->urlGenerator->linkToDocs('user-sharing-federated'));
|
||||
|
||||
return new TemplateResponse('federatedfilesharing', 'settings-personal', $parameters, '');
|
||||
return new TemplateResponse('federatedfilesharing', 'settings-personal', [], TemplateResponse::RENDER_AS_BLANK);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string the section ID, e.g. 'sharing'
|
||||
* @since 9.1
|
||||
*/
|
||||
public function getSection() {
|
||||
public function getSection(): ?string {
|
||||
if ($this->federatedShareProvider->isIncomingServer2serverShareEnabled() ||
|
||||
$this->federatedShareProvider->isIncomingServer2serverGroupShareEnabled()) {
|
||||
return 'sharing';
|
||||
|
|
@ -106,7 +96,7 @@ class Personal implements ISettings {
|
|||
* E.g.: 70
|
||||
* @since 9.1
|
||||
*/
|
||||
public function getPriority() {
|
||||
public function getPriority(): int {
|
||||
return 40;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -496,6 +496,15 @@ class ThemingDefaults extends \OC_Defaults {
|
|||
return $this->util->invertTextColor($this->getColorPrimary()) ? '#000000' : '#ffffff';
|
||||
}
|
||||
|
||||
/**
|
||||
* Color of text in the header and primary buttons
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getDefaultTextColorPrimary() {
|
||||
return $this->util->invertTextColor($this->getDefaultColorPrimary()) ? '#000000' : '#ffffff';
|
||||
}
|
||||
|
||||
/**
|
||||
* Has the admin disabled user customization
|
||||
*/
|
||||
|
|
|
|||
|
|
@ -380,7 +380,7 @@ EOF;
|
|||
$this->headerAdded = true;
|
||||
|
||||
$logoUrl = $this->urlGenerator->getAbsoluteURL($this->themingDefaults->getLogo(false));
|
||||
$this->htmlBody .= vsprintf($this->header, [$this->themingDefaults->getColorPrimary(), $logoUrl, $this->themingDefaults->getName()]);
|
||||
$this->htmlBody .= vsprintf($this->header, [$this->themingDefaults->getDefaultColorPrimary(), $logoUrl, $this->themingDefaults->getName()]);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -555,7 +555,7 @@ EOF;
|
|||
$this->ensureBodyIsOpened();
|
||||
$this->ensureBodyListClosed();
|
||||
|
||||
$color = $this->themingDefaults->getColorPrimary();
|
||||
$color = $this->themingDefaults->getDefaultColorPrimary();
|
||||
$textColor = $this->themingDefaults->getTextColorPrimary();
|
||||
|
||||
$this->htmlBody .= vsprintf($this->buttonGroup, [$color, $color, $urlLeft, $color, $textColor, $textColor, $textLeft, $urlRight, $textRight]);
|
||||
|
|
@ -586,7 +586,7 @@ EOF;
|
|||
$text = htmlspecialchars($text);
|
||||
}
|
||||
|
||||
$color = $this->themingDefaults->getColorPrimary();
|
||||
$color = $this->themingDefaults->getDefaultColorPrimary();
|
||||
$textColor = $this->themingDefaults->getTextColorPrimary();
|
||||
$this->htmlBody .= vsprintf($this->button, [$color, $color, $url, $color, $textColor, $textColor, $text]);
|
||||
|
||||
|
|
|
|||
|
|
@ -205,6 +205,18 @@ class Defaults {
|
|||
return $this->defaults->getColorPrimary();
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the default color primary
|
||||
* @return string
|
||||
* @since 25.0.4
|
||||
*/
|
||||
public function getDefaultColorPrimary(): string {
|
||||
if (method_exists($this->defaults, 'getDefaultColorPrimary')) {
|
||||
return $this->defaults->getDefaultColorPrimary();
|
||||
}
|
||||
return $this->defaults->getColorPrimary();
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $key
|
||||
* @return string URL to doc with key
|
||||
|
|
@ -231,4 +243,16 @@ class Defaults {
|
|||
public function getTextColorPrimary(): string {
|
||||
return $this->defaults->getTextColorPrimary();
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns primary color
|
||||
* @return string
|
||||
* @since 25.0.4
|
||||
*/
|
||||
public function getDefaultTextColorPrimary(): string {
|
||||
if (method_exists($this->defaults, 'getDefaultTextColorPrimary')) {
|
||||
return $this->defaults->getDefaultTextColorPrimary();
|
||||
}
|
||||
return $this->defaults->getTextColorPrimary();
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -63,7 +63,7 @@ class EMailTemplateTest extends TestCase {
|
|||
public function testEMailTemplateCustomFooter() {
|
||||
$this->defaults
|
||||
->expects($this->any())
|
||||
->method('getColorPrimary')
|
||||
->method('getDefaultColorPrimary')
|
||||
->willReturn('#0082c9');
|
||||
$this->defaults
|
||||
->expects($this->any())
|
||||
|
|
@ -104,7 +104,7 @@ class EMailTemplateTest extends TestCase {
|
|||
public function testEMailTemplateDefaultFooter() {
|
||||
$this->defaults
|
||||
->expects($this->any())
|
||||
->method('getColorPrimary')
|
||||
->method('getDefaultColorPrimary')
|
||||
->willReturn('#0082c9');
|
||||
$this->defaults
|
||||
->expects($this->any())
|
||||
|
|
@ -147,7 +147,7 @@ class EMailTemplateTest extends TestCase {
|
|||
public function testEMailTemplateSingleButton() {
|
||||
$this->defaults
|
||||
->expects($this->any())
|
||||
->method('getColorPrimary')
|
||||
->method('getDefaultColorPrimary')
|
||||
->willReturn('#0082c9');
|
||||
$this->defaults
|
||||
->expects($this->any())
|
||||
|
|
@ -192,7 +192,7 @@ class EMailTemplateTest extends TestCase {
|
|||
public function testEMailTemplateAlternativePlainTexts() {
|
||||
$this->defaults
|
||||
->expects($this->any())
|
||||
->method('getColorPrimary')
|
||||
->method('getDefaultColorPrimary')
|
||||
->willReturn('#0082c9');
|
||||
$this->defaults
|
||||
->expects($this->any())
|
||||
|
|
|
|||
Loading…
Reference in a new issue