teamMember.vue 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. <template>
  2. <view class="page">
  3. <view class="achievementInfo">
  4. <view class="infoTitle d-flex a-center">业绩信息</view>
  5. <view class="achievementStatistics d-flex">
  6. <view class="achievementStatistics_item d-flex flex-1 flex-column">
  7. <view class="d-flex a-center j-center">签单保费</view>
  8. <view class="d-flex a-center j-center">0</view>
  9. </view>
  10. <view class="achievementStatistics_item d-flex flex-1 flex-column">
  11. <view class="d-flex a-center j-center">出单人力</view>
  12. <view class="d-flex a-center j-center">0</view>
  13. </view>
  14. <view class="achievementStatistics_item d-flex flex-1 flex-column">
  15. <view class="d-flex a-center j-center">平均保费</view>
  16. <view class="d-flex a-center j-center">0</view>
  17. </view>
  18. </view>
  19. <view class="achievementAssessment d-flex">
  20. <view class="achievementAssessment_item d-flex a-center j-center flex-1">
  21. <view>机制考核</view><br />
  22. <view>守维持</view>
  23. </view>
  24. <view class="achievementAssessment_item d-flex flex-1 flex-column">
  25. <view>差距:3000 (标保)</view>
  26. <view>差距: (出单人力)</view>
  27. <view>差距: (继续率)</view>
  28. </view>
  29. </view>
  30. </view>
  31. <!-- <view class="teamInfo">
  32. <view class="teamInfo_item d-flex a-center j-sb" hover-class="teamInfo-list-hover">
  33. <view class="d-flex a-center">团队信息</view>
  34. <view class="icon iconfont icon-youjiantou" @tap="toTeam"></view>
  35. </view>
  36. </view> -->
  37. <view class="personInfo">
  38. <view class="infoTitle d-flex a-center">个人信息</view>
  39. <view class="personInfo_item d-flex a-center j-sb">
  40. <view class="d-flex a-center">姓名</view>
  41. <view>{{info.username}}</view>
  42. </view>
  43. <view class="personInfo_item d-flex a-center j-sb">
  44. <view class="d-flex a-center">会员号</view>
  45. <view>{{info.id}}</view>
  46. </view>
  47. <view class="personInfo_item d-flex a-center j-sb">
  48. <view class="d-flex a-center">手机</view>
  49. <view @tap="callPhone(phone)" style="color: #007AFF;">
  50. {{phone?(phone.substring(0,3)+'****'+phone.substring(7)):''}}
  51. </view>
  52. </view>
  53. <view class="personInfo_item d-flex a-center j-sb">
  54. <view class="d-flex a-center">注册时间</view>
  55. <view>{{createTime}}</view>
  56. </view>
  57. </view>
  58. <view class="team_members">
  59. <view class="team_member d-flex">
  60. <view class="d-flex a-center j-center flex-1">
  61. <view>保险公司</view>
  62. </view>
  63. <view class="d-flex a-center j-center flex-1">
  64. <view>报价笔数</view>
  65. </view>
  66. <view class="d-flex a-center j-center flex-1">
  67. <view>核保笔数</view>
  68. </view>
  69. <view class="d-flex a-center j-center flex-1">
  70. <view>出单笔数</view>
  71. </view>
  72. <view class="d-flex a-center j-center flex-1">
  73. <view>签单保费</view>
  74. </view>
  75. </view>
  76. <view class="dataOver">
  77. <view class="dis j-s a-c team_members-data"
  78. v-for="(item,index) in list" :key="index"
  79. @click="toTeamMember('list',index)">
  80. <view class="dis j-start a-c">{{item.companyName}}</view>
  81. <view class="dis j-c a-c">{{item.bjpolicynum}}</view>
  82. <view class="dis j-c a-c">{{item.policynum}}</view>
  83. <view class="dis j-c a-c">{{item.ordernum}}</view>
  84. <view class="dis j-end a-c">{{item.sumpremium}}</view>
  85. </view>
  86. </view>
  87. </view>
  88. </view>
  89. </template>
  90. <script>
  91. import {
  92. mapState
  93. } from "vuex";
  94. export default {
  95. data() {
  96. return {
  97. info: {},
  98. phone: "",
  99. createTime: "",
  100. list:[],
  101. dateRange: [new Date().getFullYear() + '-' + (new Date().getMonth() + 1) + '-01', new Date()
  102. .getFullYear() + '-' + (new Date().getMonth() + 1) + '-' + new Date().getDate()
  103. ],
  104. }
  105. },
  106. computed: {
  107. ...mapState(['userInfo']),
  108. getHeight() {
  109. let height = uni.getSystemInfoSync().windowHeight - uni.upx2px(770);
  110. return `height: ${height}px;`;
  111. }
  112. },
  113. // 监听导航栏的按钮
  114. onNavigationBarButtonTap(e) {
  115. if (e.index == 0) {
  116. this.navigate({
  117. url: '/pages/index/index'
  118. }, "switchTab", true);
  119. }
  120. },
  121. onLoad() {
  122. const eventChannel = this.getOpenerEventChannel()
  123. // 监听acceptData事件,获取上一页面通过eventChannel传送到当前页面的数据
  124. eventChannel.on('acceptData', async (data) => {
  125. this.info = data.item;
  126. this.dateRange=[...data.date]
  127. this.getCompanyList()
  128. let res = await this.$http.get('/app/customer/' + this.info.id);
  129. if (res.code == '200') {
  130. this.phone = res.data.phone;
  131. this.createTime = res.data.createTime;
  132. }
  133. })
  134. },
  135. methods: {
  136. callPhone(tel) {
  137. uni.makePhoneCall({
  138. phoneNumber: tel,
  139. success: () => {
  140. console.log("成功拨打电话")
  141. }
  142. })
  143. },
  144. async getCompanyList(){
  145. let params={
  146. id:this.info.id,
  147. "enddate": this.dateRange[1],
  148. "startdate": this.dateRange[0]
  149. }
  150. let res = await this.$http.post('/esm/user/queryUserCountForUser' ,params);
  151. if (res.code == '200') {
  152. console.log(res)
  153. // this.phone = res.data.phone;
  154. this.list = res.data;
  155. }
  156. }
  157. // toTeam() {
  158. // this.navigate({
  159. // url: '/pages/tools/team/team?id=' + this.staffInfo.sysUser.id + '&name=' + this.staffInfo
  160. // .sysUser.name
  161. // }, "navigateTo", true)
  162. // }
  163. }
  164. }
  165. </script>
  166. <style>
  167. page {
  168. background: #F1F1F3;
  169. }
  170. .achievementInfo,
  171. .teamInfo,
  172. .personInfo {
  173. margin-top: 20rpx;
  174. background: #FFFFFF;
  175. }
  176. /* 业绩信息Start */
  177. .infoTitle {
  178. height: 80rpx;
  179. padding: 0rpx 20rpx;
  180. border-bottom: 1px solid #EDEDED;
  181. }
  182. .achievementStatistics {
  183. /* height: 140rpx; */
  184. border-bottom: 1px solid #EDEDED;
  185. }
  186. .achievementStatistics_item {
  187. padding: 10rpx 0;
  188. box-sizing: border-box;
  189. }
  190. .achievementStatistics_item>view:nth-of-type(1) {
  191. font-size: 32rpx;
  192. line-height: 60rpx;
  193. color: #4D4D4D;
  194. }
  195. .achievementStatistics_item>view:nth-of-type(2) {
  196. font-size: 32rpx;
  197. color: #D30500;
  198. }
  199. .achievementAssessment {
  200. border-bottom: 1px solid #EDEDED;
  201. }
  202. .achievementAssessment_item {
  203. padding: 15rpx 0;
  204. }
  205. .achievementAssessment .achievementAssessment_item:nth-child(1) {
  206. border-right: 1px solid #F1F1F1;
  207. flex: 2;
  208. }
  209. .achievementAssessment .achievementAssessment_item:nth-child(1)>view:nth-of-type(2) {
  210. display: inline-block;
  211. background-color: #007AFF;
  212. padding: 0rpx 10rpx;
  213. border-radius: 20rpx;
  214. font-size: 20rpx;
  215. text-align: center;
  216. color: #fff;
  217. margin-left: 20rpx;
  218. }
  219. .achievementAssessment .achievementAssessment_item:nth-child(2) {
  220. padding-left: 40rpx;
  221. box-sizing: border-box;
  222. flex: 3;
  223. color: #5F5F5F;
  224. }
  225. /* 业绩信息End */
  226. .teamInfo-list-hover {
  227. background: #f4f4f4;
  228. }
  229. .teamInfo_item>view:first-child {
  230. color: #000;
  231. }
  232. .teamInfo_item>view:last-child {
  233. color: #6A6A6A;
  234. }
  235. .personInfo_item,
  236. .teamInfo_item {
  237. padding: 15upx 30upx;
  238. border-top: 1upx solid #F4F4F4;
  239. border-bottom: 1upx solid #F4F4F4;
  240. }
  241. .personInfo_item>view:first-child {
  242. color: #3C3C3C;
  243. }
  244. .personInfo_item>view:first-child>view {
  245. margin-right: 20upx;
  246. }
  247. .personInfo_item>view:last-child {
  248. color: #6A6A6A;
  249. }
  250. /* 团队成员列表Start */
  251. .team_members {
  252. width: 100%;
  253. height: auto;
  254. background: #FFFFFF;
  255. box-shadow: 0px 4px 10px 0px #DAE3F4;
  256. border-radius: 6px;
  257. margin-top: 10px;
  258. }
  259. .team_members .team_member {
  260. min-height: 70upx;
  261. box-sizing: border-box;
  262. line-height: 70upx;
  263. width: 100%;
  264. height: 34px;
  265. background: #E7ECFD;
  266. border-radius: 6px 6px 0px 0px;
  267. }
  268. /* .team_members .team_member:nth-of-type(1){
  269. background: #CCCCCC;
  270. } */
  271. .team_members .team_member>view {
  272. flex-wrap: nowrap;
  273. }
  274. .team_members-data {
  275. padding: 0 8px;
  276. border-bottom: 1px solid #ddd;
  277. }
  278. .team_members-data>view {
  279. width: 25%;
  280. padding: 4px;
  281. }
  282. /* 团队成员列表End */
  283. </style>