Procházet zdrojové kódy

c端文件导入列表,c端文件导入bug修改

lucky-lzx před 2 roky
rodič
revize
c8a5c004d0

+ 3 - 1
src/apis/service/orderEntry/orderEnter/index.js

@@ -1,4 +1,4 @@
-// 物业管理员
+// c端订单录入/订单列表
 import http from "@/apis/axios";
 const api = "admin/";
 export default {
@@ -14,4 +14,6 @@ export default {
     status: (data, params) => http(api + 'brandstatus', data, 'post', params),
     // 详情
     detail: (data, params) => http(api + "orderimportinfo", data, "post", params),
+    // 提交导入数据
+    orderimportlist: (data, params) => http(api + "orderimportlist", data, "post", params),
 };

+ 105 - 486
src/views/orderEntry/orderEnter/columns.js

@@ -1,530 +1,149 @@
-
-//是否定制
-const options1 = [
-  { id: "0", name: "否" },
-  { id: "1", name: "是" },
-]
-//专属类型
-const options2 = [
-  { id: "0", name: "非泰康" },
-  { id: "1", name: "泰康" },
-]
-//销售权限
-const options3 = [
-  { id: "0", name: "无销售权限" },
-  { id: "1", name: "有销售权限" },
-]
-
-//是否库存品
-const options4 = [
-  { id: "0", name: "非库存品" },
-  { id: "1", name: "库存品" },
-]
-//是否启用实时金价
-const options5 = [
-  { id: "0", name: "否" },
-  { id: "1", name: "是" },
-]
-//供货区域
-const options6 = [
-  { id: "1", name: "全国" },
-  { id: "2", name: "全国除偏远" },
-]
-//是否启用阶梯
-const options7 = [
-  { id: "0", name: "否" },
-  { id: "1", name: "是" },
-]
-
-//有无工差
-const options8 = [
-  { id: "0", name: "无工差" },
-  { id: "1", name: "有工差" },
-]
-//配置要求
-const options9 = ["证书", "包装盒", "绒布袋", "标签", "其他"]
-const statusList = [
-  {
-    code: "0",
-    name: "新建待审核",
-    type: "",
-  },
-  {
-    code: "1",
-    name: "审核通过",
-    type: "success",
+const listCol = [{
+    type: "selection",
+    fixed: "left",
+    _noset_: true
   },
   {
-    code: "2",
-    name: "基础修改待审核",
-    type: "",
+    prop: "platform_code",
+    label: "平台订单号",
+    width: "152px",
   },
   {
-    code: "3",
-    name: "成本修改待审核",
-    type: "",
-  },
-  {
-    code: "4",
-    name: "基础修改驳回",
-    type: "danger",
-  },
-  {
-    code: "5",
-    name: "成本修改驳回",
-    type: "danger",
-  },
-  {
-    code: "6",
-    name: "新建审核驳回",
-    type: "danger",
-  },
-  {
-    code: "7",
-    name: "复制商品待编辑",
-    type: "info",
+    prop: "po_code",
+    label: "其他单号",
+    width: "140px",
   },
   {
-    code: "8",
-    name: "咨询商品待编辑",
-    type: "info",
+    prop: "platform_time",
+    label: "平台订单下单时间",
+    width: "140px",
   },
-]
-const listCol = [
-  { type: "selection", fixed: "left", _noset_: true },
   {
-    prop: "spuCode",
-    label: "编号",
-    width: "160px",
+    prop: "sale_source",
+    label: "销售渠道",
+    width: "140px",
   },
   {
-    prop: "good_thumb_img",
-    label: "图片",
-    _slot_: "good_thumb_img",
-    width: "45px",
+    prop: "plat_code",
+    label: "平台商品编号",
+    width: "140px",
   },
   {
-    prop: "good_name",
-    label: "名称",
-    "min-width": "160px",
+    prop: "price",
+    label: "单价(元)",
+    width: "140px",
   },
   {
-    prop: "cat_name",
-    label: "分类",
+    prop: "num",
+    label: "数量",
+    width: "140px",
   },
   {
-    prop: "brand_name",
-    label: "品牌",
+    prop: "before_discount_all_price",
+    label: "优惠前总金额",
+    width: "140px",
   },
   {
-    prop: "isonline",
-    label: "是否上线",
-    _slot_: "isonline",
-    width: "70px",
+    prop: "discount_price",
+    label: "优惠金额",
+    width: "140px",
   },
   {
-    prop: "status",
-    label: "状态",
-    _slot_: "status",
-    width: "118px",
+    prop: "after_price",
+    label: "商品优惠后的金额",
+    width: "140px",
   },
   {
-    prop: "supplierNo",
-    label: "供应商编号",
-    width: "110px",
+    prop: "activity_name",
+    label: "优惠活动名称",
+    width: "140px",
   },
   {
-    prop: "supplier_name",
-    label: "供应商名称",
-    width: "110px",
+    prop: "mode",
+    label: "收费模式",
+    width: "140px",
   },
   {
-    prop: "companyNo",
-    label: "业务公司编号",
-    width: "110px",
+    prop: "order_remark",
+    label: "订单备注",
+    width: "140px",
   },
   {
-    prop: "company",
-    label: "业务公司名称",
-    width: "110px",
+    prop: "contactor",
+    label: "收货人",
+    width: "140px",
   },
   {
-    prop: "creater",
-    label: "创建人",
-    width: "70px",
+    prop: "mobile",
+    label: "联系电话",
+    width: "140px",
   },
-
-
   {
-    prop: "addtime",
-    label: "创建时间",
+    prop: "addr",
+    label: "联系地址",
     width: "140px",
   },
+  // {
+  //   prop: "",
+  //   label: "订单编号",
+  //   width: "160px",
+  // },
+  // {
+  //   prop: "",
+  //   label: "供应商编码",
+  //   width: "160px",
+  // },
+  // {
+  //   prop: "",
+  //   label: "供应商名称",
+  //   width: "160px",
+  // },
+  // {
+  //   prop: "",
+  //   label: "业务公司编号",
+  //   width: "160px",
+  // },
+  // {
+  //   prop: "",
+  //   label: "业务公司名称",
+  //   width: "160px",
+  // },
+  // {
+  //   prop: "",
+  //   label: "商品编码",
+  //   width: "160px",
+  // },
+  // {
+  //   prop: "",
+  //   label: "商品名称",
+  //   width: "160px",
+  // },
+  // {
+  //   prop: "",
+  //   label: "平台商品编号",
+  //   width: "160px",
+  // },
+  // {
+  //   prop: "",
+  //   label: "单位",
+  //   width: "60px",
+  // },
+  // {
+  //   prop: "",
+  //   label: "录入状态",
+  //   width: "120px",
+  // },
+
   {
     prop: "",
     label: "操作",
     fixed: "right",
     _noset_: true,
-    width: "50px",
+    width: "80px",
     _slot_: "operation",
   },
 ]
-const validate_num = (rule, value, callback) => {
-  const { required } = rule
-  if (required && value === "") {
-    callback(new Error("不能为空!"));
-  } else {
-    callback();
-  }
-};
-const validate_num_0 = (rule, value, callback) => {
-  const { required } = rule
-  if (required && value === "") {
-    callback(new Error("不能为空!"));
-  } else if (required && (value === "0" ||
-    value === "0." ||
-    value === "0.0" ||
-    value === "0.00" ||
-    value === "0.000"
-  )) {
-    callback(new Error("不能为零!"));
-  } else {
-    callback();
-  }
-};
-const validate_good_img = (rule, value, callback) => {
-  const { required } = rule
-  if (required && value.length == 0) {
-    callback(new Error("请上传商品主图!"));
-  } else if (required && (value.length < 3 || value.length > 10)) {
-    callback(new Error("商品主图应为3~10张!"));
-  } else {
-    callback();
-  }
-};
-const rules = {
-  cat_id: [
-    {
-      type: "array",
-      required: true,
-      message: "请选择商品分类",
-      trigger: "change",
-    },
-  ],
-  brandid: [
-    {
-      type: "array",
-      required: true,
-      message: "请选择商品品牌",
-      trigger: "change",
-    },
-  ],
-  noble_weight: [
-    {
-      required: true,
-      validator: validate_num_0,
-      trigger: "blur",
-    },
-  ],
-  weight: [
-    {
-      required: true,
-      validator: validate_num,
-      trigger: "blur",
-    },
-  ],
-  good_type: [
-    {
-      required: true,
-      message: "请选择是否定制",
-      trigger: "change",
-    },
-  ],
-  is_stock: [
-    {
-      required: true,
-      message: "请选择是否库存品",
-      trigger: "change",
-    },
-  ],
-  company_id: [
-    {
-      required: true,
-      message: "请选择业务公司",
-      trigger: "change",
-    },
-  ],
-  supplierNo: [
-    {
-      type: "array",
-      required: true,
-      message: "请选择供应商",
-      trigger: "change",
-    },
-  ],
-  is_auth: [
-    {
-      required: true,
-      message: "请选择是否有权限销售",
-      trigger: "change",
-    },
-  ],
-  tax: [
-    {
-      required: true,
-      message: "请选择税率",
-      trigger: "change",
-    },
-  ],
-  good_name: [
-    {
-      required: true,
-      message: "请输入商品名称",
-      trigger: "blur",
-    },
-  ],
-  unit: [
-    {
-      type: "array",
-      required: true,
-      message: "请输入商品单位",
-      trigger: "blur",
-    },
-  ],
-  is_exclusive: [
-    {
-      required: true,
-      type: "array",
-      message: "请选择专属类型",
-      trigger: "change",
-    },
-  ],
-  noble_metal: [
-    {
-      required: true,
-      message: "请选择贵金属种类",
-      trigger: "change",
-    },
-  ],
-  is_gold_price: [
-    {
-      required: true,
-      message: "请选择是否启用实时金价",
-      trigger: "change",
-    },
-  ],
-  moq: [
-    {
-      required: true,
-      validator: validate_num,
-      trigger: "blur",
-    },
-  ],
-  customized: [
-    {
-      required: true,
-      validator: validate_num,
-      trigger: "blur",
-    },
-  ],
-  after_sales: [
-    {
-      required: true,
-      message: "售后说明不能为空",
-      trigger: "blur",
-    },
-  ],
-  good_remark: [
-    {
-      required: true,
-      message: "商品备注不能为空",
-      trigger: "blur",
-    },
-  ],
-  //包装/发货/图片
-  packing_list: [
-    {
-      required: true,
-      message: "请输入包装清单",
-      trigger: "blur",
-    },
-  ],
-  packing_way: [
-    {
-      required: true,
-      message: "请输入包装方式",
-      trigger: "blur",
-    },
-  ],
-
-  packing_spec: [
-    {
-      required: true,
-      message: "请输入装箱规格",
-      trigger: "blur",
-    },
-  ],
-  packing_weight: [
-    {
-      required: true,
-      message: "请输入装箱重量",
-      trigger: "blur",
-    },
-  ],
-  packing_szie: [
-    {
-      required: true,
-      message: "请输入装箱尺寸",
-      trigger: "blur",
-    },
-  ],
-  supply_area: [
-    {
-      required: true,
-      message: "请选择供货区域",
-      trigger: "change",
-    },
-  ],
-  delivery_place: [
-    {
-      type: "array",
-      required: true,
-      message: "请选择发货地",
-      trigger: "change",
-    },
-  ],
-  origin_place: [
-    {
-      type: "array",
-      required: true,
-      message: "请选择产地",
-      trigger: "change",
-    },
-  ],
-  delivery_day: [
-    {
-      required: true,
-      message: "请输入物流时间",
-      trigger: "blur",
-    },
-  ],
-  lead_time: [
-    {
-      required: true,
-      message: "请输入供货周期",
-      trigger: "blur",
-    },
-  ],
-  sample_day: [
-    {
-      required: true,
-      message: "请输入调样周期",
-      trigger: "blur",
-    },
-  ],
-  packing_size: [
-    {
-      required: true,
-      message: "请输入装箱尺寸",
-      trigger: "blur",
-    },
-  ],
-  good_size: [
-    {
-      required: true,
-      message: "请输入商品尺寸",
-      trigger: "blur",
-    },
-  ],
-  good_thumb_img: [
-    {
-      required: true,
-      message: "请上传商品缩略图",
-      trigger: "change",
-    },
-  ],
-  good_img: [
-    {
-      type: "array",
-      required: true,
-      validator: validate_good_img,
-      trigger: "change",
-    },
-  ],
-  good_info_img: [
-    {
-      type: "array",
-      required: true,
-      message: "至少上传一张商品详情介绍图",
-      trigger: "change",
-    },
-  ],
-
-
 
-  demo_fee: [
-    {
-      required: true,
-      validator: validate_num,
-      trigger: "blur",
-    },
-  ],
-  is_diff: [
-    {
-      required: true,
-      message: "请选择有无工差",
-      trigger: "change",
-    },
-  ],
-  config: [
-    {
-      required: true,
-      type: 'array',
-      message: "请选择配置要求",
-      trigger: "change",
-    },
-  ],
-  other_config: [
-    {
-      required: true,
-      message: "其他要求不能为空",
-      trigger: "blur",
-    },
-  ],
-  open_fee: [
-    {
-      required: true,
-      validator: validate_num,
-      trigger: "blur",
-    },
-  ],
-  sample_fee: [
-    {
-      required: true,
-      validator: validate_num,
-      trigger: "blur",
-    },
-  ],
-  market_price: [
-    {
-      required: true,
-      validator: validate_num,
-      trigger: "blur",
-    },
-  ],
-
-  cgd_gold_price: [
-    {
-      required: true,
-      validator: validate_num,
-      trigger: "blur",
-    },
-  ],
-  // is_step: {
-  //   required: true,
-  //   message: "请选择是否启用阶梯",
-  //   trigger: "change",
-  // },
+export {
+  listCol
 }
-
-export { options1, options2, options3, options4, options5, options6, options7, options8, options9, listCol, rules, statusList }

+ 403 - 543
src/views/orderEntry/orderEnter/index.vue

@@ -1,274 +1,328 @@
 <template>
-  <div class="goodsCost pagePadding">
-    <ex-table
-      v-loading="loading"
-      v-if="powers && powers.length > 0 && powers.some((item) => item == '001')"
-      :table="table"
-      :data="tableData"
-      :columns="columns"
-      :page="pageInfo"
-      :size="size"
-      @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();
-      "
-      @selection="selection_change"
-    >
-      <template #table-header="{}">
-        <div style="width: 100%">
-          <el-row style="padding: 0 0 10px 80px">
-            <el-col :span="6" style="width: 303px">
-              <period-date-picker
-                :type="1"
-                :width="'135px'"
-                :size="searchSize"
-                :start="parmValue.start"
-                :end="parmValue.end"
-                @timeReturned="handleTime"
-              />
-            </el-col>
-            <el-col :span="4" style="width: 135px">
-              <search-brand
-                :value="brandid"
-                :disabled="false"
-                :size="'mini'"
-                :isDetail="false"
-                :names="''"
-                :placeholder="'商品品牌'"
-                @searchChange="brandidsearchChange"
-              />
-            </el-col>
-            <el-col :span="6" style="width: 310px; 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; padding: 0 0 0 10px"
-            >
-              <el-button type="primary" :size="searchSize" @click="searchList">
-                刷新
-              </el-button>
-            </el-col>
-            <el-col
-              :span="3"
-              class="fr"
-              style="width: 66px; padding: 0 0 0 10px"
-            >
-              <el-button type="warning" :size="searchSize" @click="restSearch">
-                重置
-              </el-button>
-            </el-col>
-          </el-row>
-          <el-row>
-            <el-col :span="4" style="width: 226px">
+  <div class="box">
+    <!-- <template #table-header="{}">
+    <div class="searchBox">
+      <el-form
+        ref="form"
+        :model="ruleForm"
+        label-width="80px"
+        size="medium "
+        class="form"
+      >
+        <el-row>
+          <el-col :span="7">
+            <el-form-item label="销售方" prop="status" label-width="100px">
               <el-select
-                v-model="parmValue.status"
-                filterable
-                clearable
-                :size="searchSize"
-                placeholder="状态"
+                v-model="ruleForm.status"
                 style="width: 100%"
-                @change="
-                  pageInfo.curr = 1;
-                  parmValue.page = 1;
-                  searchList();
-                "
+                placeholder="咨询类型"
               >
                 <el-option
-                  v-for="item in statusList"
-                  :key="'status' + item.code"
-                  :label="item.name"
-                  :value="item.code"
-                />
-              </el-select>
-            </el-col>
-            <el-col :span="4" style="width: 145px; padding: 0 0 0 10px">
-              <el-select
-                v-model="parmValue.isonline"
-                filterable
-                clearable
-                :size="searchSize"
-                placeholder="是否上线"
-                style="width: 100%"
-                @change="
-                  pageInfo.curr = 1;
-                  parmValue.page = 1;
-                  searchList();
-                "
-              >
-                <el-option
-                  v-for="item in isonlineoptions"
-                  :key="'isonline' + item.id"
-                  :label="item.name"
-                  :value="item.id"
-                />
+                  v-for="item in statusArr"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value"
+                >
+                </el-option>
               </el-select>
-            </el-col>
-            <el-col :span="4" style="width: 420px; padding: 0 0 0 10px">
+            </el-form-item>
+          </el-col>
+          <el-col :span="7">
+            <el-form-item
+              label="平台订单号"
+              prop="platform_code"
+              label-width="110px"
+            >
               <el-input
+                v-model="ruleForm.platform_code"
+                placeholder="平台订单号"
+              ></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="10">
+            <el-form-item label="平台下单时间" label-width="120px">
+              <period-date-picker
+                :start="ruleForm.platform_time_start"
+                :end="ruleForm.platform_time_end"
+                :width="'130px'"
                 :size="searchSize"
-                v-model="sinput"
-                :maxlength="40"
-                @blur="
-                  pageInfo.curr = 1;
-                  parmValue.page = 1;
-                  searchList();
-                "
-                placeholder="关键字"
-                ><el-select
-                  v-model="select"
-                  slot="prepend"
-                  style="width: 135px"
-                  @change="
-                    pageInfo.curr = 1;
-                    parmValue.page = 1;
-                    searchList();
-                  "
-                  placeholder="关键字类型"
-                >
-                  <el-option label="商品编号" value="1" />
-                  <el-option label="商品名称" value="2" />
-                  <el-option label="业务企业编号" value="3" />
-                  <el-option label="供应商编号" value="4" /> </el-select
+                @timeReturned="platformTime"
+              />
+            </el-form-item>
+          </el-col>
+          <el-col :span="7">
+            <el-form-item label="PO编号" prop="po_code" label-width="100px">
+              <el-input
+                v-model="ruleForm.po_code"
+                placeholder="PO编号"
               ></el-input>
-            </el-col>
-
-            <el-col
-              :span="3"
-              class="fr"
-              style="width: 66px; padding: 0 0 0 10px"
-              v-if="powers.some((item) => item == '003')"
+            </el-form-item>
+          </el-col>
+          <el-col :span="7">
+            <el-form-item
+              label="平台商品编号"
+              prop="plat_code"
+              label-width="110px"
             >
-              <el-button
+              <el-input
+                v-model="ruleForm.plat_code"
+                placeholder="平台商品编号"
+              ></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="10">
+            <el-form-item label="导入时间" label-width="120px">
+              <period-date-picker
+                :start="ruleForm.addtime_start"
+                :end="ruleForm.addtime_end"
+                :width="'130px'"
                 :size="searchSize"
-                type="success"
-                style="float: right"
-                @click="
-                  routeGoto('goodsCostDetail', { id: 'add', type: 'add' })
-                "
-              >
-                添加
-              </el-button>
-            </el-col>
-            <el-col
-              :span="3"
-              class="fr"
-              style="width: 110px; padding: 0 0 0 10px"
-              v-if="powers.some((item) => item == '055')"
+                @timeReturned="addtime"
+              />
+            </el-form-item>
+          </el-col>
+        </el-row>
+      </el-form>
+      <div class="rightBtn">
+        <el-button type="primary" icon="el-icon-search" class="btn" @click="selectStock"
+          >批量关联库存</el-button
+        >
+        <el-button type="primary" icon="el-icon-search" class="btn" @click="search"
+          >搜索</el-button
+        >
+        <el-button type="primary" icon="el-icon-download" class="btn"
+          ><a href="./static/C端订单导入模板.xlsx">下载导入模板</a></el-button
+        >
+        <el-button icon="el-icon-refresh-right" class="btn" @click="reset">重置</el-button>
+      </div>
+    </div>
+    </template> -->
+    <div class="tableBox">
+      <ex-table
+        v-loading="loading"
+        v-if="
+          powers && powers.length > 0 && powers.some((item) => item == '001')
+        "
+        :table="table"
+        :data="tableData"
+        :columns="columns"
+        :page="pageInfo"
+        :size="size"
+        @page-curr-change="handlePageChange"
+        @page-size-change="handleSizeChange"
+        @screen-reset="
+          pageInfo.curr = 1;
+          ruleForm.page = 1;
+          initHttp();
+        "
+        @screen-submit="
+          pageInfo.curr = 1;
+          ruleForm.page = 1;
+          initHttp();
+        "
+        @selection="selection_change"
+        ><template #table-header="{}">
+          <div class="searchBox">
+            <el-form
+              ref="form"
+              :model="ruleForm"
+              label-width="80px"
+              size="medium "
+              class="form"
             >
+              <el-row>
+                <el-col :span="7">
+                  <el-form-item
+                    label="销售方"
+                    prop="status"
+                    label-width="100px"
+                  >
+                    <el-select
+                      v-model="ruleForm.status"
+                      style="width: 100%"
+                      placeholder="咨询类型"
+                    >
+                      <el-option
+                        v-for="item in statusArr"
+                        :key="item.value"
+                        :label="item.label"
+                        :value="item.value"
+                      >
+                      </el-option>
+                    </el-select>
+                  </el-form-item>
+                </el-col>
+                <el-col :span="7">
+                  <el-form-item
+                    label="平台订单号"
+                    prop="platform_code"
+                    label-width="110px"
+                  >
+                    <el-input
+                      v-model="ruleForm.platform_code"
+                      placeholder="平台订单号"
+                    ></el-input>
+                  </el-form-item>
+                </el-col>
+                <el-col :span="10">
+                  <el-form-item label="平台下单时间" label-width="120px">
+                    <period-date-picker
+                      :start="ruleForm.platform_time_start"
+                      :end="ruleForm.platform_time_end"
+                      :width="'130px'"
+                      :size="searchSize"
+                      @timeReturned="platformTime"
+                    />
+                  </el-form-item>
+                </el-col>
+                <el-col :span="7">
+                  <el-form-item
+                    label="PO编号"
+                    prop="po_code"
+                    label-width="100px"
+                  >
+                    <el-input
+                      v-model="ruleForm.po_code"
+                      placeholder="PO编号"
+                    ></el-input>
+                  </el-form-item>
+                </el-col>
+                <el-col :span="7">
+                  <el-form-item
+                    label="平台商品编号"
+                    prop="plat_code"
+                    label-width="110px"
+                  >
+                    <el-input
+                      v-model="ruleForm.plat_code"
+                      placeholder="平台商品编号"
+                    ></el-input>
+                  </el-form-item>
+                </el-col>
+                <el-col :span="10">
+                  <el-form-item label="导入时间" label-width="120px">
+                    <period-date-picker
+                      :start="ruleForm.addtime_start"
+                      :end="ruleForm.addtime_end"
+                      :width="'130px'"
+                      :size="searchSize"
+                      @timeReturned="addtime"
+                    />
+                  </el-form-item>
+                </el-col>
+              </el-row>
+            </el-form>
+            <div class="rightBtn">
               <el-button
-                :size="searchSize"
-                type="warning"
-                style="float: right"
-                @click="add_online"
+                type="primary"
+                icon="el-icon-search"
+                class="btn"
+                @click="selectStock"
+                >批量关联库存</el-button
               >
-                <i class="el-icon-circle-plus-outline"></i>
-                <span>商品上线</span>
-              </el-button>
-            </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 #status="{ scope }">
-        <el-tag
-          :size="tablebtnSize"
-          :type="
-            (statusList.find((item) => item.code == scope.row.status) || {})
-              .type || '--'
-          "
-          v-text="
-            (statusList.find((item) => item.code == scope.row.status) || {})
-              .name || '--'
-          "
-        ></el-tag>
-      </template>
-      <template #isonline="{ scope }">
-        <el-tag
-          :size="tablebtnSize"
-          :type="scope.row.is_online == '0' ? 'warning' : ''"
-          v-text="
-            (
-              isonlineoptions.find((item) => item.id == scope.row.is_online) ||
-              {}
-            ).name || '--'
-          "
-        ></el-tag>
-      </template>
+              <el-button
+                type="primary"
+                icon="el-icon-search"
+                class="btn"
+                @click="search"
+                >搜索</el-button
+              >
+              <el-button type="primary" icon="el-icon-download" class="btn"
+                ><a href="./static/C端订单导入模板.xlsx"
+                  >下载导入模板</a
+                ></el-button
+              >
+              <el-button icon="el-icon-refresh-right" class="btn" @click="reset"
+                >重置</el-button
+              >
+            </div>
+          </div>
+        </template>
+        <template #operation="{ scope }">
+          <el-tooltip
+            v-if="powers.some((item) => item == '007')"
+            effect="dark"
+            content="详情"
+            placement="top"
+          >
+            <i
+              class="el-icon-view tb-icon"
+              @click="
+                routeGoto('goodsCostDetail', {
+                  id: scope.row.spuCode,
+                  type: 'view',
+                })
+              "
+            ></i>
+          </el-tooltip>
 
-      <template #operation="{ scope }">
-        <el-tooltip
-          effect="dark"
-          content="详情"
-          placement="top"
-        >
-          <i
-            class="el-icon-view tb-icon"
-            @click="
-              routeGoto('orderConfirm', {
-                id: scope.row.id,
-                type: 'view',
-              })
-            "
-          ></i>
-        </el-tooltip>
-      </template>
-    </ex-table>
-    <no-auth v-else></no-auth>
-    <add-edit
-      :id="''"
-      :sitem="changeList"
-      :show-model="showModel"
-      :is-detail="false"
-      @refresh="showModel = false"
-      @cancel="showModel = false"
-    />
+          <el-tooltip effect="dark" content="确认订单信息" placement="top">
+            <i
+              class="el-icon-c-scale-to-original tb-icon"
+              @click="
+                wantto(
+                  scope.row.is_online,
+                  scope.row.spuCode,
+                  scope.row.status,
+                  '2'
+                )
+              "
+            ></i>
+          </el-tooltip>
+        </template>
+      </ex-table>
+    </div>
   </div>
 </template>
+
 <script>
+import { listCol } from "./columns";
+import { mapGetters } from "vuex";
 import asyncRequest from "@/apis/service/orderEntry/orderEnter";
 import mixinPage from "@/mixins/elPaginationHandle";
-import { mapGetters } from "vuex";
 import resToken from "@/mixins/resToken";
-import { listCol, options1, statusList } from "./columns";
-// import addEdit from "./components/addEdit";
 export default {
-  name: "goodsCost",
   mixins: [mixinPage, resToken],
-  // components: {
-  //   addEdit,
-  // },
+  data() {
+    return {
+      loading: true,
+      //咨询类型
+      statusArr: [
+        { value: "1", label: "系统验证数据中" },
+        { value: "2", label: "待确认订单信息" },
+        { value: "3", label: "信息已确认待关联库存" },
+        { value: "4", label: "订单录入成功" },
+      ],
+      ruleForm: {
+        status: "1",
+        platform_code: "",
+        // cs3: "",
+        po_code: "",
+        plat_code: "",
+        // cs6: "",
+        platform_time_end: "",
+        platform_time_start: "",
+        addtime_end: "",
+        addtime_start: "",
+        page: "",
+        size: "",
+      },
+      changeList: [],
+      // 表格 - 分页
+      pageInfo: {
+        size: 15,
+        curr: 1,
+        total: 0,
+      },
+      table: {
+        stripe: true,
+        border: true,
+        _defaultHeader_: ["setcol"],
+      },
+      tableData: [],
+      columns: listCol,
+    };
+  },
   computed: {
     //组件SIZE设置
     ...mapGetters(["tablebtnSize", "searchSize", "size"]),
@@ -284,319 +338,125 @@ export default {
       }
     },
   },
-  data() {
-    return {
-      statusList,
-      isonlineoptions: [
-        { id: "0", name: "未上线" },
-        { id: "1", name: "已上线" },
-      ],
-      showModel: false,
-      options1: options1,
-      loading: false,
-      changeList: [],
-      parmValue: {
-        page: 1, // 页码
-        size: 15, // 每页显示条数
-        start: "",
-        end: "",
-        status: "",
-        good_name: "",
-        spucode: "",
-        cat_id: [],
-        brandid: "",
-        good_type: "",
-        companyNo: "",
-        supplierNo: "",
-        isonline: "",
-        // creater: "",
-      },
-      sinput: "",
-      select: "",
-      // 表格 - 数据
-      tableData: [],
-      // 表格 - 参数
-      table: {
-        stripe: true,
-        border: true,
-        _defaultHeader_: ["setcol"],
-      },
-      // 表格 - 分页
-      pageInfo: {
-        size: 15,
-        curr: 1,
-        total: 0,
-      },
-      // 表格 - 列参数
-      columns: listCol,
-      supplierNo: [],
-      brandid: [],
-    };
-  },
   mounted() {
-    this.select = "1";
-    this.supplierNo = [];
-    this.brandid = [];
-    this.searchList();
+    this.tableData = [];
+    this.initHttp();
   },
   methods: {
-    restSearch() {
-      this.select = "1";
-      this.supplierNo = [];
-      this.brandid = [];
-      // 表格 - 分页
-      this.pageInfo = {
-        size: 15,
-        curr: 1,
-        total: 0,
-      };
-      this.parmValue = {
-        page: 1, // 页码
-        size: 15, // 每页显示条数
-        start: "",
-        end: "",
-        status: "",
-        good_name: "",
-        spucode: "",
-        cat_id: [],
-        brandid: "",
-        good_type: "",
-        isonline: "",
-        companyNo: "",
-        supplierNo: "",
-      };
-      this.searchList();
-    },
-    wantto(isonline, code, ntype, wtype) {
-      console.log(isonline);
-      if (isonline + "" === "1") {
-        this.$message.warning("已上线的商品需要下线才能修改!");
-        return;
-      }
-      if (ntype === "0") {
-        this.$message.warning("新建商品成正在审核中,请审核结束后再修改!");
-        return;
-      }
-      if (ntype === "2") {
-        if (wtype === "2") {
-          this.$message.warning("商品基础信息已修改,请等待审核结果!");
-          return;
-        }
-        if (wtype === "3") {
-          this.$message.warning(
-            "商品基础信息修改流程正在审核中,请审核结束后再修改!"
-          );
-          return;
-        }
-      }
-      if (ntype === "3") {
-        if (wtype === "3") {
-          this.$message.warning("商品成本信息已修改,请等待审核结果!");
-          return;
-        }
-        if (wtype === "2") {
-          this.$message.warning(
-            "商品成信息修改流程正在审核中,请审核结束后再修改!"
-          );
-          return;
-        }
-      }
-      console.log(ntype + "----" + wtype);
-      this.routeGoto("goodsCostDetail", {
-        id: code,
-        type: wtype === "2" ? "editBase" : wtype === "3" ? "editCoin" : "",
-      });
-    },
-    selection_change(e) {
-      const { list } = e;
-      this.changeList = list.length > 0 ? JSON.parse(JSON.stringify(list)) : [];
-    },
-    //商品品牌选择
-    async brandidsearchChange(e) {
-      const { id, code, label } = e;
-      if (id) {
-        this.brandid = [id];
-      } else {
-        this.brandid = [];
-      }
-      this.parmValue.brandid = this.brandid.toString();
-      this.pageInfo.curr = 1;
-      this.parmValue.page = 1;
-      await this.searchList();
-    },
-    // 时间
-    async handleTime(e) {
-      this.parmValue.start = e.startTime || "";
-      this.parmValue.end = e.endTime || "";
-      if (
-        (this.parmValue.start !== "" && this.parmValue.end !== "") ||
-        (this.parmValue.start === "" && this.parmValue.end === "")
-      ) {
-        this.pageInfo.curr = 1;
-        this.parmValue.page = 1;
-        await this.searchList();
-      }
-    },
-    async good_copy(spuCode) {
-      await this.$confirm(`确定要复制该商品?`, {
-        confirmButtonText: "确定",
-        cancelButtonText: "取消",
-        type: "warning",
-      })
-        .then(async () => {
-          this.loading = true;
-          const model = {
-            spuCode: spuCode,
-          };
-          const res = await asyncRequest.copy(model);
-          if (res && res.code === 0) {
-            this.loading = false;
-            this.$notify.success({
-              title: "复制商品成功!",
-              message: "",
-            });
-            await this.searchList();
-          } else if (res && res.code >= 100 && res.code <= 104) {
-            await this.logout();
-          } else {
-            this.loading = false;
-            this.$message.warning(res.message);
-          }
-        })
-        .catch(() => {
-          console.log("取消");
-        });
-    },
-    /**
-     * 启用/禁用
-     * @param {String} id id
-     * @param {String} status 0-禁用 1-启用
-     */
-    async changeStatus(id, status) {
-      await this.$confirm(`确定要改为${status === "1" ? "禁用" : "启用"}?`, {
-        confirmButtonText: "确定",
-        cancelButtonText: "取消",
-        type: "warning",
-      })
-        .then(async () => {
-          this.loading = true;
-          const model = {
-            id: id,
-            status: status === "1" ? "0" : "1",
-          };
-          const res = await asyncRequest.status(model);
-          if (res && res.code === 0) {
-            this.loading = false;
-            this.$notify.success({
-              title: "状态修改成功!",
-              message: "",
-            });
-            await this.searchList();
-          } else if (res && res.code >= 100 && res.code <= 104) {
-            await this.logout();
-          } else {
-            this.loading = false;
-            this.$message.warning(res.message);
-          }
-        })
-        .catch(() => {
-          console.log("取消");
-        });
-    },
-    async deleteItem(code) {
-      await this.$confirm("确定要删除?", {
-        confirmButtonText: "确定",
-        cancelButtonText: "取消",
-        type: "warning",
-      })
-        .then(async () => {
-          const model = {
-            codes: [code],
-          };
-          const res = await asyncRequest.delete(model);
-          if (res && res.code === 0) {
-            this.$notify.success({
-              title: "删除成功",
-              message: "",
-            });
-            this.searchList();
-          } else if (res && res.code >= 100 && res.code <= 104) {
-            await this.logout();
-          } else {
-            this.$message.warning(res.message);
-          }
-        })
-        .catch(() => {
-          console.log("取消");
-        });
-    },
-    // 刷新表格
-    async searchList() {
-      if (
-        (this.parmValue.start !== "" && this.parmValue.end === "") ||
-        (this.parmValue.start === "" && this.parmValue.end !== "")
-      ) {
-        this.$message.warning("时间区间不完整!");
-        return;
-      }
+    //初始化请求
+    async initHttp() {
       this.loading = true;
-      this.parmValue.spucode = this.select === "1" ? this.sinput : "";
-      this.parmValue.good_name = this.select === "2" ? this.sinput : "";
-      this.parmValue.companyNo = this.select === "3" ? this.sinput : "";
-      this.parmValue.supplierNo = this.select === "4" ? this.sinput : "";
-      let item = JSON.parse(JSON.stringify(this.parmValue));
-      item.cat_id =
-        item.cat_id.length > 0 ? item.cat_id[item.cat_id.length - 1] : "";
-      const res = await asyncRequest.list(item);
+      let model = this.ruleForm;
+      model.page = this.pageInfo.curr;
+      model.size = this.pageInfo.size;
+      let res = await asyncRequest.orderimportlist(model);
       if (res && res.code === 0 && res.data) {
         this.tableData = res.data.list;
-        this.tableData.forEach((a) => {
-          a.cat_name = "";
-          let list = a.cat_info || [];
-          list.forEach((b, i) => {
-            a.cat_name += i == 0 ? b.name : "/" + b.name;
-          });
-        });
         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.$message.warning(res.message);
       }
       this.loading = false;
     },
-    //商品分类选择
-    async goods_class_change(e) {
-      this.parmValue.cat_id = e;
-      this.pageInfo.curr = 1;
-      this.parmValue.page = 1;
-      await this.searchList();
+    //导入时间
+    async addtime(e) {
+      this.ruleForm.addtime_start = e.startTime || "";
+      this.ruleForm.addtime_end = e.endTime || "";
+
+      // if (
+      //   (this.ruleForm.start !== "" && this.ruleForm.end !== "") ||
+      //   (this.ruleForm.start === "" && this.ruleForm.end === "")
+      // ) {
+      //   this.pageInfo.curr = 1;
+      //   this.ruleForm.page = 1;
+      //   // await this.initHttp();
+      // }
     },
-    add_online() {
-      if (this.changeList.length === 0) {
-        this.$message.warning("至少选择一个商品!");
-        return;
-      }
-      if (this.changeList.length > 100) {
-        this.$message.warning("商品数量不能超过100!");
-        return;
-      }
-      let isok = true;
-      this.changeList.forEach((e) => {
-        if (e.status !== "1") {
-          isok = false;
-        }
-      });
-      if (!isok) {
-        this.$message.warning("只有审核通过的商品可以上线!");
-        return;
-      }
-      this.showModel = true;
+    //平台时间
+    async platformTime(e) {
+      this.ruleForm.platform_time_start = e.startTime || "";
+      this.ruleForm.platform_time_end = e.endTime || "";
+    },
+    //批量关联库存
+    selectStock() {
+      alert(111);
+    },
+    //重置按钮
+    reset() {
+      this.ruleForm = {
+        status: "1",
+        platform_code: "",
+        // cs3: "",
+        po_code: "",
+        plat_code: "",
+        // cs6: "",
+        platform_time_end: "",
+        platform_time_start: "",
+        addtime_end: "",
+        addtime_start: "",
+        page: "",
+        size: "",
+      };
+      this.initHttp();
+    },
+    //搜索按钮
+    search() {
+      this.initHttp();
+    },
+
+    //选中触发函数
+    selection_change(e) {
+      const { list } = e;
+      //选中的数组集合
+      this.changeList = list.length > 0 ? JSON.parse(JSON.stringify(list)) : [];
     },
   },
 };
 </script>
 
 <style lang="scss" scoped>
+.box {
+  width: 100%;
+  padding: 8px 12px 0 10px;
+}
+.searchBox {
+  width: 100%;
+  padding-left: 30px;
+  box-sizing: border-box;
+  // padding-top: 15px;
+  // margin-top: 20px;
+  display: flex;
+}
+.form {
+  width: 80%;
+}
+/deep/ .el-input__inner {
+  height: 36px;
+  line-height: 36px;
+}
+.rightBtn {
+  width: 20%;
+  display: flex;
+  flex-wrap: wrap;
+  justify-content: space-around;
+  .btn {
+    height: 36px;
+    margin-left: 0px;
+    display: flex;
+    align-items: center;
+  }
+}
+.tableBox {
+  width: 100%;
+  margin-top: 20px;
+}
+/deep/ .el-dropdown-selfdefine {
+  margin-top: 4px;
+  background: #63cbe7;
+  color: #fff;
+  font-weight: bold;
+  border:none;
+}
 </style>

+ 8 - 8
src/views/orderEntry/orderImport/columns.js

@@ -81,14 +81,14 @@ const columns = [
     label: "联系地址",
     width: "140px",
   },
-//   {
-//     prop: "",
-//     label: "操作",
-//     fixed: "right",
-//       _noset_: true,
-//     width: "50px",
-//       _slot_: "operation",
-//   },
+  {
+    prop: "",
+    label: "操作",
+    fixed: "right",
+      _noset_: true,
+    width: "50px",
+      _slot_: "operation",
+  },
 ]
 export {
   columns

+ 35 - 8
src/views/orderEntry/orderImport/index.vue

@@ -13,7 +13,7 @@
         </ex-table>
       </div>
       <div class="btn">
-            <el-button type="primary" @click="submit">提交</el-button>
+          <el-button type="primary" @click="submit">提交</el-button>
           <el-button @click="cancel">取消</el-button>
       </div>
   </div>
@@ -113,15 +113,17 @@ export default {
       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 = {
           platform_code: b[0] + "",
           po_code: b[1] + "",
-          platform_time: b[2] + "",
+          platform_time: this.formatDate(b[2],"/")+ "",
           sale_source: b[3] + "",
           plat_code: b[4] + "",
           price: b[5] + "",
@@ -137,30 +139,55 @@ export default {
           addr: b[15] + "",
           
         };
-       
+        
         this.tableData.push(model);
       });
 
-      
+      console.log(this.tableData)
     },
-  
     //取消
     cancel(){
       this.tableData = [];
     },
+    //日期转换
+    formatDate(numb, format) {
+      const time = new Date((numb - 1) * 24 * 3600000 + 1)
+      time.setYear(time.getFullYear() - 70)
+      const year = time.getFullYear() + ''
+      const month = time.getMonth() + 1 + ''
+      const date = time.getDate()  + ''
+      if (format && format.length === 1) {
+        return year + format + month + format + date
+      }
+      return year + (month < 10 ? '0' + month : month) + (date < 10 ? '0' + date : date)
+    },
     //提交
    async submit(){
      const model = {
        list:this.tableData
-     }
-      console.log(model)
+     } 
+
+      
+      let flag = model.list.every((item,index)=>{
+        return item.platform_code && item.sale_source && item.plat_code
+           && item.price && item.contactor && item.mobile && item.addr
+      })
+     
+      if(flag){
+        alert(flag)
+      }else{
+        alert(flag)
+      }
+        return;
+
       const res = await asyncRequest.orderimport(model)
-      console.log(res)
       if (res && res.code === 0) {
         this.$notify.success({
           title: "成功!",
           message: "",
         });
+
+        this.tableData = [];
       } else if (res && res.code >= 100 && res.code <= 104) {
         await this.logout();
       } else {