Transfer.vue
1.94 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
<template>
<el-dialog title="选择角色" :close-on-click-modal="false"
class="NCC-dialog NCC-dialog_center transfer-dialog" lock-scroll append-to-body
v-bind="$attrs" width="800px" :modal-append-to-body="false" v-on="$listeners" @open="onOpen">
<NCCTransfer :loading="loading" :treeData="treeData" v-model="selectedData" ref="NCCTransfer"
type="role" />
<span slot="footer" class="dialog-footer">
<el-button @click="closeTransfer">{{$t('common.cancelButton')}}</el-button>
<el-button type="primary" @click="confirm">{{$t('common.confirmButton')}}</el-button>
</span>
</el-dialog>
</template>
<script>
import { getModelData, setModelData } from '@/api/permission/authorize'
import { getRoleSelector } from '@/api/permission/role'
import NCCTransfer from '@/components/NCC-transfer'
export default {
name: 'transfer',
components: { NCCTransfer },
props: {
id: {
type: String,
default: ''
},
},
data() {
return {
selectedData: [],
treeData: [],
loading: false,
}
},
methods: {
onOpen() {
this.dataInit()
},
closeTransfer() {
this.$emit('update:visible', false)
},
confirm() {
let query = { itemType: 'portal', objectType: 'Role', objectId: this.selectedData }
setModelData(this.id, query).then(res => {
this.$message({
type: 'success',
message: res.msg,
duration: 1000,
onClose: () => {
this.closeTransfer()
}
});
})
},
async dataInit() {
this.loading = true
this.selectedData = []
this.$nextTick(() => {
this.$refs.NCCTransfer && (this.$refs.NCCTransfer.filterText = '')
})
getRoleSelector().then(res => {
this.treeData = res.data.list
getModelData(this.id, 'Role').then(res => {
this.selectedData = res.data.ids
this.loading = false
})
})
},
}
}
</script>