仓管的采购单和入库单未完成的完成
This commit is contained in:
		
							parent
							
								
									05bf3832ab
								
							
						
					
					
						commit
						2c198e67b9
					
				| @ -17,7 +17,10 @@ | |||||||
|     <view class="listBox"> |     <view class="listBox"> | ||||||
|       <view class="list"> |       <view class="list"> | ||||||
|         <view v-for="(item, index) in wares" :key="index" class="listItem"> |         <view v-for="(item, index) in wares" :key="index" class="listItem"> | ||||||
|           <view class="repairName">{{ item.waresName }}</view> |           <view class="repairName"> | ||||||
|  |             <radio @click="chooseItem(item)" :checked="item.isSelected"/> | ||||||
|  |             {{ item.waresName }} | ||||||
|  |           </view> | ||||||
|           <view class="repairBottom"> |           <view class="repairBottom"> | ||||||
|             <text class="repairDesc">单位: |             <text class="repairDesc">单位: | ||||||
|               <text class="repairUnit">{{ item.wares.unit }}</text> |               <text class="repairUnit">{{ item.wares.unit }}</text> | ||||||
| @ -74,7 +77,8 @@ export default { | |||||||
|       formData: {}, |       formData: {}, | ||||||
|       active: '', |       active: '', | ||||||
|       isToBeReviewed: true, |       isToBeReviewed: true, | ||||||
|       query: null |       query: null, | ||||||
|  |       selectRows: [] | ||||||
|     }; |     }; | ||||||
|   }, |   }, | ||||||
|   onLoad(data) { |   onLoad(data) { | ||||||
| @ -91,7 +95,21 @@ export default { | |||||||
| 
 | 
 | ||||||
|   computed: {}, |   computed: {}, | ||||||
|   methods: { |   methods: { | ||||||
|     handleSearch(){ |     chooseItem(item) { | ||||||
|  |       const index = this.selectRows.findIndex(i => i.id === item.id) | ||||||
|  |       const parentIndex = this.wares.findIndex(i => i.id === item.id) | ||||||
|  |       if (index === -1) { | ||||||
|  |         this.$set(item, 'isSelected', true) | ||||||
|  |         this.selectRows.push(item) | ||||||
|  |       } else { | ||||||
|  |         this.$set(item, 'isSelected', false) | ||||||
|  |         this.selectRows.splice(index, 1) | ||||||
|  |       } | ||||||
|  |       if (parentIndex !== -1) { | ||||||
|  |         this.$set(this.wares, parentIndex, item) | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     handleSearch() { | ||||||
|       this.init() |       this.init() | ||||||
|     }, |     }, | ||||||
|     /** |     /** | ||||||
| @ -108,12 +126,12 @@ export default { | |||||||
|         params: params |         params: params | ||||||
|       }).then((res) => { |       }).then((res) => { | ||||||
|         this.wares = res.data |         this.wares = res.data | ||||||
|         if (this.isToBeReviewed){ |         if (this.isToBeReviewed) { | ||||||
|           this.wares = this.wares.filter(item => item.waresStatus === '1') |           this.wares = this.wares.filter(item => item.waresStatus === '1') | ||||||
|           this.wares = this.wares.filter(item => this.isReceive ? (item.waresCount > item.waresAlreadyCount) : (item.waresAlreadyCount > 0)) |           this.wares = this.wares.filter(item => this.isReceive ? (item.waresCount > item.waresAlreadyCount) : (item.waresAlreadyCount > 0)) | ||||||
|         } |         } | ||||||
|         this.wares.forEach(item => { |         this.wares.forEach(item => { | ||||||
|           if (!item.wares.stock){ |           if (!item.wares.stock) { | ||||||
|             item.wares.stock = 0 |             item.wares.stock = 0 | ||||||
|           } |           } | ||||||
|           if (this.isReceive) { |           if (this.isReceive) { | ||||||
| @ -128,6 +146,11 @@ export default { | |||||||
|             item.maxNum = item.waresAlreadyCount |             item.maxNum = item.waresAlreadyCount | ||||||
|             item.thisNum = 0 |             item.thisNum = 0 | ||||||
|           } |           } | ||||||
|  |           if (!this.selectRows || this.selectRows.length === 0){ | ||||||
|  |             item.isSelected = false | ||||||
|  |           }else { | ||||||
|  |             item.isSelected = this.selectRows.findIndex(i => i.id === item.id) !== -1 | ||||||
|  |           } | ||||||
|         }) |         }) | ||||||
|         // res.data.map((item)=>{ |         // res.data.map((item)=>{ | ||||||
|         //   if(!item.waresAlreadyCount){ |         //   if(!item.waresAlreadyCount){ | ||||||
| @ -208,7 +231,7 @@ export default { | |||||||
|       } |       } | ||||||
|       // 过滤一下,thisNum不等0才行 |       // 过滤一下,thisNum不等0才行 | ||||||
|       const flag = this.wares.filter(item => item.thisNum > 0) |       const flag = this.wares.filter(item => item.thisNum > 0) | ||||||
|       if (!flag || flag.length === 0){ |       if (!flag || flag.length === 0) { | ||||||
|         uni.showToast({ |         uni.showToast({ | ||||||
|           title: '请设置配件数量!', |           title: '请设置配件数量!', | ||||||
|           icon: 'none' |           icon: 'none' | ||||||
| @ -252,7 +275,11 @@ export default { | |||||||
|      */ |      */ | ||||||
|     toPart() { |     toPart() { | ||||||
|       const formData = this.formData; |       const formData = this.formData; | ||||||
|  |       if (this.selectRows && this.selectRows.length > 0) { | ||||||
|  |         formData.items = this.selectRows | ||||||
|  |       } else { | ||||||
|         formData.items = this.wares; |         formData.items = this.wares; | ||||||
|  |       } | ||||||
|       setJSONData("applyWaresForm", formData) |       setJSONData("applyWaresForm", formData) | ||||||
|       uni.navigateTo({ |       uni.navigateTo({ | ||||||
|         url: '/pages-warehouse/inOutWarehouse/part' |         url: '/pages-warehouse/inOutWarehouse/part' | ||||||
|  | |||||||
| @ -8,6 +8,11 @@ | |||||||
|           <input type="text" style="text-align: right" v-model="serviceName" placeholder="请输入供应商名称"/> |           <input type="text" style="text-align: right" v-model="serviceName" placeholder="请输入供应商名称"/> | ||||||
|           <view @click="searchService">查询</view> |           <view @click="searchService">查询</view> | ||||||
|         </view> |         </view> | ||||||
|  |         <view class="formItem" v-if="isInput"> | ||||||
|  |           <text class="formLabel">关键字</text> | ||||||
|  |           <input type="text" style="text-align: right" v-model="query" placeholder="名称、规格、编码"/> | ||||||
|  |           <view @click="searchQuery">查询</view> | ||||||
|  |         </view> | ||||||
|         <view class="formItem" v-if="!isInput"> |         <view class="formItem" v-if="!isInput"> | ||||||
|           <text class="formLabel">备注</text> |           <text class="formLabel">备注</text> | ||||||
|           <text class="formValue"></text> |           <text class="formValue"></text> | ||||||
| @ -15,16 +20,76 @@ | |||||||
|         <view style="padding-bottom: 60rpx;border-bottom: 1px solid #ddd;" class="formItem" v-if="!isInput"> |         <view style="padding-bottom: 60rpx;border-bottom: 1px solid #ddd;" class="formItem" v-if="!isInput"> | ||||||
|           <textarea style="height: 50px" auto-height placeholder="请输入备注" v-model="remark"/> |           <textarea style="height: 50px" auto-height placeholder="请输入备注" v-model="remark"/> | ||||||
|         </view> |         </view> | ||||||
|         <uni-card v-for="(item, index) in partList" :key="index" :title="item.name" :extra="'上次价格:'+item.purPrice"> |         <uni-card title="车辆信息" v-if="!isInput"> | ||||||
|           <view class="formItem"> |           <view class="formItem"> | ||||||
|             <view class="formLabel">单价</view> |             <view>车牌号</view> | ||||||
|             <input type="number" style="text-align: right" v-model="item.newPrice" placeholder="请输入单价"/> |             <view>{{ carInfo.licenseNumber }}</view> | ||||||
|           </view> |           </view> | ||||||
|           <view class="formItem"> |           <view class="formItem"> | ||||||
|             <view class="formLabel">数量</view> |             <view>品牌</view> | ||||||
|             <input type="number" style="text-align: right" v-model="item.count" placeholder="请输入数量"/> |             <view>{{ carInfo.carBrand }}</view> | ||||||
|  |           </view> | ||||||
|  |           <view class="formItem"> | ||||||
|  |             <view>型号</view> | ||||||
|  |             <view>{{ carInfo.carModel }}</view> | ||||||
|           </view> |           </view> | ||||||
|         </uni-card> |         </uni-card> | ||||||
|  |         <uni-collapse ref="collapse"> | ||||||
|  |           <uni-collapse-item v-for="[key, value] in partList" :title="key + `(${value.length})`"> | ||||||
|  |             <uni-card v-for="(item, index) in value" :key="index"> | ||||||
|  |               <template> | ||||||
|  |                 <view class="card-header"> | ||||||
|  |                   <radio :checked="item.isSelected" @click="chooseItem(item)"/> | ||||||
|  |                   <text class="card-title">{{ item.wares.name }}</text> | ||||||
|  |                 </view> | ||||||
|  |               </template> | ||||||
|  |               <view class="formItem"> | ||||||
|  |                 <view class="formLabel">进价</view> | ||||||
|  |                 <input type="number" style="text-align: right" v-model="item.wares.purPrice" placeholder="请输入单价"/> | ||||||
|  |               </view> | ||||||
|  |               <view class="formItem"> | ||||||
|  |                 <view class="formLabel">售价</view> | ||||||
|  |                 <input type="number" style="text-align: right" v-model="item.wares.price" placeholder="请输入单价"/> | ||||||
|  |               </view> | ||||||
|  |               <view class="formItem"> | ||||||
|  |                 <view class="formLabel">分类</view> | ||||||
|  |                 <view> | ||||||
|  |                   <picker @change="bindPickerChange($event, item)" :range="options" range-key="label"> | ||||||
|  |                     <view class="picker"> | ||||||
|  |                       {{ getServerName(item.wares.type) }} | ||||||
|  |                     </view> | ||||||
|  |                   </picker> | ||||||
|  |                 </view> | ||||||
|  |               </view> | ||||||
|  |               <view class="formItem"> | ||||||
|  |                 <view class="formLabel">计量单价</view> | ||||||
|  |                 <picker @change="bindUnitChange($event, item)" :range="unitList" range-key="label"> | ||||||
|  |                   <view class="picker"> | ||||||
|  |                     {{ getUnitName(item.wares.unit) }} | ||||||
|  |                   </view> | ||||||
|  |                 </picker> | ||||||
|  |               </view> | ||||||
|  |               <view class="formItem" v-if="!isInput"> | ||||||
|  |                 <view class="formLabel">数量</view> | ||||||
|  |                 <input type="number" style="text-align: right" v-model="item.waresCount" placeholder="请输入数量"/> | ||||||
|  |               </view> | ||||||
|  |               <view class="formItem" v-if="isInput"> | ||||||
|  |                 <view class="formLabel">数量</view> | ||||||
|  |                 <input type="number" style="text-align: right" v-model="item.inCount" placeholder="请输入数量"/> | ||||||
|  |               </view> | ||||||
|  |             </uni-card> | ||||||
|  |           </uni-collapse-item> | ||||||
|  |         </uni-collapse> | ||||||
|  |         <!--        <uni-card v-for="(item, index) in partList" :key="index" :title="item.name" :extra="'上次价格:'+item.purPrice">--> | ||||||
|  |         <!--          <view class="formItem">--> | ||||||
|  |         <!--            <view class="formLabel">单价</view>--> | ||||||
|  |         <!--            <input type="number" style="text-align: right" v-model="item.newPrice" placeholder="请输入单价"/>--> | ||||||
|  |         <!--          </view>--> | ||||||
|  |         <!--          <view class="formItem">--> | ||||||
|  |         <!--            <view class="formLabel">数量</view>--> | ||||||
|  |         <!--            <input type="number" style="text-align: right" v-model="item.count" placeholder="请输入数量"/>--> | ||||||
|  |         <!--          </view>--> | ||||||
|  |         <!--        </uni-card>--> | ||||||
|       </view> |       </view> | ||||||
|     </view> |     </view> | ||||||
|     <view class="footer"> |     <view class="footer"> | ||||||
| @ -41,9 +106,11 @@ import VNavigationBar from "@/components/VNavigationBar.vue"; | |||||||
| import request from '@/utils/request'; | import request from '@/utils/request'; | ||||||
| import {getDictTextByCodeAndValue, createUniqueCodeByHead} from "@/utils/utils"; | import {getDictTextByCodeAndValue, createUniqueCodeByHead} from "@/utils/utils"; | ||||||
| import {getUserInfo, getJSONData} from '@/utils/auth.js' | import {getUserInfo, getJSONData} from '@/utils/auth.js' | ||||||
|  | import UniCollapse from "../../uni_modules/uni-collapse/components/uni-collapse/uni-collapse.vue"; | ||||||
|  | import {getStorageWithExpiry} from "../../utils/auth"; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|   components: {VNavigationBar}, |   components: {UniCollapse, VNavigationBar}, | ||||||
|   data() { |   data() { | ||||||
|     return { |     return { | ||||||
|       //配件申请单id |       //配件申请单id | ||||||
| @ -69,27 +136,105 @@ export default { | |||||||
|       //供应商id |       //供应商id | ||||||
|       serviceId: "", |       serviceId: "", | ||||||
|       soId: "", |       soId: "", | ||||||
|       soiIds: [] |       soiIds: [], | ||||||
|  |       carInfo: {}, | ||||||
|  |       options: [], | ||||||
|  |       selectedIndex: -1, | ||||||
|  |       unitList: [], | ||||||
|  |       query: null, | ||||||
|  |       selectRows: [], | ||||||
|     }; |     }; | ||||||
|   }, |   }, | ||||||
|   onLoad(data) { |   onLoad(data) { | ||||||
|  |     this.listServer() | ||||||
|  |     this.listUnit() | ||||||
|     if (data.soId) { |     if (data.soId) { | ||||||
|       this.soId = data.soId |       this.soId = data.soId | ||||||
|       this.isInput = true |       this.isInput = true | ||||||
|       this.title = '配件入库' |       this.title = '配件入库' | ||||||
|       this.getSoiId() |       this.getSoiId() | ||||||
|     }else { |     } else { | ||||||
|       if (getJSONData("applyWaresForm")) { |       if (getJSONData("applyWaresForm")) { | ||||||
|         this.formData = getJSONData("applyWaresForm") |         this.formData = getJSONData("applyWaresForm") | ||||||
|         this.wares = this.formData.items |         this.wares = this.formData.items | ||||||
|         this.init() |         this.init() | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   computed: {}, |   computed: {}, | ||||||
|   methods: { |   methods: { | ||||||
|  |     chooseItem(item) { | ||||||
|  |       const parentIndex = this.partList.map(([key, value]) => value).reduce((acc, value) => acc.concat(value)).findIndex(i => i.id === item.id) | ||||||
|  |       const index = this.selectRows.findIndex(i => i.id === item.id) | ||||||
|  |       if (index === -1){ | ||||||
|  |         this.$set(item, 'isSelected', true) | ||||||
|  |         this.selectRows.push(item) | ||||||
|  |       }else { | ||||||
|  |         this.$set(item, 'isSelected', false) | ||||||
|  |         this.selectRows.splice(index, 1) | ||||||
|  |       } | ||||||
|  |       if (parentIndex !== -1){ | ||||||
|  |         const partListFlat = this.partList | ||||||
|  |             .map(([key, value]) => value) | ||||||
|  |             .reduce((acc, value) => acc.concat(value), []); | ||||||
|  |         this.$set(partListFlat, parentIndex, { ...partListFlat[parentIndex], isSelected: item.isSelected }); | ||||||
|  |         const updatedPartList = this.partList.map(([key, value]) => { | ||||||
|  |           const newValue = value.map(v => { | ||||||
|  |             const foundItem = partListFlat.find(f => f.id === v.id); | ||||||
|  |             return foundItem ? { ...v, ...foundItem } : v; | ||||||
|  |           }); | ||||||
|  |           return [key, newValue]; | ||||||
|  |         }); | ||||||
|  |         this.$set(this, 'partList', updatedPartList); | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     searchQuery() { | ||||||
|  |       this.getSoiId() | ||||||
|  |     }, | ||||||
|  |     getUnitName(id) { | ||||||
|  |       const index = this.unitList.findIndex(item => item.value === id) | ||||||
|  |       if (index !== -1) { | ||||||
|  |         return this.unitList[index].label | ||||||
|  |       } | ||||||
|  |       return "请选择" | ||||||
|  |     }, | ||||||
|  |     bindUnitChange(e, row) { | ||||||
|  |       const index = e.detail.value | ||||||
|  |       const choose = this.unitList[index] | ||||||
|  |       row.wares.unit = choose.value | ||||||
|  |     }, | ||||||
|  |     listUnit() { | ||||||
|  |       if (!getStorageWithExpiry("repair_unit")) { | ||||||
|  |         getDictTextByCodeAndValue("repair_unit", null) | ||||||
|  |       } | ||||||
|  |       this.unitList = getStorageWithExpiry("repair_unit") | ||||||
|  |     }, | ||||||
|  |     getServerName(id) { | ||||||
|  |       const index = this.options.findIndex(item => item.value === id) | ||||||
|  |       if (index !== -1) { | ||||||
|  |         return this.options[index].label | ||||||
|  |       } | ||||||
|  |       return "请选择" | ||||||
|  |     }, | ||||||
|  |     listServer() { | ||||||
|  |       request({ | ||||||
|  |         url: '/admin-api/conf/baseType/list', | ||||||
|  |         method: 'get', | ||||||
|  |         params: {type: '02'} | ||||||
|  |       }).then(res => { | ||||||
|  |         this.options = res.data.map(item => { | ||||||
|  |           return { | ||||||
|  |             label: item.name, | ||||||
|  |             value: item.id | ||||||
|  |           } | ||||||
|  |         }) | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     bindPickerChange(node, row) { | ||||||
|  |       const index = node.detail.value | ||||||
|  |       const choose = this.options[index] | ||||||
|  |       row.wares.type = choose.value | ||||||
|  |     }, | ||||||
|     /** |     /** | ||||||
|      * 查询供应商 |      * 查询供应商 | ||||||
|      */ |      */ | ||||||
| @ -129,14 +274,35 @@ export default { | |||||||
|      * 初始化配件数据 |      * 初始化配件数据 | ||||||
|      */ |      */ | ||||||
|     init() { |     init() { | ||||||
|       this.partList = [...this.wares.map(item => { |       request({ | ||||||
|         return { |         url: '/admin-api/repair/tickets/getCusAndCarById?id=' + this.formData.ticketId, | ||||||
|           ...item.wares, |         method: 'get' | ||||||
|           count: item.waresCount, |       }).then(res => { | ||||||
|           newPrice: item.wares.purPrice, |         this.carInfo = res.data.carInfo | ||||||
|           totalPrice: item.waresCount * item.wares.purPrice, |         if (this.carInfo.carBrand) { | ||||||
|  |           request({ | ||||||
|  |             url: '/admin-api/base/carBrand/get?id=' + this.carInfo.carBrand, | ||||||
|  |             method: 'get' | ||||||
|  |           }).then(res => { | ||||||
|  |             this.carInfo.carBrand = res.data.brandName | ||||||
|  |           }) | ||||||
|         } |         } | ||||||
|       })] |       }) | ||||||
|  |       const ids = this.wares.map(item => item.id) | ||||||
|  |       request({ | ||||||
|  |         url: "/admin-api/repair/tw/getByIds?ids=" + ids, | ||||||
|  |         method: 'get' | ||||||
|  |       }).then(res => { | ||||||
|  |         this.partList = Object.entries(res.data) | ||||||
|  |         const value = this.partList.map(([key, value]) => value) | ||||||
|  |         value.forEach(item => { | ||||||
|  |           item.forEach(i => { | ||||||
|  |             // i.count = i.waresCount | ||||||
|  |             // i.newPrice = i.wares.purPrice | ||||||
|  |             i.totalPrice = i.waresCount * i.wares.purPrice | ||||||
|  |           }) | ||||||
|  |         }) | ||||||
|  |       }) | ||||||
|     }, |     }, | ||||||
|     /** |     /** | ||||||
|      * |      * | ||||||
| @ -171,33 +337,34 @@ export default { | |||||||
|      */ |      */ | ||||||
|     submit() { |     submit() { | ||||||
|       const userInfo = getUserInfo() |       const userInfo = getUserInfo() | ||||||
|  |       const values = this.partList.map(([key, value]) => value).reduce((acc, value) => acc.concat(value)) | ||||||
|       const data = { |       const data = { | ||||||
|         soType: '01', |         soType: '01', | ||||||
|         purchaseType: '01', |         purchaseType: '01', | ||||||
|         soNo: createUniqueCodeByHead("CG"), |         soNo: createUniqueCodeByHead("CG"), | ||||||
|         userId: userInfo.id, |         userId: userInfo.id, | ||||||
|         userName: userInfo.nickname, |         userName: userInfo.nickname, | ||||||
|         itemCount: this.partList.length, |         itemCount: values.length, | ||||||
|         totalPrice: this.partList.reduce((x, y) => { |         totalPrice: values.reduce((x, y) => { | ||||||
|           return x + y.totalPrice |           return x + y.totalPrice | ||||||
|         }, 0), |         }, 0), | ||||||
|         soStatus: '03', |         soStatus: "03", | ||||||
|         remark: this.remark, |         remark: this.remark, | ||||||
|         supplierId: this.serviceId, |         supplierId: this.serviceId, | ||||||
|         supplierName: this.serviceName |         supplierName: this.serviceName | ||||||
|       } |       } | ||||||
|       data.goodsList = [...this.partList.map(item => { |       data.goodsList = [...values.map(item => { | ||||||
|         return { |         return { | ||||||
|           soiType: '01', |           soiType: '01', | ||||||
|           goodsId: item.id, |           goodsId: item.wares.id, | ||||||
|           goodsType: '0', |           goodsType: '0', | ||||||
|           wareId: item?.wareId, |           wareId: item.wares?.warehouse, | ||||||
|           goodsCount: item.count, |           goodsCount: item.waresCount, | ||||||
|           goodsPrice: item.newPrice, |           goodsPrice: item.wares.price, | ||||||
|           remark: item.remark |           remark: item.remark | ||||||
|         } |         } | ||||||
|       })] |       })] | ||||||
|       console.log(data) |       data.waresList = [...values.map(item => item.wares)] | ||||||
|       request({ |       request({ | ||||||
|         url: '/admin-api/repair/so/create', |         url: '/admin-api/repair/so/create', | ||||||
|         method: 'post', |         method: 'post', | ||||||
| @ -216,59 +383,85 @@ export default { | |||||||
|     }, |     }, | ||||||
|     getSoiId() { |     getSoiId() { | ||||||
|       request({ |       request({ | ||||||
|         url: '/admin-api/repair/so/get', |         url: '/admin-api/repair/soi/getMapBySoIdAndQuery?id=' + this.soId + "&query=" + this.query, | ||||||
|         method: 'get', |         method: 'get' | ||||||
|         params: { |       }).then(res => { | ||||||
|           id: this.soId |         this.partList = Object.entries(res.data) | ||||||
|  |         this.partList = this.partList.filter(([key, value]) => { | ||||||
|  |           const newValue = value.filter(item => item.inCount !== item.goodsCount) | ||||||
|  |           return newValue && newValue.length > 0 | ||||||
|  |         }) | ||||||
|  |         this.partList.forEach(([key, value]) => { | ||||||
|  |           value.forEach(item => { | ||||||
|  |             item.goodsCount = item.goodsCount - item?.inCount | 0 | ||||||
|  |             item.inCount = item.goodsCount - item?.inCount | 0 | ||||||
|  |           }) | ||||||
|  |         }) | ||||||
|  |         const values = this.partList.map(([key, value]) => value) | ||||||
|  |         if (!this.selectRows || this.selectRows.length === 0){ | ||||||
|  |           values.forEach(item => { | ||||||
|  |             item.forEach(i => { | ||||||
|  |               i.isSelected = false | ||||||
|  |             }) | ||||||
|  |           }) | ||||||
|  |         }else { | ||||||
|  |           values.forEach(item => { | ||||||
|  |             item.forEach(i => { | ||||||
|  |               i.isSelected = this.selectRows.findIndex(j => j.id === i.id) !== -1 | ||||||
|  |             }) | ||||||
|  |           }) | ||||||
|         } |         } | ||||||
|       }).then((res) => { // 将 `.then` 移到这里 |  | ||||||
|         console.log(res) |  | ||||||
|         res.data.goodsList.forEach(item => { |  | ||||||
|           this.soiIds.push(item.id) |  | ||||||
|         }) |  | ||||||
|         console.log('返回',res.data) |  | ||||||
| 
 |  | ||||||
|         request({ |  | ||||||
|           url: '/admin-api/repair/soi/get', |  | ||||||
|           method: 'get', |  | ||||||
|           params: { |  | ||||||
|             ids: this.soiIds.join(',') |  | ||||||
|           } |  | ||||||
|         }).then((res) => { // 同样这里也要移到外层括号后 |  | ||||||
|           console.log('配件信息', res.data) |  | ||||||
|           res.data.map(item => { |  | ||||||
|             item.wares = item.repairWares |  | ||||||
|             item.waresCount = 0 |  | ||||||
|           }) |  | ||||||
|           this.wares = res.data |  | ||||||
|           this.init() |  | ||||||
|         }) |  | ||||||
|       }) |       }) | ||||||
|  |       // request({ | ||||||
|  |       //   url: '/admin-api/repair/so/get', | ||||||
|  |       //   method: 'get', | ||||||
|  |       //   params: { | ||||||
|  |       //     id: this.soId | ||||||
|  |       //   } | ||||||
|  |       // }).then((res) => { // 将 `.then` 移到这里 | ||||||
|  |       //   // console.log(res) | ||||||
|  |       //   res.data.goodsList.forEach(item => { | ||||||
|  |       //     this.soiIds.push(item.id) | ||||||
|  |       //   }) | ||||||
|  |       //   console.log('返回', res.data) | ||||||
|  |       // | ||||||
|  |       //   request({ | ||||||
|  |       //     url: '/admin-api/repair/soi/get', | ||||||
|  |       //     method: 'get', | ||||||
|  |       //     params: { | ||||||
|  |       //       ids: this.soiIds.join(',') | ||||||
|  |       //     } | ||||||
|  |       //   }).then((res) => { // 同样这里也要移到外层括号后 | ||||||
|  |       //     console.log('配件信息', res.data) | ||||||
|  |       //     res.data.map(item => { | ||||||
|  |       //       item.wares = item.repairWares | ||||||
|  |       //       item.waresCount = 0 | ||||||
|  |       //     }) | ||||||
|  |       //     this.wares = res.data | ||||||
|  |       //     this.init() | ||||||
|  |       //   }) | ||||||
|  |       // }) | ||||||
|     }, |     }, | ||||||
|     /** |     /** | ||||||
|      * 入库 |      * 入库 | ||||||
|      */ |      */ | ||||||
|     inWare(){ |     inWare() { | ||||||
|       console.log('partList',this.partList) |       const data = { | ||||||
|       // this.partList.forEach(item => { |         id: this.soId, | ||||||
|       //   item.inCount = item.count |         soNo: createUniqueCodeByHead("RK") | ||||||
|       //   item.goodsId = item.id |       } | ||||||
|       //   // item.id = this.soiIds[0] |       if (this.selectRows && this.selectRows.length > 0){ | ||||||
|       //   }) |         data.soiList = [...this.selectRows] | ||||||
|       const copiedPartList = JSON.parse(JSON.stringify(this.partList)); |         data.waresList = [...this.selectRows.map(item => item.wares)] | ||||||
|       for (let i = 0; i < this.partList.length; i++) { |       }else { | ||||||
|         this.partList[i].inCount = this.partList[i].count |         const values = this.partList.map(([key, value]) => value).reduce((acc, item) => acc.concat(item)) | ||||||
|         this.partList[i].goodsId = copiedPartList[i].id |         data.soiList = [...values] | ||||||
|         this.partList[i].id = this.soiIds[i] |         data.waresList = [...values.map(item => item.wares)] | ||||||
|       } |       } | ||||||
|       console.log('partList',this.partList) |  | ||||||
|       request({ |       request({ | ||||||
|         url: '/admin-api/repair/so/inWare', |         url: '/admin-api/repair/so/inWare', | ||||||
|         method: 'post', |         method: 'post', | ||||||
|         data: { |         data: data | ||||||
|           id: this.soId, |  | ||||||
|           soiList: this.partList |  | ||||||
|         } |  | ||||||
|       }).then((res) => { |       }).then((res) => { | ||||||
|         if (res.code == 200) { |         if (res.code == 200) { | ||||||
|           uni.showToast({ |           uni.showToast({ | ||||||
| @ -280,6 +473,36 @@ export default { | |||||||
|           }, 700) |           }, 700) | ||||||
|         } |         } | ||||||
|       }) |       }) | ||||||
|  |       // this.partList.forEach(item => { | ||||||
|  |       //   item.inCount = item.count | ||||||
|  |       //   item.goodsId = item.id | ||||||
|  |       //   // item.id = this.soiIds[0] | ||||||
|  |       //   }) | ||||||
|  |       // const copiedPartList = JSON.parse(JSON.stringify(this.partList)); | ||||||
|  |       // for (let i = 0; i < this.partList.length; i++) { | ||||||
|  |       //   this.partList[i].inCount = this.partList[i].count | ||||||
|  |       //   this.partList[i].goodsId = copiedPartList[i].id | ||||||
|  |       //   this.partList[i].id = this.soiIds[i] | ||||||
|  |       // } | ||||||
|  |       // console.log('partList', this.partList) | ||||||
|  |       // request({ | ||||||
|  |       //   url: '/admin-api/repair/so/inWare', | ||||||
|  |       //   method: 'post', | ||||||
|  |       //   data: { | ||||||
|  |       //     id: this.soId, | ||||||
|  |       //     soiList: this.partList | ||||||
|  |       //   } | ||||||
|  |       // }).then((res) => { | ||||||
|  |       //   if (res.code == 200) { | ||||||
|  |       //     uni.showToast({ | ||||||
|  |       //       title: '入库成功!', | ||||||
|  |       //       icon: 'none' | ||||||
|  |       //     }) | ||||||
|  |       //     setTimeout(() => { | ||||||
|  |       //       uni.navigateBack() | ||||||
|  |       //     }, 700) | ||||||
|  |       //   } | ||||||
|  |       // }) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 xiaofajia
						xiaofajia