profile.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541
  1. <template>
  2. <view>
  3. <image src="../../static/bg.png" mode="" class="bg"></image>
  4. <view class="top u-flex u-row-between">
  5. <view class="u-flex leftBox">
  6. <image :src="info.headimg" mode="" class="avatar"></image>
  7. <view class="">
  8. <view class="name" @click="toLogin">
  9. {{is_login?info.nickname:'点击登录'}} <image src="../../static/profile/8@2x.png" mode="" v-show="info.vip_level==0"></image>
  10. </view>
  11. <view class="info" >
  12. 资料完成度{{info.progress||0}}% <text class="wanshan" v-show="info.progress!=100" @click="toPage">去完善></text>
  13. </view>
  14. <template>
  15. <u-line-progress :percentage="info.progress" :showText="false" activeColor="#A890FE" height="8"></u-line-progress>
  16. </template>
  17. </view>
  18. </view>
  19. <image src="../../static/profile/7@2x.png" mode="" class="set" @click="toset"></image>
  20. </view>
  21. <view class="user u-flex u-row-between">
  22. <view class="u-flex-col u-col-center userItem" @click="tofensi">
  23. <text class="num">{{info.fans}}</text>
  24. <text class="itemName">粉丝</text>
  25. </view>
  26. <view class="u-flex-col u-col-center userItem" @click="toguanzhu">
  27. <text class="num">{{info.follow}}</text>
  28. <text class="itemName">关注</text>
  29. </view>
  30. <view class="u-flex-col u-col-center userItem" @click="todianzan">
  31. <text class="num">{{info.fabulous}}</text>
  32. <text class="itemName">点赞</text>
  33. </view>
  34. <view class="u-flex-col u-col-center userItem" @click="toxingqu">
  35. <text class="num">{{info.interested}}</text>
  36. <text class="itemName">感兴趣</text>
  37. </view>
  38. </view>
  39. <view class="center u-flex u-row-around">
  40. <view class="u-flex-col u-col-center" @click="todongtai" v-if="isShow!=0">
  41. <image src="../../static/profile/2@2x.png" mode=""></image>
  42. <text>我的动态</text>
  43. </view>
  44. <view class="u-flex-col u-col-center" @click="toliaotian">
  45. <image src="../../static/profile/3@2x.png" mode=""></image>
  46. <text>聊天记录</text>
  47. </view>
  48. <view class="u-flex-col u-col-center" @click="toactivity">
  49. <image src="../../static/profile/4@2x.png" mode=""></image>
  50. <text>报名活动</text>
  51. </view>
  52. <view class="u-flex-col u-col-center" @click="toreport">
  53. <image src="../../static/profile/1@2x.png" mode=""></image>
  54. <text>举报记录</text>
  55. </view>
  56. </view>
  57. <view class="bottom">
  58. <view class="u-flex u-row-between" @click="tosuqiu">
  59. <view class="item u-flex u-col-center">
  60. <image src="../../static/profile/zeou.png" mode=""></image>
  61. <text>择偶条件</text>
  62. <image src="../../static/profile/tan.png" mode="" style="width: 20rpx;height: 20rpx;vertical-align: middle;margin: 0 4rpx;"></image>
  63. <text style="font-size: 16rpx;color: #777777;">此项内容为智能推荐功能重要依据,请认真填写</text>
  64. </view>
  65. <u-icon name="arrow-right"></u-icon>
  66. </view>
  67. <view class="u-flex u-row-between" style="margin-top: 54rpx;" @click="tostatus">
  68. <view class="item">
  69. <image src="../../static/profile/5@2x.png" mode=""></image>
  70. <text>个人状态</text>
  71. </view>
  72. <u-icon name="arrow-right"></u-icon>
  73. </view>
  74. <view class="u-flex u-row-between" style="margin-top: 54rpx;" @click="toPage">
  75. <view class="item">
  76. <image src="../../static/profile/6@2x.png" mode=""></image>
  77. <text>个人主页</text>
  78. </view>
  79. <u-icon name="arrow-right"></u-icon>
  80. </view>
  81. <view class="u-flex u-row-between" style="margin-top: 54rpx;" @click="tozixun">
  82. <view class="item">
  83. <image src="../../static/profile/qinggai@2x.png" mode=""></image>
  84. <text>情感咨询记录</text>
  85. </view>
  86. <u-icon name="arrow-right"></u-icon>
  87. </view>
  88. <view class="u-flex u-row-between" style="margin-top: 54rpx;" @click="tofankui">
  89. <view class="item">
  90. <image src="../../static/profile/contact.png" mode=""></image>
  91. <text>意见反馈</text>
  92. </view>
  93. <u-icon name="arrow-right"></u-icon>
  94. </view>
  95. <view class="u-flex u-row-between" style="margin-top: 54rpx;" @click="tofenxiang">
  96. <view class="item">
  97. <image src="../../static/profile/contact.png" mode=""></image>
  98. <text>推荐分享</text>
  99. </view>
  100. <u-icon name="arrow-right"></u-icon>
  101. </view>
  102. <!-- <view class="u-flex u-row-between" style="margin-top: 54rpx;" @click="contact">
  103. <view class="item">
  104. <image src="../../static/profile/lianxi@2x.png" mode=""></image>
  105. <text>联系我们</text>
  106. </view>
  107. <u-icon name="arrow-right"></u-icon>
  108. </view> -->
  109. </view>
  110. <Showtoast @canceltoast='canceltoast' :showtoast='showtoast' />
  111. </view>
  112. </template>
  113. <script>
  114. import Showtoast from'../../components/Showtoast.vue'
  115. export default {
  116. components:{
  117. Showtoast
  118. },
  119. data() {
  120. return {
  121. is_login:false,
  122. showtoast:false,
  123. isShow:0,
  124. info:{},
  125. is_info:0,
  126. }
  127. },
  128. onPullDownRefresh() {
  129. this.getInfo()
  130. setTimeout(function () {
  131. uni.stopPullDownRefresh();
  132. }, 1000);
  133. },
  134. onShow() {
  135. if (!uni.getStorageSync('token')) {
  136. this.is_login=false
  137. }else{
  138. this.is_login=true
  139. this.getInfo()
  140. }
  141. if(uni.getStorageSync('is_info')){
  142. this.is_info=uni.getStorageSync('is_info')
  143. }
  144. this.isShow=getApp().globalData.isShow
  145. },
  146. methods: {
  147. tosuqiu(){
  148. if(!this.is_login){
  149. this.toLogin()
  150. return
  151. }
  152. if (this.is_info != 2) {
  153. uni.navigateTo({
  154. url: '/pages/index/base'
  155. })
  156. return
  157. }
  158. uni.navigateTo({
  159. url:'/pages/profile/suqiu'
  160. })
  161. },
  162. tofenxiang(){
  163. if(!this.is_login){
  164. this.toLogin()
  165. return
  166. }
  167. if (this.is_info != 2) {
  168. uni.navigateTo({
  169. url: '/pages/index/base'
  170. })
  171. return
  172. }
  173. uni.navigateTo({
  174. url:'/pages/index/recommend'
  175. })
  176. },
  177. toLogin(){
  178. if (!uni.getStorageSync('token')) {
  179. uni.navigateTo({
  180. url:'/pages/profile/login'
  181. })
  182. }
  183. },
  184. canceltoast(){
  185. this.showtoast=false
  186. },
  187. tofankui(){
  188. if(!this.is_login){
  189. this.toLogin()
  190. return
  191. }
  192. if (this.is_info != 2) {
  193. uni.navigateTo({
  194. url: '/pages/index/base'
  195. })
  196. return
  197. }
  198. uni.navigateTo({
  199. url:'./fankuiList'
  200. })
  201. },
  202. tozixun(){
  203. if(!this.is_login){
  204. this.toLogin()
  205. return
  206. }
  207. if (this.is_info != 2) {
  208. uni.navigateTo({
  209. url: '/pages/index/base'
  210. })
  211. return
  212. }
  213. uni.navigateTo({
  214. url:'./zixunList'
  215. })
  216. },
  217. contact(){
  218. if(!this.is_login){
  219. this.toLogin()
  220. return
  221. }
  222. if (this.is_info != 2) {
  223. uni.navigateTo({
  224. url: '/pages/index/base'
  225. })
  226. return
  227. }
  228. uni.navigateTo({
  229. url:'/pages/index/contactour'
  230. })
  231. },
  232. toliaotian(){
  233. if(!this.is_login){
  234. this.toLogin()
  235. return
  236. }
  237. if (this.is_info != 2) {
  238. uni.navigateTo({
  239. url: '/pages/index/base'
  240. })
  241. return
  242. }
  243. if(this.info.vip_level==0){
  244. this.showtoast=true
  245. return
  246. }
  247. if(this.info.vip_level==2){
  248. this.$u.toast('经用户反馈,您账户存在违规行为,暂不支持使用该功能')
  249. return
  250. }
  251. if(this.info.vip_level==3){
  252. this.$u.toast('您的账户已注销,暂不支持使用该功能')
  253. return
  254. }
  255. uni.navigateTo({
  256. url:'/pages/index/message'
  257. })
  258. },
  259. getInfo(){
  260. uni.$u.http.post('/api/user/userinfo').then(res => {
  261. if(res.code==1){
  262. this.info=res.data
  263. uni.setStorageSync('userId',res.data.id)
  264. uni.setStorageSync('userInfo',JSON.stringify(res.data))
  265. }
  266. })
  267. },
  268. toPage(){
  269. if(!this.is_login){
  270. this.toLogin()
  271. return
  272. }
  273. if (this.is_info != 2) {
  274. uni.navigateTo({
  275. url: '/pages/index/base'
  276. })
  277. return
  278. }
  279. uni.navigateTo({
  280. url:'./myPage'
  281. })
  282. },
  283. tostatus(){
  284. if(!this.is_login){
  285. this.toLogin()
  286. return
  287. }
  288. if (this.is_info != 2) {
  289. uni.navigateTo({
  290. url: '/pages/index/base'
  291. })
  292. return
  293. }
  294. uni.navigateTo({
  295. url:'./personStatus'
  296. })
  297. },
  298. toreport(){
  299. if(!this.is_login){
  300. this.toLogin()
  301. return
  302. }
  303. if (this.is_info != 2) {
  304. uni.navigateTo({
  305. url: '/pages/index/base'
  306. })
  307. return
  308. }
  309. uni.navigateTo({
  310. url:'./reportList'
  311. })
  312. },
  313. toactivity(){
  314. if(!this.is_login){
  315. this.toLogin()
  316. return
  317. }
  318. if (this.is_info != 2) {
  319. uni.navigateTo({
  320. url: '/pages/index/base'
  321. })
  322. return
  323. }
  324. // if(this.info.vip_level==0){
  325. // this.showtoast=true
  326. // return
  327. // }
  328. if(this.info.vip_level==2){
  329. this.$u.toast('经用户反馈,您账户存在违规行为,暂不支持使用该功能')
  330. return
  331. }
  332. if(this.info.vip_level==3){
  333. this.$u.toast('您的账户已注销,暂不支持使用该功能')
  334. return
  335. }
  336. uni.navigateTo({
  337. url:'../activity/activityLIst'
  338. })
  339. },
  340. todongtai(){
  341. if(!this.is_login){
  342. this.toLogin()
  343. return
  344. }
  345. if (this.is_info != 2) {
  346. uni.navigateTo({
  347. url: '/pages/index/base'
  348. })
  349. return
  350. }
  351. if(this.info.vip_level==0){
  352. this.$u.toast('您暂未认证')
  353. return
  354. }
  355. if(this.info.vip_level==2){
  356. this.$u.toast('经用户反馈,您账户存在违规行为,暂不支持使用该功能')
  357. return
  358. }
  359. if(this.info.vip_level==3){
  360. this.$u.toast('您的账户已注销,暂不支持使用该功能')
  361. return
  362. }
  363. uni.navigateTo({
  364. url:'./mydongtai'
  365. })
  366. },
  367. toxingqu(){
  368. if(!this.is_login){
  369. this.toLogin()
  370. return
  371. }
  372. if (this.is_info != 2) {
  373. uni.navigateTo({
  374. url: '/pages/index/base'
  375. })
  376. return
  377. }
  378. uni.navigateTo({
  379. url:'./ganxingqu'
  380. })
  381. },
  382. todianzan(){
  383. if(!this.is_login){
  384. this.toLogin()
  385. return
  386. }
  387. if (this.is_info != 2) {
  388. uni.navigateTo({
  389. url: '/pages/index/base'
  390. })
  391. return
  392. }
  393. uni.navigateTo({
  394. url:'./dianzan'
  395. })
  396. },
  397. tofensi(){
  398. if(!this.is_login){
  399. this.toLogin()
  400. return
  401. }
  402. if (this.is_info != 2) {
  403. uni.navigateTo({
  404. url: '/pages/index/base'
  405. })
  406. return
  407. }
  408. uni.navigateTo({
  409. url:'./fensi'
  410. })
  411. },
  412. toguanzhu(){
  413. if(!this.is_login){
  414. this.toLogin()
  415. return
  416. }
  417. if (this.is_info != 2) {
  418. uni.navigateTo({
  419. url: '/pages/index/base'
  420. })
  421. return
  422. }
  423. uni.navigateTo({
  424. url:'./guanzhu'
  425. })
  426. },
  427. toset(){
  428. if(!this.is_login){
  429. this.toLogin()
  430. return
  431. }
  432. // if (this.is_info != 2) {
  433. // uni.navigateTo({
  434. // url: '/pages/index/base'
  435. // })
  436. // return
  437. // }
  438. uni.navigateTo({
  439. url:'./set'
  440. })
  441. }
  442. }
  443. }
  444. </script>
  445. <style lang="scss">
  446. // #ifdef H5
  447. page{
  448. background: url(/static/bg.png) no-repeat;
  449. }
  450. //#endif
  451. .bottom{
  452. box-sizing: border-box;
  453. padding: 36rpx 20rpx;
  454. margin: 0 auto;
  455. width: 690rpx;
  456. background: #FFFFFF;
  457. border-radius: 28rpx;
  458. font-size: 28rpx;
  459. color: #222;
  460. .item{
  461. image{
  462. width: 44rpx;
  463. height: 44rpx;
  464. vertical-align: middle;
  465. margin-right: 20rpx;
  466. }
  467. }
  468. }
  469. .center{
  470. font-size: 24rpx;
  471. margin: 0 auto 24rpx;
  472. width: 690rpx;
  473. height: 228rpx;
  474. background: #FFFFFF;
  475. border-radius: 28rpx;
  476. image{
  477. width: 76rpx;
  478. height: 76rpx;
  479. margin-bottom: 16rpx;
  480. }
  481. }
  482. .user{
  483. margin: 52rpx 0 40rpx;
  484. padding: 0 30rpx;
  485. }
  486. .userItem{
  487. color: #222222;
  488. font-size: 24rpx;
  489. .num{
  490. font-size: 52rpx;
  491. font-weight: 600;
  492. margin-bottom: 10rpx;
  493. }
  494. }
  495. page{
  496. }
  497. .top{
  498. padding: 196rpx 30rpx 0;
  499. }
  500. .set{
  501. width: 40rpx;
  502. height: 40rpx;
  503. }
  504. .leftBox{
  505. .avatar{
  506. margin-right: 20rpx;
  507. width: 132rpx;
  508. height: 132rpx;
  509. border-radius: 50%;
  510. border: 4rpx solid #FFFFFF;
  511. }
  512. .name{
  513. font-size: 32rpx;
  514. color: #222222;
  515. image{
  516. width: 96rpx;
  517. height: 32rpx;
  518. margin-left: 12rpx;
  519. vertical-align: middle;
  520. }
  521. }
  522. .info{
  523. margin: 14rpx 0 4rpx;
  524. font-size: 16rpx;
  525. color: #222222;
  526. .wanshan{
  527. color: #9887FF;
  528. background: linear-gradient(270deg, #A890FE 0%, #FFAEAE 100%);
  529. -webkit-background-clip: text;
  530. -webkit-text-fill-color: transparent;
  531. }
  532. }
  533. }
  534. </style>