Add the "server info" settings

Signed-off-by: Michael Weimann <mail@michael-weimann.eu>
This commit is contained in:
Michael Weimann 2018-12-18 22:07:41 +01:00
parent 107fab9dfa
commit 6993faaf67
No known key found for this signature in database
GPG Key ID: 34F0524D4DA694A1
7 changed files with 240 additions and 8 deletions

View File

@ -0,0 +1,43 @@
<?php
namespace OC\Settings\Admin;
use OCP\AppFramework\Http\TemplateResponse;
use OCP\Settings\ISettings;
/**
* Class ServerInfo
*
* @package OC\Settings\Admin
*/
class ServerInfo implements ISettings {
/**
* @return TemplateResponse
*/
public function getForm() {
$parameters = [];
return new TemplateResponse('settings', 'settings/admin/server-info', $parameters, '');
}
/**
* Returns the server info section id.
*
* @return string
*/
public function getSection() {
return 'server-info';
}
/**
* Returns the server info settings priority.
*
* @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.
*/
public function getPriority() {
return 20;
}
}

View File

@ -231,6 +231,8 @@ class Manager implements IManager {
$forms[$form->getPriority()] = [$form];
$form = $this->container->query(Admin\Mail::class);
$forms[$form->getPriority()] = [$form];
$form = $this->container->query(Admin\ServerInfo::class);
$forms[$form->getPriority()] = [$form];
}
if ($section === 'security') {
/** @var ISettings $form */

View File

@ -141,7 +141,7 @@ class PersonalInfo implements ISettings {
'twitterVerification' => $userData[AccountManager::PROPERTY_TWITTER]['verified'],
'groups' => $this->getGroups($user),
'dataLocation' => 'Germany',
'provider' => 'Hetzner Online GmbH',
'provider' => 'Mustermann GmbH',
'providerLink' => 'https://www.hetzner.de/',
'providerPrivacyLink' => 'https://www.hetzner.de/rechtliches/datenschutz',
'encryptionEnabled' => true || $this->encryptionManager->isEnabled(),

View File

@ -0,0 +1,95 @@
.server-info-settings {
.label {
display: block;
}
.form-input {
margin-bottom: 10px;
width: 100%;
}
.margin-bottom {
margin-bottom: 15px;
}
.form-actions {
text-align: right;
.button {
align-items: center;
display: inline-flex;
margin: 0;
transition: background-color 500ms linear;
.default-label,
.working-label,
.success-label,
.error-label {
align-items: center;
gap: 4px;
}
.working-label,
.success-label,
.error-label {
display: none;
}
}
.button-working,
.button-success,
.button-error {
background-color: $color-background-dark;
color: $color-text-lighter;
opacity: 1;
.default-label {
display: none;
}
}
.button-working {
.working-label {
display: inline-flex;
}
}
.button-success {
background-color: $color-success;
border-color: darken($color-success, 10%);
color: $color-primary-text-dark;
.success-label {
display: inline-flex;
}
}
.button-error {
background-color: $color-error;
border-color: darken($color-error, 10%);
color: $color-primary-text-dark;
.error-label {
display: inline-flex;
}
}
}
@media (min-width: 1000px) {
.label {
display: inline-block;
text-align: right;
width: 175px;
}
.form-input {
margin-left: 5px;
width: 225px;
}
.form-actions {
margin-left: 180px;
width: 225px;
}
}
}

View File

@ -0,0 +1,6 @@
.where-is-your-data {
// @todo replace by common link style as soon as available
a:not(.icon-info) {
border-bottom: 1px dotted;
}
}

View File

@ -2,6 +2,9 @@
This file is licensed under the Affero General Public License version 3 or later.
See the COPYING-README file. */
@import "server-info";
@import "where-is-your-data";
input {
&#openid, &#webdav {
width: 20em;
@ -1624,10 +1627,3 @@ doesnotexist:-o-prefocus, .strengthify-wrapper {
}
}
}
.where-is-your-data {
// @todo replace by common Nextcloud link style as soon as available
a {
border-bottom: 1px dotted;
}
}

View File

@ -0,0 +1,90 @@
<?php ?>
<div class="section server-info-settings">
<h2><?php p($l->t('Server info')); ?></h2>
<p class="settings-hint">
<?php p($l->t('Enter common info about your Nextcloud instance here. These info are visible to all users.')) ?>
</p>
<form>
<div class="margin-bottom">
<label class="label" for="location"><?php p($l->t('Server location')); ?></label>
<input
class="form-input"
id="location"
name="location"
type="text"
maxlength="100"
placeholder="<?php p($l->t('country')); ?>">
</div>
<div>
<label class="label" for="provider"><?php p($l->t('Service provider')); ?></label>
<input
class="form-input"
id="provider"
name="provider"
type="text"
maxlength="100"
placeholder="<?php p($l->t('company or person')); ?>">
</div>
<div>
<label class="label" for="providerWebsite"><?php p($l->t('Website')); ?></label>
<input
class="form-input"
id="providerWebsite"
name="providerWebsite"
type="url"
maxlength="200"
placeholder="<?php p($l->t('link to website')); ?>">
</div>
<div class="margin-bottom">
<label class="label" for="providerPrivacyLink"><?php p($l->t('Link to privacy policy')); ?></label>
<input
class="form-input"
id="providerPrivacyLink"
name="providerPrivacyLink"
type="url"
maxlength="200"
placeholder="<?php p($l->t('link to privacy policy')); ?>">
</div>
<div class="margin-bottom">
<label class="label" for="admin"><?php p($l->t('Admin contact')); ?></label>
<select class="form-input" name="admin">
<option>Michael Weimann</option>
<option>Max Mustermann</option>
<option>Peter Petrowski</option>
</select>
</div>
<div class="form-actions">
<button id="test123" class="button">
<span class="default-label">
<?php p($l->t('Save')); ?>
</span>
<span class="working-label">
<span class="icon-loading-small-dark"></span>
<?php p($l->t('saving…')); ?>
</span>
<span class="success-label">
<span class="icon-checkmark-white"></span>
<?php p($l->t('saved')); ?>
</span>
<span class="error-label">
<span class="icon-error-white"></span>
<?php p($l->t('error saving settings')); ?>
</span>
</button>
<script>
const button = $('#test123');
button.on('click', (event) => {
event.stopImmediatePropagation();
event.preventDefault();
button.prop('disabled', true);
button.addClass('button-working');
setTimeout(() => {
button.removeClass('button-working');
button.addClass('button-success');
}, 1500);
});
</script>
</div>
</form>
</div>