送货单,退货单,到货单等相关修整
							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