194 lines
5.5 KiB
Vue
194 lines
5.5 KiB
Vue
<template>
|
|
<div class="app-container">
|
|
<el-row :gutter="10" class="mb8">
|
|
<el-col :span="1.5">
|
|
<router-link to="./releaseService">
|
|
<el-button type="primary" size="small">发布需求</el-button>
|
|
</router-link>
|
|
</el-col>
|
|
<right-toolbar
|
|
v-model:showSearch="showSearch"
|
|
@queryTable="getList"
|
|
></right-toolbar>
|
|
</el-row>
|
|
|
|
<el-radio-group
|
|
v-model="queryParams.status"
|
|
size="small"
|
|
@change="handleQuery"
|
|
>
|
|
<el-radio-button :label="0">待受理</el-radio-button>
|
|
<el-radio-button :label="1">已受理</el-radio-button>
|
|
<el-radio-button :label="2">已驳回</el-radio-button>
|
|
<el-radio-button :label="4">已结束</el-radio-button>
|
|
</el-radio-group>
|
|
|
|
<el-table v-loading="loading" :data="dataList" style="margin-top: 20px">
|
|
<!-- <el-table-column label="需求名称" align="center" prop="title" /> -->
|
|
<el-table-column label="需求类别" align="center" prop="kind" />
|
|
<!-- <el-table-column label="状态" align="center" prop="status" /> -->
|
|
<el-table-column label="联系人" align="center" prop="name" />
|
|
<el-table-column label="手机号" align="center" prop="mobile" />
|
|
<el-table-column
|
|
label="发布时间"
|
|
align="center"
|
|
prop="createTime"
|
|
width="180"
|
|
>
|
|
<template #default="{ row }">
|
|
<span>{{ parseTime(row.createTime) }}</span>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
label="操作"
|
|
align="center"
|
|
class-name="small-padding fixed-width"
|
|
>
|
|
<template #default="{ row }">
|
|
<el-button
|
|
v-if="queryParams.type == 2"
|
|
size="small"
|
|
type="text"
|
|
icon="Delete"
|
|
@click="handleDelete(row.id)"
|
|
>删除</el-button
|
|
>
|
|
<el-button
|
|
v-if="queryParams.type == 0"
|
|
size="small"
|
|
type="text"
|
|
icon="Close"
|
|
@click="handleDelete(row.id)"
|
|
>取消发布</el-button
|
|
>
|
|
<el-button
|
|
v-if="queryParams.type != 2"
|
|
size="small"
|
|
type="text"
|
|
icon="View"
|
|
@click="handleEdit(row.id)"
|
|
>查看</el-button
|
|
>
|
|
<el-button
|
|
size="small"
|
|
type="text"
|
|
icon="View"
|
|
@click="complete(row.id)"
|
|
>完成</el-button
|
|
>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
|
|
<pagination
|
|
v-show="total > 0"
|
|
:total="total"
|
|
v-model:page="queryParams.pageNum"
|
|
v-model:limit="queryParams.pageSize"
|
|
@pagination="getList"
|
|
/>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup>
|
|
import { demandList } from "@/api/admin/enterprise";
|
|
import { updateDemand } from "@/api/admin/enterprise/demand";
|
|
import { ElMessage, ElMessageBox } from "element-plus";
|
|
import { onActivated } from "vue";
|
|
import { useRouter } from "vue-router";
|
|
|
|
const { proxy } = getCurrentInstance();
|
|
const router = useRouter();
|
|
|
|
const dataList = ref([]);
|
|
const loading = ref(true);
|
|
const showSearch = ref(true);
|
|
const total = ref(0);
|
|
const dateRange = ref([]);
|
|
|
|
const data = reactive({
|
|
form: {},
|
|
queryParams: {
|
|
pageNum: 1,
|
|
pageSize: 10,
|
|
status: 1,
|
|
},
|
|
rules: {
|
|
name: [{ required: true, message: "公司名称不能为空", trigger: "blur" }],
|
|
dutyParagraph: [
|
|
{ required: true, message: "公司税号不能为空", trigger: "blur" },
|
|
],
|
|
bank: [{ required: true, message: "开户行不能为空", trigger: "blur" }],
|
|
bankAccount: [
|
|
{ required: true, message: "开户行账号不能为空", trigger: "blur" },
|
|
],
|
|
bankPhone: [
|
|
{ required: true, message: "开户行电话不能为空", trigger: "blur" },
|
|
],
|
|
email: [{ required: true, message: "电子邮箱不能为空", trigger: "blur" }],
|
|
phone: [{ required: true, message: "联系电话不能为空", trigger: "blur" }],
|
|
address: [{ required: true, message: "地址不能为空", trigger: "blur" }],
|
|
username: [{ required: true, message: "联系人不能为空", trigger: "blur" }],
|
|
userPhone: [
|
|
{ required: true, message: "联系人电话不能为空", trigger: "blur" },
|
|
],
|
|
userAddress: [
|
|
{ required: true, message: "邮寄地址不能为空", trigger: "blur" },
|
|
],
|
|
},
|
|
});
|
|
|
|
const { queryParams, form, rules } = toRefs(data);
|
|
|
|
/** 查询列表 */
|
|
const getList = async () => {
|
|
loading.value = true;
|
|
const resp = await demandList(queryParams.value);
|
|
dataList.value = resp.rows;
|
|
total.value = resp.total;
|
|
loading.value = false;
|
|
};
|
|
/** 搜索按钮操作 */
|
|
function handleQuery() {
|
|
queryParams.value.pageNum = 1;
|
|
getList();
|
|
}
|
|
/** 重置按钮操作 */
|
|
function resetQuery() {
|
|
dateRange.value = [];
|
|
proxy.resetForm("queryRef");
|
|
handleQuery();
|
|
}
|
|
/** 删除按钮操作 */
|
|
function handleDelete(id) {
|
|
ElMessageBox.confirm('是否确认删除订单号为"' + id + '"的数据项?')
|
|
.then(function () {
|
|
return demandDelete(postIds);
|
|
})
|
|
.then(() => {
|
|
getList();
|
|
ElMessage.success("删除成功");
|
|
})
|
|
.catch(() => {});
|
|
}
|
|
function handleEdit(id) {
|
|
router.push({ path: "./releaseService", query: { id } });
|
|
}
|
|
|
|
// 修改为完成状态
|
|
const complete = (id) => {
|
|
ElMessageBox.confirm(`是否确认结束编号为${id}的数据项?`)
|
|
.then(async () => {
|
|
await updateDemand({ id, status: 4 });
|
|
getList();
|
|
ElMessage.success("删除成功");
|
|
})
|
|
.catch(() => {});
|
|
};
|
|
|
|
getList();
|
|
onActivated(() => {
|
|
getList();
|
|
});
|
|
</script>
|