合并
This commit is contained in:
		| @ -118,7 +118,8 @@ | ||||
|             <el-table-column prop="name" label="工程或费用名称" /> | ||||
|             <el-table-column prop="unit" label="单位" /> | ||||
|             <!-- <el-table-column prop="quantity" label="数量" /> --> | ||||
|             <el-table-column prop="selectNum" label="选择数量" align="center"> | ||||
|             <el-table-column prop="quantity" label="计划量" align="center" /> | ||||
|             <el-table-column prop="selectNum" label="设计量" align="center"> | ||||
|               <template #default="scope"> | ||||
|                 <el-input-number | ||||
|                   :model-value="scope.row.selectNum" | ||||
| @ -132,16 +133,36 @@ | ||||
|                   :step="1" | ||||
|                   :controls="false" | ||||
|                   :max="Math.floor(scope.row.quantity)" | ||||
|                   v-if="scope.row.quantity && scope.row.quantity != 0" | ||||
|                   v-if="scope.row.quantity && scope.row.quantity != 0 && scope.row.unitPrice" | ||||
|                 /> | ||||
|               </template> | ||||
|             </el-table-column> | ||||
|             <el-table-column prop="unitPrice" label="单价" align="center" /> | ||||
|             <!-- <el-table-column prop="price" label="总价" align="center"> | ||||
|  | ||||
|             <el-table-column prop="useQuantity" label="剩余量" align="center"> | ||||
|               <template #default="scope"> | ||||
|                 {{ scope.row.price }} | ||||
|                 {{ | ||||
|                   (scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0) == 0 | ||||
|                     ? '' | ||||
|                     : (scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0) | ||||
|                 }} | ||||
|               </template> | ||||
|             </el-table-column> --> | ||||
|             </el-table-column> | ||||
|  | ||||
|             <el-table-column prop="unitPrice" label="单价" align="center" /> | ||||
|             <el-table-column prop="price" label="总价" align="center"> | ||||
|               <template #default="scope"> | ||||
|                 {{ | ||||
|                   ((scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0)) * | ||||
|                     Number(scope.row.unitPrice) == | ||||
|                   0 | ||||
|                     ? '' | ||||
|                     : ( | ||||
|                         ((scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0)) * | ||||
|                         Number(scope.row.unitPrice) | ||||
|                       ).toFixed(2) | ||||
|                 }} | ||||
|               </template> | ||||
|             </el-table-column> | ||||
|           </el-table> | ||||
|         </el-col> | ||||
|       </el-row> | ||||
|  | ||||
| @ -259,7 +259,7 @@ | ||||
|     </el-dialog> | ||||
|  | ||||
|     <!-- 添加或修改手续办理清单模板对话框 --> | ||||
|     <el-dialog title="添加手续办理清单模板" v-model="tempDialogVisible" width="500px" append-to-body @close="templateCancel"> | ||||
|     <el-dialog title="添加手续办理清单" v-model="tempDialogVisible" width="500px" append-to-body @close="templateCancel"> | ||||
|       <el-form ref="listOfFormalitiesFormRef" :model="formTemplate" label-width="80px"> | ||||
|         <el-form-item label="父级" prop="formalitiesPid" :rules="[{ required: true, message: '请选择父级', trigger: 'blur' }]"> | ||||
|           <el-select v-model="formTemplate.formalitiesPid" placeholder="请选择父级"> | ||||
|  | ||||
| @ -1,245 +1,78 @@ | ||||
| <template> | ||||
|   <div class="p-2"> | ||||
|     <transition :enter-active-class="proxy?.animate.searchAnimate.enter" :leave-active-class="proxy?.animate.searchAnimate.leave"> | ||||
|       <el-card shadow="always"> | ||||
|         <el-form :model="queryForm" :inline="true"> | ||||
|           <el-form-item label="表名" prop="sheet"> | ||||
|             <el-select v-model="queryForm.sheet" placeholder="选择表名" @change="changeSheet"> | ||||
|               <el-option v-for="item in sheets" :key="item" :label="item" :value="item" /> | ||||
|             </el-select> | ||||
|           </el-form-item> | ||||
|           <el-form-item> | ||||
|             <el-button type="primary" @click="toggleExpandAll">{{ isExpandAll ? '一键收起' : '一键展开' }}</el-button> | ||||
|           </el-form-item> | ||||
|           <el-form-item> | ||||
|             <el-upload | ||||
|               ref="uploadRef" | ||||
|               class="upload-demo" | ||||
|               :http-request="importExcel" | ||||
|               :show-file-list="false" | ||||
|               v-hasPermi="['bidding:biddingLimitList:importExcelFile']" | ||||
|             > | ||||
|               <template #trigger> | ||||
|                 <el-button type="primary">导入excel</el-button> | ||||
|               </template> | ||||
|             </el-upload> | ||||
|           </el-form-item> | ||||
|           <el-form-item> | ||||
|             <el-button type="primary" @click="handleExport()" v-hasPermi="['bidding:biddingLimitList:export']">导出excel</el-button> | ||||
|           </el-form-item> | ||||
|         </el-form> | ||||
|       </el-card> | ||||
|     </transition> | ||||
|     <el-card shadow="never" class="mb8"> | ||||
|       <el-table ref="tableRef" v-loading="loading" :data="tableData" row-key="id" border lazy default-expand-all> | ||||
|         <el-table-column prop="num" label="编号" /> | ||||
|         <el-table-column prop="name" label="工程或费用名称" /> | ||||
|         <el-table-column prop="unit" label="单位" /> | ||||
|         <el-table-column prop="quantity" label="数量" /> | ||||
|         <el-table-column prop="remark" label="单价" align="center"> | ||||
|           <template #default="scope"> | ||||
|             <el-input-number | ||||
|               :model-value="scope.row.unitPrice" | ||||
|               @change="(val) => (scope.row.unitPrice = val)" | ||||
|               :precision="2" | ||||
|               :step="0.1" | ||||
|               :controls="false" | ||||
|               v-if="scope.row.quantity && scope.row.quantity != 0" | ||||
|             /> | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column prop="price" label="总价" align="center"> | ||||
|           <template #default="scope"> | ||||
|             {{ scope.row.price }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column prop="price" label="操作" align="center"> | ||||
|           <template #default="scope"> | ||||
|             <el-button | ||||
|               type="primary" | ||||
|               size="small" | ||||
|               @click="handleSave(scope.row)" | ||||
|               v-if="scope.row.quantity && scope.row.quantity != 0" | ||||
|               v-hasPermi="['bidding:biddingLimitList:edit']" | ||||
|               >修改</el-button | ||||
|             > | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
|     </el-card> | ||||
|   </div> | ||||
|   <el-dialog v-model="dialogVisible" title="招标文件" width="500" draggable> | ||||
|     <el-form ref="ruleFormRef" style="max-width: 600px" :model="ruleForm" :rules="rules" label-width="auto"> | ||||
|       <el-form-item label="招标文件" prop="name"> | ||||
|         <file-upload | ||||
|           v-model="form.costEstimationFile" | ||||
|           :fileSize="100" | ||||
|           :auto-upload="false" | ||||
|           uploadUrl="/tender/biddingPlan/uploadBiddingDocuments" | ||||
|           method="put" | ||||
|           ref="fileUploadRef" | ||||
|           :data="{ | ||||
|             projectId: currentProject?.id, | ||||
|             type: planType, | ||||
|             fileType: '1', | ||||
|             bidStatus: '0', | ||||
|             id: row.id | ||||
|           }" | ||||
|           showFileList | ||||
|         /> | ||||
|       </el-form-item> | ||||
|     </el-form> | ||||
|     <template #footer> | ||||
|       <div class="dialog-footer"> | ||||
|         <el-button @click="closeDialog()"> 取消 </el-button> | ||||
|         <el-button type="primary" @click="submitForm()">确定</el-button> | ||||
|       </div> | ||||
|     </template> | ||||
|   </el-dialog> | ||||
| </template> | ||||
|  | ||||
| <script setup lang="ts"> | ||||
| import { useUserStoreHook } from '@/store/modules/user'; | ||||
| import { obtainAllVersionNumbers } from '@/api/contract/index'; | ||||
| import { BiddingImportExcelFile, getTreeLimit, biddingLimitListUpdate, sheetList } from '@/api/bidding/biddingLimit'; | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
|  | ||||
| const userStore = useUserStoreHook(); | ||||
| const currentProject = computed(() => userStore.selectedProject); | ||||
| const queryForm = ref({ | ||||
|   versions: '', | ||||
|   sheet: '' | ||||
| const dialogVisible = ref(false); | ||||
| const row = ref<any>(); | ||||
| const planType = ref<any>(''); | ||||
| const fileUploadRef = ref<any>(); | ||||
| const ruleForm = ref<any>(); | ||||
| const rules = ref({ | ||||
|   costEstimationFile: [{ required: true, message: '请上传招标文件', trigger: ['blur'] }] | ||||
| }); | ||||
| const loading = ref(false); | ||||
| const options = ref<any[]>([]); | ||||
| const sheets = ref<any[]>([]); | ||||
| const tableData = ref<any[]>([]); | ||||
| const isExpandAll = ref(true); | ||||
| // 接受父组件传递的参数 | ||||
| const props = defineProps({ | ||||
|   type: { | ||||
|     type: String, | ||||
|     default: '' | ||||
|   } | ||||
| const emit = defineEmits(['success']); | ||||
| const form = ref({ | ||||
|   costEstimationFile: '' | ||||
| }); | ||||
|  | ||||
| //获取版本号 | ||||
| const getVersionNums = async () => { | ||||
|   try { | ||||
|     const params = { | ||||
|       projectId: currentProject.value?.id, | ||||
|       pageSize: 1000, | ||||
|       pageNum: 1 | ||||
|     }; | ||||
|  | ||||
|     const res = await obtainAllVersionNumbers(params); | ||||
|     if (res.code == 200) { | ||||
|       options.value = res.data; | ||||
|       if (res.data.length > 0) { | ||||
|         queryForm.value.versions = res.data[0]; | ||||
|         getSheetName(); | ||||
|       } else { | ||||
|         queryForm.value.versions = ''; | ||||
|       } | ||||
|     } | ||||
|   } catch (error) { | ||||
|     console.log(error); | ||||
|   } | ||||
| const open = (rows: any, type: string) => { | ||||
|   dialogVisible.value = true; | ||||
|   console.log(rows, type); | ||||
|   row.value = rows; | ||||
|   planType.value = type; | ||||
| }; | ||||
| //选择版本号 | ||||
| const changeVersions = () => { | ||||
|   getSheetName(); | ||||
| const closeDialog = () => { | ||||
|   dialogVisible.value = false; | ||||
|   form.value.costEstimationFile = ''; | ||||
|   emit('success'); | ||||
| }; | ||||
|  | ||||
| //选择表名 | ||||
| const changeSheet = () => { | ||||
|   getTableData(); | ||||
| }; | ||||
|  | ||||
| //获取表名 | ||||
| const getSheetName = async () => { | ||||
|   try { | ||||
|     const params = { | ||||
|       projectId: currentProject.value?.id | ||||
|       // versions: queryForm.value.versions | ||||
|     }; | ||||
|     const res = await sheetList(params); | ||||
|     if (res.code == 200) { | ||||
|       sheets.value = res.data; | ||||
|       if (res.data.length > 0) { | ||||
|         queryForm.value.sheet = res.data[0]; | ||||
|       } else { | ||||
|         queryForm.value.sheet = ''; | ||||
|       } | ||||
|       getTableData(); | ||||
|     } | ||||
|   } catch (error) {} | ||||
| }; | ||||
| //获取表格 | ||||
| const getTableData = async () => { | ||||
|   loading.value = true; | ||||
|   const params = { | ||||
|     projectId: currentProject.value?.id, | ||||
|     sheet: queryForm.value.sheet, | ||||
|     type: props.type | ||||
|   }; | ||||
|   const res = await getTreeLimit(params); | ||||
|   loading.value = false; | ||||
|   if (res.code == 200) { | ||||
|     tableData.value = [res.data[0]]; | ||||
|   } | ||||
|   console.log(loading.value); | ||||
| }; | ||||
| //修改单价 | ||||
| const handleSave = (row: any) => { | ||||
|   try { | ||||
|     if (!row.unitPrice) { | ||||
| const submitForm = () => { | ||||
|   fileUploadRef.value.submitUpload().then((res) => { | ||||
|     if (res == 'noFile') { | ||||
|       ElMessage({ | ||||
|         message: '请输入单价', | ||||
|         message: '请上传招标文件', | ||||
|         type: 'warning' | ||||
|       }); | ||||
|       return; | ||||
|     } | ||||
|     loading.value = true; | ||||
|     biddingLimitListUpdate(row).then((res) => { | ||||
|       if (res.code == 200) { | ||||
|         ElMessage({ | ||||
|           message: '修改成功', | ||||
|           type: 'success' | ||||
|         }); | ||||
|         getTableData(); | ||||
|       } | ||||
|     }); | ||||
|   } catch (error) { | ||||
|     ElMessage({ | ||||
|       message: '修改失败', | ||||
|       type: 'error' | ||||
|     }); | ||||
|   } | ||||
| }; | ||||
| const tableRef = ref<any>(); | ||||
|  | ||||
| const toggleExpandAll = () => { | ||||
|   isExpandAll.value = !isExpandAll.value; | ||||
|   console.log(isExpandAll.value); | ||||
|  | ||||
|   tableData.value.forEach((row) => { | ||||
|     tableRef.value.toggleRowExpansion(row, isExpandAll.value); | ||||
|     dialogVisible.value = false; | ||||
|     emit('success'); | ||||
|   }); | ||||
| }; | ||||
| //导入 | ||||
| const importExcel = (options: any): any => { | ||||
|   let formData = new FormData(); | ||||
|   formData.append('file', options.file); | ||||
|   loading.value = true; | ||||
|   BiddingImportExcelFile({ projectId: currentProject.value?.id }, formData) | ||||
|     .then((res) => { | ||||
|       const { code } = res; | ||||
|       if (code == 200) { | ||||
|         proxy.$modal.msgSuccess(res.msg || '导入成功'); | ||||
|         getTableData(); | ||||
|       } | ||||
|     }) | ||||
|     .catch((err) => {}) | ||||
|     .finally(() => { | ||||
|       loading.value = false; | ||||
|     }); | ||||
| }; | ||||
| //监听项目id刷新数据 | ||||
| const listeningProject = watch( | ||||
|   () => currentProject.value?.id, | ||||
|   (nid, oid) => { | ||||
|     getVersionNums(); | ||||
|   } | ||||
| ); | ||||
| const handleExport = () => { | ||||
|   proxy?.download( | ||||
|     '/bidding/biddingLimitList/export', | ||||
|     { | ||||
|       projectId: currentProject.value?.id, | ||||
|       sheet: queryForm.value.sheet | ||||
|     }, | ||||
|     `限价一览表${queryForm.value.sheet}.xlsx` | ||||
|   ); | ||||
| }; | ||||
| onUnmounted(() => { | ||||
|   listeningProject(); | ||||
| }); | ||||
| onMounted(() => { | ||||
|   getSheetName(); | ||||
| defineExpose({ | ||||
|   open | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <style scoped></style> | ||||
| <style scoped lang="scss"></style> | ||||
|  | ||||
							
								
								
									
										99
									
								
								src/views/tender/plan/comm/winTheBid.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								src/views/tender/plan/comm/winTheBid.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,99 @@ | ||||
| <template> | ||||
|   <el-dialog v-model="dialogVisible" title="中标文件" width="500" draggable> | ||||
|     <el-form ref="ruleFormRef" style="max-width: 600px" :model="form" :rules="rules" label-width="auto"> | ||||
|       <el-form-item label="中标单位" prop="winningBidder"> | ||||
|         <el-select v-model="form.winningBidder" filterable placeholder="请选择单位" style="width: 240px"> | ||||
|           <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value" /> | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="招标文件" prop="name"> | ||||
|         <file-upload | ||||
|           v-model="form.costEstimationFile" | ||||
|           :fileSize="100" | ||||
|           :auto-upload="false" | ||||
|           uploadUrl="/tender/biddingPlan/uploadBiddingDocuments" | ||||
|           method="put" | ||||
|           ref="fileUploadRef" | ||||
|           :data="{ | ||||
|             projectId: currentProject?.id, | ||||
|             type: planType, | ||||
|             fileType: '0', | ||||
|             bidStatus: '0', | ||||
|             id: row.id, | ||||
|             winningBidderId: form.winningBidder | ||||
|           }" | ||||
|           showFileList | ||||
|         /> | ||||
|       </el-form-item> | ||||
|     </el-form> | ||||
|     <template #footer> | ||||
|       <div class="dialog-footer"> | ||||
|         <el-button @click="closeDialog()"> 取消 </el-button> | ||||
|         <el-button type="primary" @click="submitForm()">确定</el-button> | ||||
|       </div> | ||||
|     </template> | ||||
|   </el-dialog> | ||||
| </template> | ||||
| <script setup lang="ts"> | ||||
| import { getUnitList } from '@/api/tender/index'; | ||||
| import { useUserStoreHook } from '@/store/modules/user'; | ||||
| const userStore = useUserStoreHook(); | ||||
| const currentProject = computed(() => userStore.selectedProject); | ||||
| const dialogVisible = ref(false); | ||||
| const row = ref<any>(); | ||||
| const planType = ref<any>(''); | ||||
| const fileUploadRef = ref<any>(); | ||||
| const ruleForm = ref<any>(); | ||||
| const options = ref<any>([]); | ||||
| const rules = ref({ | ||||
|   costEstimationFile: [{ required: true, message: '请上传招标文件', trigger: ['blur'] }] | ||||
| }); | ||||
| const emit = defineEmits(['success']); | ||||
| const form = ref({ | ||||
|   costEstimationFile: '', | ||||
|   winningBidder: '' | ||||
| }); | ||||
| const open = (rows: any, type: string) => { | ||||
|   dialogVisible.value = true; | ||||
|   console.log(rows, type); | ||||
|   row.value = rows; | ||||
|   planType.value = type; | ||||
|   getUnitListData(); | ||||
| }; | ||||
| const getUnitListData = async () => { | ||||
|   let res = await getUnitList({ | ||||
|     projectId: currentProject.value?.id | ||||
|   }); | ||||
|   if (res.code == 200) { | ||||
|     options.value = res.data.map((item: any) => { | ||||
|       return { | ||||
|         label: item.supplierName, | ||||
|         value: item.id | ||||
|       }; | ||||
|     }); | ||||
|   } | ||||
|   console.log(res); | ||||
| }; | ||||
| const closeDialog = () => { | ||||
|   dialogVisible.value = false; | ||||
|   form.value.winningBidder = ''; | ||||
|   emit('success'); | ||||
| }; | ||||
| const submitForm = () => { | ||||
|   fileUploadRef.value.submitUpload().then((res) => { | ||||
|     if (res == 'noFile') { | ||||
|       ElMessage({ | ||||
|         message: '请上传招标文件', | ||||
|         type: 'warning' | ||||
|       }); | ||||
|       return; | ||||
|     } | ||||
|     closeDialog(); | ||||
|     emit('success'); | ||||
|   }); | ||||
| }; | ||||
| defineExpose({ | ||||
|   open | ||||
| }); | ||||
| </script> | ||||
| <style scoped lang="scss"></style> | ||||
| @ -189,7 +189,8 @@ | ||||
|             <el-table-column prop="name" label="工程或费用名称" /> | ||||
|             <el-table-column prop="unit" label="单位" /> | ||||
|             <!-- <el-table-column prop="quantity" label="数量" /> --> | ||||
|             <el-table-column prop="selectNum" label="选择数量" align="center"> | ||||
|             <el-table-column prop="quantity" label="计划量" align="center" /> | ||||
|             <el-table-column prop="selectNum" label="设计量" align="center"> | ||||
|               <template #default="scope"> | ||||
|                 <el-input-number | ||||
|                   :model-value="scope.row.selectNum" | ||||
| @ -203,16 +204,36 @@ | ||||
|                   :step="1" | ||||
|                   :controls="false" | ||||
|                   :max="Math.floor(scope.row.quantity)" | ||||
|                   v-if="scope.row.quantity && scope.row.quantity != 0" | ||||
|                   v-if="scope.row.quantity && scope.row.quantity != 0 && scope.row.unitPrice" | ||||
|                 /> | ||||
|               </template> | ||||
|             </el-table-column> | ||||
|             <el-table-column prop="unitPrice" label="单价" align="center" /> | ||||
|             <!-- <el-table-column prop="price" label="总价" align="center"> | ||||
|  | ||||
|             <el-table-column prop="useQuantity" label="剩余量" align="center"> | ||||
|               <template #default="scope"> | ||||
|                 {{ scope.row.price }} | ||||
|                 {{ | ||||
|                   (scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0) == 0 | ||||
|                     ? '' | ||||
|                     : (scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0) | ||||
|                 }} | ||||
|               </template> | ||||
|             </el-table-column> --> | ||||
|             </el-table-column> | ||||
|  | ||||
|             <el-table-column prop="unitPrice" label="单价" align="center" /> | ||||
|             <el-table-column prop="price" label="总价" align="center"> | ||||
|               <template #default="scope"> | ||||
|                 {{ | ||||
|                   ((scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0)) * | ||||
|                     Number(scope.row.unitPrice) == | ||||
|                   0 | ||||
|                     ? '' | ||||
|                     : ( | ||||
|                         ((scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0)) * | ||||
|                         Number(scope.row.unitPrice) | ||||
|                       ).toFixed(2) | ||||
|                 }} | ||||
|               </template> | ||||
|             </el-table-column> | ||||
|           </el-table> | ||||
|         </el-col> | ||||
|       </el-row> | ||||
| @ -266,6 +287,9 @@ import { useUserStoreHook } from '@/store/modules/user'; | ||||
| import { getDicts } from '@/api/system/dict/data'; | ||||
| import { Plus } from '@element-plus/icons-vue'; | ||||
| import { FormInstance } from 'element-plus'; | ||||
| import winTheBid from './comm/winTheBid.vue'; | ||||
| import information from './comm/planPage.vue'; | ||||
|  | ||||
| import { | ||||
|   sheetList, | ||||
|   tenderPlanList, | ||||
| @ -279,7 +303,6 @@ import { | ||||
|   delBiddView, | ||||
|   editStatus | ||||
| } from '@/api/tender/index'; | ||||
| import { it } from 'element-plus/es/locale/index.mjs'; | ||||
|  | ||||
| const userStore = useUserStoreHook(); | ||||
| const currentProject = computed(() => userStore.selectedProject); | ||||
|  | ||||
		Reference in New Issue
	
	Block a user