teamMember.vue 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316
  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.getCompanyList()
  127. let res = await this.$http.get('/app/customer/' + this.info.id);
  128. if (res.code == '200') {
  129. this.phone = res.data.phone;
  130. this.createTime = res.data.createTime;
  131. }
  132. })
  133. },
  134. methods: {
  135. callPhone(tel) {
  136. uni.makePhoneCall({
  137. phoneNumber: tel,
  138. success: () => {
  139. console.log("成功拨打电话")
  140. }
  141. })
  142. },
  143. async getCompanyList(){
  144. let params={
  145. id:this.info.id,
  146. "enddate": this.dateRange[1],
  147. "startdate": this.dateRange[0]
  148. }
  149. let res = await this.$http.post('/esm/user/queryUserCountForUser' ,params);
  150. if (res.code == '200') {
  151. console.log(res)
  152. // this.phone = res.data.phone;
  153. this.list = res.data;
  154. }
  155. }
  156. // toTeam() {
  157. // this.navigate({
  158. // url: '/pages/tools/team/team?id=' + this.staffInfo.sysUser.id + '&name=' + this.staffInfo
  159. // .sysUser.name
  160. // }, "navigateTo", true)
  161. // }
  162. }
  163. }
  164. </script>
  165. <style>
  166. page {
  167. background: #F1F1F3;
  168. }
  169. .achievementInfo,
  170. .teamInfo,
  171. .personInfo {
  172. margin-top: 20rpx;
  173. background: #FFFFFF;
  174. }
  175. /* 业绩信息Start */
  176. .infoTitle {
  177. height: 80rpx;
  178. padding: 0rpx 20rpx;
  179. border-bottom: 1px solid #EDEDED;
  180. }
  181. .achievementStatistics {
  182. /* height: 140rpx; */
  183. border-bottom: 1px solid #EDEDED;
  184. }
  185. .achievementStatistics_item {
  186. padding: 10rpx 0;
  187. box-sizing: border-box;
  188. }
  189. .achievementStatistics_item>view:nth-of-type(1) {
  190. font-size: 32rpx;
  191. line-height: 60rpx;
  192. color: #4D4D4D;
  193. }
  194. .achievementStatistics_item>view:nth-of-type(2) {
  195. font-size: 32rpx;
  196. color: #D30500;
  197. }
  198. .achievementAssessment {
  199. border-bottom: 1px solid #EDEDED;
  200. }
  201. .achievementAssessment_item {
  202. padding: 15rpx 0;
  203. }
  204. .achievementAssessment .achievementAssessment_item:nth-child(1) {
  205. border-right: 1px solid #F1F1F1;
  206. flex: 2;
  207. }
  208. .achievementAssessment .achievementAssessment_item:nth-child(1)>view:nth-of-type(2) {
  209. display: inline-block;
  210. background-color: #007AFF;
  211. padding: 0rpx 10rpx;
  212. border-radius: 20rpx;
  213. font-size: 20rpx;
  214. text-align: center;
  215. color: #fff;
  216. margin-left: 20rpx;
  217. }
  218. .achievementAssessment .achievementAssessment_item:nth-child(2) {
  219. padding-left: 40rpx;
  220. box-sizing: border-box;
  221. flex: 3;
  222. color: #5F5F5F;
  223. }
  224. /* 业绩信息End */
  225. .teamInfo-list-hover {
  226. background: #f4f4f4;
  227. }
  228. .teamInfo_item>view:first-child {
  229. color: #000;
  230. }
  231. .teamInfo_item>view:last-child {
  232. color: #6A6A6A;
  233. }
  234. .personInfo_item,
  235. .teamInfo_item {
  236. padding: 15upx 30upx;
  237. border-top: 1upx solid #F4F4F4;
  238. border-bottom: 1upx solid #F4F4F4;
  239. }
  240. .personInfo_item>view:first-child {
  241. color: #3C3C3C;
  242. }
  243. .personInfo_item>view:first-child>view {
  244. margin-right: 20upx;
  245. }
  246. .personInfo_item>view:last-child {
  247. color: #6A6A6A;
  248. }
  249. /* 团队成员列表Start */
  250. .team_members {
  251. width: 100%;
  252. height: auto;
  253. background: #FFFFFF;
  254. box-shadow: 0px 4px 10px 0px #DAE3F4;
  255. border-radius: 6px;
  256. margin-top: 10px;
  257. }
  258. .team_members .team_member {
  259. min-height: 70upx;
  260. box-sizing: border-box;
  261. line-height: 70upx;
  262. width: 100%;
  263. height: 34px;
  264. background: #E7ECFD;
  265. border-radius: 6px 6px 0px 0px;
  266. }
  267. /* .team_members .team_member:nth-of-type(1){
  268. background: #CCCCCC;
  269. } */
  270. .team_members .team_member>view {
  271. flex-wrap: nowrap;
  272. }
  273. .team_members-data {
  274. padding: 0 8px;
  275. border-bottom: 1px solid #ddd;
  276. }
  277. .team_members-data>view {
  278. width: 25%;
  279. padding: 4px;
  280. }
  281. /* 团队成员列表End */
  282. </style>