Commit de3b0c9a authored by 何远江's avatar 何远江

添加负责客户配置页面

parent 7b002171
...@@ -3,11 +3,10 @@ const formHeader = { ...@@ -3,11 +3,10 @@ const formHeader = {
'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8' 'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'
} }
/** /**
* 获取客户列表 * 获取客户列表
* @param params * @param params
* @returns * @returns
*/ */
export const getCustomerPage = (params: any) => { export const getCustomerPage = (params: any) => {
return axios.get('/api/customer/page', { return axios.get('/api/customer/page', {
...@@ -15,3 +14,45 @@ export const getCustomerPage = (params: any) => { ...@@ -15,3 +14,45 @@ export const getCustomerPage = (params: any) => {
headers: formHeader headers: formHeader
}) })
} }
/**
* 获取用户负责客户列表
* @param params
* @returns
*/
export const getUserOrderFileConfPage = (params: any) => {
return axios.get('/api/userOrderFileConf/page', {
params,
headers: formHeader
})
}
/**
* 批量删除用户负责客户
* @param params
* @returns
*/
export const deleteUserOrderFileConfByIds = (ids: string) => {
return axios.get('/api/userOrderFileConf/batchDeleteByIds', {
params: { ids },
headers: formHeader
})
}
/**
* 添加用户负责客户
* @param data
* @returns
*/
export const addUserOrderFileConf = (data: any) => {
return axios.post('/api/userOrderFileConf/add', data)
}
/**
* 修改用户负责客户
* @param data
* @returns
*/
export const editUserOrderFileConf = (data: any) => {
return axios.post('/api/userOrderFileConf/edit', data)
}
...@@ -53,6 +53,12 @@ export const routes = [ ...@@ -53,6 +53,12 @@ export const routes = [
name: 'OrderCustomerEmail', name: 'OrderCustomerEmail',
component: () => import('@/views/customer/CustomerEmail/CustomerEmail.vue'), component: () => import('@/views/customer/CustomerEmail/CustomerEmail.vue'),
meta: { title: '客户邮箱' } meta: { title: '客户邮箱' }
},
{
path: '/order/responsible-customer',
name: 'ResponsibleCustomer',
component: () => import('@/views/customer/ResponsibleCustomer/ResponsibleCustomer.vue'),
meta: { title: '负责客户' }
} }
] ]
}, },
......
<template>
<div class="w-full h-full bg-white p-4">
<p class="font-bold text-lg leading-10 border-b-2">负责客户配置</p>
<el-form class="pt-4" :inline="true" :model="formState">
<el-form-item label="客户">
<el-input v-model="formState.customerId_dictText" placeholder="" disabled>
<template #append>
<el-button :icon="MoreFilled" @click="openModal('search')"></el-button>
</template>
</el-input>
</el-form-item>
<el-form-item label="用户">
<el-input v-model="formState.userId_dictText" placeholder="" />
</el-form-item>
<el-form-item>
<el-button type="default" @click="onReset">重置</el-button>
<el-button type="primary" @click="onQuery">查询</el-button>
</el-form-item>
</el-form>
<div class="">
<vxe-toolbar>
<template #buttons>
<!-- <vxe-button @click="allAlign = 'left'">居左</vxe-button> -->
<el-button type="primary" @click="showEdit = true">新增</el-button>
<el-button type="danger" @click="removeRows">删除</el-button>
</template>
</vxe-toolbar>
<vxe-table
ref="xTable"
size="small"
min-height="460"
border
:loading="loading"
:data="tableData"
>
<vxe-column type="checkbox" width="50"></vxe-column>
<!-- <vxe-column field="customerEmailId" title="id" width="200"></vxe-column> -->
<vxe-column field="customerId_dictText" title="客户名称" width="200"></vxe-column>
<vxe-column field="userId_dictText" title="用户名称"></vxe-column>
<vxe-column field="action" title="操作" width="100">
<template #default="{ row }">
<el-button type="primary" text size="small" @click="editRow(row)">修改</el-button>
</template>
</vxe-column>
</vxe-table>
<vxe-pager
size="small"
background
v-model:current-page="formState.currentPage"
v-model:page-size="formState.pageSize"
:total="formState.total"
@page-change="onQuery"
:layouts="['PrevPage', 'JumpNumber', 'NextPage', 'Sizes', 'FullJump', 'Total']"
>
</vxe-pager>
</div>
<vxe-modal :z-index="1005" v-model="showEdit" title="编辑&保存" destroy-on-close esc-closable @hide="onHide">
<template #default>
<el-form ref="formRef" label-width="90px" :model="formEdit" :rules="formRules">
<el-form-item label="客户" prop="customerId_dictText">
<el-input v-model="formEdit.customerId_dictText" disabled>
<template #append>
<el-button :icon="MoreFilled" @click="openModal('edit')"></el-button>
</template>
</el-input>
</el-form-item>
<el-form-item label="用户" prop="userId_dictText">
<el-input v-model="formEdit.userId_dictText" disabled>
<!-- <template #append>
<el-button :icon="MoreFilled" @click="openModal('edit')"></el-button>
</template> -->
</el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit" :loading="saveLoading">提交</el-button>
<el-button @click="showEdit = false">取消</el-button>
</el-form-item>
</el-form>
</template>
</vxe-modal>
<CustomerModal v-model:visible="visibleModal" @confirm="confirmCustomer" />
</div>
</template>
<script lang="ts" setup>
import { onMounted, reactive, ref } from 'vue'
import { ElMessage } from 'element-plus'
import type { VxeTableInstance } from 'vxe-table'
import { MoreFilled } from '@element-plus/icons-vue'
import CustomerModal from '@/components/CustomerModal/CustomerModal.vue'
import { useRoute } from 'vue-router'
import { getUserOrderFileConfPage, editUserOrderFileConf, addUserOrderFileConf, deleteUserOrderFileConfByIds } from '@/api/customer'
const route = useRoute()
const visibleModal = ref(false)
const loading = ref(false)
const saveLoading = ref(false)
const showEdit = ref(false)
const formState = reactive({
customerId_dictText: '',
userId_dictText: '',
customerId: '',
userId: '',
currentPage: 1,
pageSize: 10,
total: 0
})
const modalType = ref('')
const formRef = ref()
const xTable = ref<VxeTableInstance>()
const formRules = reactive({
userId_dictText: [{ required: true, message: '请选择邮箱客户', trigger: 'change' }],
customerId_dictText: [{ required: true, message: '请选择邮箱客户', trigger: 'change' }]
})
const formEdit = reactive<Record<string, any>>({
customerId_dictText: '',
userId_dictText: '',
})
const tableData = ref([])
const onHide = () => {
// 重置表单
Object.assign(formEdit, {
customerId_dictText: '',
userId_dictText: '',
})
}
const onReset = () => {
Object.assign(formState, {
customerName: '',
email: '',
customerId: ''
})
}
const openModal = (type: string) => {
visibleModal.value = true
modalType.value = type
}
const editRow = (row) => {
Object.assign(formEdit, row)
showEdit.value = true
}
const removeRows = async () => {
const list = xTable.value?.getCheckboxRecords()
if (list?.length) {
const ids = list.map((item) => item.userOrderFileId).join(',')
await deleteUserOrderFileConfByIds(ids)
ElMessage.success('删除成功!')
onQuery()
}
}
// 表单提交
const onSubmit = async () => {
await formRef.value.validate()
saveLoading.value = true
try {
formEdit?.userOrderFileId
? await editUserOrderFileConf(formEdit)
: await addUserOrderFileConf(formEdit)
ElMessage.success('操作成功!')
showEdit.value = false
onQuery()
} catch {}
saveLoading.value = false
}
const confirmCustomer = (list: any) => {
const [item] = list
if (!item) return
if (modalType.value === 'search') {
formState.customerId = item.customerId
formState.customerId_dictText = item.customerName
} else {
formEdit.customerId = item.customerId
formEdit.customerId_dictText = item.customerName
}
}
const onQuery = async () => {
loading.value = true
try {
const { data } = await getUserOrderFileConfPage(formState)
tableData.value = data.result.records
formState.total = +data.result.total
} catch {}
loading.value = false
}
onMounted(() => {
// Object.assign(formState, route.query)
onQuery()
})
</script>
<style lang="scss" scoped></style>
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
</el-form-item> </el-form-item>
</el-form> </el-form>
<div class="flex-1 flex overflow-hidden border rounded"> <div class="flex-1 flex overflow-hidden border rounded">
<el-scrollbar class="h-full w-96 flex border-r-2" v-loading="loading"> <el-scrollbar class="scroll-container" v-loading="loading">
<ListItem :list="emailList" @selected="onSelected" /> <ListItem :list="emailList" @selected="onSelected" />
</el-scrollbar> </el-scrollbar>
<div class="flex-1 flex flex-col"> <div class="flex-1 flex flex-col">
...@@ -78,4 +78,9 @@ onUnmounted(() => { ...@@ -78,4 +78,9 @@ onUnmounted(() => {
clearInterval(timer) clearInterval(timer)
}) })
</script> </script>
<style lang="scss" scoped></style> <style lang="scss" scoped>
.scroll-container {
width: 260px;
border-right: 2px solid #ccc;
}
</style>
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
</li> </li>
</ul> </ul>
</template> </template>
<script lang="ts"> <script lang="ts">
import { defineComponent } from 'vue' import { defineComponent } from 'vue'
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment