Compare commits
	
		
			No commits in common. "9ec6e7a515a8c1e2d57f5a187596361505a0ab5f" and "9fd0101266519c06cf9ed6b33eda84b40dd587f4" have entirely different histories.
		
	
	
		
			9ec6e7a515
			...
			9fd0101266
		
	
		
| @ -1,20 +1 @@ | ||||
| import request from '@/utils/request' | ||||
| 
 | ||||
| const preUrl = "/repair/so" | ||||
| 
 | ||||
| // 采购单\领料单 新增
 | ||||
| export function createRepairSo(data){ | ||||
|   return request({ | ||||
|     url: preUrl + "/create", | ||||
|     method: "post", | ||||
|     data | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| export function getRepairSoPage(params){ | ||||
|   return request({ | ||||
|     url: preUrl + "/page", | ||||
|     method: "get", | ||||
|     params | ||||
|   }) | ||||
| } | ||||
|  | ||||
| @ -2,17 +2,17 @@ | ||||
|   <el-select v-model="partSelected" ref="selectTable" clearable style="width: 45rem"> | ||||
|     <el-option style="display: none" v-for="part in partList" :key="part.id" :label="part.name" :value="part.id"/> | ||||
|     <el-table :data="partList" style="width: 100%" @row-click="handleSelectionChange"> | ||||
|       <el-table-column label="序号" align="center" width="80"> | ||||
|       <el-table-column label="序号" align="center"> | ||||
|         <template scope="scope"> | ||||
|           <span>{{ scope.$index + 1 }}</span> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column label="商品名称" prop="name" width="120"/> | ||||
|       <el-table-column label="规格" prop="model" width="120"/> | ||||
|       <el-table-column label="商品编码" prop="code" width="120"/> | ||||
|       <el-table-column label="可用库存" prop="stock" width="80"/> | ||||
|       <el-table-column label="成本" prop="price" width="80"/> | ||||
|       <el-table-column label="仓库" prop="warehouse" width="80"/> | ||||
|       <el-table-column label="商品名称" prop="name" /> | ||||
|       <el-table-column label="规格" prop="name" /> | ||||
|       <el-table-column label="商品编码" prop="name" /> | ||||
|       <el-table-column label="可用库存" prop="name" /> | ||||
|       <el-table-column label="成本" prop="name" /> | ||||
|       <el-table-column label="仓库" prop="name" /> | ||||
|     </el-table> | ||||
|     <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" | ||||
|     /> | ||||
| @ -26,48 +26,8 @@ export default { | ||||
|     return{ | ||||
|       partSelected: null, | ||||
|       partList: [ | ||||
|         { | ||||
|           id: 1, | ||||
|           tenantId: 1, | ||||
|           barCode: "12344564632463", | ||||
|           code: "12312312", | ||||
|           name: "测试1", | ||||
|           model: "12321", | ||||
|           price: "100", | ||||
|           type: "不知道", | ||||
|           unit: "个", | ||||
|           warehouse: "d1", | ||||
|           miniStock: 100, | ||||
|           maxStock: 100, | ||||
|           stock: 20, | ||||
|           img: '', | ||||
|           attribute: "123213123", | ||||
|           corpId: 1, | ||||
|           coverImage: '', | ||||
|           carModel: "大车", | ||||
|           remark: "没有", | ||||
|         }, | ||||
|         { | ||||
|           id: 2, | ||||
|           tenantId: 1, | ||||
|           barCode: "12344564632463", | ||||
|           code: "12312312", | ||||
|           name: "测试2", | ||||
|           model: "12321", | ||||
|           price: "10", | ||||
|           type: "不知道", | ||||
|           unit: "个", | ||||
|           warehouse: "d2", | ||||
|           miniStock: 10, | ||||
|           maxStock: 10, | ||||
|           stock: 5, | ||||
|           img: '', | ||||
|           attribute: "123213123", | ||||
|           corpId: 1, | ||||
|           coverImage: '', | ||||
|           carModel: "大车", | ||||
|           remark: "没有", | ||||
|         } | ||||
|         {id: 1, name: '张胜男', age:20, gender: 1}, | ||||
|         {id: 2, name: '张胜妇', age:20, gender: 1} | ||||
|       ], | ||||
|       queryParams:{ | ||||
|         pageNo: 1, | ||||
|  | ||||
| @ -10,12 +10,6 @@ import {getStaffList} from "@/api/company/staff"; | ||||
| 
 | ||||
| export default { | ||||
|   name: "StaffChoose", | ||||
|   props:{ | ||||
|     value: { | ||||
|       type: Object, | ||||
|       defaultValue: null | ||||
|     } | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       staffList: [], | ||||
| @ -25,14 +19,7 @@ export default { | ||||
|   watch:{ | ||||
|     staffSelected(val) { | ||||
|       const staff = this.staffList.find(item => item.id === val); | ||||
|       this.$emit("input", staff); | ||||
|     }, | ||||
|     value(newVal){ | ||||
|       if (newVal){ | ||||
|         this.staffSelected = newVal.id | ||||
|       }else { | ||||
|         this.staffSelected = null | ||||
|       } | ||||
|       this.$emit("selected", staff); | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|  | ||||
| @ -11,12 +11,6 @@ import {getBaseSupplierList} from "@/api/repair/supplier"; | ||||
| 
 | ||||
| export default { | ||||
|   name: "SupplierChoose", | ||||
|   props: { | ||||
|     value: { | ||||
|       type: Object, | ||||
|       defaultValue: null | ||||
|     } | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       supplierSelected: undefined, | ||||
| @ -25,15 +19,8 @@ export default { | ||||
|   }, | ||||
|   watch:{ | ||||
|     supplierSelected(val) { | ||||
|       const supplier = this.supplierList.find(item => item.id === val) | ||||
|       this.$emit("input", supplier); | ||||
|     }, | ||||
|     value(newVal) { | ||||
|       if (newVal) { | ||||
|         this.supplierSelected = newVal.id | ||||
|       } else { | ||||
|         this.supplierSelected = null | ||||
|       } | ||||
|       const supplier = this.supplierList.find(item => item.id === val); | ||||
|       this.$emit("selected", supplier); | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|  | ||||
| @ -51,8 +51,7 @@ export default { | ||||
|       return JSON.parse(JSON.stringify(result)) | ||||
|     }, | ||||
|     handleNodeClick(node){ | ||||
|       this.$emit("input", node.name) | ||||
|       this.$emit("change") | ||||
|       this.$emit("selected", node) | ||||
|       this.warehouseSelected = node.name | ||||
|       this.$refs.selectTree.blur() | ||||
|     } | ||||
|  | ||||
| @ -117,7 +117,6 @@ import SupplierChoose from "@/views/repair/Components/SupplierChoose.vue"; | ||||
| import CorpChoose from "@/views/repair/Components/CorpChoose.vue"; | ||||
| import StaffChoose from "@/views/repair/Components/StaffChoose.vue"; | ||||
| import {DICT_TYPE} from "@/utils/dict"; | ||||
| import {getRepairSoPage} from "@/api/repair/stockOperate/stockOperate"; | ||||
| 
 | ||||
| export default { | ||||
|   name: "SoIndex", | ||||
| @ -156,8 +155,7 @@ export default { | ||||
|         soStatus: null, | ||||
|         corpId: null, | ||||
|         userId: null, | ||||
|         userName: null, | ||||
|         soType: this.soByType ? "01" : "02" | ||||
|         userName: null | ||||
|       }, | ||||
|       showSearch: true, | ||||
|       list: [], | ||||
| @ -165,24 +163,9 @@ export default { | ||||
|       total: 0 | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|     this.pageSo(); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 分页 | ||||
|     async pageSo() { | ||||
|       try { | ||||
|         this.loading = true | ||||
|         const res = await getRepairSoPage(this.queryParams) | ||||
|         this.list = res.data.records | ||||
|         this.total = res.data.total | ||||
|       }finally { | ||||
|         this.loading = false | ||||
|       } | ||||
|     }, | ||||
|     // 搜索按钮 | ||||
|     handleQuery() { | ||||
|     }, | ||||
|     handleQuery(){}, | ||||
|     // 搜索重置 | ||||
|     resetQuery(){ | ||||
|       this.resetForm('queryForm') | ||||
|  | ||||
| @ -4,8 +4,8 @@ | ||||
|       <el-row :gutter="20"> | ||||
|         <el-col :span="24"> | ||||
|           <!-- 供应商 组件 --> | ||||
|           <el-form-item v-if="soByType" label="供应商" prop="supplier"> | ||||
|             <SupplierChoose v-model="formData.supplier"/> | ||||
|           <el-form-item v-if="soByType" label="供应商" prop="supplierId"> | ||||
|             <SupplierChoose @selected="getSupplier"/> | ||||
|           </el-form-item> | ||||
|           <!-- 日期 内嵌 --> | ||||
|           <el-form-item label="日期" prop="soTime"> | ||||
| @ -20,8 +20,8 @@ | ||||
|             <el-input disabled v-model="formData.soNo" style="width: 20rem"/> | ||||
|           </el-form-item> | ||||
|           <!-- 采购员/领料人 组件 --> | ||||
|           <el-form-item :label="staffRole" prop="user"> | ||||
|             <StaffChoose v-model="formData.user"/> | ||||
|           <el-form-item :label="staffRole" prop="userId"> | ||||
|             <StaffChoose @selected="getStaff"/> | ||||
|           </el-form-item> | ||||
|         </el-col> | ||||
|       </el-row> | ||||
| @ -36,25 +36,20 @@ | ||||
|       <!-- 商品表格 组件 --> | ||||
|       <el-row :gutter="20"> | ||||
|         <el-col :span="24"> | ||||
|           <SoTable @tableData="tableData" :part-list="partList" :so-by-type="soByType" @deleteItem="deleteItem"/> | ||||
|           <SoTable :part-list="partList" :so-by-type="soByType" @deleteItem="deleteItem"/> | ||||
|         </el-col> | ||||
|       </el-row> | ||||
|       <el-row :gutter="4" style="margin-top: 1rem"> | ||||
|         <el-col :span="6"> | ||||
|           <el-form-item label="应付金额" prop="totalPrice"> | ||||
|             <el-input disabled v-model="formData.totalPrice"/> | ||||
|           </el-form-item> | ||||
|         </el-col> | ||||
|       <el-row :gutter="2" style="margin-top: 1rem"> | ||||
|         <!-- 备注 --> | ||||
|         <el-col :span="12"> | ||||
|           <el-form-item label="备注" prop="remark"> | ||||
|             <el-input style="width: 40rem" v-model="formData.remark"/> | ||||
|           <el-form-item label="备注"> | ||||
|             <el-input style="width: 45rem"/> | ||||
|           </el-form-item> | ||||
|         </el-col> | ||||
|         <!-- 按钮操作 --> | ||||
|         <el-col :span="6" style="text-align: right"> | ||||
|           <el-button v-if="soByType" type="danger" @click="handleSubmit">结算</el-button> | ||||
|           <el-button v-else type="primary" @click="handleSubmit">确定</el-button> | ||||
|         <el-col :span="12" style="text-align: right"> | ||||
|           <el-button v-if="soByType" type="danger">结算</el-button> | ||||
|           <el-button v-else type="primary">确定</el-button> | ||||
|         </el-col> | ||||
|       </el-row> | ||||
|     </el-form> | ||||
| @ -68,7 +63,6 @@ import PartChoose from "@/views/repair/Components/PartChoose.vue"; | ||||
| import SoTable from "@/views/repair/stockOperate/Components/SoTable.vue"; | ||||
| import SupplierChoose from "@/views/repair/Components/SupplierChoose.vue"; | ||||
| import {createUniqueCodeByHead} from "@/utils/createUniqueCode"; | ||||
| import {createRepairSo} from "@/api/repair/stockOperate/stockOperate"; | ||||
| 
 | ||||
| export default { | ||||
|   name: "SoInfo", | ||||
| @ -83,29 +77,26 @@ export default { | ||||
|       type: Boolean, | ||||
|       defaultValue: true, | ||||
|       required: true | ||||
|     }, | ||||
|     } | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       formData: { | ||||
|         soNo: null, | ||||
|         supplier: null, | ||||
|         supplierId: null, | ||||
|         supplierName: null, | ||||
|         soTime: Date.now(), | ||||
|         user: null, | ||||
|         goodsList: [], | ||||
|         totalPrice: null, | ||||
|         soType: this.soByType ? "01" : "02", | ||||
|         purchaseType: "01", | ||||
|         itemCount: 0, | ||||
|         soStatus: this.soByType ? "01" : "04", | ||||
|         remark: null, | ||||
|         userId: null, | ||||
|         userName: null, | ||||
|         partList: [] | ||||
|       }, | ||||
|       staffRole: "采购员", | ||||
|       partList: [], | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|     this.init() | ||||
|     this.formData.soNo = createUniqueCodeByHead(this.soByType ? "CG" : "LL") | ||||
|     this.staffRole = this.soByType ? this.staffRole : "领料人" | ||||
|   }, | ||||
|   methods: { | ||||
|     // 得到选择的员工 | ||||
| @ -115,8 +106,7 @@ export default { | ||||
|     }, | ||||
|     // 得到选择的供应商 | ||||
|     getSupplier(data) { | ||||
|       this.formData.supplierId = data.id | ||||
|       this.formData.supplierName = data.name | ||||
|       console.log(data) | ||||
|     }, | ||||
|     // 得到选择的商品 | ||||
|     async getPart(data) { | ||||
| @ -134,66 +124,6 @@ export default { | ||||
|     // 删除数据 | ||||
|     deleteItem(index) { | ||||
|       this.partList.splice(index, 1) | ||||
|     }, | ||||
|     // 表格的数据 | ||||
|     tableData(data){ | ||||
|       this.formData.totalPrice = data.reduce((x, y) => {return x + y.totalPrice}, 0) | ||||
|       this.formData.itemCount = data.reduce((x, y) => {return x + y.count}, 0) | ||||
|       this.formData.goodsList = data.map(item => { | ||||
|         return { | ||||
|           goodsId: item.id, | ||||
|           goodsType: "0", | ||||
|           wareId: "0", | ||||
|           goodsCount: item.count, | ||||
|           goodsPrice: item.newPrice, | ||||
|           remark: item.remark | ||||
|         } | ||||
|       }) | ||||
|     }, | ||||
|     // 提交 | ||||
|     async handleSubmit(){ | ||||
|       try { | ||||
|         this.createInit() | ||||
|         await createRepairSo(this.formData) | ||||
|         this.$modal.msgSuccess("新增成功") | ||||
|         this.init() | ||||
|       }catch{ | ||||
|       } | ||||
|     }, | ||||
|     // 初始化 | ||||
|     init(){ | ||||
|       this.formData = { | ||||
|         soNo: null, | ||||
|         supplier: null, | ||||
|         soTime: Date.now(), | ||||
|         user: null, | ||||
|         goodsList: [], | ||||
|         totalPrice: null, | ||||
|         soType: this.soByType ? "01" : "02", | ||||
|         purchaseType: "01", | ||||
|         itemCount: 0, | ||||
|         soStatus: this.soByType ? "01" : "04", | ||||
|         remark: null, | ||||
|       } | ||||
|       this.formData.soNo = createUniqueCodeByHead(this.soByType ? "CG" : "LL") | ||||
|       this.staffRole = this.soByType ? this.staffRole : "领料人" | ||||
|       this.partList = [] | ||||
|     }, | ||||
|     // 提交前的构建 | ||||
|     createInit(){ | ||||
|       const data = this.formData | ||||
|       this.formData = { | ||||
|         ...data, | ||||
|         userId: data.user.id, | ||||
|         userName: data.user.name, | ||||
|       } | ||||
|       if (this.soByType){ | ||||
|         this.formData = { | ||||
|           ...data, | ||||
|           supplierId: data.supplier.id, | ||||
|           supplierName: data.supplier.name | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| @ -1,62 +1,21 @@ | ||||
| <template> | ||||
|   <el-table v-loading="loading" | ||||
|             :data="list" | ||||
|             :stripe="true" | ||||
|             :show-overflow-tooltip="true" | ||||
|             show-summary | ||||
|             :summary-method="getSummaries" | ||||
|             :key="randomKey" | ||||
|             @cell-dblclick="editData" | ||||
|   > | ||||
|   <el-table v-loading="loading" :data="partList" :stripe="true" :show-overflow-tooltip="true"> | ||||
|     <el-table-column label="序号" align="center"> | ||||
|       <template scope="scope"> | ||||
|         <span>{{ scope.$index + 1 }}</span> | ||||
|       </template> | ||||
|     </el-table-column> | ||||
|     <el-table-column label="商品名称" align="center" prop="name" width="200"/> | ||||
|     <el-table-column label="规格" align="center" width="180" prop="model"/> | ||||
|     <el-table-column label="商品编码" align="center" width="180" prop="code"/> | ||||
|     <el-table-column label="仓库" align="center" width="150" prop="warehouse"> | ||||
|       <template slot-scope="scope"> | ||||
|         <WarehouseChoose v-if="scope.row[scope.column.property + 'isShow'] && soByType" | ||||
|                          :ref="scope.column.property" | ||||
|                          v-model="scope.row.warehouse" | ||||
|                          @change="alterData(scope.row,scope.column)" | ||||
|         /> | ||||
|         <span v-else>{{ scope.row.warehouse }}</span> | ||||
|       </template> | ||||
|     </el-table-column> | ||||
|     <el-table-column label="库存" align="center" width="150" prop="stock"/> | ||||
|     <el-table-column label="单位" align="center" width="150" prop="unit"/> | ||||
|     <el-table-column label="数量" align="center" width="150" prop="count"> | ||||
|       <template slot-scope="scope"> | ||||
|         <el-input v-if="scope.row[scope.column.property + 'isShow']" | ||||
|                   :ref="scope.column.property" | ||||
|                   v-model="scope.row.count" | ||||
|                   @blur="alterData(scope.row,scope.column)"></el-input> | ||||
|         <span v-else>{{ scope.row.count }}</span> | ||||
|       </template> | ||||
|     </el-table-column> | ||||
|     <el-table-column :label="soByType ? '上次进价' : '成本'" align="center" width="150" prop="price"/> | ||||
|     <el-table-column v-if="soByType" label="采购单价" align="center" width="150" prop="newPrice"> | ||||
|       <template slot-scope="scope"> | ||||
|         <el-input v-if="scope.row[scope.column.property + 'isShow'] && soByType" | ||||
|                   :ref="scope.column.property" | ||||
|                   v-model="scope.row.newPrice" | ||||
|                   @blur="alterData(scope.row,scope.column)"></el-input> | ||||
|         <span v-else>{{ scope.row.newPrice }}</span> | ||||
|       </template> | ||||
|     </el-table-column> | ||||
|     <el-table-column :label="soByType ? '采购金额' : '合计'" align="center" width="150" prop="totalPrice"/> | ||||
|     <el-table-column label="备注" align="center" width="180" prop="remark"> | ||||
|       <template slot-scope="scope"> | ||||
|         <el-input v-if="scope.row[scope.column.property + 'isShow']" | ||||
|                   :ref="scope.column.property" | ||||
|                   v-model="scope.row.remark" | ||||
|                   @blur="alterData(scope.row,scope.column)"></el-input> | ||||
|         <span v-else>{{ scope.row.remark }}</span> | ||||
|       </template> | ||||
|     </el-table-column> | ||||
|     <el-table-column label="规格" align="center" width="180"/> | ||||
|     <el-table-column label="商品编码" align="center" width="180"/> | ||||
|     <el-table-column label="仓库" align="center" width="150"/> | ||||
|     <el-table-column label="库存" align="center" width="150" /> | ||||
|     <el-table-column label="单位" align="center" width="150"/> | ||||
|     <el-table-column label="数量" align="center" width="150"/> | ||||
|     <el-table-column :label="soByType ? '上次进价' : '成本'" align="center" width="150"/> | ||||
|     <el-table-column v-if="soByType" label="采购进价" align="center" width="150"/> | ||||
|     <el-table-column :label="soByType ? '采购金额' : '合计'" align="center" width="150"/> | ||||
|     <el-table-column label="备注" align="center" width="180"/> | ||||
|     <el-table-column label="操作" fixed="right" align="center" width="150"> | ||||
|       <template v-slot="scope"> | ||||
|         <el-button size="mini" type="text" icon="el-icon-delete" @click="deleteItem(scope.$index)" | ||||
| @ -68,11 +27,8 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import WarehouseChoose from "@/views/repair/Components/WarehouseChoose.vue"; | ||||
| 
 | ||||
| export default { | ||||
|   name: "SoTable", | ||||
|   components: {WarehouseChoose}, | ||||
|   props:{ | ||||
|     soByType:{ | ||||
|       type: Boolean, | ||||
| @ -89,80 +45,13 @@ export default { | ||||
|     return { | ||||
|       loading: false, | ||||
|       list: [], | ||||
|       includeColumn: ['count', 'totalPrice'], | ||||
|       randomKey: Math.random(), | ||||
|     } | ||||
|   }, | ||||
|   watch: { | ||||
|     partList(val) { | ||||
|       if (val && val.length > 0) { | ||||
|         const data = val[val.length - 1] | ||||
|         const newData = { | ||||
|           ...data, | ||||
|           count: 1, | ||||
|           totalPrice: data.price * 1, | ||||
|           remark: '', | ||||
|           newPrice: data.price, | ||||
|         } | ||||
|         this.list.push(newData) | ||||
|       }else { | ||||
|         this.list = [] | ||||
|         this.refreshTable() | ||||
|       } | ||||
|     }, | ||||
|     list: { | ||||
|       handler(newVal, oldVal) { | ||||
|         this.$emit("tableData", newVal) | ||||
|       }, | ||||
|       deep: true | ||||
|     } | ||||
|   }, | ||||
|   methods: { | ||||
|     // 通知父组件,删除数据 | ||||
|     deleteItem(index){ | ||||
|       this.$emit("deleteItem", index) | ||||
|     }, | ||||
|     // 设置不统计的字段 | ||||
|     getSummaries(param) { | ||||
|       const {columns, data} = param | ||||
|       const sums = [] | ||||
|       columns.forEach((column, index) => { | ||||
|         if (index === 0) { | ||||
|           sums[index] = '合计'; | ||||
|           return; | ||||
|     } | ||||
|         const values = data.map(item => Number(item[column.property])); | ||||
|         if (this.includeColumn.includes(column.property)) { | ||||
|           sums[index] = values.reduce((prev, curr) => { | ||||
|             const value = Number(curr); | ||||
|             if (!isNaN(value)) { | ||||
|               return prev + curr; | ||||
|             } else { | ||||
|               return prev; | ||||
|             } | ||||
|           }, 0); | ||||
|           sums[index]; | ||||
|         } | ||||
|       }); | ||||
|       return sums | ||||
|     }, | ||||
|     editData(row, column) { | ||||
|       row[column.property + "isShow"] = true | ||||
|       //refreshTable是table数据改动时,刷新table的 | ||||
|       this.refreshTable() | ||||
|       // this.$nextTick(() => { | ||||
|       //   this.$refs[column.property] && this.$refs[column.property].focus() | ||||
|       // }) | ||||
|     }, | ||||
|     alterData(row, column) { | ||||
|       row[column.property + "isShow"] = false | ||||
|       const data = this.list.find(item => item.id === row.id) | ||||
|       data.totalPrice = data.newPrice * data.count | ||||
|       this.refreshTable() | ||||
|     }, | ||||
|     refreshTable() { | ||||
|       this.randomKey = Math.random() | ||||
|     }, | ||||
|   } | ||||
| } | ||||
| </script> | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user