index.vue 12 KB

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