maxkb/ui/src/views/team/index.vue
2024-03-20 15:02:18 +08:00

267 lines
7.0 KiB
Vue

<template>
<LayoutContainer header="团队成员">
<div class="team-manage flex main-calc-height">
<div class="team-member p-8 border-r">
<div class="flex-between p-16">
<h4>成员</h4>
<el-button type="primary" link @click="addMember">
<AppIcon iconName="app-add-users" class="add-user-icon" />
</el-button>
</div>
<div class="team-member-input">
<el-input v-model="filterText" placeholder="请输入用户名搜索" prefix-icon="Search" />
</div>
<common-list
:data="filterMember"
class="mt-8"
v-loading="loading"
@click="clickMemberHandle"
:default-active="currentUser"
>
<template #default="{ row }">
<div class="flex-between">
<div>
<span class="mr-8">{{ row.username }}</span>
<el-tag v-if="isManage(row.type)" class="default-tag">所有者</el-tag>
</div>
<div @click.stop style="margin-top: 5px">
<el-dropdown trigger="click" v-if="!isManage(row.type)">
<span class="cursor">
<el-icon class="rotate-90"><MoreFilled /></el-icon>
</span>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item @click.prevent="deleteMember(row)">移除</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
</div>
</div>
</template>
</common-list>
</div>
<div class="permission-setting flex" v-loading="rLoading">
<div class="team-manage__table">
<h4 class="p-24 pb-0 mb-4">权限设置</h4>
<el-tabs v-model="activeName" class="team-manage__tabs">
<el-tab-pane
v-for="(item, index) in settingTags"
:key="item.value"
:label="item.label"
:name="item.value"
>
<PermissionSetting
:key="index"
:data="item.data"
:type="item.value"
:tableHeight="tableHeight"
:manage="isManage(currentType)"
></PermissionSetting>
</el-tab-pane>
</el-tabs>
</div>
<div class="submit-button">
<el-button type="primary" @click="submitPermissions">保存</el-button>
</div>
</div>
</div>
<CreateMemberDialog ref="CreateMemberRef" @refresh="refresh" />
</LayoutContainer>
</template>
<script lang="ts" setup>
import { onMounted, ref, reactive, watch } from 'vue'
import TeamApi from '@/api/team'
import type { TeamMember } from '@/api/type/team'
import CreateMemberDialog from './component/CreateMemberDialog.vue'
import PermissionSetting from './component/PermissionSetting.vue'
import { MsgSuccess, MsgConfirm } from '@/utils/message'
import { DATASET, APPLICATION, isManage } from './utils'
const CreateMemberRef = ref<InstanceType<typeof CreateMemberDialog>>()
const loading = ref(false)
const rLoading = ref(false)
const memberList = ref<TeamMember[]>([]) // 全部成员
const filterMember = ref<TeamMember[]>([]) // 搜索过滤后列表
const currentUser = ref<String>('')
const currentType = ref<String>('')
const filterText = ref('')
const activeName = ref(DATASET)
const tableHeight = ref(0)
const settingTags = reactive([
{
label: '知识库',
value: DATASET,
data: [] as any
},
{
label: '应用',
value: APPLICATION,
data: [] as any
}
])
watch(filterText, (val) => {
if (val) {
filterMember.value = memberList.value.filter((v) => v.username.includes(val))
} else {
filterMember.value = memberList.value
}
})
function submitPermissions() {
rLoading.value = true
const obj: any = {
team_member_permission_list: []
}
settingTags.map((item) => {
item.data.map((v: any) => {
obj['team_member_permission_list'].push({
target_id: v.id,
type: v.type,
operate: v.operate
})
})
})
TeamApi.putMemberPermissions(currentUser.value, obj)
.then(() => {
MsgSuccess('提交成功')
MemberPermissions(currentUser.value)
})
.catch(() => {
rLoading.value = false
})
}
function MemberPermissions(id: String) {
rLoading.value = true
TeamApi.getMemberPermissions(id)
.then((res) => {
if (!res.data || Object.keys(res.data).length > 0) {
settingTags.map((item) => {
if (Object.keys(res.data).indexOf(item.value) !== -1) {
item.data = res.data[item.value]
}
})
}
rLoading.value = false
})
.catch(() => {
rLoading.value = false
})
}
function deleteMember(row: TeamMember) {
MsgConfirm(
`是否移除成员:${row.username}?`,
'移除后将会取消成员拥有的知识库和应用权限。',
{
confirmButtonText: '移除',
confirmButtonClass: 'danger'
}
)
.then(() => {
loading.value = true
TeamApi.delTeamMember(row.id)
.then(() => {
MsgSuccess('删除成功')
getMember()
})
.catch(() => {
loading.value = false
})
})
.catch(() => {})
}
function clickMemberHandle(item: any) {
currentUser.value = item.id
currentType.value = item.type
MemberPermissions(item.id)
}
function addMember() {
CreateMemberRef.value?.open()
}
function getMember(id?: string) {
loading.value = true
TeamApi.getTeamMember()
.then((res) => {
memberList.value = res.data
filterMember.value = res.data
const user = (id && memberList.value.find((p) => p.user_id === id)) || null
currentUser.value = user ? user.id : memberList.value[0].id
currentType.value = user ? user.type : memberList.value[0].type
MemberPermissions(currentUser.value)
loading.value = false
})
.catch(() => {
loading.value = false
})
}
function refresh(data?: string[]) {
getMember(data && data[0])
}
onMounted(() => {
tableHeight.value = window.innerHeight - 330
window.onresize = () => {
return (() => {
tableHeight.value = window.innerHeight - 330
})()
}
getMember()
})
</script>
<style lang="scss" scoped>
.team-manage {
.add-user-icon {
font-size: 17px;
}
.team-member-input {
padding: 0 calc(var(--app-base-px) * 2);
}
.team-member {
box-sizing: border-box;
width: var(--setting-left-width);
min-width: var(--setting-left-width);
}
.permission-setting {
box-sizing: border-box;
width: calc(100% - var(--setting-left-width));
flex-direction: column;
position: relative;
.submit-button {
position: absolute;
top: 54px;
right: 24px;
}
}
&__tabs {
margin-top: 10px;
:deep(.el-tabs__nav-wrap::after) {
height: 1px;
}
:deep(.el-tabs__nav-scroll) {
padding: 0 24px;
}
:deep(.el-tabs__active-bar) {
height: 3px;
}
}
&__table {
flex: 1;
}
}
</style>