You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

249 lines
29 KiB

3 months ago
  1. <template>
  2. <view :data-theme="theme">
  3. <view class="CommissionRank">
  4. <view class="header">
  5. <view class="rank" v-if="position">您目前的排名<text class="num">{{position}}</text></view>
  6. <view class="rank" v-else>您目前暂无排名</view>
  7. </view>
  8. <view class="wrapper">
  9. <view class="nav acea-row row-around">
  10. <view class="item" :class="active == index ? 'font_color' : ''" v-for="(item,index) in navList" :key="index"
  11. @click="switchTap(index)">
  12. {{ item }}
  13. </view>
  14. </view>
  15. <view class="list">
  16. <view class="item acea-row row-between-wrapper" v-for="(item,index) in rankList" :key="index">
  17. <view class="num" v-if="index <= 2">
  18. <image :src="urlDomain+'crmebimage/perset/staticImg/medal0'+(index+1)+'.png'"></image>
  19. </view>
  20. <view class="num" v-else>
  21. {{index+1}}
  22. </view>
  23. <view class="picTxt acea-row row-between-wrapper">
  24. <view class="pictrue">
  25. <image :src="item.avatar"></image>
  26. </view>
  27. <view class="text line1">{{item.nickname}}</view>
  28. </view>
  29. <view class="people font_color">{{item.brokeragePrice}}</view>
  30. </view>
  31. </view>
  32. <view class='noCommodity' v-if="rankList.length == 0 && isShow">
  33. <emptyPage title="暂无排行~"></emptyPage>
  34. </view>
  35. </view>
  36. </view>
  37. </view>
  38. </template>
  39. <script>
  40. import {
  41. getBrokerageRank,
  42. brokerageRankNumber
  43. } from '@/api/user.js';
  44. import {toLogin} from '@/libs/login.js';
  45. import emptyPage from '@/components/emptyPage.vue'
  46. import {mapGetters} from "vuex";
  47. import {setThemeColor} from '@/utils/setTheme.js'
  48. const app = getApp();
  49. export default {
  50. components: {
  51. emptyPage
  52. },
  53. data() {
  54. return {
  55. urlDomain: this.$Cache.get("imgHost"),
  56. navList: ["周排行", "月排行"],
  57. active: 0,
  58. rankList: [],
  59. page: 1,
  60. limit: 20,
  61. loadend: false,
  62. loading: false,
  63. loadTitle: '加载更多',
  64. type: 'week',
  65. position: 0,
  66. isShow: false,
  67. isAuto: false, //没有授权的不会自动授权
  68. isShowAuth: false, //是否隐藏授权
  69. theme:app.globalData.theme,
  70. bgColor:'#e93323'
  71. };
  72. },
  73. computed: mapGetters(['isLogin']),
  74. watch:{
  75. isLogin:{
  76. handler:function(newV,oldV){
  77. if(newV){
  78. this.getBrokerageRankList();
  79. this.getBrokerageRankNumber(this.type);
  80. }
  81. },
  82. deep:true
  83. }
  84. },
  85. onLoad() {
  86. if (this.isLogin) {
  87. this.getBrokerageRankList();
  88. this.getBrokerageRankNumber(this.type);
  89. } else {
  90. toLogin();
  91. }
  92. let that = this;
  93. that.bgColor = setThemeColor();
  94. uni.setNavigationBarColor({
  95. frontColor: '#ffffff',
  96. backgroundColor:that.bgColor,
  97. });
  98. },
  99. methods: {
  100. onLoadFun: function() {
  101. this.getBrokerageRankList();
  102. this.getBrokerageRankNumber(this.type);
  103. },
  104. // 授权关闭
  105. authColse: function(e) {
  106. this.isShowAuth = e
  107. },
  108. switchTap: function(index) {
  109. this.active = index;
  110. this.type = index ? 'month' : 'week';
  111. this.page = 1;
  112. this.loadend = false;
  113. this.$set(this, 'rankList', []);
  114. this.getBrokerageRankList();
  115. this.getBrokerageRankNumber(this.type);
  116. },
  117. getBrokerageRankNumber(type) {
  118. brokerageRankNumber({
  119. type: type
  120. }).then(res => {
  121. this.position = res.data;
  122. })
  123. },
  124. getBrokerageRankList: function() {
  125. if (this.loadend) return;
  126. if (this.loading) return;
  127. this.loading = true;
  128. this.loadTitle = '';
  129. getBrokerageRank({
  130. page: this.page,
  131. limit: this.limit,
  132. type: this.type
  133. }).then(res => {
  134. let list = res.data || [];
  135. let loadend = list.length <= this.limit;
  136. this.rankList.push.apply(this.rankList, list);
  137. this.loading = false;
  138. this.loadend = loadend;
  139. this.loadTitle = loadend ? '我也是有底线的~' : '加载更多';
  140. this.$set(this, 'rankList', this.rankList);
  141. this.isShow = true;
  142. //this.position = res.data.position;
  143. }).catch(err => {
  144. this.loading = false;
  145. this.loadTitle = '加载更多';
  146. })
  147. }
  148. },
  149. onReachBottom: function() {
  150. this.getBrokerageRankList();
  151. }
  152. }
  153. </script>
  154. <style scoped lang="scss">
  155. .CommissionRank .header {
  156. background: url("
  157. @include main_bg_color(theme);
  158. width: 100%;
  159. height: 344rpx;
  160. background-size: 100% 100%;
  161. }
  162. .CommissionRank .header .rank {
  163. font-size: 33rpx;
  164. color: #fff;
  165. position: absolute;
  166. top: 160rpx;
  167. left: 48rpx;
  168. }
  169. .CommissionRank .header .rank .num {
  170. font-size: 51rpx;
  171. font-weight: bold;
  172. margin: 0 10rpx;
  173. }
  174. .CommissionRank .wrapper {
  175. width: 710rpx;
  176. background-color: #fff;
  177. border-radius: 14rpx;
  178. margin: -76rpx auto 0 auto;
  179. }
  180. .CommissionRank .wrapper .nav {
  181. height: 99rpx;
  182. border-bottom: 2.5rpx solid #f3f3f3;
  183. font-size: 30rpx;
  184. font-weight: bold;
  185. color: #999;
  186. line-height: 99rpx;
  187. }
  188. .CommissionRank .wrapper .nav .item.font_color {
  189. @include main_color(theme);
  190. @include tab_border_bottom(theme);
  191. margin-top: -2rpx;
  192. }
  193. .CommissionRank .wrapper .list {
  194. padding: 0 30rpx;
  195. }
  196. .CommissionRank .wrapper .list .item {
  197. border-bottom: 1px solid #f3f3f3;
  198. height: 101rpx;
  199. font-size: 28rpx;
  200. }
  201. .CommissionRank .wrapper .list .item .num {
  202. color: #666;
  203. width: 70rpx;
  204. }
  205. .CommissionRank .wrapper .list .item .num image {
  206. width: 34rpx;
  207. height: 40rpx;
  208. display: block;
  209. }
  210. .CommissionRank .wrapper .list .item .picTxt {
  211. width: 350rpx;
  212. }
  213. .CommissionRank .wrapper .list .item .picTxt .pictrue {
  214. width: 68rpx;
  215. height: 68rpx;
  216. }
  217. .CommissionRank .wrapper .list .item .picTxt .pictrue image {
  218. width: 100%;
  219. height: 100%;
  220. display: block;
  221. border-radius: 50%;
  222. }
  223. .CommissionRank .wrapper .list .item .picTxt .text {
  224. width: 262rpx;
  225. color: #333;
  226. }
  227. .CommissionRank .wrapper .list .item .people {
  228. width: 175rpx;
  229. text-align: right;
  230. }
  231. .font_color{
  232. @include price_color(theme);
  233. }
  234. </style>