index.vue 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. <template>
  2. <div class="container">
  3. <div class="head-bg"/>
  4. <div class="head-body">
  5. <div class="user-info-body">
  6. <van-image
  7. width="46px"
  8. height="46px"
  9. fit="cover"
  10. round
  11. src="https://fastly.jsdelivr.net/npm/@vant/assets/cat.jpeg"
  12. />
  13. <div class="user-info">
  14. <div class="user-info-name">十里桃花</div>
  15. <div class="user-info-key-body">
  16. <span>xxxxXXXXddddBE</span>
  17. <svg-icon style="width: 24px; height: 24px;" name="copy" />
  18. </div>
  19. </div>
  20. </div>
  21. <van-row justify="end" class="user-info-row">
  22. <van-col span="6" >
  23. <div class="user-bar-icon-box">
  24. <svg-icon class="user-bar-icon" name="address-book" @click="goToaPage('addressManagement')"/>
  25. <span class="user-info-text">地址薄</span>
  26. </div>
  27. </van-col>
  28. <van-col span="6">
  29. <div class="user-bar-icon-box">
  30. <svg-icon class="user-bar-icon" name="bar-url"/>
  31. <span class="user-info-text">下载链接</span>
  32. </div>
  33. </van-col>
  34. <van-col span="6">
  35. <div class="user-bar-icon-box" @click="goToaPage('walletManagement')">
  36. <svg-icon class="user-bar-icon" name="wallet"/>
  37. <span class="user-info-text">钱包管理</span>
  38. </div>
  39. </van-col>
  40. <van-col span="6">
  41. <div class="user-bar-icon-box" @click="goToaPage('personalInformation')">
  42. <svg-icon class="user-bar-icon" name="id-card"/>
  43. <span class="user-info-text">个人资料</span>
  44. </div>
  45. </van-col>
  46. </van-row>
  47. </div>
  48. <!-- 用户索引栏 -->
  49. <van-list class="user-bar-list">
  50. <van-cell
  51. v-for="(item, index) in vanListConfig"
  52. :key="index"
  53. :class="index == vanListConfig.length - 1 ? 'user-bar-list-last' : ''"
  54. :title="item.title"
  55. is-link
  56. @click="evGoPath(item.url)"
  57. >
  58. <template #icon>
  59. <svg-icon class="cell-icon" :name="item.icon" />
  60. </template>
  61. </van-cell>
  62. </van-list>
  63. </div>
  64. </template>
  65. <script setup>
  66. import { useRouter } from 'vue-router'
  67. const router = useRouter();
  68. const vanListConfig = [
  69. { title: '元宝兑换', icon:"ingot", url: 'exchange' },
  70. { title: '竞赛', icon:"competition", url: '/' },
  71. { title: '节点分红', icon:"red-envelope", url: 'nodeDividend' },
  72. { title: '帮助中心', icon:"help", url: '/' },
  73. { title: '关于我们', icon:"me", url: '/' },
  74. { title: '系统设置', icon:"set", url: '/' },
  75. { title: '管理员设置', icon:"admin-set", url: '/' },
  76. ]
  77. const evGoPath = (path)=>{
  78. router.push(path)
  79. }
  80. const goToaPage = (url) => {
  81. router.push(url)
  82. }
  83. </script>
  84. <style lang="less" scoped>
  85. .head-bg {
  86. .fn-head-bg()
  87. }
  88. .head-body {
  89. width: 100%;
  90. display: flex;
  91. flex-direction: column;
  92. .user-info-body {
  93. flex: 1;
  94. display: flex;
  95. padding: 44px 17px 0 17px;
  96. .user-info {
  97. margin-left: 17px;
  98. .user-info-name {
  99. font-size: 1.1rem;
  100. font-weight: 500;
  101. color: @theme-color1;
  102. }
  103. .user-info-key-body{
  104. display: flex;
  105. align-items: center;
  106. font-weight: 400;
  107. font-size: 12px;
  108. color: @font-color2;
  109. span {
  110. margin-top: 4px;
  111. margin-right: 4px;
  112. }
  113. }
  114. }
  115. }
  116. .user-info-row {
  117. margin: 27px 17px 0 17px;
  118. height: 78px;
  119. min-height: 78px;
  120. background: @bg-color1;
  121. box-shadow: 0px 4px 8px -2px rgba(25, 75, 137, 0.25);
  122. border-radius: 17px 17px 17px 17px;
  123. }
  124. .user-bar-icon-box{
  125. height: 100%;
  126. display: flex;
  127. flex-direction: column;
  128. align-items: center;
  129. justify-content: center;
  130. .user-bar-icon{
  131. width: 25px;
  132. height: 25px;
  133. }
  134. .user-info-text{
  135. font-weight: 400;
  136. font-size: 12px;
  137. color: #000000;
  138. margin-top: 5px;
  139. }
  140. }
  141. }
  142. .van-cell{
  143. height: 42px;
  144. background: @bg-color1;
  145. border-bottom: 1px solid @bg-color1;
  146. font-size: 15px ;
  147. &::after{
  148. border-bottom: 1px solid #F2F2F2;
  149. }
  150. }
  151. .user-bar-list-last::after{
  152. border-bottom: 0;
  153. }
  154. .user-bar-list{
  155. margin: 37px 17px 0 17px;
  156. border-radius: 12px 12px 12px 12px;
  157. overflow: hidden;
  158. .cell-icon{
  159. width: 21px;
  160. height: 21px;
  161. margin-right: 4px;
  162. }
  163. }
  164. </style>