Bladeren bron

Merge branch 'sit'

xiaodai2022 2 jaren geleden
bovenliggende
commit
e91ee0c958

File diff suppressed because it is too large
+ 8 - 0
dist/static/js/0.js


File diff suppressed because it is too large
+ 0 - 0
dist/static/js/app.js


+ 2 - 1
src/components/globalComponents/search-terrace/main.vue

@@ -96,6 +96,7 @@ export default {
             id: this.options[index].id,
             code: this.options[index].platform_code,
             label: this.options[index].platform_name,
+            platform_type:this.options[index].platform_type
           };
           this.$emit("searchChange", model);
         } else {
@@ -126,4 +127,4 @@ export default {
 </script>
 
 <style>
-</style>
+</style>

+ 73 - 0
src/components/good-online-platform-modal/columns.js

@@ -0,0 +1,73 @@
+export default [
+  { type: "selection", fixed: "left", _noset_: true },
+  {
+    prop: "skuCode",
+    label: "商品编码",
+    width: "160",
+  },
+  {
+    prop: "good_thumb_img",
+    label: "图片",
+    _slot_: "good_thumb_img", 
+    "width": "50",
+  },
+  {
+    prop: "good_name",
+    label: "商品名称",
+    // good_thumb_img
+    "min-width": "120",
+  },
+  {
+    prop: "plat_code",
+    label: "平台商品编号",
+    "width": "160",
+  },
+  {
+    prop: "cat_name",
+    label: "商品分类",
+    width: "120",
+  },
+
+  {
+    prop: "unit",
+    label: "单位",
+    width: "45",
+  },
+  {
+    prop: "model",
+    label: "规格",
+    _slot_: "model",
+    width: "110",
+  },
+  
+  {
+    prop: "brand_name",
+    label: "品牌",
+    "width": "100",
+  },
+  {
+    prop: "is_stock",
+    label: "库存类型",
+    _slot_: "is_stock",
+    "width": "100",
+  },
+  
+  {
+    prop: "platform_name",
+    label: "所属平台",
+    "width": "100",
+  },
+  
+  {
+    prop: "company",
+    label: "业务公司",
+    "min-width": "150",
+  },
+  {
+    prop: "purchase",
+    label: "供应商负责人",
+    fixed: "right",
+    width: "95",
+  },
+  
+]

+ 2 - 0
src/components/good-online-platform-modal/index.js

@@ -0,0 +1,2 @@
+import Main from './main.vue'
+export default Main

+ 376 - 0
src/components/good-online-platform-modal/main.vue

@@ -0,0 +1,376 @@
+<template>
+  <el-dialog
+    :title="'选择已上线的商品'"
+    :center="true"
+    align="left"
+    top="8vh"
+    width="1040px"
+    @close="showModelThis = false"
+    :close-on-click-modal="false"
+    :visible.sync="showModelThis"
+    v-loading="loading"
+    element-loading-text="拼命加载中"
+    element-loading-spinner="el-icon-loading"
+    element-loading-background="rgba(0, 0, 0, 0.8)"
+    append-to-body
+  >
+    <el-card style="margin-top: -20px" class="modal-form-style">
+      <ex-table
+        v-loading="loading"
+        :table="table"
+        :data="tableData"
+        :columns="columns"
+        :page="pageInfo"
+        :size="'mini'"
+        @page-curr-change="handlePageChange"
+        @page-size-change="handleSizeChange"
+        @screen-reset="
+          pageInfo.curr = 1;
+          parmValue.page = 1;
+          searchList();
+        "
+        @screen-submit="
+          pageInfo.curr = 1;
+          parmValue.page = 1;
+          searchList();
+        "
+      >
+        <template #table-header="{ selection }">
+          <div style="width: 100%">
+            <el-row style="margin-top: -15px">
+              <el-col :span="24">
+                <el-col :span="4" style="width: 210px">
+                  <search-brand
+                    :value="parmValue.brandid"
+                    :disabled="false"
+                    :size="'mini'"
+                    :isDetail="false"
+                    :names="''"
+                    :placeholder="'品牌'"
+                    @searchChange="brandidsearchChange"
+                  />
+                </el-col>
+                <el-col :span="6" style="width: 370px; padding: 0 0 0 10px">
+                  <good-class
+                    :value="parmValue.cat_id"
+                    @handleChange="goods_class_change"
+                    :disabled="false"
+                    :size="searchSize"
+                    :isDetail="false"
+                    :placeholder="'分类'"
+                  />
+                </el-col>
+
+                <el-col :span="3" class="fr" style="width: 66px">
+                  <el-button
+                    :size="'mini'"
+                    type="primary"
+                    style="float: right; margin-left: 5px"
+                    @click="searchList"
+                  >
+                    刷新
+                  </el-button>
+                </el-col>
+                <el-col :span="4" class="fr" style="width: 66px">
+                  <el-button
+                    type="warning"
+                    class="fr"
+                    :size="'mini'"
+                    @click="restSearch"
+                  >
+                    重置
+                  </el-button>
+                </el-col>
+              </el-col>
+              <el-col :span="24" style="padding: 10px 0 0 0">
+                <el-col :span="4" style="width: 450px">
+                  <el-input
+                    clearable
+                    :size="'mini'"
+                    v-model="sinput"
+                    :maxlength="40"
+                    placeholder="关键字"
+                    @blur="
+                      pageInfo.curr = 1;
+                      parmValue.page = 1;
+                      searchList();
+                    "
+                  >
+                    <el-select
+                      v-model="select"
+                      style="width: 120px"
+                      slot="prepend"
+                      placeholder="关键字类型"
+                    >
+                      <el-option label="商品名称" value="1" />
+                      <el-option label="成本商品编码" value="2" />
+                      <el-option label="上线商品编码" value="4" />
+                      <el-option label="平台商品编码" value="3" />
+                    </el-select>
+                  </el-input>
+                </el-col>
+
+                <el-col :span="3" style="width: 66px; float: right">
+                  <el-button
+                    :size="'mini'"
+                    type="success"
+                    style="float: right; margin-left: 5px"
+                    @click="resultList(selection)"
+                  >
+                    保存
+                  </el-button>
+                </el-col>
+              </el-col>
+            </el-row>
+          </div>
+        </template>
+        <template #good_thumb_img="{ scope }">
+          <div
+            v-if="scope.row.good_thumb_img"
+            style="width: 20px; height: 20px"
+            class="hover"
+            v-viewer
+          >
+            <img
+              :src="scope.row.good_thumb_img"
+              style="display: inline-block; width: 100%; height: 100%"
+              alt=""
+            />
+          </div>
+        </template>
+        <template #model="{ scope }">
+          <span v-for="(si, sii) in scope.row.specinfo" :key="si.spec_id">
+            <span v-if="sii !== 0">--</span
+            ><span>{{ si.spec_name }}[{{ si.spec_value }}]</span></span
+          >
+        </template>
+        <template #is_stock="{ scope }">
+          <span>{{ scope.row.is_stock === "1" ? "库存品" : "非库存品" }} </span>
+        </template>
+      </ex-table>
+    </el-card>
+  </el-dialog>
+</template>
+
+<script>
+import asyncRequest from "@/apis/components/search-good-online-modal";
+import asyncYZRequest from "@/apis/service/youzan/othgoodsOnline";
+import resToken from "@/mixins/resToken";
+import mixinPage from "@/mixins/elPaginationHandle";
+import { mapGetters } from "vuex";
+import columns from "./columns";
+export default {
+  name: "searchGoodOnlineModal",
+  mixins: [resToken, mixinPage],
+  computed: {
+    ...mapGetters(["tablebtnSize", "searchSize", "size"]),
+  },
+  props: ["showModel", "once", "sitem", "active","platform_type"],
+
+  /**
+   * 属性集合
+   * @param {Boolean}       showModel             : 是否弹出弹窗        必填
+   * @param {Boolean}       once                  : 是否只选一条        非必填
+   */
+  /**
+   * 事件集合
+   * @searchChange             : 选中值变化调用   抛出选中数据
+   */
+  data() {
+    return {
+      select: "1",
+      sinput: "",
+      is_stock: [
+        { id: "0", name: "非库存品" },
+        { id: "1", name: "库存品" },
+      ],
+      selectLoading: false,
+      searchName: "",
+      supplierCode: [],
+      loading: true,
+      showModelThis: false,
+      parmValue: {
+        platform_code: "",
+        companyNo: "",
+        is_stock: "",
+        exam_status: "",
+        cat_id: [], // 商品属性code
+        brandid: [],
+        skucode: "",
+        spucode: "", // 商品编码
+        good_name: "", // 商品名称
+        plat_code: "",
+
+        page: 1, // 页码
+        size: 15, // 每页显示条数
+      },
+      tableData: [],
+      passwordModel: false,
+      passwordModelId: 0,
+      isPasswordDetail: false,
+      // 表格 - 数据
+      tableData: [],
+      // 表格 - 参数
+      table: {
+        stripe: true,
+        border: true,
+        // _defaultHeader_: ["setcol"],
+      },
+      // 表格 - 分页
+      pageInfo: {
+        size: 15,
+        curr: 1,
+        total: 0,
+      },
+      // 表格 - 列参数
+      columns: columns,
+    };
+  },
+  watch: {
+    showModel: function (val) {
+      this.showModelThis = val;
+      if (val) {
+        this.restSearch();
+      }
+    },
+    showModelThis(val) {
+      if (!val) {
+        this.$emit("cancel");
+      }
+    },
+  },
+
+  methods: {
+    restSearch() {
+      console.log(this.active);
+      console.log(this.sitem);
+      const { platform_code, company_id, is_stock } = this.sitem;
+
+      this.parmValue = {
+        platform_code: platform_code || "",
+        companyNo: company_id || "", //业务企业编号
+        is_stock: is_stock || "",
+        cat_id: [], // 商品属性code
+        brandid: [],
+        exam_status: this.active ? "6" : "",
+       skucode: "",
+        spucode: "", // 商品编码
+        good_name: "", // 商品名称
+        plat_code: "",
+        page: 1, // 页码
+        size: 15, // 每页显示条数
+      };
+      // 表格 - 分页
+      this.pageInfo = {
+        size: 15,
+        curr: 1,
+        total: 0,
+      };
+      this.searchList();
+    },
+    async goods_class_change(e) {
+      this.parmValue.cat_id = e;
+      this.pageInfo.curr = 1;
+      this.parmValue.page = 1;
+      await this.searchList();
+    },
+    async brandidsearchChange(e) {
+      const { id } = e;
+      this.parmValue.brandid = id ? [id] : [];
+      this.pageInfo.curr = 1;
+      this.parmValue.page = 1;
+      await this.searchList();
+    },
+    async platform_codesearchChange(e) {
+      const { id, code, label } = e;
+      this.parmValue.platform_code = id ? [id] : [];
+      this.pageInfo.curr = 1;
+      this.parmValue.page = 1;
+      await this.searchList();
+    },
+    async company_idsearchChange(e) {
+      const { id, code, label } = e;
+      this.parmValue.company_id = code || "";
+      this.pageInfo.curr = 1;
+      this.parmValue.page = 1;
+      await this.searchList();
+    },
+    async searchList() {
+      this.loading = true;
+      let model = JSON.parse(JSON.stringify(this.parmValue));
+      model.cat_id =
+        model.cat_id.length > 0 ? model.cat_id[model.cat_id.length - 1] : "";
+      model.brandid =
+        model.brandid.length > 0 ? model.brandid[model.brandid.length - 1] : "";
+      model.spucode = this.select === "2" ? this.sinput : ""; // 商品编码
+      model.good_name = this.select === "1" ? this.sinput : ""; // 商品名称
+      model.plat_code = this.select === "3" ? this.sinput : "";
+      model.skucode = this.select === "4" ? this.sinput : "";
+      // model.platform_code =
+      //   model.platform_code.length > 0
+      //     ? model.platform_code[model.platform_code.length - 1]
+      //     : "";
+
+      const apis = this.platform_type === '1' ? asyncYZRequest : asyncRequest;
+
+      const res = await apis.list(model);
+      if (res && res.code === 0 && res.data) {
+        this.tableData = res.data.list;
+        this.tableData.map((e) => {
+          e.cat_name = "";
+          if (e.cat_info && e.cat_info.length > 0) {
+            e.cat_info.forEach((si, sii) => {
+              e.cat_name += `${sii !== 0 ? "_" : ""}${si.name}`;
+            });
+          }
+          return e;
+        });
+
+        this.pageInfo.total = Number(res.data.count);
+      } else if (res && res.code >= 100 && res.code <= 104) {
+        await this.logout();
+      } else {
+        this.tableData = [];
+        this.pageInfo.total = 0;
+      }
+      this.loading = false;
+    },
+    async remoteMethod(query) {
+      this.selectLoading = true;
+      if (query !== "") {
+        this.options = [];
+        let formValue = {
+          page: 1,
+          size: 100,
+          name: query,
+          code: "",
+        };
+
+        let res = await asyncRequest.supplierList(formValue);
+        if (res && res.code === 0 && res.data) {
+          const { list } = res.data;
+          this.options = list;
+        } else if (res && res.code >= 100 && res.code <= 104) {
+          await this.logout();
+        } else {
+          this.$message.warning(res.message);
+        }
+      } else {
+        this.options = [];
+      }
+      this.selectLoading = false;
+    },
+    async resultList(selection) {
+      if (selection && selection.length > 1 && this.once) {
+        this.$message.warning("只能选择一条商品信息!");
+        return;
+      }
+      this.showModelThis = false;
+      this.$emit("resultList", selection);
+    },
+  },
+};
+</script>
+
+<style>
+</style>

+ 0 - 0
src/components/good-online-platform-modal/上线后商品选择


+ 599 - 0
src/components/in-address-model/index.vue

@@ -0,0 +1,599 @@
+<template>
+  <el-dialog
+    v-loading="loading"
+    :title="title"
+    :center="true"
+    align="left"
+    top="8vh"
+    width="1040px"
+    :close-on-click-modal="false"
+    :visible.sync="showModelThis"
+    element-loading-text="拼命加载中"
+    element-loading-spinner="el-icon-loading"
+    element-loading-background="rgba(0, 0, 0, 0.8)"
+    @close="showModelThis = false"
+    append-to-body
+  >
+    <el-card style="margin-top: -25px">
+      <upload-excel :on-success="handleSuccess" :before-upload="beforeUpload" />
+      <el-form :model="ruleForm" ref="ruleForm" :size="'mini'">
+        <el-table
+          :data="ruleForm.order_addr"
+          border
+          :size="'mini'"
+          style="width: 100%"
+          max-height="400px"
+          row-key="key"
+        >
+          <el-table-column
+            prop="receipt_quantity"
+            label="收货总数"
+            width="100"
+            show-overflow-tooltip
+          />
+
+          <el-table-column
+            prop="contactor"
+            label="收件联系人"
+            show-overflow-tooltip
+            width="85"
+          />
+
+          <el-table-column
+            prop="mobile"
+            label="收货联系电话"
+            show-overflow-tooltip
+            width="100"
+          />
+          <el-table-column
+            show-overflow-tooltip
+            prop="in_addr"
+            label="收货省市区(文件导入)"
+            width="150"
+          />
+          <el-table-column
+            show-overflow-tooltip
+            prop="addr_code_name"
+            label="收货省市区(系统解析)"
+            width="150"
+          />
+          <el-table-column prop="addr" label="详细地址" show-overflow-tooltip />
+
+          <el-table-column fixed="right" width="80" label="操作">
+            <template slot-scope="scope">
+              <el-tooltip effect="dark" content="编辑" placement="top">
+                <i class="el-icon-edit tb-icon" @click="openHouseModal(scope.$index)"></i>
+              </el-tooltip>
+              <el-tooltip effect="dark" content="删除" placement="top">
+                <i
+                  class="el-icon-delete tb-icon"
+                  @click="deleteRow(scope.$index, ruleForm.order_addr)"
+                ></i>
+              </el-tooltip>
+            </template>
+          </el-table-column>
+        </el-table>
+      </el-form>
+      <addr-add-edit-modal
+        :showModel="showAddrAddEditModal"
+        :index="AddrAddEditModalIndex"
+        :sitem="AddrAddEditModalSitem"
+        @cancel="showAddrAddEditModal = false"
+        :type="'1'"
+        @refresh="showAddrAddEditModalRefresh"
+      />
+      <div class="tr" style="padding: 10px 0 0 0">
+        <el-button type="primary" size="small" @click="submitForm">保 存 </el-button>
+      </div>
+    </el-card>
+  </el-dialog>
+</template>
+<script>
+import resToken from "@/mixins/resToken";
+import { province_list, city_list, county_list } from "@/assets/js/area-data";
+import {
+  isnumber,
+  isMobile,
+  isChinese,
+  isEmoticon,
+  isSpecialSymbol,
+  hasSpace,
+  isAddr,
+} from "@/utils/validate";
+import AddrAddEditModal from "@/components/addr-add-edit-modal";
+export default {
+  name: "inAddrModel",
+  props: ["showModel", "id", "sitem"],
+  mixins: [resToken],
+  components: { AddrAddEditModal },
+  data() {
+    const validatemobile = (rule, value, callback) => {
+      if (value === "") {
+        callback(new Error("联系电话不能为空!"));
+      } else {
+        if (!isMobile(value)) {
+          callback(new Error("联系电话格式不正确!"));
+        } else {
+          callback();
+        }
+      }
+    };
+    const validateWeight = (rule, value, callback) => {
+      if (value === "") {
+        callback(new Error("收货总数不能为空!"));
+      } else {
+        if (!isnumber(value)) {
+          callback(new Error("收货总数仅支持整数!"));
+        } else {
+          callback();
+        }
+      }
+    };
+    const validatecontactor = (rule, value, callback) => {
+      if (value === "") {
+        callback(new Error("联系人不能为空!"));
+      } else {
+        if (value.length < 2 || value.length > 10) {
+          callback(new Error("联系人规则为2~10位汉字!"));
+        } else {
+          if (!isChinese(value)) {
+            callback(new Error("联系人规则为2~10位汉字!"));
+          } else if (isEmoticon(value)) {
+            callback(new Error("联系人规则为2~10位汉字!"));
+          } else {
+            callback();
+          }
+        }
+      }
+    };
+    const validateAddr = (rule, value, callback) => {
+      if (value === "") {
+        callback(new Error("详细地址不能为空!"));
+      } else {
+        if (hasSpace(value)) {
+          callback(new Error("不能出现回车/换行符!"));
+        } else if (isSpecialSymbol(value)) {
+          callback(new Error("不能使用英文特殊字符!"));
+        } else if (isAddr(value)) {
+          callback();
+        } else {
+          callback(new Error("详细地址填写不规范!"));
+        }
+      }
+    };
+    return {
+      showAddrAddEditModal: false,
+      AddrAddEditModalIndex: -1,
+      AddrAddEditModalSitem: {},
+      tableData: [],
+      tableHeader: [],
+      title: "",
+      showModelThis: false,
+      loading: false,
+      newTime: 0,
+      pickerOptions: {
+        disabledDate: (time) => {
+          return time.getTime() < new Date().valueOf();
+        },
+      },
+      rulesThis: this.rules,
+      ruleForm: {
+        order_addr: [], //收货地址
+      },
+      rules: {
+        receipt_quantity: [
+          {
+            required: true,
+            validator: validateWeight,
+            trigger: "blur",
+          },
+        ],
+
+        contactor: [
+          {
+            required: true,
+            trigger: "blur",
+            validator: validatecontactor,
+          },
+        ],
+        mobile: [
+          {
+            required: true,
+            validator: validatemobile,
+            trigger: "blur",
+          },
+        ],
+        addr_code: [
+          {
+            type: "array",
+            required: false,
+            trigger: "change",
+          },
+        ],
+        addr: [
+          {
+            required: true,
+            validator: validateAddr,
+            trigger: "blur",
+          },
+        ],
+      },
+    };
+  },
+  watch: {
+    showModel: function (val) {
+      this.showModelThis = val;
+      if (val) {
+        this.initForm();
+      }
+    },
+    showModelThis(val) {
+      if (!val) {
+        this.$emit("cancel");
+      }
+    },
+  },
+  mounted() {
+    this.get_code();
+  },
+  methods: {
+    async resetForm() {
+      // 重置
+      await this.$nextTick(() => {
+        if (this.$refs.ruleForm) {
+          this.$refs.ruleForm.resetFields();
+          this.$refs.ruleForm.clearValidate();
+          this.ruleForm = {
+            order_addr: [],
+          };
+        }
+      });
+    },
+    // 省市区删除行操作
+    deleteRow(index, rows) {
+      rows.splice(index, 1);
+    },
+    showAddrAddEditModalRefresh(e) {
+      const { index, item } = e;
+
+      if (index === -1) {
+        this.ruleForm.order_addr.push(JSON.parse(JSON.stringify(item)));
+      } else {
+        const {
+          receipt_quantity,
+          contactor,
+          mobile,
+          addr_code,
+          addr_code_name,
+          addr,
+          id,
+        } = JSON.parse(JSON.stringify(item));
+        this.ruleForm.order_addr[index].receipt_quantity = receipt_quantity;
+        this.ruleForm.order_addr[index].contactor = contactor;
+        this.ruleForm.order_addr[index].mobile = mobile;
+        this.ruleForm.order_addr[index].addr_code = addr_code;
+        this.ruleForm.order_addr[index].addr_code_name = addr_code_name;
+        this.ruleForm.order_addr[index].addr = addr;
+        this.ruleForm.order_addr[index].id = id;
+      }
+      this.$refs.ruleForm.validateField("order_addr");
+    },
+    beforeUpload(file) {
+      const isLt1M = file.size / 1024 < 500;
+      if (isLt1M) {
+        return true;
+      }
+      this.$message({
+        message: "请不要上传大于500KB的文件.",
+        type: "warning",
+      });
+      return false;
+    },
+    handleSuccess({ results, header }) {
+      if (results.length === 0) {
+        this.$message.error("表格无有效数据!");
+        return;
+      }
+      if (results.length > 500) {
+        this.$message.error("地址数据不能超过500条!");
+        return;
+      }
+      let head = [
+        "收货总数",
+        "收货联系人",
+        "收货联系电话",
+        "收货省名称",
+        "收货市名称",
+        "收货区名称",
+        "详细地址",
+      ];
+      if (head.length !== header.length) {
+        this.$message.error("表头与导入模板不匹配!");
+        return;
+      }
+      let hederOk = true;
+      head.forEach((v1, i1) => {
+        if (v1 !== header[i1].replace(/\s*/g, "")) {
+          hederOk = false;
+        }
+      });
+
+      if (!hederOk) {
+        this.$message.error("表头与导入模板不匹配!");
+        return;
+      }
+      this.tableHeader = header;
+      this.tableData = [];
+      let list = results;
+      let tableOk = true;
+      this.ruleForm.order_addr = [];
+      list.forEach((v1) => {
+        let b = Object.values(v1);
+        let item = this.get_code(b[3], b[4], b[5]);
+        let model = {
+          receipt_quantity: b[0] + "",
+          contactor: b[1] + "",
+          mobile: b[2] + "",
+          in_addr: b[3] + "/" + b[4] + "/" + b[5],
+          addr_code_name: item.name + "",
+          addr_code: item.code,
+          addr: b[6] + "",
+          edit: false,
+        };
+        this.ruleForm.order_addr.push(model);
+      });
+      if (!tableOk) {
+        this.$message.error("最晚收货日期不正确,请将表格格式转为文本上传!");
+      }
+    },
+    openHouseModal(index) {
+      this.AddrAddEditModalIndex = index;
+
+      if (index === -1) {
+        this.AddrAddEditModalSitem = {};
+      } else {
+        this.AddrAddEditModalSitem = JSON.parse(
+          JSON.stringify(this.ruleForm.order_addr[index])
+        );
+      }
+      this.showAddrAddEditModal = true;
+      // let findex = this.ruleForm.order_addr.findIndex((v) => v.edit === true);
+      // if (findex !== -1) {
+      //   this.$message.warning("当前已有地址在编辑,请保存后再试!");
+      //   return;
+      // } else {
+      //   this.ruleForm.order_addr[index].edit = true;
+      // }
+    },
+    unique(arr) {
+      let hash = [];
+      for (let i = 0; i < arr.length; i++) {
+        let index = hash.findIndex((v1) => v1.inv_number === arr[i].inv_number);
+        if (index === -1) {
+          hash.push(arr[i]);
+        }
+      }
+      return hash;
+    },
+    setTime(time) {
+      time = time.replace(/\//g, "-");
+      time = time.replace(/\./g, "-");
+      let key = new Date(time).valueOf() + "";
+      if (key.length !== 13) {
+        time = "";
+      }
+      return time;
+    },
+    async initForm() {
+      this.rulesThis = this.rules;
+      await this.resetForm();
+      this.newTime = 0;
+      this.loading = true;
+      this.tableData = [];
+      this.tableHeader = [];
+      this.step = 1;
+      this.title = "批量导入收货地址信息";
+
+      this.changea();
+      this.loading = false;
+    },
+    refreshAll() {
+      this.showModelThis = false;
+      this.$emit("refresh");
+    },
+    changea() {
+      this.newTime = new Date().valueOf();
+    },
+
+    async submitForm() {
+      if (!this.loading) {
+        this.loading = true;
+        const { order_addr } = this.ruleForm;
+        if (order_addr.length < 1) {
+          this.$message.error("导入数据不能为空!");
+          this.loading = false;
+          return;
+        }
+        let isEdit = false;
+        order_addr.forEach((v) => {
+          v.err = false;
+          if (v.edit) {
+            v.err = true;
+            isEdit = true;
+          }
+        });
+        if (isEdit) {
+          this.$message.error("当前收货地址已在编辑,请保存后再试!");
+          this.loading = false;
+          return;
+        }
+        let cItem = null;
+        order_addr.some((x, i) => {
+          cItem = this.checkItem(x);
+          if (!cItem.isok) {
+            cItem.index = i;
+            return true;
+          }
+        });
+        if (cItem && !cItem.isok) {
+          this.$message.error(`第${cItem.index + 1}行,${cItem.message}`);
+          this.loading = false;
+          return;
+        }
+        let list = JSON.parse(JSON.stringify(order_addr));
+        this.$emit("refresh", { list: list });
+      }
+    },
+    checkItem(sitem) {
+      let model = {
+        isok: true,
+        message: "",
+      };
+      const { arrive_time, receipt_quantity, contactor, mobile, addr_code, addr } = sitem;
+      if (receipt_quantity === "" && model.isok) {
+        model.isok = false;
+        model.message = "收货总数不能为空!";
+      }
+      if (!isnumber(receipt_quantity) && model.isok) {
+        model.isok = false;
+        model.message = "收货总数仅支持整数!";
+      }
+      if (arrive_time === "" && model.isok) {
+        model.isok = false;
+        model.message = "最晚收货日期不能为空!";
+      }
+
+      if (contactor === "" && model.isok) {
+        model.isok = false;
+        model.message = "收货联系人不能为空!";
+      }
+      if (mobile === "" && model.isok) {
+        model.isok = false;
+        model.message = "收货联系电话不能为空!";
+      }
+      if (!isMobile(mobile) && model.isok) {
+        model.isok = false;
+        model.message = "收货联系电话格式不正确!";
+      }
+      // if (addr_code.length !== 3 && model.isok) {
+      //   model.isok = false;
+      //   model.message = "收货省市区不能为空!";
+      // }
+      if (addr === "" && model.isok) {
+        model.isok = false;
+        model.message = "详细地址不能为空!";
+      }
+      return model;
+    },
+    get_code(name1, name2, name3) {
+      let name = "",
+        code = [];
+      if (name1 && name2 && name3) {
+        for (let x in province_list) {
+          if (name1 === province_list[x]) {
+            code.push(x);
+            name += province_list[x];
+            break;
+          }
+        }
+        if (code.length === 1) {
+          for (let y in city_list) {
+            if (name2 === city_list[y]) {
+              code.push(y);
+              name += "/" + city_list[y];
+              break;
+            }
+          }
+        }
+        if (code.length === 2) {
+          for (let z in county_list) {
+            if (name3 === county_list[z]) {
+              code.push(z);
+              name += "/" + county_list[z];
+              break;
+            }
+          }
+        }
+
+        if (code.length === 3) {
+          let str1 = "",
+            str2 = "",
+            isok = false;
+          str1 = code[0].slice(0, 2);
+          str2 = code[1].slice(2, 4);
+          if (
+            code[1].indexOf(str1) === 0 &&
+            code[2].indexOf(str1) === 0 &&
+            code[2].indexOf(str2) == 2
+          ) {
+            isok = true;
+          }
+          if (!isok) {
+            name = "";
+            code = [];
+          }
+        } else {
+          name = "";
+          code = [];
+        }
+      }
+      return { name: name, code: code };
+    },
+  },
+};
+</script>
+
+<style lang="scss" scoped>
+.account {
+  .gongshi {
+    span {
+      vertical-align: top;
+      display: inline-block;
+      color: #000;
+    }
+    .icon-span {
+      padding: 0 5px;
+      height: 40px;
+      line-height: 40px;
+      font-size: 20px;
+      color: #606266;
+      display: inline-block;
+      // vertical-align: top;
+      // display: inline-block;
+    }
+    .label {
+      height: 40px;
+      line-height: 40px;
+    }
+    .tuan {
+      &.chu {
+        width: 60px;
+        height: 40px;
+        display: inline-block;
+        span {
+          width: 60px;
+          display: inline-block;
+          line-height: 20px;
+          text-align: center;
+          font-size: 12px;
+          height: 20px;
+          &:last-child {
+            border-top: 1px solid #606266;
+          }
+        }
+      }
+      &.cheng {
+        .name {
+          height: 40px;
+          line-height: 40px;
+        }
+        .icon-span {
+          line-height: 40px;
+          font-size: 16px;
+          padding: 0 1px;
+        }
+      }
+    }
+  }
+}
+</style>

+ 29 - 8
src/views/goodStore/active/components/baseForm.vue

@@ -138,6 +138,21 @@
                 width="170"
               />
               <el-table-column prop="good_name" label="商品名称" show-overflow-tooltip />
+
+              <template v-if="Number(sitem.status) > 3">
+                <el-table-column prop="is_activity" label="是否使用结算单价" width="120px">
+                  <template slot-scope="scope">
+                    <span>{{scope.row.is_activity === '1' ? '是' : '否'}}</span>
+                  </template>
+                </el-table-column>
+
+                <el-table-column prop="settle_price" label="结算单价">
+                  <template slot-scope="scope">
+                    <span>{{scope.row.settle_price}}</span>
+                  </template>
+                </el-table-column>
+              </template>
+
               <el-table-column prop="activity_stock" label="活动库存" width="180">
                 <template slot-scope="scope">
                   <el-input-number
@@ -268,11 +283,12 @@
         </el-col>
       </el-row>
     </el-form>
-    <search-good-online-modal
+    <good-online-platform-modal
       :once="once"
       :sitem="ruleForm"
       :active="true"
       :show-model="showModel"
+      :platform_type="platform_type"
       @resultList="resultList"
       @cancel="showModel = false"
     />
@@ -301,7 +317,7 @@
 import asyncRequest from "@/apis/service/goodStore/active";
 import resToken from "@/mixins/resToken";
 import { mapGetters } from "vuex";
-import searchGoodOnlineModal from "@/components/search-good-online-modal";
+import goodOnlinePlatformModal from "@/components/good-online-platform-modal";
 import showGoodDataModal from "@/components/show-good-data-modal";
 import addStock from "./addStock";
 
@@ -310,7 +326,7 @@ export default {
   mixins: [resToken],
   props: ["showModel", "id", "type", "sitem", "newTime"],
   components: {
-    searchGoodOnlineModal,
+    goodOnlinePlatformModal,
     showGoodDataModal,
     addStock,
   },
@@ -335,6 +351,7 @@ export default {
       size: "small",
       activeName: "3",
       status: "",
+      platform_type:"",
       options: [
         {
           value: "0",
@@ -512,8 +529,9 @@ export default {
     },
     platform_codesearchChange(e) {
       let old = this.ruleForm.platform_code;
-      const { id, code, label } = e;
+      const { id, code, label ,platform_type} = e;
       this.ruleForm.platform_code = id || "";
+      this.platform_type = platform_type;
       this.$refs.ruleForm.validateField("platform_code");
       let newList = this.ruleForm.platform_code;
       if (old !== newList) {
@@ -521,7 +539,6 @@ export default {
       }
     },
     resultList(e) {
-      console.log(e);
       this.showModel = false;
       let list = JSON.parse(JSON.stringify(e));
       let oldList = JSON.parse(JSON.stringify(this.ruleForm.good_list));
@@ -531,8 +548,11 @@ export default {
           let item = JSON.parse(JSON.stringify(list[ei]));
           item.activity_stock = "1";
           item.newTime = new Date().valueOf();
-          console.log(item.activity_stock);
-          this.ruleForm.good_list.push(item);
+          this.ruleForm.good_list.push({
+            ...item,
+            is_activity:'1',
+            settle_price:'0.00'
+          });
         }
       });
     },
@@ -592,6 +612,7 @@ export default {
               return;
             }
             let model = JSON.parse(JSON.stringify(this.ruleForm));
+
             const { good_list } = model;
 
             let list = JSON.parse(JSON.stringify(good_list));
@@ -600,7 +621,7 @@ export default {
             list.forEach((e) => {
               let item = {
                 skuCode: e.skuCode,
-                activity_stock: e.activity_stock,
+                activity_stock: e.activity_stock
               };
               newList.push(item);
             });

+ 12 - 0
src/views/goodStore/active/components/finance-exam-three-form.vue

@@ -71,6 +71,18 @@
         label="商品名称"
         show-overflow-tooltip
       />
+      <el-table-column prop="is_activity" label="是否使用结算单价" width="120px">
+          <template slot-scope="scope">
+             <span>{{scope.row.is_activity === '1' ? '是' : '否'}}</span>
+          </template>
+        </el-table-column>
+
+      <el-table-column prop="settle_price" label="结算单价">
+        <template slot-scope="scope">
+          <span>{{scope.row.settle_price}}</span>
+         </template>
+     </el-table-column>
+     
       <el-table-column
         prop="activity_stock"
         label="活动库存"

+ 18 - 1
src/views/goodStore/active/components/finance-exam-two-form.vue

@@ -18,6 +18,19 @@
         label="商品名称"
         show-overflow-tooltip
       />
+
+      <el-table-column prop="is_activity" label="是否使用结算单价" width="120px">
+          <template slot-scope="scope">
+             <span>{{scope.row.is_activity === '1' ? '是' : '否'}}</span>
+          </template>
+        </el-table-column>
+
+      <el-table-column prop="settle_price" label="结算单价">
+        <template slot-scope="scope">
+          <span>{{scope.row.settle_price}}</span>
+         </template>
+     </el-table-column>
+
       <el-table-column
         prop="activity_stock"
         label="活动库存"
@@ -138,10 +151,12 @@ export default {
     },
     editRefresh(e) {
       this.showModel = false;
-      const { skuCode, activity_price } = JSON.parse(JSON.stringify(e));
+      const { skuCode, activity_price ,is_activity,settle_price} = JSON.parse(JSON.stringify(e));
       const aindex = this.tableData.findIndex((eis) => eis.skuCode === skuCode);
       if (aindex !== -1) {
         this.tableData[aindex].activity_price = activity_price;
+        this.tableData[aindex].is_activity = is_activity;
+        this.tableData[aindex].settle_price = settle_price;
         this.$set(this.tableData, aindex, this.tableData[aindex]);
       }
     },
@@ -175,6 +190,8 @@ export default {
           let item = {
             id: e.id,
             activity_price: e.activity_price,
+            is_activity:e.is_activity,
+            settle_price:e.is_activity === '0' ? '0' :e.settle_price
           };
           newlist.push(item);
         });

+ 45 - 23
src/views/goodStore/active/components/set-active-price-form.vue

@@ -22,10 +22,10 @@
             :model="ruleForm"
             status-icon
             :rules="rulesThis"
-            label-width="80px"
+            label-width="130px"
             class="demo-ruleForm"
           >
-            <el-form-item label="商品编号" prop="skuCode">
+            <el-form-item label="商品编号" prop="skuCode" label-width="80px">
               <el-input
                 v-model="ruleForm.skuCode"
                 placeholder="商品编号"
@@ -33,23 +33,8 @@
                 disabled
               />
             </el-form-item>
-            <el-form-item label="商品名称" prop="good_name">
-              <el-input
-                v-model="ruleForm.good_name"
-                disabled
-                placeholder="商品名称"
-                maxlength="100"
-              />
-            </el-form-item>
-            <el-form-item label="活动库存" prop="activity_stock">
-              <el-input
-                v-model="ruleForm.activity_stock"
-                placeholder="活动库存"
-                disabled
-                maxlength="100"
-              />
-            </el-form-item>
-            <el-form-item label="起订量" prop="moq_num">
+            <div style="display:flex">
+              <el-form-item label="起订量" prop="moq_num" label-width="80px">
               <el-input
                 v-model="ruleForm.moq_num"
                 disabled
@@ -57,7 +42,7 @@
                 maxlength="100"
               />
             </el-form-item>
-            <el-form-item label="成本单价" prop="cost_price">
+            <el-form-item label="成本单价" prop="cost_price" label-width="80px">
               <el-input
                 v-model="ruleForm.cost_price"
                 disabled
@@ -67,7 +52,8 @@
                 <template slot="append">元</template></el-input
               >
             </el-form-item>
-            <el-form-item label="非活动价" prop="sale_price">
+            </div>
+            <el-form-item label="非活动价" prop="sale_price" label-width="80px">
               <el-input
                 v-model="ruleForm.sale_price"
                 disabled
@@ -77,7 +63,35 @@
                 <template slot="append">元</template></el-input
               >
             </el-form-item>
-            <el-form-item label="活动价" prop="activity_price">
+            <el-form-item label="是否使用结算单价" prop="is_activity">
+              <el-select
+                v-model="ruleForm.is_activity"
+                style="width:100%"
+                placeholder="是否使用活动单价"
+                maxlength="100"
+              >
+              <el-option value="0" label="否" />
+              <el-option value="1" label="是" />
+            </el-select>
+            </el-form-item>
+
+            <el-form-item label="结算单价" prop="settle_price" label-width="80px">
+              <digital-input
+              :disabled="ruleForm.is_activity === '0'"
+              :values="ruleForm.is_activity === '0' ? '0' : ruleForm.settle_price"
+              :placeholder="'结算单价'"
+              :min="0"
+              :max="100000000000"
+              :position="'right'"
+              :precision="2"
+              :size="'large'"
+              :controls="false"
+              :append="'元'"
+              @reschange="budget_total_change"
+            />
+            </el-form-item>
+
+            <el-form-item label="活动价" prop="activity_price" label-width="80px">
               <digital-input
                 :values="ruleForm.activity_price"
                 :placeholder="'活动价'"
@@ -128,6 +142,8 @@ export default {
         cost_price: "",
         sale_price: "",
         activity_price: "",
+        is_activity:'1',
+        settle_price:''
       },
       rulesThis: this.rules,
       rules: {
@@ -155,6 +171,9 @@ export default {
     },
   },
   methods: {
+    budget_total_change(e){
+      this.ruleForm.settle_price = e + ''
+    },
     async initForm() {
       this.loading = true;
       this.rulesThis = this.rules;
@@ -194,7 +213,10 @@ export default {
             let model = JSON.parse(JSON.stringify(this.ruleForm));
             this.showModelThis = false;
             // 刷新
-            this.$emit("refresh", model);
+            this.$emit("refresh", {
+              ...model,
+              settle_price:this.ruleForm.is_activity === '0' ? '0' : this.ruleForm.settle_price
+            });
           }
         } else {
           console.log("error submit!!");

+ 14 - 0
src/views/goodStore/activeGood/index.vue

@@ -158,6 +158,10 @@
           ></el-tag>
         </template>
 
+        <template #is_activity="{scope}">
+          {{scope.row.is_activity === '1' ? '是' : '否'}}
+        </template>
+
         <template #operation="{ scope }">
           <el-tooltip
             v-if="powers.some((i) => i == '007')"
@@ -274,6 +278,16 @@ export default {
           prop: "moq_num",
           label: "起订量",
         },
+        {
+          prop:'is_activity',
+          label:'是否使用活动价',
+          width: "110",
+          _slot_:'is_activity'
+        },
+        {
+          prop:'settle_price',
+          label:'结算单价'
+        },
 
         // {
         //   prop: "cost_price",

+ 2 - 1
src/views/login/index.vue

@@ -16,7 +16,8 @@
       >
         <div class="title-container">
           <h3 class="title">
-            采销平台<span>{{ ver }}</span>
+            采销平台
+            <div style="font-size:20px;margin-top:5px">{{ ver }}</div>
           </h3>
         </div>
 

+ 4 - 3
src/views/sellOut/salesOrder/components/order-out-table.vue

@@ -236,7 +236,7 @@ import resToken from "@/mixins/resToken";
 import asyncRequest from "@/apis/service/sellOut/salesOrder/detail";
 import outOrderAddModel from "./out-order-add-model";
 import addModel from "@/views/sellOut/sellReturn/components/addModel";
-import inAddrModel from "@/components/in-addr-model";
+import inAddrModel from "@/components/in-address-model";
 import addReturnAllModel from "./addReturnAllModel";
 import { mapGetters } from "vuex";
 
@@ -396,7 +396,7 @@ export default {
         this.loading = true;
         const { arrive_time, orderCode, wsend_num } = this.sitem;
         const { list } = e;
-        console.log(list);
+    
         let t_num = 0,
           add_num = 0;
         let model = {
@@ -421,13 +421,14 @@ export default {
           return;
         }
         const { code, message } = await asyncRequest.saleaddr(model);
-        this.loading = false;
         if (code === 0) {
           this.$notify.success({
             title: "地址导入成功!",
             message: "",
           });
           this.showModelThis = false;
+          this.addrmodel = false;
+          this.loading = false;
           // 刷新
           this.$emit("refresh");
         } else if (code >= 100 && code <= 104) {

Some files were not shown because too many files changed in this diff