adjust Theming app
This commit is contained in:
parent
6a35c7d124
commit
3ae0a380ae
|
@ -23,8 +23,6 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
\OCP\App::registerAdmin('theming', 'settings/settings-admin');
|
|
||||||
|
|
||||||
$linkToCSS = \OC::$server->getURLGenerator()->linkToRoute(
|
$linkToCSS = \OC::$server->getURLGenerator()->linkToRoute(
|
||||||
'theming.Theming.getStylesheet',
|
'theming.Theming.getStylesheet',
|
||||||
[
|
[
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<description>Adjust the Nextcloud theme</description>
|
<description>Adjust the Nextcloud theme</description>
|
||||||
<licence>AGPL</licence>
|
<licence>AGPL</licence>
|
||||||
<author>Nextcloud</author>
|
<author>Nextcloud</author>
|
||||||
<version>1.0.0</version>
|
<version>1.0.1</version>
|
||||||
<namespace>Theming</namespace>
|
<namespace>Theming</namespace>
|
||||||
<category>other</category>
|
<category>other</category>
|
||||||
|
|
||||||
|
@ -18,4 +18,9 @@
|
||||||
</types>
|
</types>
|
||||||
|
|
||||||
<default_enable/>
|
<default_enable/>
|
||||||
|
|
||||||
|
<settings>
|
||||||
|
<admin>OCA\Theming\Settings\Admin</admin>
|
||||||
|
<admin-section>OCA\Theming\Settings\Section</admin-section>
|
||||||
|
</settings>
|
||||||
</info>
|
</info>
|
||||||
|
|
|
@ -0,0 +1,99 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2016 Arthur Schiwon <blizzz@arthur-schiwon.de>
|
||||||
|
*
|
||||||
|
* @author Arthur Schiwon <blizzz@arthur-schiwon.de>
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace OCA\Theming\Settings;
|
||||||
|
|
||||||
|
use OCA\Theming\Template;
|
||||||
|
use OCP\AppFramework\Http\TemplateResponse;
|
||||||
|
use OCP\IConfig;
|
||||||
|
use OCP\IL10N;
|
||||||
|
use OCP\IURLGenerator;
|
||||||
|
use OCP\Settings\ISettings;
|
||||||
|
|
||||||
|
class Admin implements ISettings {
|
||||||
|
|
||||||
|
/** @var IConfig */
|
||||||
|
private $config;
|
||||||
|
|
||||||
|
/** @var IL10N */
|
||||||
|
private $l;
|
||||||
|
|
||||||
|
/** @var Template */
|
||||||
|
private $themingDefaults;
|
||||||
|
|
||||||
|
/** @var IURLGenerator */
|
||||||
|
private $urlGenerator;
|
||||||
|
|
||||||
|
public function __construct(IConfig $config, IL10N $l, Template $themingDefaults, IURLGenerator $urlGenerator) {
|
||||||
|
$this->config = $config;
|
||||||
|
$this->l = $l;
|
||||||
|
$this->themingDefaults = $themingDefaults;
|
||||||
|
$this->urlGenerator = $urlGenerator;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return TemplateResponse
|
||||||
|
*/
|
||||||
|
public function getForm() {
|
||||||
|
$path = $this->urlGenerator->linkToRoute('theming.Theming.updateLogo');
|
||||||
|
|
||||||
|
$themable = true;
|
||||||
|
$errorMessage = '';
|
||||||
|
$theme = $this->config->getSystemValue('theme', '');
|
||||||
|
if ($theme !== '') {
|
||||||
|
$themable = false;
|
||||||
|
$errorMessage = $this->l->t('You already use a custom theme');
|
||||||
|
}
|
||||||
|
|
||||||
|
$parameters = [
|
||||||
|
'themable' => $themable,
|
||||||
|
'errorMessage' => $errorMessage,
|
||||||
|
'name' => $this->themingDefaults->getEntity(),
|
||||||
|
'url' => $this->themingDefaults->getBaseUrl(),
|
||||||
|
'slogan' => $this->themingDefaults->getSlogan(),
|
||||||
|
'color' => $this->themingDefaults->getMailHeaderColor(),
|
||||||
|
'uploadLogoRoute' => $path,
|
||||||
|
];
|
||||||
|
|
||||||
|
return new TemplateResponse('theming', 'settings-admin', $parameters, '');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string the section ID, e.g. 'sharing'
|
||||||
|
*/
|
||||||
|
public function getSection() {
|
||||||
|
return 'theming';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return int whether the form should be rather on the top or bottom of
|
||||||
|
* the admin section. The forms are arranged in ascending order of the
|
||||||
|
* priority values. It is required to return a value between 0 and 100.
|
||||||
|
*
|
||||||
|
* E.g.: 70
|
||||||
|
*/
|
||||||
|
public function getPriority() {
|
||||||
|
return 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,67 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2016 Arthur Schiwon <blizzz@arthur-schiwon.de>
|
||||||
|
*
|
||||||
|
* @author Arthur Schiwon <blizzz@arthur-schiwon.de>
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace OCA\Theming\Settings;
|
||||||
|
|
||||||
|
use OCP\IL10N;
|
||||||
|
use OCP\Settings\ISection;
|
||||||
|
|
||||||
|
class Section implements ISection {
|
||||||
|
/** @var IL10N */
|
||||||
|
private $l;
|
||||||
|
|
||||||
|
public function __construct(IL10N $l) {
|
||||||
|
$this->l = $l;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns the ID of the section. It is supposed to be a lower case string,
|
||||||
|
* e.g. 'ldap'
|
||||||
|
*
|
||||||
|
* @returns string
|
||||||
|
*/
|
||||||
|
public function getID() {
|
||||||
|
return 'theming';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns the translated name as it should be displayed, e.g. 'LDAP / AD
|
||||||
|
* integration'. Use the L10N service to translate it.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getName() {
|
||||||
|
return $this->l->t('Theming');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return int whether the form should be rather on the top or bottom of
|
||||||
|
* the settings navigation. The sections are arranged in ascending order of
|
||||||
|
* the priority values. It is required to return a value between 0 and 99.
|
||||||
|
*
|
||||||
|
* E.g.: 70
|
||||||
|
*/
|
||||||
|
public function getPriority() {
|
||||||
|
return 30;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,52 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* @copyright Copyright (c) 2016 Bjoern Schiessle <bjoern@schiessle.org>
|
|
||||||
* @copyright Copyright (c) 2016 Lukas Reschke <lukas@statuscode.ch>
|
|
||||||
*
|
|
||||||
* @author Bjoern Schiessle <bjoern@schiessle.org>
|
|
||||||
* @author Lukas Reschke <lukas@statuscode.ch>
|
|
||||||
*
|
|
||||||
* @license GNU AGPL version 3 or any later version
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Affero General Public License as
|
|
||||||
* published by the Free Software Foundation, either version 3 of the
|
|
||||||
* License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Affero General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Affero General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
$config = \OC::$server->getConfig();
|
|
||||||
$l = \OC::$server->getL10N('theming');
|
|
||||||
$urlGenerator = \OC::$server->getURLGenerator();
|
|
||||||
|
|
||||||
$theming = \OC::$server->getThemingDefaults();
|
|
||||||
|
|
||||||
$themable = true;
|
|
||||||
$errorMessage = '';
|
|
||||||
$theme = $config->getSystemValue('theme', '');
|
|
||||||
|
|
||||||
if ($theme !== '') {
|
|
||||||
$themable = false;
|
|
||||||
$errorMessage = $l->t('You already use a custom theme');
|
|
||||||
}
|
|
||||||
|
|
||||||
$template = new \OCP\Template('theming', 'settings-admin');
|
|
||||||
|
|
||||||
$template->assign('themable', $themable);
|
|
||||||
$template->assign('errorMessage', $errorMessage);
|
|
||||||
$template->assign('name', $theming->getEntity());
|
|
||||||
$template->assign('url', $theming->getBaseUrl());
|
|
||||||
$template->assign('slogan', $theming->getSlogan());
|
|
||||||
$template->assign('color', $theming->getMailHeaderColor());
|
|
||||||
$path = $urlGenerator->linkToRoute('theming.Theming.updateLogo');
|
|
||||||
$template->assign('uploadLogoRoute', $path);
|
|
||||||
|
|
||||||
return $template->fetchPage();
|
|
|
@ -255,7 +255,6 @@ class Manager implements IManager {
|
||||||
0 => [new Section('server', $this->l->t('Server Settings'), 0)],
|
0 => [new Section('server', $this->l->t('Server Settings'), 0)],
|
||||||
5 => [new Section('sharing', $this->l->t('Sharing'), 0)],
|
5 => [new Section('sharing', $this->l->t('Sharing'), 0)],
|
||||||
//15 => [new Section('collaboration', $this->l->t('Collaboration'), 0)],
|
//15 => [new Section('collaboration', $this->l->t('Collaboration'), 0)],
|
||||||
//30 => [new Section('theming', $this->l->t('Theming'), 0)],
|
|
||||||
45 => [new Section('encryption', $this->l->t('Encryption'), 0)],
|
45 => [new Section('encryption', $this->l->t('Encryption'), 0)],
|
||||||
90 => [new Section('logging', $this->l->t('Logging'), 0)],
|
90 => [new Section('logging', $this->l->t('Logging'), 0)],
|
||||||
98 => [new Section('additional', $this->l->t('Additional Settings'), 0)],
|
98 => [new Section('additional', $this->l->t('Additional Settings'), 0)],
|
||||||
|
|
Loading…
Reference in New Issue