customShareList.vue 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101
  1. <!-- 页面在客户列表上进行的二次修改,若后续有和客户列表相似的功能,请查看客户列表页面 -->
  2. <template>
  3. <div class="customList_container" id="customList_container" ref="cusContainer">
  4. <div class="customList_bot">
  5. <div class="customList_bot_search">
  6. <div style="margin-bottom: 8px;" v-if="Role=='thisAdmin'">
  7. <el-select v-model="status" placeholder="请选择状态" @change="getTableData" style="width: 214px; margin-right: 20px;">
  8. <el-option :label="item.label" :value="item.value" v-for="(item,index) in statusList" :key="index" ></el-option>
  9. </el-select>
  10. <el-cascader
  11. v-model="originalSales"
  12. placeholder="请选择原销售"
  13. style="width:240px;marginRight:10px;marginBottom:8px;"
  14. :options="originalSalesArr"
  15. :props="defaultSalesProps"
  16. :show-all-levels="false"
  17. collapse-tags
  18. clearable
  19. filterable
  20. @change="getTableData"
  21. />
  22. <el-select v-model="sales" placeholder="请选择分配销售" style="width: 214px; margin-right: 20px;"
  23. clearable filterable multiple collapse-tags @change="getTableData">
  24. <el-option :label="item.RealName" :value="item.AdminId" v-for="item in salesArr" :key="item.AdminId" ></el-option>
  25. </el-select>
  26. </div>
  27. <div v-else>
  28. <el-button type="primary" @click="$router.push('/customCityList')">查看同城客户</el-button>
  29. <el-cascader
  30. v-model="originalSales"
  31. placeholder="请选择原销售"
  32. style="width:200px;marginRight:10px;marginBottom:8px;"
  33. :options="originalSalesArr"
  34. :props="defaultSalesProps"
  35. :show-all-levels="false"
  36. collapse-tags
  37. clearable
  38. filterable
  39. @change="getTableData"
  40. />
  41. </div>
  42. <el-input
  43. placeholder="客户名称/社会信用码/手机号码/邮箱"
  44. v-model="search_txt"
  45. style="max-width:531px;margin-bottom: 8px;"
  46. @input="getTableData"
  47. clearable>
  48. <i slot="prefix" class="el-input__icon el-icon-search"></i>
  49. </el-input>
  50. </div>
  51. <div class="bot_cont">
  52. <el-table
  53. ref="userTable"
  54. :data="tableData"
  55. v-loading="isShowloadding"
  56. element-loading-text="数据加载中..."
  57. @sort-change="sortChangeHandle"
  58. border>
  59. <el-table-column
  60. prop="CompanyName"
  61. label="客户名称"
  62. align="center"
  63. min-width="7.14%"
  64. >
  65. <template slot-scope="scope">
  66. <span
  67. v-if="scope.row.IsSuspend ===1 || scope.row.Status=='潜在'"
  68. @click="goDetail(scope.row)"
  69. class="mouse-enter"
  70. :class="{'color-red':scope.row.Status.includes('正式')&&scope.row.WeekViewActive===0}"
  71. :style="scope.row.Status=='潜在'?'':'color:#bbb;cursor:pointer'">
  72. {{scope.row.CompanyName}}
  73. </span>
  74. <span v-else style="color:#409EFF;cursor:pointer;" @click="goDetail(scope.row)" class="customName"
  75. :class="{'isShared':scope.row.IsShared,'color-red':scope.row.Status.includes('正式')&&scope.row.WeekViewActive===0}"
  76. >{{scope.row.CompanyName}}</span>
  77. <img width="15" src="../../../assets/img/icons/remark.png" alt="" v-if="scope.row.RenewalReason||(scope.row.Status==='冻结'&&scope.row.FreezeReason)">
  78. </template>
  79. </el-table-column>
  80. <el-table-column
  81. prop="CompanyType"
  82. label="类型"
  83. align="center"
  84. min-width="4.14%"
  85. >
  86. <template slot-scope="{row}">
  87. <template v-if="row.CompanyType.indexOf('/')!==-1">
  88. <span :style="row.IsSuspend===1?'color:#bbb':''">{{row.CompanyType.split('/')[0]}}</span><br/>
  89. <span v-if="row.FiccPackageType" class="ficc-package">{{row.FiccPackageType == 1 ? '大套餐': '小套餐'}}</span>
  90. <br v-if="row.FiccPackageType"/>
  91. <span :style="row.IsSuspend===1?'color:#bbb':''">{{row.CompanyType.split('/')[1]}}</span>
  92. </template>
  93. <template v-else>
  94. <span :style="row.IsSuspend===1?'color:#bbb':''">{{row.CompanyType}}</span>
  95. <span v-if="row.FiccPackageType&&row.CompanyType.includes('ficc')" class="ficc-package">{{row.FiccPackageType == 1 ? '大套餐': '小套餐'}}</span>
  96. </template>
  97. </template>
  98. </el-table-column>
  99. <el-table-column
  100. prop="IndustryName"
  101. label="所属行业"
  102. min-width="6.14%"
  103. align="center">
  104. <template slot-scope="scope">
  105. <div :style="scope.row.IsSuspend===1?'color:#bbb':''">
  106. <p :style="scope.row.IsSuspend===1?'color:#bbb':''" v-for="item in scope.row.IndustryName.split('/')" :key="item">{{item}}</p>
  107. </div>
  108. </template>
  109. </el-table-column>
  110. <el-table-column
  111. prop="City"
  112. label="客户地址"
  113. min-width="6.14%"
  114. align="center">
  115. <template slot-scope="scope">
  116. <span v-if="scope.row.Province && scope.row.City" :style="scope.row.IsSuspend===1?'color:#bbb':''">{{scope.row.Province}}<br/>{{scope.row.City}}</span>
  117. <span v-else :style="scope.row.IsSuspend===1?'color:#bbb':''">{{scope.row.RegionType}}</span>
  118. </template>
  119. </el-table-column>
  120. <el-table-column
  121. prop="SellerName"
  122. label="原销售"
  123. min-width="6.14%"
  124. align="center">
  125. <template slot-scope="scope">
  126. <p :style="scope.row.IsSuspend===1?'color:#bbb':''" v-for="item in scope.row.SellerName.split('/')" :key="item">{{item}}</p>
  127. </template>
  128. </el-table-column>
  129. <el-table-column
  130. prop="ShareSeller"
  131. label="分配销售"
  132. min-width="6.14%"
  133. align="center">
  134. </el-table-column>
  135. <el-table-column
  136. prop="Status"
  137. label="状态"
  138. min-width="7.14%"
  139. align="center">
  140. <template slot-scope="scope">
  141. <p :style="scope.row.IsSuspend===1?'color:#bbb;margin:3px 0':'margin:3px 0'" v-for="(item,index) in scope.row.Status.split('/')" :key="item">
  142. {{ item }}
  143. <template v-if="item === '试用' && scope.row.TryStageSlice">
  144. <el-select
  145. v-model="scope.row.TryStageSlice[index].TryStage"
  146. v-if="scope.row.Status === '试用/试用'"
  147. :disabled="!scope.row.TryStageSlice[index].HasPermission"
  148. size="mini"
  149. style="width: 50px"
  150. placeholder=""
  151. @change="changeTrialHandle(scope.row,scope.row.TryStageSlice[index])"
  152. >
  153. <el-option
  154. v-for="item in trialTags"
  155. :key="item.value"
  156. :label="item.label"
  157. :value="item.value">
  158. </el-option>
  159. </el-select>
  160. <el-select
  161. v-model="scope.row.TryStageSlice[0].TryStage"
  162. :disabled="!scope.row.TryStageSlice[0].HasPermission"
  163. v-else
  164. size="mini"
  165. style="width: 50px"
  166. placeholder=""
  167. @change="changeTrialHandle(scope.row,scope.row.TryStageSlice[0])"
  168. >
  169. <el-option
  170. v-for="item in trialTags"
  171. :key="item.value"
  172. :label="item.label"
  173. :value="item.value">
  174. </el-option>
  175. </el-select>
  176. </template>
  177. </p>
  178. </template>
  179. </el-table-column>
  180. <el-table-column
  181. label="累计试用天数"
  182. align="center"
  183. min-width="5.14%"
  184. prop="tryOutDay"
  185. sortable="custom">
  186. <template slot-scope="{row}">
  187. <el-tooltip :disabled="row.IsSuspend===1||(row.FiccTryOutDay+row.RaiTryOutDay===0)">
  188. <div slot="content">
  189. <p v-if="row.FiccTryOutDay">FICC累计试用天数:{{row.FiccTryOutDay}}</p>
  190. <p v-if="row.RaiTryOutDay">权益累计试用天数:{{row.RaiTryOutDay}}</p>
  191. </div>
  192. <span :style="row.IsSuspend===1?'color:#bbb':'color:#409EFF;cursor:pointer;'" @click="handleTotalDayClick(row)">
  193. {{row.FiccTryOutDay+row.RaiTryOutDay}}
  194. </span>
  195. </el-tooltip>
  196. </template>
  197. </el-table-column>
  198. <el-table-column
  199. label="阅读"
  200. align="center"
  201. min-width="5.14%"
  202. prop="viewTotal"
  203. sortable="custom">
  204. <template slot-scope="{row}">
  205. <el-tooltip :disabled="row.IsSuspend===1 || (row.FiccView+row.RaiView)===0">
  206. <div slot="content"><p v-if="row.FiccView">FICC报告阅读次数:{{row.FiccView}}</p><p v-if="row.RaiView">权益报告阅读次数:{{row.RaiView}}</p></div>
  207. <span :style="row.IsSuspend===1?'color:#bbb':'color:#409EFF;cursor:pointer;'">
  208. <!-- 阅读次数拆分 -->
  209. {{row.AllViewTotal}}
  210. </span>
  211. </el-tooltip>
  212. </template>
  213. </el-table-column>
  214. <el-table-column
  215. label="路演"
  216. align="center"
  217. min-width="5.14%"
  218. prop="roadShowTotal"
  219. sortable="custom">
  220. <template slot-scope="scope">
  221. <span :style="scope.row.IsSuspend===1?'color:#bbb':''" @click="accumulativeFrequencyClick(scope)" class="editsty" v-if="scope.row.RoadShowTotal > 0">{{scope.row.RoadShowTotal}}</span>
  222. <span :style="scope.row.IsSuspend===1?'color:#bbb':''" v-else>{{scope.row.RoadShowTotal}}</span>
  223. </template>
  224. </el-table-column>
  225. <el-table-column
  226. label="最近阅读"
  227. min-width="8.14%"
  228. align="center"
  229. prop="viewTime"
  230. sortable="custom">
  231. <template slot-scope="scope">
  232. <p v-if="scope.row.FiccLastViewTime" :style="scope.row.IsSuspend===1?'color:#bbb':''">ficc: {{$moment(scope.row.FiccLastViewTime).format('YYYY.MM.DD')}}</p>
  233. <p v-else-if="scope.row.RaiLastViewTime" :style="scope.row.IsSuspend===1?'color:#bbb':''">权益: {{$moment(scope.row.RaiLastViewTime).format('YYYY.MM.DD')}}</p>
  234. <p v-else :style="scope.row.IsSuspend===1?'color:#bbb':''">--</p>
  235. </template>
  236. </el-table-column>
  237. <el-table-column
  238. prop="EndDate"
  239. :label="'服务期限'"
  240. align="center"
  241. min-width="6.14%">
  242. <template slot-scope="scope">
  243. <span :style="scope.row.IsSuspend===1?'color:#bbb':''">
  244. <!-- 正常的时间显示 -->
  245. <template v-if="scope.row.StartDate.indexOf('/')==-1">
  246. {{scope.row.StartDate}}~{{scope.row.EndDate}}
  247. </template>
  248. <!-- 公用客户的时间显示 -->
  249. <template v-else>
  250. {{scope.row.StartDate.substr(0,10)}}~{{scope.row.EndDate.substr(0,10)}}/{{scope.row.StartDate.substr(11)}}~{{scope.row.EndDate.substr(11)}}
  251. </template>
  252. </span>
  253. </template>
  254. </el-table-column>
  255. <el-table-column
  256. prop="expireDay"
  257. :label="'到期'"
  258. align="center"
  259. min-width="5.14%"
  260. sortable="custom">
  261. <template slot-scope="scope">
  262. <span :style="scope.row.IsSuspend===1?'color:#bbb':''">
  263. {{scope.row.ExpireDay||'--'}}
  264. </span>
  265. </template>
  266. </el-table-column>
  267. <el-table-column
  268. prop="createTime"
  269. :label="'创建时间'"
  270. sortable="custom"
  271. align="center" min-width="6.14%">
  272. <template slot-scope="scope">
  273. <span :style="scope.row.IsSuspend===1?'color:#bbb':''">
  274. {{$moment(scope.row.CreatedTime).format('YYYY.MM.DD')}}
  275. </span>
  276. </template>
  277. </el-table-column>
  278. <el-table-column
  279. prop="lastServiceTime"
  280. :label="'最新服务时间'"
  281. sortable="custom"
  282. align="center" min-width="6.14%">
  283. <template slot-scope="scope">
  284. <span :style="scope.row.IsSuspend===1?'color:#bbb':''">
  285. {{scope.row.LastServiceTime.substr(0,10).replaceAll('-','.')||'--'}}
  286. </span>
  287. </template>
  288. </el-table-column>
  289. <el-table-column
  290. prop="serviceTimes"
  291. :label="'服务次数'"
  292. sortable="custom"
  293. align="center" min-width="6.14%">
  294. <template slot-scope="scope">
  295. <span :style="scope.row.ServiceTimes>0?'color:#409eff;cursor: pointer;':''" @click="handleShowShareRecode(scope.row,'list')">
  296. {{scope.row.ServiceTimes}}
  297. </span>
  298. </template>
  299. </el-table-column>
  300. <el-table-column label="操作" align="center" min-width="7.14%">
  301. <template slot-scope="scope">
  302. <div class="tool" style="display: flex; align-items: center;justify-content: center;" v-if="scope.row.ApproveStatus!='待审批'">
  303. <!-- <span class="editsty" style="white-space: nowrap;" @click="itemclickHandle({type:'查看权限',data:scope.row})">
  304. 查看权限
  305. </span>
  306. <span @click="itemclickHandle({type:'分配销售',data:scope.row})" v-if="Role=='thisAdmin'" class="editsty"
  307. style="white-space: nowrap;">
  308. {{scope.row.ShareSellerId?'修改销售':'分配销售'}}
  309. </span>
  310. <span class="editsty" @click="itemclickHandle({type:'服务记录',data:scope.row})">
  311. 服务记录
  312. </span>
  313. <span class="editsty" @click="itemclickHandle({type:'备注',data:scope.row})">
  314. 备注
  315. </span> -->
  316. <div class="font-tool" style="display:flex;flex-direction:column;">
  317. <span class="editsty" v-for="item in getToolBtnList(scope.row).slice(0,3)" :key="item.type" @click="itemclickHandle({type:item.type,data:scope.row})">
  318. {{item.type==='分配销售'?scope.row.ShareSellerId?'修改销售':'分配销售':item.type}}
  319. </span>
  320. </div>
  321. <el-dropdown size="medium" placement="bottom-start" @command="itemclickHandle" style="height: 16px;margin-left: 5px;" v-if="getToolBtnList(scope.row).length>3">
  322. <span class="el-dropdown-link">
  323. <i class="el-icon-more el-icon--right"></i>
  324. <el-dropdown-menu slot="dropdown">
  325. <el-dropdown-item :command="{type:item.type,data:scope.row}"
  326. v-for="item in getToolBtnList(scope.row).slice(3)" :key="item.type">
  327. <span>{{item.type}}</span>
  328. </el-dropdown-item>
  329. </el-dropdown-menu>
  330. </span>
  331. </el-dropdown>
  332. </div>
  333. </template>
  334. </el-table-column>
  335. <div slot="empty" style="line-height:44px;margin:60px 0;color:#999;">
  336. <img src="~@/assets/img/cus_m/nodata.png" alt="" style="display:block;width:160px;height:128px;margin: auto;">
  337. <span>暂无信息</span>
  338. </div>
  339. </el-table>
  340. <div class="toolbar fixedbar">
  341. <el-pagination
  342. layout="prev,pager,next,total"
  343. background
  344. :current-page="page_no"
  345. @current-change="handleCurrentChange"
  346. :page-size="pageSize"
  347. :total="total"
  348. style="float:right;">
  349. </el-pagination>
  350. </div>
  351. </div>
  352. </div>
  353. <!-- 修改销售弹窗 -->
  354. <el-dialog
  355. v-dialogDrag
  356. :visible.sync="assignedSellerShow"
  357. :close-on-click-modal="false"
  358. :modal-append-to-body='false'
  359. :title="assignedSellerTitle"
  360. @close="cancelAssign"
  361. center
  362. width="444px">
  363. <el-form :model="assignform" :rules="rule" ref="assignform" label-width="110px">
  364. <el-form-item label="客户名称" prop="name">
  365. <span style="fontSize:16px;">{{assignform.CompanyName}}</span>
  366. </el-form-item>
  367. <el-form-item label="分配销售" prop="SellsId">
  368. <el-select
  369. v-model="assignform.SellsId"
  370. placeholder="请选择修改的销售"
  371. style="width: 240px"
  372. filterable>
  373. <el-option :label="item.RealName" :value="item.AdminId" v-for="item in salesArr" :key="item.AdminId"></el-option>
  374. </el-select>
  375. </el-form-item>
  376. </el-form>
  377. <div style="display:flex;justify-content:center;margin:60px 0 35px;">
  378. <el-button type="primary" style="width:80px;marginRight:24px;" @click="saveAssign">保存</el-button>
  379. <el-button style="width:80px;" @click="cancelAssign">取消</el-button>
  380. </div>
  381. </el-dialog>
  382. <!-- 查看权限弹窗 -->
  383. <permissionView :isLook.sync="isLook" :lookTitle="lookTitle" :lookAuthList="lookAuthList" :lookAuthListEquity="lookAuthListEquity"
  384. @closeDia="closeDia"></permissionView>
  385. <!-- 累计试用天数弹窗 -->
  386. <total-day-dialog
  387. :isTotalDayDialogShow.sync="isTotalDayDialogShow"
  388. :customInfo.sync="customInfo"
  389. />
  390. <!-- 路演业阅读的弹框 -->
  391. <accumulative-frequency-dlg :accumulativeFrequencyDlg.sync="accumulativeFrequencyDlg" :accumulativeFrequencyItem.sync="accumulativeFrequencyItem" />
  392. <!-- 服务记录弹窗 -->
  393. <share-list-dialog
  394. :isShareRecodeDialogShow.sync="isShareRecodeDialogShow"
  395. :customInfo="customInfo"
  396. :allowEdit="allowEdit"
  397. @close="()=>{isShareRecodeDialogShow&&getTableData();isShareRecodeDialogShow=false;}"/>
  398. <!-- 备注弹窗 -->
  399. <custom-remark-dialog
  400. :isRemarkLook="isRemarkLook"
  401. :lookRemarkItem="customInfo"
  402. @close="isRemarkLook=false"
  403. />
  404. <!-- 补全客户信息弹窗 -->
  405. <CompleteInfo
  406. :form="completeForm"
  407. @cancel="cancelCompleteInfo($event)"
  408. ></CompleteInfo>
  409. <!-- 合同 -->
  410. <el-dialog
  411. :visible.sync="contractModel.show"
  412. :modal-append-to-body='false'
  413. width="800px"
  414. class="self-dialog"
  415. v-dialogDrag
  416. >
  417. <div style="text-align:center;margin:30px 0 100px 0">
  418. <img width="191" src="../../../assets/img/cus_m/bzht.png" @click="handleContractModel('标准')" style="margin-right:80px;cursor: pointer;">
  419. <img width="191" src="../../../assets/img/cus_m/fbzht.png" @click="handleContractModel('非标准')" style="cursor: pointer;">
  420. <p style="font-size:15px;color:#333;text-align:left;padding-left:100px;margin-top:30px">
  421. 注:<br>
  422. 系统生成合同请选择标准合同入口<br>
  423. 非系统生成合同请选择非标准合同入口(包含已走完邮件流程的标准合同)</p>
  424. </div>
  425. </el-dialog>
  426. <!-- 合同信息 -->
  427. <ContractInfo
  428. :initData="contractDialog"
  429. @contractInfoDialogClose="contractInfoDialogClose"
  430. ></ContractInfo>
  431. <!-- 增开试用弹窗 -->
  432. <el-dialog
  433. :visible.sync="isAddTrial"
  434. :close-on-click-modal="false"
  435. :modal-append-to-body='false'
  436. @close="isAddTrial=false"
  437. width="800px"
  438. v-dialogDrag
  439. center>
  440. <div slot="title" style="display:flex;alignItems:center;">
  441. <span style="fontSize:16px;">增开试用(默认两个月)</span>
  442. </div>
  443. <Cauthlist
  444. :autharr="authList"
  445. :id="addTryId"
  446. @addOver="addTryOver"
  447. @close="isAddTrial=false"/>
  448. </el-dialog>
  449. </div>
  450. </template>
  451. <script>
  452. import { customInterence } from '@/api/api.js'
  453. import AccumulativeFrequencyDlg from '../compontents/accumulativeFrequencyDlg.vue'
  454. import permissionView from './components/permissionView.vue'
  455. import mixin from './mixins/customlistMixin';
  456. import TotalDayDialog from '../compontents/TotalDayDialog.vue'
  457. import ShareListDialog from './components/shareListDialog.vue';
  458. import CustomRemarkDialog from './components/customRemarkDialog.vue';
  459. import ContractInfo from '../compontents/ContractInfo.vue';
  460. import CompleteInfo from '../compontents/CompleteInfo.vue';
  461. import Cauthlist from '../compontents/CauthList.vue';
  462. export default {
  463. name:'',
  464. mixins: [ mixin ],
  465. components: {TotalDayDialog,AccumulativeFrequencyDlg,permissionView, ShareListDialog,CustomRemarkDialog,ContractInfo,CompleteInfo,Cauthlist},
  466. computed:{
  467. isPWang(){
  468. return this.adminId == 66
  469. },
  470. isYDLou(){
  471. // 不同环境下 楼颖丹账号的adminId 不一样
  472. if(process.env.NODE_ENV == 'development'||process.env.NODE_ENV == 'test'){
  473. return this.adminId == 476
  474. }else if(process.env.NODE_ENV == 'production'){
  475. return this.adminId == 15
  476. }
  477. },
  478. Role() {
  479. let role = localStorage.getItem('Role') || '';
  480. if(role=='admin' || this.isPWang || this.isYDLou){
  481. // 只有王沛、楼颖丹和所有admin账号才有分配销售的权利
  482. return 'thisAdmin';
  483. }else{
  484. return 'thisSeller';
  485. }
  486. }
  487. },
  488. data () {
  489. this.statusList = [{label:'未共享',value:3},{label:'已分配',value:1},{label:'待分配',value:2}]
  490. return {
  491. adminId:localStorage.getItem('AdminId'),
  492. sales:[],
  493. salesArr:[],//销售
  494. tableData:[],
  495. isShowloadding:false,
  496. status:2,
  497. search_txt:'',
  498. total:0,
  499. page_no:1,
  500. pageSize:10,
  501. isLook:false,//权限弹窗
  502. lookTitle:'',//权限弹窗标题
  503. lookAuthList:[],//查看的权限
  504. lookAuthListEquity:[],//权益
  505. assignedSellerShow:false,//分配销售弹窗
  506. assignedSellerTitle:'分配销售',
  507. assignform:{
  508. CompanyId:'',
  509. CompanyName:'',
  510. SellsId:''//选择的销售
  511. },
  512. rule:{
  513. SellsId:[
  514. { required: true, message: '销售不能为空', trigger: 'change' },
  515. ]
  516. },
  517. sort_type:'',//自定义排序方式
  518. sort_param:'',//自定义排序方式的哪一个
  519. btnCommandList:{
  520. BtnView: '查看权限',
  521. BtnModifySeller: '分配销售',
  522. BtnUpdate: '续约申请',
  523. BtnAddAgreement: '补充协议',
  524. BtnTryOut: '增开试用',
  525. BtnServiceRecord:'服务记录',
  526. BtnRemarkView:'备注'
  527. }, // 按钮命令列表
  528. accumulativeFrequencyDlg:false,//路演业阅读的弹框
  529. accumulativeFrequencyItem:{},
  530. isRemarkLook:false,//备注的弹框
  531. contractDialog:{
  532. show:false,
  533. type:'',//类型 续约申请、补充协议
  534. cusdata:null,//客户信息(列表用户数据)
  535. },//续约申请、补充协议 合同信息弹窗
  536. contractModel:{
  537. show:false,
  538. data:null,//客户信息(列表用户数据)
  539. type:'',//类型 续约申请、补充协议
  540. },//续约申请、补充协议 选择合同类型弹窗
  541. completeForm:{},
  542. isAddTrial:false,
  543. authList:[],
  544. originalSales:'',
  545. originalSalesArr:[],
  546. defaultSalesProps:{
  547. multiple: true,
  548. label:'RealName',
  549. children:'ChildrenList',
  550. value:'AdminId'
  551. },//销售级联配置
  552. };
  553. },
  554. methods: {
  555. /* 获取表格 */
  556. getTableData() {
  557. this.isShowloadding = true;
  558. // 处理销售筛选
  559. let salesArr=[]
  560. if(this.sales.length){
  561. salesArr=this.sales.map(item=>{
  562. return item[item.length-1]
  563. })
  564. }
  565. let params = {
  566. SortParam:this.sort_param,//自定义排序字段
  567. SortType:this.sort_type,//排序方式
  568. PageSize:this.pageSize,
  569. CurrentIndex:this.page_no,
  570. Keyword:this.search_txt,
  571. ListParam:this.Role=='thisSeller'?1:this.status, // 销售只能看分配给自己的共享客户,即状态需要是已分配
  572. SellerId:this.sales.join(','),
  573. OriginalSellerId:salesArr.join(','),
  574. }
  575. customInterence.getShareCustomList(params).then(res => {
  576. if(res.Ret === 200) {
  577. this.total = res.Data.Paging.Totals || 0;
  578. this.tableData = res.Data.List || [];
  579. this.isShowloadding = false;
  580. }
  581. })
  582. },
  583. /* 获取销售 */
  584. getSale() {
  585. customInterence.salesShareList().then(res => {
  586. console.log(res);
  587. if(res.Ret === 200) {
  588. this.salesArr = res.Data|| []
  589. }
  590. })
  591. },
  592. /* 前往详情页 */
  593. goDetail(item) {
  594. const { href } = this.$router.resolve({
  595. path:'/customDetail',
  596. query:{
  597. id:item.CompanyId,
  598. }});
  599. window.open(href, '_blank');
  600. },
  601. getToolBtnList(data){
  602. let toolList = []
  603. const {BtnItem} = data
  604. for(const i in this.btnCommandList){
  605. if(BtnItem[i]){
  606. toolList.push({type:this.btnCommandList[i]})
  607. }
  608. }
  609. return toolList
  610. },
  611. /* 操作-按钮 */
  612. async itemclickHandle(query) {
  613. if(query.type == '分配销售'||query.type=='修改销售') {
  614. this.assignedSellerFun(query.data)
  615. }else if(query.type=='查看权限'){
  616. this.lookHandle(query.data)
  617. }else if(query.type=='服务记录'){
  618. this.handleShowShareRecode(query.data)
  619. }else if(query.type=='备注'){
  620. this.handleShowRemark(query.data)
  621. }else if(["续约申请","补充协议"].includes(query.type)){
  622. this.handleOpenContractChoose(query.type,query.data)
  623. }else if("增开试用"){
  624. this.addTrialHandle(query.data)
  625. }
  626. },
  627. /* 查看权限 */
  628. lookHandle(item) {
  629. this.lookTitle = item.CompanyName;
  630. customInterence.lookauth({
  631. CompanyId:item.CompanyId
  632. }).then(res => {
  633. if(res.Ret === 200) {
  634. this.isLook = true;
  635. let auth = [];
  636. res.Data.List ? res.Data.List.forEach(item=> {
  637. auth.push(item.Items)
  638. }):''
  639. this.lookAuthList = auth.flat(Infinity);
  640. let authEquity =[] //权益
  641. res.Data.ListRai ? res.Data.ListRai.forEach(item=> {//权益
  642. // 过滤没有权限的套餐
  643. authEquity.push(item.Items.filter(it => item.CheckList.includes(it.ChartPermissionId)))
  644. }):''
  645. this.lookAuthListEquity = authEquity.flat(Infinity) //权益
  646. }
  647. })
  648. },
  649. assignedSellerFun(row){
  650. this.assignform = {
  651. CompanyName:row.CompanyName,
  652. CompanyId:row.CompanyId,
  653. SellsId:row.ShareSellerId==0?'':row.ShareSellerId+'',
  654. }
  655. this.assignedSellerShow = true;
  656. },
  657. /* 页码改变 */
  658. handleCurrentChange(page) {
  659. this.page_no = page;
  660. this.getTableData();
  661. },
  662. /* 关闭查看权限弹窗 */
  663. closeDia() {
  664. this.lookTitle = '';
  665. this.lookAuthList = [];
  666. this.lookAuthListEquity = []
  667. this.isLook = false;
  668. },
  669. /* 分配销售 */
  670. saveAssign() {
  671. this.$refs.assignform.validate((valid) => {
  672. if (valid) {
  673. let param={
  674. CompanyId:this.assignform.CompanyId,
  675. SellsId:+this.assignform.SellsId
  676. }
  677. customInterence.assignShareSeller(param).then(res=>{
  678. if(res.Ret == 200){
  679. this.$message.success(this.assignedSellerTitle+'成功');
  680. this.getTableData();
  681. this.assignedSellerShow = false;
  682. }
  683. })
  684. }
  685. })
  686. },
  687. /* 取消移动客户 */
  688. cancelAssign() {
  689. this.assignform = {
  690. CompanyName:'',
  691. CompanyId:'',
  692. SellsId:'',
  693. }
  694. this.$refs.assignform.resetFields();
  695. this.assignedSellerShow = false;
  696. },
  697. /* 到期天数排序发生变化 全局排序 */
  698. sortChangeHandle(item) {
  699. this.sort_type = item.order === 'ascending' ? 'asc':item.order === 'descending' ? 'desc' : '';
  700. this.sort_param = item.prop;
  701. this.getTableData();
  702. },
  703. accumulativeFrequencyClick(item){
  704. this.accumulativeFrequencyDlg = true
  705. this.accumulativeFrequencyItem = item.row
  706. },
  707. handleShowRemark(item){
  708. this.customInfo = item
  709. this.isRemarkLook = true
  710. },
  711. //关闭合同信息弹窗
  712. contractInfoDialogClose(e){
  713. this.contractDialog={
  714. show:false,
  715. type:'',
  716. cusdata:null,
  717. }
  718. if(e==='updateList'){
  719. this.getTableData();
  720. }
  721. },
  722. //验证客户信息完整性
  723. async getCustomerDetail(id){
  724. let res=await customInterence.customDetail({
  725. CompanyId:id
  726. })
  727. if(res.Ret!=200) return
  728. let RoleType=localStorage.getItem('RoleType')
  729. let IndustryId='',Source=';'
  730. if(RoleType=='ficc'){
  731. IndustryId=res.Data.FiccItem.IndustryId
  732. Source=res.Data.FiccItem.Source
  733. }else if(RoleType=='权益'){
  734. IndustryId=res.Data.RaiItem.IndustryId
  735. Source=res.Data.RaiItem.Source
  736. }
  737. if((res.Data.Item.RegionType!='海外'&&!res.Data.Item.Province&&!res.Data.Item.City)||!res.Data.Item.CreditCode||!IndustryId||!Source){
  738. this.completeForm={
  739. nameDisable:res.Data.Item.CompanyName!='',
  740. CityDisable:res.Data.Item.City!='',
  741. CreditCodeDisable:res.Data.Item.CreditCode!='',
  742. IndustryIdDisable:IndustryId!=' ',
  743. SourceDisable:Source!='',
  744. CompanyId:id,
  745. name:res.Data.Item.CompanyName,
  746. Province:res.Data.Item.Province,
  747. RegionType:res.Data.Item.RegionType,
  748. City:res.Data.Item.City,
  749. CreditCode:res.Data.Item.CreditCode,
  750. IndustryId:IndustryId?IndustryId:'',
  751. Source:Source,
  752. flag:false,//是否为跨部门
  753. show:true
  754. }
  755. }else{
  756. this.completeForm.show=false
  757. }
  758. return new Promise((resolve,reject)=>{
  759. resolve(this.completeForm.show)
  760. })
  761. },
  762. //关闭补全信息弹窗
  763. cancelCompleteInfo(refresh){
  764. // 刷新列表
  765. if(refresh){
  766. this.getTableData()
  767. }
  768. this.completeForm={
  769. show:false
  770. }
  771. },
  772. //打开合同选择弹窗
  773. async handleOpenContractChoose(type,data){
  774. let flag=await this.getCustomerDetail(data.CompanyId)
  775. if(flag) return
  776. this.contractModel = {
  777. type,data,show:true
  778. }
  779. },
  780. //选择标准/非标合同
  781. handleContractModel(model){
  782. if(model==='标准'){
  783. this.contractDialog.type = this.contractModel.type
  784. this.contractDialog.cusdata = this.contractModel.data
  785. this.contractDialog.show = true
  786. }else{
  787. sessionStorage.setItem('companyInfo',JSON.stringify(this.contractModel.data))
  788. const routeMap = {
  789. '续约申请':'/updateCustom',
  790. '补充协议':'/addAgreement'
  791. }
  792. const { href } = this.$router.resolve({path:routeMap[this.contractModel.type],})||{href:''}
  793. href&&window.open(href, '_blank');
  794. }
  795. this.contractModel={
  796. type:'',data:null,show:false
  797. }
  798. },
  799. //增加试用完成
  800. addTryOver(){
  801. this.isAddTrial = false;
  802. this.getTableData();
  803. },
  804. //增开试用
  805. addTrialHandle(item) {
  806. this.authList = [];
  807. customInterence.lookauth({
  808. CompanyId:item.CompanyId,
  809. LookType:1
  810. }).then(res => {
  811. if(res.Ret === 200) {
  812. let auth = [];
  813. // res.Data.List 有值为 ficc
  814. // res.Data.ListRai 有值为 权益
  815. res.Data.List ? res.Data.List.forEach(item=> {
  816. let obj = {
  817. checkAll:item.CheckList&&item.CheckList.length===item.Items.length?true:false,
  818. isIndeterminate:item.CheckList&&item.CheckList.length>0 && item.CheckList.length<item.Items.length,
  819. defaultAuth:item.CheckList,
  820. customType:'ficc',
  821. ...item,
  822. }
  823. auth.push(obj)
  824. }):
  825. // 权益 RaiMerge 0不管 1合并 2拆分 所传入的数据结构不一样
  826. res.Data.ListRai[0].RaiMerge==1?res.Data.ListRai.forEach(item=> { // 合并
  827. let obj = {
  828. checkAll:item.CheckList&&item.CheckList.length===item.Items.length?true:false,
  829. isIndeterminate:item.CheckList&&item.CheckList.length>0 && item.CheckList.length<item.Items.length,
  830. defaultAuth:item.CheckList,
  831. ...item,
  832. }
  833. auth.push(obj)
  834. }): res.Data.ListRai.forEach(item=> { // 拆分
  835. let obj = {
  836. defaultAuth:item.CheckList,
  837. customType:'权益',
  838. ...item,
  839. }
  840. // 组合所需的数据格式
  841. obj.dataList=[
  842. {
  843. PermissionTypeName:'',
  844. medicine:{
  845. value:'医药',
  846. isIndeterminate:item.CheckList.filter(id => [obj.Items[0].ChartPermissionId,obj.Items[1].ChartPermissionId].includes(id)).length ==1,
  847. isCheckAll:item.CheckList.filter(id => [obj.Items[0].ChartPermissionId,obj.Items[1].ChartPermissionId].includes(id)).length == 2,
  848. isDisabled:item.CheckList.filter(id => [obj.Items[0].ChartPermissionId,obj.Items[1].ChartPermissionId].includes(id)).length ==2
  849. },
  850. consumption:{
  851. value:'消费',
  852. isIndeterminate:item.CheckList.filter(id => [obj.Items[2].ChartPermissionId,obj.Items[3].ChartPermissionId].includes(id)).length ==1,
  853. isCheckAll:item.CheckList.filter(id => [obj.Items[2].ChartPermissionId,obj.Items[3].ChartPermissionId].includes(id)).length == 2,
  854. isDisabled:item.CheckList.filter(id => [obj.Items[2].ChartPermissionId,obj.Items[3].ChartPermissionId].includes(id)).length ==2
  855. },
  856. technology:{
  857. value:'科技',
  858. isIndeterminate:item.CheckList.filter(id => [obj.Items[4].ChartPermissionId,obj.Items[5].ChartPermissionId].includes(id)).length ==1,
  859. isCheckAll:item.CheckList.filter(id => [obj.Items[4].ChartPermissionId,obj.Items[5].ChartPermissionId].includes(id)).length == 2,
  860. isDisabled:item.CheckList.filter(id => [obj.Items[4].ChartPermissionId,obj.Items[5].ChartPermissionId].includes(id)).length ==2
  861. },
  862. smart:{
  863. value:'智造',
  864. isIndeterminate:item.CheckList.filter(id => [obj.Items[6].ChartPermissionId,obj.Items[7].ChartPermissionId].includes(id)).length ==1,
  865. isCheckAll:item.CheckList.filter(id => [obj.Items[6].ChartPermissionId,obj.Items[7].ChartPermissionId].includes(id)).length == 2,
  866. isDisabled:item.CheckList.filter(id => [obj.Items[6].ChartPermissionId,obj.Items[7].ChartPermissionId].includes(id)).length ==2
  867. },
  868. strategy:{
  869. value:'策略'
  870. },
  871. experts:{
  872. value:'专家'
  873. },
  874. roadshow:{
  875. value:'路演服务'
  876. },
  877. choose:{
  878. value:'买方研选'
  879. }
  880. },
  881. {
  882. PermissionTypeName:{
  883. value:'主观',
  884. isIndeterminate:[1,2,3].includes(item.CheckList.filter(id => [obj.Items[0].ChartPermissionId,obj.Items[2].ChartPermissionId,
  885. obj.Items[4].ChartPermissionId,obj.Items[6].ChartPermissionId].includes(id)).length),
  886. isCheckAll:item.CheckList.filter(id => [obj.Items[0].ChartPermissionId,obj.Items[2].ChartPermissionId,
  887. obj.Items[4].ChartPermissionId,obj.Items[6].ChartPermissionId].includes(id)).length == 4,
  888. isDisabled:item.CheckList.filter(id => [obj.Items[0].ChartPermissionId,obj.Items[2].ChartPermissionId,
  889. obj.Items[4].ChartPermissionId,obj.Items[6].ChartPermissionId].includes(id)).length ==4
  890. },
  891. medicine:{
  892. value:obj.Items[0].ChartPermissionId,
  893. isDisabled:item.CheckList.includes(obj.Items[0].ChartPermissionId)
  894. },
  895. consumption:{
  896. value:obj.Items[2].ChartPermissionId,
  897. isDisabled:item.CheckList.includes(obj.Items[2].ChartPermissionId)
  898. },
  899. technology:{
  900. value:obj.Items[4].ChartPermissionId,
  901. isDisabled:item.CheckList.includes(obj.Items[4].ChartPermissionId)
  902. },
  903. smart:{
  904. value:obj.Items[6].ChartPermissionId,
  905. isDisabled:item.CheckList.includes(obj.Items[6].ChartPermissionId)
  906. },
  907. strategy:{
  908. value:obj.Items[8].ChartPermissionId,
  909. isDisabled:item.CheckList.includes(obj.Items[8].ChartPermissionId)
  910. },
  911. experts:{
  912. value:obj.Items[9].ChartPermissionId,
  913. isDisabled:item.CheckList.includes(obj.Items[9].ChartPermissionId)
  914. },
  915. roadshow:{
  916. value:obj.Items[10].ChartPermissionId,
  917. isDisabled:item.CheckList.includes(obj.Items[10].ChartPermissionId)
  918. },
  919. choose:{
  920. value:obj.Items[11].ChartPermissionId,
  921. isDisabled:item.CheckList.includes(obj.Items[11].ChartPermissionId)
  922. }
  923. },
  924. {
  925. PermissionTypeName:{
  926. value:'客观',
  927. isIndeterminate:[1,2,3].includes(item.CheckList.filter(id => [obj.Items[1].ChartPermissionId,obj.Items[3].ChartPermissionId,
  928. obj.Items[5].ChartPermissionId,obj.Items[7].ChartPermissionId].includes(id)).length),
  929. isCheckAll:item.CheckList.filter(id => [obj.Items[1].ChartPermissionId,obj.Items[3].ChartPermissionId,
  930. obj.Items[5].ChartPermissionId,obj.Items[7].ChartPermissionId].includes(id)).length == 4,
  931. isDisabled:item.CheckList.filter(id => [obj.Items[1].ChartPermissionId,obj.Items[3].ChartPermissionId,
  932. obj.Items[5].ChartPermissionId,obj.Items[7].ChartPermissionId].includes(id)).length ==4
  933. },
  934. medicine:{
  935. value:obj.Items[1].ChartPermissionId,
  936. isDisabled:item.CheckList.includes(obj.Items[1].ChartPermissionId)
  937. },
  938. consumption:{
  939. value:obj.Items[3].ChartPermissionId,
  940. isDisabled:item.CheckList.includes(obj.Items[3].ChartPermissionId)
  941. },
  942. technology:{
  943. value:obj.Items[5].ChartPermissionId,
  944. isDisabled:item.CheckList.includes(obj.Items[5].ChartPermissionId)
  945. },
  946. smart:{
  947. value:obj.Items[7].ChartPermissionId,
  948. isDisabled:item.CheckList.includes(obj.Items[7].ChartPermissionId)
  949. },
  950. strategy:{
  951. value:obj.Items[8].ChartPermissionId,
  952. isDisabled:item.CheckList.includes(obj.Items[8].ChartPermissionId)
  953. },
  954. experts:{
  955. value:obj.Items[9].ChartPermissionId,
  956. isDisabled:item.CheckList.includes(obj.Items[9].ChartPermissionId)
  957. },
  958. roadshow:{
  959. value:obj.Items[10].ChartPermissionId,
  960. isDisabled:item.CheckList.includes(obj.Items[10].ChartPermissionId)
  961. },
  962. choose:{
  963. value:obj.Items[11].ChartPermissionId,
  964. isDisabled:item.CheckList.includes(obj.Items[11].ChartPermissionId)
  965. }
  966. }
  967. ]
  968. auth.push(obj)
  969. })
  970. this.authList = auth;
  971. }
  972. })
  973. this.addTryId = item.CompanyId;
  974. this.isAddTrial = true;
  975. },
  976. /* 获取销售 */
  977. getoriginalSale() {
  978. let status=0;
  979. customInterence.getSale({"Status":status}).then(res => {
  980. if(res.Ret === 200) {
  981. this.originalSalesArr = res.Data.List||[];
  982. }
  983. })
  984. },
  985. },
  986. created() {
  987. this.getSale()
  988. this.getoriginalSale()
  989. this.getTableData()
  990. }
  991. }
  992. </script>
  993. <style lang='scss'>
  994. .self-dialog{
  995. .el-dialog__header{
  996. background-color: #fff !important;
  997. .el-dialog__close.el-icon.el-icon-close{
  998. color: #666;
  999. }
  1000. }
  1001. }
  1002. </style>
  1003. <style lang='scss' scoped>
  1004. .ficc-package {
  1005. display: inline-block;
  1006. font-size: 12px;
  1007. padding:0 5px;
  1008. border-radius: 5px;
  1009. color: #3994fb;
  1010. background-color: #dcecfc;
  1011. }
  1012. .color-red{
  1013. color:red !important;
  1014. }
  1015. .isShared::after{
  1016. content: '共享';
  1017. font-size: 12px;
  1018. // padding: 0px 0px 0px 2px;
  1019. width: 30px;
  1020. color: #3994fb;
  1021. background-color: #dcecfc;
  1022. position: absolute;
  1023. left: 0;
  1024. bottom: 0;
  1025. border-top-right-radius: 5px;
  1026. }
  1027. .customList_container {
  1028. .customList_bot {
  1029. min-height: calc(100vh - 324px);
  1030. padding: 30px 30px 80px;
  1031. background: #fff;
  1032. position: relative;
  1033. border: 1px solid #ECECEC;
  1034. border-radius: 4px;
  1035. box-shadow: 0 3px 6px rgba(0, 0, 0, 0.05);
  1036. .customList_bot_search{
  1037. display: flex;
  1038. align-items: center;
  1039. justify-content: space-between;
  1040. flex-wrap: wrap;
  1041. margin-bottom: 12px;
  1042. }
  1043. .bot_cont{
  1044. //padding-bottom: 20px;
  1045. .fixedbar{
  1046. position: fixed;
  1047. right: 45px;
  1048. bottom: 20px;
  1049. background-color: transparent;
  1050. z-index: 2;
  1051. }
  1052. }
  1053. }
  1054. .mouse-enter {
  1055. &:hover {
  1056. text-decoration:underline;
  1057. }
  1058. }
  1059. }
  1060. </style>
  1061. <style lang="scss">
  1062. #customList_container {
  1063. .el-input--mini {
  1064. .el-input__inner{
  1065. padding: 0 6px !important;
  1066. height: 24px;
  1067. line-height: 24px;
  1068. color: #409EFF;
  1069. background: #ECF5FF;
  1070. border-color: #409EFF;
  1071. text-align: center;
  1072. }
  1073. .el-input__suffix {
  1074. right: -22px;
  1075. }
  1076. &.is-disabled {
  1077. .el-input__inner {
  1078. border-color: #E4E7ED;
  1079. }
  1080. .el-input__suffix {
  1081. display: none;
  1082. }
  1083. }
  1084. }
  1085. }
  1086. </style>