完成工程管理模块前端页面与SQL脚本开发

This commit is contained in:
zuqijia
2026-06-12 14:21:54 +08:00
parent 41720e624c
commit 81d3c03f09
72 changed files with 9926 additions and 319 deletions

View File

@@ -0,0 +1,77 @@
import request from '@/utils/request'
export function listConstruction(query) {
return request({
url: '/system/engineering/construction/list',
method: 'get',
params: query
})
}
export function getConstructionTree(query) {
return request({
url: '/system/engineering/construction/tree',
method: 'get',
params: query
})
}
export function getConstruction(constructionId) {
return request({
url: '/system/engineering/construction/' + constructionId,
method: 'get'
})
}
export function addConstruction(data) {
return request({
url: '/system/engineering/construction',
method: 'post',
data: data
})
}
export function updateConstruction(data) {
return request({
url: '/system/engineering/construction',
method: 'put',
data: data
})
}
export function delConstruction(constructionIds) {
return request({
url: '/system/engineering/construction/' + constructionIds,
method: 'delete'
})
}
export function updateProgress(constructionId, progress) {
return request({
url: '/system/engineering/construction/progress/' + constructionId + '?progress=' + progress,
method: 'put'
})
}
export function submitAcceptance(constructionId, remark) {
return request({
url: '/system/engineering/construction/acceptance/submit/' + constructionId,
method: 'put',
data: remark ? { remark } : {}
})
}
export function approveAcceptance(constructionId, data) {
return request({
url: '/system/engineering/construction/acceptance/approve/' + constructionId,
method: 'put',
data: data
})
}
export function getConstructionStatistics(contractId) {
return request({
url: '/system/engineering/construction/statistics/' + contractId,
method: 'get'
})
}

View File

@@ -0,0 +1,97 @@
import request from '@/utils/request'
export function listContract(query) {
return request({
url: '/system/engineering/contract/list',
method: 'get',
params: query
})
}
export function getContract(contractId) {
return request({
url: '/system/engineering/contract/' + contractId,
method: 'get'
})
}
export function addContract(data) {
return request({
url: '/system/engineering/contract',
method: 'post',
data: data
})
}
export function updateContract(data) {
return request({
url: '/system/engineering/contract',
method: 'put',
data: data
})
}
export function delContract(contractIds) {
return request({
url: '/system/engineering/contract/' + contractIds,
method: 'delete'
})
}
export function updateContractStatus(contractId, status) {
return request({
url: '/system/engineering/contract/status/' + contractId + '/' + status,
method: 'put'
})
}
export function getContractOptions() {
return request({
url: '/system/engineering/contract/options',
method: 'get'
})
}
export function getContractDetail(contractId) {
return request({
url: '/system/engineering/contract/detail/' + contractId,
method: 'get'
})
}
export function addContractChange(data) {
return request({
url: '/system/engineering/contract/change',
method: 'post',
data: data
})
}
export function updateContractChange(data) {
return request({
url: '/system/engineering/contract/change',
method: 'put',
data: data
})
}
export function delContractChange(changeId) {
return request({
url: '/system/engineering/contract/change/' + changeId,
method: 'delete'
})
}
export function getContractChanges(contractId) {
return request({
url: '/system/engineering/contract/changes/' + contractId,
method: 'get'
})
}
export function approveContractChange(changeId, approvalResult) {
return request({
url: '/system/engineering/contract/change/approve/' + changeId + '?approvalResult=' + approvalResult,
method: 'put'
})
}

View File

@@ -0,0 +1,136 @@
import request from '@/utils/request'
export function listMaterial(query) {
return request({
url: '/system/engineering/material/list',
method: 'get',
params: query
})
}
export function getMaterial(materialId) {
return request({
url: '/system/engineering/material/' + materialId,
method: 'get'
})
}
export function addMaterial(data) {
return request({
url: '/system/engineering/material',
method: 'post',
data: data
})
}
export function updateMaterial(data) {
return request({
url: '/system/engineering/material',
method: 'put',
data: data
})
}
export function delMaterial(materialIds) {
return request({
url: '/system/engineering/material/' + materialIds,
method: 'delete'
})
}
export function getMaterialOptions() {
return request({
url: '/system/engineering/material/options',
method: 'get'
})
}
export function listMaterialIn(query) {
return request({
url: '/system/engineering/material/in/list',
method: 'get',
params: query
})
}
export function getMaterialIn(inId) {
return request({
url: '/system/engineering/material/in/' + inId,
method: 'get'
})
}
export function addMaterialIn(data) {
return request({
url: '/system/engineering/material/in',
method: 'post',
data: data
})
}
export function updateMaterialIn(data) {
return request({
url: '/system/engineering/material/in',
method: 'put',
data: data
})
}
export function approveMaterialIn(inId) {
return request({
url: '/system/engineering/material/in/approve/' + inId,
method: 'put'
})
}
export function delMaterialIn(inId) {
return request({
url: '/system/engineering/material/in/' + inId,
method: 'delete'
})
}
export function listMaterialOut(query) {
return request({
url: '/system/engineering/material/out/list',
method: 'get',
params: query
})
}
export function getMaterialOut(outId) {
return request({
url: '/system/engineering/material/out/' + outId,
method: 'get'
})
}
export function addMaterialOut(data) {
return request({
url: '/system/engineering/material/out',
method: 'post',
data: data
})
}
export function updateMaterialOut(data) {
return request({
url: '/system/engineering/material/out',
method: 'put',
data: data
})
}
export function approveMaterialOut(outId) {
return request({
url: '/system/engineering/material/out/approve/' + outId,
method: 'put'
})
}
export function delMaterialOut(outId) {
return request({
url: '/system/engineering/material/out/' + outId,
method: 'delete'
})
}

View File

@@ -0,0 +1,67 @@
import request from '@/utils/request'
export function listPayment(query) {
return request({
url: '/system/engineering/payment/list',
method: 'get',
params: query
})
}
export function getPayment(paymentId) {
return request({
url: '/system/engineering/payment/' + paymentId,
method: 'get'
})
}
export function addPayment(data) {
return request({
url: '/system/engineering/payment',
method: 'post',
data: data
})
}
export function updatePayment(data) {
return request({
url: '/system/engineering/payment',
method: 'put',
data: data
})
}
export function delPayment(paymentIds) {
return request({
url: '/system/engineering/payment/' + paymentIds,
method: 'delete'
})
}
export function approvePayment(paymentId) {
return request({
url: '/system/engineering/payment/approve/' + paymentId,
method: 'put'
})
}
export function rejectPayment(paymentId) {
return request({
url: '/system/engineering/payment/reject/' + paymentId,
method: 'put'
})
}
export function processPayment(paymentId) {
return request({
url: '/system/engineering/payment/process/' + paymentId,
method: 'put'
})
}
export function getPaymentsByContract(contractId) {
return request({
url: '/system/engineering/payment/contract/' + contractId,
method: 'get'
})
}

View File

@@ -0,0 +1,99 @@
import request from '@/utils/request'
export function listSupplier(query) {
return request({
url: '/system/engineering/supplier/list',
method: 'get',
params: query
})
}
export function getSupplier(supplierId) {
return request({
url: '/system/engineering/supplier/' + supplierId,
method: 'get'
})
}
export function addSupplier(data) {
return request({
url: '/system/engineering/supplier',
method: 'post',
data: data
})
}
export function updateSupplier(data) {
return request({
url: '/system/engineering/supplier',
method: 'put',
data: data
})
}
export function delSupplier(supplierIds) {
return request({
url: '/system/engineering/supplier/' + supplierIds,
method: 'delete'
})
}
export function updateSupplierStatus(supplierId, status) {
return request({
url: '/system/engineering/supplier/status/' + supplierId + '/' + status,
method: 'put'
})
}
export function getSupplierOptions(status) {
const params = status ? { status } : {}
return request({
url: '/system/engineering/supplier/options',
method: 'get',
params: params
})
}
export function getSupplierDetail(supplierId) {
return request({
url: '/system/engineering/supplier/detail/' + supplierId,
method: 'get'
})
}
export function addSupplierAccount(data) {
return request({
url: '/system/engineering/supplier/account',
method: 'post',
data: data
})
}
export function updateSupplierAccount(data) {
return request({
url: '/system/engineering/supplier/account',
method: 'put',
data: data
})
}
export function delSupplierAccount(accountId) {
return request({
url: '/system/engineering/supplier/account/' + accountId,
method: 'delete'
})
}
export function getSupplierAccounts(supplierId) {
return request({
url: '/system/engineering/supplier/accounts/' + supplierId,
method: 'get'
})
}
export function getSupplierPaymentRecords(supplierId) {
return request({
url: '/system/engineering/supplier/payment-records/' + supplierId,
method: 'get'
})
}

View File

@@ -1 +0,0 @@
<svg width="128" height="128" xmlns="http://www.w3.org/2000/svg"><path d="M96.258 57.462h31.421C124.794 27.323 100.426 2.956 70.287.07v31.422a32.856 32.856 0 0 1 25.971 25.97zm-38.796-25.97V.07C27.323 2.956 2.956 27.323.07 57.462h31.422a32.856 32.856 0 0 1 25.97-25.97zm12.825 64.766v31.421c30.46-2.885 54.507-27.253 57.713-57.712H96.579c-2.886 13.466-13.146 23.726-26.292 26.291zM31.492 70.287H.07c2.886 30.46 27.253 54.507 57.713 57.713V96.579c-13.466-2.886-23.726-13.146-26.291-26.292z"/></svg>

Before

Width:  |  Height:  |  Size: 497 B

View File

@@ -96,6 +96,48 @@ export const constantRoutes = [
}
]
export const engineeringRoutes = [
{
path: '/engineering',
component: Layout,
redirect: '/engineering/supplier',
name: 'Engineering',
meta: { title: '工程管理', icon: 'build', permission: 'system:engineering' },
children: [
{
path: 'supplier',
component: () => import('@/views/engineering/supplier/index'),
name: 'Supplier',
meta: { title: '供应商管理', icon: 'people', permission: 'system:engineering:supplier' }
},
{
path: 'contract',
component: () => import('@/views/engineering/contract/index'),
name: 'Contract',
meta: { title: '合同管理', icon: 'file-text', permission: 'system:engineering:contract' }
},
{
path: 'construction',
component: () => import('@/views/engineering/construction/index'),
name: 'Construction',
meta: { title: '施工进度管理', icon: 'tree-table', permission: 'system:engineering:construction' }
},
{
path: 'material',
component: () => import('@/views/engineering/material/index'),
name: 'Material',
meta: { title: '物料管理', icon: 'shopping', permission: 'system:engineering:material' }
},
{
path: 'payment',
component: () => import('@/views/engineering/payment/index'),
name: 'Payment',
meta: { title: '付款管理', icon: 'money', permission: 'system:engineering:payment' }
}
]
}
]
// 动态路由,基于用户权限动态去加载
export const dynamicRoutes = [
{

View File

@@ -0,0 +1,79 @@
<template>
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
<el-form :model="form" ref="form" :rules="rules" label-width="80px">
<el-form-item label="节点名称">
<el-input :value="form.nodeName" disabled />
</el-form-item>
<el-form-item label="当前进度">
<el-progress :percentage="form.progress" :show-text="true" :text-inside="true" />
</el-form-item>
<el-form-item label="验收备注" prop="remark">
<el-textarea v-model="form.remark" placeholder="请输入验收备注" rows="4" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitAcceptance">提交验收</el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</template>
<script>
import { submitAcceptance } from '@/api/engineering/construction'
export default {
name: 'AcceptanceDialog',
data() {
return {
open: false,
title: '提交验收',
form: {
constructionId: null,
nodeName: '',
progress: 0,
remark: ''
},
rules: {
remark: [
{ required: true, message: '请输入验收备注', trigger: 'blur' }
]
}
}
},
methods: {
open(row) {
this.open = true
this.form = {
constructionId: row.constructionId,
nodeName: row.nodeName,
progress: row.progress || 0,
remark: ''
}
},
submitAcceptance() {
this.$refs['form'].validate(valid => {
if (valid) {
submitAcceptance(this.form.constructionId, this.form.remark).then(response => {
if (response.code === 200) {
this.$message.success('验收提交成功')
this.open = false
this.$emit('refresh')
} else {
this.$message.error(response.msg)
}
})
}
})
},
cancel() {
this.open = false
this.form = {
constructionId: null,
nodeName: '',
progress: 0,
remark: ''
}
}
}
}
</script>

View File

@@ -0,0 +1,137 @@
<template>
<el-dialog :title="title" :visible.sync="open" width="600px" append-to-body>
<el-form :model="form" ref="form" :rules="rules" label-width="100px">
<el-form-item label="合同" prop="contractId">
<el-select v-model="form.contractId" placeholder="请选择合同" :disabled="!!form.constructionId">
<el-option v-for="contract in contractOptions" :key="contract.contractId" :label="contract.contractName" :value="contract.contractId" />
</el-select>
</el-form-item>
<el-form-item label="父节点" prop="parentId">
<el-select v-model="form.parentId" placeholder="请选择父节点(可选)">
<el-option :value="0" label="无(顶级节点)" />
<el-option v-for="node in parentOptions" :key="node.constructionId" :label="node.nodeName" :value="node.constructionId" />
</el-select>
</el-form-item>
<el-form-item label="节点编号" prop="nodeCode">
<el-input v-model="form.nodeCode" placeholder="请输入节点编号" />
</el-form-item>
<el-form-item label="节点名称" prop="nodeName">
<el-input v-model="form.nodeName" placeholder="请输入节点名称" />
</el-form-item>
<el-form-item label="计划开始日期" prop="planStartDate">
<el-date-picker v-model="form.planStartDate" type="date" placeholder="请选择计划开始日期" />
</el-form-item>
<el-form-item label="计划结束日期" prop="planEndDate">
<el-date-picker v-model="form.planEndDate" type="date" placeholder="请选择计划结束日期" />
</el-form-item>
<el-form-item label="进度(%)" prop="progress">
<el-slider v-model="form.progress" :min="0" :max="100" :step="1" show-input />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="form.status" placeholder="请选择状态">
<el-option label="进行中" value="in_progress" />
<el-option label="已完成" value="completed" />
<el-option label="已暂停" value="paused" />
</el-select>
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-textarea v-model="form.remark" placeholder="请输入备注" rows="3" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</template>
<script>
import { addConstruction, updateConstruction } from '@/api/engineering/construction'
import { getContractOptions } from '@/api/engineering/contract'
export default {
name: 'ConstructionAddOrEdit',
data() {
return {
open: false,
title: '',
form: {},
contractOptions: [],
parentOptions: [],
rules: {
contractId: [
{ required: true, message: '请选择合同', trigger: 'change' }
],
nodeName: [
{ required: true, message: '请输入节点名称', trigger: 'blur' }
],
planStartDate: [
{ required: true, message: '请选择计划开始日期', trigger: 'change' }
],
planEndDate: [
{ required: true, message: '请选择计划结束日期', trigger: 'change' }
]
}
}
},
methods: {
open(row) {
this.open = true
this.title = row ? '修改施工节点' : '新增施工节点'
this.form = row ? { ...row } : { progress: 0, status: 'in_progress', parentId: 0 }
this.loadContractOptions()
this.loadParentOptions()
},
loadContractOptions() {
getContractOptions().then(response => {
this.contractOptions = response.data
})
},
loadParentOptions() {
if (this.form.contractId) {
import('@/api/engineering/construction').then(api => {
api.listConstruction({ contractId: this.form.contractId }).then(response => {
this.parentOptions = response.rows.filter(r => r.constructionId !== this.form.constructionId)
})
})
}
},
submitForm() {
this.$refs['form'].validate(valid => {
if (valid) {
if (this.form.constructionId) {
updateConstruction(this.form).then(response => {
if (response.code === 200) {
this.$message.success('修改成功')
this.open = false
this.$emit('refresh')
} else {
this.$message.error(response.msg)
}
})
} else {
addConstruction(this.form).then(response => {
if (response.code === 200) {
this.$message.success('新增成功')
this.open = false
this.$emit('refresh')
} else {
this.$message.error(response.msg)
}
})
}
}
})
},
cancel() {
this.open = false
this.form = {}
}
},
watch: {
'form.contractId': function() {
this.loadParentOptions()
}
}
}
</script>

View File

@@ -0,0 +1,175 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" inline :label-width="100px">
<el-form-item label="合同" prop="contractId">
<el-select v-model="queryParams.contractId" placeholder="请选择合同" clearable>
<el-option v-for="contract in contractOptions" :key="contract.contractId" :label="contract.contractName" :value="contract.contractId" />
</el-select>
</el-form-item>
<el-form-item label="节点名称" prop="nodeName">
<el-input v-model="queryParams.nodeName" placeholder="请输入节点名称" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">查询</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button type="primary" icon="el-icon-plus" @click="handleAdd">新增</el-button>
</el-col>
<el-col :span="1.5">
<el-button icon="el-icon-edit" @click="handleEdit">修改</el-button>
</el-col>
<el-col :span="1.5">
<el-button icon="el-icon-delete" type="danger" @click="handleDelete">删除</el-button>
</el-col>
</el-row>
<el-table v-loading="loading" :data="constructionList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="节点编号" prop="nodeCode" align="center" />
<el-table-column label="节点名称" prop="nodeName" align="center" />
<el-table-column label="层级" prop="nodeLevel" align="center" />
<el-table-column label="进度" prop="progress" align="center">
<template slot-scope="scope">
<div class="progress-wrapper">
<el-progress :percentage="scope.row.progress" :show-text="true" :text-inside="true" />
</div>
</template>
</el-table-column>
<el-table-column label="状态" prop="status" align="center">
<template slot-scope="scope">
<el-tag :type="getStatusType(scope.row.status)">{{ getStatusLabel(scope.row.status) }}</el-tag>
</template>
</el-table-column>
<el-table-column label="验收状态" prop="acceptanceStatus" align="center">
<template slot-scope="scope">
<el-tag :type="getAcceptanceType(scope.row.acceptanceStatus)">{{ getAcceptanceLabel(scope.row.acceptanceStatus) }}</el-tag>
</template>
</el-table-column>
<el-table-column label="计划开始" prop="planStartDate" align="center" />
<el-table-column label="计划结束" prop="planEndDate" align="center" />
<el-table-column label="操作" align="center">
<template slot-scope="scope">
<el-button size="mini" icon="el-icon-edit" @click="handleEdit(scope.row)">修改</el-button>
<el-button size="mini" icon="el-icon-delete" type="danger" @click="handleDelete(scope.row)">删除</el-button>
<el-button size="mini" icon="el-icon-check" @click="handleSubmitAcceptance(scope.row)">提交验收</el-button>
</template>
</el-table-column>
</el-table>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList" />
<construction-add-or-edit ref="addOrEdit" @refresh="getList" />
<acceptance-dialog ref="acceptanceDialog" @refresh="getList" />
</div>
</template>
<script>
import { listConstruction, delConstruction } from '@/api/engineering/construction'
import { getContractOptions } from '@/api/engineering/contract'
import ConstructionAddOrEdit from './ConstructionAddOrEdit.vue'
import AcceptanceDialog from './AcceptanceDialog.vue'
export default {
name: 'Construction',
components: { ConstructionAddOrEdit, AcceptanceDialog },
data() {
return {
loading: false,
constructionList: [],
total: 0,
contractOptions: [],
queryParams: {
pageNum: 1,
pageSize: 10,
contractId: '',
nodeName: ''
},
ids: []
}
},
created() {
this.loadContractOptions()
this.getList()
},
methods: {
loadContractOptions() {
getContractOptions().then(response => {
this.contractOptions = response.data
})
},
getList() {
this.loading = true
listConstruction(this.queryParams).then(response => {
this.constructionList = response.rows
this.total = response.total
this.loading = false
})
},
handleQuery() {
this.queryParams.pageNum = 1
this.getList()
},
resetQuery() {
this.$refs.queryForm.resetFields()
this.handleQuery()
},
handleSelectionChange(val) {
this.ids = val.map(item => item.constructionId)
},
handleAdd() {
this.$refs.addOrEdit.open()
},
handleEdit(row) {
this.$refs.addOrEdit.open(row)
},
handleDelete(row) {
const ids = row ? [row.constructionId] : this.ids
if (ids.length === 0) {
this.$message.warning('请选择要删除的数据')
return
}
this.$confirm(`确定删除选中的${ids.length}条记录?`, '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
delConstruction(ids.join(',')).then(() => {
this.$message.success('删除成功')
this.getList()
}).catch(() => {
this.$message.error('删除失败')
})
})
},
handleSubmitAcceptance(row) {
this.$refs.acceptanceDialog.open(row)
},
getStatusType(status) {
const types = { in_progress: 'primary', completed: 'success', paused: 'warning' }
return types[status] || 'info'
},
getStatusLabel(status) {
const labels = { in_progress: '进行中', completed: '已完成', paused: '已暂停' }
return labels[status] || status
},
getAcceptanceType(status) {
const types = { not_submitted: 'info', pending: 'warning', approved: 'success', rejected: 'danger' }
return types[status] || 'info'
},
getAcceptanceLabel(status) {
const labels = { not_submitted: '未提交', pending: '待验收', approved: '已通过', rejected: '已拒绝' }
return labels[status] || status
}
}
}
</script>
<style scoped>
.progress-wrapper {
width: 120px;
}
</style>

View File

@@ -0,0 +1,123 @@
<template>
<el-dialog :title="title" :visible.sync="open" width="600px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="120px">
<el-form-item label="合同编号" prop="contractNo">
<el-input v-model="form.contractNo" placeholder="请输入合同编号" />
</el-form-item>
<el-form-item label="合同名称" prop="contractName">
<el-input v-model="form.contractName" placeholder="请输入合同名称" />
</el-form-item>
<el-form-item label="合同类型" prop="contractType">
<el-input v-model="form.contractType" placeholder="请输入合同类型" />
</el-form-item>
<el-form-item label="供应商" prop="supplierId">
<el-select v-model="form.supplierId" placeholder="请选择供应商">
<el-option v-for="supplier in supplierOptions" :key="supplier.supplierId" :label="supplier.supplierName" :value="supplier.supplierId" />
</el-select>
</el-form-item>
<el-form-item label="合同金额" prop="amount">
<el-input v-model="form.amount" placeholder="请输入合同金额" />
</el-form-item>
<el-form-item label="签订日期" prop="signDate">
<el-date-picker v-model="form.signDate" type="date" placeholder="请选择签订日期" />
</el-form-item>
<el-form-item label="开始日期" prop="startDate">
<el-date-picker v-model="form.startDate" type="date" placeholder="请选择开始日期" />
</el-form-item>
<el-form-item label="结束日期" prop="endDate">
<el-date-picker v-model="form.endDate" type="date" placeholder="请选择结束日期" />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="form.status" placeholder="请选择状态">
<el-option label="待审批" value="pending" />
<el-option label="已生效" value="effective" />
<el-option label="已终止" value="terminated" />
</el-select>
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-textarea v-model="form.remark" placeholder="请输入备注" :rows="3" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm">确定</el-button>
<el-button @click="cancel">取消</el-button>
</div>
</el-dialog>
</template>
<script>
import { addContract, updateContract } from '@/api/engineering/contract'
import { getSupplierOptions } from '@/api/engineering/supplier'
export default {
name: 'ContractAddOrEdit',
data() {
return {
open: false,
title: '',
form: {},
supplierOptions: [],
rules: {
contractNo: [{ required: true, message: '合同编号不能为空', trigger: 'blur' }],
contractName: [{ required: true, message: '合同名称不能为空', trigger: 'blur' }],
supplierId: [{ required: true, message: '供应商不能为空', trigger: 'blur' }],
amount: [{ required: true, message: '合同金额不能为空', trigger: 'blur' }]
}
}
},
created() {
this.loadSupplierOptions()
},
methods: {
loadSupplierOptions() {
getSupplierOptions('normal').then(response => {
this.supplierOptions = response.data
})
},
open(row) {
this.open = true
this.form = {
contractId: null,
contractNo: '',
contractName: '',
contractType: '',
supplierId: null,
amount: '',
signDate: '',
startDate: '',
endDate: '',
status: 'pending',
remark: ''
}
if (row) {
this.title = '修改合同'
Object.assign(this.form, row)
} else {
this.title = '新增合同'
}
},
submitForm() {
this.$refs.form.validate((valid) => {
if (valid) {
if (this.form.contractId) {
updateContract(this.form).then(() => {
this.$message.success('修改成功')
this.open = false
this.$emit('refresh')
})
} else {
addContract(this.form).then(() => {
this.$message.success('新增成功')
this.open = false
this.$emit('refresh')
})
}
}
})
},
cancel() {
this.open = false
}
}
}
</script>

View File

@@ -0,0 +1,153 @@
<template>
<el-dialog :title="title" :visible.sync="open" width="800px" append-to-body>
<div v-if="detail">
<el-tabs type="border-card">
<el-tab-pane label="基本信息">
<el-form :model="detail.contract" label-width="120px" class="detail-form">
<el-row>
<el-col :span="12">
<el-form-item label="合同编号">
<span>{{ detail.contract.contractNo }}</span>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="合同名称">
<span>{{ detail.contract.contractName }}</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="合同类型">
<span>{{ detail.contract.contractType }}</span>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="状态">
<el-tag :type="getStatusType(detail.contract.status)">{{ getStatusLabel(detail.contract.status) }}</el-tag>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="合同金额">
<span>{{ formatMoney(detail.contract.amount) }}</span>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="已付款">
<span>{{ formatMoney(detail.contract.paidAmount) }}</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="签订日期">
<span>{{ detail.contract.signDate }}</span>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="开始日期">
<span>{{ detail.contract.startDate }}</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="结束日期">
<span>{{ detail.contract.endDate }}</span>
</el-form-item>
</el-col>
</el-row>
</el-form>
</el-tab-pane>
<el-tab-pane label="付款记录">
<el-table :data="detail.payments" border>
<el-table-column label="付款金额" prop="amount" />
<el-table-column label="付款日期" prop="paymentDate" />
<el-table-column label="付款类型" prop="paymentType" />
<el-table-column label="状态" prop="status">
<template slot-scope="scope">
<el-tag :type="getPaymentStatusType(scope.row.status)">{{ getPaymentStatusLabel(scope.row.status) }}</el-tag>
</template>
</el-table-column>
</el-table>
</el-tab-pane>
<el-tab-pane label="变更记录">
<el-table :data="detail.changes" border>
<el-table-column label="变更类型" prop="changeType" />
<el-table-column label="变更原因" prop="reason" />
<el-table-column label="状态" prop="status">
<template slot-scope="scope">
<el-tag :type="getChangeStatusType(scope.row.status)">{{ getChangeStatusLabel(scope.row.status) }}</el-tag>
</template>
</el-table-column>
<el-table-column label="审批意见" prop="approvalRemark" />
</el-table>
</el-tab-pane>
</el-tabs>
</div>
<div slot="footer" class="dialog-footer">
<el-button @click="cancel">关闭</el-button>
</div>
</el-dialog>
</template>
<script>
import { getContractDetail } from '@/api/engineering/contract'
export default {
name: 'ContractDetail',
data() {
return {
open: false,
title: '合同详情',
detail: {}
}
},
methods: {
open(contractId) {
this.open = true
getContractDetail(contractId).then(response => {
this.detail = response.data
})
},
cancel() {
this.open = false
},
formatMoney(val) {
return val ? val.toLocaleString('zh-CN', { minimumFractionDigits: 2 }) : '0.00'
},
getStatusType(status) {
const types = { pending: 'warning', effective: 'success', terminated: 'danger' }
return types[status] || 'info'
},
getStatusLabel(status) {
const labels = { pending: '待审批', effective: '已生效', terminated: '已终止' }
return labels[status] || status
},
getPaymentStatusType(status) {
const types = { pending: 'warning', approved: 'success', paid: 'primary', rejected: 'danger' }
return types[status] || 'info'
},
getPaymentStatusLabel(status) {
const labels = { pending: '待审批', approved: '已审批', paid: '已付款', rejected: '已拒绝' }
return labels[status] || status
},
getChangeStatusType(status) {
const types = { pending: 'warning', approved: 'success', rejected: 'danger' }
return types[status] || 'info'
},
getChangeStatusLabel(status) {
const labels = { pending: '待审批', approved: '已通过', rejected: '已拒绝' }
return labels[status] || status
}
}
}
</script>
<style scoped>
.detail-form {
padding: 10px;
}
</style>

View File

@@ -0,0 +1,165 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" inline :label-width="100px">
<el-form-item label="合同编号" prop="contractNo">
<el-input v-model="queryParams.contractNo" placeholder="请输入合同编号" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="合同名称" prop="contractName">
<el-input v-model="queryParams.contractName" placeholder="请输入合同名称" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="queryParams.status" placeholder="请选择状态" clearable>
<el-option label="待审批" value="pending" />
<el-option label="已生效" value="effective" />
<el-option label="已终止" value="terminated" />
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">查询</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button type="primary" icon="el-icon-plus" @click="handleAdd">新增</el-button>
</el-col>
<el-col :span="1.5">
<el-button icon="el-icon-edit" @click="handleEdit">修改</el-button>
</el-col>
<el-col :span="1.5">
<el-button icon="el-icon-delete" type="danger" @click="handleDelete">删除</el-button>
</el-col>
</el-row>
<el-table v-loading="loading" :data="contractList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="合同编号" prop="contractNo" align="center" />
<el-table-column label="合同名称" prop="contractName" align="center" />
<el-table-column label="合同类型" prop="contractType" align="center" />
<el-table-column label="供应商" prop="supplierName" align="center" />
<el-table-column label="合同金额" prop="amount" align="center">
<template slot-scope="scope">
{{ formatMoney(scope.row.amount) }}
</template>
</el-table-column>
<el-table-column label="已付款" prop="paidAmount" align="center">
<template slot-scope="scope">
{{ formatMoney(scope.row.paidAmount) }}
</template>
</el-table-column>
<el-table-column label="未付款" align="center">
<template slot-scope="scope">
{{ formatMoney(scope.row.amount - scope.row.paidAmount) }}
</template>
</el-table-column>
<el-table-column label="签订日期" prop="signDate" align="center" />
<el-table-column label="状态" prop="status" align="center">
<template slot-scope="scope">
<el-tag :type="getStatusType(scope.row.status)">{{ getStatusLabel(scope.row.status) }}</el-tag>
</template>
</el-table-column>
<el-table-column label="操作" align="center">
<template slot-scope="scope">
<el-button size="mini" icon="el-icon-edit" @click="handleEdit(scope.row)">修改</el-button>
<el-button size="mini" icon="el-icon-delete" type="danger" @click="handleDelete(scope.row)">删除</el-button>
<el-button size="mini" icon="el-icon-view" @click="handleView(scope.row)">详情</el-button>
</template>
</el-table-column>
</el-table>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList" />
<contract-add-or-edit ref="addOrEdit" @refresh="getList" />
<contract-detail ref="detail" />
</div>
</template>
<script>
import { listContract, delContract } from '@/api/engineering/contract'
import ContractAddOrEdit from './ContractAddOrEdit.vue'
import ContractDetail from './ContractDetail.vue'
export default {
name: 'Contract',
components: { ContractAddOrEdit, ContractDetail },
data() {
return {
loading: false,
contractList: [],
total: 0,
queryParams: {
pageNum: 1,
pageSize: 10,
contractNo: '',
contractName: '',
status: ''
},
ids: []
}
},
created() {
this.getList()
},
methods: {
getList() {
this.loading = true
listContract(this.queryParams).then(response => {
this.contractList = response.rows
this.total = response.total
this.loading = false
})
},
handleQuery() {
this.queryParams.pageNum = 1
this.getList()
},
resetQuery() {
this.$refs.queryForm.resetFields()
this.handleQuery()
},
handleSelectionChange(val) {
this.ids = val.map(item => item.contractId)
},
handleAdd() {
this.$refs.addOrEdit.open()
},
handleEdit(row) {
this.$refs.addOrEdit.open(row)
},
handleDelete(row) {
const ids = row ? [row.contractId] : this.ids
if (ids.length === 0) {
this.$message.warning('请选择要删除的数据')
return
}
this.$confirm(`确定删除选中的${ids.length}条记录?`, '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
delContract(ids.join(',')).then(() => {
this.$message.success('删除成功')
this.getList()
}).catch(() => {
this.$message.error('删除失败')
})
})
},
handleView(row) {
this.$refs.detail.open(row.contractId)
},
formatMoney(val) {
return val ? val.toLocaleString('zh-CN', { minimumFractionDigits: 2 }) : '0.00'
},
getStatusType(status) {
const types = { pending: 'warning', effective: 'success', terminated: 'danger' }
return types[status] || 'info'
},
getStatusLabel(status) {
const labels = { pending: '待审批', effective: '已生效', terminated: '已终止' }
return labels[status] || status
}
}
}
</script>

View File

@@ -0,0 +1,371 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
<el-form-item label="物料编码" prop="materialCode">
<el-input v-model="queryParams.materialCode" placeholder="请输入物料编码" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="物料名称" prop="materialName">
<el-input v-model="queryParams.materialName" placeholder="请输入物料名称" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="物料类别" prop="category">
<el-input v-model="queryParams.category" placeholder="请输入物料类别" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button type="primary" plain icon="el-icon-plus" @click="handleAdd">新增物料</el-button>
</el-col>
<el-col :span="1.5">
<el-button type="success" plain icon="el-icon-download" @click="handleImport">入库</el-button>
</el-col>
<el-col :span="1.5">
<el-button type="warning" plain icon="el-icon-upload" @click="handleExport">出库</el-button>
</el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
</el-row>
<el-table v-loading="loading" :data="materialList" border fit highlight-current-row @row-click="handleRowClick">
<el-table-column label="物料编码" prop="materialCode" />
<el-table-column label="物料名称" prop="materialName" />
<el-table-column label="规格型号" prop="specification" />
<el-table-column label="计量单位" prop="unit" />
<el-table-column label="库存数量" prop="stock" />
<el-table-column label="最低库存" prop="minStock" />
<el-table-column label="物料类别" prop="category" />
<el-table-column label="存放位置" prop="location" />
<el-table-column label="状态" prop="status">
<template slot-scope="scope">
<el-tag :type="scope.row.status === 'normal' ? 'success' : 'warning'">
{{ scope.row.status === 'normal' ? '正常' : '预警' }}
</el-tag>
</template>
</el-table-column>
<el-table-column label="创建时间" prop="createTime" />
<el-table-column label="操作" align="center">
<template slot-scope="scope">
<el-button size="mini" icon="el-icon-edit" @click="handleEdit(scope.row)">编辑</el-button>
<el-button size="mini" icon="el-icon-delete" type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
</el-table-column>
</el-table>
<pagination v-show="total>0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList" />
<el-dialog title="物料信息" :visible.sync="open" width="700px" append-to-body>
<el-form :model="form" ref="form" :rules="rules" label-width="100px">
<el-form-item label="物料编码" prop="materialCode">
<el-input v-model="form.materialCode" placeholder="请输入物料编码" />
</el-form-item>
<el-form-item label="物料名称" prop="materialName">
<el-input v-model="form.materialName" placeholder="请输入物料名称" />
</el-form-item>
<el-form-item label="规格型号" prop="specification">
<el-input v-model="form.specification" placeholder="请输入规格型号" />
</el-form-item>
<el-form-item label="计量单位" prop="unit">
<el-input v-model="form.unit" placeholder="请输入计量单位" />
</el-form-item>
<el-form-item label="最低库存" prop="minStock">
<el-input v-model="form.minStock" type="number" placeholder="请输入最低库存" />
</el-form-item>
<el-form-item label="物料类别" prop="category">
<el-input v-model="form.category" placeholder="请输入物料类别" />
</el-form-item>
<el-form-item label="存放位置" prop="location">
<el-input v-model="form.location" placeholder="请输入存放位置" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-textarea v-model="form.remark" placeholder="请输入备注" rows="3" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
<el-dialog title="物料入库" :visible.sync="openIn" width="700px" append-to-body>
<el-form :model="formIn" ref="formIn" :rules="rulesIn" label-width="100px">
<el-form-item label="物料" prop="materialId">
<el-select v-model="formIn.materialId" placeholder="请选择物料" @change="onMaterialChange">
<el-option v-for="item in materialOptions" :key="item.materialId" :label="item.materialName + ' (' + item.materialCode + ')'" :value="item.materialId" />
</el-select>
</el-form-item>
<el-form-item label="入库数量" prop="quantity">
<el-input v-model="formIn.quantity" type="number" placeholder="请输入入库数量" />
</el-form-item>
<el-form-item label="单价" prop="price">
<el-input v-model="formIn.price" type="number" placeholder="请输入单价" />
</el-form-item>
<el-form-item label="入库日期" prop="inDate">
<el-date-picker v-model="formIn.inDate" type="date" placeholder="请选择入库日期" />
</el-form-item>
<el-form-item label="供应商" prop="supplierId">
<el-select v-model="formIn.supplierId" placeholder="请选择供应商">
<el-option v-for="item in supplierOptions" :key="item.supplierId" :label="item.supplierName" :value="item.supplierId" />
</el-select>
</el-form-item>
<el-form-item label="批次号" prop="batchNo">
<el-input v-model="formIn.batchNo" placeholder="请输入批次号" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-textarea v-model="formIn.remark" placeholder="请输入备注" rows="3" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitInForm"> </el-button>
<el-button @click="cancelIn"> </el-button>
</div>
</el-dialog>
<el-dialog title="物料出库" :visible.sync="openOut" width="700px" append-to-body>
<el-form :model="formOut" ref="formOut" :rules="rulesOut" label-width="100px">
<el-form-item label="物料" prop="materialId">
<el-select v-model="formOut.materialId" placeholder="请选择物料" @change="onMaterialOutChange">
<el-option v-for="item in materialOptions" :key="item.materialId" :label="item.materialName + ' (' + item.materialCode + ') 库存:' + item.stock" :value="item.materialId" />
</el-select>
</el-form-item>
<el-form-item label="出库数量" prop="quantity">
<el-input v-model="formOut.quantity" type="number" placeholder="请输入出库数量" />
</el-form-item>
<el-form-item label="出库日期" prop="outDate">
<el-date-picker v-model="formOut.outDate" type="date" placeholder="请选择出库日期" />
</el-form-item>
<el-form-item label="用途" prop="usePurpose">
<el-input v-model="formOut.usePurpose" placeholder="请输入用途" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-textarea v-model="formOut.remark" placeholder="请输入备注" rows="3" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitOutForm"> </el-button>
<el-button @click="cancelOut"> </el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import { listMaterial, getMaterial, addMaterial, updateMaterial, delMaterial, getMaterialOptions } from '@/api/engineering/material'
import { getSupplierOptions } from '@/api/engineering/supplier'
export default {
name: 'Material',
data() {
return {
showSearch: true,
loading: false,
total: 0,
queryParams: {
pageNum: 1,
pageSize: 10,
materialCode: '',
materialName: '',
category: ''
},
materialList: [],
materialOptions: [],
supplierOptions: [],
open: false,
openIn: false,
openOut: false,
form: {},
formIn: {},
formOut: {},
rules: {
materialCode: [
{ required: true, message: '物料编码不能为空', trigger: 'blur' }
],
materialName: [
{ required: true, message: '物料名称不能为空', trigger: 'blur' }
],
unit: [
{ required: true, message: '计量单位不能为空', trigger: 'blur' }
]
},
rulesIn: {
materialId: [
{ required: true, message: '请选择物料', trigger: 'change' }
],
quantity: [
{ required: true, message: '入库数量不能为空', trigger: 'blur' }
],
inDate: [
{ required: true, message: '入库日期不能为空', trigger: 'change' }
]
},
rulesOut: {
materialId: [
{ required: true, message: '请选择物料', trigger: 'change' }
],
quantity: [
{ required: true, message: '出库数量不能为空', trigger: 'blur' }
],
outDate: [
{ required: true, message: '出库日期不能为空', trigger: 'change' }
]
}
}
},
created() {
this.getList()
this.getOptions()
},
methods: {
getList() {
this.loading = true
listMaterial(this.queryParams).then(response => {
this.materialList = response.rows
this.total = response.total
this.loading = false
})
},
getOptions() {
getMaterialOptions().then(response => {
this.materialOptions = response.data
})
getSupplierOptions().then(response => {
this.supplierOptions = response.data
})
},
handleQuery() {
this.queryParams.pageNum = 1
this.getList()
},
resetQuery() {
this.queryParams = {
pageNum: 1,
pageSize: 10,
materialCode: '',
materialName: '',
category: ''
}
this.getList()
},
handleAdd() {
this.open = true
this.form = {}
},
handleEdit(row) {
this.open = true
getMaterial(row.materialId).then(response => {
this.form = response.data
})
},
handleDelete(row) {
this.$confirm('确定删除该物料吗?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
delMaterial(row.materialId).then(response => {
if (response.code === 200) {
this.msgSuccess('删除成功')
this.getList()
} else {
this.msgError(response.msg)
}
})
})
},
handleRowClick(row) {
},
handleImport() {
this.openIn = true
this.formIn = {}
this.getOptions()
},
handleExport() {
this.openOut = true
this.formOut = {}
this.getOptions()
},
onMaterialChange() {
},
onMaterialOutChange() {
},
submitForm() {
this.$refs['form'].validate(valid => {
if (valid) {
if (this.form.materialId) {
updateMaterial(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess('修改成功')
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
} else {
addMaterial(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess('新增成功')
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
}
}
})
},
cancel() {
this.open = false
this.form = {}
},
submitInForm() {
this.$refs['formIn'].validate(valid => {
if (valid) {
import('@/api/engineering/material').then(api => {
api.addMaterialIn(this.formIn).then(response => {
if (response.code === 200) {
this.msgSuccess('入库成功')
this.openIn = false
this.getList()
} else {
this.msgError(response.msg)
}
})
})
}
})
},
cancelIn() {
this.openIn = false
this.formIn = {}
},
submitOutForm() {
this.$refs['formOut'].validate(valid => {
if (valid) {
import('@/api/engineering/material').then(api => {
api.addMaterialOut(this.formOut).then(response => {
if (response.code === 200) {
this.msgSuccess('出库成功')
this.openOut = false
this.getList()
} else {
this.msgError(response.msg)
}
})
})
}
})
},
cancelOut() {
this.openOut = false
this.formOut = {}
}
}
}
</script>
<style scoped>
</style>

View File

@@ -0,0 +1,423 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
<el-form-item label="付款单号" prop="paymentNo">
<el-input v-model="queryParams.paymentNo" placeholder="请输入付款单号" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="合同编号" prop="contractNo">
<el-input v-model="queryParams.contractNo" placeholder="请输入合同编号" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="供应商" prop="supplierName">
<el-input v-model="queryParams.supplierName" placeholder="请输入供应商名称" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="付款类型" prop="paymentType">
<el-select v-model="queryParams.paymentType" placeholder="请选择付款类型" clearable>
<el-option label="预付款" value="advance" />
<el-option label="进度款" value="progress" />
<el-option label="尾款" value="final" />
<el-option label="质保金" value="quality" />
</el-select>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="queryParams.status" placeholder="请选择状态" clearable>
<el-option label="待审批" value="pending" />
<el-option label="已审批" value="approved" />
<el-option label="已打款" value="paid" />
<el-option label="已驳回" value="rejected" />
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button type="primary" plain icon="el-icon-plus" @click="handleAdd">新增付款</el-button>
</el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
</el-row>
<el-table v-loading="loading" :data="paymentList" border fit highlight-current-row>
<el-table-column label="付款单号" prop="paymentNo" />
<el-table-column label="合同编号" prop="contractNo" />
<el-table-column label="合同名称" prop="contractName" />
<el-table-column label="供应商" prop="supplierName" />
<el-table-column label="付款类型" prop="paymentType">
<template slot-scope="scope">
<el-tag :type="getPaymentTypeTagType(scope.row.paymentType)">
{{ getPaymentTypeLabel(scope.row.paymentType) }}
</el-tag>
</template>
</el-table-column>
<el-table-column label="付款金额" prop="amount">
<template slot-scope="scope">
{{ formatMoney(scope.row.amount) }}
</template>
</el-table-column>
<el-table-column label="付款方式" prop="paymentMethod">
<template slot-scope="scope">
{{ getPaymentMethodLabel(scope.row.paymentMethod) }}
</template>
</el-table-column>
<el-table-column label="计划付款日期" prop="planDate" />
<el-table-column label="实际付款日期" prop="actualDate" />
<el-table-column label="状态" prop="status">
<template slot-scope="scope">
<el-tag :type="getStatusTagType(scope.row.status)">
{{ getStatusLabel(scope.row.status) }}
</el-tag>
</template>
</el-table-column>
<el-table-column label="创建时间" prop="createTime" />
<el-table-column label="操作" align="center">
<template slot-scope="scope">
<el-button size="mini" icon="el-icon-edit" @click="handleEdit(scope.row)" v-if="scope.row.status === 'pending'">编辑</el-button>
<el-button size="mini" icon="el-icon-check" type="success" @click="handleApprove(scope.row)" v-if="scope.row.status === 'pending'">审批通过</el-button>
<el-button size="mini" icon="el-icon-close" type="danger" @click="handleReject(scope.row)" v-if="scope.row.status === 'pending'">驳回</el-button>
<el-button size="mini" icon="el-icon-money" type="primary" @click="handleProcess(scope.row)" v-if="scope.row.status === 'approved'">确认打款</el-button>
<el-button size="mini" icon="el-icon-delete" type="danger" @click="handleDelete(scope.row)" v-if="scope.row.status === 'pending'">删除</el-button>
</template>
</el-table-column>
</el-table>
<pagination v-show="total>0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList" />
<el-dialog title="付款申请" :visible.sync="open" width="800px" append-to-body>
<el-form :model="form" ref="form" :rules="rules" label-width="100px">
<el-form-item label="付款单号" prop="paymentNo">
<el-input v-model="form.paymentNo" placeholder="系统自动生成" :disabled="!!form.paymentId" />
</el-form-item>
<el-form-item label="合同" prop="contractId">
<el-select v-model="form.contractId" placeholder="请选择合同" @change="onContractChange" :disabled="!!form.paymentId">
<el-option v-for="item in contractOptions" :key="item.contractId" :label="item.contractName + ' (' + item.contractNo + ')'" :value="item.contractId" />
</el-select>
</el-form-item>
<el-form-item label="供应商" prop="supplierId">
<el-select v-model="form.supplierId" placeholder="请选择供应商" :disabled="true">
<el-option v-for="item in supplierOptions" :key="item.supplierId" :label="item.supplierName" :value="item.supplierId" />
</el-select>
</el-form-item>
<el-form-item label="付款类型" prop="paymentType">
<el-select v-model="form.paymentType" placeholder="请选择付款类型">
<el-option label="预付款" value="advance" />
<el-option label="进度款" value="progress" />
<el-option label="尾款" value="final" />
<el-option label="质保金" value="quality" />
</el-select>
</el-form-item>
<el-form-item label="付款金额" prop="amount">
<el-input v-model="form.amount" type="number" placeholder="请输入付款金额" />
</el-form-item>
<el-form-item label="付款方式" prop="paymentMethod">
<el-select v-model="form.paymentMethod" placeholder="请选择付款方式">
<el-option label="银行转账" value="bank" />
<el-option label="现金" value="cash" />
<el-option label="支票" value="check" />
<el-option label="其他" value="other" />
</el-select>
</el-form-item>
<el-form-item label="付款银行" prop="bankName">
<el-input v-model="form.bankName" placeholder="请输入付款银行" />
</el-form-item>
<el-form-item label="付款账号" prop="bankAccount">
<el-input v-model="form.bankAccount" placeholder="请输入付款账号" />
</el-form-item>
<el-form-item label="发票号码" prop="invoiceNo">
<el-input v-model="form.invoiceNo" placeholder="请输入发票号码" />
</el-form-item>
<el-form-item label="计划付款日期" prop="planDate">
<el-date-picker v-model="form.planDate" type="date" placeholder="请选择计划付款日期" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-textarea v-model="form.remark" placeholder="请输入备注" rows="3" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
<el-dialog title="驳回原因" :visible.sync="showRejectDialog" width="500px" append-to-body>
<el-form :model="rejectForm" ref="rejectForm" :rules="rejectRules" label-width="80px">
<el-form-item label="驳回原因" prop="remark">
<el-textarea v-model="rejectForm.remark" placeholder="请输入驳回原因" rows="4" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitReject"> </el-button>
<el-button @click="cancelReject"> </el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import { listPayment, getPayment, addPayment, updatePayment, delPayment, approvePayment, rejectPayment, processPayment } from '@/api/engineering/payment'
import { getContractOptions } from '@/api/engineering/contract'
import { getSupplierOptions } from '@/api/engineering/supplier'
export default {
name: 'Payment',
data() {
return {
showSearch: true,
loading: false,
total: 0,
queryParams: {
pageNum: 1,
pageSize: 10,
paymentNo: '',
contractNo: '',
supplierName: '',
paymentType: '',
status: ''
},
paymentList: [],
contractOptions: [],
supplierOptions: [],
open: false,
showRejectDialog: false,
form: {},
rejectForm: {
remark: ''
},
rejectPaymentId: null,
rules: {
contractId: [
{ required: true, message: '请选择合同', trigger: 'change' }
],
paymentType: [
{ required: true, message: '请选择付款类型', trigger: 'change' }
],
amount: [
{ required: true, message: '付款金额不能为空', trigger: 'blur' }
],
paymentMethod: [
{ required: true, message: '请选择付款方式', trigger: 'change' }
]
},
rejectRules: {
remark: [
{ required: true, message: '请输入驳回原因', trigger: 'blur' }
]
}
}
},
created() {
this.getList()
this.getOptions()
},
methods: {
getList() {
this.loading = true
listPayment(this.queryParams).then(response => {
this.paymentList = response.rows
this.total = response.total
this.loading = false
})
},
getOptions() {
getContractOptions().then(response => {
this.contractOptions = response.data
})
getSupplierOptions().then(response => {
this.supplierOptions = response.data
})
},
handleQuery() {
this.queryParams.pageNum = 1
this.getList()
},
resetQuery() {
this.queryParams = {
pageNum: 1,
pageSize: 10,
paymentNo: '',
contractNo: '',
supplierName: '',
paymentType: '',
status: ''
}
this.getList()
},
handleAdd() {
this.open = true
this.form = {}
this.getOptions()
},
handleEdit(row) {
this.open = true
getPayment(row.paymentId).then(response => {
this.form = response.data
})
},
handleDelete(row) {
this.$confirm('确定删除该付款申请吗?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
delPayment(row.paymentId).then(response => {
if (response.code === 200) {
this.msgSuccess('删除成功')
this.getList()
} else {
this.msgError(response.msg)
}
})
})
},
handleApprove(row) {
this.$confirm('确定通过该付款申请吗?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
approvePayment(row.paymentId).then(response => {
if (response.code === 200) {
this.msgSuccess('审批通过')
this.getList()
} else {
this.msgError(response.msg)
}
})
})
},
handleReject(row) {
this.rejectPaymentId = row.paymentId
this.rejectForm = { remark: '' }
this.showRejectDialog = true
},
submitReject() {
this.$refs['rejectForm'].validate(valid => {
if (valid) {
rejectPayment(this.rejectPaymentId).then(response => {
if (response.code === 200) {
this.msgSuccess('驳回成功')
this.showRejectDialog = false
this.getList()
} else {
this.msgError(response.msg)
}
})
}
})
},
cancelReject() {
this.showRejectDialog = false
this.rejectForm = { remark: '' }
this.rejectPaymentId = null
},
handleProcess(row) {
this.$confirm('确定确认打款吗?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
processPayment(row.paymentId).then(response => {
if (response.code === 200) {
this.msgSuccess('打款成功')
this.getList()
} else {
this.msgError(response.msg)
}
})
})
},
onContractChange() {
const contract = this.contractOptions.find(c => c.contractId === this.form.contractId)
if (contract) {
this.form.supplierId = contract.supplierId
this.form.contractNo = contract.contractNo
this.form.contractName = contract.contractName
}
},
submitForm() {
this.$refs['form'].validate(valid => {
if (valid) {
if (this.form.paymentId) {
updatePayment(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess('修改成功')
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
} else {
addPayment(this.form).then(response => {
if (response.code === 200) {
this.msgSuccess('新增成功')
this.open = false
this.getList()
} else {
this.msgError(response.msg)
}
})
}
}
})
},
cancel() {
this.open = false
this.form = {}
},
getPaymentTypeLabel(type) {
const labels = {
'advance': '预付款',
'progress': '进度款',
'final': '尾款',
'quality': '质保金'
}
return labels[type] || type
},
getPaymentTypeTagType(type) {
const types = {
'advance': 'primary',
'progress': 'success',
'final': 'warning',
'quality': 'info'
}
return types[type] || 'default'
},
getPaymentMethodLabel(method) {
const labels = {
'bank': '银行转账',
'cash': '现金',
'check': '支票',
'other': '其他'
}
return labels[method] || method
},
getStatusLabel(status) {
const labels = {
'pending': '待审批',
'approved': '已审批',
'paid': '已打款',
'rejected': '已驳回'
}
return labels[status] || status
},
getStatusTagType(status) {
const types = {
'pending': 'warning',
'approved': 'primary',
'paid': 'success',
'rejected': 'danger'
}
return types[status] || 'default'
},
formatMoney(amount) {
if (!amount) return '0.00'
return amount.toFixed(2)
}
}
}
</script>
<style scoped>
</style>

View File

@@ -0,0 +1,133 @@
<template>
<el-dialog :title="title" :visible.sync="open" width="600px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="120px">
<el-form-item label="供应商编号" prop="supplierCode">
<el-input v-model="form.supplierCode" placeholder="请输入供应商编号" />
</el-form-item>
<el-form-item label="供应商名称" prop="supplierName">
<el-input v-model="form.supplierName" placeholder="请输入供应商名称" />
</el-form-item>
<el-form-item label="简称" prop="shortName">
<el-input v-model="form.shortName" placeholder="请输入简称" />
</el-form-item>
<el-form-item label="联系人" prop="contactPerson">
<el-input v-model="form.contactPerson" placeholder="请输入联系人" />
</el-form-item>
<el-form-item label="联系电话" prop="contactPhone">
<el-input v-model="form.contactPhone" placeholder="请输入联系电话" />
</el-form-item>
<el-form-item label="邮箱" prop="email">
<el-input v-model="form.email" placeholder="请输入邮箱" />
</el-form-item>
<el-form-item label="地址" prop="address">
<el-input v-model="form.address" placeholder="请输入地址" />
</el-form-item>
<el-form-item label="经营范围" prop="businessScope">
<el-textarea v-model="form.businessScope" placeholder="请输入经营范围" :rows="3" />
</el-form-item>
<el-form-item label="资质等级" prop="qualification">
<el-input v-model="form.qualification" placeholder="请输入资质等级" />
</el-form-item>
<el-form-item label="注册资本" prop="registerCapital">
<el-input v-model="form.registerCapital" placeholder="请输入注册资本" />
</el-form-item>
<el-form-item label="成立日期" prop="establishDate">
<el-date-picker v-model="form.establishDate" type="date" placeholder="请选择成立日期" />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="form.status" placeholder="请选择状态">
<el-option label="正常" value="normal" />
<el-option label="禁用" value="disabled" />
<el-option label="黑名单" value="blacklist" />
</el-select>
</el-form-item>
<el-form-item label="合作状态" prop="cooperationStatus">
<el-select v-model="form.cooperationStatus" placeholder="请选择合作状态">
<el-option label="合作中" value="cooperating" />
<el-option label="已终止" value="terminated" />
<el-option label="待审核" value="pending" />
</el-select>
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-textarea v-model="form.remark" placeholder="请输入备注" :rows="3" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm">确定</el-button>
<el-button @click="cancel">取消</el-button>
</div>
</el-dialog>
</template>
<script>
import { addSupplier, updateSupplier, getSupplier } from '@/api/engineering/supplier'
export default {
name: 'SupplierAddOrEdit',
data() {
return {
open: false,
title: '',
form: {},
rules: {
supplierCode: [
{ required: true, message: '供应商编号不能为空', trigger: 'blur' }
],
supplierName: [
{ required: true, message: '供应商名称不能为空', trigger: 'blur' }
]
}
}
},
methods: {
open(row) {
this.open = true
this.form = {
supplierId: null,
supplierCode: '',
supplierName: '',
shortName: '',
contactPerson: '',
contactPhone: '',
email: '',
address: '',
businessScope: '',
qualification: '',
registerCapital: '',
establishDate: '',
status: 'normal',
cooperationStatus: 'cooperating',
remark: ''
}
if (row) {
this.title = '修改供应商'
Object.assign(this.form, row)
} else {
this.title = '新增供应商'
}
},
submitForm() {
this.$refs.form.validate((valid) => {
if (valid) {
if (this.form.supplierId) {
updateSupplier(this.form).then(() => {
this.$message.success('修改成功')
this.open = false
this.$emit('refresh')
})
} else {
addSupplier(this.form).then(() => {
this.$message.success('新增成功')
this.open = false
this.$emit('refresh')
})
}
}
})
},
cancel() {
this.open = false
}
}
}
</script>

View File

@@ -0,0 +1,169 @@
<template>
<el-dialog :title="title" :visible.sync="open" width="800px" append-to-body>
<div v-if="detail">
<el-tabs type="border-card">
<el-tab-pane label="基本信息">
<el-form :model="detail.supplier" label-width="120px" class="detail-form">
<el-row>
<el-col :span="12">
<el-form-item label="供应商编号">
<span>{{ detail.supplier.supplierCode }}</span>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商名称">
<span>{{ detail.supplier.supplierName }}</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="简称">
<span>{{ detail.supplier.shortName }}</span>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="联系人">
<span>{{ detail.supplier.contactPerson }}</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="联系电话">
<span>{{ detail.supplier.contactPhone }}</span>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="邮箱">
<span>{{ detail.supplier.email }}</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item label="地址">
<span>{{ detail.supplier.address }}</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="资质等级">
<span>{{ detail.supplier.qualification }}</span>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="注册资本">
<span>{{ detail.supplier.registerCapital }}</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="状态">
<el-tag :type="getStatusType(detail.supplier.status)">{{ getStatusLabel(detail.supplier.status) }}</el-tag>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="合作状态">
<el-tag :type="getCooperationType(detail.supplier.cooperationStatus)">{{ getCooperationLabel(detail.supplier.cooperationStatus) }}</el-tag>
</el-form-item>
</el-col>
</el-row>
</el-form>
</el-tab-pane>
<el-tab-pane label="银行账户">
<el-table :data="detail.accounts" border>
<el-table-column label="账户ID" prop="accountId" />
<el-table-column label="开户行" prop="bankName" />
<el-table-column label="账号" prop="accountNo" />
<el-table-column label="户名" prop="accountName" />
<el-table-column label="默认账户" prop="isDefault">
<template slot-scope="scope">
{{ scope.row.isDefault === '1' ? '是' : '否' }}
</template>
</el-table-column>
</el-table>
</el-tab-pane>
<el-tab-pane label="统计信息">
<el-form :model="detail.statistics" label-width="120px" class="detail-form">
<el-row>
<el-col :span="12">
<el-form-item label="合同总额">
<span>{{ formatMoney(detail.statistics.totalContractAmount) }}</span>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="已付款">
<span>{{ formatMoney(detail.statistics.totalPayment) }}</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="未付款">
<span>{{ formatMoney(detail.statistics.unpaidAmount) }}</span>
</el-form-item>
</el-col>
</el-row>
</el-form>
</el-tab-pane>
</el-tabs>
</div>
<div slot="footer" class="dialog-footer">
<el-button @click="cancel">关闭</el-button>
</div>
</el-dialog>
</template>
<script>
import { getSupplierDetail } from '@/api/engineering/supplier'
export default {
name: 'SupplierDetail',
data() {
return {
open: false,
title: '供应商详情',
detail: {}
}
},
methods: {
open(supplierId) {
this.open = true
getSupplierDetail(supplierId).then(response => {
this.detail = response.data
})
},
cancel() {
this.open = false
},
formatMoney(val) {
return val ? val.toLocaleString('zh-CN', { minimumFractionDigits: 2 }) : '0.00'
},
getStatusType(status) {
const types = { normal: 'success', disabled: 'warning', blacklist: 'danger' }
return types[status] || 'info'
},
getStatusLabel(status) {
const labels = { normal: '正常', disabled: '禁用', blacklist: '黑名单' }
return labels[status] || status
},
getCooperationType(status) {
const types = { cooperating: 'success', terminated: 'danger', pending: 'warning' }
return types[status] || 'info'
},
getCooperationLabel(status) {
const labels = { cooperating: '合作中', terminated: '已终止', pending: '待审核' }
return labels[status] || status
}
}
}
</script>
<style scoped>
.detail-form {
padding: 10px;
}
</style>

View File

@@ -0,0 +1,189 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" inline :label-width="100px">
<el-form-item label="供应商编号" prop="supplierCode">
<el-input v-model="queryParams.supplierCode" placeholder="请输入供应商编号" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="供应商名称" prop="supplierName">
<el-input v-model="queryParams.supplierName" placeholder="请输入供应商名称" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select v-model="queryParams.status" placeholder="请选择状态" clearable>
<el-option label="正常" value="normal" />
<el-option label="禁用" value="disabled" />
<el-option label="黑名单" value="blacklist" />
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">查询</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button type="primary" icon="el-icon-plus" @click="handleAdd">新增</el-button>
</el-col>
<el-col :span="1.5">
<el-button icon="el-icon-edit" @click="handleEdit">修改</el-button>
</el-col>
<el-col :span="1.5">
<el-button icon="el-icon-delete" type="danger" @click="handleDelete">删除</el-button>
</el-col>
</el-row>
<el-table v-loading="loading" :data="supplierList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="供应商编号" prop="supplierCode" align="center" />
<el-table-column label="供应商名称" prop="supplierName" align="center" />
<el-table-column label="联系人" prop="contactPerson" align="center" />
<el-table-column label="联系电话" prop="contactPhone" align="center" />
<el-table-column label="合同总额" prop="totalContractAmount" align="center">
<template slot-scope="scope">
{{ formatMoney(scope.row.totalContractAmount) }}
</template>
</el-table-column>
<el-table-column label="已付款" prop="totalPaymentAmount" align="center">
<template slot-scope="scope">
{{ formatMoney(scope.row.totalPaymentAmount) }}
</template>
</el-table-column>
<el-table-column label="状态" prop="status" align="center">
<template slot-scope="scope">
<el-tag :type="getStatusType(scope.row.status)">{{ getStatusLabel(scope.row.status) }}</el-tag>
</template>
</el-table-column>
<el-table-column label="合作状态" prop="cooperationStatus" align="center">
<template slot-scope="scope">
<el-tag :type="getCooperationType(scope.row.cooperationStatus)">{{ getCooperationLabel(scope.row.cooperationStatus) }}</el-tag>
</template>
</el-table-column>
<el-table-column label="创建时间" prop="createTime" align="center" />
<el-table-column label="操作" align="center">
<template slot-scope="scope">
<el-button size="mini" icon="el-icon-edit" @click="handleEdit(scope.row)">修改</el-button>
<el-button size="mini" icon="el-icon-delete" type="danger" @click="handleDelete(scope.row)">删除</el-button>
<el-button size="mini" icon="el-icon-view" @click="handleView(scope.row)">详情</el-button>
</template>
</el-table-column>
</el-table>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList" />
<supplier-add-or-edit ref="addOrEdit" @refresh="getList" />
<supplier-detail ref="detail" />
</div>
</template>
<script>
import { listSupplier, delSupplier } from '@/api/engineering/supplier'
import SupplierAddOrEdit from './SupplierAddOrEdit.vue'
import SupplierDetail from './SupplierDetail.vue'
export default {
name: 'Supplier',
components: { SupplierAddOrEdit, SupplierDetail },
data() {
return {
loading: false,
supplierList: [],
total: 0,
queryParams: {
pageNum: 1,
pageSize: 10,
supplierCode: '',
supplierName: '',
status: ''
},
ids: []
}
},
created() {
this.getList()
},
methods: {
getList() {
this.loading = true
listSupplier(this.queryParams).then(response => {
this.supplierList = response.rows
this.total = response.total
this.loading = false
})
},
handleQuery() {
this.queryParams.pageNum = 1
this.getList()
},
resetQuery() {
this.$refs.queryForm.resetFields()
this.handleQuery()
},
handleSelectionChange(val) {
this.ids = val.map(item => item.supplierId)
},
handleAdd() {
this.$refs.addOrEdit.open()
},
handleEdit(row) {
this.$refs.addOrEdit.open(row)
},
handleDelete(row) {
const ids = row ? [row.supplierId] : this.ids
if (ids.length === 0) {
this.$message.warning('请选择要删除的数据')
return
}
this.$confirm(`确定删除选中的${ids.length}条记录?`, '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
delSupplier(ids.join(',')).then(() => {
this.$message.success('删除成功')
this.getList()
}).catch(() => {
this.$message.error('删除失败')
})
})
},
handleView(row) {
this.$refs.detail.open(row.supplierId)
},
formatMoney(val) {
return val ? val.toLocaleString('zh-CN', { minimumFractionDigits: 2 }) : '0.00'
},
getStatusType(status) {
const types = {
normal: 'success',
disabled: 'warning',
blacklist: 'danger'
}
return types[status] || 'info'
},
getStatusLabel(status) {
const labels = {
normal: '正常',
disabled: '禁用',
blacklist: '黑名单'
}
return labels[status] || status
},
getCooperationType(status) {
const types = {
cooperating: 'success',
terminated: 'danger',
pending: 'warning'
}
return types[status] || 'info'
},
getCooperationLabel(status) {
const labels = {
cooperating: '合作中',
terminated: '已终止',
pending: '待审核'
}
return labels[status] || status
}
}
}
</script>