Compare commits
	
		
			2 Commits
		
	
	
		
			3914d1a5d0
			...
			ff3c246049
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ff3c246049 | ||
|   | f7699f76bd | 
| @ -1 +1,11 @@ | ||||
| import request from '@/utils/request' | ||||
| 
 | ||||
| const preUrl = '/repair/tickets' | ||||
| 
 | ||||
| export function createTickets(data){ | ||||
|   return request({ | ||||
|     url: preUrl + "/create", | ||||
|     method: "post", | ||||
|     data | ||||
|   }) | ||||
| } | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| <template> | ||||
|   <el-select v-model="staffSelected" clearable filterable> | ||||
|   <el-select v-model="staffSelected" clearable filterable @blur="$emit('input-blur', $event)"> | ||||
|     <el-option v-for="staff in staffList" :key="staff.id" :label="staff.name" :value="staff.id"/> | ||||
|   </el-select> | ||||
| </template> | ||||
|  | ||||
| @ -18,22 +18,74 @@ | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="规格" width="180" prop="model"/> | ||||
|       <el-table-column align="center" label="编码" width="180" prop="code"/> | ||||
|       <el-table-column align="center" label="数量" width="180" prop="count"/> | ||||
|       <el-table-column align="center" label="数量" width="180" prop="count"> | ||||
|         <div class="item" slot-scope="scope"> | ||||
|           <el-input @blur="save(scope.row)" class="item__input" v-model="scope.row.count"/> | ||||
|           <span class="item__txt">{{ scope.row.count }}</span> | ||||
|         </div> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="单位" width="180" prop="unit"/> | ||||
|       <el-table-column align="center" label="折扣" width="180"/> | ||||
|       <el-table-column align="center" label="金额" width="180"/> | ||||
|       <el-table-column align="center" label="施工人员" width="180"/> | ||||
|       <el-table-column align="center" label="销售人员" width="180"/> | ||||
|       <el-table-column align="center" label="类型" width="180"/> | ||||
|       <el-table-column align="center" label="账类" width="180"/> | ||||
|       <el-table-column align="center" label="状态" width="180"/> | ||||
|       <el-table-column align="center" label="备注" width="180"/> | ||||
|       <el-table-column align="center" label="单价" width="180" prop="price"> | ||||
|         <div class="item" slot-scope="scope"> | ||||
|           <el-input @blur="save(scope.row)" class="item__input" v-model="scope.row.price"/> | ||||
|           <span class="item__txt">{{ scope.row.price }}</span> | ||||
|         </div> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="折扣" width="180" prop="discount"> | ||||
|         <div class="item" slot-scope="scope"> | ||||
|           <el-input @blur="save(scope.row)" class="item__input" v-model="scope.row.discount"/> | ||||
|           <span class="item__txt">{{ scope.row.discount }}</span> | ||||
|         </div> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="金额" width="180" prop="totalPrice"> | ||||
|         <div class="item" slot-scope="scope"> | ||||
|           <el-input @blur="save(scope.row)" class="item__input" v-model="scope.row.totalPrice"/> | ||||
|           <span class="item__txt">{{ scope.row.totalPrice }}</span> | ||||
|         </div> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="施工人员" width="180" prop="repair"> | ||||
|         <div class="item" slot-scope="scope"> | ||||
|           <StaffChoose @input-blur="save(scope.row)" class="item__input" v-model="scope.row.repair" | ||||
|                        :select-width="'15rem'"/> | ||||
|           <span class="item__txt">{{ scope.row.repair ? scope.row.repair.name : scope.row.repair }}</span> | ||||
|         </div> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="销售人员" width="180" prop="sale"> | ||||
|         <div class="item" slot-scope="scope"> | ||||
|           <StaffChoose @input-blur="save(scope.row)" class="item__input" v-model="scope.row.sale" | ||||
|                        :select-width="'15rem'"/> | ||||
|           <span class="item__txt">{{ scope.row.sale ? scope.row.sale.name : scope.row.sale }}</span> | ||||
|         </div> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="类型" width="180" prop="type"> | ||||
|         <div class="item" slot-scope="scope"> | ||||
|           <el-input @blur="save(scope.row)" class="item__input" v-model="scope.row.type"/> | ||||
|           <span class="item__txt">{{ scope.row.type }}</span> | ||||
|         </div> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="账类" width="180" prop="accountType"> | ||||
|         <div class="item" slot-scope="scope"> | ||||
|           <el-input @blur="save(scope.row)" class="item__input" v-model="scope.row.accountType"/> | ||||
|           <span class="item__txt">{{ scope.row.accountType }}</span> | ||||
|         </div> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="状态" width="180" prop="itemStatus"> | ||||
|         <template slot-scope="scope"> | ||||
|           <dict-tag v-if="scope.row.itemStatus" :type="DICT_TYPE.REPAIR_ITEM_STATUS" v-model="scope.row.itemStatus"/> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" label="备注" width="180" prop="remark"> | ||||
|         <div class="item" slot-scope="scope"> | ||||
|           <el-input @blur="save(scope.row)" class="item__input" v-model="scope.row.remark"/> | ||||
|           <span class="item__txt">{{ scope.row.remark }}</span> | ||||
|         </div> | ||||
|       </el-table-column> | ||||
|       <el-table-column label="操作" fixed="right" align="center" width="150"> | ||||
|         <template v-slot="scope"> | ||||
|           <el-button size="mini" type="text" icon="el-icon-delete" | ||||
|           <el-button size="mini" type="text" icon="el-icon-plus" | ||||
|           >新增 | ||||
|           </el-button> | ||||
|           <el-button size="mini" type="text" icon="el-icon-delete" | ||||
|           <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDeleteItem(scope.$index)" | ||||
|           >删除 | ||||
|           </el-button> | ||||
|         </template> | ||||
| @ -44,12 +96,13 @@ | ||||
| 
 | ||||
| <script> | ||||
| import PartChoose from "@/views/repair/Components/PartChoose.vue"; | ||||
| import StaffChoose from "@/views/repair/Components/StaffChoose.vue"; | ||||
| 
 | ||||
| export default { | ||||
|   name: "TicketItem", | ||||
|   components: {PartChoose}, | ||||
|   props:{ | ||||
|     itemType:{ | ||||
|   components: {StaffChoose, PartChoose}, | ||||
|   props: { | ||||
|     itemType: { | ||||
|       type: String, | ||||
|       default: 'project', | ||||
|       required: true | ||||
| @ -60,14 +113,28 @@ export default { | ||||
|       loading: false, | ||||
|       list: [{}], | ||||
|       // 需要编辑的属性 | ||||
|       editProp: ["goods"], | ||||
|       editProp: ["goods", 'count', 'price', 'discount', 'repair', 'sale', 'remark', 'type', 'accountType'], | ||||
|       // 保存进入编辑的cell | ||||
|       clickCellMap: {} | ||||
|       clickCellMap: {}, | ||||
|       selectRepair: {}, | ||||
|       selectSale: {}, | ||||
|       formData: { | ||||
|         repair: null, | ||||
|         sale: null, | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   computed:{ | ||||
|     getLabelName(){ | ||||
|       switch (this.itemType){ | ||||
|   watch:{ | ||||
|     list:{ | ||||
|       handler(val){ | ||||
|         this.$emit("tableData", val) | ||||
|       }, | ||||
|       deep: true | ||||
|     } | ||||
|   }, | ||||
|   computed: { | ||||
|     getLabelName() { | ||||
|       switch (this.itemType) { | ||||
|         case "project": | ||||
|           return "维修项目"; | ||||
|         case "part": | ||||
| @ -98,11 +165,13 @@ export default { | ||||
|     handleCellClick(row, column, cell, event) { | ||||
|       const property = column.property | ||||
|       if (this.editProp.includes(property)) { | ||||
|         // 保存cell | ||||
|         this.saveCellClick(row, cell) | ||||
|         cell.querySelector('.item__txt').style.display = 'none' | ||||
|         cell.querySelector('.item__input').style.display = 'inline' | ||||
|         cell.querySelector('input').focus() | ||||
|         if (!row.id || property !== 'goods') { | ||||
|           // 保存cell | ||||
|           this.saveCellClick(row, cell) | ||||
|           cell.querySelector('.item__txt').style.display = 'none' | ||||
|           cell.querySelector('.item__input').style.display = 'inline' | ||||
|           cell.querySelector('input').focus() | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     /** 取消编辑状态 */ | ||||
| @ -122,7 +191,12 @@ export default { | ||||
|       } | ||||
|     }, | ||||
|     /** 保存数据 */ | ||||
|     save (row) { | ||||
|     save(row) { | ||||
|       // TODO 有BUG 更新表格 | ||||
|       if (row.id){ | ||||
|         row.itemStatus = row.repair ? "02" : "01" | ||||
|         row.totalPrice = row.count * row.price * (row.discount / 10) | ||||
|       } | ||||
|       const id = row.id | ||||
|       // 取消本行所有cell的编辑状态 | ||||
|       this.clickCellMap[id].forEach(cell => { | ||||
| @ -130,8 +204,21 @@ export default { | ||||
|       }) | ||||
|       this.clickCellMap[id] = [] | ||||
|     }, | ||||
|     getPart(data){ | ||||
|     getPart(data) { | ||||
|       data = { | ||||
|         ...data, | ||||
|         count: 1, | ||||
|         discount: 10, | ||||
|         remark: null, | ||||
|         itemStatus: '01', | ||||
|         totalPrice: data.price | ||||
|       } | ||||
|       this.list.splice(this.list.length - 1, 0, data) | ||||
|     }, | ||||
|     handleDeleteItem(index) { | ||||
|       if (this.list[index].id) { | ||||
|         this.list.splice(index, 1) | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| @ -92,12 +92,12 @@ | ||||
|         </template> | ||||
|         <el-input v-model="selectCar.newMaintenanceMileage"/> | ||||
|       </el-descriptions-item> | ||||
|       <el-descriptions-item :span="3"> | ||||
|         <template slot="label"> | ||||
|           备注 | ||||
|         </template> | ||||
|         <el-input v-model="formData.remark"/> | ||||
|       </el-descriptions-item> | ||||
| <!--      <el-descriptions-item :span="3">--> | ||||
| <!--        <template slot="label">--> | ||||
| <!--          备注--> | ||||
| <!--        </template>--> | ||||
| <!--        <el-input v-model="formData.remark"/>--> | ||||
| <!--      </el-descriptions-item>--> | ||||
|       <el-descriptions-item> | ||||
|         <template slot="label"> | ||||
|           服务顾问 | ||||
| @ -129,9 +129,9 @@ | ||||
|         </el-select> | ||||
|       </el-col> | ||||
|     </el-row> | ||||
|     <TicketItem item-type="project"/> | ||||
|     <TicketItem v-if="createTicketType" item-type="part"/> | ||||
|     <TicketItem v-if="createTicketType" item-type="other"/> | ||||
|     <TicketItem item-type="project" @tableData="projectData"/> | ||||
|     <TicketItem v-if="createTicketType" item-type="part" @tableData="partData"/> | ||||
|     <TicketItem v-if="createTicketType" item-type="other" @tableData="otherData"/> | ||||
|     <el-row :gutter="createTicketType ? 2 : 3" style="margin-top: 1rem"> | ||||
|       <el-col :span="createTicketType ? 12 : 16"> | ||||
|         <el-descriptions class="margin-top" :column="createTicketType ? 2 : 3" border :size="'medium'" | ||||
| @ -164,11 +164,11 @@ | ||||
|       <el-col v-if="createTicketType" :span="12"> | ||||
|         <el-descriptions class="margin-top" :column="5" :size="'medium'" | ||||
|                          style="margin-left: 1rem;margin-top: 1rem"> | ||||
|           <el-descriptions-item label="数量">0</el-descriptions-item> | ||||
|           <el-descriptions-item label="项目">0</el-descriptions-item> | ||||
|           <el-descriptions-item label="配件">0</el-descriptions-item> | ||||
|           <el-descriptions-item label="附加">0</el-descriptions-item> | ||||
|           <el-descriptions-item label="合计">0</el-descriptions-item> | ||||
|           <el-descriptions-item label="数量">{{ formData.count }}</el-descriptions-item> | ||||
|           <el-descriptions-item label="项目">{{ formData.projectPrice }}</el-descriptions-item> | ||||
|           <el-descriptions-item label="配件">{{ formData.partPrice }}</el-descriptions-item> | ||||
|           <el-descriptions-item label="附加">{{ formData.otherPrice }}</el-descriptions-item> | ||||
|           <el-descriptions-item label="合计">{{ formData.totalPrice }}</el-descriptions-item> | ||||
|         </el-descriptions> | ||||
|       </el-col> | ||||
|       <el-col v-else :span="8" style="margin-top:1rem;display: flex;justify-content: right"> | ||||
| @ -183,11 +183,12 @@ | ||||
|             <template slot="label"> | ||||
|               备注 | ||||
|             </template> | ||||
|             <el-input/> | ||||
|             <el-input v-model="formData.remark"/> | ||||
|           </el-descriptions-item> | ||||
|         </el-descriptions> | ||||
|       </el-col> | ||||
|       <el-col :span="12" style="margin-top:1rem;display: flex;justify-content: right"> | ||||
|         <el-button type="success" @click="handleSave">登记保存</el-button> | ||||
|         <el-button type="danger">结算</el-button> | ||||
|         <el-button type="success">完成</el-button> | ||||
|         <el-button type="primary">通知施工</el-button> | ||||
| @ -203,7 +204,8 @@ import UserChoose from "@/views/repair/Components/UserChoose.vue"; | ||||
| import StaffChoose from "@/views/repair/Components/StaffChoose.vue"; | ||||
| import TicketItem from "@/views/repair/tickets/Components/TicketItem.vue"; | ||||
| import CarChoose from "@/views/repair/Components/CarChoose.vue"; | ||||
| import {parseTime} from "../../../../utils/ruoyi"; | ||||
| import {createUniqueCodeByHead} from "@/utils/createUniqueCode"; | ||||
| import {createTickets} from "@/api/repair/tickets/Tickets"; | ||||
| 
 | ||||
| export default { | ||||
|   name: "UserInfo", | ||||
| @ -236,15 +238,212 @@ export default { | ||||
|         remark: null, | ||||
|         inTime: Date.now(), | ||||
|         outTime: null, | ||||
|         ticketTime: Date.now() | ||||
|         ticketTime: Date.now(), | ||||
|         projectPrice: 0, | ||||
|         partPrice: 0, | ||||
|         otherPrice: 0, | ||||
|         totalPrice: 0, | ||||
|         count: 0, | ||||
|         userId: null, | ||||
|         userName: null, | ||||
|         userMobile: null, | ||||
|         carId: null, | ||||
|         carNo: null, | ||||
|         carVin: null, | ||||
|         carBrandId: null, | ||||
|         carBrandName: null, | ||||
|         carBrandType: null, | ||||
|         adviserId: null, | ||||
|         adviserName: null, | ||||
|         payType: null, | ||||
|         repairAdvice: null, | ||||
|         qualityExplain: null, | ||||
|         ticketType: null, | ||||
|         itemList: [], | ||||
|       }, | ||||
|       selectUser: {}, | ||||
|       selectCar: {}, | ||||
|       selectStaff: {}, | ||||
|       projectList: [], | ||||
|       partList: [], | ||||
|       otherList: [] | ||||
|     } | ||||
|   }, | ||||
|   methods: { | ||||
|     parseTime | ||||
|     projectData(data) { | ||||
|       // 去掉最后一行 | ||||
|       this.projectList = [...data] | ||||
|       this.projectList.pop() | ||||
|       // 通知计算 | ||||
|       this.computedData() | ||||
|     }, | ||||
|     partData(data) { | ||||
|       // 去掉最后一行 | ||||
|       this.partList = [...data] | ||||
|       this.partList.pop() | ||||
|       // 通知计算 | ||||
|       this.computedData() | ||||
|     }, | ||||
|     otherData(data) { | ||||
|       // 去掉最后一行 | ||||
|       this.otherList = [...data] | ||||
|       this.otherList.pop() | ||||
|       // 通知计算 | ||||
|       this.computedData() | ||||
|     }, | ||||
|     computedData() { | ||||
|       const data = this.formData | ||||
|       this.formData = { | ||||
|         ...data, | ||||
|         projectPrice: 0, | ||||
|         partPrice: 0, | ||||
|         otherPrice: 0, | ||||
|         totalPrice: 0, | ||||
|         count: 0 | ||||
|       } | ||||
|       // 项目 | ||||
|       if (this.projectList) { | ||||
|         this.formData.projectPrice = this.computeByItem(this.projectList) | ||||
|       } | ||||
|       // 配件 | ||||
|       if (this.partList) { | ||||
|         this.formData.partPrice = this.computeByItem(this.partList) | ||||
|       } | ||||
|       // 其他 | ||||
|       if (this.otherList) { | ||||
|         this.formData.otherPrice = this.computeByItem(this.otherList) | ||||
|       } | ||||
|     }, | ||||
|     computeByItem(item) { | ||||
|       const count = item.reduce((x, y) => { | ||||
|         return x + y.count | ||||
|       }, 0) | ||||
|       const totalPrice = item.reduce((x, y) => { | ||||
|         return x + y.totalPrice | ||||
|       }, 0) | ||||
|       this.formData.count += parseInt(count) | ||||
|       this.formData.totalPrice += parseFloat(totalPrice) | ||||
|       return parseFloat(totalPrice) | ||||
|     }, | ||||
|     // 登记保存 | ||||
|     async handleSave() { | ||||
|       this.createInit() | ||||
|       this.createItemInit() | ||||
|       try { | ||||
|         // await createTickets(this.formData) | ||||
|         this.$modal.msgSuccess("新增成功") | ||||
|         this.init() | ||||
|       }catch{} | ||||
|     }, | ||||
|     // 初始化 | ||||
|     init(){ | ||||
|       this.formData = { | ||||
|         endCheck: 1, | ||||
|         partDisposal: '01', | ||||
|         repairType: '01', | ||||
|         ticketNo: null, | ||||
|         remark: null, | ||||
|         inTime: Date.now(), | ||||
|         outTime: null, | ||||
|         ticketTime: Date.now(), | ||||
|         projectPrice: 0, | ||||
|         partPrice: 0, | ||||
|         otherPrice: 0, | ||||
|         totalPrice: 0, | ||||
|         count: 0, | ||||
|         userId: null, | ||||
|         userName: null, | ||||
|         userMobile: null, | ||||
|         carId: null, | ||||
|         carNo: null, | ||||
|         carVin: null, | ||||
|         carBrandId: null, | ||||
|         carBrandName: null, | ||||
|         carBrandType: null, | ||||
|         adviserId: null, | ||||
|         adviserName: null, | ||||
|         payType: null, | ||||
|         repairAdvice: null, | ||||
|         qualityExplain: null, | ||||
|         ticketType: null, | ||||
|         itemList: [], | ||||
|       } | ||||
|       this.selectUser ={} | ||||
|       this.selectCar = {} | ||||
|       this.selectStaff = {} | ||||
|       this.projectList = [] | ||||
|       this.partList = [] | ||||
|       this.otherList = [] | ||||
|     }, | ||||
|     // 新增基础信息init | ||||
|     createInit() { | ||||
|       // 生成工单号 | ||||
|       this.formData.ticketNo = createUniqueCodeByHead("GD") | ||||
|       // 选择的用户 | ||||
|       this.formData.userId = this.selectUser?.userId | ||||
|       this.formData.userName = this.selectUser?.cusName | ||||
|       this.formData.userMobile = this.selectUser?.phoneNumber | ||||
| 
 | ||||
|       // 选择的车辆 | ||||
|       this.formData.carId = this.selectCar?.id | ||||
|       this.formData.carNo = this.selectCar?.licenseNumber | ||||
|       this.formData.carVin = this.selectCar?.vin | ||||
|       this.formData.carBrandId = this.selectCar?.carBrand | ||||
|       this.formData.carBrandName = this.selectCar?.brandStr | ||||
|       this.formData.carBrandType = this.selectCar?.brandType | ||||
| 
 | ||||
|       // 服务顾问 | ||||
|       this.formData.adviserId = this.selectStaff?.id | ||||
|       this.formData.adviserName = this.selectStaff?.name | ||||
|     }, | ||||
|     // 新增子表信息init | ||||
|     createItemInit() { | ||||
|       // 项目 | ||||
|       this.formData.itemList = [...this.formData.itemList, ...this.formatItem("project", this.projectList)] | ||||
|       // 配件 | ||||
|       this.formData.itemList = [...this.formData.itemList, ...this.formatItem("part", this.partList)] | ||||
|       // 其他 | ||||
|       this.formData.itemList = [...this.formData.itemList, ...this.formatItem("other", this.otherList)] | ||||
|     }, | ||||
|     // 子表信息预处理 | ||||
|     formatItem(type, list) { | ||||
|       if (!(list && list.length > 0)){ | ||||
|         return [] | ||||
|       } | ||||
|       return list.map(item => { | ||||
|         const temp = { | ||||
|           ...item, | ||||
|           itemName: item.name, | ||||
|           itemCount: item.count, | ||||
|           itemUnit: item.unit, | ||||
|           itemPrice: item.price, | ||||
|           itemDiscount: item.discount, | ||||
|           itemMoney: item.totalPrice, | ||||
|           repairId: item?.repair?.id, | ||||
|           repairName: item?.repair?.name, | ||||
|           saleId: item?.sale?.id, | ||||
|           saleName: item?.sale?.name, | ||||
|           itemTypeId: item?.type?.id, | ||||
|           remark: item.remark, | ||||
|           itemStatus: item.itemStatus, | ||||
|         } | ||||
|         switch (type) { | ||||
|           case 'project': | ||||
|             temp['itemType'] = "01" | ||||
|             break; | ||||
|           case 'part': | ||||
|             temp['itemType'] = "02" | ||||
|             break; | ||||
|           case 'other': | ||||
|             temp['itemType'] = "03" | ||||
|             break; | ||||
|           default: | ||||
|             return ""; | ||||
|         } | ||||
|         temp[type + 'Id'] = item.id | ||||
|         return temp; | ||||
|       }) | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user