送货单,退货单,到货单等相关修整
							parent
							
								
									d8e914504c
								
							
						
					
					
						commit
						3d78d6252a
					
				@ -0,0 +1,394 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div>
 | 
				
			||||||
 | 
					    <el-card class="el-card">
 | 
				
			||||||
 | 
					      <el-form :model="listQuery" label-width="120px" v-show="showSearch">
 | 
				
			||||||
 | 
					        <el-row>
 | 
				
			||||||
 | 
					          <el-col :span="12">
 | 
				
			||||||
 | 
					            <el-form-item label="UDI码:" class="query-form-item">
 | 
				
			||||||
 | 
					              <el-input v-model="listQuery.udiCode" style="width: 96%" placeholder="请扫描或输入UDI码" clearable="true"
 | 
				
			||||||
 | 
					                        @keyup.enter.native="keyup_submit($event)"></el-input>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					          </el-col>
 | 
				
			||||||
 | 
					          <el-col :span="6">
 | 
				
			||||||
 | 
					            <el-form-item label="第三方产品编码:" class="query-form-item">
 | 
				
			||||||
 | 
					              <el-input v-model="listQuery.thrPiId" style="width: 90%" placeholder="请输入第三方产品编码"
 | 
				
			||||||
 | 
					                        clearable="true"></el-input>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					          </el-col>
 | 
				
			||||||
 | 
					        </el-row>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        <el-row>
 | 
				
			||||||
 | 
					          <el-col :span="6">
 | 
				
			||||||
 | 
					            <el-form-item label="物品编码:" class="query-form-item">
 | 
				
			||||||
 | 
					              <el-input v-model="listQuery.unionCode" style="width: 90%" placeholder="请输入DI/医保编码/商品条码"
 | 
				
			||||||
 | 
					                        clearable="true"></el-input>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					          </el-col>
 | 
				
			||||||
 | 
					          <el-col :span="6">
 | 
				
			||||||
 | 
					            <el-form-item label="产品通用名:" class="query-form-item">
 | 
				
			||||||
 | 
					              <el-input v-model="listQuery.cpmctymc" style="width: 90%" placeholder="请输入产品通用名"
 | 
				
			||||||
 | 
					                        clearable="true"></el-input>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					          </el-col>
 | 
				
			||||||
 | 
					          <el-col :span="6">
 | 
				
			||||||
 | 
					            <el-form-item label="规格型号:" class="query-form-item">
 | 
				
			||||||
 | 
					              <el-input v-model="listQuery.ggxh" style="width: 90%" placeholder="请输入规格型号" clearable="true"></el-input>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					          </el-col>
 | 
				
			||||||
 | 
					          <el-col :span="6">
 | 
				
			||||||
 | 
					            <el-form-item label="生产企业:" class="query-form-item">
 | 
				
			||||||
 | 
					              <el-input v-model="listQuery.ylqxzcrbarmc" style="width: 90%" placeholder="请输入生产企业/注册备案人"
 | 
				
			||||||
 | 
					                        clearable="true"></el-input>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					          </el-col>
 | 
				
			||||||
 | 
					        </el-row>
 | 
				
			||||||
 | 
					      </el-form>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      <div class="top-right-btn">
 | 
				
			||||||
 | 
					        <el-button-group style="display:flex;">
 | 
				
			||||||
 | 
					          <el-button icon="el-icon-view" type="primary" @click="hideSearch">显示/隐藏搜索栏</el-button>
 | 
				
			||||||
 | 
					          <el-button type="primary" icon="el-icon-refresh" @click="onReset">重置</el-button>
 | 
				
			||||||
 | 
					          <el-button type="primary" icon="el-icon-search" @click="search">查询</el-button>
 | 
				
			||||||
 | 
					          <el-button type="primary" icon="el-icon-plus" @click="confirmSelect">确定</el-button>
 | 
				
			||||||
 | 
					        </el-button-group>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <el-divider style="margin: 15px"></el-divider>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      <el-table :data="dataList" style="width: 100%" v-loading="loading" border highlight-current-row
 | 
				
			||||||
 | 
					                :row-class-name="tableRowClassName" @current-change="handleChange" ref="multipleTable">
 | 
				
			||||||
 | 
					        <el-table-column label width="45">
 | 
				
			||||||
 | 
					          <template slot-scope="scope">
 | 
				
			||||||
 | 
					            <el-radio :label="scope.row.id" v-model="radioCheck"><span></span></el-radio>
 | 
				
			||||||
 | 
					          </template>
 | 
				
			||||||
 | 
					        </el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="序号" type="index"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="最小销售产品标识" prop="nameCode" width="140" show-overflow-tooltip></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="产品编码" prop="thirdId" show-overflow-tooltip></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="医疗器械注册人" prop="ylqxzcrbarmc"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="产品通用名" prop="cpmctymc" show-overflow-tooltip></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="规格型号" prop="ggxh" show-overflow-tooltip></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="注册/备案凭证" prop="zczbhhzbapzbh" show-overflow-tooltip></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="器械类别" prop="qxlb" show-overflow-tooltip></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="配送企业" prop="companyName" show-overflow-tooltip></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="操作" width="160">
 | 
				
			||||||
 | 
					          <template slot-scope="scope">
 | 
				
			||||||
 | 
					            <el-button type="text" size="small" @click.native.stop="handleDetailClick(scope.row)">详情</el-button>
 | 
				
			||||||
 | 
					          </template>
 | 
				
			||||||
 | 
					        </el-table-column>
 | 
				
			||||||
 | 
					      </el-table>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      <pagination
 | 
				
			||||||
 | 
					        v-show="pageTotal>0"
 | 
				
			||||||
 | 
					        :total="pageTotal"
 | 
				
			||||||
 | 
					        :page.sync="listQuery.page"
 | 
				
			||||||
 | 
					        :limit.sync="listQuery.limit"
 | 
				
			||||||
 | 
					        @pagination="handleErpPageChange"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      ></pagination>
 | 
				
			||||||
 | 
					    </el-card>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <el-dialog
 | 
				
			||||||
 | 
					      title="耗材字典详情"
 | 
				
			||||||
 | 
					      :visible.sync="udiRlDetailVisible"
 | 
				
			||||||
 | 
					      width="80%"
 | 
				
			||||||
 | 
					      :close-on-click-modal="false"
 | 
				
			||||||
 | 
					      :close-on-press-escape="false"
 | 
				
			||||||
 | 
					      append-to-body
 | 
				
			||||||
 | 
					      v-if="udiRlDetailVisible"
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
 | 
					      <udiRlDetailDialog :editQuery="currentRow"></udiRlDetailDialog>
 | 
				
			||||||
 | 
					    </el-dialog>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <el-dialog title="请选择对应的资质证书" :visible.sync="dialogFormVisible" append-to-body width="40%">
 | 
				
			||||||
 | 
					      <el-form :model="form">
 | 
				
			||||||
 | 
					        <el-form-item label="" prop="isGive">
 | 
				
			||||||
 | 
					          <el-radio-group v-model="currentCert">
 | 
				
			||||||
 | 
					            <el-radio :label="item" :key="item" v-for="item in certList">{{ item }}</el-radio>
 | 
				
			||||||
 | 
					          </el-radio-group>
 | 
				
			||||||
 | 
					        </el-form-item>
 | 
				
			||||||
 | 
					      </el-form>
 | 
				
			||||||
 | 
					      <div slot="footer" class="dialog-footer">
 | 
				
			||||||
 | 
					        <el-button type="primary" @click="selectCert">确 定</el-button>
 | 
				
			||||||
 | 
					        <el-button @click="dialogFormVisible = false">取 消</el-button>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </el-dialog>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import {filterCompanyProductRelevance} from "../../../api/basic/udiRlSuptRelevance";
 | 
				
			||||||
 | 
					import {addOrderDetail} from "@/api/purchase/purArrival"
 | 
				
			||||||
 | 
					import udiRlDetailDialog from "./../../purchase/purApply/purUdiRlDetailDialog";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "stockOrderNewSelectProduct",
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    data: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    closeDialog: {
 | 
				
			||||||
 | 
					      type: Function,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    purType: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    pId: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    customerId: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      showSearch: true,
 | 
				
			||||||
 | 
					      listQuery: {
 | 
				
			||||||
 | 
					        purType: null,
 | 
				
			||||||
 | 
					        udiCode: null,
 | 
				
			||||||
 | 
					        unicode: null,
 | 
				
			||||||
 | 
					        cpmctymc: null,
 | 
				
			||||||
 | 
					        ggxh: null,
 | 
				
			||||||
 | 
					        ylqxzcrbarmc: null,
 | 
				
			||||||
 | 
					        thrPiId: null,
 | 
				
			||||||
 | 
					        page: 1,
 | 
				
			||||||
 | 
					        limit: 10,
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      combineQuery: {
 | 
				
			||||||
 | 
					        thirdId: "",
 | 
				
			||||||
 | 
					        relId: "",
 | 
				
			||||||
 | 
					        erpName: "",
 | 
				
			||||||
 | 
					        keys: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      ids: [],
 | 
				
			||||||
 | 
					      radioCheck: null,
 | 
				
			||||||
 | 
					      dataList: [],
 | 
				
			||||||
 | 
					      pageTotal: 1,
 | 
				
			||||||
 | 
					      total: 1,
 | 
				
			||||||
 | 
					      currentRow: null,
 | 
				
			||||||
 | 
					      loading: false,
 | 
				
			||||||
 | 
					      udiRlDetailVisible: false,
 | 
				
			||||||
 | 
					      thirdSys: [],
 | 
				
			||||||
 | 
					      thirdSysFk: null,
 | 
				
			||||||
 | 
					      busTypes: [],
 | 
				
			||||||
 | 
					      actDateRange: [],
 | 
				
			||||||
 | 
					      pickerOptions: {
 | 
				
			||||||
 | 
					        shortcuts: [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            text: "最近一周",
 | 
				
			||||||
 | 
					            onClick(picker) {
 | 
				
			||||||
 | 
					              const end = new Date();
 | 
				
			||||||
 | 
					              const start = new Date();
 | 
				
			||||||
 | 
					              start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
 | 
				
			||||||
 | 
					              picker.$emit("pick", [start, end]);
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            text: "最近一个月",
 | 
				
			||||||
 | 
					            onClick(picker) {
 | 
				
			||||||
 | 
					              const end = new Date();
 | 
				
			||||||
 | 
					              const start = new Date();
 | 
				
			||||||
 | 
					              start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
 | 
				
			||||||
 | 
					              picker.$emit("pick", [start, end]);
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            text: "最近三个月",
 | 
				
			||||||
 | 
					            onClick(picker) {
 | 
				
			||||||
 | 
					              const end = new Date();
 | 
				
			||||||
 | 
					              const start = new Date();
 | 
				
			||||||
 | 
					              start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
 | 
				
			||||||
 | 
					              picker.$emit("pick", [start, end]);
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      orderEditor: false,
 | 
				
			||||||
 | 
					      orderId: "",
 | 
				
			||||||
 | 
					      currentCert: null,
 | 
				
			||||||
 | 
					      certList: [],
 | 
				
			||||||
 | 
					      dialogFormVisible: false,
 | 
				
			||||||
 | 
					      multipleSelection: null,
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    onReset() {
 | 
				
			||||||
 | 
					      this.$router.push({
 | 
				
			||||||
 | 
					        path: "",
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					      this.listQuery = {
 | 
				
			||||||
 | 
					        purType: null,
 | 
				
			||||||
 | 
					        udiCode: null,
 | 
				
			||||||
 | 
					        unicode: null,
 | 
				
			||||||
 | 
					        cpmctymc: null,
 | 
				
			||||||
 | 
					        ggxh: null,
 | 
				
			||||||
 | 
					        ylqxzcrbarmc: null,
 | 
				
			||||||
 | 
					        thrPiId: null,
 | 
				
			||||||
 | 
					        page: 1,
 | 
				
			||||||
 | 
					        limit: 10
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.multipleSelection = [];
 | 
				
			||||||
 | 
					      this.radioCheck = null;
 | 
				
			||||||
 | 
					      this.currentRow = null;
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    hideSearch() {
 | 
				
			||||||
 | 
					      this.showSearch = !this.showSearch;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    tableRowClassName({row}) {
 | 
				
			||||||
 | 
					      if (row.checked) return "warning-row";
 | 
				
			||||||
 | 
					      return "";
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    checkSelectable(row) {
 | 
				
			||||||
 | 
					      return !row.check;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleCurrentChange(val) {
 | 
				
			||||||
 | 
					      this.unionQuery.page = val;
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleChange(val) {
 | 
				
			||||||
 | 
					      this.radioCheck = val.id;
 | 
				
			||||||
 | 
					      this.currentRow = val;
 | 
				
			||||||
 | 
					      this.multipleSelection = val
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleDetailClick(row) {
 | 
				
			||||||
 | 
					      this.currentRow = row;
 | 
				
			||||||
 | 
					      this.udiRlDetailVisible = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleErpPageChange(val) {
 | 
				
			||||||
 | 
					      this.listQuery.page = val.page;
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    keyup_submit(event) {
 | 
				
			||||||
 | 
					      this.listQuery.page = 1;
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					      event.target.select();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    search() {
 | 
				
			||||||
 | 
					      this.listQuery.page = 1;
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getList() {
 | 
				
			||||||
 | 
					      this.loading = true;
 | 
				
			||||||
 | 
					      this.listQuery.customerId = this.customerId;
 | 
				
			||||||
 | 
					      filterCompanyProductRelevance(this.listQuery)
 | 
				
			||||||
 | 
					        .then((response) => {
 | 
				
			||||||
 | 
					          this.loading = false;
 | 
				
			||||||
 | 
					          if (response.code === 20000) {
 | 
				
			||||||
 | 
					            this.dataList = response.data.list || [];
 | 
				
			||||||
 | 
					            this.pageTotal = response.data.total || 0;
 | 
				
			||||||
 | 
					          } else {
 | 
				
			||||||
 | 
					            this.$message.error(response.message);
 | 
				
			||||||
 | 
					            this.dataList = [];
 | 
				
			||||||
 | 
					            this.pageTotal = 0;
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        .catch(() => {
 | 
				
			||||||
 | 
					          this.loading = false;
 | 
				
			||||||
 | 
					          this.dataList = [];
 | 
				
			||||||
 | 
					          this.pageTotal = 0;
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    intentBack() {
 | 
				
			||||||
 | 
					      this.closeDialog();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    confirmSelect() {
 | 
				
			||||||
 | 
					      if (this.multipleSelection == null) {
 | 
				
			||||||
 | 
					        this.$message.error('未选择产品');
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      if (this.ids.length > 0) {
 | 
				
			||||||
 | 
					        for (var i = 0; i < this.ids.length; i++) {
 | 
				
			||||||
 | 
					          if (this.ids[i] == this.multipleSelection.rlId) {
 | 
				
			||||||
 | 
					            this.$message.error("该产品已录入!");
 | 
				
			||||||
 | 
					            return
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      let str = this.multipleSelection.zczbhhzbapzbh;
 | 
				
			||||||
 | 
					      if (str.search(",") != -1) {
 | 
				
			||||||
 | 
					        this.currentCert = null;
 | 
				
			||||||
 | 
					        this.certList = str.split(',');
 | 
				
			||||||
 | 
					        this.dialogFormVisible = true;
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.combine();
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    combine() {
 | 
				
			||||||
 | 
					      this.loading = true;
 | 
				
			||||||
 | 
					      let tQuery = {
 | 
				
			||||||
 | 
					        productId: this.multipleSelection.rlId,
 | 
				
			||||||
 | 
					        productName: this.multipleSelection.cpmctymc,
 | 
				
			||||||
 | 
					        count: 1,
 | 
				
			||||||
 | 
					        orderIdFk: this.pId,
 | 
				
			||||||
 | 
					        supId: this.multipleSelection.customerId,
 | 
				
			||||||
 | 
					        zczbhhzbapzbh: this.multipleSelection.zczbhhzbapzbh
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					      addOrderDetail(tQuery).then((response) => {
 | 
				
			||||||
 | 
					        this.loading = false;
 | 
				
			||||||
 | 
					        if (response.code === 20000) {
 | 
				
			||||||
 | 
					          this.closeDialog(response.data);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          if (response.code == 601) {
 | 
				
			||||||
 | 
					            this.$alert(response.message, "提示", {
 | 
				
			||||||
 | 
					              confirmButtonText: "确定",
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					          } else
 | 
				
			||||||
 | 
					            this.$message.error(response.message);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }).catch(() => {
 | 
				
			||||||
 | 
					        this.loading = false;
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    selectCert() {
 | 
				
			||||||
 | 
					      if (this.currentCert == null) {
 | 
				
			||||||
 | 
					        this.$message.error("请先选择对应的注册证!");
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.multipleSelection.zczbhhzbapzbh = this.currentCert;
 | 
				
			||||||
 | 
					        this.combine();
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  components: {udiRlDetailDialog},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  created() {
 | 
				
			||||||
 | 
					    console.log(this.data)
 | 
				
			||||||
 | 
					    if (this.$isNotBlank(this.data)) {
 | 
				
			||||||
 | 
					      this.ids = [];
 | 
				
			||||||
 | 
					      if (this.data.stockOrderLists.length > 0) {
 | 
				
			||||||
 | 
					        for (var i = 0; i < this.data.stockOrderLists.length; i++) {
 | 
				
			||||||
 | 
					          this.ids.push(this.data.stockOrderLists[i].productId);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					div /deep/ .el-table .warning-row {
 | 
				
			||||||
 | 
					  background: #bebebe;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					div /deep/ .el-table .success-row {
 | 
				
			||||||
 | 
					  background: #ffffff;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
@ -0,0 +1,251 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div>
 | 
				
			||||||
 | 
					    <el-card>
 | 
				
			||||||
 | 
					      <el-form :model="filterQuery" size="mini" label-width="100px" v-show="showSearch">
 | 
				
			||||||
 | 
					        <el-row>
 | 
				
			||||||
 | 
					          <el-col :span="6">
 | 
				
			||||||
 | 
					            <el-form-item label="产品标识DI:">
 | 
				
			||||||
 | 
					              <el-input v-model="filterQuery.nameCode" style="width: 90%" placeholder="产品标识DI"></el-input>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					          </el-col>
 | 
				
			||||||
 | 
					          <el-col :span="6">
 | 
				
			||||||
 | 
					            <el-form-item label="产品名称:">
 | 
				
			||||||
 | 
					              <el-input v-model="filterQuery.cpmctymc" style="width: 90%" placeholder="产品名称"></el-input>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					          </el-col>
 | 
				
			||||||
 | 
					          <el-col :span="6">
 | 
				
			||||||
 | 
					            <el-form-item label="批次号:">
 | 
				
			||||||
 | 
					              <el-input v-model="filterQuery.batchNo" style="width: 90%" placeholder="批次号"></el-input>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					          </el-col>
 | 
				
			||||||
 | 
					        </el-row>
 | 
				
			||||||
 | 
					      </el-form>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      <div class="top-right-btn">
 | 
				
			||||||
 | 
					        <el-button-group style="display:flex;">
 | 
				
			||||||
 | 
					          <el-button icon="el-icon-view" type="primary" @click="hideSearch">显示/隐藏搜索栏</el-button>
 | 
				
			||||||
 | 
					          <el-button type="primary" icon="el-icon-refresh" @click="onReset">重置</el-button>
 | 
				
			||||||
 | 
					          <el-button type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button>
 | 
				
			||||||
 | 
					          <el-button type="primary" icon="el-icon-plus" @click="combine">确定</el-button>
 | 
				
			||||||
 | 
					        </el-button-group>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      <el-divider style="margin: 15px"></el-divider>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      <el-table v-loading="loading" :data="list" style="width: 100%" highlight-current-row="false" border
 | 
				
			||||||
 | 
					                :row-class-name="tableRowClassName" @current-change="handleChange"
 | 
				
			||||||
 | 
					                ref="multipleTable">
 | 
				
			||||||
 | 
					        <el-table-column label width="45">
 | 
				
			||||||
 | 
					          <template slot-scope="scope">
 | 
				
			||||||
 | 
					            <el-radio :label="scope.row.id" v-model="radioCheck"><span></span></el-radio>
 | 
				
			||||||
 | 
					          </template>
 | 
				
			||||||
 | 
					        </el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="序号" type="index"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="产品标识" prop="nameCode"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="产品名称" prop="cpmctymc">
 | 
				
			||||||
 | 
					        </el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="规格型号" prop="ggxh"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="批次号" prop="batchNo"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="生产日期" prop="productionDate"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="失效日期" prop="expireDate"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="入库数量" prop="inCount"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="出库数量" prop="outCount"></el-table-column>
 | 
				
			||||||
 | 
					        <el-table-column label="结余数量" prop="reCount"></el-table-column>
 | 
				
			||||||
 | 
					      </el-table>
 | 
				
			||||||
 | 
					    </el-card>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <pagination
 | 
				
			||||||
 | 
					      v-show="total>0"
 | 
				
			||||||
 | 
					      :total="total"
 | 
				
			||||||
 | 
					      :limit.sync="filterQuery.limit"
 | 
				
			||||||
 | 
					      :page.sync="filterQuery.page"
 | 
				
			||||||
 | 
					      @pagination="handleCurrentChange"
 | 
				
			||||||
 | 
					    ></pagination>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
					  getInvProduct,
 | 
				
			||||||
 | 
					} from "@/api/inventory/invPorduct";
 | 
				
			||||||
 | 
					import {addOrderDetail} from "@/api/purchase/purReturned";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "DialogInvProduct",
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    closeDialog: {
 | 
				
			||||||
 | 
					      type: Function,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    invQueryData: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    pId: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    customerId: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    invCode: {},
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      showSearch: true,
 | 
				
			||||||
 | 
					      filterQuery: {
 | 
				
			||||||
 | 
					        cpmctymc: null,
 | 
				
			||||||
 | 
					        nameCode: null,
 | 
				
			||||||
 | 
					        relIdFk: null,
 | 
				
			||||||
 | 
					        batchNo: null,
 | 
				
			||||||
 | 
					        page: 1,
 | 
				
			||||||
 | 
					        limit: 10,
 | 
				
			||||||
 | 
					        customerId: null,
 | 
				
			||||||
 | 
					        supId: null,
 | 
				
			||||||
 | 
					        unitFk: null,
 | 
				
			||||||
 | 
					        invCode: this.invCode,
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      detailQuery: {
 | 
				
			||||||
 | 
					        code: null,
 | 
				
			||||||
 | 
					        productIdFk: null,
 | 
				
			||||||
 | 
					        page: 1,
 | 
				
			||||||
 | 
					        limit: 20,
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      list: [],
 | 
				
			||||||
 | 
					      radioCheck: null,
 | 
				
			||||||
 | 
					      total: 0,
 | 
				
			||||||
 | 
					      loading: true,
 | 
				
			||||||
 | 
					      index: null,
 | 
				
			||||||
 | 
					      dialogTableVisible: false,
 | 
				
			||||||
 | 
					      formLoading: false,
 | 
				
			||||||
 | 
					      dialogVisible: false,
 | 
				
			||||||
 | 
					      deleteLoading: false,
 | 
				
			||||||
 | 
					      busTypes: [],
 | 
				
			||||||
 | 
					      idQuery: null,
 | 
				
			||||||
 | 
					      showSup: false,
 | 
				
			||||||
 | 
					      fromOptions: [],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  components: {},
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    onReset() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      this.$router.push({
 | 
				
			||||||
 | 
					        path: "",
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					      this.filterQuery = {
 | 
				
			||||||
 | 
					        cpmctymc: null,
 | 
				
			||||||
 | 
					        nameCode: null,
 | 
				
			||||||
 | 
					        relIdFk: null,
 | 
				
			||||||
 | 
					        batchNo: null,
 | 
				
			||||||
 | 
					        customerId: null,
 | 
				
			||||||
 | 
					        unitFk: null,
 | 
				
			||||||
 | 
					        supId: null,
 | 
				
			||||||
 | 
					        page: 1,
 | 
				
			||||||
 | 
					        limit: 10,
 | 
				
			||||||
 | 
					        invCode: this.invCode,
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    onSubmit() {
 | 
				
			||||||
 | 
					      this.loading = true;
 | 
				
			||||||
 | 
					      this.filterQuery.page = 1;
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleSizeChange(val) {
 | 
				
			||||||
 | 
					      this.filterQuery.limit = val;
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleCurrentChange(val) {
 | 
				
			||||||
 | 
					      this.filterQuery.page = val.page;
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    closeDetailDialog(val) {
 | 
				
			||||||
 | 
					      this.codeDetailVisible = false;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    getList() {
 | 
				
			||||||
 | 
					      this.loading = true;
 | 
				
			||||||
 | 
					      this.filterQuery.supId = this.customerId
 | 
				
			||||||
 | 
					      getInvProduct(this.filterQuery)
 | 
				
			||||||
 | 
					        .then((response) => {
 | 
				
			||||||
 | 
					          this.showSup = response.data.showSup;
 | 
				
			||||||
 | 
					          this.loading = false;
 | 
				
			||||||
 | 
					          this.list = response.data.list || [];
 | 
				
			||||||
 | 
					          this.total = response.data.total || 0;
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        .catch(() => {
 | 
				
			||||||
 | 
					          this.loading = false;
 | 
				
			||||||
 | 
					          this.list = [];
 | 
				
			||||||
 | 
					          this.total = 0;
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    hideSearch() {
 | 
				
			||||||
 | 
					      this.showSearch = !this.showSearch;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    combine() {
 | 
				
			||||||
 | 
					      this.loading = true;
 | 
				
			||||||
 | 
					      let tQuery = {
 | 
				
			||||||
 | 
					        productId: this.multipleSelection.relIdFk,
 | 
				
			||||||
 | 
					        productName: this.multipleSelection.cpmctymc,
 | 
				
			||||||
 | 
					        count: 1,
 | 
				
			||||||
 | 
					        orderIdFk: this.pId,
 | 
				
			||||||
 | 
					        supId: this.multipleSelection.customerId,
 | 
				
			||||||
 | 
					        zczbhhzbapzbh: this.multipleSelection.zczbhhzbapzbh
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					      addOrderDetail(tQuery).then((response) => {
 | 
				
			||||||
 | 
					        this.loading = false;
 | 
				
			||||||
 | 
					        if (response.code === 20000) {
 | 
				
			||||||
 | 
					          this.closeDialog(response.data);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          if (response.code == 601) {
 | 
				
			||||||
 | 
					            this.$alert(response.message, "提示", {
 | 
				
			||||||
 | 
					              confirmButtonText: "确定",
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					          } else
 | 
				
			||||||
 | 
					            this.$message.error(response.message);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }).catch(() => {
 | 
				
			||||||
 | 
					        this.loading = false;
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    tableRowClassName({row}) {
 | 
				
			||||||
 | 
					      if (row.checked) return "warning-row";
 | 
				
			||||||
 | 
					      return "";
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    checkSelectable(row) {
 | 
				
			||||||
 | 
					      return !row.check;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleChange(val) {
 | 
				
			||||||
 | 
					      this.radioCheck = val.id;
 | 
				
			||||||
 | 
					      this.currentRow = val;
 | 
				
			||||||
 | 
					      this.multipleSelection = val
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  filters: {
 | 
				
			||||||
 | 
					    statusFilterType(status) {
 | 
				
			||||||
 | 
					      const statusMap = {
 | 
				
			||||||
 | 
					        false: "success",
 | 
				
			||||||
 | 
					        true: "danger",
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					      return statusMap[status];
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    document.body.ondrop = function (event) {
 | 
				
			||||||
 | 
					      event.preventDefault();
 | 
				
			||||||
 | 
					      event.stopPropagation();
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  created() {
 | 
				
			||||||
 | 
					    // 加载表格数据
 | 
				
			||||||
 | 
					    this.getList();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style type="text/scss" lang="scss">
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
					Loading…
					
					
				
		Reference in New Issue