diff options
author | julia.kirschenheuter <julia.kirschenheuter@nextcloud.com> | 2023-05-23 12:02:13 +0200 |
---|---|---|
committer | julia.kirschenheuter <julia.kirschenheuter@nextcloud.com> | 2023-05-23 14:12:45 +0200 |
commit | 1c90d7faf1689b230ee5fdba92781dd0eebd1d3f (patch) | |
tree | 88e9e6afa2df67843f166b80eec770f125c78cbd /apps/settings | |
parent | 0713c1c4c6c7860fc792f0eab1ff712fce3fe14c (diff) | |
download | nextcloud-server-1c90d7faf1689b230ee5fdba92781dd0eebd1d3f.tar.gz nextcloud-server-1c90d7faf1689b230ee5fdba92781dd0eebd1d3f.zip |
Add label to "default quota" multiselect
Signed-off-by: julia.kirschenheuter <julia.kirschenheuter@nextcloud.com>
Diffstat (limited to 'apps/settings')
-rw-r--r-- | apps/settings/src/views/Users.vue | 38 |
1 files changed, 22 insertions, 16 deletions
diff --git a/apps/settings/src/views/Users.vue b/apps/settings/src/views/Users.vue index 3dbb031232f..d2c8c6a0a4e 100644 --- a/apps/settings/src/views/Users.vue +++ b/apps/settings/src/views/Users.vue @@ -82,19 +82,17 @@ :count="group.count" /> </template> <template #footer> - <NcAppNavigationSettings> + <NcAppNavigationSettings exclude-click-outside-selectors=".vs__dropdown-menu"> <div> - <p>{{ t('settings', 'Default quota:') }}</p> - <NcMultiselect :value="defaultQuota" + <label for="default-quota-multiselect">{{ t('settings', 'Default quota:') }}</label> + <NcSelect v-model="defaultQuota" + input-id="default-quota-multiselect" + :taggable="true" :options="quotaOptions" - tag-placeholder="create" + :create-option="validateQuota" :placeholder="t('settings', 'Select default quota')" - label="label" - track-by="id" - :allow-empty="false" - :taggable="true" - @tag="validateQuota" - @input="setDefaultQuota" /> + :close-on-select="true" + @option:selected="setDefaultQuota" /> </div> <div> <input id="showLanguages" @@ -156,7 +154,7 @@ import NcAppNavigationSettings from '@nextcloud/vue/dist/Components/NcAppNavigat import axios from '@nextcloud/axios' import NcContent from '@nextcloud/vue/dist/Components/NcContent.js' import { generateUrl } from '@nextcloud/router' -import NcMultiselect from '@nextcloud/vue/dist/Components/NcMultiselect.js' +import NcSelect from '@nextcloud/vue/dist/Components/NcSelect.js' import Vue from 'vue' import VueLocalStorage from 'vue-localstorage' @@ -179,7 +177,7 @@ export default { NcAppNavigationSettings, NcContent, GroupListItem, - NcMultiselect, + NcSelect, Plus, UserList, }, @@ -368,6 +366,10 @@ export default { * @param {string | object} quota Quota in readable format '5 GB' or Object {id: '5 GB', label: '5GB'} */ setDefaultQuota(quota = 'none') { + // Make sure correct label is set for unlimited quota + if (quota === 'none') { + quota = this.unlimitedQuota + } this.$store.dispatch('setAppConfig', { app: 'files', key: 'default_quota', @@ -384,17 +386,21 @@ export default { /** * Validate quota string to make sure it's a valid human file size * - * @param {string} quota Quota in readable format '5 GB' - * @return {Promise|boolean} + * @param {string | object} quota Quota in readable format '5 GB' or Object {id: '5 GB', label: '5GB'} + * @return {object} The validated quota object or unlimited quota if input is invalid */ validateQuota(quota) { + if (typeof quota === 'object') { + quota = quota?.id || quota.label + } // only used for new presets sent through @Tag const validQuota = OC.Util.computerFileSize(quota) if (validQuota === null) { - return this.setDefaultQuota('none') + return this.unlimitedQuota } else { // unify format output - return this.setDefaultQuota(OC.Util.humanFileSize(OC.Util.computerFileSize(quota))) + quota = OC.Util.humanFileSize(OC.Util.computerFileSize(quota)) + return { id: quota, label: quota } } }, |