fix
This commit is contained in:
@@ -1,151 +1,129 @@
|
||||
<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;"
|
||||
@change="handleAmountMinChange"
|
||||
/>
|
||||
<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;"
|
||||
@change="handleAmountMaxChange"
|
||||
/>
|
||||
<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>
|
||||
<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"
|
||||
@change="handleAmountMinChange"
|
||||
/>
|
||||
<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"
|
||||
@change="handleAmountMaxChange"
|
||||
/>
|
||||
<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 #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";
|
||||
import { useMessage } from '/@/hooks/message';
|
||||
import { getObj, addObj, putObj, getRuleTypes } from '/@/api/purchase/purchasingRuleConfig';
|
||||
|
||||
const emit = defineEmits(['refresh']);
|
||||
|
||||
@@ -156,106 +134,106 @@ const formRef = ref();
|
||||
const ruleTypes = ref<{ code: string; name: string }[]>([]);
|
||||
|
||||
const isEdit = ref(false);
|
||||
const dialogTitle = computed(() => isEdit.value ? '编辑规则' : '新增规则');
|
||||
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: ''
|
||||
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' }]
|
||||
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();
|
||||
visible.value = true;
|
||||
isEdit.value = !!id;
|
||||
resetForm();
|
||||
|
||||
const res = await getRuleTypes();
|
||||
ruleTypes.value = res.data || [];
|
||||
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;
|
||||
}
|
||||
}
|
||||
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();
|
||||
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();
|
||||
const submitData = {
|
||||
...form,
|
||||
amountMin: form.amountMin ?? null,
|
||||
amountMax: form.amountMax ?? null
|
||||
};
|
||||
submitLoading.value = true;
|
||||
try {
|
||||
if (isEdit.value) {
|
||||
await putObj(submitData);
|
||||
useMessage().success('修改成功');
|
||||
} else {
|
||||
await addObj(submitData);
|
||||
useMessage().success('新增成功');
|
||||
}
|
||||
visible.value = false;
|
||||
emit('refresh');
|
||||
} catch (err: any) {
|
||||
useMessage().error(err.msg || '操作失败');
|
||||
} finally {
|
||||
submitLoading.value = false;
|
||||
}
|
||||
await formRef.value?.validate();
|
||||
const submitData = {
|
||||
...form,
|
||||
amountMin: form.amountMin ?? null,
|
||||
amountMax: form.amountMax ?? null,
|
||||
};
|
||||
submitLoading.value = true;
|
||||
try {
|
||||
if (isEdit.value) {
|
||||
await putObj(submitData);
|
||||
useMessage().success('修改成功');
|
||||
} else {
|
||||
await addObj(submitData);
|
||||
useMessage().success('新增成功');
|
||||
}
|
||||
visible.value = false;
|
||||
emit('refresh');
|
||||
} catch (err: any) {
|
||||
useMessage().error(err.msg || '操作失败');
|
||||
} finally {
|
||||
submitLoading.value = false;
|
||||
}
|
||||
};
|
||||
|
||||
const handleAmountMinChange = (val: number | undefined) => {
|
||||
form.amountMin = val ?? null;
|
||||
form.amountMin = val ?? null;
|
||||
};
|
||||
|
||||
const handleAmountMaxChange = (val: number | undefined) => {
|
||||
form.amountMax = val ?? null;
|
||||
form.amountMax = val ?? null;
|
||||
};
|
||||
|
||||
defineExpose({ openDialog });
|
||||
</script>
|
||||
</script>
|
||||
|
||||
@@ -1,116 +1,92 @@
|
||||
<template>
|
||||
<div class="layout-padding">
|
||||
<div class="layout-padding-auto layout-padding-view">
|
||||
<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-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-alert type="warning" :closable="false">既定规则请不要随意修改,否则会出错</el-alert>
|
||||
<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>
|
||||
|
||||
<el-alert type="warning" :closable="false">既定规则请不要随意修改,否则会出错</el-alert>
|
||||
<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>
|
||||
|
||||
<pagination
|
||||
@size-change="sizeChangeHandle"
|
||||
@current-change="currentChangeHandle"
|
||||
v-bind="state.pagination"
|
||||
/>
|
||||
</div>
|
||||
|
||||
<form-dialog ref="formDialogRef" @refresh="getDataList(false)" />
|
||||
</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";
|
||||
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'));
|
||||
|
||||
@@ -121,50 +97,45 @@ const selectObjs = ref([]) as any;
|
||||
const multiple = ref(true);
|
||||
|
||||
const state: BasicTableProps = reactive<BasicTableProps>({
|
||||
queryForm: {},
|
||||
pageList: fetchList
|
||||
queryForm: {},
|
||||
pageList: fetchList,
|
||||
});
|
||||
|
||||
const {
|
||||
getDataList,
|
||||
currentChangeHandle,
|
||||
sizeChangeHandle,
|
||||
tableStyle
|
||||
} = useTable(state);
|
||||
const { getDataList, currentChangeHandle, sizeChangeHandle, tableStyle } = useTable(state);
|
||||
|
||||
const selectionChangHandle = (objs: { id: string }[]) => {
|
||||
selectObjs.value = objs.map(({ id }) => id);
|
||||
multiple.value = !objs.length;
|
||||
selectObjs.value = objs.map(({ id }) => id);
|
||||
multiple.value = !objs.length;
|
||||
};
|
||||
|
||||
const handleDelete = async (ids: string[]) => {
|
||||
try {
|
||||
await useMessageBox().confirm('此操作将永久删除该规则,是否继续?');
|
||||
} catch {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
await useMessageBox().confirm('此操作将永久删除该规则,是否继续?');
|
||||
} catch {
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
await delObjs(ids);
|
||||
getDataList();
|
||||
useMessage().success('删除成功');
|
||||
} catch (err: any) {
|
||||
useMessage().error(err.msg || '删除失败');
|
||||
}
|
||||
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) + '万';
|
||||
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;
|
||||
const map: Record<string, string> = {
|
||||
isCentralized: '是否集采',
|
||||
isSpecial: '是否特殊',
|
||||
hasSupplier: '是否有推荐供应商',
|
||||
projectType: '项目类别',
|
||||
};
|
||||
return map[field] || field;
|
||||
};
|
||||
</script>
|
||||
</script>
|
||||
|
||||
Reference in New Issue
Block a user