diff options
author | Christoph Wurst <christoph@winzerhof-wurst.at> | 2019-12-09 11:55:42 +0100 |
---|---|---|
committer | Christoph Wurst <christoph@winzerhof-wurst.at> | 2019-12-10 12:49:26 +0100 |
commit | 146732f7f98764ef89ae8494f21f787de95f14ba (patch) | |
tree | aa5d73fe4be9cf8601419bef5fb08133d5c8a9b8 /apps/files/src | |
parent | 162b47075a986d943dcf2cbe59799112a7ee6c9a (diff) | |
download | nextcloud-server-146732f7f98764ef89ae8494f21f787de95f14ba.tar.gz nextcloud-server-146732f7f98764ef89ae8494f21f787de95f14ba.zip |
Add autocompletion to the ownership transfer UI
Signed-off-by: Christoph Wurst <christoph@winzerhof-wurst.at>
Diffstat (limited to 'apps/files/src')
-rw-r--r-- | apps/files/src/components/TransferOwnershipDialogue.vue | 79 |
1 files changed, 74 insertions, 5 deletions
diff --git a/apps/files/src/components/TransferOwnershipDialogue.vue b/apps/files/src/components/TransferOwnershipDialogue.vue index 01873536913..8889d908716 100644 --- a/apps/files/src/components/TransferOwnershipDialogue.vue +++ b/apps/files/src/components/TransferOwnershipDialogue.vue @@ -42,7 +42,20 @@ <div class="step-header"> {{ t('files', 'Target user') }} </div> - <input id="files-transfer-user" v-model="uid" type="text"> + <Multiselect + v-model="selectedUser" + :options="formatedUserSuggestions" + :multiple="false" + :searchable="true" + :placeholder="t('core', 'Target user …')" + :preselect-first="true" + :preserve-search="true" + :loading="loadingUsers" + track-by="user" + label="displayName" + :clear-on-select="false" + :user-select="true" + @search-change="findUserDebounced" /> </li> <li> <input type="submit" @@ -58,8 +71,11 @@ <script> import axios from '@nextcloud/axios' +import debounce from 'debounce' import { generateOcsUrl } from '@nextcloud/router' import { getFilePickerBuilder } from '@nextcloud/dialogs' +import { Multiselect } from 'nextcloud-vue/dist/Components/Multiselect' +import Vue from 'vue' import logger from '../logger' @@ -72,19 +88,37 @@ const picker = getFilePickerBuilder(t('files', 'Select directory to transfer')) export default { name: 'TransferOwnershipDialogue', + components: { + Multiselect + }, data() { return { directory: undefined, directoryPickerError: undefined, submitError: undefined, - uid: '' + loadingUsers: false, + selectedUser: null, + userSuggestions: {} } }, computed: { canSubmit() { - return !!this.directory && !!this.uid + return !!this.directory && !!this.selectedUser + }, + formatedUserSuggestions() { + return Object.keys(this.userSuggestions).map((uid) => { + const user = this.userSuggestions[uid] + return { + user: user.uid, + displayName: user.displayName, + icon: 'icon-user' + } + }) } }, + created() { + this.findUserDebounced = debounce(this.findUser, 300) + }, methods: { start() { this.directoryPickerError = undefined @@ -105,6 +139,41 @@ export default { this.directoryPickerError = error.message || t('files', 'Unknown error') }) }, + async findUser(query) { + this.query = query.trim() + + if (query.length < 3) { + return + } + + this.loadingUsers = true + try { + const response = await axios.get(generateOcsUrl('apps/files_sharing/api/v1') + 'sharees', { + params: { + format: 'json', + itemType: 'file', + search: query, + perPage: 20, + lookup: false + } + }) + + if (response.data.ocs.meta.statuscode !== 100) { + logger.error('Error fetching suggestions', { response }) + } + + response.data.ocs.data.users.forEach(user => { + Vue.set(this.userSuggestions, user.value.shareWith, { + uid: user.value.shareWith, + displayName: user.label + }) + }) + } catch (error) { + logger.error('could not fetch users', { error }) + } finally { + this.loadingUsers = false + } + }, submit() { if (!this.canSubmit) { logger.warn('ignoring form submit') @@ -113,7 +182,7 @@ export default { this.submitError = undefined const data = { path: this.directory, - recipient: this.uid + recipient: this.selectedUser.user } logger.debug('submit transfer ownership form', data) @@ -125,7 +194,7 @@ export default { logger.info('Transfer ownership request sent', { data }) this.directory = undefined - this.recipient = undefined + this.selectedUser = null OCP.Toast.success(t('files', 'Ownership transfer request sent')) }) .catch(error => { |