haoxuan
2023-08-28 6365989d130a8f5e222687b7441aa19a8b5eb9d6
采购单联调
1个文件已添加
1 文件已重命名
5个文件已修改
511 ■■■■■ 已修改文件
src/api/data.js 26 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/purchaseManage/purchase.js 98 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/purchaseManage/purchase/DetailSupplier.vue 56 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/purchaseManage/purchase/components/AddPurchase.vue 201 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/purchaseManage/purchase/components/SelectSupplierDialog.vue 52 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/purchaseManage/purchase/index.vue 76 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
vue.config.js 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/data.js
New file
@@ -0,0 +1,26 @@
// 采购状态
const purchaseStatus=[
  {
    name:'已下单',
    id:1,
  },
  {
    name:'到货质检',
    id:2,
  },
  {
    name:'已入库',
    id:3,
  },
  {
    name:'已完成',
    id:4,
  },
]
export const getDataByType = type => {
  if(type =='purchaseStatus'){
    return purchaseStatus;
  }
}
src/api/purchaseManage/purchase.js
@@ -1 +1,97 @@
// import request from "@/common/untils/request.js"
import request from "@/common/untils/request.js"
import axios from "axios"
// 销售线索列表
export function getSalesLeadsList(data) {
  return request({
    url: "/api/salesLeads/list",
    method: "post",
    data
  })
}
// 添加销售线索
export function getAddSalesLeads(data) {
  return request({
    url: "/api/salesLeads/add",
    method: "post",
    data
  })
}
// 删除销售线索
export function getDeleteSalesLeads(data) {
  return request({
    url: "/api/salesLeads/delete",
    method: "delete",
    data
  })
}
// 更新销售线索
export function getUpdateSalesLeads(data) {
  return request({
    url: "/api/salesLeads/update",
    method: "put",
    data
  })
}
// 推进销售线索
export function pushSalesSources(data) {
  return request({
    url: "/api/salesLeads/push",
    method: "post",
    data
  })
}
// 商机来源列表
export function getSalesSourcesList() {
  return request({
    url: "/api/salesSources/list",
    method: "get"
  })
}
// 采购单列表
export const getPurchaseList = async (data) => {
    return await axios.get(`/api/purchase/purchaseList`, {
      params: data
    })
  }
// 创建采购单
export function addPurchase(data) {
    return request({
      url: "/api/purchase/purchase",
      method: "post",
      data
    })
  }
// 更新采购单
export function updatePurchase(data) {
    return request({
      url: "/api/purchase/purchase",
      method: "put",
      data
    })
  }
//   获取采购单信息
export function getPurchaseInfo(data) {
    return request({
      url: "/api/purchase/purchase/"+data.id,
      method: "get",
      data
    })
  }
  //  删除采购单信息
export function deletePurchase(data) {
    return request({
      url: "/api/purchase/purchase/"+data.id,
      method: "delete",
      data
    })
  }
//   提交采购单
export function submitPurchase(data) {
    return request({
      url: "/api/purchase/submit/"+data.id,
      method: "post",
      data
    })
  }
src/views/purchaseManage/purchase/DetailSupplier.vue
@@ -152,7 +152,7 @@
</template>
<script>
import { getDeleteSalesLeads } from "@/api/client/salesLead";
import { deletePurchase } from "@/api/purchaseManage/purchase";
export default {
  name: "DetailSupplier",
  props: {
@@ -177,7 +177,6 @@
      basicInfoList: [],
      isDynamicExpand: true, // 账户信息
      dynamicInfoList: [],
      addConfig: {},
      record: "", // 最新进展
      noContactDays: 0,
      newContactDays: "",
@@ -193,13 +192,7 @@
  },
  created() {
    this.setData(this.detailConfig.infomation);
    this.addConfig = {
      id_name: "sales_leads_id",
      id: this.detailConfig.infomation.id,
      common_name: this.detailConfig.infomation.id,
      sales_leads_name: this.detailConfig.infomation.name,
      sales_leads_id: this.detailConfig.infomation.id,
    };
  },
  mounted() {},
  computed: {},
@@ -214,10 +207,11 @@
        type: "warning",
      })
        .then(() => {
          getDeleteSalesLeads({ ids: this.selValueList }).then((response) => {
          deletePurchase({ id: this.commonDetail.infomation.ID }).then((response) => {
            if (response.code === 200) {
              this.$message.success("删除成功");
              this.getData();
              this.detailConfig.visible=false;
              this.$parent.getData();
            } else {
              this.$message.warning("删除失败");
            }
@@ -227,16 +221,13 @@
    },
    setData(item) {
      if (item.FollowRecord && item.FollowRecord.length > 0) {
        this.record = item.FollowRecord[0].record;
        console.log(item.FollowRecord[0].follow_time);
        let follow_time = item.FollowRecord[0].follow_time;
        this.newContactDays = follow_time.substring(0, 10);
        this.noContactDays = this.getDiffDay(Date.now(), this.newContactDays);
      }
      this.record =item.record?item.record:''
      this.formInfoList = [
        {
          str: "供应商名称",
          value: "",
          value: item.name,
        },
        {
          str: "合计",
@@ -252,7 +243,7 @@
        },
        {
          str: "签约日期",
          value: "",
          value:item.signingDate,
        },
        {
          str: "采购负责人",
@@ -282,15 +273,15 @@
        },
        {
          leftStr: "采购联系人",
          leftValue: item.contact_phone,
          leftValue: item.contact,
          rightStr: "联系电话",
          rightValue: "18513375588",
          rightValue:  item.phone,
        },
        {
          leftStr: "签约日期",
          leftValue: item.sales_resources,
          leftValue: item.signingDate,
          rightStr: "交付日期",
          rightValue: item.member_name,
          rightValue: item.deliveryDate,
        },
        {
          leftStr: "到货仓库",
@@ -320,22 +311,17 @@
        },
      ];
      this.tableList = {
        tableInfomation: [
            {
            number:1,
            total:1,
          }
        ],
        tableInfomation: item.productList?item.productList:[],
        selectIndex: true,
        tableColumn: [
          { label: "产品名称", prop: "number", min: 190, isCommonClick: true },
          { label: "产品编码", prop: "total", min: 130, isCommonClick: true },
          { label: "计量单位", prop: "contact_name", min: 130 },
          { label: "规格型号", prop: "contact_phone", min: 130 },
          { label: "数量", prop: "contact_phone", min: 130 },
          { label: "销售单价", prop: "sales_resources", min: 130 },
          { label: "价税合计", prop: "province", min: 130 },
          { label: "描述", prop: "province", min: 130 },
          { label: "产品名称", prop: "name", min: 190, isCommonClick: true },
          { label: "产品编码", prop: "number", min: 130, isCommonClick: true },
          { label: "计量单位", prop: "unit", min: 130 },
          { label: "规格型号", prop: "specifications", min: 130 },
          { label: "数量", prop: "amount", min: 130 },
          { label: "销售单价", prop: "price", min: 130 },
          { label: "价税合计", prop: "total", min: 130 },
          { label: "描述", prop: "remark", min: 130 },
        ],
      };
    },
src/views/purchaseManage/purchase/components/AddPurchase.vue
@@ -3,7 +3,7 @@
    <el-dialog
      :title="editCommonConfig.title + '采购单'"
      :visible.sync="editConfig.visible"
      :width="dialogWidth"
      width="50%"
      :before-close="handleClose"
      append-to-body
      custom-class="iframe-dialog"
@@ -26,12 +26,12 @@
              <el-col :span="12">
                <el-form-item
                  label="采购类型"
                  prop="brand"
                  prop="purchaseTypeId"
                  class="form-item float_left"
                >
                  <el-select
                    placeholder="请选择采购类型"
                    v-model="editConfig.infomation.client_name"
                    v-model="editConfig.infomation.purchaseTypeId"
                    clearable
                    style="width: calc(100% - 30px)"
                  >
@@ -51,11 +51,11 @@
              </el-col>
              <el-col :span="12">
                <el-form-item label="供应商名称" prop="client_name">
                <el-form-item label="供应商名称" prop="supplierName">
                  <div class="custom-name">
                    <el-autocomplete
                      style="width: calc(100% - 40px)"
                      v-model="editConfig.infomation.client_name"
                      v-model="editConfig.infomation.supplierName"
                      :fetch-suggestions="
                        (queryString, callback) => {
                          querySearchAsync(queryString, callback, 'client');
@@ -73,8 +73,8 @@
                    </div>
                    <div
                      v-if="
                        editConfig.infomation.client_name &&
                        editConfig.infomation.client_name.length > 0
                        editConfig.infomation.supplierName &&
                        editConfig.infomation.supplierName.length > 0
                      "
                      class="common-select-btn"
                      @click="clearupClient('client')"
@@ -88,40 +88,45 @@
                <el-form-item label="单据来源" prop="number">
                  <el-input
                    v-model="editConfig.infomation.number"
                    disabled
                    placeholder="请填写"
                  ></el-input>
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="采购单名称" prop="number">
                <el-form-item label="采购单名称" prop="name">
                  <el-input
                    v-model="editConfig.infomation.number"
                    v-model="editConfig.infomation.name"
                    placeholder="请填写"
                    clearable
                  ></el-input>
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="供应商联系人" prop="number">
                <el-form-item label="供应商联系人" prop="contact">
                  <el-input
                    v-model="editConfig.infomation.number"
                    v-model="editConfig.infomation.contact"
                    placeholder="请填写"
                    clearable
                  ></el-input>
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="联系电话" prop="contact_phone">
                <el-form-item label="联系电话" prop="phone">
                  <el-input
                    v-model="editConfig.infomation.contact_phone"
                    v-model="editConfig.infomation.phone"
                    placeholder="请填写"
                    clearable
                  ></el-input>
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="签约日期" prop="validity_date">
                <el-form-item label="签约日期" prop="signingDate">
                  <el-date-picker
                    v-model="editConfig.infomation.validity_date"
                    v-model="editConfig.infomation.signingDate"
                    style="width: 100%"
                    type="date"
                    clearable
                    placeholder="选择日期"
                    value-format="yyyy-MM-dd"
                  >
@@ -129,11 +134,12 @@
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="交付日期" prop="validity_date">
                <el-form-item label="交付日期" prop="deliveryDate">
                  <el-date-picker
                    v-model="editConfig.infomation.validity_date"
                    v-model="editConfig.infomation.deliveryDate"
                    style="width: 100%"
                    type="date"
                    clearable
                    placeholder="选择日期"
                    value-format="yyyy-MM-dd"
                  >
@@ -141,13 +147,13 @@
                </el-form-item>
              </el-col>
              <el-col :span="24">
                <el-form-item label="备注信息" prop="member_id">
                <el-form-item label="备注信息" prop="remark">
                  <el-input
                    type="textarea"
                    :autosize="{ minRows: 3, maxRows: 4 }"
                    maxlength="500"
                    clearable
                    v-model="editConfig.infomation.member_id"
                    v-model="editConfig.infomation.remark"
                  ></el-input>
                </el-form-item>
              </el-col>
@@ -163,7 +169,6 @@
              @inputContent="inputContent"
              @addProductClick="addProductClick"
              @emptyProductClick="emptyProductClick"
              @recalculateProductClick="recalculateProductClick"
              @clearupProduct="clearupProduct"
            />
          </div>
@@ -230,10 +235,10 @@
          >取消</el-button
        >
      </div>
      <!-- 选择客户 -->
      <SelectClientDialog
        v-if="editSelectClientConfig.editVisible"
        :edit-common-config="editSelectClientConfig"
      <!-- 选择供应商名称-->
      <SelectSupplierDialog
        v-if="editSelectSupplierConfig.editVisible"
        :edit-common-config="editSelectSupplierConfig"
        @selClient="selClient"
      />
    </el-dialog>
@@ -250,18 +255,19 @@
<script>
import CommonFormTableView from "@/components/makepager/CommonFormTableView";
import BomDialog from "@/components/makepager/BomDialog";
import {
  getAddQuotation,
  getUpdateQuotation,
  getAllData,
  addPurchase,
  updatePurchase,
} from "@/api/purchaseManage/purchase";
// import {
//   postGetUnitDictList,
//   postGetSaveSUnitDict,
// } from "@/api/purchaseManage/purchase";
import SelectClientDialog from "@/views/purchaseManage/purchase/components/SelectClientDialog";
import SelectSupplierDialog from "@/views/purchaseManage/purchase/components/SelectSupplierDialog";
export default {
  name: "QuotationDialog",
  components: { SelectSupplierDialog, CommonFormTableView,BomDialog },
  props: {
    editCommonConfig: {
      type: Object,
@@ -274,46 +280,25 @@
      },
    },
  },
  components: { SelectClientDialog, CommonFormTableView,BomDialog },
  computed: {
    searchCommonHeight() {
      return this.$refs.searchCommonView.offsetHeight;
    },
    contactNamelist() {
      return this.$store.state.getClientName.contactNamelist;
    },
  },
  data() {
    return {
      dialogWidth: "50%",
      editConfig: this.editCommonConfig,
      rules: {
        client_id: [{ required: true, message: "请输入", trigger: "blur" }],
        number: [{ required: true, message: "请输入", trigger: "blur" }],
        quotation_status_id: [
          { required: true, message: "请选择", trigger: "change" },
        ],
        member_id: [
          { required: true, message: "请选择负责人", trigger: "change" },
        ],
        contact_phone: [
        supplierName: [{ required: true, message: "请选择", trigger: "change" }],
        phone: [
          {
            required: true,
            required: false,
            message: "请填写",
            trigger: "change",
          },
          { validator: this.validatorPhone, trigger: "change" },
        ],
      },
      memberOptions: [],
      quotationStatusOptions: [{ id: 1, name: "不知道" }], // 报价单状态
      currencyOptions: [{ id: 1, name: "人民币" }], // 币种
      approvalWorkflowOptions: [], // 审批流程
      productTableList: {},
      showSummary: {
        show: true,
        total: false,
        sumProp: ["Amount", "total"],
        sumProp: ["price", "total"],
        titleProp: [
          "编号",
          "产品名称",
@@ -325,14 +310,12 @@
        ],
        mergeNumber: 4,
      },
      editSelectClientConfig: {
      editSelectSupplierConfig: {
        editVisible: false,
        title: "",
        infomation: {},
      },
      clientId: this.editCommonConfig.infomation.client_id,
      contactId: this.editCommonConfig.infomation.contact_id,
      saleChanceId: this.editCommonConfig.infomation.sale_chance_id,
      supplierId: this.editCommonConfig.infomation.supplierId,
      tableData: [],
      productId: 1,
      isNoProduct: true,
@@ -342,7 +325,16 @@
  },
  created() {
    this.setTableForm();
    this.getCommonData();
  },
  computed: {
  },
  watch:{
    'editCommonConfig.visible':{
      immediate:true,
      handler:function(){
        this.setTableForm();
      }
    }
  },
  methods: {
    // PLC配置设置
@@ -402,17 +394,6 @@
        callback();
      }
    },
    getCommonData() {
      getAllData()
        .then((res) => {
          this.memberOptions = res.data.member;
          this.quotationStatusOptions = res.data.quotationStatus;
        })
        .catch((err) => {
          console.log(err);
        });
    },
    // 保存
    saveClick(formName) {
      this.$refs[formName].validate((valid) => {
@@ -431,7 +412,7 @@
            const params = this.saveParams();
            console.log(params);
            if (this.editConfig.title === "创建") {
              getAddQuotation(params).then((res) => {
              addPurchase(params).then((res) => {
                console.log(res);
                this.editConfig.visible = false;
                if (res.code === 200) {
@@ -440,7 +421,7 @@
                }
              });
            } else {
              getUpdateQuotation(params).then((res) => {
              updatePurchase(params).then((res) => {
                this.editConfig.visible = false;
                if (res.code === 200) {
                  this.$message.success("编辑成功");
@@ -456,20 +437,24 @@
      });
    },
    saveParams() {
      let data = this.editConfig.infomation;
      debugger
      let data =JSON.parse(JSON.stringify(this.editConfig.infomation));
      let params = {
        id: this.editConfig.title === "创建" ? 0 : data.id,
        client_id: this.clientId || 0,
        conditions: data.conditions || "",
        contact_id: this.contactId || 0,
        file: data.file || "",
        member_id: data.member_id || 0,
        number: data.number || "",
        quotation_status_id: data.quotation_status_id || 0,
        sale_chance_id: this.saleChanceId || 0,
        validity_date: data.validity_date || "",
        products: this.tableData,
        productList:this.tableData,
        purchase:{
          supplierId:this.supplierId||0,
          signingDate:data.signingDate||'',
          remark:data.remark,
          purchaseTypeId:this.purchaseTypeId||0,
          phone:data.phone||'',
          name:data.name||'',
          deliveryDate:data.deliveryDate||'',
          contact:data.contact
        }
      };
      if(data.ID){
        params.purchase.id=data.ID
      }
      return params;
    },
    handleClose() {
@@ -480,9 +465,7 @@
      var restaurants = [];
      if (value === "client") {
        restaurants = this.clientList;
      } else if (value === "contact") {
        restaurants = this.contactNamelist;
      }
      }
      var results = queryString
        ? restaurants.filter(this.createStateFilter(queryString))
        : restaurants;
@@ -498,37 +481,30 @@
    handleSelectClient(value, item) {
      console.log(value);
      if (value === "client") {
        this.clientId = item.id;
      } else if (value === "chance") {
        this.saleChanceId = item.id;
      } else {
        this.contactId = item.id;
        this.supplierId = item.id;
      }
    },
    selClientClick() {
      this.editSelectClientConfig.editVisible = true;
      this.editSelectSupplierConfig.editVisible = true;
    },
    selClient(row) {
      this.editConfig.infomation.client_name = row.name;
      this.clientId = row.id;
      this.$set(this.editConfig.infomation,'supplierName',row.name)
      this.editConfig.infomation.contact = row.contact;
      this.editConfig.infomation.phone = row.phone;
      this.supplierId = row.ID;
    },
    // 清除已选择用户
    clearupClient(value) {
      if (value == "client") {
        this.editConfig.infomation.client_name = "";
        this.$set(this.editConfig.infomation, "client_name", "");
        this.clientId = null;
        this.$set(this.editConfig.infomation, "supplierName", "");
        this.supplierId = null;
        this.$forceUpdate();
      }
    },
    // 添加附件
    addAnnexClick() {},
    // 设置允许上传文件格式
    setFormatClick() {},
    setTableForm() {
      if (
        this.editConfig.title === "创建" ||
        this.editConfig.infomation.products.length === 0
        !this.editConfig.infomation.ID  ||
        this.editConfig.infomation.productList.length === 0
      ) {
        this.tableData = [
          {
@@ -543,15 +519,14 @@
          },
        ];
      } else {
        this.tableData = this.editConfig.infomation.products;
        this.tableData.map((item, index) => {
          item.productId = index + 1;
        });
        this.tableData = this.editConfig.infomation.productList;
        // this.tableData.map((item, index) => {
        //   item.productId = index + 1;
        // });
      }
      this.productTableList = {
        tableData: this.tableData,
        tableColumn: [
          { label: "编号", prop: "productId", width: 40 },
          {
            label: "产品名称",
            prop: "name",
@@ -559,8 +534,8 @@
            isRequird: true,
          },
          { label: "产品编号", prop: "number" },
          { label: "计量单位", prop: "number" },
          { label: "规格型号", prop: "number" },
          { label: "计量单位", prop: "unit" },
          { label: "规格型号", prop: "specifications" },
          { label: "数量", prop: "amount", inputNumber: true, isRequird: true },
          {
            label: "采购单价",
@@ -569,7 +544,7 @@
            isRequird: true,
          },
          { label: "价税合计", prop: "total", inputFloat: true },
          { label: "描述", prop: "name", input: true },
          { label: "描述", prop: "remark", input: true },
        ],
      };
    },
@@ -609,13 +584,11 @@
          name: "",
          number: "",
          price: 0,
          total: 0,
          total: 0
        },
      ];
      this.productTableList.tableData = this.tableData;
    },
    // 产品重算
    recalculateProductClick() {},
    clearupProduct(data) {
      this.tableData = data;
      this.productTableList.tableData = this.tableData;
src/views/purchaseManage/purchase/components/SelectSupplierDialog.vue
File was renamed from src/views/purchaseManage/purchase/components/SelectClientDialog.vue
@@ -1,7 +1,7 @@
<template>
  <div class="edit-selClient-box">
    <el-dialog
      :title="'客户管理'"
      :title="'供应商名称'"
      :visible.sync="editConfig.editVisible"
      :width="dialogWidth"
      :before-close="handleClose"
@@ -38,9 +38,7 @@
</template>
<script>
import {
  getClientList
} from "@/api/purchaseManage/purchase";
import { getSupplierList } from "@/api/supplierManage/supplier"
export default {
  name: "EditSelClientDialog",
  props: {
@@ -80,15 +78,14 @@
      this.tableList = {
        tableInfomation: [],
        tableColumn: [
          { label: "客户名称", prop: "name", min: 100, isClick: true },
          { label: "客户编号", prop: "number" },
          { label: "客户状态", prop: "client_status" },
          { label: "销售负责人", prop: "member_name", min: 100 },
          { label: "法定代表人", prop: "representative", min: 100 },
          { label: "注册时间", prop: "registration_time" },
          { label: "经营范围", prop: "business_scope" },
          { label: "详细地址", prop: "detail_address" },
          { label: "备注", prop: "remark" }
         { label: "供应商编号", prop: "number", min: 190, isCommonClick: true },
          { label: "供应商名称", prop: "name", min: 130 },
          { label: "供应商类型", prop: "supplierType", min: 130 },
          { label: "所属行业", prop: "industry", min: 130 },
          { label: "联系人", prop: "contact", min: 130 },
          { label: "联系电话", prop: "phone", min: 130 },
          { label: "状态", prop: "status_name", min: 130 },
          { label: "创建时间", prop: "member_name", min: 130 }
        ]
      }
      this.searchOptions = []
@@ -102,22 +99,20 @@
      this.editConfig.editVisible = false
    },
    // 请求数据
    async getData() {
    async getData(val, content) {
      this.loading = true
      await getClientList({
        search_map: this.search_map,
        page: 0,
        pageSize: 0
      await getSupplierList({
        [val]: content,
        page:1,
        pageSize: 10
      })
        .then((res) => {
          console.log(res)
          if (res.code === 200) {
            if (res.data.list && res.data.list.length > 0) {
              const list = res.data.list.map((item) => {
          if (res.data.code == 200) {
            if (res.data.data.list && res.data.data.list.length > 0) {
              const list = res.data.data.list.map((item) => {
                return {
                  ...item,
                  client_status: item.client_status.name,
                  member_name: item.member.username
                  status_name: item.status === 0 ? "未启用" : "启用"
                }
              })
              this.tableList.tableInfomation = list.slice(0, 5) || []
@@ -131,7 +126,7 @@
        })
        .catch((err) => {
          console.log(err)
          this.this.tableList.tableInfomation = []
          this.tableList.tableInfomation = []
          this.loading = false
        })
    },
@@ -141,14 +136,9 @@
    },
    // 搜索
    searchClick(val, content) {
      console.log(val, content)
      this.search_map = {
        [val.value]: content
      }
      this.getData()
      this.getData(val.value, content)
    },
    resetClick() {
      this.search_map = {}
      this.getData()
    }
  }
src/views/purchaseManage/purchase/index.vue
@@ -40,19 +40,21 @@
    <!-- 新建/编辑销售线索 -->
    <!-- <AddSalesLeadDialog v-if="editSalesLeadConfig.visible" :edit-rightContent-config="editSalesLeadConfig" /> -->
    <!-- 详情 -->
    <DetailSupplier v-if="commonDetail.visible" :common-detail="commonDetail" @submitClick="submitClick" />
    <DetailSupplier v-if="commonDetail.visible" :common-detail="commonDetail"  />
    <!-- 新建/编辑 -->
    <AddPurchase v-if="editConfig.visible" :edit-common-config="editConfig" />
  </div>
</template>
<script>
import pageMixin from "@/components/makepager/pager/mixin/pageMixin"
import {
  getSalesLeadsList, getDeleteSalesLeads
  getPurchaseList,getPurchaseInfo,submitPurchase,
} from "@/api/purchaseManage/purchase";
import DetailSupplier from "@/views/purchaseManage/purchase/DetailSupplier"
import AddPurchase from "@/views/purchaseManage/purchase/components/AddPurchase"
import { getDataByType } from "@/api/data";
export default {
  name: "SupplierManage",
  props: {},
@@ -74,6 +76,7 @@
        title: "创建",
        infomation: {}
      },
      purchaseStatusList:getDataByType('purchaseStatus'),
    }
  },
  created() {
@@ -87,9 +90,9 @@
        selectIndex: true,
        tableColumn: [
          { label: "采购单号", prop: "number", min: 150, isCommonClick: true },
          { label: "采购单名称", prop: "name", min: 130,},
          { label: "采购单名称", prop: "name", min: 130, isCommonClick: true},
          { label: "单据类型", prop: "contact_name", min: 130 },
          { label: "供应商名称", prop: "contact_phone", min: 130 },
          { label: "供应商名称", prop: "contact", min: 130 },
          { label: "采购数量", prop: "sales_resources", min: 130 },
          { label: "收货仓库", prop: "province", min: 130 },
          { label: "经办人", prop: "city", min: 130 },
@@ -100,23 +103,17 @@
    },
    // 请求数据
    async getData() {
      await getSalesLeadsList({
        search_map: this.search_map,
      await getPurchaseList({
        keyword: this.search_map,
        page: this.pagerOptions.currPage,
        pageSize: this.pagerOptions.pageSize
      })
        .then((res) => {
          const list = res.data.list.map((item) => {
            return {
              ...item,
              province: item.Province.name,
              city: item.City.name,
              sales_resources: item.sales_sources.name,
              member_name: item.member.username
            }
          })
          this.tableList.tableInfomation = list || []
          this.pagerOptions.totalCount = res.data.count
          if (res.data.code === 200) {
            const list = res.data.data.list
            this.tableList.tableInfomation = list || []
            this.pagerOptions.totalCount = res.data.data.total
          }
        })
        .catch((err) => {
          console.log(err)
@@ -140,19 +137,39 @@
      // this.$refs.add.islook = true;
      this.editConfig.visible = true
      this.editConfig.title = "创建"
      this.editConfig.infomation = { }
      this.editConfig.infomation = {
        productList:[],
        supplierId:'',
          signingDate:'',
          remark:'',
          purchaseTypeId:'',
          phone:'',
          name:'',
          deliveryDate:'',
          contact:''
       }
    },
    
    // 编辑
    editClick(row){
      getPurchaseInfo({id:row.ID}).then((res) => {
        if (res.code == 200) {
          this.editConfig.visible = true
          this.editConfig.title = "编辑"
          this.editConfig.infomation = {
            productList:res.data.productList,
            ...res.data.purchase
           }
        }else{
          this.$message.error(res.msg?res.msg+',':''+'获取信息失败!')
        }
      })
      // this.editRow = row;
      // this.$refs.add.islook = true;
      this.editConfig.visible = true
      this.editConfig.title = "编辑"
      this.editConfig.infomation = { ...row }
    },
    // 确认发货
    submitClick() {
    submitClick(row) {
        this.$confirm("是否提交?", "提示", {
          confirmButtonText: "确定",
          cancelButtonText: "取消",
@@ -160,7 +177,7 @@
        })
          .then(() => {
            console.log("dddd")
            getDeleteSalesLeads({ ids: this.selValueList }).then((response) => {
            submitPurchase({ id: row.ID }).then((response) => {
              if (response.code === 200) {
                this.$message.success("提交成功")
                this.getData()
@@ -175,8 +192,17 @@
    // 详情
    selCommonClick(row) {
      console.log(row)
      this.commonDetail.visible = true
      this.commonDetail.infomation = { ...row }
      getPurchaseInfo({id:row.ID}).then((res) => {
        if (res.code == 200) {
          this.commonDetail.visible = true
          this.commonDetail.infomation = {
            productList:res.data.productList,
            ...res.data.purchase
           }
        }else{
          this.$message.error(res.msg?res.msg+',':''+'获取信息失败!')
        }
      })
    }
  }
}
vue.config.js
@@ -15,6 +15,8 @@
    proxy: {
      "/api": {
        target: "http://192.168.20.118:8889", // http://192.168.20.119:8002 http://fai365.com:30150/
        // target: "http://192.168.20.120:8889",
        // target: "http://192.168.20.119:8004",
        ws: true,
        changeOrigin: true
      }