bding 11 months ago
parent
commit
8d33b6db48

+ 8 - 0
src/api/modules/crmApi.js

@@ -1287,6 +1287,14 @@ const xClassCustomApi = {
   enterScoreDelete:(params)=>{
     return http.post("/cygx/enterScore/delete",params)
   },  
+  // 评分总览接口
+  enterScoreScoreOverview:(params)=>{
+    return http.get("/cygx/enterScore/scoreOverview",params)
+  }, 
+  // 排名总览接口
+  enterScoreRankingOverview:(params)=>{
+    return http.get("/cygx/enterScore/rankingOverview",params)
+  }, 
 }
 
 export { customInterence,customAllInterence, equityContacts,etaTrialInterence,xClassCustomApi};

+ 9 - 1
src/views/custom_manage/approvalTurn.vue

@@ -14,7 +14,7 @@
 							<span>合同类型: {{contractInfo.ContractType}}</span>
 						</li>
 						<li>
-							<span style="min-width:450px;marginRight:260px;display:inline-block;">合同期限:{{contractInfo.StartDate}}-{{contractInfo.EndDate}}({{contractInfo.StartDate|formateYear(contractInfo.EndDate)}})</span>
+							<span style="min-width:450px;marginRight:260px;display:inline-block;">合同期限:{{ContractTermTxt}}</span>
 							<span>合同金额:{{contractInfo.Money}}元</span>
 						</li>
 						<li>
@@ -267,6 +267,14 @@ export default {
 		}
 		this.getCompanyInfo()
 	},
+	computed:{
+		ContractTermTxt(){
+			let date = `${this.contractInfo.StartDate}-${this.contractInfo.EndDate}`;
+			let calculation = CalculationDate(this.contractInfo.StartDate,this.contractInfo.EndDate);
+			let str = this.contractInfo.Quarter ? this.contractInfo.Quarter + `(${date})` : date + `(${calculation})`;
+			return str
+		}
+	},
 }
 </script>
 <style lang='scss'>

+ 1 - 1
src/views/custom_manage/approvalUpdate.vue

@@ -12,7 +12,7 @@
 						<span>合同类型:{{contractInfo.ContractType}}</span><span class="contract_type_hint">{{contractInfo.SourceTag}}</span>
 					</li>
 					<li>
-						<span style="min-width:320px;marginRight:260px;display:inline-block;">合同期限:{{contractInfo.StartDate}}-{{contractInfo.EndDate}}({{diff_time}}年期)</span>
+						<span style="min-width:320px;marginRight:260px;display:inline-block;">合同期限:{{contractInfo.Quarter}}{{contractInfo.StartDate}}-{{contractInfo.EndDate}}({{diff_time}}年期)</span>
 						<span>合同金额:{{contractInfo.Money}}元</span>
 					</li>
 					<li>

+ 11 - 9
src/views/custom_manage/customList/applyTurn.vue

@@ -66,7 +66,7 @@
 									<i class="el-icon-info"></i>
 							</el-tooltip>
 						</el-form-item>
-						<el-form-item label="合同期限" prop="term" style="marginRight:60px;" v-if="companyInfo.Status !='永续'">
+						<el-form-item label="合同期限" prop="term" style="marginRight:60px;" :rules="{ required: true, message: '合同期限不能为空', trigger: 'blur' }" v-if="companyInfo.Status !='永续'">
 							<i style="color:#f00;fontSize:20px;position:absolute;left:-90px;top:10%;">*</i>
 							<el-date-picker
 							v-model="formData.term"
@@ -79,11 +79,11 @@
 							style="width:400px;">
 							</el-date-picker>
 						</el-form-item>
-						<el-form-item label="合同期限" prop="term" style="marginRight:60px;" v-if="companyInfo.Status =='永续'">
+						<el-form-item label="合同期限" prop="term" :rules="{ required: true, message: '合同期限不能为空2211', trigger: 'change' }" style="marginRight:60px;" v-if="companyInfo.Status =='永续'">
 							<i style="color:#f00;fontSize:20px;position:absolute;left:-90px;top:10%;">*</i>
 							<div class="quarters-content">
-								<el-checkbox-group v-model="selectedQuarters">
-									<el-checkbox v-for="quarter in quarters" :key="quarter.value" :label="quarter.label" :disabled="isDisabled(quarter)">
+								<el-checkbox-group v-model="selectedQuarters" @input="checkboxInputHandler">
+									<el-checkbox v-for="quarter in quarters" :key="quarter.value" :label="quarter.label" :disabled="isDisabled(quarter)" >
 										{{ quarter.label }}
 									</el-checkbox>
 								</el-checkbox-group>
@@ -214,9 +214,6 @@ export default {
 			hasNoChild:false, // 医药、消费、科技、智造是否没有主客观
 			authList:[],//权限列表
 			formRule:{
-				term:[
-					{ required: true, message: '合同期限不能为空', trigger: 'blur' },
-				],
 				amount:[
 					{ required: true, message: '合同金额不能为空', trigger: 'blur' },
 					{ type: 'number', message: '合同金额必须为数字'}
@@ -309,7 +306,8 @@ export default {
 		/* 获取基本权限信息 */
 		getAuthBasic() {
 			customInterence.authList({
-				IsShowYanXuanKouDian:true
+				IsShowYanXuanKouDian:true,
+				CompanyStatus:this.companyInfo.Status 
 			}).then(res => {
 				let newArr = [];
 				if(res.Ret === 200) {
@@ -592,7 +590,11 @@ export default {
 				})
 				this.$message.warning('请勾选品种')
 			}
-		}
+		},
+	checkboxInputHandler(){
+		this.formData.term = this.selectedQuarters ? [this.selectedDateRange.split(" ~ ")[0],this.selectedDateRange.split(" ~ ")[1]]:[]
+		console.log(this.formData.term);
+	}
 	
 	},
 	created() {},

+ 1 - 1
src/views/custom_manage/customList/components/raiPermissionbox.vue

@@ -51,7 +51,7 @@
             </el-checkbox>
           </div>
         </el-checkbox-group>
-        <div class="rai-checkbox-notice-box">
+        <div class="rai-checkbox-notice-box" v-if="data.ItemsUp.length>0">
           <span class="rai-checkbox-notice" v-if="formData.qyBigServeCheck">
             同时包含{{formData.qyBigServeCheck==2?"10":"16"}}次专项调研</span>
           <p class="rai-checkbox-notice" v-if="equityGroupDisabled(data.CheckList)">同时包含升级行业各5次专项调研</p>

+ 0 - 18
src/views/custom_manage/customList/mixins/quartersMixin.js

@@ -69,24 +69,6 @@ export default {
           return `${year}-10-01 ~ ${year}-12-31`;
       }
     },
-
-    // handleCheckboxChange(value) {
-    //   value.sort((a, b) => a.localeCompare(b));
-
-    //   for (let i = value.length - 1; i > 0; i--) {
-    //     if (!this.areConsecutive(value[i], value[i - 1])) {
-    //       this.selectedQuarters.splice(i, 1);
-    //       break;
-    //     }
-    //   }
-    // },
-
-    // areConsecutive(a, b) {
-    //   const indexA = this.quarters.findIndex((q) => q.value === a);
-    //   const indexB = this.quarters.findIndex((q) => q.value === b);
-
-    //   return Math.abs(indexA - indexB) === 1;
-    // },
     isConsecutiveSelection() {
       const sortedSelectedIndexes = this.selectedQuarters.map((sq) => this.quarters.findIndex((aq) => aq.value === sq)).sort((a, b) => a - b);
       for (let i = 0; i < sortedSelectedIndexes.length - 1; i++) {

+ 2 - 0
src/views/custom_manage/points/AddNewEntries.vue

@@ -288,6 +288,8 @@ export default {
         this.brokerName = res.Data.SecuritiesFirmsName;
         this.mergeProportion = res.Data.MergeProportion;
         this.selectedQuarters = res.Data.Quarter;
+        this.companyId = res.Data.CompanyId;
+        this.companyName = res.Data.CompanyName;
       }
     },
     //

+ 71 - 17
src/views/custom_manage/points/EntryRecords.vue

@@ -1,20 +1,28 @@
 <template>
   <div class="container entry-records-points">
     <div>
-      <el-input placeholder="请输入公司名称" v-model="companyName" style="width: 220px" @input="companyHandleSearch" clearable>
+      <el-autocomplete
+        v-model="companyName"
+        :fetch-suggestions="querySearchAsync"
+        style="width: 220px; margin-right: 20px"
+        @select="selectCompanyChange"
+        clearable
+        placeholder="请输入公司名称"
+        @clear="clearCompanyHandleSearch"
+      >
         <i slot="prefix" class="el-input__icon el-icon-search"></i>
-      </el-input>
+      </el-autocomplete>
       <el-cascader
         v-model="sales"
         placeholder="请选择销售"
-        style="width: 200px; marginright: 10px; marginbottom: 8px"
+        style="width: 200px; margin-right: 20px"
         :options="salesArr"
         :props="defaultSalesProps"
         :show-all-levels="false"
         collapse-tags
         clearable
         filterable
-        @change="changeSales"
+        @change="companyHandleSearch"
       >
       </el-cascader>
       <el-button type="primary" @click="$router.push('AddNewEntries')"> 新增</el-button>
@@ -25,14 +33,14 @@
         <el-table-column align="center" prop="CompanyName" label="客户名称"> </el-table-column>
         <el-table-column align="center" prop="SellerName" label="销售" width="100"> </el-table-column>
         <el-table-column align="center" prop="Quarter" label="季度" width="180">
-          <template scope="{row}">
+          <template slot-scope="{ row }">
             <span>{{ row.Quarter.join(",") }}</span>
           </template>
         </el-table-column>
         <el-table-column align="center" prop="ProportionTotal" label="总分" width="100"> </el-table-column>
         <el-table-column align="center" prop="Ranking" label="排名" width="100"> </el-table-column>
         <el-table-column align="center" prop="IsMergeScoring" label="合并打分" width="80">
-          <template scope="{row}">
+          <template slot-scope="{ row }">
             <span>{{ row.IsMergeScoring == 1 ? "是" : "否" }}</span>
           </template>
         </el-table-column>
@@ -40,7 +48,7 @@
         <el-table-column align="center" prop="CreateTime" label="首次录入时间" width="180"> </el-table-column>
         <el-table-column align="center" prop="ModifyTime" label="最近更新时间" width="180"> </el-table-column>
         <el-table-column align="center" prop="name" label="操作" width="180">
-          <template scope="{row}">
+          <template slot-scope="{ row }">
             <span class="editsty" @click="lookHandler(row)">查看明细</span>
             <span class="deletesty" @click="deleteHandle(row)">删除</span>
           </template>
@@ -52,11 +60,14 @@
 
 <script>
 import { customInterence, xClassCustomApi } from "@/api/api.js";
-import { async } from "@antv/x6/lib/registry/marker/main";
 export default {
-  name: "",
-  components: {},
-  props: {},
+  name: "EntryRecords",
+  props: {
+    searchVal: {
+      type: String,
+      default: "",
+    },
+  },
   data() {
     return {
       page_no: 1,
@@ -74,16 +85,21 @@ export default {
       }, //销售级联配置
     };
   },
-  computed: {},
-  watch: {},
-  created() {},
+  watch: {
+    searchVal() {
+      this.getDataList();
+    },
+  },
   mounted() {
     this.getSale();
     this.getDataList();
   },
   methods: {
     // 公司名称
-    companyHandleSearch() {},
+    companyHandleSearch(value) {
+      this.page_no = 1;
+      this.getDataList();
+    },
     /* 获取销售 */
     getSale() {
       let status = 0;
@@ -98,9 +114,17 @@ export default {
     },
     // 获取列表信息
     async getDataList() {
+      let salesArr = [];
+      if (this.sales.length) {
+        salesArr = this.sales.map((item) => {
+          return item[item.length - 1];
+        });
+      }
       const res = await xClassCustomApi.enterScoreList({
         PageSize: this.pageSize,
         CurrentIndex: this.page_no,
+        KeyWord: this.companyName,
+        AdminId: salesArr.join(","),
       });
       if (res.Ret === 200) {
         this.total = res.Data.Paging.Totals;
@@ -140,10 +164,40 @@ export default {
         query: { id: item.EnterScoreId },
       });
     },
+    //
+    async querySearchAsync(query, cb) {
+      cb([]);
+      if (query) {
+        const res = await xClassCustomApi.enterScoreSearchlist({ KeyWord: query });
+        if (res.Ret === 200) {
+          console.log(res);
+          this.querySearchList = res.Data.List.map((_) => {
+            return {
+              ..._,
+              value: _.CompanyName,
+            };
+          });
+          cb(this.querySearchList);
+        }
+      }
+      // else if (query == "") {
+      //   this.clearCompanyHandleSearch();
+      // }
+    },
+    // 选择后客户名称的id
+    selectCompanyChange(value) {
+      console.log(value, "selectCompanyChange");
+      this.companyId = value.CompanyId;
+    },
+    clearCompanyHandleSearch() {
+      this.companyId = "";
+      this.page_no = 1;
+      this.getDataList();
+    },
   },
 };
 </script>
 <style scoped lang="scss">
-.entry-records-points {
-}
+// .entry-records-points {
+// }
 </style>

+ 160 - 4
src/views/custom_manage/points/RankingOverview.vue

@@ -4,7 +4,7 @@
       <el-cascader
         v-model="sales"
         placeholder="请选择销售"
-        style="width: 200px; margin-right: 10px"
+        style="width: 220px"
         :options="salesArr"
         :props="defaultSalesProps"
         :show-all-levels="false"
@@ -14,14 +14,52 @@
         @change="changeSales"
       >
       </el-cascader>
-      <el-cascader v-model="valueLocation" collapse-tags :props="{ multiple: true, value: 'name', children: 'city', label: 'name' }" clearable :options="locationOptions" placeholder="请选择城市">
+      <el-cascader
+        style="width: 220px; margin: 0 20px"
+        v-model="valueLocation"
+        collapse-tags
+        :props="{ multiple: true, value: 'name', children: 'city', label: 'name' }"
+        clearable
+        :options="locationOptions"
+        placeholder="请选择城市"
+      >
       </el-cascader>
+      <a :href="exportUser" download>
+        <el-button type="primary" style="width: 80px">导出</el-button>
+      </a>
+    </div>
+    <div class="table-cont">
+      <template v-if="tableTheadColumns.length">
+        <table>
+          <thead>
+            <tr>
+              <td class="'head-column'"></td>
+              <td v-for="item in tableTheadColumns" :key="item" :class="['head-column']">
+                {{ item.CompanyName }}
+              </td>
+            </tr>
+          </thead>
+        </table>
+
+        <div class="table-body-wrapper">
+          <table>
+            <tbody v-for="(item, index) in datalist" :key="index">
+              <tr>
+                <td class="thead-rs">{{ item.Quarter }}</td>
+                <td v-for="key in item.ProportionListText" :key="key">{{ key }}</td>
+              </tr>
+            </tbody>
+          </table>
+        </div>
+        <template v-if="!datalist.length"> <div class="not-text">暂无数据</div> </template>
+      </template>
+      <template v-else> <div class="not-text">暂无数据</div> </template>
     </div>
   </div>
 </template>
 
 <script>
-import { customInterence } from "@/api/api.js";
+import { customInterence, xClassCustomApi } from "@/api/api.js";
 import { locationOptions } from "../customList/location";
 
 export default {
@@ -30,7 +68,6 @@ export default {
   props: {},
   data() {
     return {
-      valueLocation: [],
       sales: "",
       salesArr: [], //销售
       defaultSalesProps: {
@@ -39,17 +76,33 @@ export default {
         children: "ChildrenList",
         value: "AdminId",
       }, //销售级联配置
+      valueLocation: [], //地址
+      tableTheadColumns: [],
+      datalist: [],
+      listGroup: [],
     };
   },
   computed: {
     locationOptions() {
       return locationOptions;
     },
+    exportUser() {
+      let baseUrl = process.env.API_ROOT + "/cygx/enterScore/rankingOverview";
+      let token = localStorage.getItem("auth") || "";
+      let paramStr = "";
+      let params = this.paramsHandler();
+      params.IsExport = true;
+      for (let key in params) {
+        paramStr = `${paramStr}&${key}=${params[key]}`;
+      }
+      return `${baseUrl}?${token}${paramStr}`;
+    },
   },
   watch: {},
   created() {},
   mounted() {
     this.getSale();
+    this.getDataList();
   },
   methods: {
     /* 获取销售 */
@@ -64,6 +117,34 @@ export default {
         }
       });
     },
+    async getDataList() {
+      let params = this.paramsHandler();
+      const res = await xClassCustomApi.enterScoreRankingOverview(params);
+      if (res.Ret === 200) {
+        console.log(res, "\\");
+        this.tableTheadColumns = res.Data.ListCompany || [];
+        this.datalist = res.Data.ListQuarterDate || [];
+      }
+    },
+    // 处理数据, 获取数据
+    paramsHandler() {
+      let salesArr = [];
+      if (this.sales.length) {
+        salesArr = this.sales.map((item) => {
+          return item[item.length - 1];
+        });
+      }
+      const cityArr = [];
+      this.valueLocation.forEach((item) => {
+        cityArr.push(item[1]);
+      });
+      let cityValue = cityArr.join(",");
+      let params = {
+        City: cityValue,
+        AdminId: salesArr.join(","),
+      };
+      return params;
+    },
   },
 };
 </script>
@@ -72,5 +153,80 @@ export default {
   .select-box {
     display: flex;
   }
+
+  .top-select {
+    display: flex;
+    justify-content: space-between;
+  }
+  .select-box {
+    display: flex;
+    margin-bottom: 30px;
+  }
+  .table-cont {
+    overflow: auto;
+    .table-body-wrapper {
+      max-height: calc(100vh - 400px);
+      margin-right: -6px;
+      border-bottom: 1px solid #dcdfe6;
+      border-top: 1px solid #dcdfe6;
+    }
+    table {
+      font-size: 14px;
+      color: #666;
+      thead {
+        position: sticky;
+        top: 0;
+        left: 0;
+        border-left: 1px solid #dcdfe6;
+        border-right: 1px solid #dcdfe6;
+        td,
+        th {
+          min-width: 100px;
+          word-break: break-all;
+          border: 1px solid #dcdfe6;
+          outline-color: #dcdfe6;
+          outline-style: solid;
+          outline-width: 0.5px;
+        }
+      }
+      td,
+      th {
+        min-width: 100px;
+        word-break: break-all;
+        border: 1px solid #dcdfe6;
+        height: 45px;
+        text-align: center;
+        background-color: #fff;
+      }
+
+      .head-column {
+        background-color: #f0f2f5;
+      }
+
+      .data-cell {
+        color: #409eff;
+        cursor: pointer;
+      }
+
+      .thead-sticky {
+        position: sticky;
+        top: 0;
+      }
+    }
+    .content-ul {
+      td {
+        // width: 15%;
+      }
+      .association {
+        color: #409eff;
+        cursor: pointer;
+      }
+    }
+  }
+  .not-text {
+    height: 300px;
+    line-height: 300px;
+    text-align: center;
+  }
 }
 </style>

+ 186 - 389
src/views/custom_manage/points/RatingOverview.vue

@@ -1,439 +1,228 @@
 <template>
   <div class="container rating-overview-content">
-    <div class="select-box">
-      <el-select v-model="yearValue" placeholder="请选择年份">
-        <el-option v-for="item in optionsYear" :key="item.value" :label="item.label" :value="item.value"> </el-option>
-      </el-select>
-      <el-select v-model="quarterValue" placeholder="请选择季度">
-        <el-option v-for="item in quarterOptions" :key="item.value" :label="item.label" :value="item.value"> </el-option>
-      </el-select>
-      <el-input placeholder="请输入券商名称" prefix-icon="el-icon-search" v-model="brokerName"> </el-input>
-      <el-cascader v-model="valueLocation" collapse-tags :props="{ multiple: true, value: 'name', children: 'city', label: 'name' }" clearable :options="locationOptions" placeholder="请选择城市">
-      </el-cascader>
+    <div class="top-select">
+      <div class="select-box">
+        <el-date-picker style="width: 220px" v-model="yearValue" type="year" placeholder="请选择年份" :clearable="false" @change="changeHandle"> </el-date-picker>
+        <el-select style="width: 220px; margin: 0 20px" v-model="selectedQuarter" placeholder="请选择季度" @change="changeHandle">
+          <el-option v-for="item in quarterOptions" :key="item.label" :label="item.label" :value="item.value"> </el-option>
+        </el-select>
+        <el-input style="width: 220px" placeholder="请输入券商名称" prefix-icon="el-icon-search" v-model="brokerName" @input="changeHandle"> </el-input>
+        <el-cascader
+          style="width: 220px; margin: 0 20px"
+          v-model="valueLocation"
+          collapse-tags
+          :props="{ multiple: true, value: 'name', children: 'city', label: 'name' }"
+          clearable
+          :options="locationOptions"
+          placeholder="请选择城市"
+          @change="changeHandle"
+        >
+        </el-cascader>
+        <a :href="exportUser" download>
+          <el-button type="primary" style="width: 80px">导出</el-button>
+        </a>
+      </div>
+      <div>
+        <el-button @click="enterScoreType = !enterScoreType" type="primary">{{ enterScoreType ? "百分比显示" : "原始值显示" }} </el-button>
+      </div>
     </div>
 
     <div class="table-cont">
-      <table>
-        <thead>
-          <tr>
-            <td v-for="(item, index) in tableTheadColumns" :key="item" :class="['head-column', index > 0 && 'head-column-item']">
-              {{ item }}
-            </td>
-          </tr>
-        </thead>
-      </table>
-
-      <div class="table-body-wrapper">
+      <template v-if="tableTheadColumns.length">
         <table>
-          <tbody v-for="(item, index) in datalist" :key="index">
+          <thead>
             <tr>
-              <td class="thead-rs">{{ item.ChartPermissionName }}</td>
-              <td v-for="item in 4" :key="item"></td>
+              <td class="'head-column'"></td>
+              <td v-for="item in tableTheadColumns" :key="item" :class="['head-column']">
+                {{ item.CompanyName }}
+              </td>
             </tr>
-            <tr v-for="rs in item.List" :key="rs.RealName" class="content-ul">
-              <td>{{ rs.RealName }}</td>
-              <td>{{ rs.TotalRelatedContract }}</td>
-              <td>{{ rs.TotalDispatchPoint }}</td>
-              <td>{{ rs.GroupProportion }}</td>
-              <td>{{ rs.DepartmentProportion }}</td>
-            </tr>
-          </tbody>
-
-          <tfoot></tfoot>
+          </thead>
         </table>
-      </div>
+
+        <div class="table-body-wrapper">
+          <table>
+            <tbody v-for="(item, index) in datalist" :key="index">
+              <tr>
+                <td class="thead-rs">{{ item.ChartPermissionName }}</td>
+                <td v-for="item in tableTheadColumns.length" :key="item"></td>
+              </tr>
+              <tr v-for="rs in item.List" :key="rs.RealName" class="content-ul">
+                <td>{{ rs.RealName }}</td>
+                <td v-for="pr in rs.ProportionListText" :key="pr">{{ pr }}</td>
+              </tr>
+            </tbody>
+            <tbody v-for="(item, index) in listGroup" :key="index">
+              <tr>
+                <td class="thead-rs">{{ item.GroupName }}</td>
+                <td v-for="key in item.ProportionListText" :key="key">{{ key }}</td>
+              </tr>
+            </tbody>
+            <tfoot></tfoot>
+          </table>
+        </div>
+        <template v-if="!datalist.length && !listGroup.length"> <div class="not-text">暂无数据</div> </template>
+      </template>
+      <template v-else> <div class="not-text">暂无数据</div> </template>
     </div>
   </div>
 </template>
 
 <script>
 import { locationOptions } from "../customList/location";
+import { customInterence, xClassCustomApi } from "@/api/api.js";
+
 export default {
   name: "",
   components: {},
   props: {},
   data() {
     return {
-      yearValue: "", // 年份
-      optionsYear: [],
-      quarterValue: "", // 季度
-      quarterOptions: [],
-      brokerName: "", // 券商名
-      valueLocation: "", //地址
-      tableTheadColumns: [],
-      datalist: [
+      yearValue: new Date().getFullYear().toString(), // 年份
+      selectedQuarter: [], // 季度
+      quarterOptions: [
         {
-          ChartPermissionName: "医药",
-          List: [
-            {
-              RealName: "赵璐",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "67.05",
-              GroupProportion: "58.91%",
-              DepartmentProportion: "10.49%",
-            },
-            {
-              RealName: "郭望葳",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "25.15",
-              GroupProportion: "22.10%",
-              DepartmentProportion: "3.93%",
-            },
-            {
-              RealName: "李金泽",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "14.35",
-              GroupProportion: "12.60%",
-              DepartmentProportion: "2.24%",
-            },
-            {
-              RealName: "张天",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "8.75",
-              GroupProportion: "7.68%",
-              DepartmentProportion: "1.36%",
-            },
-            {
-              RealName: "合计",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "113.80/107.5",
-              GroupProportion: "100%",
-              DepartmentProportion: "17.80%",
-            },
-            {
-              RealName: "平均",
-              TotalRelatedContract: 13.25,
-              TotalDispatchPoint: "28.45",
-              GroupProportion: "25%",
-              DepartmentProportion: "4.45%",
-            },
-          ],
+          label: "Q1",
+          value: ["01-01", "03-31"],
         },
         {
-          ChartPermissionName: "消费",
-          List: [
-            {
-              RealName: "霍健",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "50.75",
-              GroupProportion: "50.44%",
-              DepartmentProportion: "7.94%",
-            },
-            {
-              RealName: "卢劲",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "16.45",
-              GroupProportion: "16.35%",
-              DepartmentProportion: "2.57%",
-            },
-            {
-              RealName: "周毓",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "11.45",
-              GroupProportion: "11.38%",
-              DepartmentProportion: "1.79%",
-            },
-            {
-              RealName: "周涛",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "10.85",
-              GroupProportion: "10.78%",
-              DepartmentProportion: "1.69%",
-            },
-            {
-              RealName: "丁衡",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "9.85",
-              GroupProportion: "9.79%",
-              DepartmentProportion: "1.54%",
-            },
-            {
-              RealName: "合计",
-              TotalRelatedContract: 11,
-              TotalDispatchPoint: "100.59/107.5",
-              GroupProportion: "100%",
-              DepartmentProportion: "15.74%",
-            },
-            {
-              RealName: "平均",
-              TotalRelatedContract: 12.8,
-              TotalDispatchPoint: "20.11",
-              GroupProportion: "20%",
-              DepartmentProportion: "3.14%",
-            },
-          ],
+          label: "Q2",
+          value: ["04-01", "06-30"],
         },
         {
-          ChartPermissionName: "科技",
-          List: [
-            {
-              RealName: "张晶",
-              TotalRelatedContract: 8,
-              TotalDispatchPoint: "33.48",
-              GroupProportion: "42.72%",
-              DepartmentProportion: "5.23%",
-            },
-            {
-              RealName: "欧阳志宏",
-              TotalRelatedContract: 8,
-              TotalDispatchPoint: "10.28",
-              GroupProportion: "13.11%",
-              DepartmentProportion: "1.60%",
-            },
-            {
-              RealName: "王修远",
-              TotalRelatedContract: 8,
-              TotalDispatchPoint: "7.27",
-              GroupProportion: "9.29%",
-              DepartmentProportion: "1.13%",
-            },
-            {
-              RealName: "冯冠儒",
-              TotalRelatedContract: 8,
-              TotalDispatchPoint: "9.98",
-              GroupProportion: "12.73%",
-              DepartmentProportion: "1.56%",
-            },
-            {
-              RealName: "陈昫锟",
-              TotalRelatedContract: 8,
-              TotalDispatchPoint: "5.77",
-              GroupProportion: "7.37%",
-              DepartmentProportion: "0.90%",
-            },
-            {
-              RealName: "许晓威",
-              TotalRelatedContract: 8,
-              TotalDispatchPoint: "5.77",
-              GroupProportion: "7.37%",
-              DepartmentProportion: "0.90%",
-            },
-            {
-              RealName: "李婉月",
-              TotalRelatedContract: 8,
-              TotalDispatchPoint: "5.77",
-              GroupProportion: "7.37%",
-              DepartmentProportion: "0.90%",
-            },
-            {
-              RealName: "合计",
-              TotalRelatedContract: 8,
-              TotalDispatchPoint: "78.35/82.5",
-              GroupProportion: "100%",
-              DepartmentProportion: "12.26%",
-            },
-            {
-              RealName: "平均",
-              TotalRelatedContract: 8,
-              TotalDispatchPoint: "11.19",
-              GroupProportion: "14.28%",
-              DepartmentProportion: "1.75%",
-            },
-          ],
+          label: "Q3",
+          value: ["07-01", "09-30"],
         },
         {
-          ChartPermissionName: "智造",
-          List: [
-            {
-              RealName: "杨云鹏",
-              TotalRelatedContract: 9,
-              TotalDispatchPoint: "32.1",
-              GroupProportion: "37.32%",
-              DepartmentProportion: "5.02%",
-            },
-            {
-              RealName: "齐妍",
-              TotalRelatedContract: 9,
-              TotalDispatchPoint: "20.90",
-              GroupProportion: "24.30%",
-              DepartmentProportion: "3.27%",
-            },
-            {
-              RealName: "钟正宇",
-              TotalRelatedContract: 9,
-              TotalDispatchPoint: "17.9",
-              GroupProportion: "20.81%",
-              DepartmentProportion: "2.80%",
-            },
-            {
-              RealName: "张振",
-              TotalRelatedContract: 9,
-              TotalDispatchPoint: "6.8",
-              GroupProportion: "7.90%",
-              DepartmentProportion: "1.06%",
-            },
-            {
-              RealName: "钱程鹏",
-              TotalRelatedContract: 9,
-              TotalDispatchPoint: "8.3",
-              GroupProportion: "9.65%",
-              DepartmentProportion: "1.29%",
-            },
-            {
-              RealName: "合计",
-              TotalRelatedContract: 9,
-              TotalDispatchPoint: "86/91.5",
-              GroupProportion: "100%",
-              DepartmentProportion: "13.45%",
-            },
-            {
-              RealName: "平均",
-              TotalRelatedContract: 9,
-              TotalDispatchPoint: "17.2",
-              GroupProportion: "20%",
-              DepartmentProportion: "2.69%",
-            },
-          ],
-        },
-        {
-          ChartPermissionName: "策略",
-          List: [
-            {
-              RealName: "马冬凡",
-              TotalRelatedContract: 4,
-              TotalDispatchPoint: "20.44",
-              GroupProportion: "49.04%",
-              DepartmentProportion: "3.20%",
-            },
-            {
-              RealName: "马楠",
-              TotalRelatedContract: 4,
-              TotalDispatchPoint: "4.25",
-              GroupProportion: "10.19%",
-              DepartmentProportion: "0.66%",
-            },
-            {
-              RealName: "王盟",
-              TotalRelatedContract: 4,
-              TotalDispatchPoint: "4.25",
-              GroupProportion: "10.19%",
-              DepartmentProportion: "0.66%",
-            },
-            {
-              RealName: "王晶晶",
-              TotalRelatedContract: 4,
-              TotalDispatchPoint: "4.25",
-              GroupProportion: "10.19%",
-              DepartmentProportion: "0.66%",
-            },
-            {
-              RealName: "李方杰",
-              TotalRelatedContract: 4,
-              TotalDispatchPoint: "4.25",
-              GroupProportion: "10.19%",
-              DepartmentProportion: "0.66%",
-            },
-            {
-              RealName: "王正凯",
-              TotalRelatedContract: 4,
-              TotalDispatchPoint: "4.25",
-              GroupProportion: "10.19%",
-              DepartmentProportion: "0.66%",
-            },
-            {
-              RealName: "合计",
-              TotalRelatedContract: 4,
-              TotalDispatchPoint: "41.69/46",
-              GroupProportion: "100%",
-              DepartmentProportion: "6.52%",
-            },
-            {
-              RealName: "平均",
-              TotalRelatedContract: 4,
-              TotalDispatchPoint: "6.94",
-              GroupProportion: "16.66%",
-              DepartmentProportion: "1.08%",
-            },
-          ],
-        },
-        {
-          ChartPermissionName: "买方研选",
-          List: [
-            {
-              RealName: "董衡",
-              TotalRelatedContract: 41,
-              TotalDispatchPoint: "42.72",
-              GroupProportion: "20.00%",
-              DepartmentProportion: "6.68%",
-            },
-            {
-              RealName: "高亦文",
-              TotalRelatedContract: 41,
-              TotalDispatchPoint: "42.72",
-              GroupProportion: "20.00%",
-              DepartmentProportion: "6.68%",
-            },
-            {
-              RealName: "吴昂迪",
-              TotalRelatedContract: 41,
-              TotalDispatchPoint: "42.72",
-              GroupProportion: "20.00%",
-              DepartmentProportion: "6.68%",
-            },
-            {
-              RealName: "冯柯然",
-              TotalRelatedContract: 41,
-              TotalDispatchPoint: "42.72",
-              GroupProportion: "20.00%",
-              DepartmentProportion: "6.68%",
-            },
-            {
-              RealName: "汪洋",
-              TotalRelatedContract: 41,
-              TotalDispatchPoint: "42.72",
-              GroupProportion: "20.00%",
-              DepartmentProportion: "6.68%",
-            },
-            {
-              RealName: "合计",
-              TotalRelatedContract: 41,
-              TotalDispatchPoint: "213.59/199.1",
-              GroupProportion: "100%",
-              DepartmentProportion: "33.42%",
-            },
-            {
-              RealName: "平均",
-              TotalRelatedContract: 41,
-              TotalDispatchPoint: "42.71",
-              GroupProportion: "20%",
-              DepartmentProportion: "6.68%",
-            },
-          ],
+          label: "Q4",
+          value: ["10-01", "12-31"],
         },
       ],
+      brokerName: "", // 券商名
+      valueLocation: [], //地址
+      tableTheadColumns: [],
+      datalist: [],
+      listGroup: [],
+      enterScoreType: false,
     };
   },
   computed: {
     locationOptions() {
       return locationOptions;
     },
+    exportUser() {
+      let baseUrl = process.env.API_ROOT + "/cygx/enterScore/scoreOverview";
+      let token = localStorage.getItem("auth") || "";
+      const cityArr = [];
+      this.valueLocation.forEach((item) => {
+        // 市
+        cityArr.push(item[1]);
+      });
+      let cityValue = cityArr.join(",");
+      let paramStr = "";
+      let params = {
+        StartDate: this.yearValue + "-" + this.selectedQuarter[0],
+        EndDate: this.yearValue + "-" + this.selectedQuarter[1],
+        KeyWord: this.brokerName,
+        City: cityValue,
+        EnterScoreType: this.enterScoreType ? 2 : 1,
+        IsExport: true,
+      };
+      for (let key in params) {
+        paramStr = `${paramStr}&${key}=${params[key]}`;
+      }
+      return `${baseUrl}?${token}${paramStr}`;
+    },
+  },
+  watch: {
+    enterScoreType: {
+      handler() {
+        this.getDataList();
+      },
+    },
+  },
+  mounted() {
+    this.setDefaultQuarter();
+
+    this.getDataList();
+  },
+  methods: {
+    setDefaultQuarter() {
+      const currentDate = new Date();
+      const month = currentDate.getMonth() + 1; // 获取当前月份(0-11,所以加1)
+
+      let currentQuarterIndex;
+      if (month >= 1 && month <= 3) {
+        // Q1
+        currentQuarterIndex = 0;
+      } else if (month >= 4 && month <= 6) {
+        // Q2
+        currentQuarterIndex = 1;
+      } else if (month >= 7 && month <= 9) {
+        // Q3
+        currentQuarterIndex = 2;
+      } else if (month >= 10 && month <= 12) {
+        // Q4
+        currentQuarterIndex = 3;
+      }
+
+      // 获取上一个季度索引
+      const previousQuarterIndex = currentQuarterIndex === 0 ? this.quarterOptions.length - 1 : currentQuarterIndex - 1;
+
+      // 设置v-model绑定的值为上一个季度的value数组
+      this.selectedQuarter = this.quarterOptions[previousQuarterIndex].value;
+    },
+
+    getPreviousYear(currentYear, currentQuarter) {
+      // 如果当前季度是第一个季度,则上个季度应该是去年的最后一个季度
+      return currentQuarter === "Q1" ? currentYear - 1 : currentYear;
+    },
+    changeHandle() {
+      this.getDataList();
+    },
+    async getDataList() {
+      const cityArr = [];
+      this.valueLocation.forEach((item) => {
+        cityArr.push(item[1]);
+      });
+      let cityValue = cityArr.join(",");
+      console.log(cityValue);
+      let params = {
+        StartDate: this.yearValue + "-" + this.selectedQuarter[0],
+        EndDate: this.yearValue + "-" + this.selectedQuarter[1],
+        KeyWord: this.brokerName,
+        City: cityValue,
+        EnterScoreType: this.enterScoreType ? 2 : 1,
+      };
+      const res = await xClassCustomApi.enterScoreScoreOverview(params);
+      if (res.Ret === 200) {
+        this.tableTheadColumns = res.Data.ListCompany || [];
+        this.datalist = res.Data.ListPermission || [];
+        this.listGroup = res.Data.ListGroup || [];
+      }
+    },
   },
-  watch: {},
-  created() {},
-  mounted() {},
-  methods: {},
 };
 </script>
 <style scoped lang="scss">
 .rating-overview-content {
+  .top-select {
+    display: flex;
+    justify-content: space-between;
+  }
   .select-box {
     display: flex;
     margin-bottom: 30px;
   }
   .table-cont {
+    overflow: auto;
     .table-body-wrapper {
-      max-height: calc(100vh - 340px);
+      max-height: calc(100vh - 400px);
       margin-right: -6px;
-      overflow-y: scroll;
-      overflow-x: auto;
       border-bottom: 1px solid #dcdfe6;
       border-top: 1px solid #dcdfe6;
     }
-    .head-column-item {
-      width: 15%;
-    }
     table {
-      width: 100%;
       font-size: 14px;
       color: #666;
       thead {
@@ -442,8 +231,11 @@ export default {
         left: 0;
         border-left: 1px solid #dcdfe6;
         border-right: 1px solid #dcdfe6;
-        td {
-          border: none;
+        td,
+        th {
+          min-width: 100px;
+          word-break: break-all;
+          border: 1px solid #dcdfe6;
           outline-color: #dcdfe6;
           outline-style: solid;
           outline-width: 0.5px;
@@ -451,8 +243,8 @@ export default {
       }
       td,
       th {
-        min-width: 35px;
-        // word-break: break-all;
+        min-width: 100px;
+        word-break: break-all;
         border: 1px solid #dcdfe6;
         height: 45px;
         text-align: center;
@@ -475,7 +267,7 @@ export default {
     }
     .content-ul {
       td {
-        width: 15%;
+        // width: 15%;
       }
       .association {
         color: #409eff;
@@ -483,5 +275,10 @@ export default {
       }
     }
   }
+  .not-text {
+    height: 300px;
+    line-height: 300px;
+    text-align: center;
+  }
 }
 </style>

+ 1 - 7
src/views/custom_manage/points/XClassCustom.vue

@@ -5,15 +5,10 @@
         <div class="tabs-box">
           <span v-for="item in listTitle" :key="item.value" @click="tabsBoxBtn(item)" :class="item.value == tabsPitchon ? 'pitch' : ''">{{ item.lable }}</span>
         </div>
-        <div>
-          <el-input placeholder="合同编号/客户名称/社会信用码" v-model="searchVal" style="width: 520px" @input="handleSearch" clearable>
-            <i slot="prefix" class="el-input__icon el-icon-search"></i>
-          </el-input>
-        </div>
       </div>
     </el-card>
     <el-card style="margin-top: 20px">
-      <EntryRecords ref="recordRefs" :searchVal.sync="searchVal" v-if="tabsPitchon == 1" />
+      <EntryRecords v-if="tabsPitchon == 1" />
       <RatingOverview v-if="tabsPitchon == 2" />
       <RankingOverview v-if="tabsPitchon == 3" />
     </el-card>
@@ -45,7 +40,6 @@ export default {
         },
       ],
       tabsPitchon: 1, //tabs 默认选中
-      searchVal: "",
     };
   },
   computed: {},