eight
2024-08-28 2bc74ebfec4a30beddc66fd55be4947e5f7cf498
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
<template>
  <!-- 操作栏 -->
  <el-row v-if="showAction" justify="end">
    <el-button v-if="validateOwnerUser" type="primary" @click="openForm">
      <Icon class="mr-5px" icon="ep:plus" />
      新增
    </el-button>
    <el-button v-if="validateOwnerUser" @click="handleUpdate">
      <Icon class="mr-5px" icon="ep:edit" />
      编辑
    </el-button>
    <el-button v-if="validateOwnerUser" @click="handleDelete">
      <Icon class="mr-5px" icon="ep:delete" />
      移除
    </el-button>
    <el-button v-if="!validateOwnerUser && list.length > 0" type="danger" @click="handleQuit">
      退出团队
    </el-button>
  </el-row>
  <!-- 团队成员展示 -->
  <el-table
    ref="elTableRef"
    v-loading="loading"
    :data="list"
    :show-overflow-tooltip="true"
    :stripe="true"
    class="mt-20px"
    @selection-change="handleSelectionChange"
  >
    <el-table-column type="selection" width="55" />
    <el-table-column align="center" label="姓名" prop="nickname" />
    <el-table-column align="center" label="部门" prop="deptName" />
    <el-table-column align="center" label="岗位" prop="postNames" />
    <el-table-column align="center" label="权限级别" prop="level">
      <template #default="{ row }">
        <dict-tag :type="DICT_TYPE.CRM_PERMISSION_LEVEL" :value="row.level" />
      </template>
    </el-table-column>
    <el-table-column :formatter="dateFormatter" align="center" label="加入时间" prop="createTime" />
  </el-table>
 
  <!-- 表单弹窗:添加/修改 -->
  <CrmPermissionForm ref="formRef" @success="getList" />
</template>
<script lang="ts" setup>
import { dateFormatter } from '@/utils/formatTime'
import { ElTable } from 'element-plus'
import * as PermissionApi from '@/api/crm/permission'
import { useUserStoreWithOut } from '@/store/modules/user'
import CrmPermissionForm from './PermissionForm.vue'
import { DICT_TYPE } from '@/utils/dict'
 
defineOptions({ name: 'CrmPermissionList' })
 
const message = useMessage() // 消息
 
const props = defineProps<{
  bizType: number // 模块类型
  bizId: number | undefined // 模块数据编号
  showAction: boolean //是否展示操作按钮
}>()
const loading = ref(true) // 列表的加载中
const list = ref<PermissionApi.PermissionVO[]>([]) // 列表的数据
const formData = ref({
  ownerUserId: 0
})
const userStore = useUserStoreWithOut() // 用户信息缓存
 
/** 查询列表 */
const getList = async () => {
  loading.value = true
  try {
    const data = await PermissionApi.getPermissionList({
      bizType: props.bizType,
      bizId: props.bizId
    })
    list.value = data
    const permission = list.value.find(
      (item) =>
        item.userId === userStore.getUser.id &&
        item.level === PermissionApi.PermissionLevelEnum.OWNER
    )
    if (permission) {
      formData.value.ownerUserId = userStore.getUser.id
    }
  } finally {
    loading.value = false
  }
}
const multipleSelection = ref<PermissionApi.PermissionVO[]>([]) // 选择的团队成员
const elTableRef = ref<InstanceType<typeof ElTable>>()
const handleSelectionChange = (val: PermissionApi.PermissionVO[]) => {
  if (val.findIndex((item) => item.level === PermissionApi.PermissionLevelEnum.OWNER) !== -1) {
    message.warning('不能选择负责人!')
    elTableRef.value?.clearSelection()
    return
  }
  multipleSelection.value = val
}
 
/** 编辑团队成员 */
const formRef = ref<InstanceType<typeof CrmPermissionForm>>() // 权限表单 Ref
const handleUpdate = () => {
  if (multipleSelection.value?.length === 0) {
    message.warning('请先选择团队成员后操作!')
    return
  }
  if (multipleSelection.value?.length > 1) {
    message.warning('编辑团队成员时只能选择一个!')
    return
  }
  formRef.value?.open0(
    'update',
    props.bizType,
    props.bizId!,
    multipleSelection.value[0].id!,
    multipleSelection.value[0].level
  )
}
 
/** 移除团队成员 */
const handleDelete = async () => {
  if (multipleSelection.value?.length === 0) {
    message.warning('请先选择团队成员后操作!')
    return
  }
  await message.delConfirm()
  const ids = multipleSelection.value?.map((item) => item.id) as unknown as number[]
  await PermissionApi.deletePermissionBatch(ids)
  message.success('移除团队成员成功!')
  await getList()
}
 
/** 添加团队成员 */
const openForm = () => {
  formRef.value?.open('create', props.bizType, props.bizId!)
}
 
// 校验负责人权限和编辑权限
const validateOwnerUser = ref(false)
const validateWrite = ref(false)
const isPool = ref(false)
watch(
  list,
  (newArr) => {
    isPool.value = false
    if (newArr?.length > 0) {
      isPool.value = !list.value.some(
        (item) => item.level === PermissionApi.PermissionLevelEnum.OWNER
      )
      validateOwnerUser.value = false
      validateWrite.value = false
      const userId = userStore.getUser?.id
      list.value
        .filter((item) => item.userId === userId)
        .forEach((item) => {
          if (item.level === PermissionApi.PermissionLevelEnum.OWNER) {
            validateOwnerUser.value = true
            validateWrite.value = true
          } else if (item.level === PermissionApi.PermissionLevelEnum.WRITE) {
            validateWrite.value = true
          }
        })
    } else {
      isPool.value = true
    }
  },
  {
    immediate: true
  }
)
 
defineExpose({ openForm, validateOwnerUser, validateWrite, isPool })
const emits = defineEmits<{
  (e: 'quitTeam'): void
}>()
/** 退出团队 */
const handleQuit = async () => {
  const permission = list.value.find(
    (item) =>
      item.userId === userStore.getUser.id && item.level === PermissionApi.PermissionLevelEnum.OWNER
  )
  if (permission) {
    message.warning('负责人不能退出团队!')
    return
  }
  const userPermission = list.value.find((item) => item.userId === userStore.getUser.id)
  if (!userPermission) {
    return
  }
  await PermissionApi.deleteSelfPermission(userPermission.id!)
  message.success('退出团队成员成功!')
  emits('quitTeam')
}
 
watch(
  () => props.bizId,
  (bizId) => {
    if (!bizId) {
      return
    }
    getList()
  },
  { immediate: true, deep: true }
)
</script>