|  |  | @ -6,23 +6,25 @@ | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |             <GuipDialog :dialogVisible="dialogVisible" :title="dialogTitle" :show-close-button="false" | 
			
		
	
		
			
				
					|  |  |  |                 :show-cancel-button="showCancelButton" @confirm="handleConfirm" @cancel="handleCancel" | 
			
		
	
		
			
				
					|  |  |  |                         @close="handleClose" | 
			
		
	
		
			
				
					|  |  |  |                         @dialogVisibleChange="dialogVisibleChange"> | 
			
		
	
		
			
				
					|  |  |  |                 @close="handleClose" @dialogVisibleChange="dialogVisibleChange"> | 
			
		
	
		
			
				
					|  |  |  |                 <el-form :model="form" class="el-row demo-ruleForm" ref="formRef"> | 
			
		
	
		
			
				
					|  |  |  |                     <el-form-item label="检测类型" prop="type"> | 
			
		
	
		
			
				
					|  |  |  |                         <GuipSelect v-model="form.type" :options="type2nameOptions"/> | 
			
		
	
		
			
				
					|  |  |  |                     </el-form-item> | 
			
		
	
		
			
				
					|  |  |  |                     <el-form-item label="采购单价" prop="type" label-width="73px"> | 
			
		
	
		
			
				
					|  |  |  |                     <!-- 组件已经封装了  el-form-item  没有特殊需求,直接在组件上传prop label 就可以实现效果--> | 
			
		
	
		
			
				
					|  |  |  |                     <GuipSelect v-model="form.type" prop="type" label="检测类型" :options="type2nameOptions" /> | 
			
		
	
		
			
				
					|  |  |  |                     <el-form-item label="采购单价" label-width="73px"> | 
			
		
	
		
			
				
					|  |  |  |                         <div style="display: flex; align-items: center; gap: 8px; width: 100%;"> | 
			
		
	
		
			
				
					|  |  |  |                             <GuipInput v-model="form.unit_price" style="flex: 1;"/> | 
			
		
	
		
			
				
					|  |  |  |                             <GuipInput v-model="form.unit_price" prop="unit_price" /> | 
			
		
	
		
			
				
					|  |  |  |                             <span>元 /</span> | 
			
		
	
		
			
				
					|  |  |  |                             <GuipInput v-model="form.unit_num" style="flex: 1;"/> | 
			
		
	
		
			
				
					|  |  |  |                             <GuipInput v-model="form.unit_num" prop="unit_num" style="flex: 1;" /> | 
			
		
	
		
			
				
					|  |  |  |                             <span>字(篇/页)</span> | 
			
		
	
		
			
				
					|  |  |  |                         </div> | 
			
		
	
		
			
				
					|  |  |  |                     </el-form-item> | 
			
		
	
		
			
				
					|  |  |  |                     <!-- <div class="flex-between" style="gap: 8px;"> | 
			
		
	
		
			
				
					|  |  |  |                         <GuipInput label="采购单价" v-model="form.unit_price" prop="unit_price" unit="元"/> | 
			
		
	
		
			
				
					|  |  |  |                         <GuipInput v-model="form.unit_num" prop="unit_num" style="flex: 1;" unit="字(篇/页)"/> | 
			
		
	
		
			
				
					|  |  |  |                     </div> --> | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                     <template v-if="type != 'purchase'"> | 
			
		
	
		
			
				
					|  |  |  |                         <el-form-item label="阶段成本" prop="type" label-width="73px"> | 
			
		
	
		
			
				
					|  |  |  |                         <el-form-item label="阶段成本" prop="cost" label-width="73px"> | 
			
		
	
		
			
				
					|  |  |  |                             <div style="display: flex; align-items: center; gap: 8px; width: 100%;"> | 
			
		
	
		
			
				
					|  |  |  |                                 <GuipInput v-model="form.cost" style="flex: 1;" /> | 
			
		
	
		
			
				
					|  |  |  |                                 <span>元</span> | 
			
		
	
	
		
			
				
					|  |  | @ -30,8 +32,7 @@ | 
			
		
	
		
			
				
					|  |  |  |                         </el-form-item> | 
			
		
	
		
			
				
					|  |  |  |                         <el-form-item label="起止日期" prop="date" label-width="73px"> | 
			
		
	
		
			
				
					|  |  |  |                             <el-date-picker v-model="form.date" type="daterange" range-separator="至" | 
			
		
	
		
			
				
					|  |  |  |                                             start-placeholder="开始日期" | 
			
		
	
		
			
				
					|  |  |  |                                             end-placeholder="结束日期" value-format="yyyy-MM-dd" | 
			
		
	
		
			
				
					|  |  |  |                                 start-placeholder="开始日期" end-placeholder="结束日期" value-format="yyyy-MM-dd" | 
			
		
	
		
			
				
					|  |  |  |                                 style="width: 100%;"> | 
			
		
	
		
			
				
					|  |  |  |                             </el-date-picker> | 
			
		
	
		
			
				
					|  |  |  |                         </el-form-item> | 
			
		
	
	
		
			
				
					|  |  | @ -100,8 +101,7 @@ | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                         <el-table-column label="操作" width="200"> | 
			
		
	
		
			
				
					|  |  |  |                             <template slot-scope="scope"> | 
			
		
	
		
			
				
					|  |  |  |                                 <a @click="editStagePurchase(scope.row)" | 
			
		
	
		
			
				
					|  |  |  |                                    style="color: #006aff;cursor: pointer;">编辑</a> | 
			
		
	
		
			
				
					|  |  |  |                                 <a @click="editStagePurchase(scope.row)" style="color: #006aff;cursor: pointer;">编辑</a> | 
			
		
	
		
			
				
					|  |  |  |                                 <a v-if="scope.row.is_sync == 0" @click="syncStagePurchase(scope.row)" | 
			
		
	
		
			
				
					|  |  |  |                                     style="color: #006aff;margin-left: 20px;cursor: pointer;">同步</a> | 
			
		
	
		
			
				
					|  |  |  |                             </template> | 
			
		
	
	
		
			
				
					|  |  | @ -109,13 +109,8 @@ | 
			
		
	
		
			
				
					|  |  |  |                     </template> | 
			
		
	
		
			
				
					|  |  |  |                 </el-table> | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                 <el-pagination background | 
			
		
	
		
			
				
					|  |  |  |                                @size-change='handleSizeChange' | 
			
		
	
		
			
				
					|  |  |  |                                @current-change='handleCurrentChange' | 
			
		
	
		
			
				
					|  |  |  |                                :current-page="currentPage" | 
			
		
	
		
			
				
					|  |  |  |                                :page-size=pageSize | 
			
		
	
		
			
				
					|  |  |  |                                layout="prev, pager, next,jumper" | 
			
		
	
		
			
				
					|  |  |  |                                :total="total"> | 
			
		
	
		
			
				
					|  |  |  |                 <el-pagination background @size-change='handleSizeChange' @current-change='handleCurrentChange' | 
			
		
	
		
			
				
					|  |  |  |                     :current-page="currentPage" :page-size=pageSize layout="prev, pager, next,jumper" :total="total"> | 
			
		
	
		
			
				
					|  |  |  |                 </el-pagination> | 
			
		
	
		
			
				
					|  |  |  |             </el-form> | 
			
		
	
		
			
				
					|  |  |  |         </div> | 
			
		
	
	
		
			
				
					|  |  | @ -150,8 +145,9 @@ export default { | 
			
		
	
		
			
				
					|  |  |  |     }, | 
			
		
	
		
			
				
					|  |  |  |     data() { | 
			
		
	
		
			
				
					|  |  |  |         return { | 
			
		
	
		
			
				
					|  |  |  |             test: '00000', | 
			
		
	
		
			
				
					|  |  |  |             id: 0, | 
			
		
	
		
			
				
					|  |  |  |             chktype: 0, | 
			
		
	
		
			
				
					|  |  |  |             chktype: '0', | 
			
		
	
		
			
				
					|  |  |  |             currentPage: 1,    //当前页 | 
			
		
	
		
			
				
					|  |  |  |             pageSize: 20,   //每页的容量 | 
			
		
	
		
			
				
					|  |  |  |             total: 0,   //列表总数 | 
			
		
	
	
		
			
				
					|  |  | @ -182,7 +178,7 @@ export default { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |             return Object.entries(this.type2name).map(([value, label]) => ({ | 
			
		
	
		
			
				
					|  |  |  |                 label, | 
			
		
	
		
			
				
					|  |  |  |                 value: Number(value)  // 如果你需要 value 是数字 | 
			
		
	
		
			
				
					|  |  |  |                 value: String(value)  // 如果你需要 value 是数字 | 
			
		
	
		
			
				
					|  |  |  |             })); | 
			
		
	
		
			
				
					|  |  |  |         }, | 
			
		
	
		
			
				
					|  |  |  |         type2filterOptions() { | 
			
		
	
	
		
			
				
					|  |  | @ -190,10 +186,10 @@ export default { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |             let options = Object.entries(this.type2name).map(([value, label]) => ({ | 
			
		
	
		
			
				
					|  |  |  |                 label, | 
			
		
	
		
			
				
					|  |  |  |                 value: Number(value)  // 如果你需要 value 是数字 | 
			
		
	
		
			
				
					|  |  |  |                 value: String(value)  // 如果你需要 value 是数字 | 
			
		
	
		
			
				
					|  |  |  |             })); | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |             return [{ label: '全部检测类型', value: '' }, ...options]; | 
			
		
	
		
			
				
					|  |  |  |             return [{ label: '全部检测类型', value: '0' }, ...options]; | 
			
		
	
		
			
				
					|  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |     }, | 
			
		
	
		
			
				
					|  |  |  |     watch: { | 
			
		
	
	
		
			
				
					|  |  | @ -266,45 +262,41 @@ export default { | 
			
		
	
		
			
				
					|  |  |  |             this.init() | 
			
		
	
		
			
				
					|  |  |  |         }, | 
			
		
	
		
			
				
					|  |  |  |         openDialog() { | 
			
		
	
		
			
				
					|  |  |  |             this.form = { | 
			
		
	
		
			
				
					|  |  |  |                 id: '', | 
			
		
	
		
			
				
					|  |  |  |                 type: '', | 
			
		
	
		
			
				
					|  |  |  |                 unit_price: '', | 
			
		
	
		
			
				
					|  |  |  |                 unit_num: '', | 
			
		
	
		
			
				
					|  |  |  |                 cost: '', | 
			
		
	
		
			
				
					|  |  |  |                 date: '', | 
			
		
	
		
			
				
					|  |  |  |                 start_date: '', | 
			
		
	
		
			
				
					|  |  |  |                 end_date: '', | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |             this.dialogVisible = true; | 
			
		
	
		
			
				
					|  |  |  |             // 重置数据 | 
			
		
	
		
			
				
					|  |  |  |             this.$nextTick(() => { | 
			
		
	
		
			
				
					|  |  |  |                 this.$refs.formRef.resetFields(); | 
			
		
	
		
			
				
					|  |  |  |             }); | 
			
		
	
		
			
				
					|  |  |  |         },  // 确认按钮事件 | 
			
		
	
		
			
				
					|  |  |  |         handleConfirm() { | 
			
		
	
		
			
				
					|  |  |  |             const that = this | 
			
		
	
		
			
				
					|  |  |  |             if (!that.form.type) { | 
			
		
	
		
			
				
					|  |  |  |             // 避免打开弹框,重置数据时,新添加的数据被清空,重新拷贝一份  或者 添加数据后,拉取新数据 | 
			
		
	
		
			
				
					|  |  |  |             let form = JSON.parse(JSON.stringify(that.form)) | 
			
		
	
		
			
				
					|  |  |  |             if (!form.type) { | 
			
		
	
		
			
				
					|  |  |  |                 this.$message.warning('请选择检测类型'); | 
			
		
	
		
			
				
					|  |  |  |                 return | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |             if (that.type == 'purchase') { | 
			
		
	
		
			
				
					|  |  |  |                 if (!that.form.unit_price || !that.form.unit_num) { | 
			
		
	
		
			
				
					|  |  |  |                 if (!form.unit_price || !form.unit_num) { | 
			
		
	
		
			
				
					|  |  |  |                     this.$message.warning('请输入采购单价'); | 
			
		
	
		
			
				
					|  |  |  |                     return | 
			
		
	
		
			
				
					|  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                 this.$http('POST', '/supernew/ajax_save_purchase', { | 
			
		
	
		
			
				
					|  |  |  |                     id: that.form.id, | 
			
		
	
		
			
				
					|  |  |  |                     type: that.form.type, | 
			
		
	
		
			
				
					|  |  |  |                     unit_price: that.form.unit_price, | 
			
		
	
		
			
				
					|  |  |  |                     unit_num: that.form.unit_num, | 
			
		
	
		
			
				
					|  |  |  |                     id: form.id, | 
			
		
	
		
			
				
					|  |  |  |                     type: form.type, | 
			
		
	
		
			
				
					|  |  |  |                     unit_price: form.unit_price, | 
			
		
	
		
			
				
					|  |  |  |                     unit_num: form.unit_num, | 
			
		
	
		
			
				
					|  |  |  |                 }).then(response => { | 
			
		
	
		
			
				
					|  |  |  |                     this.$nextTick(() => { | 
			
		
	
		
			
				
					|  |  |  |                         if (!response.status) { | 
			
		
	
		
			
				
					|  |  |  |                             this.$message.warning(response.info); | 
			
		
	
		
			
				
					|  |  |  |                         } else { | 
			
		
	
		
			
				
					|  |  |  |                             if(that.form.id > 0){ | 
			
		
	
		
			
				
					|  |  |  |                                 that.$set(this.tableData, this.tableData.findIndex(item => item.id === that.form.id), {...that.form}); | 
			
		
	
		
			
				
					|  |  |  |                             if (form.id > 0) { | 
			
		
	
		
			
				
					|  |  |  |                                 that.$set(this.tableData, this.tableData.findIndex(item => item.id === form.id), { ...form }); | 
			
		
	
		
			
				
					|  |  |  |                             } else { | 
			
		
	
		
			
				
					|  |  |  |                                 that.form.id = response.data | 
			
		
	
		
			
				
					|  |  |  |                                 that.tableData.unshift(that.form); | 
			
		
	
		
			
				
					|  |  |  |                                 form.id = response.data | 
			
		
	
		
			
				
					|  |  |  |                                 that.tableData.unshift(form); | 
			
		
	
		
			
				
					|  |  |  |                             } | 
			
		
	
		
			
				
					|  |  |  |                         } | 
			
		
	
		
			
				
					|  |  |  |                         this.dialogVisible = false; | 
			
		
	
	
		
			
				
					|  |  | @ -314,35 +306,35 @@ export default { | 
			
		
	
		
			
				
					|  |  |  |                     this.dialogVisible = false; | 
			
		
	
		
			
				
					|  |  |  |                 }) | 
			
		
	
		
			
				
					|  |  |  |             } else { | 
			
		
	
		
			
				
					|  |  |  |                 if ((!that.form.unit_price || !that.form.unit_num) && !that.form.cost) { | 
			
		
	
		
			
				
					|  |  |  |                 if ((!form.unit_price || !form.unit_num) && !form.cost) { | 
			
		
	
		
			
				
					|  |  |  |                     this.$message.warning('请输入采购单价或阶段成本'); | 
			
		
	
		
			
				
					|  |  |  |                     return | 
			
		
	
		
			
				
					|  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                 if (!that.form.start_date || !that.form.end_date) { | 
			
		
	
		
			
				
					|  |  |  |                 if (!form.start_date || !form.end_date) { | 
			
		
	
		
			
				
					|  |  |  |                     this.$message.warning('请选择起止日期'); | 
			
		
	
		
			
				
					|  |  |  |                     return | 
			
		
	
		
			
				
					|  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                 this.$http('POST', '/supernew/ajax_save_stage_purchase', { | 
			
		
	
		
			
				
					|  |  |  |                     id: that.form.id, | 
			
		
	
		
			
				
					|  |  |  |                     type: that.form.type, | 
			
		
	
		
			
				
					|  |  |  |                     unit_price: that.form.unit_price, | 
			
		
	
		
			
				
					|  |  |  |                     unit_num: that.form.unit_num, | 
			
		
	
		
			
				
					|  |  |  |                     cost: that.form.cost, | 
			
		
	
		
			
				
					|  |  |  |                     sdate: that.form.start_date, | 
			
		
	
		
			
				
					|  |  |  |                     edate: that.form.end_date, | 
			
		
	
		
			
				
					|  |  |  |                     id: form.id, | 
			
		
	
		
			
				
					|  |  |  |                     type: form.type, | 
			
		
	
		
			
				
					|  |  |  |                     unit_price: form.unit_price, | 
			
		
	
		
			
				
					|  |  |  |                     unit_num: form.unit_num, | 
			
		
	
		
			
				
					|  |  |  |                     cost: form.cost, | 
			
		
	
		
			
				
					|  |  |  |                     sdate: form.start_date, | 
			
		
	
		
			
				
					|  |  |  |                     edate: form.end_date, | 
			
		
	
		
			
				
					|  |  |  |                 }).then(response => { | 
			
		
	
		
			
				
					|  |  |  |                     this.$nextTick(() => { | 
			
		
	
		
			
				
					|  |  |  |                         if (!response.status) { | 
			
		
	
		
			
				
					|  |  |  |                             this.$message.warning(response.info); | 
			
		
	
		
			
				
					|  |  |  |                         } else { | 
			
		
	
		
			
				
					|  |  |  |                             if(that.form.id > 0){ | 
			
		
	
		
			
				
					|  |  |  |                                 that.$set(this.tableData, this.tableData.findIndex(item => item.id === that.form.id), {...that.form}); | 
			
		
	
		
			
				
					|  |  |  |                             if (form.id > 0) { | 
			
		
	
		
			
				
					|  |  |  |                                 that.$set(this.tableData, this.tableData.findIndex(item => item.id === form.id), { ...form }); | 
			
		
	
		
			
				
					|  |  |  |                             } else { | 
			
		
	
		
			
				
					|  |  |  |                                 that.form.id = response.data | 
			
		
	
		
			
				
					|  |  |  |                                 that.form.is_sync = 0 | 
			
		
	
		
			
				
					|  |  |  |                                 that.tableData.unshift(that.form); | 
			
		
	
		
			
				
					|  |  |  |                                 form.id = response.data | 
			
		
	
		
			
				
					|  |  |  |                                 form.is_sync = 0 | 
			
		
	
		
			
				
					|  |  |  |                                 that.tableData.unshift(form); | 
			
		
	
		
			
				
					|  |  |  |                             } | 
			
		
	
		
			
				
					|  |  |  |                         } | 
			
		
	
		
			
				
					|  |  |  |                         this.dialogVisible = false; | 
			
		
	
	
		
			
				
					|  |  | @ -374,13 +366,20 @@ export default { | 
			
		
	
		
			
				
					|  |  |  |             return `${Y}-${M}-${D}`; | 
			
		
	
		
			
				
					|  |  |  |         }, | 
			
		
	
		
			
				
					|  |  |  |         editPurchase(row) { | 
			
		
	
		
			
				
					|  |  |  |             this.form = {...row}; | 
			
		
	
		
			
				
					|  |  |  |             this.dialogVisible = true; | 
			
		
	
		
			
				
					|  |  |  |             this.$nextTick(() => { | 
			
		
	
		
			
				
					|  |  |  |                 this.form = { ...row }; | 
			
		
	
		
			
				
					|  |  |  |                 // 如果需要强制更新视图 | 
			
		
	
		
			
				
					|  |  |  |                 this.$forceUpdate(); | 
			
		
	
		
			
				
					|  |  |  |             }) | 
			
		
	
		
			
				
					|  |  |  |         }, | 
			
		
	
		
			
				
					|  |  |  |         editStagePurchase(row) { | 
			
		
	
		
			
				
					|  |  |  |             this.dialogVisible = true; | 
			
		
	
		
			
				
					|  |  |  |             this.$nextTick(()=>{ | 
			
		
	
		
			
				
					|  |  |  |                 this.form = { ...row }; | 
			
		
	
		
			
				
					|  |  |  |                 this.form.date = [row.start_date, row.end_date] | 
			
		
	
		
			
				
					|  |  |  |             this.dialogVisible = true; | 
			
		
	
		
			
				
					|  |  |  |                 this.$forceUpdate(); | 
			
		
	
		
			
				
					|  |  |  |             }) | 
			
		
	
		
			
				
					|  |  |  |         }, | 
			
		
	
		
			
				
					|  |  |  |         syncStagePurchase(row) { | 
			
		
	
		
			
				
					|  |  |  |             this.$http('POST', '/supernew/ajax_sync_order_cost', { | 
			
		
	
	
		
			
				
					|  |  | 
 |