<script lang="ts" setup name="procurementComplaint">
|
import { ref, reactive, onMounted } from "vue";
|
import { ElMessageBox, ElMessage } from "element-plus";
|
// import { downloadStreamFile } from "@/utils/download";
|
import { useProcurementComplaintApi } from "/@/api/fb_p_complaints/procurementComplaint";
|
import editDialog from "/@/views/fb_p_complaints/procurementComplaint/component/editDialog.vue";
|
import printDialog from "/@/views/system/print/component/hiprint/preview.vue";
|
import ModifyRecord from "/@/components/table/modifyRecord.vue";
|
import ImportData from "/@/components/table/importData.vue";
|
import commonFunction from "@/utils/commonFunction";
|
|
const { dateFormatYMD } = commonFunction();
|
const procurementComplaintApi = useProcurementComplaintApi();
|
const printDialogRef = ref();
|
const editDialogRef = ref();
|
const importDataRef = ref();
|
const state = reactive({
|
exportLoading: false,
|
tableLoading: false,
|
stores: {},
|
showAdvanceQueryUI: false,
|
dropdownData: {} as any,
|
selectData: [] as any[],
|
tableQueryParams: {} as any,
|
tableParams: {
|
page: 1,
|
pageSize: 20,
|
total: 0,
|
field: "decisionDate", // 默认的排序字段
|
order: "descending", // 排序方向
|
descStr: "descending" // 降序排序的关键字符
|
},
|
tableData: []
|
});
|
|
// 页面加载时
|
onMounted(async () => {});
|
|
// 查询操作
|
const handleQuery = async (params: any = {}) => {
|
state.tableLoading = true;
|
state.tableParams = Object.assign(state.tableParams, params);
|
const result = await procurementComplaintApi
|
.page(Object.assign(state.tableQueryParams, state.tableParams))
|
.then(res => res.data.result);
|
state.tableParams.total = result?.total;
|
state.tableData = result?.items ?? [];
|
state.tableLoading = false;
|
};
|
|
// 列排序
|
const sortChange = async (column: any) => {
|
state.tableParams.field = column.prop;
|
state.tableParams.order = column.order;
|
await handleQuery();
|
};
|
|
// 删除
|
const delProcurementComplaint = (row: any) => {
|
ElMessageBox.confirm(`确定要删除吗?`, "提示", {
|
confirmButtonText: "确定",
|
cancelButtonText: "取消",
|
type: "warning"
|
})
|
.then(async () => {
|
await procurementComplaintApi.delete({ id: row.id });
|
handleQuery();
|
ElMessage.success("删除成功");
|
})
|
.catch(() => {});
|
};
|
|
// 批量删除
|
const batchDelProcurementComplaint = () => {
|
ElMessageBox.confirm(
|
`确定要删除${state.selectData.length}条记录吗?`,
|
"提示",
|
{
|
confirmButtonText: "确定",
|
cancelButtonText: "取消",
|
type: "warning"
|
}
|
)
|
.then(async () => {
|
await procurementComplaintApi
|
.batchDelete(state.selectData.map(u => ({ id: u.id })))
|
.then(res => {
|
ElMessage.success(`成功批量删除${res.data.result}条记录`);
|
handleQuery();
|
});
|
})
|
.catch(() => {});
|
};
|
|
// 导出数据
|
const exportProcurementComplaintCommand = async (command: string) => {
|
try {
|
state.exportLoading = true;
|
if (command === "select") {
|
const params = Object.assign(
|
{},
|
state.tableQueryParams,
|
state.tableParams,
|
{ selectKeyList: state.selectData.map(u => u.id) }
|
);
|
await procurementComplaintApi
|
.exportData(params)
|
.then(res => downloadStreamFile(res));
|
} else if (command === "current") {
|
const params = Object.assign(
|
{},
|
state.tableQueryParams,
|
state.tableParams
|
);
|
await procurementComplaintApi
|
.exportData(params)
|
.then(res => downloadStreamFile(res));
|
} else if (command === "all") {
|
const params = Object.assign(
|
{},
|
state.tableQueryParams,
|
state.tableParams,
|
{ page: 1, pageSize: 99999999 }
|
);
|
await procurementComplaintApi
|
.exportData(params)
|
.then(res => downloadStreamFile(res));
|
}
|
} finally {
|
state.exportLoading = false;
|
}
|
};
|
|
handleQuery();
|
</script>
|
<template>
|
<div v-loading="state.exportLoading" class="procurementComplaint-container">
|
<el-card shadow="hover" :body-style="{ paddingBottom: '0' }">
|
<el-form ref="queryForm" :model="state.tableQueryParams" labelWidth="90">
|
<el-row>
|
<el-col :xs="24" :sm="12" :md="12" :lg="5" :xl="4" class="mb10">
|
<el-form-item label="决定日期">
|
<el-date-picker
|
v-model="state.tableQueryParams.decisionDateRange"
|
type="daterange"
|
value-format="YYYY-MM-DD HH:mm:ss"
|
start-placeholder="开始日期"
|
end-placeholder="结束日期"
|
:default-time="[new Date('1 00:00:00'), new Date('1 23:59:59')]"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col
|
v-if="state.showAdvanceQueryUI"
|
:xs="24"
|
:sm="12"
|
:md="12"
|
:lg="4"
|
:xl="4"
|
class="mb10"
|
>
|
<el-form-item label="项目名称">
|
<el-input
|
v-model="state.tableQueryParams.projectName"
|
clearable
|
placeholder="请输入项目名称"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col
|
v-if="state.showAdvanceQueryUI"
|
:xs="24"
|
:sm="12"
|
:md="12"
|
:lg="4"
|
:xl="4"
|
class="mb10"
|
>
|
<el-form-item label="项目编号">
|
<el-input
|
v-model="state.tableQueryParams.projectCode"
|
clearable
|
placeholder="请输入项目编号"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col
|
v-if="state.showAdvanceQueryUI"
|
:xs="24"
|
:sm="12"
|
:md="12"
|
:lg="4"
|
:xl="4"
|
class="mb10"
|
>
|
<el-form-item label="采购人">
|
<el-input
|
v-model="state.tableQueryParams.purchaser"
|
clearable
|
placeholder="请输入采购人"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col
|
v-if="state.showAdvanceQueryUI"
|
:xs="24"
|
:sm="12"
|
:md="12"
|
:lg="4"
|
:xl="4"
|
class="mb10"
|
>
|
<el-form-item label="采购代理机构">
|
<el-input
|
v-model="state.tableQueryParams.procurementAgency"
|
clearable
|
placeholder="请输入采购代理机构"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col
|
v-if="state.showAdvanceQueryUI"
|
:xs="24"
|
:sm="12"
|
:md="12"
|
:lg="5"
|
:xl="4"
|
class="mb10"
|
>
|
<el-form-item label="采购监督部门">
|
<el-input
|
v-model="
|
state.tableQueryParams.procurementSupervisionDepartment
|
"
|
clearable
|
placeholder="请输入采购监督部门"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col
|
v-if="state.showAdvanceQueryUI"
|
:xs="24"
|
:sm="12"
|
:md="12"
|
:lg="4"
|
:xl="4"
|
class="mb10"
|
>
|
<el-form-item label="投诉人">
|
<el-input
|
v-model="state.tableQueryParams.complainant"
|
clearable
|
placeholder="请输入投诉人"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col
|
v-if="state.showAdvanceQueryUI"
|
:xs="24"
|
:sm="12"
|
:md="12"
|
:lg="4"
|
:xl="4"
|
class="mb10"
|
>
|
<el-form-item label="投诉事项">
|
<el-input
|
v-model="state.tableQueryParams.keyword"
|
clearable
|
placeholder="请输入投诉事项"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col
|
v-if="state.showAdvanceQueryUI"
|
:xs="24"
|
:sm="12"
|
:md="12"
|
:lg="4"
|
:xl="4"
|
class="mb10"
|
>
|
<el-form-item label="是否成立">
|
<el-select
|
v-model="state.tableQueryParams.status"
|
placeholder="请选择"
|
clearable
|
>
|
<el-option label="成立" value="Valid" />
|
<el-option label="驳回" value="Rejected" />
|
<el-option label="其它" value="Other" />
|
</el-select>
|
</el-form-item>
|
</el-col>
|
|
<!-- <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10">
|
<el-form-item label="关键字">
|
<el-input v-model="state.tableQueryParams.keyword" clearable placeholder="请输入模糊查询关键字"/>
|
</el-form-item>
|
</el-col> -->
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10">
|
<el-form-item>
|
<el-button-group style="display: flex; align-items: center">
|
<el-button
|
v-reclick="1000"
|
type="primary"
|
icon="ele-Search"
|
@click="handleQuery"
|
>
|
查询
|
</el-button>
|
<el-button
|
icon="ele-Refresh"
|
@click="() => (state.tableQueryParams = {})"
|
>
|
重置
|
</el-button>
|
<el-button
|
v-if="!state.showAdvanceQueryUI"
|
icon="ele-ZoomIn"
|
style="margin-left: 5px"
|
@click="() => (state.showAdvanceQueryUI = true)"
|
>
|
高级查询
|
</el-button>
|
<el-button
|
v-if="state.showAdvanceQueryUI"
|
icon="ele-ZoomOut"
|
style="margin-left: 5px"
|
@click="() => (state.showAdvanceQueryUI = false)"
|
>
|
隐藏
|
</el-button>
|
<el-button
|
type="danger"
|
style="margin-left: 5px"
|
icon="ele-Delete"
|
:disabled="state.selectData.length == 0"
|
@click="batchDelProcurementComplaint"
|
>
|
删除
|
</el-button>
|
<el-button
|
type="primary"
|
style="margin-left: 5px"
|
icon="ele-Plus"
|
@click="
|
editDialogRef.openDialog(null, '新增政府采购投诉数据处理')
|
"
|
>
|
新增
|
</el-button>
|
<!-- <el-dropdown :show-timeout="70" :hide-timeout="50" @command="exportProcurementComplaintCommand">
|
<el-button type="primary" style="margin-left:5px;" icon="ele-FolderOpened" v-reclick="20000"
|
v-auth="'procurementComplaint:export'"> 导出 </el-button>
|
<template #dropdown>
|
<el-dropdown-menu>
|
<el-dropdown-item command="select"
|
:disabled="state.selectData.length == 0">导出选中</el-dropdown-item>
|
<el-dropdown-item command="current">导出本页</el-dropdown-item>
|
<el-dropdown-item command="all">导出全部</el-dropdown-item>
|
</el-dropdown-menu>
|
</template>
|
</el-dropdown>
|
<el-button type="warning" style="margin-left:5px;" icon="ele-MostlyCloudy"
|
@click="importDataRef.openDialog()" v-auth="'procurementComplaint:import'"> 导入 </el-button> -->
|
</el-button-group>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
</el-form>
|
</el-card>
|
<el-card class="full-table" shadow="hover" style="margin-top: 5px">
|
<el-table
|
v-loading="state.tableLoading"
|
:data="state.tableData"
|
:default-sort="{ prop: 'decisionDate', order: 'descending' }"
|
style="width: 100%"
|
tooltip-effect="light"
|
row-key="id"
|
border
|
@selection-change="
|
(val: any[]) => {
|
state.selectData = val;
|
}
|
"
|
@sort-change="sortChange"
|
>
|
<el-table-column type="selection" width="40" align="center" />
|
<el-table-column type="index" label="序号" width="55" align="center" />
|
<el-table-column
|
prop="decisionDate"
|
label="决定日期"
|
width="90"
|
show-overflow-tooltip
|
sortable
|
>
|
<template #default="{ row }">
|
<span>{{ dateFormatYMD(null, null, row.decisionDate) }}</span>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="projectName"
|
label="项目名称"
|
show-overflow-tooltip
|
/>
|
<el-table-column
|
prop="projectCode"
|
label="项目编号"
|
width="135"
|
show-overflow-tooltip
|
/>
|
<el-table-column
|
prop="purchaser"
|
label="采购人"
|
show-overflow-tooltip
|
/>
|
<el-table-column
|
prop="procurementAgency"
|
label="采购代理机构"
|
show-overflow-tooltip
|
/>
|
<el-table-column
|
prop="complainant"
|
label="投诉人"
|
show-overflow-tooltip
|
/>
|
<el-table-column
|
prop="procurementSupervisionDepartment"
|
label="采购监督部门"
|
width="140"
|
show-overflow-tooltip
|
/>
|
<!-- <el-table-column prop='complaints' label='是否成立' show-overflow-tooltip /> -->
|
<el-table-column prop="url" label="线上地址" show-overflow-tooltip>
|
<template #default="{ row }">
|
<el-link underline :href="row.url" target="_blank">{{
|
row.url
|
}}</el-link>
|
</template>
|
</el-table-column>
|
<!-- <el-table-column label="修改记录" width="100" align="center" show-overflow-tooltip>
|
<template #default="scope">
|
<ModifyRecord :data="scope.row" />
|
</template>
|
</el-table-column> -->
|
<el-table-column
|
label="操作"
|
width="70"
|
align="center"
|
fixed="right"
|
show-overflow-tooltip
|
>
|
<template #default="scope">
|
<el-button
|
icon="ele-Edit"
|
size="small"
|
text
|
type="primary"
|
@click="
|
editDialogRef.openDialog(scope.row, '编辑政府采购投诉数据处理')
|
"
|
/>
|
<el-button
|
icon="ele-Delete"
|
size="small"
|
text
|
type="primary"
|
@click="delProcurementComplaint(scope.row)"
|
/>
|
</template>
|
</el-table-column>
|
</el-table>
|
<el-pagination
|
v-model:currentPage="state.tableParams.page"
|
v-model:page-size="state.tableParams.pageSize"
|
layout="total, sizes, prev, pager, next, jumper"
|
:page-sizes="[10, 20, 50, 100, 200, 500]"
|
:total="state.tableParams.total"
|
size="small"
|
background
|
@size-change="(val: any) => handleQuery({ pageSize: val })"
|
@current-change="(val: any) => handleQuery({ page: val })"
|
/>
|
<ImportData
|
ref="importDataRef"
|
:import="procurementComplaintApi.importData"
|
:download="procurementComplaintApi.downloadTemplate"
|
@refresh="handleQuery"
|
/>
|
<printDialog
|
ref="printDialogRef"
|
:title="'打印政府采购投诉数据处理'"
|
@reloadTable="handleQuery"
|
/>
|
<editDialog ref="editDialogRef" @reloadTable="handleQuery" />
|
</el-card>
|
</div>
|
</template>
|
<style scoped>
|
:deep(.el-input),
|
:deep(.el-select),
|
:deep(.el-input-number) {
|
width: 100%;
|
}
|
</style>
|