<template> <section class="goods pagex"> <div class="goods-con"> <el-form :inline="true" :model="formParam" label-width="95px" ref="ruleForm"> <el-form-item> <el-button type="primary" @click="submit('ruleForm')">提交</el-button> <el-button @click="canel">取消</el-button> </el-form-item> <div class="tip-title" style="margin-top: 0"> <p>基本信息</p> </div> <el-form-item label="物流公司:"> <el-select v-model="formParam.shipping_id" placeholder="请选择" prop="shipping_id"> <el-option value="13" label="联邦快递"></el-option> <el-option value="12" label="DHL国际快递"></el-option> <el-option value="1" label="顺丰速运"></el-option> <el-option value="100" label="供应商配送"></el-option> <el-option value="4" label="快递送货"></el-option> <el-option value="5" label="韵达快递"></el-option> <el-option value="8" label="速尔快递"></el-option> <el-option value="9" label="TNT快递"></el-option> <el-option value="10" label="自提"></el-option> <el-option value="11" label="京东快递"></el-option> <el-option value="15" label="优速物流"></el-option> <el-option value="16" label="顺丰特惠"></el-option> <el-option value="17" label="UPS"></el-option> </el-select> </el-form-item> <el-form-item label="物流单号:"> <el-input v-model="formParam.shipment_number" placeholder="请输入物流单号"></el-input> </el-form-item> <el-form-item label="发货时间:"> <el-date-picker v-model="formParam.delivery_time" type="date" placeholder="请选择发货时间" value-format="yyyy-MM-dd" :picker-options="pickerOption"></el-date-picker> </el-form-item> <el-form-item label="订货公司:"> <span v-if="purOrderDetail.purchase_info">{{ purOrderDetail.purchase_info.company_name }}</span> </el-form-item> <el-form-item label="订单人员:"> <span v-if="purOrderDetail.purchase_info">{{ purOrderDetail.purchase_info.purchase_name }}</span> </el-form-item> <div class="tip-title"> <p>发货信息</p> </div> </el-form> <div class="data-box th-all"> <el-table :data="purOrderDetail.purchase_item_list" border max-height="600" @selection-change="handleSelectionChange"> <el-table-column fixed type="selection" width="40"></el-table-column> <el-table-column prop="goods_name" label="型号" min-width="15%"></el-table-column> <el-table-column prop="brand_name" label="品牌" min-width="15%"></el-table-column> <el-table-column prop="out_qty" label="发货数量" min-width="15%"> <template slot-scope="scope"> <el-input v-model="itemlist[scope.$index].out_qty" placeholder="请输入内容"></el-input> </template> </el-table-column> <el-table-column prop="no_out_qty" label="未发货数量" min-width="15%"></el-table-column> <el-table-column prop="out_qty" label="已发货数量" min-width="15%"></el-table-column> <el-table-column prop="purchase_qty" label="订单数量" min-width="15%"></el-table-column> <el-table-column prop="price_in_tax" label="单价" min-width="15%"></el-table-column> <el-table-column prop="total_amount" label="小计" min-width="15%"></el-table-column> </el-table> </div> </div> <Menu></Menu> </section> </template> <script> import Vue from 'vue'; import Menu from "@/components/menu.vue"; import {Autocomplete, Button, Cascader, DatePicker, Dialog, Form, FormItem, Input, Message, Option, Pagination, Select, Table, TableColumn} from 'element-ui' Vue.prototype.$message = Message; Vue.use(Button).use(Form).use(Select).use(Option).use(Input).use(FormItem).use(Dialog).use(Pagination).use(DatePicker); Vue.use(TableColumn).use(Table).use(Cascader).use(Autocomplete); export default { name: "orderTrackPurAdd", data() { return { purOrderDetail: {},//基本信息,发货信息 purchase_uid: '', multipleSelection: [],//选中的数据 pickerOption: { disabledDate(time) { return time.getTime() < Date.now() - 8.64e7; } }, itemlist: [], formParam: { company_id: '', shipping_id: '', shipment_number: '', delivery_time: '', itemlist: [] } }; }, created() { this.purchase_uid = this.$route.query.purchase_id; this.getData(); }, methods: { getData() { this.$http('POST', "/api/purchase/purOrderDetail", { id: this.purchase_uid }).then(res => { if (res.code === 0) { this.purOrderDetail = res.data; this.formParam.company_id = res.data.purchase_info.company_id; //组装formParam for (let i = 0; i < res.data.purchase_item_list.length; i++) { this.itemlist.push({ "purchase_item_id": res.data.purchase_item_list[i].purchase_item_id, "purchase_id": res.data.purchase_item_list[i].purchase_id, "out_qty": res.data.purchase_item_list[i].purchase_qty - res.data.purchase_item_list[i].out_qty }) } } else { this.$message({ message: res.msg, type: 'warning' }); } }) }, handleCurrentChange(val) { this.page = val; this.getData(); }, handleSelectionChange(val) { this.multipleSelection = val; }, submit(formName) { var self = this; this.$refs[formName].validate((valid) => { if (valid) { if (this.multipleSelection.length <= 0) { this.$message({ message: "请选择发货信息", type: 'warning' }); return false; } let filterArr = []; for (let i = 0; i < this.itemlist.length; i++) { for (let j = 0; j < this.multipleSelection.length; j++) { if (this.multipleSelection[j].purchase_item_id == this.itemlist[i].purchase_item_id) { filterArr.push(this.itemlist[i]) } } } this.formParam.itemlist = filterArr; this.$http('POST', "/api/purchase/addSupDelivery", this.formParam).then(res => { if (res.code === 0) { this.$message({ message: res.msg, type: 'success', duration: 2000, onClose() { document.querySelector('.item-boxs a.act .iconfont').click(); self.$router.push({ path: "/orderTrackGoods" }) } }); } else { this.$message({ message: res.msg, type: 'error' }); } }) } else { console.log('error submit!!'); return false; } }); }, canel() { document.querySelector('.item-boxs a.act .iconfont').click(); setTimeout(() => { this.$router.push({ path: "/orderTrackGoods" }) }, 1000) } }, components: { Menu } }; </script> <style scoped> @import "../../assets/css/goods/goods.min.css"; </style>