equityCustomStatistics.vue 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797
  1. <template>
  2. <div class="dataReport-container" id="dataReport-container">
  3. <div class="dataReport-top">
  4. <a :href="exportExcel" download>
  5. <button class="button-sty act">导出EXCEL</button>
  6. </a>
  7. <button :class="['button-sty', { act: filterObj.month === item.label }]" v-for="item in monthLabel" @click="toggleMonth(item.label)" :key="item.label">
  8. {{ item.label }}
  9. </button>
  10. <date-picker v-model="filterObj.date" type="date" range value-type="format" placeholder="自定义时间段" :clearable="false" :editable="false" @change="dateChange" />
  11. <el-input placeholder="请输入客户名称" v-model="searchVal" style="width: 400px; margin-left: auto" @input="handleSearch" clearable>
  12. <i slot="prefix" class="el-input__icon el-icon-search"></i>
  13. </el-input>
  14. </div>
  15. <div class="dataReport-main">
  16. <div class="main-top">
  17. <el-cascader
  18. v-if="Role == 'finance' || Role == 'admin' || Role == 'ficc_admin' || Role == 'rai_admin' || ManageType != 0"
  19. v-model="filterObj.sale"
  20. placeholder="请选择销售"
  21. style="min-width: 250px; margin-right: 10px; margin-bottom: 8px"
  22. :options="salesArr"
  23. :props="defaultSalesProps"
  24. :show-all-levels="false"
  25. collapse-tags
  26. clearable
  27. filterable
  28. @change="changeFilter"
  29. >
  30. </el-cascader>
  31. </div>
  32. <div class="main-section">
  33. <div v-for="item in data_typeArr" :key="item.label">
  34. <el-card style="margin-right: 50px" :class="['base-card', { 'main-card': filterObj.data_type === item.label }]" shadow="hover" @click.native="toggleType(item.label)">
  35. <div slot="header" class="clearfix">
  36. <span>
  37. {{ lableTextDisplay(item.label) }}数
  38. <el-tooltip class="item" effect="dark" :content="item.label === '新签客户' ? '<br />' : item.label === '续约客户' ? '起始时间在所选时间段内的续约合同' : ''" placement="top">
  39. <template slot="content">
  40. <div v-if="item.label === '新签客户'">
  41. <p>起始时间在所选时间段内的新签合同</p>
  42. <p>(第一份合同起始时间一年内的再次签约仍属于新签合同)</p>
  43. </div>
  44. <div v-else-if="item.label === '续约客户'">
  45. <p>起始时间在所选时间段内的续约合同</p>
  46. <p>(第一份合同起始时间一年以后的再次签约均属于续约合同)</p>
  47. </div>
  48. <p v-else>合同截止时间在所选时间段内的非正式、非永续客户</p>
  49. </template>
  50. <i class="el-icon-info"></i>
  51. </el-tooltip>
  52. </span>
  53. </div>
  54. <div class="card-cont">
  55. {{
  56. item.label === "新签客户"
  57. ? NewCompanyTotal
  58. : item.label === "续约客户"
  59. ? RenewalCompanyTotal
  60. : item.label === "未续约客户"
  61. ? NotRenewalCompanyTotal + " / " + NotRenewalCompanyToBeConfirmTotal
  62. : ""
  63. }}
  64. </div>
  65. </el-card>
  66. </div>
  67. <div class="annual-select-content">
  68. <div class="select-content">
  69. <div class="lable-text">
  70. 不续约率
  71. <el-tooltip style="margin-right: 16px" class="item" effect="dark" content="所选年度的续约合同/所选年度的到期合同" placement="top-start">
  72. <template slot="content">
  73. <div>
  74. <p>所选时间段的已确认不续约的合同金额/所选时间段的到期的合同金额</p>
  75. <p>(剔除非业务不续约的金额)</p>
  76. </div>
  77. </template>
  78. <i class="el-icon-info" style="color: #999"></i>
  79. </el-tooltip>
  80. </div>
  81. <el-date-picker
  82. v-model="yearValue"
  83. type="daterange"
  84. format="yyyy-MM-dd"
  85. value-format="yyyy-MM-dd"
  86. :clearable="false"
  87. @change="getIncrementalCompanyContractPercentageList"
  88. range-separator="至"
  89. start-placeholder="开始日期"
  90. end-placeholder="结束日期"
  91. >
  92. </el-date-picker>
  93. </div>
  94. <div class="select-content">
  95. <span class="editsty" v-if="RenewalDataForm.RenewalRateMoney" @click="renewalRateLableHandler">&nbsp;&nbsp;{{ RenewalDataForm.RenewalRateMoney }}&nbsp;&nbsp;</span>
  96. {{ RenewalDataForm.RenewalRateTotalContent ? `(${RenewalDataForm.RenewalRateTotalContent})` : " - -" }}
  97. </div>
  98. </div>
  99. </div>
  100. <div class="tabs-box">
  101. <div class="tabs-box-confirm" v-if="filterObj.data_type =='续约客户'">
  102. <div style="margin-bottom: 0px" class="tabs-box-confirm" v-for="(item, index) in packageTypeList" :key="item">
  103. <div :class="['confirm-box-li', PackageDifference == item && 'active']" @click="notPackageDifferenceChange(item)">{{ item }}</div>
  104. <div v-if="index != 2" class="center-line"></div>
  105. </div>
  106. </div>
  107. </div>
  108. <div class="tabs-box" v-if="filterObj.data_type == '未续约客户'">
  109. <el-radio-group v-model="isNotRenewedConfirm" class="tabs-box-confirm" @change="notRenewedConfirmChange">
  110. <el-radio-button :label="1">已确认</el-radio-button>
  111. <div class="center-line"></div>
  112. <el-radio-button :label="0">待确认</el-radio-button>
  113. </el-radio-group>
  114. <div class="tabs-box-status" v-show="isNotRenewedConfirm">
  115. <el-select v-model="noRenewalReasonId" placeholder="请选择不续约归因" clearable @change="getTableData" style="width: 240px; margin-right: 50px">
  116. <el-option :label="item.AscribeContent" :value="item.CompanyAscribeId" v-for="item in noRenewalReasonList" :key="item.reasonId"></el-option>
  117. </el-select>
  118. <el-select v-model="tabsActiveName" placeholder="当前状态" clearable @change="getTableData" style="width: 240px; margin-right: 50px">
  119. <el-option :label="item.name" :value="item.value" v-for="item in tabsList" :key="item.value"></el-option>
  120. </el-select>
  121. </div>
  122. </div>
  123. <el-table :data="tableData" border style="margin-top: 20px; min-height: 400px" v-loading="isShowloadding" element-loading-text="数据加载中...">
  124. <template v-for="item in incrementTableColums">
  125. <el-table-column :key="item.label" :label="item.label" :width="item.widthsty" align="center" v-if="item.key != 'AscribeContent'">
  126. <template slot-scope="scope">
  127. <span :style="item.textsty" @click="jumpHandle(scope.row, item)" v-if="item.key === 'CreateTime'">
  128. {{ scope.row[item.key] | formatTime }}
  129. </span>
  130. <span v-else-if="item.label == '未续约说明'">
  131. <span style="display: block" v-if="scope.row[item.key]">最新情况:{{ scope.row[item.key] }}</span>
  132. <span v-if="scope.row.RenewalTodo">To Do 事项:{{ scope.row.RenewalTodo }}</span>
  133. <span v-if="scope.row[item.key] || scope.row.RenewalTodo" style="color: #409eff; cursor: pointer" @click="renewalReasonMore(scope.row)">&emsp;更多>></span>
  134. </span>
  135. <div v-else-if="item.key == 'CompanyName'" style="padding: 4px 0">
  136. <el-tooltip effect="dark" placement="top-start" content="过去4周,kp均未覆盖服务" v-if="scope.row.IsUserMaker == -1">
  137. <span class="deletesty" @click="jumpHandle(scope.row, item)">{{ scope.row[item.key] }}</span>
  138. </el-tooltip>
  139. <span v-else class="editsty" @click="jumpHandle(scope.row, item)">{{ scope.row[item.key] }}</span>
  140. <div class="package-difference" v-if="scope.row.PackageDifference && filterObj.data_type == '续约客户'" @click="previousDetailHadler(scope.row)">
  141. {{ scope.row.PackageDifference }}
  142. </div>
  143. </div>
  144. <div v-else-if="item.key === 'Remark'" class="remark-row">
  145. <span class="remark-text" @click="viewHistoryRemarkFun(scope.row)" v-if="scope.row.IsShowNoRenewedNote">...</span>
  146. <span class="operation-button" v-show="canConfirmNotRenewed && !isNotRenewedConfirm" style="margin-right: 0" @click="addRemarkFun(scope.row)">添加</span>
  147. </div>
  148. <div v-else-if="item.key == 'AscribeContent'">
  149. <span style="color: #409eff; cursor: pointer" @click="editReasonLabel(scope.row)">
  150. {{ scope.row[item.key] }}
  151. </span>
  152. </div>
  153. <div v-else-if="item.key == 'PermissionName'">
  154. <template v-if="scope.row.PermissionName.length">
  155. <el-tag size="mini" style="margin: 0 10px 10px 0" v-for="key in scope.row.PermissionName.split(',')" :key="key">{{ key }}</el-tag>
  156. </template>
  157. </div>
  158. <div v-else-if="item.key == 'StartDate'">
  159. <span> {{ scope.row[item.key] }} ~ {{ scope.row.EndDate }} </span>
  160. </div>
  161. <span v-else :style="item.textsty" @click="jumpHandle(scope.row, item)">
  162. {{ scope.row[item.key] }}
  163. </span>
  164. </template>
  165. </el-table-column>
  166. <el-table-column :key="item.label" :label="item.label" :width="item.widthsty" align="center" v-else-if="item.key == 'AscribeContent' && isNotRenewedConfirm == 1">
  167. <template slot-scope="scope">
  168. <span style="color: #409eff; cursor: pointer" @click="editReasonLabel(scope.row)">
  169. {{ scope.row[item.key] }}
  170. </span>
  171. </template>
  172. </el-table-column>
  173. </template>
  174. <el-table-column label="操作" width="180px" align="center">
  175. <template slot-scope="scope">
  176. <div>
  177. <span v-if="canConfirmNotRenewed && !isNotRenewedConfirm && filterObj.data_type == '未续约客户'" class="editsty" @click="confirmedNoRenewalFun(scope.row)">确认不续约</span>
  178. <span v-if="isRoleType == 'admin' || isRoleType == '权益'" @click="historicalNotesClickHandler(scope.row)" class="editsty">历史备注</span>
  179. </div>
  180. </template>
  181. </el-table-column>
  182. <div slot="empty" style="line-height: 44px; margin: 60px 0; color: #999">
  183. <img src="~@/assets/img/cus_m/nodata.png" alt="" style="display: block; width: 160px; height: 128px; margin: auto" />
  184. <span>暂无数据</span>
  185. </div>
  186. </el-table>
  187. <el-col :span="24" class="toolbar" v-if="total">
  188. <m-page :total="total" :page_no="page_no" @handleCurrentChange="handleCurrentChange" />
  189. </el-col>
  190. </div>
  191. <!-- 未续约说明列表弹窗 -->
  192. <renewalListDia :isShow.sync="isRenewalShow" :rowInfo="rowInfo" />
  193. <!-- 添加备注弹窗 -->
  194. <addRemark :isShow.sync="isAddRemarkShow" @saveRemark="saveRemark" />
  195. <!-- 历史备注弹窗 -->
  196. <viewRemark :isShow.sync="isViewRemarkShow" :tableData="historyRemarkList" />
  197. <!-- 确认不续约弹窗 -->
  198. <confirmedNoRenewal
  199. :isShow.sync="isConfirmNoRenewalShow"
  200. :dataForm="confirmNoRenewalForm"
  201. :noRenewalReasonList="noRenewalReasonList"
  202. @refreshReasonList="getNORenewalReasonList"
  203. @saveLabel="saveLabel"
  204. equityType="权益客户统计"
  205. />
  206. <previous-detail :previousDetailDlg.sync="previousDetailDlg" :rowInfo="rowInfo" />
  207. <RenewalRateDetail :showRenewalRateDetailDlg.sync="showRenewalRateDetailDlg" :renewalRateDetailForm.sync="renewalRateDetailForm" :noRenewalReasonListSon="noRenewalReasonList" />
  208. <historical-notes-dlg :historicalNotesDlgVisible.sync="historicalNotesDlgVisible" :CompanyId.sync="historicalNotesId" />
  209. </div>
  210. </template>
  211. <script>
  212. import { equityTableColums } from "./configdata.js";
  213. import { dataMainInterface, customInterence } from "@/api/api.js";
  214. import mPage from "@/components/mPage.vue";
  215. import renewalListDia from "./components/renewalListDia.vue";
  216. import addRemark from "./components/noRenewalReasonDia/addRemark.vue";
  217. import viewRemark from "./components/noRenewalReasonDia/viewRemark.vue";
  218. import confirmedNoRenewal from "./components/noRenewalReasonDia/confirmedNoRenewal.vue";
  219. import PreviousDetail from "./components/previousDetail.vue";
  220. import RenewalRateDetail from "./components/renewalRateDetail.vue";
  221. import HistoricalNotesDlg from "@/components/historicalNotesDlg.vue";
  222. var moment = require("moment");
  223. moment().format();
  224. export default {
  225. name: "",
  226. components: { mPage, renewalListDia, addRemark, viewRemark, confirmedNoRenewal, PreviousDetail, RenewalRateDetail, HistoricalNotesDlg },
  227. computed: {
  228. exportExcel() {
  229. let baseUrl = process.env.API_ROOT + "/statistic_report/merge_company_list";
  230. let token = localStorage.getItem("auth") || "";
  231. let paramStr = "";
  232. // 处理销售筛选
  233. let salesArr = [];
  234. if (this.filterObj.sale.length) {
  235. salesArr = this.filterObj.sale.map((item) => {
  236. return item[item.length - 1];
  237. });
  238. }
  239. let obj = {
  240. AdminId: salesArr.join(","),
  241. EndDate: this.end_date,
  242. StartDate: this.start_date,
  243. DataType: this.filterObj.data_type == "新增试用客户" ? "新增试用" : this.filterObj.data_type,
  244. Keyword: this.searchVal,
  245. IsExport: true,
  246. IsConfirm: this.filterObj.data_type == "未续约客户" ? this.isNotRenewedConfirm : -1,
  247. CompanyAscribeId: this.noRenewalReasonId,
  248. };
  249. for (let key in obj) {
  250. paramStr = `${paramStr}&${key}=${obj[key]}`;
  251. }
  252. return `${baseUrl}?${token}${paramStr}`;
  253. },
  254. Role() {
  255. let role = localStorage.getItem("Role") || "";
  256. return role;
  257. },
  258. //管理权限
  259. ManageType() {
  260. return localStorage.getItem("ManageType") || "";
  261. },
  262. //确认未续约权限
  263. canConfirmNotRenewed() {
  264. return ["admin", "rai_admin"].includes(this.Role);
  265. },
  266. // crm 15.9.1 区分权益FICC的展示
  267. isRoleType() {
  268. return localStorage.getItem("RoleType") || "";
  269. },
  270. },
  271. data() {
  272. return {
  273. searchVal: sessionStorage.getItem("incrementBack") ? JSON.parse(sessionStorage.getItem("incrementBack")).searchVal : "",
  274. tableData: [],
  275. isShowloadding: false,
  276. start_date: "",
  277. end_date: "",
  278. /* 筛选条件 */
  279. filterObj: {
  280. month: "近1个月",
  281. date: [],
  282. sale: "",
  283. data_type: "新签客户",
  284. },
  285. monthLabel: [
  286. {
  287. label: "近1个月",
  288. },
  289. {
  290. label: "近2个月",
  291. },
  292. {
  293. label: "近3个月",
  294. },
  295. ],
  296. salesArr: [], //销售列表
  297. defaultSalesProps: {
  298. multiple: true,
  299. label: "RealName",
  300. children: "ChildrenList",
  301. value: "AdminId",
  302. }, //销售级联配置
  303. pageSize: 10,
  304. page_no: sessionStorage.getItem("incrementBack") ? JSON.parse(sessionStorage.getItem("incrementBack")).page_no : 1,
  305. total: 0,
  306. data_typeArr: [
  307. {
  308. label: "新签客户",
  309. },
  310. {
  311. label: "续约客户",
  312. },
  313. {
  314. label: "未续约客户",
  315. },
  316. ], //数据类型
  317. NewCompanyTotal: 0, //新签客户数
  318. NotRenewalCompanyTotal: 0, //未续约客户数
  319. RenewalCompanyTotal: 0, //续约客户数
  320. NotRenewalCompanyToBeConfirmTotal: 0,
  321. isRenewalShow: false, //未续约说明列表弹框是否显示
  322. rowInfo: null, // 未续约说明更多行信息
  323. tabsList: [
  324. { name: "试用", value: "试用" },
  325. { name: "冻结/流失", value: "非试用" },
  326. ],
  327. tabsActiveName: "",
  328. NotRenewalNotTryOut: 0, //冻结流失的人数
  329. NotRenewalTryOut: 0, //试用的人数
  330. isNotRenewedConfirm: 1, //未续约的是否已确认
  331. noRenewalReasonList: [],
  332. noRenewalReasonId: "",
  333. selectItemRow: {}, // 当前选中的row
  334. // 添加备注
  335. isAddRemarkShow: false,
  336. //历史备注
  337. isViewRemarkShow: false,
  338. historyRemarkList: [],
  339. //确认不续约
  340. isConfirmNoRenewalShow: false,
  341. confirmNoRenewalForm: {
  342. reason: "",
  343. detailReason: "",
  344. },
  345. incrementTableColums: [],
  346. PackageDifference: "",
  347. previousDetailDlg: false,
  348. packageTypeList: ["增加套餐", "减少套餐", "维持套餐"],
  349. yearValue: "",
  350. showRenewalRateDetailDlg: false,
  351. renewalRateDetailForm: {},
  352. RenewalDataForm: {},
  353. historicalNotesDlgVisible: false, //历史备注的弹框
  354. historicalNotesId: 0,
  355. };
  356. },
  357. /* 页面跳转前记录参数 */
  358. beforeRouteLeave(to, form, next) {
  359. let backData = {
  360. page_no: this.page_no,
  361. end_date: this.end_date,
  362. start_date: this.start_date,
  363. filterObj: this.filterObj,
  364. };
  365. sessionStorage.setItem("incrementBack", JSON.stringify(backData));
  366. next();
  367. },
  368. /* 页面进入前是否清除参数 */
  369. beforeRouteEnter(to, from, next) {
  370. if (from.path != "/customDetail") {
  371. sessionStorage.removeItem("incrementBack");
  372. }
  373. next();
  374. },
  375. methods: {
  376. // 搜索
  377. handleSearch() {
  378. if (!this.searchVal) {
  379. this.page_no = 1;
  380. this.filterObj = {
  381. month: "近1个月",
  382. date: [],
  383. sale: "",
  384. data_type: this.filterObj.data_type,
  385. };
  386. let date_before = moment().subtract(1, "M").format("YYYY-MM-DD");
  387. let date_now = moment().format("YYYY-MM-DD");
  388. let date = [date_before, date_now];
  389. this.start_date = date_before;
  390. this.end_date = date_now;
  391. this.filterObj.date = date;
  392. this.getTableData();
  393. return;
  394. }
  395. this.page_no = 1;
  396. this.filterObj = {
  397. month: "",
  398. date: [],
  399. sale: "",
  400. data_type: this.filterObj.data_type,
  401. };
  402. this.start_date = "";
  403. this.end_date = "";
  404. this.getTableData();
  405. },
  406. //tabs 的点击事件
  407. // tabsHandler(item) {
  408. // this.tabsActiveName = item.value;
  409. // this.noRenewalReasonId = "";
  410. // this.page_no = 1;
  411. // this.getTableData();
  412. // },
  413. notRenewedConfirmChange() {
  414. this.tabsActiveName = "";
  415. this.noRenewalReasonId = "";
  416. this.page_no = 1;
  417. this.getTableData();
  418. },
  419. notPackageDifferenceChange(type) {
  420. if (this.PackageDifference == type) {
  421. this.PackageDifference = "";
  422. } else {
  423. this.PackageDifference = type;
  424. }
  425. this.page_no = 1;
  426. this.getTableData();
  427. },
  428. /* 获取表格 */
  429. getTableData() {
  430. this.isShowloadding = true;
  431. // 处理销售筛选
  432. let salesArr = [];
  433. if (this.filterObj.sale.length) {
  434. salesArr = this.filterObj.sale.map((item) => {
  435. return item[item.length - 1];
  436. });
  437. }
  438. let params = {
  439. Keyword: this.searchVal,
  440. PageSize: this.pageSize,
  441. CurrentIndex: this.page_no,
  442. AdminId: salesArr.join(","),
  443. EndDate: this.end_date,
  444. StartDate: this.start_date,
  445. DataType: this.filterObj.data_type == "新增试用客户" ? "新增试用" : this.filterObj.data_type,
  446. TryOutType: this.filterObj.data_type == "未续约客户" && this.isNotRenewedConfirm == 1 ? this.tabsActiveName : "",
  447. IsConfirm: this.filterObj.data_type == "未续约客户" ? this.isNotRenewedConfirm : -1,
  448. CompanyAscribeId: this.noRenewalReasonId,
  449. PackageDifference: this.PackageDifference,
  450. };
  451. dataMainInterface.incrementalEquityList(params).then((res) => {
  452. if (res.Ret === 200) {
  453. this.tableData = res.Data.List || [];
  454. this.total = res.Data.Paging.Totals;
  455. this.NewCompanyTotal = res.Data.NewCompanyTotal;
  456. this.RenewalCompanyTotal = res.Data.RenewalCompanyTotal;
  457. this.NotRenewalCompanyTotal = res.Data.NotRenewalCompanyTotal;
  458. this.NotRenewalCompanyToBeConfirmTotal = res.Data.NotRenewalCompanyToBeConfirmTotal;
  459. this.NotRenewalTryOut = res.Data.NotRenewalTryOut;
  460. this.NotRenewalNotTryOut = res.Data.NotRenewalNotTryOut;
  461. this.isShowloadding = false;
  462. }
  463. });
  464. },
  465. /* 获取销售 */
  466. getSale() {
  467. customInterence.getSalesRaiData().then((res) => {
  468. if (res.Ret === 200) {
  469. this.salesArr = res.Data.List;
  470. }
  471. });
  472. },
  473. /* 切换月份 */
  474. toggleMonth(label) {
  475. this.filterObj.month = label;
  476. let days = label == "近1个月" ? 1 : label == "近2个月" ? 2 : label == "近3个月" ? 3 : 0;
  477. this.filterDate(days);
  478. },
  479. /* 选择服务日期 */
  480. dateChange(e) {
  481. if (e[0]) {
  482. this.start_date = e[0];
  483. this.end_date = e[1];
  484. } else {
  485. this.start_date = "";
  486. this.end_date = "";
  487. }
  488. this.filterObj.month = "";
  489. this.page_no = 1;
  490. this.searchVal = "";
  491. this.getTableData();
  492. },
  493. /* 切换数据类型 */
  494. toggleType(label) {
  495. console.log(this.filterObj.data_type);
  496. this.filterObj.data_type = label;
  497. this.incrementTableColums = equityTableColums(this.filterObj.data_type);
  498. this.noRenewalReasonId = "";
  499. if (label == "未续约客户") {
  500. this.getNORenewalReasonList();
  501. }
  502. this.tabsActiveName = "";
  503. this.page_no = 1;
  504. this.getTableData();
  505. },
  506. /* 筛选改变时 */
  507. changeFilter() {
  508. this.page_no = 1;
  509. this.searchVal = "";
  510. this.getTableData();
  511. if (this.yearValue.length > 0) {
  512. this.getIncrementalCompanyContractPercentageList();
  513. }
  514. },
  515. /* 切换页码 */
  516. handleCurrentChange(page) {
  517. this.page_no = page;
  518. this.getTableData();
  519. },
  520. /* 获取近几个月的日期范围 */
  521. filterDate(month) {
  522. if (month) {
  523. let date_before = moment().subtract(month, "M").format("YYYY-MM-DD");
  524. let date_now = moment().format("YYYY-MM-DD");
  525. let date = [date_before, date_now];
  526. this.start_date = date_before;
  527. this.end_date = date_now;
  528. this.filterObj.date = date;
  529. this.page_no = 1;
  530. this.searchVal = "";
  531. this.getTableData();
  532. }
  533. },
  534. /* 跳转 */
  535. jumpHandle(row, item) {
  536. if (item.link) {
  537. let { href } = this.$router.resolve({
  538. path: "/customDetail",
  539. query: {
  540. id: row.CompanyId,
  541. },
  542. });
  543. window.open(href, "_blank");
  544. }
  545. },
  546. getNORenewalReasonList() {
  547. dataMainInterface.getAscribList().then((res) => {
  548. if (res.Ret == 200) {
  549. this.noRenewalReasonList = res.Data.List || [];
  550. }
  551. });
  552. },
  553. // 未续约说明更多按钮
  554. renewalReasonMore(row) {
  555. this.rowInfo = {
  556. CompanyId: row.CompanyId,
  557. ProductId: row.ProductId,
  558. };
  559. this.isRenewalShow = true;
  560. },
  561. // 添加备注
  562. addRemarkFun(row) {
  563. this.selectItemRow = row;
  564. this.isAddRemarkShow = true;
  565. },
  566. // 添加备注 保存
  567. saveRemark(remark) {
  568. // console.log(remark);
  569. let params = {
  570. CompanyId: this.selectItemRow.CompanyId,
  571. ProductId: this.selectItemRow.ProductId,
  572. Content: remark,
  573. };
  574. dataMainInterface.addNotRenewedRemark(params).then((res) => {
  575. if (res.Ret == 200) {
  576. this.$message.success("添加成功");
  577. this.getTableData();
  578. this.isAddRemarkShow = false;
  579. this.selectItemRow = {};
  580. }
  581. });
  582. },
  583. // 查看历史备注
  584. viewHistoryRemarkFun(row) {
  585. dataMainInterface.getNotRenewedRemarkList({ CompanyId: row.CompanyId, ProductId: row.ProductId }).then((res) => {
  586. if (res.Ret == 200) {
  587. this.historyRemarkList = res.Data.List || [];
  588. this.isViewRemarkShow = true;
  589. }
  590. });
  591. },
  592. confirmedNoRenewalFun(row) {
  593. this.confirmNoRenewalForm.reason = "";
  594. this.confirmNoRenewalForm.detailReason = "";
  595. this.selectItemRow = row;
  596. this.isConfirmNoRenewalShow = true;
  597. },
  598. editReasonLabel(row) {
  599. dataMainInterface.contractInfoNoRenewedAscribe({ CompanyContractId: row.CompanyContractId }).then((res) => {
  600. if (res.Ret == 200) {
  601. this.confirmNoRenewalForm.reason = res.Data.Detail ? res.Data.Detail.CompanyAscribeId || "" : "";
  602. this.confirmNoRenewalForm.detailReason = res.Data.Detail ? res.Data.Detail.Content || "" : "";
  603. this.selectItemRow = row;
  604. this.isConfirmNoRenewalShow = true;
  605. }
  606. });
  607. },
  608. saveLabel(item) {
  609. let params = {
  610. CompanyContractId: this.selectItemRow.CompanyContractId,
  611. CompanyAscribeId: item.CompanyAscribeId,
  612. Content: item.Content,
  613. };
  614. dataMainInterface.addAscribContract(params).then((res) => {
  615. if (res.Ret == 200) {
  616. this.$message.success("确认成功");
  617. this.isConfirmNoRenewalShow = false;
  618. this.selectItemRow = {};
  619. this.getTableData();
  620. }
  621. });
  622. },
  623. previousDetailHadler(row) {
  624. this.rowInfo = row;
  625. this.previousDetailDlg = true;
  626. },
  627. lableTextDisplay(text) {
  628. let str = text == "新签客户" ? "新签合同" : text == "续约客户" ? "续约合同" : "未续约客户";
  629. return str;
  630. },
  631. // 年度续约的标签点击事件
  632. annualSelectHandler(item) {
  633. this.annualSelectActivue = item.name;
  634. this.getIncrementalCompanyContractPercentageList();
  635. },
  636. // 点击了续约率
  637. renewalRateLableHandler() {
  638. this.showRenewalRateDetailDlg = true;
  639. this.renewalRateDetailForm = this.initCompanyContractPercentageList();
  640. },
  641. // 获取年度续约的数据
  642. async getIncrementalCompanyContractPercentageList() {
  643. let params = this.initCompanyContractPercentageList();
  644. const res = await dataMainInterface.incrementalCompanyContractPercentageListV2(params);
  645. if (res.Ret === 200) {
  646. this.RenewalDataForm = res.Data;
  647. }
  648. },
  649. // 处理年度续约的数据
  650. initCompanyContractPercentageList() {
  651. let salesArr = [];
  652. if (this.filterObj.sale.length) {
  653. salesArr = this.filterObj.sale.map((item) => {
  654. return item[item.length - 1];
  655. });
  656. }
  657. let params = {
  658. EndDate: this.yearValue.length > 0 ? this.yearValue[1] : "",
  659. StartDate: this.yearValue.length > 0 ? this.yearValue[0] : "",
  660. AdminId: salesArr.join(","),
  661. };
  662. return params;
  663. },
  664. // 点击了历史留言
  665. historicalNotesClickHandler(item) {
  666. this.historicalNotesDlgVisible = true;
  667. this.historicalNotesId = item.CompanyId;
  668. },
  669. },
  670. created() {},
  671. mounted() {
  672. this.incrementTableColums = equityTableColums(this.filterObj.data_type);
  673. this.getSale();
  674. if (sessionStorage.getItem("incrementBack")) {
  675. let backData = JSON.parse(sessionStorage.getItem("incrementBack"));
  676. this.page_no = backData.page_no;
  677. this.end_date = backData.end_date;
  678. this.start_date = backData.start_date;
  679. this.filterObj = backData.filterObj;
  680. this.searchVal = backData.searchVal;
  681. }
  682. /* 默认选中近1个月 */
  683. this.filterDate(this.filterObj.month === "近1个月" ? 1 : this.filterObj.month === "近2个月" ? 2 : this.filterObj.month === "近3个月" ? 3 : 0);
  684. },
  685. };
  686. </script>
  687. <style lang="scss" scoped>
  688. @import "./index.scss";
  689. .tabs-box {
  690. flex-direction: column;
  691. .tabs-box-confirm {
  692. display: flex;
  693. align-items: center;
  694. margin-bottom: 20px;
  695. .center-line {
  696. width: 1px;
  697. height: 21px;
  698. background-color: #333333;
  699. margin: 0 20px;
  700. }
  701. .confirm-box-li {
  702. display: flex;
  703. align-items: center;
  704. justify-content: center;
  705. cursor: pointer;
  706. width: 120px;
  707. height: 40px;
  708. border-radius: 4px;
  709. }
  710. .active {
  711. background-color: #409eff;
  712. color: #fff;
  713. }
  714. }
  715. }
  716. .operation-button {
  717. color: #409eff;
  718. cursor: pointer;
  719. font-size: 14px;
  720. margin-right: 10px;
  721. }
  722. .remark-row {
  723. display: flex;
  724. justify-content: center;
  725. .remark-text {
  726. width: 18px;
  727. height: 18px;
  728. margin-right: 8px;
  729. font-size: 18px;
  730. color: #409eff;
  731. cursor: pointer;
  732. }
  733. }
  734. .operation-row {
  735. display: flex;
  736. align-items: center;
  737. justify-content: center;
  738. flex-wrap: wrap;
  739. .operation-button {
  740. &:last-child {
  741. margin-right: 0;
  742. }
  743. }
  744. }
  745. .package-difference {
  746. cursor: pointer;
  747. }
  748. .annual-select-content {
  749. .select-content {
  750. display: flex;
  751. align-items: center;
  752. margin-bottom: 15px;
  753. .lable-text {
  754. flex-shrink: 0;
  755. }
  756. .select-lable {
  757. display: flex;
  758. align-items: center;
  759. justify-content: center;
  760. box-sizing: border-box;
  761. margin-left: 10px;
  762. width: 92px;
  763. height: 40px;
  764. color: #409eff;
  765. background-color: #ecf5ff;
  766. border: 1px solid #b3d8ff;
  767. border-radius: 4px;
  768. cursor: pointer;
  769. }
  770. .act-select-lable {
  771. color: #fff;
  772. background-color: #409eff;
  773. border: none;
  774. }
  775. }
  776. }
  777. </style>
  778. <style lang="scss">
  779. #dataReport-container {
  780. .tabs-box {
  781. .el-radio-button {
  782. margin-right: 0;
  783. }
  784. .el-radio-button .el-radio-button__inner {
  785. border: none;
  786. width: 120px;
  787. height: 40px;
  788. border-radius: 4px;
  789. }
  790. }
  791. }
  792. </style>