index.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497
  1. <template>
  2. <view>
  3. <view class="mine-container">
  4. <view class="mine-header" :style="{ paddingTop: globalData.navBarHeight + 'px' }">
  5. <view class="flex_c_s mine-header-info">
  6. <img :show-loading="true" :src="userInfo.avatar" class="header-avatar" />
  7. <view class="header-info flex_c_s">
  8. <view class="info-top ">
  9. <view class="user-info flex_c_c">
  10. <view class="info-name" @click="onLogin">{{
  11. userInfo.nickName
  12. }}</view>
  13. <view class="info-tag flex_c_c" v-if="userType">{{ userType === 1 ? '用户' : '志愿者' }}
  14. </view>
  15. </view>
  16. <view class="info-real-name flex_c_c">
  17. <view class="real-name">{{ authentication ? '已实名' : '暂未实名' }}</view>
  18. <img src="/static/serverImg/mine/suce.png" alt="" style="width: 24rpx; height: 24rpx;"
  19. v-if="authentication">
  20. <img src="/static/serverImg/mine/left.png" alt="" style="width: 24rpx; height: 24rpx;" v-else>
  21. </view>
  22. </view>
  23. <img src="/static/serverImg/mine/setting.png" alt="" style="width: 60rpx; height: 60rpx;"
  24. @click="handLsetTing">
  25. </view>
  26. </view>
  27. <view class="applause-rate flex_c_c" v-if="userType === 2">
  28. <view class="rate-lable">好评率:</view>
  29. <view class="rate-value">{{ rateValue }}星</view>
  30. <view v-for="(item, index) in new Array(5)" :key="item">
  31. <img src="/static/serverImg/mine/flower.png" v-if="rateValue <= index" alt="" class="flower" />
  32. <img src="/static/serverImg/mine/flower_active.png" v-else alt="" class="flower" />
  33. </view>
  34. </view>
  35. <view class="order-main flex_c_s" v-if="userType === 1">
  36. <view v-for="item in orderMainList" :key="item.iconName" class="order-item flex_c_c_f">
  37. <view class="order-num">
  38. {{ data[item.key] }}
  39. </view>
  40. <view>
  41. {{ item.name }}
  42. </view>
  43. </view>
  44. </view>
  45. </view>
  46. <view class="price-main ">
  47. <view class="price-card flex_c_c">
  48. <view v-for="item in priceList" :key="item.key" class="price-item flex_c_c" @click="onClick(item)">
  49. <view class="flex_c_c_f">
  50. <view class="price-balance">{{ data[item.key] }}</view>
  51. <view class="price-name flex_c_c">
  52. <view class="price-name-text">{{ item.name }}</view>
  53. </view>
  54. </view>
  55. <img src="/static/serverImg/mine/rigth.png" alt="" class="price-rigth"
  56. style="width: 24rpx;height: 24rpx;" />
  57. </view>
  58. </view>
  59. </view>
  60. <view class="list-main">
  61. <view class="list-box">
  62. <view v-for="item in list" :key="item.key" class="list-item flex_c_s" @click="onClick(item)">
  63. <view class="list-left flex_c_l">
  64. <img :src="item.img" alt="" style="width: 56rpx;height: 56rpx;">
  65. <view class="list-name">{{ item.name }}</view>
  66. </view>
  67. <view class="list-rigth flex_c_r">
  68. <view class="list-text">{{ item.text }}</view>
  69. <up-icon name="arrow-right"></up-icon>
  70. </view>
  71. </view>
  72. </view>
  73. </view>
  74. </view>
  75. <CustomTabBar page="mine" />
  76. <up-popup :show="show" mode="center" @close="close" @open="open">
  77. <view v-if="show">
  78. <QRCode scene="123" page="/pages/index/index" width="430" auto-color line-color="#000000" is-hyaline>
  79. </QRCode>
  80. </view>
  81. </up-popup>
  82. </view>
  83. </template>
  84. <script setup>
  85. import { onMounted, ref, computed } from 'vue'
  86. import { onLoad, onShow } from '@dcloudio/uni-app'
  87. import store from '@/store'
  88. import { getVolunteerAccountInfo, volunteerOrderStatistics, getAccountInfo } from '@/api/mine'
  89. import CustomTabBar from '@/components/CustomTabBar/index.vue'
  90. import QRCode from '@/components/QRCode/index.vue'
  91. import { getNavBarHeight } from '@/utils/index.js'
  92. import { getToken } from '@/utils/auth'
  93. import { showConfirm } from '@/utils/common'
  94. import {
  95. userOrWorker
  96. } from '@/api/login';
  97. const show = ref(false); // 是否显示二维码
  98. const userInfo = ref({
  99. avatar: '/static/serverImg/mine/user.png',
  100. nickName: '登陆/注册',
  101. })
  102. const authentication = ref(false);//是否认证
  103. const globalData = ref({
  104. statusBarHeight: 47,
  105. navBarHeight: 91,
  106. })
  107. const data = ref({
  108. balance: 0.0,
  109. reservationCount: 0,
  110. doingCount: 0,
  111. finishedCount: 0,
  112. cancelCount: 0,
  113. orderCount: 0,
  114. orderFrozenBalance: 0,
  115. browsing: 0,
  116. collect: 0,
  117. comment: 0
  118. })
  119. const rateValue = ref(5)
  120. const orderMainList = [
  121. {
  122. name: '浏览记录',
  123. key: 'browsing',
  124. },
  125. {
  126. name: '收藏',
  127. key: 'collect',
  128. },
  129. {
  130. name: '评论',
  131. key: 'comment',
  132. },
  133. ]
  134. const priceUser = [
  135. {
  136. name: '我的钱包(元)',
  137. key: 'balance',
  138. decimals: 2,
  139. balance: 'orderFrozenBalance',
  140. page: '/pages_mine/pages/wallet/index',
  141. },
  142. {
  143. name: '我的积分',
  144. key: 'orderCount',
  145. decimals: 0,
  146. page: '/pages_mine/pages/integral/index',
  147. },
  148. ]
  149. const priceAdmin = [
  150. {
  151. name: '我的余额',
  152. key: 'balance',
  153. decimals: 2,
  154. balance: 'orderFrozenBalance',
  155. page: '/pages_mine/pages/wallet/index',
  156. },
  157. {
  158. name: '预约单数',
  159. key: 'orderCount',
  160. decimals: 0,
  161. switchPage: '/pages/classify',
  162. value: 1,
  163. },
  164. ]
  165. const priceList = computed(() => {
  166. if (userType === 1) {
  167. return priceUser
  168. }
  169. return priceAdmin
  170. })
  171. const userType = uni.getStorageSync('userType') //读取本地存储
  172. const adminList = [
  173. {
  174. name: '实名认证',
  175. img: '/static/serverImg/mine/adress.png',
  176. key: 'map',
  177. text: '前往实名认证',
  178. operate: () => {
  179. hanldeAuthentication()
  180. },
  181. },
  182. {
  183. name: '我的地址',
  184. img: '/static/serverImg/mine/adress.png',
  185. key: 'map',
  186. text: '',
  187. page: '/pages_mine/pages/selectAddress/index',
  188. },
  189. {
  190. name: '帮助与客服',
  191. img: '/static/serverImg/mine/kf.png',
  192. key: 'map',
  193. text: '',
  194. operate: () => {
  195. uni.navigateTo({
  196. url: `/pages_orderuser/pages/talk/pages/index/index?customerService=true&conversationType=3`
  197. })
  198. },
  199. },
  200. {
  201. name: '我的评论',
  202. key: 'share',
  203. img: '/static/serverImg/mine/yq.png',
  204. text: '查看所有订单',
  205. switchPage: '/pages/classify',
  206. value: 3,
  207. },
  208. // {
  209. // name: '修改个人信息',
  210. // img: '/static/serverImg/mine/xg.png',
  211. // key: 'map',
  212. // text: '去认证资质',
  213. // operate: () => {
  214. // handLsetTing();
  215. // },
  216. // },
  217. {
  218. name: '邀请二维码',
  219. key: 'share',
  220. img: '/static/img/Iconly@1x.png',
  221. text: '推荐好友得好礼',
  222. operate: () => {
  223. show.value = true
  224. },
  225. },
  226. {
  227. name: '志愿者',
  228. img: '/static/serverImg/mine/sf.png',
  229. key: 'map',
  230. text: '切换为用户',
  231. operate: () => {
  232. switchUserType(1)
  233. },
  234. },
  235. ]
  236. const userList = [
  237. {
  238. name: '实名认证',
  239. img: '/static/serverImg/mine/adress.png',
  240. key: 'map',
  241. text: '前往实名认证',
  242. operate: () => {
  243. hanldeAuthentication()
  244. },
  245. },
  246. {
  247. name: '我的地址',
  248. img: '/static/serverImg/mine/adress.png',
  249. key: 'map',
  250. text: '',
  251. page: '/pages_mine/pages/selectAddress/index',
  252. },
  253. {
  254. name: '帮助与客服',
  255. img: '/static/serverImg/mine/kf.png',
  256. key: 'map',
  257. text: '',
  258. operate: () => {
  259. uni.navigateTo({
  260. url: `/pages_orderuser/pages/talk/pages/index/index?customerService=true&conversationType=3`
  261. })
  262. },
  263. },
  264. {
  265. name: '邀请二维码',
  266. key: 'share',
  267. img: '/static/img/Iconly@1x.png',
  268. text: '推荐好友得好礼',
  269. operate: () => {
  270. show.value = true
  271. },
  272. },
  273. {
  274. name: '用户',
  275. img: '/static/serverImg/mine/sf.png',
  276. key: 'map',
  277. text: '切换为志愿者',
  278. operate: () => {
  279. switchUserType(2)
  280. },
  281. },
  282. ]
  283. // 实名认证
  284. const hanldeAuthentication = () => {
  285. // wx.startFacialRecognitionVerify({
  286. // name: '陈建均',
  287. // idCardNumber:'500230200006011928',
  288. // checkAliveType:'2',
  289. // success: (result) => {
  290. // console.log("TCL: hanldeAuthentication -> result", result)
  291. // if (result.verifyResult) {
  292. // // 认证成功,提交服务端校验
  293. // }
  294. // },
  295. // fail: (err) => {
  296. // console.log("TCL: hanldeAuthentication -> err", err)
  297. // },
  298. // })
  299. // uni.navigateTo({
  300. // url: `/pages_mine/pages/authentication/index`
  301. // })
  302. }
  303. const switchUserType = (userType) => {
  304. uni.setStorageSync('userType', userType)
  305. store.dispatch('GetInfo').then((res) => {
  306. uni.$u.closeSoket();
  307. userInfo.value = store.state.user
  308. userOrWorker({ userType: userType })
  309. .then(res => {
  310. console.log("TCL: loginSuccess -> res", res)
  311. uni.$u.connectSoket(userInfo.value.userId)
  312. uni.reLaunch({
  313. url: '/pages/index',
  314. })
  315. })
  316. })
  317. .catch(err => {
  318. console.error('设置失败:', err);
  319. });
  320. }
  321. const list = computed(() => {
  322. if (userType === 1) {
  323. return userList
  324. }
  325. return adminList
  326. })
  327. function open() { //弹框打开逻辑
  328. // 打开逻辑,比如设置 show 为 true
  329. show.value = true;
  330. }
  331. function close() {
  332. // 关闭逻辑,设置 show 为 false
  333. show.value = false;
  334. }
  335. const onLogin = () => {
  336. const token = getToken()
  337. !token &&
  338. showConfirm('您还未登陆系统,是否前往登陆?').then((res) => {
  339. if (res.confirm) {
  340. store.dispatch('LogOut').then((res) => {
  341. uni.navigateTo({ url: '/pages/login' })
  342. })
  343. }
  344. })
  345. }
  346. const onLogou = () => {
  347. showConfirm('确认退出登陆吗?').then((res) => {
  348. if (res.confirm) {
  349. store.dispatch('LogOut').then((res) => {
  350. uni.reLaunch({
  351. url: '/pages/index',
  352. })
  353. })
  354. }
  355. })
  356. }
  357. const onClick = (record) => {
  358. console.log('record', record, record.page)
  359. if (record.page) {
  360. uni.navigateTo({
  361. url: record.page,
  362. })
  363. }
  364. if (record.operate) {
  365. record.operate()
  366. }
  367. if (record.switchPage && record.value) {
  368. const app = getApp()
  369. app.globalData.switchTabParams = {
  370. tabKey: record.value,
  371. }
  372. // JS跳转
  373. uni.switchTab({
  374. url: record.switchPage,
  375. })
  376. return
  377. }
  378. }
  379. const getDetails = async () => {
  380. try {
  381. // const res = await getVolunteerAccount();
  382. // console.log('res',res);
  383. } catch (error) {
  384. console.log('error', error)
  385. }
  386. }
  387. const handLsetTing = () => {
  388. console.log('uni.$u.closeSoket',uni.$u);
  389. uni.navigateTo({
  390. url: '/pages_mine/pages/setupUser/index',
  391. })
  392. }
  393. const geUserInfo = () => {
  394. console.log(store.state.user, '>>>>99')
  395. userInfo.value = store.state.user
  396. // store.dispatch('GetInfo').then((res) => {
  397. // userInfo.value = store.state.user
  398. // });
  399. }
  400. onShow(() => {
  401. const token = getToken()
  402. // console.log("TCL: token", token)
  403. if (token) {
  404. geUserInfo()
  405. init()
  406. }
  407. })
  408. onMounted(() => {
  409. getNav()
  410. })
  411. const init = async () => {
  412. try {
  413. // uni.hideLoading();
  414. // uni.showLoading({
  415. // title: '数据加载中...',
  416. // })
  417. if (userType === 2) {
  418. const res1 = await getVolunteerAccountInfo()
  419. const res2 = await volunteerOrderStatistics()
  420. data.value = {
  421. ...res1.data,
  422. ...res2.data,
  423. }
  424. console.log(11, res1, res2, data.value, userType)
  425. }
  426. if (userType === 1) {
  427. const res = await getAccountInfo();
  428. data.value = {
  429. ...data.value,
  430. ...res.data,
  431. };
  432. }
  433. } catch (error) {
  434. console.log('error', error)
  435. uni.showToast({
  436. title: error.msg,
  437. icon: 'error',
  438. })
  439. } finally {
  440. // uni.hideLoading()
  441. }
  442. }
  443. const getNav = async () => {
  444. try {
  445. const res = await getNavBarHeight();
  446. globalData.value = res;
  447. console.log("TCL: getNav -> res", res)
  448. } catch (error) {
  449. console.log("TCL: getNav -> error", error)
  450. }
  451. }
  452. </script>
  453. <style lang="scss" scoped>
  454. @import "./index.scss";
  455. </style>