This commit is contained in:
吴红兵
2026-03-03 13:59:57 +08:00
parent d0e4071836
commit 168e134e1b
5 changed files with 642 additions and 20 deletions

View File

@@ -0,0 +1,246 @@
<template>
<el-dialog
v-model="visible"
:title="dialogTitle"
width="700px"
:close-on-click-modal="false"
draggable
>
<el-form
ref="formRef"
:model="form"
:rules="rules"
label-width="120px"
v-loading="loading"
>
<el-row :gutter="16">
<el-col :span="12">
<el-form-item label="规则编码" prop="ruleCode">
<el-input v-model="form.ruleCode" placeholder="请输入规则编码" :disabled="isEdit" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="规则名称" prop="ruleName">
<el-input v-model="form.ruleName" placeholder="请输入规则名称" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="规则类型" prop="ruleType">
<el-select v-model="form.ruleType" placeholder="请选择规则类型" style="width: 100%">
<el-option
v-for="item in ruleTypes"
:key="item.code"
:label="item.name"
:value="item.code"
/>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="优先级" prop="sortOrder">
<el-input-number v-model="form.sortOrder" :min="1" :max="999" style="width: 100%" />
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="金额区间">
<div style="display: flex; align-items: center; gap: 8px;">
<el-input-number
v-model="form.amountMin"
:min="0"
:precision="2"
:controls="false"
placeholder="金额下限"
style="width: 200px;"
/>
<span></span>
<span style="margin: 0 8px;"></span>
<el-input-number
v-model="form.amountMax"
:min="0"
:precision="2"
:controls="false"
placeholder="金额上限"
style="width: 200px;"
/>
<span></span>
<span style="color: #909399; font-size: 12px;">不填表示不限</span>
</div>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="附加条件字段">
<el-select v-model="form.conditionField" placeholder="请选择" clearable style="width: 100%">
<el-option label="是否集采" value="isCentralized" />
<el-option label="是否特殊情况" value="isSpecial" />
<el-option label="是否有推荐供应商" value="hasSupplier" />
<el-option label="项目类别" value="projectType" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="附加条件值">
<el-input v-model="form.conditionValue" placeholder="如0、1、A等" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="动作类型" prop="actionType">
<el-select v-model="form.actionType" placeholder="请选择动作类型" style="width: 100%">
<el-option label="设置字段值" value="SET_FIELD" />
<el-option label="切换模板" value="SWITCH_TEMPLATE" />
<el-option label="要求文件" value="REQUIRE_FILE" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="动作目标" prop="actionTarget">
<el-select v-model="form.actionTarget" placeholder="请选择" allow-create filterable style="width: 100%">
<el-option v-if="form.actionType === 'SET_FIELD'" label="采购形式" value="purchaseMode" />
<el-option v-if="form.actionType === 'SET_FIELD'" label="学校采购方式" value="purchaseSchool" />
<el-option v-if="form.actionType === 'SWITCH_TEMPLATE'" label="比选模板" value="bidTemplate" />
<el-option v-if="form.actionType === 'REQUIRE_FILE'" label="可行性论证报告" value="feasibilityReport" />
<el-option v-if="form.actionType === 'REQUIRE_FILE'" label="会议纪要" value="meetingMinutes" />
<el-option v-if="form.actionType === 'REQUIRE_FILE'" label="政府采购意向表" value="governmentIntention" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="动作值">
<el-input v-model="form.actionValue" placeholder="设置的值" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="是否启用">
<el-radio-group v-model="form.isEnabled">
<el-radio label="1">启用</el-radio>
<el-radio label="0">禁用</el-radio>
</el-radio-group>
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="规则描述">
<el-input
v-model="form.description"
type="textarea"
:rows="2"
placeholder="请输入规则描述"
/>
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="备注">
<el-input v-model="form.remark" placeholder="请输入备注" />
</el-form-item>
</el-col>
</el-row>
</el-form>
<template #footer>
<el-button @click="visible = false">取消</el-button>
<el-button type="primary" @click="handleSubmit" :loading="submitLoading">确定</el-button>
</template>
</el-dialog>
</template>
<script setup lang="ts">
import { useMessage } from "/@/hooks/message";
import { getObj, addObj, putObj, getRuleTypes } from "/@/api/purchase/purchasingRuleConfig";
const emit = defineEmits(['refresh']);
const visible = ref(false);
const loading = ref(false);
const submitLoading = ref(false);
const formRef = ref();
const ruleTypes = ref<{ code: string; name: string }[]>([]);
const isEdit = ref(false);
const dialogTitle = computed(() => isEdit.value ? '编辑规则' : '新增规则');
const form = reactive({
id: '',
ruleCode: '',
ruleName: '',
ruleType: '',
amountMin: null as number | null,
amountMax: null as number | null,
conditionField: '',
conditionValue: '',
actionType: '',
actionTarget: '',
actionValue: '',
description: '',
sortOrder: 1,
isEnabled: '1',
remark: ''
});
const rules = {
ruleCode: [{ required: true, message: '请输入规则编码', trigger: 'blur' }],
ruleName: [{ required: true, message: '请输入规则名称', trigger: 'blur' }],
ruleType: [{ required: true, message: '请选择规则类型', trigger: 'change' }],
actionType: [{ required: true, message: '请选择动作类型', trigger: 'change' }],
actionTarget: [{ required: true, message: '请输入动作目标', trigger: 'blur' }]
};
const openDialog = async (id?: string) => {
visible.value = true;
isEdit.value = !!id;
resetForm();
const res = await getRuleTypes();
ruleTypes.value = res.data || [];
if (id) {
loading.value = true;
try {
const response = await getObj(id);
if (response.data) {
Object.assign(form, response.data);
}
} finally {
loading.value = false;
}
}
};
const resetForm = () => {
form.id = '';
form.ruleCode = '';
form.ruleName = '';
form.ruleType = '';
form.amountMin = null;
form.amountMax = null;
form.conditionField = '';
form.conditionValue = '';
form.actionType = '';
form.actionTarget = '';
form.actionValue = '';
form.description = '';
form.sortOrder = 1;
form.isEnabled = '1';
form.remark = '';
formRef.value?.resetFields();
};
const handleSubmit = async () => {
await formRef.value?.validate();
submitLoading.value = true;
try {
if (isEdit.value) {
await putObj(form);
useMessage().success('修改成功');
} else {
await addObj(form);
useMessage().success('新增成功');
}
visible.value = false;
emit('refresh');
} catch (err: any) {
useMessage().error(err.msg || '操作失败');
} finally {
submitLoading.value = false;
}
};
defineExpose({ openDialog });
</script>

View File

@@ -0,0 +1,169 @@
<template>
<div class="layout-padding">
<div class="layout-padding-auto layout-padding-view">
<el-row>
<div class="mb8" style="width: 100%">
<el-button
icon="folder-add"
type="primary"
class="ml10"
@click="formDialogRef.openDialog()"
v-auth="'purchase_purchasingruleconfig_add'"
>
新增规则
</el-button>
<el-button
plain
:disabled="multiple"
icon="Delete"
type="primary"
v-auth="'purchase_purchasingruleconfig_del'"
@click="handleDelete(selectObjs)"
>
删除
</el-button>
<right-toolbar
v-model:showSearch="showSearch"
class="ml10 mr20"
style="float: right;"
@queryTable="getDataList"
/>
</div>
</el-row>
<el-table
:data="state.dataList"
v-loading="state.loading"
border
:cell-style="tableStyle.cellStyle"
:header-cell-style="tableStyle.headerCellStyle"
@selection-change="selectionChangHandle"
>
<el-table-column type="selection" width="40" align="center" />
<el-table-column type="index" label="#" width="50" />
<el-table-column prop="ruleCode" label="规则编码" width="180" show-overflow-tooltip />
<el-table-column prop="ruleName" label="规则名称" min-width="200" show-overflow-tooltip />
<el-table-column prop="ruleTypeName" label="规则类型" width="120" />
<el-table-column label="金额区间" width="180">
<template #default="scope">
<span v-if="scope.row.amountMin || scope.row.amountMax">
{{ formatAmount(scope.row.amountMin) }} ~ {{ formatAmount(scope.row.amountMax) }}
</span>
<span v-else>-</span>
</template>
</el-table-column>
<el-table-column label="附加条件" width="150">
<template #default="scope">
<span v-if="scope.row.conditionField">
{{ getConditionLabel(scope.row.conditionField) }} = {{ scope.row.conditionValue }}
</span>
<span v-else>-</span>
</template>
</el-table-column>
<el-table-column prop="actionTypeName" label="动作类型" width="100" />
<el-table-column prop="description" label="规则描述" min-width="250" show-overflow-tooltip />
<el-table-column prop="sortOrder" label="优先级" width="80" align="center" />
<el-table-column label="状态" width="80" align="center">
<template #default="scope">
<el-tag :type="scope.row.isEnabled === '1' ? 'success' : 'danger'" size="small">
{{ scope.row.isEnabled === '1' ? '启用' : '禁用' }}
</el-tag>
</template>
</el-table-column>
<el-table-column label="操作" width="150" fixed="right">
<template #default="scope">
<el-button
icon="edit-pen"
text
type="primary"
v-auth="'purchase_purchasingruleconfig_edit'"
@click="formDialogRef.openDialog(scope.row.id)"
>
编辑
</el-button>
<el-button
icon="delete"
text
type="primary"
v-auth="'purchase_purchasingruleconfig_del'"
@click="handleDelete([scope.row.id])"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<pagination
@size-change="sizeChangeHandle"
@current-change="currentChangeHandle"
v-bind="state.pagination"
/>
</div>
<form-dialog ref="formDialogRef" @refresh="getDataList(false)" />
</div>
</template>
<script setup lang="ts" name="purchasingRuleConfig">
import { BasicTableProps, useTable } from "/@/hooks/table";
import { fetchList, delObjs } from "/@/api/purchase/purchasingRuleConfig";
import { useMessage, useMessageBox } from "/@/hooks/message";
const FormDialog = defineAsyncComponent(() => import('./form.vue'));
const formDialogRef = ref();
const queryRef = ref();
const showSearch = ref(true);
const selectObjs = ref([]) as any;
const multiple = ref(true);
const state: BasicTableProps = reactive<BasicTableProps>({
queryForm: {},
pageList: fetchList
});
const {
getDataList,
currentChangeHandle,
sizeChangeHandle,
tableStyle
} = useTable(state);
const selectionChangHandle = (objs: { id: string }[]) => {
selectObjs.value = objs.map(({ id }) => id);
multiple.value = !objs.length;
};
const handleDelete = async (ids: string[]) => {
try {
await useMessageBox().confirm('此操作将永久删除该规则,是否继续?');
} catch {
return;
}
try {
await delObjs(ids);
getDataList();
useMessage().success('删除成功');
} catch (err: any) {
useMessage().error(err.msg || '删除失败');
}
};
const formatAmount = (amount: number | null) => {
if (amount === null || amount === undefined) return '不限';
return (amount / 10000).toFixed(0) + '万';
};
const getConditionLabel = (field: string) => {
const map: Record<string, string> = {
isCentralized: '是否集采',
isSpecial: '是否特殊',
hasSupplier: '是否有推荐供应商',
projectType: '项目类别'
};
return map[field] || field;
};
</script>