| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368 |
- <template>
- <div>
- <el-form ref="form" :model="form" :rules="rules" label-width="120px">
- <headerTitle title="发货信息"></headerTitle>
- <el-row :gutter="20">
- <el-col :span="12">
- <el-form-item
- label="选择订单"
- prop="orderNo"
- style="margin-bottom: 22px"
- >
- <el-input
- clearable
- v-model="form.orderNo"
- @click.native="handleOrderBtn"
- placeholder="请输入"
- />
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="外协单位"
- prop="contactName"
- style="margin-bottom: 22px"
- >
- <el-input v-model="form.supplierName" disabled></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="12">
- <el-form-item
- label="订单类型"
- prop="sourceTypeName"
- style="margin-bottom: 22px"
- >
- <el-input v-model="form.sourceTypeName" disabled></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="外协单位联系人"
- prop="linkName"
- style="margin-bottom: 22px"
- >
- <el-input clearable v-model="form.linkName" placeholder="请输入"/>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <!-- <el-col :span="12">
- <el-form-item
- label="计价方式"
- style="margin-bottom: 22px">
- <el-select v-model="form.pricingWay" disabled style="width: 100%">
- <el-option label="按数量计费" :value="1"></el-option>
- <el-option label="按重量计费" :value="2"></el-option>
- </el-select>
- </el-form-item>
- </el-col> -->
- <el-col :span="12">
- <el-form-item
- label="外协单位电话"
- prop="linkPhone"
- style="margin-bottom: 22px"
- >
- <el-input clearable v-model="form.linkPhone" placeholder="请输入"/>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="12">
- <el-form-item
- label="发货日期"
- prop="sendDate"
- style="margin-bottom: 22px">
- <el-date-picker
- v-model="form.sendDate"
- style="width: 100%"
- type="date"
- value-format="yyyy-MM-dd"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="发货单号"
- prop="sendNoteNo"
- style="margin-bottom: 22px"
- >
- <el-input
- clearable
- v-model="form.sendNoteNo"
- placeholder="请输入"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="12">
- <el-form-item label="车辆号" prop="carNo" style="margin-bottom: 22px">
- <el-input clearable v-model="form.carNo" placeholder="请输入"/>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item prop="files" label="附件">
- <fileMain v-model="form.files"></fileMain>
- <!-- <fileUpload-->
- <!-- v-model="form.files"-->
- <!-- module="main"-->
- <!-- :showLib="false"-->
- <!-- :limit="10"-->
- <!-- />-->
- </el-form-item>
- </el-col>
- <el-col :span="12">
- </el-col>
- </el-row>
- </el-form>
- <headerTitle title="物品清单" style="margin-top: 30px"></headerTitle>
- <inventoryTable
- :pricingWay="form.pricingWay"
- ref="inventoryTableref"
- :orderId="form.orderId"
- ></inventoryTable>
- <!-- 采购订单 -->
- <orderListDialog
- :searchParams="orderSearchParams"
- ref="orderListDialogRef"
- @changeParent="changeOrder"
- ></orderListDialog>
- </div>
- </template>
- <script>
- import fileUpload from '@/components/upload/fileUpload';
- import dictMixins from '@/mixins/dictMixins';
- import {
- savePurchaseOutSourceSendAPI,
- updatePurchaseOutSourceSendAPI,
- getPurchaseOutSourceSendDetailAPI,
- submit
- } from '@/api/bpm/components/purchasingManage/outSourceSend';
- // import {getcontactlink} from '@/api/saleManage/businessFollow';
- import inventoryTable from './inventoryTable.vue';
- import orderListDialog from '../invoice/orderListDialog.vue';
- import {copyObj} from '@/utils/util';
- import {getpurchaseorderDetail} from "@/api/bpm/components/purchasingManage/purchaseOrder";
- import fileMain from "@/components/addDoc/index.vue";
- export default {
- mixins: [dictMixins],
- components: {
- fileMain,
- fileUpload,
- inventoryTable,
- orderListDialog
- },
- props: {
- businessId: {
- default: ''
- }
- },
- data() {
- return {
- orderSearchParams: {
- sourceType: '3,4',
- },
- detailData: {},
- payWayOptions: [],
- delDetailIds: [],
- linkNameOptions: [],
- title: '',
- row: {},
- form: {
- id: '',
- carNo: '',
- files: [],
- linkName: '',
- linkPhone: '',
- orderId: '',
- orderNo: '',
- pricingWay: '',
- productList: [],
- sendNoteNo: '',
- sourceType: '',
- sourceTypeName: '',
- supplierId: '',
- supplierName: '',
- },
- rules: {
- partaName: [
- {required: true, message: '请选择客户名称', trigger: 'change'}
- ],
- linkName: [
- {required: true, message: '请输入', trigger: ['blur', 'change']}
- ],
- linkPhone: [
- {required: true, message: '请输入', trigger: ['blur', 'change']}
- ],
- orderNo: [
- {required: true, message: '请选择', trigger: 'change'}
- ],
- receiveAddress: [
- {required: true, message: '请输入', trigger: 'change'}
- ],
- },
- // 提交状态
- loading: false,
- };
- },
- async created() {
- await this.getSendSaleOrderDetail(this.businessId);
- },
- methods: {
- //选择订单弹框
- handleOrderBtn(e) {
- if (e.target.nodeName == 'I') {
- this.form = Object.assign({}, this.form, {
- supplierId: '',
- supplierName: '',
- linkName: '',
- linkPhone: '',
- orderNo: '',
- orderId: '',
- sourceTypeName: '',
- sourceType: '',
- productList: [],
- pricingWay: ''
- });
- this.$refs.inventoryTableref &&
- this.$refs.inventoryTableref.putTableValue([]);
- return
- }
- this.$refs.orderListDialogRef.open();
- },
- //选择订单回调
- changeOrder(obj) {
- this.getPurchaseOrderDetail(obj.id);
- },
- //获取订单详情
- async getPurchaseOrderDetail(id) {
- this.loading = true;
- const data = await getpurchaseorderDetail(id);
- this.loading = false;
- if (data) {
- this.$nextTick(() => {
- let {
- partbId,
- partbName,
- partbTel,
- orderNo,
- id,
- partbLinkName,
- productList,
- sourceTypeName,
- sourceType,
- pricingWay
- } = data;
- if (productList && productList.length > 0) {
- productList.forEach((v) => {
- v.orderTotalCount = v.orderTotalCount || v.totalCount;
- });
- }
- this.form = Object.assign({}, this.form, {
- supplierId: partbId,
- supplierName: partbName,
- linkName: partbLinkName,
- linkPhone: partbTel,
- orderNo,
- orderId: id,
- sourceTypeName,
- sourceType,
- productList,
- pricingWay
- });
- this.$refs.inventoryTableref &&
- this.$refs.inventoryTableref.putTableValue(productList);
- });
- }
- },
- //发货单详情
- async getSendSaleOrderDetail(id) {
- this.businessId = id;
- this.loading = true;
- const data = await getPurchaseOutSourceSendDetailAPI(id);
- this.loading = false;
- if (data) {
- this.$nextTick(() => {
- this.form = data;
- this.$refs.inventoryTableref &&
- this.$refs.inventoryTableref.putTableValue(data.productList);
- });
- }
- },
- getValidate() {
- return Promise.all([
- new Promise((resolve, reject) => {
- this.$refs.form.validate((valid) => {
- if (!valid) {
- reject(false);
- } else {
- resolve(true);
- }
- });
- }),
- new Promise((resolve, reject) => {
- this.$refs.inventoryTableref.validateForm((valid) => {
- if (!valid) {
- reject(false);
- } else {
- resolve(true);
- }
- });
- })
- ]);
- },
- async getTableValue() {
- return new Promise(async (resolve, reject) => {
- try {
- await this.getValidate();
- this.form.files = this.form.files || [];
- let commitData = Object.assign({}, this.form, {
- productList: this.$refs.inventoryTableref.getTableValue()
- });
- await updatePurchaseOutSourceSendAPI(commitData)
- resolve(true)
- } catch (error) {
- reject(false)
- // 表单验证未通过,不执行保存操作
- }
- })
- }
- }
- };
- </script>
- <style scoped lang="scss">
- .TotalAmount {
- font-size: 16px;
- padding-right: 30px;
- }
- .headbox {
- display: flex;
- justify-content: flex-start;
- align-items: center;
- .amount {
- font-size: 14px;
- font-weight: bold;
- margin-right: 20px;
- }
- }
- </style>
|