This commit is contained in:
jia 2023-12-28 14:19:25 +08:00
parent 0732996993
commit 0a5a42552a
45 changed files with 1105 additions and 1031 deletions

View File

@ -0,0 +1,8 @@
import request from '@/utils/request'
// 工资明细列表列表
export function projectsalaryDetailLists(params: any) {
return request.get({ url: '/project.project_salary_detail/lists', params })
}

View File

@ -28,4 +28,6 @@ export function projectsalarypaymentDetail(params: any) {
//获取所有工资付款记录
export function getAllProjectRoles(params: any) {
return request.post({ url: '/project.project_salary_payment/getAllProjectRoles', params })
}
}

View File

@ -0,0 +1,102 @@
<template>
<div>
<el-card class="!border-none" shadow="never">
<el-form class="mb-[-16px]" :model="queryParams" inline>
<el-form-item label="查询" prop="name">
<el-input class="w-[280px]" v-model="queryParams.contract_no" clearable placeholder="请输入内容" />
</el-form-item>
<el-form-item>
<el-button type="primary" @click="resetPage">查询</el-button>
<el-button @click="resetParams">重置</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card class="!border-none" v-loading="pager.loading" shadow="never">
<div class="mt-4">
<el-table :data="pager.lists" @cell-click="handleCurrentChange">
<el-table-column type="selection" width="55" />
<el-table-column label="序号" type="index" width="55" />
<el-table-column label="流程编号" prop="supplier_name" show-overflow-tooltip />
<el-table-column label="组织名称" prop="project_name" show-overflow-tooltip />
<el-table-column label="部门名称" prop="contract_no" show-overflow-tooltip />
<el-table-column label="客户名称" prop="contract_no" show-overflow-tooltip />
<el-table-column label="项目名称" prop="project_name" show-overflow-tooltip />
<el-table-column label="项目编码" prop="project_name" show-overflow-tooltip />
<el-table-column label="标书编号" prop="contract_no" show-overflow-tooltip />
<el-table-column label="购买人员" prop="pay_date" show-overflow-tooltip />
<el-table-column label="招标公司名称" prop="amount" show-overflow-tooltip />
<el-table-column label="投标公司名称" prop="refunder" show-overflow-tooltip />
<el-table-column label="投标时间" prop="refunder" show-overflow-tooltip />
<el-table-column label="招标方式" prop="remark" show-overflow-tooltip />
<el-table-column label="投标地址" prop="remark" show-overflow-tooltip />
<el-table-column label="是否需要保证金" prop="is_need_deposit">
<template #default="{ row }">
<dict-value :options="dictData.whether_status" :value="row.is_need_deposit" />
</template>
</el-table-column>
<el-table-column label="保证金金额" prop="remark" show-overflow-tooltip />
<el-table-column label="开标日期" prop="bid_opening_date" show-overflow-tooltip />
<el-table-column label="保证金退还时间" prop="deposit_refund_time" show-overflow-tooltip />
<el-table-column label="招标项目概况" prop="bidding_project_overview" show-overflow-tooltip />
<el-table-column label="项目简介" prop="project_introduction" show-overflow-tooltip />
<el-table-column label="技术协议偏差" prop="technical_protocol_deviation" show-overflow-tooltip />
<el-table-column label="协议偏差处理方案" prop="protocol_deviation_handling_plan" show-overflow-tooltip />
<el-table-column label="总金额" prop="business_review_total_amount" show-overflow-tooltip />
<el-table-column label="税率" prop="tax_rate">
<template #default="{ row }">
<dict-value :options="dictData.tax_rate" :value="row.tax_rate" />
</template>
</el-table-column>
<el-table-column label="付款方式" prop="pay_type">
<template #default="{ row }">
<dict-value :options="dictData.pay_type" :value="row.pay_type" />
</template>
</el-table-column>
<el-table-column label="付款比例" prop="pay_rate" show-overflow-tooltip />
<el-table-column label="商务合同偏差" prop="business_contract_deviation" show-overflow-tooltip />
<el-table-column label="偏差处理方案" prop="business_contract_deviation_handling_plan" show-overflow-tooltip />
</el-table>
</div>
<div class="flex mt-4 justify-end">
<pagination v-model="pager" @change="getLists" />
</div>
</el-card>
</div>
</template>
<script lang="ts" setup>
import { usePaging } from "@/hooks/usePaging"
import { useDictData } from "@/hooks/useDictOptions"
import {
apiBidDocumentExaminationLists
} from '@/api/bid_document_examination'
import { defineEmits } from "vue"
import { timeFormat } from '@/utils/util'
//
const queryParams = reactive({
status: 1,
});
//
const { dictData } = useDictData('tax_rate,pay_type,whether_status')
//
const emits = defineEmits(["customEvent"]);
//
const handleCurrentChange = (value: any) => {
emits("customEvent", value);
};
//
const { pager, getLists, resetParams, resetPage } = usePaging({
fetchFun: apiBidDocumentExaminationLists,
params: queryParams,
});
getLists();
</script>

View File

@ -5,20 +5,20 @@
<el-row>
<el-col :span="8">
<el-form-item label="项目名称" prop="bid_document_examination_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]" @click="showDialog = true">
<el-input v-model="project_name" readonly clearable placeholder="请输入" />
<el-input v-model="project_name" readonly clearable placeholder="请选择项目" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="项目编码" prop="bid_document_examination_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]">
<el-input v-model="project_code" clearable readonly placeholder="请输入" />
<el-input v-model="project_code" clearable disabled placeholder="系统自动填写" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="客户名称" prop="bid_document_examination_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]">
<el-input v-model="matsname" clearable readonly placeholder="请输入" />
<el-input v-model="matsname" clearable disabled placeholder="系统自动填写" />
</el-form-item></el-col><el-col :span="8">
<!-- @click="showDialog1 = true" -->
<el-form-item label="产品id" prop="product_id">
<el-input v-model="formData.product_id" readonly clearable placeholder="请输入产品id" />
<el-input v-model="formData.product_id" readonly clearable placeholder="请输入产品" />
</el-form-item></el-col><el-col :span="8">
<el-form-item label="产品数量" prop="product_num">
<el-input v-model="formData.product_num" clearable placeholder="请输入产品数量" />
@ -46,7 +46,6 @@
</popup>
<el-dialog v-model="showDialog" title="选择标书" width="70%">
<biddocumentTable @customEvent="customEvent"></biddocumentTable>
</el-dialog>
<el-dialog v-model="showDialog1" title="选择产品" width="70%">
<prodctTable @customEvent="customEvent1"></prodctTable>
@ -106,8 +105,8 @@ const formRules = reactive<any>({
//
const customEvent = (e: any) => {
formData.bid_document_examination_id = e.id;
matsname.value = e.person
project_name.value = e.custom_name
matsname.value = e.customer_name
project_name.value = e.project_name
project_code.value = e.project_code
showDialog.value = false;

View File

@ -2,17 +2,17 @@
<div class="edit-popup">
<popup ref="popupRef" :title="popupTitle" :async="true" width="550px" @confirm="handleSubmit" @close="handleClose">
<el-form ref="formRef" :model="formData" label-width="90px" :rules="formRules">
<el-form-item label="标书审查id" prop="bid_document_examination_id">
<el-input v-model="formData.bid_document_examination_id" clearable placeholder="请输入标书审查id" />
<el-form-item label="标书审查id" prop="bid_document_examination_id" @click="showDialog = true">
<el-input v-model="formData.bid_document_examination_id" clearable placeholder="点击选择标书评审(可以为空)" />
</el-form-item>
<el-form-item label="项目名称" prop="project_id">
<el-input v-model="project_name" readonly clearable placeholder="请选择项目" />
<el-input v-model="project_name" clearable disabled placeholder="系统自动填写" />
</el-form-item>
<el-form-item label="项目编码" prop="project_id">
<el-input v-model="project_code" readonly clearable placeholder="请选择项目" />
<el-input v-model="project_code" clearable disabled placeholder="系统自动填写" />
</el-form-item>
<el-form-item label="客户名称" prop="project_id">
<el-input v-model="project_matername" readonly clearable placeholder="请选择项目" />
<el-input v-model="project_matername" clearable disabled placeholder="系统自动填写" />
</el-form-item>
<el-form-item label="是否中标" prop="is_successful">
<el-input v-model="formData.is_successful" clearable placeholder="请输入是否中标" />
@ -34,21 +34,18 @@
</el-form-item>
</el-form>
</popup>
<el-dialog v-model="showDialog" title="选择标书" width="70%">
<el-dialog v-model="showDialog" title="选择标书审查" width="70%">
<biddocumentTable @customEvent="customEvent"></biddocumentTable>
</el-dialog>
<el-dialog v-model="showDialog1" title="选择产品" width="70%">
<prodctTable @customEvent="customEvent1"></prodctTable>
</el-dialog>
</div>
</template>
<script lang="ts" setup name="bidResultEdit">
import type { FormInstance } from 'element-plus'
import Popup from '@/components/popup/index.vue'
import biddocumentTable from "@/components/biddocument/index.vue"
import prodctTable from "@/components/product/index.vue"
import biddocumentTable from "@/components/document_examination/index.vue"
import { apiBidResultAdd, apiBidResultEdit, apiBidResultDetail } from '@/api/bid_result'
import { timeFormat } from '@/utils/util'
import type { PropType } from 'vue'
@ -65,6 +62,7 @@ const mode = ref('add')
const project_matername = ref('')
const project_name = ref('')
const project_code = ref('')
const showDialog = ref(false)
//
const popupTitle = computed(() => {
return mode.value == 'edit' ? '编辑投标结果' : '新增投标结果'

View File

@ -12,16 +12,16 @@
<el-option v-for="(item, index) in jobs" :key="index" :label="item.name" :value="parseInt(item.id)" />
</el-select>
</el-form-item>
<el-form-item label="项目名称" prop="project_id" @click="showDialog = true" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]">
<el-input v-model="project_name" clearable placeholder="请输入项目id" />
<el-form-item label="项目名称" prop="project_id" @click="showDialog = true" :rules="[{ required: true, message: '不可为空', trigger: 'change' }]">
<el-input v-model="project_name" clearable placeholder="请选择项目" />
</el-form-item>
<el-form-item label="项目编码" prop="project_id">
<el-input v-model="project_code
" clearable placeholder="请输入项目id" />
" clearable disabled placeholder="系统自动填写" />
</el-form-item>
<el-form-item label="客户名称" prop="project_id">
<el-input v-model="custom_name
" clearable placeholder="请输入项目id" />
" clearable disabled placeholder="系统自动填写" />
</el-form-item>
<el-form-item label="需求主题" prop="theme">
<el-input v-model="formData.theme" clearable placeholder="请输入需求主题" />

View File

@ -32,13 +32,13 @@
</el-form>
</el-card>
<el-card class="!border-none" v-loading="pager.loading" shadow="never">
<el-button v-perms="['project.project/add']" type="primary" @click="handleAdd">
<el-button v-perms="['procurement_contract_change.procurement_contract_change/add']" type="primary" @click="handleAdd">
<template #icon>
<icon name="el-icon-Plus" />
</template>
新增
</el-button>
<el-button v-perms="['project.project/delete']" :disabled="!selectData.length" @click="handleDelete(selectData)">
<el-button v-perms="['procurement_contract_change.procurement_contract_change/delete']" :disabled="!selectData.length" @click="handleDelete(selectData)">
删除
</el-button>
@ -82,13 +82,13 @@
<el-table-column label="备注" prop="remark" show-overflow-tooltip />
<el-table-column label="操作" width="160" fixed="right">
<template #default="{ row }">
<el-button v-perms="['project.project/edit']" type="primary" link @click="handleEdit(row)">
<el-button v-perms="['procurement_contract_change.procurement_contract_change/edit']" type="primary" link @click="handleEdit(row)">
编辑
</el-button>
<el-button v-perms="['project.project/delete']" type="danger" link @click="handleDelete(row.id)">
<el-button v-perms="['procurement_contract_change.procurement_contract_change/delete']" type="danger" link @click="handleDelete(row.id)">
删除
</el-button>
<el-button v-perms="['project.project/detail']" link @click="handledetail(row)">
<el-button v-perms="['procurement_contract_change.procurement_contract_change/detail']" link @click="handledetail(row)">
详情
</el-button>
</template>

View File

@ -0,0 +1,138 @@
<template>
<div class="detail-popup">
<popup ref="popupRef" title="项目费用模板详情" :async="true" width="80%" @confirm="handleSubmit" @close="handleClose">
<el-form ref="formRef" :model="formData" label-width="120px">
<el-card class="mb-2">
<el-row>
<el-col :span="12">
<el-form-item label="项目类型">
{{ formData.project_type_name
}}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="科目编码">
{{ formData.subject_code
}}
</el-form-item>
</el-col> <el-col :span="12">
<el-form-item label="一级科目">
{{ formData.first_level_subject }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="二级科目">
{{ formData.second_level_subject }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="三级科目">
{{ formData.third_level_subject }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="单位">
{{ formData.unit
}}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="是否属于差旅科目">
{{ formData.is_travel == 1 ? '是' : '否' }}
</el-form-item>
</el-col>
</el-row>
</el-card>
</el-form>
</popup>
</div>
</template>
<script lang="ts" setup name="customdetail">
import type { FormInstance } from 'element-plus'
import Popup from '@/components/popup/index.vue'
import { apiCustomDetail } from '@/api/custom'
import { timeFormat } from '@/utils/util'
import type { PropType } from 'vue'
defineProps({
dictData: {
type: Object as PropType<Record<string, any[]>>,
default: () => ({})
}
})
const emit = defineEmits(['success', 'close'])
const formRef = shallowRef<FormInstance>()
const popupRef = shallowRef<InstanceType<typeof Popup>>()
const datas = reactive({
provinceOptions: [],
cityOptions: [],
areaOptions: [],
});
//
const formData = reactive({
})
//
const setFormData = async (data: Record<any, any>) => {
Object.assign(formData, data)
}
const getDetail = async (row: Record<string, any>) => {
const data = await apiCustomDetail({
id: row.id
})
setFormData(data)
}
//
const handleSubmit = async () => {
popupRef.value?.close()
}
//
const open = () => {
console.log('1111111')
popupRef.value?.open()
}
//
const handleClose = () => {
emit('close')
}
defineExpose({
open,
setFormData,
getDetail
})
</script>
<style lang="scss">
.tit {
font-size: 1.2em;
margin-bottom: 10px;
}
</style>

View File

@ -0,0 +1,172 @@
<template>
<div class="edit-popup">
<popup ref="popupRef" :title="popupTitle" :async="true" width="80%" @confirm="handleSubmit" @close="handleClose">
<el-form ref="formRef" :model="formData" label-width="120px" :rules="formRules">
<el-row>
<el-col :span="8">
<el-form-item label="项目类型" prop="project_id" @click="showDialog = true">
<el-select class="w-[280px]" v-model="formData.project_type_id" clearable placeholder="请选择项目类型">
<el-option label="全部" value=""></el-option>
<el-option v-for="(item, index) in list" :key="index" :label="item.name" :value="parseInt(item.id)" />
</el-select>
</el-form-item> </el-col>
<el-col :span="8">
<el-form-item label="科目编码" prop="formData.subject_code">
<el-input v-model="formData.subject_code" clearable placeholder="请输入科目编码" />
</el-form-item> </el-col>
<el-col :span="8">
<el-form-item label="一级科目" prop="first_level_subject">
<el-input v-model="formData.first_level_subject" clearable placeholder="请输入一级科目" />
</el-form-item> </el-col>
<el-col :span="8">
<el-form-item label="二级科目" prop="second_level_subject">
<el-input v-model="formData.second_level_subject" clearable placeholder="请输入二级科目" />
</el-form-item> </el-col>
<el-col :span="8">
<el-form-item label="三级科目" prop="third_level_subject">
<el-input v-model="formData.third_level_subject" clearable placeholder="请输入三级科目" />
</el-form-item> </el-col>
<el-col :span="8">
<el-form-item label="单位" prop="unit">
<el-input v-model="formData.unit" clearable placeholder="请输入单位" />
</el-form-item> </el-col>
<el-col :span="8">
<el-form-item label="差旅科目" prop="is_travel">
<el-select class="w-[280px]" v-model="formData.is_travel" clearable placeholder="请选择的是否属于差旅科目">
<el-option v-for="(item, index) in list1" :key="index" :label="item.name" :value="parseInt(item.id)" />
</el-select>
</el-form-item>
</el-col>
</el-row>
</el-form>
</popup>
</div>
</template>
<script lang="ts" setup name="procurementContractEdit">
import type { FormInstance } from 'element-plus'
import Popup from '@/components/popup/index.vue'
import { apiProjectcostAdd, apiProjectcostEdit, apiProjectcostDetail } from '@/api/project_cost_temp_set'
import { getAllProjectTypes } from '@/api/projecttype'
import { timeFormat } from '@/utils/util'
import type { PropType } from 'vue'
defineProps({
dictData: {
type: Object as PropType<Record<string, any[]>>,
default: () => ({})
}
})
const emit = defineEmits(['success', 'close'])
const formRef = shallowRef<FormInstance>()
const popupRef = shallowRef<InstanceType<typeof Popup>>()
const mode = ref('add')
const list = ref([])
const list1 = ref([{
name: '是',
id: 1
},
{
name: '否',
id: 2
}])
const showDialog = ref(false)
const project_name = ref('')
const project_code = ref('')
//
const popupTitle = computed(() => {
return mode.value == 'edit' ? '编辑项目WBS设置' : '新增项目WBS设置'
})
//
const formData = reactive({
id: '',
subject_code: '',
project_type_id: '',
first_level_subject: '',
second_level_subject: '',
third_level_subject: '',
unit: '',
is_travel: '',
})
//
const formRules = reactive<any>({
})
//
const getlist = () => {
getAllProjectTypes().then((res) => {
list.value = res
})
}
//
const setFormData = async (data: Record<any, any>) => {
for (const key in formData) {
if (data[key] != null && data[key] != undefined) {
//@ts-ignore
formData[key] = data[key]
}
}
}
const getDetail = async (row: Record<string, any>) => {
const data = await apiProjectcostDetail({
id: row.id
})
setFormData(data)
}
//
const handleSubmit = async () => {
await formRef.value?.validate()
const data = { ...formData, }
mode.value == 'edit'
? await apiProjectcostEdit(data)
: await apiProjectcostAdd(data)
popupRef.value?.close()
emit('success')
}
//
const open = (type = 'add') => {
mode.value = type
popupRef.value?.open()
}
//
const handleClose = () => {
emit('close')
}
getlist()
defineExpose({
open,
setFormData,
getDetail
})
</script>

View File

@ -0,0 +1,174 @@
<template>
<div>
<el-card class="!border-none mb-4" shadow="never">
<el-form class="mb-[-16px]" :model="queryParams" inline>
<el-form-item label="项目类型名称" prop="project_type_name">
<el-input class="w-[280px]" v-model="queryParams.project_type_name" clearable placeholder="请输入项目类型名称" />
</el-form-item>
<el-form-item label="科目编码" prop="subject_code">
<el-input class="w-[280px]" v-model="queryParams.subject_code" clearable placeholder="请输入科目编码" />
</el-form-item>
<el-form-item label="一级科目" prop="first_level_subject">
<el-input class="w-[280px]" v-model="queryParams.first_level_subject" clearable placeholder="请输入一级科目" />
</el-form-item>
<el-form-item label="二级科目" prop="second_level_subject">
<el-input class="w-[280px]" v-model="queryParams.second_level_subject" clearable placeholder="请输入二级科目" />
</el-form-item>
<el-form-item label="三级科目" prop="third_level_subject">
<el-input class="w-[280px]" v-model="queryParams.third_level_subject" clearable placeholder="请输入二级科目" />
</el-form-item>
<el-form-item label="单位" prop="unit">
<el-input class="w-[280px]" v-model="queryParams.unit" clearable placeholder="请输入单位" />
</el-form-item>
<el-form-item label="差旅科目" prop="unit">
<el-select class="w-[280px]" v-model="queryParams.is_travel" clearable placeholder="请选择的是否属于差旅科目">
<el-option v-for="(item, index) in list1" :key="index" :label="item.name" :value="parseInt(item.id)" />
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="resetPage">查询</el-button>
<el-button @click="resetParams">重置</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card class="!border-none" v-loading="pager.loading" shadow="never">
<el-button v-perms="['project.project/add']" type="primary" @click="handleAdd">
<template #icon>
<icon name="el-icon-Plus" />
</template>
新增
</el-button>
<el-button v-perms="['project.project/delete']" :disabled="!selectData.length" @click="handleDelete(selectData)">
删除
</el-button>
<div class="mt-4">
<el-table :data="pager.lists" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" />
<el-table-column label="项目类型" prop="project_type_name" show-overflow-tooltip />
<el-table-column label="科目编码" prop="subject_code" show-overflow-tooltip />
<el-table-column label="一级科目" prop="first_level_subject" show-overflow-tooltip />
<el-table-column label="二级科目" prop="second_level_subject" show-overflow-tooltip />
<el-table-column label="三级科目" prop="third_level_subject" show-overflow-tooltip />
<el-table-column label="单位" prop="unit" show-overflow-tooltip />
<el-table-column label="差旅科目" show-overflow-tooltip>
<template #default="{ row }">
{{ row.is_travel == 1 ? '是' : '否' }}
</template>
</el-table-column>
<el-table-column label="操作" width="150" fixed="right">
<template #default="{ row }">
<el-button v-perms="['project.project/edit']" type="primary" link @click="handleEdit(row)">
编辑
</el-button>
<el-button v-perms="['project.project/delete']" type="danger" link @click="handleDelete(row.id)">
删除
</el-button>
<el-button v-perms="['project.project/detail']" link @click="handledetail(row)">
详情
</el-button>
</template>
</el-table-column>
</el-table>
</div>
<div class="flex justify-end mt-4">
<pagination v-model="pager" @change="getLists" />
</div>
</el-card>
<edit-popup v-if="showEdit" ref="editRef" :dict-data="dictData" @success="getLists" @close="showEdit = false" />
<detail-popup v-if="showDtail" ref="detailRef" :dict-data="dictData" @close="showDtail = false" />
</div>
</template>
<script lang="ts" setup name="projectLists">
import { usePaging } from '@/hooks/usePaging'
import { useDictData } from '@/hooks/useDictOptions'
import { apiProjectcostLists, apiProjectcostDelete, apiProjectcostDetail } from '@/api/project_cost_temp_set'
import { timeFormat } from '@/utils/util'
import { getAllProjectTypes } from '@/api/projecttype'
const protype = reactive([])
import feedback from '@/utils/feedback'
import EditPopup from './edit.vue'
import DetailPopup from './detail.vue'
const detailRef = shallowRef<InstanceType<typeof DetailPopup>>()
const editRef = shallowRef<InstanceType<typeof EditPopup>>()
//
const showEdit = ref(false)
const showDtail = ref(false)
const list1 = ref([{
name: '是',
id: 1
},
{
name: '否',
id: 2
}])
//
const queryParams = reactive({
project_type_name: '',
subject_code: '',
first_level_subject: '',
second_level_subject: '',
third_level_subject: '',
unit: '',
is_travel: '',
})
//
const selectData = ref<any[]>([])
//
const handleSelectionChange = (val: any[]) => {
selectData.value = val.map(({ id }) => id)
}
//
const { dictData } = useDictData('')
//
const { pager, getLists, resetParams, resetPage } = usePaging({
fetchFun: apiProjectcostLists,
params: queryParams
})
//
const handleAdd = async () => {
showEdit.value = true
await nextTick()
editRef.value?.open('add')
}
//
const handleEdit = async (data: any) => {
console.log(data.id)
let res = await apiProjectcostDetail({ id: data.id })
showEdit.value = true
await nextTick()
editRef.value?.open('edit')
editRef.value?.setFormData(res)
}
//
const handleDelete = async (id: number | any[]) => {
await feedback.confirm('确定要删除?')
await apiProjectcostDelete({ id })
getLists()
}
const handledetail = async (data: any) => {
let res = await apiProjectcostDetail({ id: data.id })
showDtail.value = true
await nextTick()
detailRef.value?.open()
detailRef.value?.setFormData(res)
}
getLists()
</script>

View File

@ -159,8 +159,8 @@
<el-table-column label="工种" prop="person_work_type_text" show-overflow-tooltip />
<el-table-column label="总收入" prop="total_income" show-overflow-tooltip />
<el-table-column label="总支出" prop="total_pay_out" show-overflow-tooltip />
<el-table-column label="未发放" prop="deposit_bank" show-overflow-tooltip />
<el-table-column label="本次付款金额" prop="balance" show-overflow-tooltip />
<el-table-column label="未发放" prop="balance" show-overflow-tooltip />
<el-table-column label="本次付款金额" prop="apply_amount" show-overflow-tooltip />
<el-table-column label="备注" prop="remark" show-overflow-tooltip />
</el-table>

View File

@ -67,9 +67,6 @@
<material-picker v-model="formData.bank_card" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="银行卡号" prop="bank_no">
<el-input v-model="formData.bank_no" clearable placeholder="请输入银行卡号" />

View File

@ -83,23 +83,19 @@
</el-col>
</el-row>
<div style="margin: 10px 0;">支付明细</div>
<div>
<el-table :data="formData.payment_detail">
<el-table-column label="序号" type="index" show-overflow-tooltip />
<el-table-column label="姓名" prop="person_name" show-overflow-tooltip />
<el-table-column label="工种" prop="person_work_type_text" show-overflow-tooltip />
<el-table-column label="银行卡号" prop="person_bank_no" show-overflow-tooltip />
<el-table-column label="总收入" prop="total_income" show-overflow-tooltip />
<el-table-column label="总支出" prop="total_pay_out" show-overflow-tooltip />
<el-table-column label="未发放" prop="total_amount_uppercase" show-overflow-tooltip />
<el-table-column label="未发放" prop="balance" show-overflow-tooltip />
<el-table-column label="本次申请付款金额" prop="apply_amount" show-overflow-tooltip />
<el-table-column label="备注" prop="remark" show-overflow-tooltip />
</el-table>
</div>
</el-card>

View File

@ -97,7 +97,7 @@
<script lang="ts" setup name="projectLists">
import { usePaging } from '@/hooks/usePaging'
import { useDictData } from '@/hooks/useDictOptions'
import { insurancemanagementLists, insurancemanagementDelete, insurancemanagementDetail } from '@/api/project_salary'
import { projectsalaryDetailLists, projectsalaryDetailDelete, projectsalaryDetailDetail } from '@/api/project_salary_detail'
import { timeFormat } from '@/utils/util'
import { getAllProjectTypes } from '@/api/projecttype'
const protype = reactive([])
@ -134,7 +134,7 @@ const handleSelectionChange = (val: any[]) => {
const { dictData } = useDictData('labor_contract_status,labor_contract_type,labor_contract_name')
//
const { pager, getLists, resetParams, resetPage } = usePaging({
fetchFun: insurancemanagementLists,
fetchFun: projectsalaryDetailLists,
params: queryParams
})
@ -149,7 +149,7 @@ const handleAdd = async () => {
//
const handleEdit = async (data: any) => {
console.log(data.id)
let res = await insurancemanagementDetail({ id: data.id })
let res = await projectsalaryDetailDetail({ id: data.id })
showEdit.value = true
await nextTick()
editRef.value?.open('edit')
@ -159,11 +159,11 @@ const handleEdit = async (data: any) => {
//
const handleDelete = async (id: number | any[]) => {
await feedback.confirm('确定要删除?')
await insurancemanagementDelete({ id })
await projectsalaryDetailDelete({ id })
getLists()
}
const handledetail = async (data: any) => {
let res = await insurancemanagementDetail({ id: data.id })
let res = await projectsalaryDetailDetail({ id: data.id })
showDtail.value = true
await nextTick()
detailRef.value?.open()

View File

@ -9,7 +9,7 @@
<el-input class="w-[280px]" v-model="queryParams.phone" clearable placeholder="请输入电话" />
</el-form-item>
<el-form-item label="项目名称" prop="project_name">
<el-input class="w-[280px]" v-model="queryParams.project_name" clearable placeholder="请输入人员名称" />
<el-input class="w-[280px]" v-model="queryParams.project_name" clearable placeholder="请输入项目名称" />
</el-form-item>
<el-form-item label="身份" prop="identity">
<el-select class="w-[280px]" v-model="queryParams.identity" clearable placeholder="请选择身份">

View File

@ -32,13 +32,13 @@
</el-form>
</el-card>
<el-card class="!border-none" v-loading="pager.loading" shadow="never">
<el-button v-perms="['project.project/add']" type="primary" @click="handleAdd">
<el-button v-perms="['contract.subcontracting_contract_negotiation/add']" type="primary" @click="handleAdd">
<template #icon>
<icon name="el-icon-Plus" />
</template>
新增
</el-button>
<el-button v-perms="['project.project/delete']" :disabled="!selectData.length" @click="handleDelete(selectData)">
<el-button v-perms="['contract.subcontracting_contract_negotiation/delete']" :disabled="!selectData.length" @click="handleDelete(selectData)">
删除
</el-button>
@ -67,13 +67,13 @@
<el-table-column label="备注" prop="remark" show-overflow-tooltip />
<el-table-column label="操作" width="160" fixed="right">
<template #default="{ row }">
<el-button v-perms="['subcontractor.subcontractor/edit']" type="primary" link @click="handleEdit(row)">
<el-button v-perms="['contract.subcontracting_contract_negotiation/edit']" type="primary" link @click="handleEdit(row)">
编辑
</el-button>
<el-button v-perms="['subcontractor.subcontractor/delete']" type="danger" link @click="handleDelete(row.id)">
<el-button v-perms="['contract.subcontracting_contract_negotiation/delete']" type="danger" link @click="handleDelete(row.id)">
删除
</el-button>
<el-button v-perms="['subcontractor.subcontractor/detail']" link @click="handledetail(row)">
<el-button v-perms="['contract.subcontracting_contract_negotiation/detail']" link @click="handledetail(row)">
详情
</el-button>
</template>

View File

@ -1,241 +0,0 @@
<template>
<div class="detail-popup">
<popup ref="popupRef" title="供应商管理详情" :async="true" width="80%" @confirm="handleSubmit" @close="handleClose">
<el-form ref="formRef" :model="formData" label-width="160px">
<el-card class="mb-2">
<el-row>
<el-col :span="12">
<el-form-item label="建档人">
{{ formData.custom_name }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="组织">
{{ formData.org.name }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="部门">
{{ formData.dept.name
}}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商编码">
{{ formData.supplier_code
}}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商名称">
{{ formData.supplier_name }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商简介">
{{ formData.supplier_introduction }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="品牌类别">
{{ formData.brand_category }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商照片" prop="photos">
<div v-if="formData.photos && formData.photos.length > 0">
<material-picker v-model="formData.photos" />
</div>
<div v-else>暂无供应商照片</div>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商分组">
<dict-value :options="dictData.supplier_group" :value="formData.group_id" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商分类">
<dict-value :options="dictData.supplier_category" :value="formData.category_id" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商等级">
<dict-value :options="dictData.supplier_grade" :value="formData.grade" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="联系人">
{{ formData.contacts }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="性别">
<dict-value :options="dictData.sex" :value="formData.contacts_sex" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="出生日期">
{{ formData.birthday }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="电话号码">
{{ formData.competitor }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="开标日期">
{{ formData.phone }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="邮箱">
{{ formData.email }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="地址">
{{ formData.address }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="备注">
{{ formData.remark }}
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="附件" prop="field127">
<div v-if="formDataannex.length > 0">
<div v-for="(item, index) in formDataannex" style="margin-left: 5px;display: block;">
<a style="margin-left: 10px; color: #4a5dff; align-self: flex-start" :href="item.uri" target="_blank">{{ item.name }}</a>
</div>
</div>
<div v-else>暂无附件</div>
</el-form-item>
</el-col>
</el-row>
</el-card>
</el-form>
</popup>
</div>
</template>
<script lang="ts" setup name="customdetail">
import type { FormInstance } from 'element-plus'
import Popup from '@/components/popup/index.vue'
import { apiCustomDetail } from '@/api/custom'
import { timeFormat } from '@/utils/util'
import type { PropType } from 'vue'
defineProps({
dictData: {
type: Object as PropType<Record<string, any[]>>,
default: () => ({})
}
})
const emit = defineEmits(['success', 'close'])
const formRef = shallowRef<FormInstance>()
const popupRef = shallowRef<InstanceType<typeof Popup>>()
const formDataannex = reactive([])
const datas = reactive({
provinceOptions: [],
cityOptions: [],
areaOptions: [],
});
//
const formData = reactive({
})
//
const setFormData = async (data: Record<any, any>) => {
// for (const key in formData) {
// if (data[key] != null && data[key] != undefined) {
// //@ts-ignore
// formData[key] = data[key]
// }
// }
if (data.annex && data.annex.length > 0) {
const arry1 = data.annex.map((item: any, index: any) => {
return {
name: `文件${index + 1}`,
uri: item
};
});
Object.assign(formDataannex, arry1)
}
Object.assign(formData, data)
console.log(formData, '2222222222')
}
const getDetail = async (row: Record<string, any>) => {
const data = await apiCustomDetail({
id: row.id
})
setFormData(data)
}
//
const handleSubmit = async () => {
popupRef.value?.close()
}
//
const open = () => {
console.log('1111111')
popupRef.value?.open()
}
//
const handleClose = () => {
emit('close')
}
defineExpose({
open,
setFormData,
getDetail
})
</script>
<style lang="scss">
.tit {
font-size: 1.2em;
margin-bottom: 10px;
}
</style>

View File

@ -1,405 +0,0 @@
<template>
<div class="edit-popup">
<popup ref="popupRef" :title="popupTitle" :async="true" width="80%" @confirm="handleSubmit" @close="handleClose">
<el-form ref="formRef" :model="formData" label-width="auto" :rules="formRules">
<el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick">
<el-tab-pane label="基本信息" name="first">
<el-row>
<el-col :span="8">
<el-form-item label="建档人" prop="create_user_id">
<el-input v-model="create_user_name" readonly clearable placeholder="请输入建档人" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="组织" prop="org_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]">
<el-select class="w-[180px]" v-model="formData.org_id" clearable placeholder="请选择组织" @change="deptrmt">
<el-option v-for="(item, index) in list1" :key="index" :label="item.name" :value="item.id" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="部门" prop="dept_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]">
<el-select class="w-[180px]" v-model="formData.dept_id" clearable placeholder="请选择部门">
<el-option v-for="(item, index) in list2" :key="index" :label="item.name" :value="item.id" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="供应商编码" prop="supplier_code">
<el-input v-model="formData.supplier_code" readonly clearable placeholder="系统默认生成" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="供应商名称" prop="supplier_name">
<el-input v-model="formData.supplier_name" clearable placeholder="请输入" />
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="供应商简介" prop="supplier_introduction">
<el-input v-model="formData.supplier_introduction" type="textarea" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="品牌类别" prop="brand_category">
<el-input v-model="formData.brand_category" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="24">
<el-form-item label="供应商照片" prop="photos">
<material-picker v-model="formData.photos" />
</el-form-item></el-col>
<el-col :span="24">
<el-form-item label="供应商分组" label-width="130px" prop="group_id">
<el-radio-group v-model="formData.group_id" placeholder="请选择供应商分组">
<el-radio v-for="(item, index) in dictData.supplier_group" :key="index" :label="parseInt(item.value)">
{{ item.name }}
</el-radio>
</el-radio-group>
</el-form-item></el-col>
<el-col :span="24">
<el-form-item label="供应商分类" label-width="130px" prop="category_id">
<el-radio-group v-model="formData.category_id" placeholder="请选择供应商分类">
<el-radio v-for="(item, index) in dictData.supplier_category" :key="index" :label="parseInt(item.value)">
{{ item.name }}
</el-radio>
</el-radio-group>
</el-form-item></el-col><el-col :span="24">
<el-form-item label="供应商等级" label-width="130px" prop="grade">
<el-radio-group v-model="formData.grade" placeholder="请选择供应商等级">
<el-radio v-for="(item, index) in dictData.supplier_grade" :key="index" :label="parseInt(item.value)">
{{ item.name }}
</el-radio>
</el-radio-group>
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="联系人" prop="contacts">
<el-input v-model="formData.contacts" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="24">
<el-form-item label="性别" label-width="130px" prop="contacts_sex">
<el-radio-group v-model="formData.contacts_sex" placeholder="请选择性别">
<el-radio v-for="(item, index) in dictData.sex" :key="index" :label="parseInt(item.value)">
{{ item.name }}
</el-radio>
</el-radio-group>
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="出生日期" prop="birthday">
<el-date-picker v-model="formData.birthday" format="YYYY-MM-DD" value-format="YYYY-MM-DD" placeholder="请选择出生日期" clearable></el-date-picker>
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="电话号码" prop="phone">
<el-input v-model="formData.phone" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="邮箱" prop="email">
<el-input v-model="formData.email" clearable placeholder="请输入" /> </el-form-item></el-col>
<el-col :span="8">
<el-form-item label="地址" prop="address">
<el-input v-model="formData.address" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="备注" prop="remark">
<el-input v-model="formData.remark" clearable placeholder="请输入备注" />
</el-form-item></el-col><el-col :span="24">
<el-form-item label="附件" prop="field127">
<el-upload accept="doc, docx, xls, xlsx, ppt, pptx, pdf, txt, zip, rar, tar, jpg, png, gif, jpeg, webp, wmv, avi, mpg, mpeg, 3gp, mov, mp4, flv, f4v, rmvb, mkv" class="upload-demo" :show-file-list="false" aria-hidden="true" :headers="{ Token: userStore.token }" :action="base_url + '/upload/file'" :on-success="handleAvatarSuccess_four" ref="upload">
<el-button type="primary">
上传
</el-button>
</el-upload>
<div>
<div v-for="(item, index) in formDataannex" style="margin-left: 5px;display: block;">
<a style="margin-left: 10px; color: #4a5dff; align-self: flex-start" :href="item.uri" target="_blank">{{ item.name }}</a>
<span style="cursor: pointer;margin-left: 5px;" @click="delFileFn(index)">x</span>
</div>
</div>
</el-form-item></el-col>
</el-row>
</el-tab-pane>
<el-tab-pane label="开票信息" name="second">
<el-row>
<el-col :span="8">
<el-form-item label="开票公司名称" prop="invoice_company_name">
<el-input v-model="formData.invoice_company_name" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="纳税人识别号" prop="taxpayer_identification_number">
<el-input v-model="formData.taxpayer_identification_number" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="开户银行" prop="bank_name">
<el-input v-model="formData.bank_name" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="开户名称" prop="bank_accnout_name">
<el-input v-model="formData.bank_accnout_name" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="账号" prop="bank_account">
<el-input v-model="formData.bank_account" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="开户地址" prop="bank_address">
<el-input v-model="formData.bank_address" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="期初未开票金额(元)" prop="init_invoice_amount">
<el-input v-model="formData.init_invoice_amount" type="number" clearable placeholder="请输入" />
</el-form-item></el-col>
</el-row>
</el-tab-pane>
<el-tab-pane label="账期管理" name="third">
<el-col :span="8">
<el-form-item label="授信额度(元)" prop="credit_limit">
<el-input v-model="formData.credit_limit" type="number" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="账期(元)" prop="account_period">
<el-input v-model="formData.account_period" type="number" clearable placeholder="请输入" />
</el-form-item></el-col>
</el-tab-pane>
</el-tabs>
</el-form>
<reviewprocess />
</popup>
<el-dialog v-model="showDialog" title="选择项目" width="70%">
<projectTable @customEvent="customEvent"></projectTable>
</el-dialog>
</div>
</template>
<script lang="ts" setup name="bidBiddingDecisionEdit">
import type { FormInstance } from 'element-plus'
import Popup from '@/components/popup/index.vue'
import reviewprocess from '@/components/reviewprocess/index.vue'
import projectTable from "@/components/project/index.vue"
import { apisupplierAdd, apisupplierEdit, apisupplierDetail } from '@/api/suppler_list'
import { timeFormat } from '@/utils/util'
import type { PropType } from 'vue'
defineProps({
dictData: {
type: Object as PropType<Record<string, any[]>>,
default: () => ({})
}
})
const create_user_name = ref('')
const project_name = ref('')
const project_code = ref('')
const emit = defineEmits(['success', 'close'])
const formRef = shallowRef<FormInstance>()
const popupRef = shallowRef<InstanceType<typeof Popup>>()
const mode = ref('add')
const showDialog = ref(false)
const list1 = reactive([])
const list2 = reactive([])
import { deptAll } from '@/api/org/department'
import { getAll } from '@/api/org/organization'
import configs from "@/config"
const base_url = configs.baseUrl + configs.urlPrefix
import useUserStore from "@/stores/modules/user";
const userStore = useUserStore();
const userInfo = userStore.userInfo
const formDataannex = reactive([])
//
const handleAvatarSuccess_four = (
response,
uploadFile
) => {
if (response.code == 0) {
ElMessage.error(response.msg);
return;
}
formDataannex.push(
{ uri: response.data.uri, name: response.data.name }
);
};
//
const delFileFn = (index: number) => {
formDataannex.splice(index, 1)
}
//
const customEvent = (e: any) => {
formData.project_id = e.id;
project_name.value = e.custom_name
project_code.value = e.project_code
showDialog.value = false;
};
//
const popupTitle = computed(() => {
return mode.value == 'edit' ? '编辑供应商管理' : '新增供应商管理'
})
//
const activeName = ref('first')
const handleClick = (tab: TabsPaneContext, event: Event) => {
// console.log(tab, event)
}
//
const getlist = () => {
getAll().then((res) => {
Object.assign(list1, res)
if (res.length > 0 && !formData.org_id) {
formData.org_id = res[0].id
deptAll({ 'org_id': res[0].id }).then((res) => {
if (res.length > 0) {
Object.assign(list2, res)
formData.dept_id = res[0].id
}
})
}
})
}
//
const deptrmt = (e: any) => {
formData.dept_id = ''
getlist1(e)
}
//
const getlist1 = (id: any) => {
deptAll({ 'org_id': id }).then((res) => {
Object.assign(list2, res)
})
}
//
const formData = reactive({
id: '',
dept_id: '',
org_id: '',
create_user_id: "",
supplier_code: "",
supplier_name: "",
supplier_introduction: "",
brand_category: "",
photos: "",
group_id: "",
category_id: "",
grade: "",
contacts: "",
contacts_sex: "",
birthday: "",
phone: "",
email: "",
address: "",
remark: "",
annex: "",
invoice_company_name: "",
taxpayer_identification_number: "",
bank_name: "",
bank_accnout_name: "",
bank_account: "",
bank_address: "",
init_invoice_amount: "",
credit_limit: "",
account_period: ""
})
//
const formRules = reactive<any>({
})
//
const setFormData = async (data: Record<any, any>) => {
if (data.annex && data.annex.length > 0) {
const arry1 = data.annex.map((item: any, index: any) => {
return {
name: `文件${index + 1}`,
uri: item
};
});
Object.assign(formDataannex, arry1)
}
if (data.dept_id) {
getlist1(data.dept_id)
}
for (const key in formData) {
if (data[key] != null && data[key] != undefined) {
//@ts-ignore
formData[key] = data[key]
}
}
}
const getDetail = async (row: Record<string, any>) => {
const data = await apisupplierDetail({
id: row.id
})
setFormData(data)
}
//
const handleSubmit = async () => {
if (formDataannex.length > 0) {
formData.annex = JSON.stringify(formDataannex.map((item: any) => item.uri))
}
if (formData.photos.length > 0) {
formData.photos = JSON.stringify(formData.photos)
}
await formRef.value?.validate()
const data = { ...formData, }
mode.value == 'edit'
? await apisupplierEdit(data)
: await apisupplierAdd(data)
popupRef.value?.close()
emit('success')
}
//
const open = (type = 'add') => {
mode.value = type
if (!formData.create_user_id) {
create_user_name.value = userInfo.name
formData.create_user_id = userInfo.id
}
popupRef.value?.open()
getlist()
}
//
const handleClose = () => {
emit('close')
}
defineExpose({
open,
setFormData,
getDetail
})
</script>

View File

@ -1,171 +0,0 @@
<template>
<div>
<el-card class="!border-none mb-4" shadow="never">
<el-form class="mb-[-16px]" :model="queryParams" inline>
<el-form-item label="供应商编码" prop="supplier_code">
<el-input class="w-[280px]" v-model="queryParams.supplier_code" clearable placeholder="请输入供应商编码" />
</el-form-item>
<el-form-item label="供应商名称" prop="supplier_name">
<el-input class="w-[280px]" v-model="queryParams.supplier_name" clearable placeholder="请输入供应商名称" />
</el-form-item>
<el-form-item label="供应商分组" prop="group_id">
<el-select class="flex-1" v-model="queryParams.group_id" clearable placeholder="请选择供应商分组">
<el-option v-for="(item, index) in dictData.supplier_group" :key="index" :label="item.name" :value="parseInt(item.value)" />
</el-select>
</el-form-item>
<el-form-item label="供应商分类" prop="category_id">
<el-select class="flex-1" v-model="queryParams.category_id" clearable placeholder="请选择供应商分类">
<el-option v-for="(item, index) in dictData.supplier_category" :key="index" :label="item.name" :value="parseInt(item.value)" />
</el-select>
</el-form-item>
<el-form-item label="供应商等级" prop="grade">
<el-select class="flex-1" v-model="queryParams.grade" clearable placeholder="请选择供应商等级">
<el-option v-for="(item, index) in dictData.supplier_grade" :key="index" :label="item.name" :value="parseInt(item.value)" />
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="resetPage">查询</el-button>
<el-button @click="resetParams">重置</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card class="!border-none" v-loading="pager.loading" shadow="never">
<el-button v-perms="['bid.bid_bidding_decision/add']" type="primary" @click="handleAdd">
<template #icon>
<icon name="el-icon-Plus" />
</template>
新增
</el-button>
<el-button v-perms="['bid.bid_bidding_decision/delete']" :disabled="!selectData.length" @click="handleDelete(selectData)">
删除
</el-button>
<div class="mt-4">
<el-table :data="pager.lists" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" />
<el-table-column label="建档人" prop="project_id" show-overflow-tooltip />
<el-table-column label="供应商编码" prop="supplier_code" show-overflow-tooltip />
<el-table-column label="供应商名称" prop="supplier_name" show-overflow-tooltip />
<el-table-column label="品牌类别" prop="brand_category" show-overflow-tooltip />
<el-table-column label="供应商分组" prop="group_id">
<template #default="{ row }">
<dict-value :options="dictData.supplier_group" :value="row.group_id" />
</template>
</el-table-column>
<el-table-column label="供应商分类" prop="category_id">
<template #default="{ row }">
<dict-value :options="dictData.supplier_category" :value="row.category_id" />
</template>
</el-table-column>
<el-table-column label="供应商等级" prop="grade">
<template #default="{ row }">
<dict-value :options="dictData.supplier_grade" :value="row.grade" />
</template>
</el-table-column>
<el-table-column label="联系人" prop="contacts" show-overflow-tooltip />
<el-table-column label="性别" prop="contacts_sex" show-overflow-tooltip>
<template #default="{ row }">
<dict-value :options="dictData.sex" :value="row.contacts_sex" />
</template>
</el-table-column>
<el-table-column label="电话号码" prop="phone" show-overflow-tooltip />
<el-table-column label="备注" prop="remark" show-overflow-tooltip />
<el-table-column label="操作" width="160" fixed="right">
<template #default="{ row }">
<el-button v-perms="['bid.bid_bidding_decision/edit']" type="primary" link @click="handleEdit(row)">
编辑
</el-button>
<el-button v-perms="['bid.bid_bidding_decision/delete']" type="danger" link @click="handleDelete(row.id)">
删除
</el-button>
<el-button v-perms="['bid.bid_bidding_decision/detail']" link @click="handledetail(row)">
详情
</el-button>
</template>
</el-table-column>
</el-table>
</div>
<div class="flex mt-4 justify-end">
<pagination v-model="pager" @change="getLists" />
</div>
</el-card>
<detail-popup v-if="showDtail" ref="detailRef" :dict-data="dictData" @close="showDtail = false" />
<edit-popup v-if="showEdit" ref="editRef" :dict-data="dictData" @success="getLists" @close="showEdit = false" />
</div>
</template>
<script lang="ts" setup name="bidBiddingDecisionLists">
import { usePaging } from '@/hooks/usePaging'
import { useDictData } from '@/hooks/useDictOptions'
import { apisupplierLists, apisupplierDelete, apisupplierDetail } from '@/api/suppler_list'
import { timeFormat } from '@/utils/util'
import feedback from '@/utils/feedback'
import EditPopup from './edit.vue'
import DetailPopup from './detail.vue'
const detailRef = shallowRef<InstanceType<typeof DetailPopup>>()
const editRef = shallowRef<InstanceType<typeof EditPopup>>()
//
const showEdit = ref(false)
const showDtail = ref(false)
//
const queryParams = reactive({
category_id: '',
grade: '',
group_id: "",
supplier_name: '',
supplier_code: ''
})
//
const selectData = ref<any[]>([])
//
const handleSelectionChange = (val: any[]) => {
selectData.value = val.map(({ id }) => id)
}
//
const { dictData } = useDictData('supplier_grade,supplier_category,supplier_group,sex')
//
const { pager, getLists, resetParams, resetPage } = usePaging({
fetchFun: apisupplierLists,
params: queryParams
})
//
const handleAdd = async () => {
showEdit.value = true
await nextTick()
editRef.value?.open('add')
}
//
const handleEdit = async (data: any) => {
let res = await apisupplierDetail({ id: data.id })
showEdit.value = true
await nextTick()
editRef.value?.open('edit')
editRef.value?.setFormData(res)
}
//
const handleDelete = async (id: number | any[]) => {
await feedback.confirm('确定要删除?')
await apisupplierDelete({ id })
getLists()
}
//
const handledetail = async (data: any) => {
let res = await apisupplierDetail({ id: data.id })
showDtail.value = true
await nextTick()
detailRef.value?.open()
detailRef.value?.setFormData(res)
}
getLists()
</script>

View File

@ -3,105 +3,131 @@
<template>
<div class="detail-popup">
<popup ref="popupRef" title="投标决策详情" :async="true" width="80%" @confirm="handleSubmit" @close="handleClose">
<popup ref="popupRef" title="供应商管理详情" :async="true" width="80%" @confirm="handleSubmit" @close="handleClose">
<el-form ref="formRef" :model="formData" label-width="160px">
<el-card class="mb-2">
<el-row>
<el-col :span="12">
<el-form-item label="客户名称">
<el-form-item label="建档人">
{{ formData.custom_name }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="项目名称">
{{ formData.project.name }}
<el-form-item label="组织">
{{ formData.org.name }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="项目编码">
{{ formData.project.project_code }}
<el-form-item label="部门">
{{ formData.dept.name
}}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商编码">
{{ formData.supplier_code
}}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商名称">
{{ formData.supplier_name }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商简介">
{{ formData.supplier_introduction }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="品牌类别">
{{ formData.brand_category }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="供应商照片" prop="photos">
<div v-if="formData.photos && formData.photos.length > 0">
<material-picker v-model="formData.photos" />
</div>
<div v-else>暂无供应商照片</div>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="项目估算(万元)">
{{ formData.project_estimation }}
<el-form-item label="供应商分组">
<dict-value :options="dictData.supplier_group" :value="formData.group_id" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="投标时间">
{{ formData.bidding_time }}
<el-form-item label="供应商分类">
<dict-value :options="dictData.supplier_category" :value="formData.category_id" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="购买标书时间">
{{ formData.buy_bid_document_date }}
<el-form-item label="供应商等级">
<dict-value :options="dictData.supplier_grade" :value="formData.grade" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="招标项目资金来源">
<dict-value :options="dictData.construction_funds_sources" :value="formData.bidding_project_fund_source" />
<el-form-item label="联系人">
{{ formData.contacts }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="招标方式">
<dict-value :options="dictData.bidding_method" :value="formData.bid_type" />
<el-form-item label="性别">
<dict-value :options="dictData.sex" :value="formData.contacts_sex" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="竞争对手">
{{ formData.competitor }}
<el-form-item label="出生日期">
{{ formData.birthday }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="保证金金额">
{{ formData.margin_amount }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="是否需要保证金">
<dict-value :options="dictData.whether_status" :value="formData.whether_status" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="保证金金额">
<el-form-item label="电话号码">
{{ formData.competitor }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="开标日期">
{{ bid_opening_date }}
{{ formData.phone }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="保证金退还时间">
{{ formData.margin_amount_return_date }}
<el-form-item label="邮箱">
{{ formData.email }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="有无内部资源">
<dict-value :options="dictData.whether_status" :value="formData.is_internal_resources" />
<el-form-item label="地址">
{{ formData.address }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="项目把握度">
{{ formData.project_assurancee }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="招标项目概况">
{{ formData.bid_project_overview }}
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="项目简介">
{{ formData.project_desc }}
<el-form-item label="备注">
{{ formData.remark }}
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="附件" prop="field127">
<div v-if="formDataannex.length > 0">
<div v-for="(item, index) in formDataannex" style="margin-left: 5px;display: block;">
<a style="margin-left: 10px; color: #4a5dff; align-self: flex-start" :href="item.uri" target="_blank">{{ item.name }}</a>
</div>
</div>
<div v-else>暂无附件</div>
</el-form-item>
</el-col>
</el-row>
</el-card>
@ -116,6 +142,7 @@ import type { FormInstance } from 'element-plus'
import Popup from '@/components/popup/index.vue'
import { apiCustomDetail } from '@/api/custom'
import { timeFormat } from '@/utils/util'
import type { PropType } from 'vue'
defineProps({
dictData: {
@ -126,7 +153,7 @@ defineProps({
const emit = defineEmits(['success', 'close'])
const formRef = shallowRef<FormInstance>()
const popupRef = shallowRef<InstanceType<typeof Popup>>()
const formDataannex = reactive([])
const datas = reactive({
provinceOptions: [],
cityOptions: [],
@ -151,7 +178,17 @@ const setFormData = async (data: Record<any, any>) => {
// }
// }
if (data.annex && data.annex.length > 0) {
const arry1 = data.annex.map((item: any, index: any) => {
return {
name: `文件${index + 1}`,
uri: item
};
});
Object.assign(formDataannex, arry1)
}
Object.assign(formData, data)
console.log(formData, '2222222222')

View File

@ -1,67 +1,201 @@
<template>
<div class="edit-popup">
<popup ref="popupRef" :title="popupTitle" :async="true" width="80%" @confirm="handleSubmit" @close="handleClose">
<el-form ref="formRef" :model="formData" label-width="90px" :rules="formRules">
<el-row>
<el-col :span="8">
<el-form-item label="项目名称" prop="bid_document_examination_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]" @click="showDialog = true">
<el-input v-model="project_name" readonly clearable placeholder="请输入" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="项目编码" prop="bid_document_examination_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]">
<el-input v-model="project_code" clearable readonly placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="客户名称" prop="bid_document_examination_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]">
<el-input v-model="matsname" clearable readonly placeholder="请输入" />
</el-form-item></el-col><el-col :span="8">
<!-- @click="showDialog1 = true" -->
<el-form-item label="产品id" prop="product_id">
<el-input v-model="formData.product_id" readonly clearable placeholder="请输入产品id" />
</el-form-item></el-col><el-col :span="8">
<el-form-item label="产品数量" prop="product_num">
<el-input v-model="formData.product_num" clearable placeholder="请输入产品数量" />
</el-form-item></el-col><el-col :span="8">
<el-form-item label="成本单价" prop="cost_unit_price">
<el-input v-model="formData.cost_unit_price" clearable placeholder="请输入成本单价" />
</el-form-item></el-col><el-col :span="8">
<el-form-item label="金额" prop="amount">
<el-input v-model="formData.amount" clearable placeholder="请输入金额" />
</el-form-item></el-col><el-col :span="8">
<el-form-item label="点数" prop="rate">
<el-input v-model="formData.rate" clearable placeholder="请输入点数" />
</el-form-item></el-col><el-col :span="8">
<el-form-item label="报价单价" prop="unit_price">
<el-input v-model="formData.unit_price" clearable placeholder="请输入报价单价" />
</el-form-item></el-col><el-col :span="8">
<el-form-item label="报价金额" prop="total_amount">
<el-input v-model="formData.total_amount" clearable placeholder="请输入报价金额" />
</el-form-item></el-col><el-col :span="8">
<el-form-item label="" prop="create_user">
<el-input v-model="formData.create_user" clearable placeholder="请输入" />
</el-form-item></el-col>
</el-row>
</el-form>
</popup>
<el-dialog v-model="showDialog" title="选择标书" width="70%">
<biddocumentTable @customEvent="customEvent"></biddocumentTable>
<el-form ref="formRef" :model="formData" label-width="auto" :rules="formRules">
<el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick">
<el-tab-pane label="基本信息" name="first">
<el-row>
<el-col :span="8">
<el-form-item label="建档人" prop="create_user_id">
<el-input v-model="create_user_name" readonly clearable placeholder="请输入建档人" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="组织" prop="org_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]">
<el-select class="w-[180px]" v-model="formData.org_id" clearable placeholder="请选择组织" @change="deptrmt">
<el-option v-for="(item, index) in list1" :key="index" :label="item.name" :value="item.id" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="部门" prop="dept_id" :rules="[{ required: true, message: '不可为空', trigger: 'blur' }]">
<el-select class="w-[180px]" v-model="formData.dept_id" clearable placeholder="请选择部门">
<el-option v-for="(item, index) in list2" :key="index" :label="item.name" :value="item.id" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="供应商编码" prop="supplier_code">
<el-input v-model="formData.supplier_code" readonly clearable placeholder="系统默认生成" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="供应商名称" prop="supplier_name">
<el-input v-model="formData.supplier_name" clearable placeholder="请输入" />
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="供应商简介" prop="supplier_introduction">
<el-input v-model="formData.supplier_introduction" type="textarea" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="品牌类别" prop="brand_category">
<el-input v-model="formData.brand_category" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="24">
<el-form-item label="供应商照片" prop="photos">
<material-picker v-model="formData.photos" />
</el-form-item></el-col>
<el-col :span="24">
<el-form-item label="供应商分组" label-width="130px" prop="group_id">
<el-radio-group v-model="formData.group_id" placeholder="请选择供应商分组">
<el-radio v-for="(item, index) in dictData.supplier_group" :key="index" :label="parseInt(item.value)">
{{ item.name }}
</el-radio>
</el-radio-group>
</el-form-item></el-col>
<el-col :span="24">
<el-form-item label="供应商分类" label-width="130px" prop="category_id">
<el-radio-group v-model="formData.category_id" placeholder="请选择供应商分类">
<el-radio v-for="(item, index) in dictData.supplier_category" :key="index" :label="parseInt(item.value)">
{{ item.name }}
</el-radio>
</el-radio-group>
</el-form-item></el-col><el-col :span="24">
<el-form-item label="供应商等级" label-width="130px" prop="grade">
<el-radio-group v-model="formData.grade" placeholder="请选择供应商等级">
<el-radio v-for="(item, index) in dictData.supplier_grade" :key="index" :label="parseInt(item.value)">
{{ item.name }}
</el-radio>
</el-radio-group>
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="联系人" prop="contacts">
<el-input v-model="formData.contacts" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="24">
<el-form-item label="性别" label-width="130px" prop="contacts_sex">
<el-radio-group v-model="formData.contacts_sex" placeholder="请选择性别">
<el-radio v-for="(item, index) in dictData.sex" :key="index" :label="parseInt(item.value)">
{{ item.name }}
</el-radio>
</el-radio-group>
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="出生日期" prop="birthday">
<el-date-picker v-model="formData.birthday" format="YYYY-MM-DD" value-format="YYYY-MM-DD" placeholder="请选择出生日期" clearable></el-date-picker>
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="电话号码" prop="phone">
<el-input v-model="formData.phone" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="邮箱" prop="email">
<el-input v-model="formData.email" clearable placeholder="请输入" /> </el-form-item></el-col>
<el-col :span="8">
<el-form-item label="地址" prop="address">
<el-input v-model="formData.address" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="备注" prop="remark">
<el-input v-model="formData.remark" clearable placeholder="请输入备注" />
</el-form-item></el-col><el-col :span="24">
<el-form-item label="附件" prop="field127">
<el-upload accept="doc, docx, xls, xlsx, ppt, pptx, pdf, txt, zip, rar, tar, jpg, png, gif, jpeg, webp, wmv, avi, mpg, mpeg, 3gp, mov, mp4, flv, f4v, rmvb, mkv" class="upload-demo" :show-file-list="false" aria-hidden="true" :headers="{ Token: userStore.token }" :action="base_url + '/upload/file'" :on-success="handleAvatarSuccess_four" ref="upload">
<el-button type="primary">
上传
</el-button>
</el-upload>
<div>
<div v-for="(item, index) in formDataannex" style="margin-left: 5px;display: block;">
<a style="margin-left: 10px; color: #4a5dff; align-self: flex-start" :href="item.uri" target="_blank">{{ item.name }}</a>
<span style="cursor: pointer;margin-left: 5px;" @click="delFileFn(index)">x</span>
</div>
</div>
</el-form-item></el-col>
</el-row>
</el-tab-pane>
<el-tab-pane label="开票信息" name="second">
<el-row>
<el-col :span="8">
<el-form-item label="开票公司名称" prop="invoice_company_name">
<el-input v-model="formData.invoice_company_name" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="纳税人识别号" prop="taxpayer_identification_number">
<el-input v-model="formData.taxpayer_identification_number" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="开户银行" prop="bank_name">
<el-input v-model="formData.bank_name" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="开户名称" prop="bank_accnout_name">
<el-input v-model="formData.bank_accnout_name" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="账号" prop="bank_account">
<el-input v-model="formData.bank_account" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="开户地址" prop="bank_address">
<el-input v-model="formData.bank_address" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="期初未开票金额(元)" prop="init_invoice_amount">
<el-input v-model="formData.init_invoice_amount" type="number" clearable placeholder="请输入" />
</el-form-item></el-col>
</el-row>
</el-tab-pane>
<el-tab-pane label="账期管理" name="third">
<el-col :span="8">
<el-form-item label="授信额度(元)" prop="credit_limit">
<el-input v-model="formData.credit_limit" type="number" clearable placeholder="请输入" />
</el-form-item></el-col>
<el-col :span="8">
<el-form-item label="账期(元)" prop="account_period">
<el-input v-model="formData.account_period" type="number" clearable placeholder="请输入" />
</el-form-item></el-col>
</el-tab-pane>
</el-tabs>
</el-form>
<reviewprocess />
</popup>
<el-dialog v-model="showDialog" title="选择项目" width="70%">
<projectTable @customEvent="customEvent"></projectTable>
</el-dialog>
<el-dialog v-model="showDialog1" title="选择产品" width="70%">
<prodctTable @customEvent="customEvent1"></prodctTable>
</el-dialog>
</div>
</template>
<script lang="ts" setup name="bidDocumentExaminationDetailEdit">
<script lang="ts" setup name="bidBiddingDecisionEdit">
import type { FormInstance } from 'element-plus'
import Popup from '@/components/popup/index.vue'
import biddocumentTable from "@/components/biddocument/index.vue"
import prodctTable from "@/components/product/index.vue"
import { apiBidDocumentExaminationDetailAdd, apiBidDocumentExaminationDetailEdit, apiBidDocumentExaminationDetailDetail } from '@/api/bid_document_examination_detail'
import { timeFormat } from '@/utils/util'
import reviewprocess from '@/components/reviewprocess/index.vue'
import projectTable from "@/components/project/index.vue"
import { apisupplierAdd, apisupplierEdit, apisupplierDetail } from '@/api/suppler_list'
import { timeFormat } from '@/utils/util'
import type { PropType } from 'vue'
defineProps({
dictData: {
@ -69,7 +203,7 @@ defineProps({
default: () => ({})
}
})
const matsname = ref('')
const create_user_name = ref('')
const project_name = ref('')
const project_code = ref('')
const emit = defineEmits(['success', 'close'])
@ -77,24 +211,113 @@ const formRef = shallowRef<FormInstance>()
const popupRef = shallowRef<InstanceType<typeof Popup>>()
const mode = ref('add')
const showDialog = ref(false)
const showDialog1 = ref(false)
const list1 = reactive([])
const list2 = reactive([])
import { deptAll } from '@/api/org/department'
import { getAll } from '@/api/org/organization'
import configs from "@/config"
const base_url = configs.baseUrl + configs.urlPrefix
import useUserStore from "@/stores/modules/user";
const userStore = useUserStore();
const userInfo = userStore.userInfo
const formDataannex = reactive([])
//
const handleAvatarSuccess_four = (
response,
uploadFile
) => {
if (response.code == 0) {
ElMessage.error(response.msg);
return;
}
formDataannex.push(
{ uri: response.data.uri, name: response.data.name }
);
};
//
const delFileFn = (index: number) => {
formDataannex.splice(index, 1)
}
//
const customEvent = (e: any) => {
formData.project_id = e.id;
project_name.value = e.custom_name
project_code.value = e.project_code
showDialog.value = false;
};
//
const popupTitle = computed(() => {
return mode.value == 'edit' ? '编辑标书审查-报价明细' : '新增标书审查-报价明细'
return mode.value == 'edit' ? '编辑供应商管理' : '新增供应商管理'
})
//
const activeName = ref('first')
const handleClick = (tab: TabsPaneContext, event: Event) => {
// console.log(tab, event)
}
//
const getlist = () => {
getAll().then((res) => {
Object.assign(list1, res)
if (res.length > 0 && !formData.org_id) {
formData.org_id = res[0].id
deptAll({ 'org_id': res[0].id }).then((res) => {
if (res.length > 0) {
Object.assign(list2, res)
formData.dept_id = res[0].id
}
})
}
})
}
//
const deptrmt = (e: any) => {
formData.dept_id = ''
getlist1(e)
}
//
const getlist1 = (id: any) => {
deptAll({ 'org_id': id }).then((res) => {
Object.assign(list2, res)
})
}
//
const formData = reactive({
id: '',
bid_document_examination_id: '',
product_id: '',
product_num: '',
cost_unit_price: '',
amount: '',
rate: '',
unit_price: '',
total_amount: '',
create_user: '',
dept_id: '',
org_id: '',
create_user_id: "",
supplier_code: "",
supplier_name: "",
supplier_introduction: "",
brand_category: "",
photos: "",
group_id: "",
category_id: "",
grade: "",
contacts: "",
contacts_sex: "",
birthday: "",
phone: "",
email: "",
address: "",
remark: "",
annex: "",
invoice_company_name: "",
taxpayer_identification_number: "",
bank_name: "",
bank_accnout_name: "",
bank_account: "",
bank_address: "",
init_invoice_amount: "",
credit_limit: "",
account_period: ""
})
@ -103,26 +326,23 @@ const formRules = reactive<any>({
})
//
const customEvent = (e: any) => {
formData.bid_document_examination_id = e.id;
matsname.value = e.person
project_name.value = e.custom_name
project_code.value = e.project_code
showDialog.value = false;
};
//
const customEvent1 = (e: any) => {
// formData.buy_bidding_document_id = e.id;
showDialog1.value = false;
};
//
const setFormData = async (data: Record<any, any>) => {
if (data.annex && data.annex.length > 0) {
const arry1 = data.annex.map((item: any, index: any) => {
return {
name: `文件${index + 1}`,
uri: item
};
});
Object.assign(formDataannex, arry1)
}
if (data.dept_id) {
getlist1(data.dept_id)
}
for (const key in formData) {
if (data[key] != null && data[key] != undefined) {
//@ts-ignore
@ -134,7 +354,7 @@ const setFormData = async (data: Record<any, any>) => {
}
const getDetail = async (row: Record<string, any>) => {
const data = await apiBidDocumentExaminationDetailDetail({
const data = await apisupplierDetail({
id: row.id
})
setFormData(data)
@ -143,11 +363,17 @@ const getDetail = async (row: Record<string, any>) => {
//
const handleSubmit = async () => {
if (formDataannex.length > 0) {
formData.annex = JSON.stringify(formDataannex.map((item: any) => item.uri))
}
if (formData.photos.length > 0) {
formData.photos = JSON.stringify(formData.photos)
}
await formRef.value?.validate()
const data = { ...formData, }
mode.value == 'edit'
? await apiBidDocumentExaminationDetailEdit(data)
: await apiBidDocumentExaminationDetailAdd(data)
? await apisupplierEdit(data)
: await apisupplierAdd(data)
popupRef.value?.close()
emit('success')
}
@ -155,7 +381,13 @@ const handleSubmit = async () => {
//
const open = (type = 'add') => {
mode.value = type
if (!formData.create_user_id) {
create_user_name.value = userInfo.name
formData.create_user_id = userInfo.id
}
popupRef.value?.open()
getlist()
}
//

View File

@ -2,11 +2,26 @@
<div>
<el-card class="!border-none mb-4" shadow="never">
<el-form class="mb-[-16px]" :model="queryParams" inline>
<el-form-item label="标书审查id" prop="bid_document_examination_id">
<el-input class="w-[280px]" v-model="queryParams.bid_document_examination_id" clearable placeholder="请输入标书审查id" />
<el-form-item label="供应商编码" prop="supplier_code">
<el-input class="w-[280px]" v-model="queryParams.supplier_code" clearable placeholder="请输入供应商编码" />
</el-form-item>
<el-form-item label="产品id" prop="product_id">
<el-input class="w-[280px]" v-model="queryParams.product_id" clearable placeholder="请输入产品id" />
<el-form-item label="供应商名称" prop="supplier_name">
<el-input class="w-[280px]" v-model="queryParams.supplier_name" clearable placeholder="请输入供应商名称" />
</el-form-item>
<el-form-item label="供应商分组" prop="group_id">
<el-select class="flex-1" v-model="queryParams.group_id" clearable placeholder="请选择供应商分组">
<el-option v-for="(item, index) in dictData.supplier_group" :key="index" :label="item.name" :value="parseInt(item.value)" />
</el-select>
</el-form-item>
<el-form-item label="供应商分类" prop="category_id">
<el-select class="flex-1" v-model="queryParams.category_id" clearable placeholder="请选择供应商分类">
<el-option v-for="(item, index) in dictData.supplier_category" :key="index" :label="item.name" :value="parseInt(item.value)" />
</el-select>
</el-form-item>
<el-form-item label="供应商等级" prop="grade">
<el-select class="flex-1" v-model="queryParams.grade" clearable placeholder="请选择供应商等级">
<el-option v-for="(item, index) in dictData.supplier_grade" :key="index" :label="item.name" :value="parseInt(item.value)" />
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="resetPage">查询</el-button>
@ -15,36 +30,57 @@
</el-form>
</el-card>
<el-card class="!border-none" v-loading="pager.loading" shadow="never">
<el-button v-perms="['bid.bid_document_examination_detail/add']" type="primary" @click="handleAdd">
<el-button v-perms="['bid.bid_bidding_decision/add']" type="primary" @click="handleAdd">
<template #icon>
<icon name="el-icon-Plus" />
</template>
新增
</el-button>
<el-button v-perms="['bid.bid_document_examination_detail/delete']" :disabled="!selectData.length" @click="handleDelete(selectData)">
<el-button v-perms="['bid.bid_bidding_decision/delete']" :disabled="!selectData.length" @click="handleDelete(selectData)">
删除
</el-button>
<div class="mt-4">
<el-table :data="pager.lists" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" />
<el-table-column label="标书审查id" prop="bid_document_examination_id" show-overflow-tooltip />
<el-table-column label="产品id" prop="product_id" show-overflow-tooltip />
<el-table-column label="产品数量" prop="product_num" show-overflow-tooltip />
<el-table-column label="成本单价" prop="cost_unit_price" show-overflow-tooltip />
<el-table-column label="金额" prop="amount" show-overflow-tooltip />
<el-table-column label="点数" prop="rate" show-overflow-tooltip />
<el-table-column label="报价单价" prop="unit_price" show-overflow-tooltip />
<el-table-column label="报价金额" prop="total_amount" show-overflow-tooltip />
<el-table-column label="" prop="create_user" show-overflow-tooltip />
<el-table-column label="建档人" prop="project_id" show-overflow-tooltip />
<el-table-column label="供应商编码" prop="supplier_code" show-overflow-tooltip />
<el-table-column label="供应商名称" prop="supplier_name" show-overflow-tooltip />
<el-table-column label="品牌类别" prop="brand_category" show-overflow-tooltip />
<el-table-column label="供应商分组" prop="group_id">
<template #default="{ row }">
<dict-value :options="dictData.supplier_group" :value="row.group_id" />
</template>
</el-table-column>
<el-table-column label="供应商分类" prop="category_id">
<template #default="{ row }">
<dict-value :options="dictData.supplier_category" :value="row.category_id" />
</template>
</el-table-column>
<el-table-column label="供应商等级" prop="grade">
<template #default="{ row }">
<dict-value :options="dictData.supplier_grade" :value="row.grade" />
</template>
</el-table-column>
<el-table-column label="联系人" prop="contacts" show-overflow-tooltip />
<el-table-column label="性别" prop="contacts_sex" show-overflow-tooltip>
<template #default="{ row }">
<dict-value :options="dictData.sex" :value="row.contacts_sex" />
</template>
</el-table-column>
<el-table-column label="电话号码" prop="phone" show-overflow-tooltip />
<el-table-column label="备注" prop="remark" show-overflow-tooltip />
<el-table-column label="操作" width="160" fixed="right">
<template #default="{ row }">
<el-button v-perms="['bid.bid_document_examination_detail/edit']" type="primary" link @click="handleEdit(row)">
<el-button v-perms="['bid.bid_bidding_decision/edit']" type="primary" link @click="handleEdit(row)">
编辑
</el-button>
<el-button v-perms="['bid.bid_document_examination_detail/delete']" type="danger" link @click="handleDelete(row.id)">
<el-button v-perms="['bid.bid_bidding_decision/delete']" type="danger" link @click="handleDelete(row.id)">
删除
</el-button>
<el-button v-perms="['bid.bid_document_examination_detail/detail']" link @click="handledetail(row)">
<el-button v-perms="['bid.bid_bidding_decision/detail']" link @click="handledetail(row)">
详情
</el-button>
</template>
@ -60,10 +96,10 @@
</div>
</template>
<script lang="ts" setup name="bidDocumentExaminationDetailLists">
<script lang="ts" setup name="bidBiddingDecisionLists">
import { usePaging } from '@/hooks/usePaging'
import { useDictData } from '@/hooks/useDictOptions'
import { apiBidDocumentExaminationDetailLists, apiBidDocumentExaminationDetailDelete, apiBidDocumentExaminationDetailDetail } from '@/api/bid_document_examination_detail'
import { apisupplierLists, apisupplierDelete, apisupplierDetail } from '@/api/suppler_list'
import { timeFormat } from '@/utils/util'
import feedback from '@/utils/feedback'
import EditPopup from './edit.vue'
@ -72,15 +108,15 @@ const detailRef = shallowRef<InstanceType<typeof DetailPopup>>()
const editRef = shallowRef<InstanceType<typeof EditPopup>>()
//
const showEdit = ref(false)
const showDtail = ref(false)
//
const queryParams = reactive({
bid_document_examination_id: '',
product_id: ''
category_id: '',
grade: '',
group_id: "",
supplier_name: '',
supplier_code: ''
})
//
@ -92,11 +128,11 @@ const handleSelectionChange = (val: any[]) => {
}
//
const { dictData } = useDictData('')
const { dictData } = useDictData('supplier_grade,supplier_category,supplier_group,sex')
//
const { pager, getLists, resetParams, resetPage } = usePaging({
fetchFun: apiBidDocumentExaminationDetailLists,
fetchFun: apisupplierLists,
params: queryParams
})
@ -109,24 +145,24 @@ const handleAdd = async () => {
//
const handleEdit = async (data: any) => {
let res = await apisupplierDetail({ id: data.id })
showEdit.value = true
await nextTick()
editRef.value?.open('edit')
editRef.value?.setFormData(data)
editRef.value?.setFormData(res)
}
//
const handleDelete = async (id: number | any[]) => {
await feedback.confirm('确定要删除?')
await apiBidDocumentExaminationDetailDelete({ id })
await apisupplierDelete({ id })
getLists()
}
//
const handledetail = async (data: any) => {
let res = await apiBidDocumentExaminationDetailDetail({ id: data.id })
let res = await apisupplierDetail({ id: data.id })
showDtail.value = true
await nextTick()
detailRef.value?.open()
detailRef.value?.setFormData(res)
}