Browse Source

Merge branch 'company' into v3.0

snow 1 year ago
parent
commit
7b30dcef8f

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


+ 12 - 0
dist/static/js/1.js

@@ -36,6 +36,18 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) *
 
 /***/ }),
 
+/***/ "./node_modules/@babel/runtime/helpers/esm/toArray.js":
+/*!************************************************************!*\
+  !*** ./node_modules/@babel/runtime/helpers/esm/toArray.js ***!
+  \************************************************************/
+/*! exports provided: default */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return _toArray; });\n/* harmony import */ var _arrayWithHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithHoles.js */ \"./node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js\");\n/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ \"./node_modules/@babel/runtime/helpers/esm/iterableToArray.js\");\n/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ \"./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js\");\n/* harmony import */ var _nonIterableRest_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableRest.js */ \"./node_modules/@babel/runtime/helpers/esm/nonIterableRest.js\");\n\n\n\n\nfunction _toArray(arr) {\n  return Object(_arrayWithHoles_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(arr) || Object(_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(arr) || Object(_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(arr) || Object(_nonIterableRest_js__WEBPACK_IMPORTED_MODULE_3__[\"default\"])();\n}\n\n//# sourceURL=webpack:///./node_modules/@babel/runtime/helpers/esm/toArray.js?");
+
+/***/ }),
+
 /***/ "./node_modules/core-js/internals/array-buffer-native.js":
 /*!***************************************************************!*\
   !*** ./node_modules/core-js/internals/array-buffer-native.js ***!

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


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


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


+ 2 - 1
src/apis/service/sellOut/filing/index.js

@@ -12,5 +12,6 @@ export default {
   addrall: (data, params) => http(api + 'addrall', data, 'post', params),
   transfer: (data) => http(api + 'filingTransfer', data, 'post'),
   saleOutList: (data) => http(api + 'xsaleout', { ...data, noRelation: true }, 'post'),
-  cancel: (data) => http(api + 'filingCancel', data, 'post')
+  cancel: (data) => http(api + 'filingCancel', data, 'post'),
+  keepqueryl: (data) => http(api + 'keepbquery', data, 'post'),
 }

+ 1 - 0
src/config/env.company.js

@@ -24,6 +24,7 @@ module.exports = {
   settlementPlatformUrl: 'http://webcx.test241.wanyuhengtong.com/',
   // 工单管理系统url
   GDUrl: 'http://http://bugweb.test241.wanyuhengtong.com/',
+  dashboardUrl:"http://web.report.caixiao365.com/",
   // token加密key
   secretKey: 'key123',
   loginTitle: '',

+ 1 - 0
src/config/env.development.js

@@ -24,6 +24,7 @@ module.exports = {
   settlementPlatformUrl: 'http://webcx.test241.wanyuhengtong.com/',
   // 工单管理系统url
   GDUrl: 'http://http://bugweb.test241.wanyuhengtong.com/',
+  dashboardUrl:"http://web.report.caixiao365.com/",
   // token加密key
   secretKey: 'key123',
   loginTitle: '',

+ 2 - 3
src/layout/components/Navbar.vue

@@ -50,15 +50,14 @@
         />
       </el-tooltip>
       <el-tooltip
-        v-if="device !== 'mobile'"
+        v-if="device !== 'mobile' && Number(currentLevel) !== 3"
         placement="bottom"
         content="登录采销数据统计"
       >
-<!--        openSettlementSystem(DBUrl)-->
         <i
           class="el-icon-data-line right-menu-item hover-effect"
           style="height: 50px; width: 40px; line-height: 52px; font-size: 22px"
-          @click="openAlert"
+          @click="openSettlementSystem(DBurl)"
         />
       </el-tooltip>
       <el-tooltip

+ 9 - 8
src/views/sellOut/filing/config/columns.js

@@ -266,7 +266,8 @@ export const coveColumns = [
   {
     prop: 'brand_name',
     label: '品牌',
-    span: 8
+    span: 8,
+    _slot_: 'brand_name'
   },
   {
     prop: 'send_way',
@@ -749,13 +750,13 @@ const validate_good_name = (rule, value, callback) => {
   }
 }
 const rules = {
-  plat_orderCode: [
-    {
-      required:true,
-      message:'请输入供应商订单号',
-      trigger:'blur'
-    }
-  ],
+  // plat_orderCode: [
+  //   {
+  //     required:true,
+  //     message:'请输入供应商订单号',
+  //     trigger:'blur'
+  //   }
+  // ],
   fill_url: [
     {
       required: true,

+ 220 - 73
src/views/sellOut/filing/cpns/baseDetail.vue

@@ -76,16 +76,18 @@
               <el-tag
                 :size="'mini'"
                 v-text="
-                  (
-                    is_determine_price_options.find(
-                      (item) => item.id == sitem.is_determine_price + ''
-                    ) || {}
-                  ).label || '--'
+                  (is_determine_price_options.find((item) => item.id == sitem.is_determine_price + '') || {})
+                  .label || '--'
                 "
               />
             </template>
           </show-data-table>
         </el-collapse-item>
+
+        <!-- 没有授权 -->
+        <!-- 授权已过期 -->
+        <!-- 授权正常 -->
+
         <el-collapse-item title="商品信息" name="20">
           <show-data-table
             v-if="newTime !== ''"
@@ -93,6 +95,59 @@
             :columns="coveColumns"
             :sitem="sitem"
           >
+            <template slot="brand_name">
+              <span>{{ sitem.brand_name }}</span>
+              <el-popover placement="top" width="450" trigger="hover">
+                <div>
+                  <p
+                    v-if="mapBrandColor[brandType].text"
+                    :style="`color:${mapBrandColor[brandType].color};font-size:16px;text-align:center;margin-bottom:${brandType === 'warning' || brandType === 'noStart' ? '10px' : '0px'}`"
+                  >{{mapBrandColor[brandType].text(sitem.brand_name)}}</p>
+
+                  <show-data-table
+                    v-if="brandType !== 'danger'"
+                    :columns="brandColumns"
+                    :sitem="{
+                    name:sitem.brand_name,
+                    ...brandData,
+                  }"
+                  >
+                    <template slot="long">
+                      {{
+                      String(brandData.long) === "1" ? "非长期" : "长期"
+                      }}
+                    </template>
+
+                    <template slot="brandTime">
+                      {{String(brandData.starttime).split(" ")[0]}} ~ {{String(brandData.long) === "0" ? "长期有效" : String(brandData.endtime).split(" ")[0]}}
+                    </template>
+
+                    <template slot="brandImage">
+                        <div
+                          v-if="brandData.brand_book"
+                          style="display:flex"
+                          class="hover"
+                          v-viewer
+                        >
+                          <img
+                            v-for="url in brandData.brand_book.split(',')"
+                            :key="url"
+                            :src="url"
+                            style="display: inline-block; width: 20px;height:20px;margin-left:5px"
+                            alt
+                          />
+                        </div>
+                    </template>
+                  </show-data-table>
+                </div>
+                <i
+                  slot="reference"
+                  class="el-icon-warning-outline fr"
+                  :style="`color:${mapBrandColor[brandType].color} !important;font-weight:500`"
+                />
+              </el-popover>
+            </template>
+
             <template slot="good_name">
               <span>{{ sitem.good_name }}</span>
               <span v-for="(si, i) in sitem.specinfo" :key="si.spec_id + i">
@@ -149,11 +204,11 @@
             <template slot="noble">
               <span v-if="sitem.noble_name">
                 {{ sitem.noble_weight ? sitem.noble_weight : "0" }}g-{{
-                  sitem.noble_name
+                sitem.noble_name
                 }}-{{ sitem.gold_price ? sitem.gold_price : "0" }}元/g-{{
-                  sitem.is_gold_price === "0" ? "不" : ""
+                sitem.is_gold_price === "0" ? "不" : ""
                 }}启用实时金价-{{ sitem.is_diff === "1" ? "有" : "无" }}工差-{{
-                  sitem.config
+                sitem.config
                 }}-{{ sitem.other_config }}
               </span>
               <span v-else>--</span>
@@ -167,7 +222,7 @@
                 class="fl"
                 :src="si"
                 alt
-              >
+              />
             </template>
           </show-data-table>
         </el-collapse-item>
@@ -176,9 +231,9 @@
   </div>
 </template>
 <script>
-import asyncRequest from '@/apis/service/sellOut/filing'
-import resToken from '@/mixins/resToken'
-import { mapGetters } from 'vuex'
+import asyncRequest from "@/apis/service/sellOut/filing";
+import resToken from "@/mixins/resToken";
+import { mapGetters } from "vuex";
 
 import {
   costArr,
@@ -199,19 +254,47 @@ import {
   bargainingArr,
   statusOptions,
   is_determine_price_options
-} from '../config/columns'
+} from "../config/columns";
 
 export default {
-  name: 'FilingDetail',
+  name: "FilingDetail",
   mixins: [resToken],
   computed: {
-    ...mapGetters(['tablebtnSize', 'searchSize', 'size', 'private_field'])
+    ...mapGetters(["tablebtnSize", "searchSize", "size", "private_field"])
   },
 
   data() {
     return {
-      size: 'small',
+      size: "small",
       eaxmList: [],
+      brandColumns: [
+        {
+          prop: "name",
+          label: "品牌",
+          span: 24
+        },
+        {
+          prop: "long",
+          label: "授权类型",
+          span: 24,
+          _slot_: "long"
+        },
+        {
+          label: "授权图片",
+          span: 24,
+          _slot_: "brandImage"
+        },
+        {
+          label: "授权时间",
+          span: 24,
+          _slot_: "brandTime"
+        },
+        {
+          prop:'remark',
+          label: "备注",
+          span: 24,
+        }
+      ],
       costArr,
       bargainingArr,
       editColumns,
@@ -230,102 +313,158 @@ export default {
       statusOptions,
       is_determine_price_options,
       coveColumns,
-      projectTabs: '1',
-      activeNames: ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '20'],
-      newTime: '',
+      brandData: {},
+      projectTabs: "1",
+      activeNames: ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "20"],
+      newTime: "",
       loading: false,
-      queryType: '',
-      queryId: '',
-      status: '',
+      queryType: "",
+      queryId: "",
+      status: "",
       sitem: null,
-
+      brandType: "info",
+      mapBrandColor: {
+        warning: {
+          text: name => `供应商的 '${name}' 品牌授权已过期`,
+          color: "#E6A23C"
+        },
+        noStart: {
+          text: name => `供应商的 '${name}' 品牌授权未开始`,
+          color: "#E6A23C"
+        },
+        danger: {
+          text: name => `供应商没有 '${name}' 的品牌授权`,
+          color: "#F56C6C"
+        },
+        info: {
+          color: "#909399"
+        }
+      },
       orderItem: {},
       moneyDirItem: {},
       moneyItem: {},
       BossItem: {}
-    }
+    };
   },
   mounted() {
-    this.initForm()
+    this.initForm();
   },
   methods: {
     async initForm() {
-      const { id, type } = this.$route.query
-      this.queryId = id
-      this.queryType = type
-      this.projectTabs = '1'
-      this.loading = true
-      await this.initData()
-      this.loading = false
+      const { id, type } = this.$route.query;
+      this.queryId = id;
+      this.queryType = type;
+      this.projectTabs = "1";
+      this.loading = true;
+      await this.initData();
+      this.loading = false;
     },
 
     handleClick(row) {
-      console.log(row)
+      console.log(row);
     },
     async refresh() {
-      this.routeReGoto('filing', {})
+      this.routeReGoto("filing", {});
     },
     download() {
-      const { fill_url } = this.sitem
-      const a = document.createElement('a')
-      a.style.display = 'none'
-      a.href = fill_url
-      document.body.appendChild(a)
-      a.click()
-      document.body.removeChild(a)
+      const { fill_url } = this.sitem;
+      const a = document.createElement("a");
+      a.style.display = "none";
+      a.href = fill_url;
+      document.body.appendChild(a);
+      a.click();
+      document.body.removeChild(a);
     },
     getAnnexName() {
-      const { fill_url } = this.sitem
-      if (!fill_url) return ''
-      const chunks = fill_url.split('/')
-      const [name, suffix] = (chunks[chunks.length - 1] || '').split('.')
+      const { fill_url } = this.sitem;
+      if (!fill_url) return "";
+      const chunks = fill_url.split("/");
+      const [name, suffix] = (chunks[chunks.length - 1] || "").split(".");
 
-      if (name.length > 10) {
-        return ([name[0], name[1], name[2], ' ... ', name[name.length - 2], name[name.length - 1]]).join('') + '.' + suffix
+      if (name.length > 12) {
+        const [first, second, third, ...rest] = name.split("");
+        return `
+          ${[
+            first,
+            second,
+            third,
+            " ... ",
+            rest[rest.length - 2],
+            rest[rest.length - 1]
+          ].join("")}.${suffix}
+        `;
       }
 
-      return name + '.' + suffix
+      return `${name}.${suffix}`;
     },
     async initData() {
-      this.loading = true
-
+      this.loading = true;
       const { code, message, data } = await asyncRequest.detail({
         id: this.queryId
-      })
-
-      // return
-      this.eaxmList = []
-      this.loading = false
+      });
+      this.eaxmList = [];
+      this.loading = false;
       if (code === 0) {
-        this.sitem = JSON.parse(JSON.stringify(data))
-        const { cat_info } = this.sitem
-        let cat = ''
-
+        this.sitem = JSON.parse(JSON.stringify(data));
+        const { cat_info } = this.sitem;
+        let cat = "";
         if (cat_info && cat_info.length > 0) {
           cat_info.forEach((e, i) => {
-            cat += i === 0 ? e.name : '_' + e.name
-          })
+            cat += i === 0 ? e.name : "_" + e.name;
+          });
+        }
+        this.sitem.cat = cat;
+        const { status, num, orderCode } = this.sitem;
+        this.status = status;
+        const { brand_id, supplierNo } = data;
+
+        const result = await asyncRequest.keepqueryl({
+          brand_id,
+          gyscode: supplierNo
+        });
+
+        if (result.code === 0) {
+          if (result.data.length === 0) {
+            // 没有找到授权信息
+            this.brandType = "danger";
+          }
+
+          this.brandData = result.data;
+          const { endtime, starttime ,long } = this.brandData;
+          const now = new Date();
+          const start = new Date(starttime);
+
+          if(start > now){
+            this.brandType = "noStart"
+          }
+
+
+          if (String(long) === "1") {
+            // 短期 查看授权是否过期
+            const end = new Date(endtime);
+
+            if (now > end) {
+              // 过期
+              this.brandType = "warning";
+            }
+          }
         }
-        this.sitem.cat = cat
-        const { status, num, orderCode } = this.sitem
-        this.status = status
 
-        this.$emit('change-detail', data)
-        // this.$emit('change-status', status)
-        this.$emit('change-num', num)
-        this.$emit('change-order-code', orderCode)
-        this.getNewTime()
+        this.$emit("change-detail", data);
+        this.$emit("change-num", num);
+        this.$emit("change-order-code", orderCode);
+        this.getNewTime();
       } else if (code >= 100 && code <= 104) {
-        await this.logout()
+        await this.logout();
       } else {
-        this.$message.warning(message)
+        this.$message.warning(message);
       }
     },
     getNewTime() {
-      this.newTime = new Date().valueOf()
+      this.newTime = new Date().valueOf();
     }
   }
-}
+};
 </script>
 <style lang="scss" scoped>
 .filingDetail {
@@ -368,5 +507,13 @@ export default {
     width: calc(100% - 40px);
     border-left: 1px solid #dcdfe6;
   }
+
+  .warning {
+    color: yellow !important;
+  }
+
+  .danger {
+    color: red;
+  }
 }
 </style>

+ 3 - 3
src/views/sellOut/filing/detail.vue

@@ -37,9 +37,9 @@
             </el-collapse-item>
           </tempalte>
 
-<!--          <el-collapse-item v-if="status === '3'" name="4" title="发货单">-->
-<!--            <shipment-request :order-code="orderCode" />-->
-<!--          </el-collapse-item>-->
+<!--          <el-collapse-item v-if="status === '3'" name="4" title="发货单"> -->
+<!--            <shipment-request :order-code="orderCode" /> -->
+<!--          </el-collapse-item> -->
         </el-collapse>
       </el-tab-pane>
 

+ 4 - 4
src/views/serviceParam/brand/index.vue

@@ -278,10 +278,10 @@ export default {
           label: "申请人部门",
           minWidth: "150px",
         },
-        // {
-        //   prop: "creater",
-        //   label: "创建人",
-        // },
+        {
+          prop: "creater",
+          label: "创建人",
+        },
         {
           prop: "addtime",
           label: "创建时间",

+ 4 - 3
src/views/serviceParam/grossProfit/index.vue

@@ -50,7 +50,7 @@
             </el-col>
           </el-row>
           <el-row>
-            <el-col :span="4" style="width: 160px">
+            <!-- <el-col :span="4" style="width: 160px">
               <el-select
                 v-model="parmValue.status"
                 filterable
@@ -71,8 +71,9 @@
                   :value="item.code"
                 />
               </el-select>
-            </el-col>
-            <el-col :span="4" style="width: 380px; padding: 0 0 0 10px">
+            </el-col> -->
+            <!-- padding: 0 0 0 10px" -->
+            <el-col :span="4" style="width: 380px;">
               <el-input
                 :size="searchSize"
                 v-model="parmValue.cat_name"

+ 112 - 46
src/views/serviceParam/supplierBrand/addEdit.vue

@@ -43,7 +43,7 @@
                 <el-radio :label="'1'">非长期</el-radio>
               </el-radio-group>
             </el-form-item>
-            <el-form-item v-if="ruleForm.long === '1'" label="授权时间" style="margin: 0">
+            <el-form-item label="授权时间" style="margin: 0" required="true">
               <el-col :span="11">
                 <el-form-item prop="starttime">
                   <el-date-picker
@@ -60,7 +60,7 @@
               </el-col>
               <el-col class="line tc" :span="2">-</el-col>
               <el-col :span="11">
-                <el-form-item prop="endtime">
+                <el-form-item prop="endtime" v-if="ruleForm.long === '1'">
                   <el-date-picker
                     type="date"
                     :disabled="type === 'view'"
@@ -72,45 +72,62 @@
                     @change="timeChange"
                   ></el-date-picker>
                 </el-form-item>
+
+                <p style="font-size:16px;font-weight:700" v-else>长期有效</p>
               </el-col>
             </el-form-item>
-            <el-col :span="17">
+            <el-col :span="24">
               <el-form-item
                 label="授权图片"
                 prop="brand_book"
                 :disabled="id == '007'"
                 class="activity-upload"
               >
-                <div class="btnupload" style="position: relative">
-                  <img
-                    v-if="ruleForm.brand_book"
-                    :src="ruleForm.brand_book"
-                    class="avatar"
-                  />
-                  <i v-else class="el-icon-plus avatar-uploader-icon"></i>
+                <template v-if="ruleForm.brand_book && ruleForm.brand_book.length > 0">
+                  <div
+                    class="btnupload"
+                    style="position: relative;"
+                    v-for="(url,index) in ruleForm.brand_book"
+                    :key="url"
+                  >
+                    <img :src="url" class="avatar" />
+                    <i v-if="type !== 'view'" class="el-icon-close" @click="ruleForm.brand_book.splice(index,1)" />
+                  </div>
+                </template>
+
+                <div class="btnupload" style="position: relative;"  v-if="type !== 'view'">
+                  <i class="el-icon-plus avatar-uploader-icon" />
                   <file-upload
                     class="Upload"
-                    :disabled="type === 'view'"
-                    :accept="'.jpg,.png,.jpeg'"
                     :multiple="true"
-                    :uploadcondition="beforeAvatarUpload"
+                    :accept="'.jpg,.png,.jpeg'"
+                    :disabled="type === 'view'"
                     @UploadErrorEvent="UploadErrorEvent"
+                    :uploadcondition="beforeAvatarUpload"
                     @UploadSuccessEvent="UploadSuccessEvent"
                   ></file-upload>
                 </div>
               </el-form-item>
             </el-col>
-            <el-col :span="7" style="text-align: right; padding: 72px 0 0 0">
+
+            <el-col :span="24">
+              <el-form-item label="备注" prop="remark">
+                <el-input :disabled="type === 'view'" type="textarea" v-model="ruleForm.remark" placeholder="备注" />
+              </el-form-item>
+            </el-col>
+
+            <el-col :span="24" style="text-align: right;">
               <el-button
                 v-if="type !== 'view'"
                 :size="'small'"
                 type="primary"
                 @click="submitForm"
-                >保 存
-              </el-button>
-              <el-button @click="showModelThis = false" :size="'small'">{{
+              >保 存</el-button>
+              <el-button @click="showModelThis = false" :size="'small'">
+                {{
                 type === "view" ? "关 闭" : "取 消"
-              }}</el-button>
+                }}
+              </el-button>
             </el-col>
           </el-form>
         </el-col>
@@ -120,7 +137,9 @@
 </template>
 <script>
 import asyncRequest from "@/apis/service/serviceParam/supplierBrand";
+import { hasSpace } from "@/utils/validate";
 import resToken from "@/mixins/resToken";
+import dayjs from 'dayjs';
 export default {
   name: "brand",
   props: ["showModel", "id", "type", "sitem"],
@@ -134,26 +153,34 @@ export default {
       ruleForm: {},
       rulesThis: this.rules,
       pickerOptions1: {
-        disabledDate: (time) => {
-          if (this.ruleForm.endtime != null && this.ruleForm.endtime != "" && time) {
+        disabledDate: time => {
+          if (
+            this.ruleForm.endtime != null &&
+            this.ruleForm.endtime != "" &&
+            time
+          ) {
             return time.getTime() > new Date(this.ruleForm.endtime).valueOf();
           }
-        },
+        }
       },
       pickerOptions2: {
-        disabledDate: (time) => {
-          if (this.ruleForm.starttime != null && this.ruleForm.starttime != "" && time) {
+        disabledDate: time => {
+          if (
+            this.ruleForm.starttime != null &&
+            this.ruleForm.starttime != "" &&
+            time
+          ) {
             return time.getTime() < new Date(this.ruleForm.starttime).valueOf();
           }
-        },
+        }
       },
       rules: {
         gyscode: [
           {
             required: true,
             message: "供应商不能为空",
-            trigger: "change",
-          },
+            trigger: "change"
+          }
         ],
 
         brand_id: [
@@ -161,17 +188,26 @@ export default {
             type: "array",
             required: true,
             message: "请选择支持品牌",
-            trigger: "blur",
-          },
+            trigger: "blur"
+          }
         ],
-        long: [{ required: false, message: "请选择授权类型", trigger: "change" }],
-        starttime: [{ required: false, message: "请选择授权开始日期", trigger: "blur" }],
-        brand_book: [{ required: false, message: "授权图片不能为空", trigger: "change" }],
-      },
+        long: [
+          { required: true, message: "请选择授权类型", trigger: "change" }
+        ],
+        starttime: [
+          { required: true, message: "请选择授权开始日期", trigger: "blur" }
+        ],
+        endtime: [
+          { required: true, message: "请选择授权结果日期", trigger: "blur" }
+        ]
+      }
     };
   },
   watch: {
-    showModel: function (val) {
+    // "ruleForm.long": function(val) {
+    //   this.rulesThis.long[0].required = Number(val) !== 0;
+    // },
+    showModel: function(val) {
       this.showModelThis = val;
       if (val) {
         this.initForm();
@@ -181,7 +217,7 @@ export default {
       if (!val) {
         this.$emit("cancel");
       }
-    },
+    }
   },
   methods: {
     async initForm() {
@@ -243,20 +279,21 @@ export default {
     resetFormData() {
       this.ruleForm = {
         id: "",
+        remark:"",
         gyscode: this.sitem,
         brand_id: [],
         long: "1",
         starttime: "",
         endtime: "",
-        brand_book: "",
+        brand_book: []
       };
-      console.log(this.sitem);
     },
     async initData() {
       this.loading = true;
       const { code, message, data } = await asyncRequest.detail({
-        id: this.id,
+        id: this.id
       });
+
       this.loading = false;
       if (code === 0) {
         const {
@@ -268,6 +305,7 @@ export default {
           starttime,
           endtime,
           gyscode,
+          remark
         } = data;
         this.brand_name = brand_name;
         this.ruleForm = {
@@ -277,7 +315,8 @@ export default {
           long: long || "",
           starttime: starttime || "",
           endtime: endtime || "",
-          brand_book: brand_book || "",
+          brand_book: brand_book ? brand_book.split(",") : [],
+          remark: remark || ""
         };
       } else if (code >= 100 && code <= 104) {
         await this.logout();
@@ -286,13 +325,26 @@ export default {
       }
     },
     async submitForm() {
-      await this.$refs.ruleForm.validate(async (valid) => {
+      await this.$refs.ruleForm.validate(async valid => {
         if (valid) {
           if (this.loading) return;
           this.loading = true;
           let model = JSON.parse(JSON.stringify(this.ruleForm));
           model.brand_id = model.brand_id.toString();
-          // model.gyscode = model.gyscode.toString();
+          model.brand_book = model.brand_book.join(",");
+          model.status = "1";
+
+          if(model.starttime){
+            model.starttime = dayjs(model.starttime).format("YYYY-MM-DD HH:mm:ss");
+          }
+
+          if(model.endtime){
+            model.endtime = dayjs(model.endtime).format("YYYY-MM-DD HH:mm:ss");
+          }
+
+          if(String(model.long) === "0"){
+            delete model.endtime
+          }
 
           let res = {};
           if (this.type === "add") {
@@ -307,7 +359,7 @@ export default {
             const title = this.type === "add" ? "添加成功!" : "修改成功!";
             this.$notify.success({
               title,
-              message: "",
+              message: ""
             });
             this.showModelThis = false;
             // 刷新
@@ -356,7 +408,7 @@ export default {
     UploadErrorEvent(res) {
       if (res !== "break") {
         this.$message.error("图片上传失败!");
-        this.ruleForm.brand_book = "";
+        this.ruleForm.brand_book = [];
         this.$refs.ruleForm.validateField("brand_book");
       }
     },
@@ -366,16 +418,30 @@ export default {
       if (url === "noToken") {
         await this.logout();
       } else {
-        this.ruleForm.brand_book = url;
+        console.log(this.ruleForm.brand_book);
+        this.ruleForm.brand_book.push(url);
         this.$message.success("图片上传成功!");
         this.$refs.ruleForm.validateField("brand_book");
       }
-    },
-  },
+    }
+  }
 };
 </script>
 
 <style lang="scss" scoped>
-.brand {
+.btnupload {
+  margin-left: 5px !important;
+  margin-bottom: 5px !important;
+
+  .el-icon-close {
+    position: absolute;
+    top: 5px;
+    right: 5px;
+    cursor: pointer;
+
+    &:hover {
+      color: #409eff;
+    }
+  }
 }
 </style>

+ 5 - 3
src/views/serviceParam/supplierBrand/index.vue

@@ -73,8 +73,10 @@
               v-viewer
             >
               <img
-                :src="scope.row.brand_book"
-                style="display: inline-block; width: 100%; height: 100%"
+                v-for="url in scope.row.brand_book.split(',')"
+                :key="url"
+                :src="url"
+                style="display: inline-block; width: 100%; height: 100%;margin-left:5px"
                 alt=""
               />
             </div>
@@ -89,7 +91,7 @@
             ></el-tag>
           </template>
           <template #longTime="{ scope }">
-            {{ scope.row.starttime }}~{{ scope.row.endtime }}
+            {{ scope.row.starttime.split(" ")[0] }}~{{ String(scope.row.long) === "0" ? "长期有效" : scope.row.endtime.split(" ")[0] }}
           </template>
           <template #status="{ scope }">
             <el-tag

+ 9 - 8
src/views/supplierSellOut/supplierFiling/config/columns.js

@@ -266,7 +266,8 @@ export const coveColumns = [
   {
     prop: 'brand_name',
     label: '品牌',
-    span: 8
+    span: 8,
+    _slot_:'brand_name'
   },
   {
     prop: 'send_way',
@@ -764,13 +765,13 @@ const rules = {
   //     trigger: 'chanage'
   //   }
   // ],
-  plat_orderCode:[
-    {
-      required: true,
-      message: '请输入供应商订单号',
-      trigger: 'blur'
-    }
-  ],
+  // plat_orderCode:[
+  //   {
+  //     required: true,
+  //     message: '请输入供应商订单号',
+  //     trigger: 'blur'
+  //   }
+  // ],
   fill_url: [
     {
       required: true,

+ 132 - 1
src/views/supplierSellOut/supplierFiling/cpns/baseDetail.vue

@@ -97,6 +97,59 @@
             :columns="coveColumns"
             :sitem="sitem"
           >
+             <template slot="brand_name">
+              <span>{{ sitem.brand_name }}</span>
+              <el-popover placement="top" width="450" trigger="hover">
+                <div>
+                  <p
+                    v-if="mapBrandColor[brandType].text"
+                    :style="`color:${mapBrandColor[brandType].color};font-size:16px;text-align:center;margin-bottom:${brandType === 'warning' || brandType === 'noStart' ? '10px' : '0px'}`"
+                  >{{mapBrandColor[brandType].text(sitem.brand_name)}}</p>
+
+                  <show-data-table
+                    v-if="brandType !== 'danger'"
+                    :columns="brandColumns"
+                    :sitem="{
+                    name:sitem.brand_name,
+                    ...brandData,
+                  }"
+                  >
+                    <template slot="long">
+                      {{
+                      String(brandData.long) === "1" ? "非长期" : "长期"
+                      }}
+                    </template>
+
+                    <template slot="brandTime">
+                      {{String(brandData.starttime).split(" ")[0]}} ~ {{String(brandData.long) === "0" ? "长期有效" : String(brandData.endtime).split(" ")[0]}}
+                    </template>
+
+                    <template slot="brandImage">
+                        <div
+                          v-if="brandData.brand_book"
+                          style="display:flex"
+                          class="hover"
+                          v-viewer
+                        >
+                          <img
+                            v-for="url in brandData.brand_book.split(',')"
+                            :key="url"
+                            :src="url"
+                            style="display: inline-block; width: 20px;height:20px;margin-left:5px"
+                            alt
+                          />
+                        </div>
+                    </template>
+                  </show-data-table>
+                </div>
+                <i
+                  slot="reference"
+                  class="el-icon-warning-outline fr"
+                  :style="`color:${mapBrandColor[brandType].color} !important;font-weight:500`"
+                />
+              </el-popover>
+            </template>
+
             <template slot="good_name">
               <span>{{ sitem.good_name }}</span>
               <span v-for="(si, i) in sitem.specinfo" :key="si.spec_id + i">
@@ -215,6 +268,34 @@ export default {
     return {
       size: 'small',
       eaxmList: [],
+      brandColumns: [
+        {
+          prop: "name",
+          label: "品牌",
+          span: 24
+        },
+        {
+          prop: "long",
+          label: "授权类型",
+          span: 24,
+          _slot_: "long"
+        },
+        {
+          label: "授权图片",
+          span: 24,
+          _slot_: "brandImage"
+        },
+        {
+          label: "授权时间",
+          span: 24,
+          _slot_: "brandTime"
+        },
+        {
+          prop:'remark',
+          label: "备注",
+          span: 24,
+        }
+      ],
       costArr,
       bargainingArr,
       editColumns,
@@ -241,7 +322,24 @@ export default {
       queryId: '',
       status: '',
       sitem: null,
-
+      brandType: "info",
+      mapBrandColor: {
+        warning: {
+          text: name => `供应商 '${name}' 的品牌授权已过期`,
+          color: "#E6A23C"
+        },
+        noStart: {
+          text: name => `供应商 '${name}' 的品牌授权未开始`,
+          color: "#E6A23C"
+        },
+        danger: {
+          text: name => `供应商没有 '${name}' 的品牌授权`,
+          color: "#F56C6C"
+        },
+        info: {
+          color: "#909399"
+        }
+      },
       orderItem: {},
       moneyDirItem: {},
       moneyItem: {},
@@ -310,6 +408,39 @@ export default {
         const { status, wait_num, orderCode } = this.sitem
         this.status = status
 
+        const { brand_id, supplierNo } = data;
+        const result = await asyncRequest.keepqueryl({
+          brand_id,
+          gyscode: supplierNo
+        });
+
+        if (result.code === 0) {
+          if (result.data.length === 0) {
+            // 没有找到授权信息
+            this.brandType = "danger";
+          }
+
+          this.brandData = result.data;
+          const { endtime, starttime ,long } = this.brandData;
+          const now = new Date();
+          const start = new Date(starttime);
+
+          if(start > now){
+            this.brandType = "noStart"
+          }
+
+
+          if (String(long) === "1") {
+            // 短期 查看授权是否过期
+            const end = new Date(endtime);
+
+            if (now > end) {
+              // 过期
+              this.brandType = "warning";
+            }
+          }
+        }
+
         this.$emit('change-detail', data)
         this.$emit('change-status', status)
         this.$emit('change-num', wait_num)

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