diff --git a/frontend/src/business/components/settings/organization/OrganizationWorkspace.vue b/frontend/src/business/components/settings/organization/OrganizationWorkspace.vue index 5d6ab25502..77700810d6 100644 --- a/frontend/src/business/components/settings/organization/OrganizationWorkspace.vue +++ b/frontend/src/business/components/settings/organization/OrganizationWorkspace.vue @@ -75,18 +75,23 @@ @close="closeFunc"> - - - - {{ item.name }} - {{ item.email }} - - + + + + { - this.$set(this.memberForm, "userList", response.data); + this.userList = response.data; }); this.result = this.$get('/role/list/test', response => { this.$set(this.memberForm, "roles", response.data); @@ -315,12 +320,24 @@ submitForm(formName) { this.$refs[formName].validate((valid) => { if (valid) { + let userIds = []; + let userId = this.memberForm.userId; + let email = this.memberForm.memberSign; + let member = this.userList.find(user => user.id === email || user.email === email); + if (!member) { + this.$warning("未找到该用户信息,请输入正确ID 或者 邮箱!"); + return false; + } else { + userId = member.id; + } + userIds.push(userId); let param = { - userIds: this.memberForm.userIds, + userIds: userIds, roleIds: this.memberForm.roleIds, workspaceId: this.currentWorkspaceRow.id }; this.result = this.$post("user/ws/member/add", param, () => { + this.$success(this.$t('commons.save_success')); this.cellClick(this.currentWorkspaceRow); this.dialogWsMemberAddVisible = false; }) @@ -371,6 +388,20 @@ buildPagePath(path) { return path + "/" + this.dialogCurrentPage + "/" + this.dialogPageSize; }, + querySearch(queryString, cb) { + var userList = this.userList; + var results = queryString ? userList.filter(this.createFilter(queryString)) : userList; + // 调用 callback 返回建议列表的数据 + cb(results); + }, + createFilter(queryString) { + return (user) => { + return (user.email.indexOf(queryString.toLowerCase()) === 0 || user.id.indexOf(queryString.toLowerCase()) === 0); + }; + }, + handleSelect(item) { + this.$set(this.form, "userId", item.id); + } }, data() { return { @@ -382,6 +413,7 @@ condition: {}, dialogCondition: {}, items: [], + userList: [], currentPage: 1, pageSize: 5, total: 0, @@ -449,5 +481,9 @@ padding: 0px; } + .input-with-autocomplete { + width: 100%; + } + diff --git a/frontend/src/business/components/settings/workspace/WorkspaceMember.vue b/frontend/src/business/components/settings/workspace/WorkspaceMember.vue index 262f5ab49d..ddd649a076 100644 --- a/frontend/src/business/components/settings/workspace/WorkspaceMember.vue +++ b/frontend/src/business/components/settings/workspace/WorkspaceMember.vue @@ -28,18 +28,23 @@ - - - - {{ item.name }} - {{ item.email }} - - + + + + @@ -116,6 +121,7 @@ queryPath: "/user/ws/member/list", condition: {}, tableData: [], + userList: [], rules: { userIds: [ {required: true, message: this.$t('member.please_choose_member'), trigger: ['blur']} @@ -219,7 +225,7 @@ } this.$post('/user/org/member/list/all', param, response => { this.createVisible = true; - this.$set(this.form, "userList", response.data); + this.userList = response.data; }) this.result = this.$get('/role/list/test', response => { this.$set(this.form, "roles", response.data); @@ -228,17 +234,43 @@ submitForm(formName) { this.$refs[formName].validate((valid) => { if (valid) { + let userIds = []; + let userId = this.form.userId; + let email = this.form.memberSign; + let member = this.userList.find(user => user.id === email || user.email === email); + if (!member) { + this.$warning("未找到该用户信息,请输入正确ID 或者 邮箱!"); + return false; + } else { + userId = member.id; + } + userIds.push(userId); let param = { - userIds: this.form.userIds, + userIds: userIds, roleIds: this.form.roleIds, workspaceId: this.currentUser().lastWorkspaceId }; this.result = this.$post("user/ws/member/add", param, () => { + this.$success(this.$t('commons.save_success')); this.initTableData(); this.createVisible = false; }) } }); + }, + querySearch(queryString, cb) { + var userList = this.userList; + var results = queryString ? userList.filter(this.createFilter(queryString)) : userList; + // 调用 callback 返回建议列表的数据 + cb(results); + }, + createFilter(queryString) { + return (user) => { + return (user.email.indexOf(queryString.toLowerCase()) === 0 || user.id.indexOf(queryString.toLowerCase()) === 0); + }; + }, + handleSelect(item) { + this.$set(this.form, "userId", item.id); } } } @@ -264,4 +296,8 @@ font-size: 13px; } + .input-with-autocomplete { + width: 100%; + } +