選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

StaffAnalysis.vue 16 KiB

3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608
  1. <template>
  2. <view>
  3. <view class="boxtittab">
  4. <view class="tabbox">
  5. <view :class="{ activecllasscet: activeTotal == 4 }" @click="tabtimetap(4)">近七天</view>
  6. </view>
  7. <view class="tabbox">
  8. <view :class="{ activecllasscet: activeTotal == 5 }" @click="tabtimetap(5)">近15天</view>
  9. </view>
  10. <view class="tabbox">
  11. <view :class="{ activecllasscet: activeTotal == 6 }" @click="tabtimetap(6)">近30天</view>
  12. </view>
  13. <view class="tabbox">
  14. <view :class="{ activecllasscet: activeTotal == 3 }" @click="tabtimetap(3)">自定义</view>
  15. </view>
  16. </view>
  17. <view class="timepick">
  18. <view class="timepicktime" @click="chiocStaff(0)">
  19. <view>{{staff1.label}}</view>
  20. <view>
  21. <image class="Underimg" src="../../../static/images/Underimg.png" mode=""></image>
  22. </view>
  23. </view>
  24. <view class="timepickpick">
  25. <view @click="checkboxChange()" style="width: 40rpx;height:40rpx;border: 1rpx solid #E0E0E0;">
  26. <image v-if="timepickpickisshow" style="width: 40rpx;height: 40rpx;" src="../../../static/images/xuanzhong.png" mode=""></image>
  27. </view>
  28. <view style="font-size:26rpx;text-indent: 12rpx;">对比</view>
  29. </view>
  30. <view class="timepicktime" v-if="timepickpickisshow" @click="chiocStaff(1)">
  31. <view>{{staff2.label}}</view>
  32. <view>
  33. <image class="Underimg" src="../../../static/images/Underimg.png" mode=""></image>
  34. </view>
  35. </view>
  36. </view>
  37. <view style="width: 100%;height: 20rpx;background: #FAFAFA;"></view>
  38. <view class="single">
  39. <view class="title">
  40. <view class="title1" style="flex: 1;">接待量</view>
  41. </view>
  42. <view class="hejibox">
  43. <view class="heji">{{staff1.label}}:{{newTeam1||0}}</view>
  44. <view class="heji" v-if="timepickpickisshow">{{staff2.label}}:{{newAvg1||0}}</view>
  45. </view>
  46. <view class="danwei">来访(人)</view>
  47. <view class="uchaserbox">
  48. <qiun-data-charts
  49. type="line"
  50. :chartData="lineOptsect"
  51. background="none"
  52. :ontouch="true"
  53. canvasId="wangxiaohuaerlingeryilingwuyibbb"
  54. :canvas2d="true"
  55. />
  56. </view>
  57. </view>
  58. <view style="width: 100%;height: 20rpx;background: #FAFAFA;"></view>
  59. <view class="single">
  60. <view class="title">
  61. <view class="title1" style="flex: 1;">录音时长</view>
  62. <view class="title3" style="flex: 1;">
  63. <!-- <view class="title3-box" style="width: 40%;" @click="tabtimetap1(0)">
  64. <view style="height: 42rpx;" :class="{ activecltab: activeTotal2 == 0 }">有效录音</view>
  65. </view>
  66. <view class="title3-box" style="width: 40%;"@click="tabtimetap1(1)">
  67. <view style="height: 42rpx;" :class="{ activecltab: activeTotal2 == 1 }">录音时长</view>
  68. </view> -->
  69. </view>
  70. </view>
  71. <view class="hejibox">
  72. <view class="heji">{{staff1.label}}:{{newTeam2||0}}</view>
  73. <view class="heji" v-if="timepickpickisshow">{{staff2.label}}:{{newAvg2||0}}</view>
  74. </view>
  75. <view class="danwei">录音时长</view>
  76. <view class="uchaserbox">
  77. <qiun-data-charts
  78. type="line"
  79. :chartData="lineOptsect1"
  80. background="none"
  81. :ontouch="true"
  82. canvasId="wangxiaouaerlingeryilingwuyibhh"
  83. :canvas2d="true"
  84. />
  85. </view>
  86. </view>
  87. <view style="width: 100%;height: 20rpx;background: #FAFAFA;"></view>
  88. <view class="single">
  89. <view class="title">
  90. <view class="title1" style="flex: 1;">销讲执行率</view>
  91. <view class="title3" style="flex: 1;">
  92. <!-- <view class="title3-box" style="width: 40%;" @click="tabtimetap1(0)">
  93. <view style="height: 42rpx;" :class="{ activecltab: activeTotal2 == 0 }">有效录音</view>
  94. </view>
  95. <view class="title3-box" style="width: 40%;"@click="tabtimetap1(1)">
  96. <view style="height: 42rpx;" :class="{ activecltab: activeTotal2 == 1 }">录音时长</view>
  97. </view> -->
  98. </view>
  99. </view>
  100. <view class="hejibox">
  101. <view class="heji">{{staff1.label}}:{{newTeam3||0}}</view>
  102. <view class="heji" v-if="timepickpickisshow">{{staff2.label}}:{{newAvg3||0}}</view>
  103. </view>
  104. <!-- <view class="danwei">录音时长</view> -->
  105. <view class="uchaserbox">
  106. <qiun-data-charts
  107. type="line"
  108. :chartData="lineOptsect2"
  109. background="none"
  110. :ontouch="true"
  111. canvasId="wangxiaohuaerlingryilingwuyibhh"
  112. :canvas2d="true"
  113. />
  114. </view>
  115. </view>
  116. <view style="width: 100%;height: 20rpx;background: #FAFAFA;"></view>
  117. <view class="single">
  118. <view class="title" style="padding-right: 30rpx;">
  119. <view class="title1" style="flex: 1;">销讲能力</view>
  120. </view>
  121. <view class="uchaserbox">
  122. <qiun-data-charts
  123. type="radar"
  124. :chartData="chartData"
  125. :canvas2d="true"
  126. canvasId="wangxiaohuaerlingeryilinwuycsdx"
  127. background="none"
  128. />
  129. </view>
  130. </view>
  131. <!-- <u-calendar v-model="totalTimeShow" mode="range" @change="totalTimeChange"></u-calendar> -->
  132. <u-calendar v-model="totalTimeShow" mode="range" @change="totalTimeChange"></u-calendar>
  133. <!-- 选择客户的选择框 -->
  134. <u-select v-model="staffShow" :list="staffList" @confirm="staffSelectCallback" :default-value='selindex'></u-select>
  135. <u-select v-model="staffShow1" :list="staffList1" @confirm="staffSelectCallback" :default-value='selindex'></u-select>
  136. </view>
  137. </template>
  138. <script>
  139. export default {
  140. data() {
  141. return {
  142. timepickpickisshow:true,
  143. totalTimeShow: false,
  144. activeTotal:4,
  145. activeTotal2:1,
  146. // 楼盘id
  147. houseId:'',
  148. staffList:[],
  149. staffList1:[],
  150. staffShow:false,
  151. staffShow1:false,
  152. newTeam1:'',
  153. newAvg1:'',
  154. newTeam2:'',
  155. newAvg2:'',
  156. newTeam3:'',
  157. newAvg3:'',
  158. staff1:{
  159. value:'',
  160. label:''
  161. },
  162. staff2:{
  163. value:'',
  164. label:'平均'
  165. },
  166. lastStartDate:'',
  167. lastEndDate :'',
  168. selindex:[0],
  169. choseStaffFlag:false,
  170. lineOptsect:{
  171. "categories": ["2016","2017","2018","2019","2020","2021"],
  172. "series": [
  173. {
  174. "name": "成交量1",
  175. "data": [35,8,25,37,4,20]
  176. },
  177. {
  178. "name": "成交量2",
  179. "data": [40,18,45,44,10,60]
  180. }
  181. ]
  182. },
  183. lineOptsect1:{
  184. "categories": ["2016","2017","2018","2019","2020","2021"],
  185. "series": [
  186. {
  187. "name": "成交量1",
  188. "data": [35,8,25,37,4,20]
  189. },
  190. {
  191. "name": "成交量2",
  192. "data": [40,18,45,44,10,60]
  193. }
  194. ]
  195. },
  196. lineOptsect2:{
  197. "categories": ["2016","2017","2018","2019","2020","2021"],
  198. "series": [
  199. {
  200. "name": "成交量1",
  201. "data": [35,8,25,37,4,20]
  202. },
  203. {
  204. "name": "成交量2",
  205. "data": [40,18,45,44,10,60]
  206. }
  207. ]
  208. },
  209. chartData:{
  210. "categories": ["维度1","维度2","维度3","维度4","维度5","维度6"],
  211. "series": [
  212. {
  213. "name": "成交量",
  214. "data": [90,110,165,195,187,172]
  215. }
  216. ]
  217. }
  218. };
  219. },
  220. onLoad: function(options) {
  221. // 获取楼盘id
  222. this.houseId = uni.getStorageSync('buildingID').id;
  223. // this.buildingname = uni.getStorageSync('buildingID').name;
  224. // 请求接口获取所有置业顾问员工的列表
  225. this.getStaffList()
  226. },
  227. methods: {
  228. //是否对比
  229. checkboxChange(){
  230. this.timepickpickisshow=!this.timepickpickisshow;
  231. this.staff2.value=''
  232. this.staff2.label='平均'
  233. // this.getreception()
  234. // this.getRecordList()
  235. // this.getAwardList()
  236. // this.getAward()
  237. this.getdata()
  238. },
  239. // 点击员工对比
  240. chiocStaff(idx){
  241. if(idx==0){
  242. // 当选择了第一个的时候
  243. this.choseStaffFlag=false
  244. this.staffShow=true
  245. }else{
  246. this.choseStaffFlag=true
  247. this.staffShow1=true
  248. }
  249. },
  250. // 获取员工列表
  251. getStaffList(){
  252. this.$u.post('/cusLvStatistics/selectAllAccountIdByHouseId',{houseId:this.houseId})
  253. .then(res=>{
  254. // console.log(res,'123')
  255. this.staffList=[]
  256. this.staffList1=[]
  257. res.map(item=>{
  258. let obj={}
  259. obj.value=item.accountId
  260. obj.label=item.name
  261. this.staffList.push(obj)
  262. })
  263. this.staffList1=[...this.staffList]
  264. this.staffList1.unshift({
  265. value:'',
  266. label:'平均'
  267. })
  268. this.staff1=this.staffList[0]
  269. // this.getreception()
  270. // this.getRecordList()
  271. // this.getAwardList()
  272. // this.getAward()
  273. this.getdata()
  274. })
  275. },
  276. getdata(){
  277. this.getreception()
  278. this.getRecordList()
  279. this.getAward()
  280. this.getAwardList()
  281. },
  282. // 获取接待量数据
  283. getreception(){
  284. this.$u.post('/cusLvStatistics/employeeAnalysisReception',{
  285. userA:this.staff1.value,
  286. userB:this.staff2.value,
  287. houseId:this.houseId,
  288. timeType:this.lastEndDate?null:this.activeTotal+'',
  289. lastEndDate:this.lastEndDate,
  290. lastStartDate:this.lastStartDate
  291. })
  292. .then(res=>{
  293. this.newTeam1=res.avg[0]
  294. this.newAvg1=res.avg[1]
  295. // console.log(res)
  296. let first=res.first
  297. let second=res.second
  298. this.lineOptsect.categories=[]
  299. if(!this.timepickpickisshow){
  300. this.lineOptsect.series=[
  301. {
  302. name:first[0].accountName,
  303. data:[]
  304. }
  305. ]
  306. first.map(item=>{
  307. this.lineOptsect.categories.push(item.statDate.slice(5,10))
  308. this.lineOptsect.series[0].data.push(item.receptionCount||0)
  309. })
  310. }else{
  311. this.lineOptsect.series=[
  312. {
  313. name:first[0].accountName,
  314. data:[]
  315. },
  316. {
  317. "name": second[0].accountName,
  318. "data": []
  319. }
  320. ]
  321. first.map(item=>{
  322. this.lineOptsect.categories.push(item.statDate.slice(5,10))
  323. this.lineOptsect.series[0].data.push(item.receptionCount)
  324. })
  325. second.map(item=>{
  326. this.lineOptsect.series[1].data.push(item.receptionCount)
  327. })
  328. }
  329. // console.log(this.lineOptsect,'1')
  330. })
  331. },
  332. // 销奖趋势
  333. getAward(){
  334. this.$u.post('/cusLvStatistics/employeeAnalysisExacutiveRate',{
  335. userA:this.staff1.value,
  336. userB:this.staff2.value,
  337. houseId:this.houseId,
  338. timeType:this.lastEndDate?null:this.activeTotal+'',
  339. lastEndDate:this.lastEndDate,
  340. lastStartDate:this.lastStartDate
  341. })
  342. .then(res=>{
  343. this.newTeam3=res.avg[0]
  344. this.newAvg3=res.avg[1]
  345. // console.log(res)
  346. let first=res.first
  347. let second=res.second
  348. this.lineOptsect2.categories=[]
  349. if(!this.timepickpickisshow){
  350. this.lineOptsect2.series=[
  351. {
  352. name:first[0].accountName,
  353. data:[]
  354. }
  355. ]
  356. first.map(item=>{
  357. // console.log(item)
  358. this.lineOptsect2.categories.push(item.statDate.slice(5,10))
  359. this.lineOptsect2.series[0].data.push(item.sumFraction)
  360. })
  361. }else{
  362. this.lineOptsect2.series=[
  363. {
  364. name:first[0].accountName,
  365. data:[]
  366. },
  367. {
  368. "name": second[0].accountName,
  369. "data": []
  370. }
  371. ]
  372. first.map(item=>{
  373. this.lineOptsect2.categories.push(item.statDate.slice(5,10))
  374. this.lineOptsect2.series[0].data.push(item.sumFraction)
  375. })
  376. second.map(item=>{
  377. this.lineOptsect2.series[1].data.push(item.sumFraction)
  378. })
  379. }
  380. // console.log(this.lineOptsect2,'3')
  381. })
  382. },
  383. // 获取有效录音
  384. async getRecordList(){
  385. // 当选择有效录音时
  386. let res=null
  387. if(this.activeTotal2==0){
  388. res= await this.$u.post('/cusLvStatistics/employeeAnalysisEffectiveRecording',{
  389. userA:this.staff1.value,
  390. userB:this.staff2.value,
  391. houseId:this.houseId,
  392. timeType:this.lastEndDate?null:this.activeTotal+'',
  393. lastEndDate:this.lastEndDate,
  394. lastStartDate:this.lastStartDate
  395. })
  396. }else{
  397. res= await this.$u.post('/cusLvStatistics/employeeAnalysisRecordingTime',{
  398. userA:this.staff1.value,
  399. userB:this.staff2.value,
  400. houseId:this.houseId,
  401. timeType:this.lastEndDate?null:this.activeTotal+'',
  402. lastEndDate:this.lastEndDate,
  403. lastStartDate:this.lastStartDate
  404. })
  405. }
  406. // console.log(res)
  407. this.newTeam2=res.avg[0]
  408. this.newAvg2=res.avg[1]
  409. let first=res.first
  410. let second=res.second
  411. this.lineOptsect1.categories=[]
  412. if(!this.timepickpickisshow){
  413. this.lineOptsect1.series=[
  414. {
  415. name:first[0].accountName,
  416. data:[]
  417. }
  418. ]
  419. first.map(item=>{
  420. this.lineOptsect1.categories.push(item.statDate.slice(5,10))
  421. this.lineOptsect1.series[0].data.push(item.sumDuration)
  422. })
  423. }else{
  424. this.lineOptsect1.series=[
  425. {
  426. name:first[0].accountName,
  427. data:[]
  428. },
  429. {
  430. "name": second[0].accountName,
  431. "data": []
  432. }
  433. ]
  434. first.map(item=>{
  435. this.lineOptsect1.categories.push(item.statDate.slice(5,10))
  436. this.lineOptsect1.series[0].data.push(item.sumDuration)
  437. })
  438. second.map(item=>{
  439. this.lineOptsect1.series[1].data.push(item.sumDuration)
  440. })
  441. }
  442. // console.log(this.lineOptsect1,'2')
  443. },
  444. // 获取销奖能力
  445. getAwardList(){
  446. this.$u.post('/cusLvStatistics/employeeAnalysisLevel1Fraction',{
  447. userA:this.staff1.value,
  448. userB:this.staff2.value,
  449. houseId:this.houseId,
  450. timeType:this.lastEndDate?null:this.activeTotal+'',
  451. lastEndDate:this.lastEndDate,
  452. lastStartDate:this.lastStartDate
  453. })
  454. .then(res=>{
  455. // console.log(res)
  456. let first=res.first
  457. let second=res.second
  458. this.chartData.categories=[]
  459. if(!this.timepickpickisshow){
  460. this.chartData.series=[
  461. {
  462. name:first[0].accountName,
  463. data:[]
  464. }
  465. ]
  466. first.map(item=>{
  467. this.chartData.categories.push(item.name)
  468. this.chartData.series[0].data.push(item.avgExecutionRate)
  469. })
  470. }else{
  471. this.chartData.series=[
  472. {
  473. name:first[0].accountName,
  474. data:[]
  475. },
  476. {
  477. "name": second[0].accountName,
  478. "data": []
  479. }
  480. ]
  481. first.map(item=>{
  482. this.chartData.categories.push(item.name)
  483. this.chartData.series[0].data.push(item.avgExecutionRate)
  484. })
  485. second.map(item=>{
  486. this.chartData.series[1].data.push(item.avgExecutionRate)
  487. })
  488. }
  489. })
  490. },
  491. tabtimetap(index){
  492. if (index == 3) {
  493. this.totalTimeShow = true;
  494. } else {
  495. this.activeTotal = index;
  496. this.lastEndDate=''
  497. this.lastStartDate=''
  498. // 获取数据
  499. // this.getreception()
  500. // this.getRecordList()
  501. // this.getAwardList()
  502. this.getdata()
  503. }
  504. },
  505. tabtimetap1(index){
  506. this.activeTotal2 = index;
  507. // 调用方法
  508. this.getRecordList()
  509. },
  510. //自定义时间
  511. totalTimeChange(e) {
  512. console.log(e.startDate, e.endDate)
  513. this.activeTotal=3;
  514. this.lastEndDate=e.endDate
  515. this.lastStartDate=e.startDate
  516. // 获取数据
  517. // this.getreception()
  518. // this.getRecordList()
  519. // this.getAwardList()
  520. this.getdata()
  521. },
  522. staffSelectCallback(e){
  523. if(this.choseStaffFlag){
  524. // 第二个客户
  525. // console.log(e,'第二个')
  526. this.staff2=e[0]
  527. }else{
  528. // 第一个客户
  529. // console.log(e,'第一个')
  530. this.staff1=e[0]
  531. }
  532. if(this.staff1.label==this.staff2.label){
  533. uni.showToast({
  534. title:'请勿选择重复',
  535. icon:'none'
  536. })
  537. this.staff2.label='请选择'
  538. // this.staff2.label='平均'
  539. // this.staff2.value=''
  540. return
  541. }else{
  542. // 获取数据
  543. // this.getreception()
  544. // this.getRecordList()
  545. // this.getAwardList()
  546. this.getdata()
  547. }
  548. },
  549. },
  550. }
  551. </script>
  552. <style lang="scss" scoped>
  553. // 对比时间切换
  554. .timepick{
  555. width: 100%;
  556. height: 90rpx;
  557. display: flex;
  558. align-items: center;
  559. background: #FAFAFA;
  560. }
  561. .timepicktime{
  562. width: 260rpx;
  563. height: 50rpx;
  564. border: 1rpx solid #E0E0E0;
  565. margin-left: 30rpx;
  566. display: flex;
  567. background: #FFFFFF;
  568. }
  569. .timepicktime>view:nth-of-type(1){
  570. width: 210rpx;
  571. height: 100%;
  572. line-height: 50rpx;
  573. font-size: 26rpx;
  574. font-weight: 400;
  575. text-align: center;
  576. }
  577. .timepicktime>view:nth-of-type(2){
  578. width: 50rpx;
  579. height: 100%;
  580. border-left: 1px solid #E0E0E0;
  581. }
  582. .timepickpick{
  583. width: 110rpx;
  584. height: 50rpx;
  585. margin-left: 30rpx;
  586. display: flex;
  587. align-items: center;
  588. }
  589. .Underimg{
  590. width: 50rpx;
  591. height:50rpx;
  592. margin-top: -2rpx;
  593. }
  594. </style>