| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174 |
- <template>
- <el-dialog v-model="deteleClueDialogVisible" width="1000" :before-close="beForeCancel" :show-close="false" top="10vh">
- <template #header="{ close, titleId, titleClass }">
- <div class="flex justify-between items-center border-b pb-3 dialog-header">
- <h4 :id="titleId">线索回收站</h4>
- <div>
- <el-button type="primary" @click="batchRestore()" v-loading="allLoading.batchRecoveryLoading">批量恢复</el-button>
- <el-button type="primary" @click="batchDeletes()"
- v-loading="allLoading.batchDeteleLoading">批量删除</el-button>
- <el-button @click="cancel()">取消</el-button>
- </div>
- </div>
- </template>
- <div class="h-[60vh] flex flex-col">
- <div class="flex-1 w-full overflow-hidden">
- <el-table ref="clueTableRef" :data="deteleClueTable" border v-loading="allLoading.tableLoading"
- style="width: 100%;height: 100%;">
- <el-table-column type="selection" width="55" />
- <el-table-column prop="clueName" label="线索名称" width="180"></el-table-column>
- <el-table-column prop="clueSourceValue" label="线索来源" width="180"></el-table-column>
- <el-table-column prop="phone" label="电话号码" width="180"></el-table-column>
- <el-table-column prop="email" label="邮箱" width="180"></el-table-column>
- <el-table-column prop="customerIndustryValue" label="客户行业" width="180"></el-table-column>
- <el-table-column prop="customerLevelValue" label="客户级别" width="180"></el-table-column>
- <el-table-column prop="inchargerName" label="负责人" width="190">
- <template #default="scope">
- <TextTranslation translationTypes="userName" :translationValue="scope.row.inchargerName"></TextTranslation>
- </template>
- </el-table-column>
- <el-table-column prop="createName" label="创建人" width="180">
- <template #default="scope">
- <TextTranslation translationTypes="userName" :translationValue="scope.row.createName"></TextTranslation>
- </template>
- </el-table-column>
- <el-table-column prop="createTime" label="创建时间" width="180"></el-table-column>
- <el-table-column label="操作" fixed="right" width="120">
- <template #default="scope">
- <el-button link type="primary" size="large" @click="restoreItemRow([scope.row])">恢复</el-button>
- <el-button link type="danger" size="large" @click="deteItemRow([scope.row])">删除</el-button>
- </template>
- </el-table-column>
- </el-table>
- </div>
- <div class="flex justify-end pt-3">
- <el-pagination layout="total, prev, pager, next, sizes" :page-size="tableForm.pageFrom"
- @size-change="handleSizeChange" @current-change="handleCurrentChange" :total="clueTotalTable"
- :hide-on-single-page="true" />
- </div>
- </div>
- </el-dialog>
- </template>
- <script lang="ts" setup>
- import { post } from '@/utils/request';
- import { ref, reactive, onMounted, watchEffect, watch, inject } from 'vue'
- import { DETERDETELE, DEYELWCLUE, ROLLBACK } from './constant';
- import { ElTable } from 'element-plus';
- import { confirmAction } from '@/utils/tools';
- const emits = defineEmits(['showDeteleClue']);
- const globalPopup = inject<GlobalPopup>('globalPopup')
- const deteleClueTable = ref([])
- const deteleClueDialogVisible = ref(false)
- const clueTotalTable = ref(0)
- const allLoading = reactive({
- batchRecoveryLoading: false,
- batchDeteleLoading: false,
- tableLoading: false
- })
- const tableForm = reactive({
- pageIndex: 1,
- pageFrom: 10
- })
- const clueTableRef = ref<InstanceType<typeof ElTable>>() // 线索table dom
- const props = defineProps<{
- visibles: boolean
- }>()
- watch(() => props.visibles, (newVal) => {
- deteleClueDialogVisible.value = newVal
- if (newVal) {
- getTableList()
- }
- })
- function batchRestore() {
- const data = clueTableRef.value && clueTableRef.value.getSelectionRows()
- if (!data.length) {
- globalPopup?.showWarning('请选择需要恢复的数据')
- return
- }
- restoreItemRow(data)
- }
- function batchDeletes() {
- const data = clueTableRef.value && clueTableRef.value.getSelectionRows()
- if (!data.length) {
- globalPopup?.showWarning('请选择需要删除的数据')
- return
- }
- deteItemRow(data)
- }
- function deteItemRow(items: any[]) {
- const ids = items.map((item: any) => item.id).join(',')
- const str = items.map((item: any) => item.clueName).join(',')
- confirmAction(`确定${items.length > 1 ? '批量删除这些' : '删除'}【${str}】线索吗?`, '', 'warning').then(() => {
- post(DETERDETELE, { ids }).then(res => {
- if (res.code != 'ok') {
- globalPopup?.showError(res.msg)
- return
- }
- globalPopup?.showSuccess('删除成功')
- getTableList()
- })
- })
- }
- function restoreItemRow(items: any[]) {
- const ids = items.map((item: any) => item.id).join(',')
- const str = items.map((item: any) => item.clueName).join(',')
- confirmAction(`确定${items.length > 1 ? '批量恢复这些' : '恢复'}【${str}】线索吗?`, '', 'warning').then(() => {
- post(ROLLBACK, { ids }).then(res => {
- if (res.code != 'ok') {
- globalPopup?.showError(res.msg)
- return
- }
- globalPopup?.showSuccess('恢复成功')
- getTableList()
- })
- })
- }
- function getTableList() {
- allLoading.tableLoading = true
- post(DEYELWCLUE, { ...tableForm }).then((res) => {
- if (res.code == 'ok') {
- const { data, total } = res.data
- deteleClueTable.value = data
- clueTotalTable.value = total
- }
- }).finally(() => {
- allLoading.tableLoading = false
- })
- }
- function handleSizeChange(val: number) {
- tableForm.pageIndex = 1
- tableForm.pageFrom = val
- getTableList()
- }
- function handleCurrentChange(val: number) {
- tableForm.pageIndex = val
- getTableList()
- }
- function cancel() {
- emits('showDeteleClue', false)
- }
- function beForeCancel(done: () => void) {
- emits('showDeteleClue', false)
- done()
- }
- onMounted(() => {
- })
- </script>
- <style lang="scss" scoped></style>
|