summaryrefslogtreecommitdiffstats
path: root/settings
diff options
context:
space:
mode:
authorJohn Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>2018-01-09 15:55:45 +0100
committerRoeland Jago Douma <roeland@famdouma.nl>2018-02-27 12:50:18 +0100
commit7f6b27aef7a3fd696a3836964bf0592e3ffe9d00 (patch)
tree1fa4fdaa56e6db0537ef048dfa6de2fa16077c7c /settings
parent2f1aa251305be4dbe0b178ff523346a65dd3cf62 (diff)
downloadnextcloud-server-7f6b27aef7a3fd696a3836964bf0592e3ffe9d00.tar.gz
nextcloud-server-7f6b27aef7a3fd696a3836964bf0592e3ffe9d00.zip
New user form in table
Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> Added value and empty check to properly display a confirm button/input Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> w3c html form table compliance and menu fixes Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> Various design fixes Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> Fix wording to consistent 'Add user' Signed-off-by: Jan-Christoph Borchardt <hey@jancborchardt.net> Focus new username input on toggle Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> Removed unwanted th after rebase Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> quote fix Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> Th to td Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> 🙈 Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> Email input to email type Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> Fixed table template cells and fix email input enabling Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> Always show email and fixed min-width of name, username, mail and fullname columns Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> Use button id Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>
Diffstat (limited to 'settings')
-rw-r--r--settings/css/settings.scss35
-rw-r--r--settings/js/users/users.js44
-rw-r--r--settings/templates/users/main.php14
-rw-r--r--settings/templates/users/part.createuser.php36
-rw-r--r--settings/templates/users/part.userlist.php226
5 files changed, 160 insertions, 195 deletions
diff --git a/settings/css/settings.scss b/settings/css/settings.scss
index 0af440594da..69e9b593d95 100644
--- a/settings/css/settings.scss
+++ b/settings/css/settings.scss
@@ -491,9 +491,12 @@ table.grid {
}
}
-td {
+td, th {
&.name {
padding-left: .8em;
+ width: 10em;
+ min-width: 10em;
+ max-width: 10em;
}
&.password {
padding-left: .8em;
@@ -504,8 +507,12 @@ td {
&.displayName > img {
visibility: hidden;
}
- &.password, &.displayName {
+ &.password,
+ &.displayName,
+ &.mailAddress {
width: 12em;
+ min-width: 12em;
+ max-width: 12em;
cursor: pointer;
}
&.mailAddress {
@@ -524,7 +531,7 @@ span.usersLastLoginTooltip {
/* dropdowns will be relative to this element */
#userlist {
position: relative;
- .mailAddress, .storageLocation, .userBackend, .lastLogin {
+ .storageLocation, .userBackend, .lastLogin {
display: none;
}
th.name {
@@ -545,17 +552,7 @@ span.usersLastLoginTooltip {
}
}
-/* because of accessibility the name cell is <th> - therefore we enforce the black color */
-/* use same height as in files app */
#newuser {
- /* positioning fixes */
- margin: 2px 0;
- display: flex;
- flex-direction: column;
-
- .groups {
- display: inline;
- }
.groupsListContainer.hidden {
display: none;
}
@@ -564,18 +561,8 @@ span.usersLastLoginTooltip {
position: relative;
top: -1px;
}
- input:not([type='submit']) {
+ #newuserHeader input:not([type="submit"]) {
width: 100%;
- margin: 2px 0;
- }
- input[type='submit'] {
- flex-grow: 2;
- }
- > div {
- display: inline-flex;
- label {
- display: block;
- }
}
}
diff --git a/settings/js/users/users.js b/settings/js/users/users.js
index 31f9605e48f..58c15cf1c93 100644
--- a/settings/js/users/users.js
+++ b/settings/js/users/users.js
@@ -32,7 +32,13 @@ var UserList = {
// initially the list might already contain user entries (not fully ajaxified yet)
// initialize these entries
this.$el.find('.quota-user').singleSelect().on('change', this.onQuotaSelect);
- OC.registerMenu($('.app-navigation-new > button'), $('#newuser'))
+ OC.registerMenu(
+ $('#new-user-button'),
+ $('#newuserHeader'),
+ function() {
+ $('#newusername').focus();
+ }
+ );
},
/**
@@ -1136,24 +1142,6 @@ $(document).ready(function () {
}
});
- if ($('#CheckboxEmailAddress').is(':checked')) {
- $("#userlist .mailAddress").show();
- }
- // Option to display/hide the "Mail Address" column
- $('#CheckboxEmailAddress').click(function () {
- if ($('#CheckboxEmailAddress').is(':checked')) {
- $("#userlist .mailAddress").show();
- if (OC.isUserAdmin()) {
- OCP.AppConfig.setValue('core', 'umgmt_show_email', 'true');
- }
- } else {
- $("#userlist .mailAddress").hide();
- if (OC.isUserAdmin()) {
- OCP.AppConfig.setValue('core', 'umgmt_show_email', 'false');
- }
- }
- });
-
if ($('#CheckboxUserBackend').is(':checked')) {
$("#userlist .userBackend").show();
}
@@ -1172,24 +1160,6 @@ $(document).ready(function () {
}
});
- if ($('#CheckboxMailOnUserCreate').is(':checked')) {
- $("#newemail").show();
- }
- // Option to display/hide the "E-Mail" input field
- $('#CheckboxMailOnUserCreate').click(function () {
- if ($('#CheckboxMailOnUserCreate').is(':checked')) {
- $("#newemail").show();
- if (OC.isUserAdmin()) {
- OCP.AppConfig.setValue('core', 'umgmt_send_email', 'true');
- }
- } else {
- $("#newemail").hide();
- if (OC.isUserAdmin()) {
- OCP.AppConfig.setValue('core', 'umgmt_send_email', 'false');
- }
- }
- });
-
// calculate initial limit of users to load
var initialUserCountLimit = UserList.initialUsersToLoad,
containerHeight = $('#app-content').height();
diff --git a/settings/templates/users/main.php b/settings/templates/users/main.php
index 6b75c46d10f..3fc80fca0b9 100644
--- a/settings/templates/users/main.php
+++ b/settings/templates/users/main.php
@@ -67,20 +67,6 @@ translation('settings');
<?php p($l->t('Show last login')) ?>
</label>
</p>
- <p>
- <input type="checkbox" name="EmailAddress" value="EmailAddress" id="CheckboxEmailAddress"
- class="checkbox" <?php if ($_['show_email'] === 'true') print_unescaped('checked="checked"'); ?> />
- <label for="CheckboxEmailAddress">
- <?php p($l->t('Show email address')) ?>
- </label>
- </p>
- <p>
- <input type="checkbox" name="MailOnUserCreate" value="MailOnUserCreate" id="CheckboxMailOnUserCreate"
- class="checkbox" <?php if ($_['send_email'] === 'true') print_unescaped('checked="checked"'); ?> />
- <label for="CheckboxMailOnUserCreate">
- <?php p($l->t('Send email to new user')) ?>
- </label>
- </p>
<p class="info-text">
<?php p($l->t('When the password of a new user is left empty, an activation email with a link to set the password is sent.')) ?>
</p>
diff --git a/settings/templates/users/part.createuser.php b/settings/templates/users/part.createuser.php
index fca9ecc0898..57fe8e8b63f 100644
--- a/settings/templates/users/part.createuser.php
+++ b/settings/templates/users/part.createuser.php
@@ -1,37 +1,3 @@
<div class="app-navigation-new">
- <button type="button" class="icon-add"><?php p($l->t('New user'))?></button>
- <form class="newUserMenu" id="newuser" autocomplete="off" style="display: none;">
- <div>
- <input id="newusername" type="text" required
- placeholder="<?php p($l->t('Username'))?>" name="username"
- autocomplete="off" autocapitalize="none" autocorrect="off" />
- </div>
- <div>
- <input id="newuserpassword" type="password" required
- placeholder="<?php p($l->t('Password'))?>" name="password"
- autocomplete="new-password" autocapitalize="none" autocorrect="off" />
- </div>
- <div>
- <input id="newemail" type="text" style="display:none"
- placeholder="<?php p($l->t('E-Mail'))?>" name="email"
- autocomplete="off" autocapitalize="none" autocorrect="off" />
- </div>
- <div>
- <label class="groups" for="newgroup">
- <div class="groupsListContainer multiselect button" data-placeholder="<?php p($l->t('Groups'))?>"><span class="title groupsList"></span>
- <span class="icon-triangle-s"></span>
- </div>
- </label>
- <input type="submit" id="newsubmit" class="button icon-confirm has-tooltip" value="" title="<?php p($l->t('Create'))?>" />
- </div>
- <?php if((bool)$_['recoveryAdminEnabled']): ?>
- <div class="recoveryPassword">
- <input id="recoveryPassword"
- type="password"
- placeholder="<?php p($l->t('Admin Recovery Password'))?>"
- title="<?php p($l->t('Enter the recovery password in order to recover the users files during password change'))?>"
- alt="<?php p($l->t('Enter the recovery password in order to recover the users files during password change'))?>"/>
- </div>
- <?php endif; ?>
- </form>
+ <button type="button" id="new-user-button" class="icon-add"><?php p($l->t('Add user'))?></button>
</div>
diff --git a/settings/templates/users/part.userlist.php b/settings/templates/users/part.userlist.php
index 2506dba7fc3..e4e5aa3df7b 100644
--- a/settings/templates/users/part.userlist.php
+++ b/settings/templates/users/part.userlist.php
@@ -1,90 +1,146 @@
-<table id="userlist" class="grid" data-groups="<?php p($_['allGroups']);?>">
- <thead>
- <tr>
- <th id="headerAvatar" scope="col"></th>
- <th id="headerName" scope="col"><?php p($l->t('Username'))?></th>
- <th id="headerDisplayName" scope="col"><?php p($l->t( 'Full name' )); ?></th>
- <th id="headerPassword" scope="col"><?php p($l->t( 'Password' )); ?></th>
- <th class="mailAddress" scope="col"><?php p($l->t( 'Email' )); ?></th>
- <th id="headerGroups" scope="col"><?php p($l->t( 'Groups' )); ?></th>
- <?php if(is_array($_['subadmins']) || $_['subadmins']): ?>
- <th id="headerSubAdmins" scope="col"><?php p($l->t('Group admin for')); ?></th>
- <?php endif;?>
- <th id="headerQuota" scope="col"><?php p($l->t('Quota')); ?></th>
- <th class="storageLocation" scope="col"><?php p($l->t('Storage location')); ?></th>
- <th class="userBackend" scope="col"><?php p($l->t('User backend')); ?></th>
- <th class="lastLogin" scope="col"><?php p($l->t('Last login')); ?></th>
- <th class="userActions"></th>
- </tr>
- </thead>
- <tbody>
- <!-- the following <tr> is used as a template for the JS part -->
- <tr style="display:none">
- <td class="avatar"><div class="avatardiv"></div></td>
- <th class="name" scope="row"></th>
- <td class="displayName"><span></span> <img class="action"
- src="<?php p(image_path('core', 'actions/rename.svg'))?>"
- alt="<?php p($l->t("change full name"))?>" title="<?php p($l->t("change full name"))?>"/>
- </td>
- <td class="password"><span>●●●●●●●</span> <img class="action"
- src="<?php print_unescaped(image_path('core', 'actions/rename.svg'))?>"
- alt="<?php p($l->t("set new password"))?>" title="<?php p($l->t("set new password"))?>"/>
- </td>
- <td class="mailAddress"><span></span><div class="loading-small hidden"></div> <img class="action"
- src="<?php p(image_path('core', 'actions/rename.svg'))?>"
- alt="<?php p($l->t('change email address'))?>" title="<?php p($l->t('change email address'))?>"/>
- </td>
- <td class="groups"><div class="groupsListContainer multiselect button"
- ><span class="title groupsList"></span><span class="icon-triangle-s"></span></div>
- </td>
- <?php if(is_array($_['subadmins']) || $_['subadmins']): ?>
- <td class="subadmins"><div class="groupsListContainer multiselect button"
- ><span class="title groupsList"></span><span class="icon-triangle-s"></span></div>
- </td>
- <?php endif;?>
- <td class="quota">
- <select class="quota-user" data-inputtitle="<?php p($l->t('Please enter storage quota (ex: "512 MB" or "12 GB")')) ?>">
- <option value='default'>
- <?php p($l->t('Default'));?>
- </option>
- <option value='none'>
- <?php p($l->t('Unlimited'));?>
- </option>
- <?php foreach($_['quota_preset'] as $preset):?>
- <option value='<?php p($preset);?>'>
- <?php p($preset);?>
+<form class="newUserMenu" id="newuser" autocomplete="off">
+ <table id="userlist" class="grid" data-groups="<?php p($_['allGroups']);?>">
+ <thead>
+ <tr>
+ <th id="headerAvatar" scope="col"></th>
+ <th id="headerName" scope="col"><?php p($l->t('Username'))?></th>
+ <th id="headerDisplayName" scope="col"><?php p($l->t( 'Full name' )); ?></th>
+ <th id="headerPassword" scope="col"><?php p($l->t( 'Password' )); ?></th>
+ <th class="mailAddress" scope="col"><?php p($l->t( 'Email' )); ?></th>
+ <th id="headerGroups" scope="col"><?php p($l->t( 'Groups' )); ?></th>
+ <?php if(is_array($_['subadmins']) || $_['subadmins']): ?>
+ <th id="headerSubAdmins" scope="col"><?php p($l->t('Group admin for')); ?></th>
+ <?php endif;?>
+ <?php if((bool)$_['recoveryAdminEnabled']): ?>
+ <th id="recoveryPassword" scope="col"><?php p($l->t('Recovery password')); ?></th>
+ <?php endif; ?>
+ <th id="headerQuota" scope="col"><?php p($l->t('Quota')); ?></th>
+ <th class="storageLocation" scope="col"><?php p($l->t('Storage location')); ?></th>
+ <th class="userBackend" scope="col"><?php p($l->t('User backend')); ?></th>
+ <th class="lastLogin" scope="col"><?php p($l->t('Last login')); ?></th>
+ <th class="userActions"></th>
+ </tr>
+ <tr id="newuserHeader" style="display:none">
+ <td class="icon-add"></td>
+ <td class="name">
+ <input id="newusername" type="text" required
+ placeholder="<?php p($l->t('Username'))?>" name="username"
+ autocomplete="off" autocapitalize="none" autocorrect="off" />
+ </td>
+ <td class="displayName">
+ <input id="newdisplayname" type="text"
+ placeholder="<?php p($l->t('Full name'))?>" name="displayname"
+ autocomplete="off" autocapitalize="none" autocorrect="off" />
+ </td>
+ <td class="password">
+ <input id="newuserpassword" type="password" required
+ placeholder="<?php p($l->t('Password'))?>" name="password"
+ autocomplete="new-password" autocapitalize="none" autocorrect="off" />
+ </td>
+ <td class="mailAddress">
+ <input id="newemail" type="email"
+ placeholder="<?php p($l->t('E-Mail'))?>" name="email"
+ autocomplete="off" autocapitalize="none" autocorrect="off" />
+ </td>
+ <td class="groups">
+ <div class="groupsListContainer multiselect button" data-placeholder="<?php p($l->t('Groups'))?>">
+ <span class="title groupsList"></span>
+ <span class="icon-triangle-s"></span>
+ </div>
+ </td>
+ <?php if(is_array($_['subadmins']) || $_['subadmins']): ?>
+ <td></td>
+ <?php endif;?>
+ <?php if((bool)$_['recoveryAdminEnabled']): ?>
+ <td class="recoveryPassword">
+ <input id="recoveryPassword"
+ type="password"
+ placeholder="<?php p($l->t('Admin Recovery Password'))?>"
+ title="<?php p($l->t('Enter the recovery password in order to recover the users files during password change'))?>"
+ alt="<?php p($l->t('Enter the recovery password in order to recover the users files during password change'))?>"/>
+ </td>
+ <?php endif; ?>
+ <td class="quota"></td>
+ <td class="storageLocation" scope="col"></td>
+ <td class="userBackend" scope="col"></td>
+ <td class="lastLogin" scope="col"></td>
+ <td class="userActions">
+ <input type="submit" id="newsubmit" class="button icon-confirm has-tooltip" value="<?php p($l->t('Add user'))?>" />
+ </td>
+ </tr>
+ </thead>
+ <tbody>
+ <!-- the following <tr> is used as a template for the JS part -->
+ <tr style="display:none">
+ <td class="avatar"><div class="avatardiv"></div></td>
+ <td class="name" scope="row"></td>
+ <td class="displayName"><span></span> <img class="action"
+ src="<?php p(image_path('core', 'actions/rename.svg'))?>"
+ alt="<?php p($l->t('change full name'))?>" title="<?php p($l->t('change full name'))?>"/>
+ </td>
+ <td class="password"><span>●●●●●●●</span> <img class="action"
+ src="<?php print_unescaped(image_path('core', 'actions/rename.svg'))?>"
+ alt="<?php p($l->t('set new password'))?>" title="<?php p($l->t('set new password'))?>"/>
+ </td>
+ <td class="mailAddress"><span></span><div class="loading-small hidden"></div> <img class="action"
+ src="<?php p(image_path('core', 'actions/rename.svg'))?>"
+ alt="<?php p($l->t('change email address'))?>" title="<?php p($l->t('change email address'))?>"/>
+ </td>
+ <td class="groups"><div class="groupsListContainer multiselect button"
+ ><span class="title groupsList"></span><span class="icon-triangle-s"></span></div>
+ </td>
+ <?php if(is_array($_['subadmins']) || $_['subadmins']): ?>
+ <td class="subadmins"><div class="groupsListContainer multiselect button"
+ ><span class="title groupsList"></span><span class="icon-triangle-s"></span></div>
+ </td>
+ <?php endif;?>
+ <?php if((bool)$_['recoveryAdminEnabled']): ?>
+ <td></td>
+ <?php endif; ?>
+ <td class="quota">
+ <select class="quota-user" data-inputtitle="<?php p($l->t('Please enter storage quota (ex: "512 MB" or "12 GB")')) ?>">
+ <option value='default'>
+ <?php p($l->t('Default'));?>
+ </option>
+ <option value='none'>
+ <?php p($l->t('Unlimited'));?>
+ </option>
+ <?php foreach($_['quota_preset'] as $preset):?>
+ <option value='<?php p($preset);?>'>
+ <?php p($preset);?>
+ </option>
+ <?php endforeach;?>
+ <option value='other' data-new>
+ <?php p($l->t('Other'));?> ...
</option>
- <?php endforeach;?>
- <option value='other' data-new>
- <?php p($l->t('Other'));?> ...
- </option>
- </select>
- <progress class="quota-user-progress" value="" max="100"></progress>
- </td>
- <td class="storageLocation"></td>
- <td class="userBackend"></td>
- <td class="lastLogin"></td>
- <td class="userActions">
- <div class="toggleUserActions">
- <a class="action"><span class="icon-more"></span></a>
- <div class="popovermenu">
- <ul class="userActionsMenu">
- <li>
- <a href="#" class="menuitem action-togglestate permanent" data-action="togglestate"></a>
- </li>
- <li>
- <a href="#" class="menuitem action-remove permanent" data-action="remove">
- <span class="icon icon-delete"></span>
- <span><?php p($l->t('Delete')); ?></span>
- </a>
- </li>
- </ul>
+ </select>
+ <progress class="quota-user-progress" value="" max="100"></progress>
+ </td>
+ <td class="storageLocation"></td>
+ <td class="userBackend"></td>
+ <td class="lastLogin"></td>
+ <td class="userActions">
+ <div class="toggleUserActions">
+ <a class="action"><span class="icon-more"></span></a>
+ <div class="popovermenu">
+ <ul class="userActionsMenu">
+ <li>
+ <a href="#" class="menuitem action-togglestate permanent" data-action="togglestate"></a>
+ </li>
+ <li>
+ <a href="#" class="menuitem action-remove permanent" data-action="remove">
+ <span class="icon icon-delete"></span>
+ <span><?php p($l->t('Delete')); ?></span>
+ </a>
+ </li>
+ </ul>
+ </div>
</div>
- </div>
- </td>
- </tr>
- </tbody>
-</table>
+ </td>
+ </tr>
+ </tbody>
+ </table>
+</form>
<div class="emptycontent" style="display:none">
<div class="icon-search"></div>