index.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686
  1. <template>
  2. <div class="page " :class="{ page_red: theme === 1 }">
  3. <nav-bar :title="' '" :themeBg="true"></nav-bar>
  4. <div class="user">
  5. <div class="user__content">
  6. <div class="user__left">
  7. <div
  8. class="user__img"
  9. @click="jumpHandle('/pages/user/setting')"
  10. >
  11. <my-image
  12. :src="
  13. userInfo.avatarUrl ||
  14. '/static/user/portrait.jpg'
  15. "
  16. ></my-image>
  17. </div>
  18. <div class="user__info">
  19. <div
  20. class="user__name"
  21. @click="jumpHandle('/pages/user/setting')"
  22. >
  23. {{ userInfo.nickName || "点击头像登录" }}
  24. </div>
  25. <div
  26. class="code-box"
  27. @click="jumpHandle('/pages/user/vip-code')"
  28. >
  29. <my-image
  30. v-if="userInfo.nickName"
  31. class="vip-code"
  32. src="/static/user/qr-code.png"
  33. ></my-image>
  34. <span class="text">会员码</span>
  35. </div>
  36. </div>
  37. </div>
  38. </div>
  39. </div>
  40. <div class="order">
  41. <div class="order__top">
  42. <div class="order__title">我的订单</div>
  43. <div
  44. class="order__right"
  45. @click="jumpHandle('/pages/order/index')"
  46. >
  47. <span class="order__all">全部订单</span>
  48. <i class="iconfont iconarrow order__arrows"></i>
  49. </div>
  50. </div>
  51. <ul class="order__list">
  52. <!-- <li
  53. class="order__item"
  54. @click="
  55. jumpHandle({
  56. path: '/pages/order/index',
  57. query: { index: 0 },
  58. })
  59. "
  60. >
  61. <i class="iconfont iconquanbu order__icon"></i>
  62. <div class="order__text">全部</div>
  63. </li> -->
  64. <li
  65. class="order__item"
  66. @click="
  67. jumpHandle({
  68. path: '/pages/order/index',
  69. query: { index: 1 },
  70. })
  71. "
  72. >
  73. <!-- <i class="iconfont iconweibiaoti2fuzhi04 order__icon"></i> -->
  74. <my-image
  75. v-if="theme === 2"
  76. class="order__icon"
  77. :src="'/static/user/icon1.png'"
  78. ></my-image>
  79. <my-image
  80. v-if="theme === 1"
  81. class="order__icon"
  82. :src="'/static/user/icon1_red.png'"
  83. ></my-image>
  84. <div class="order__text">待支付</div>
  85. <div
  86. class="order__num"
  87. v-if="info.orderCountInfo.unpaidOrderCount"
  88. >
  89. {{ info.orderCountInfo.unpaidOrderCount }}
  90. </div>
  91. </li>
  92. <li
  93. class="order__item"
  94. @click="
  95. jumpHandle({
  96. path: '/pages/order/index',
  97. query: { index: 2 },
  98. })
  99. "
  100. >
  101. <!-- <i class="iconfont iconicon-test order__icon"></i> -->
  102. <my-image
  103. v-if="theme === 2"
  104. class="order__icon"
  105. :src="'/static/user/icon2.png'"
  106. ></my-image>
  107. <my-image
  108. v-if="theme === 1"
  109. class="order__icon"
  110. :src="'/static/user/icon2_red.png'"
  111. ></my-image>
  112. <div class="order__text">拣货中</div>
  113. <div
  114. class="order__num"
  115. v-if="info.orderCountInfo.waitShippedOrderCount"
  116. >
  117. {{ info.orderCountInfo.waitShippedOrderCount }}
  118. </div>
  119. </li>
  120. <li
  121. class="order__item"
  122. @click="
  123. jumpHandle({
  124. path: '/pages/order/index',
  125. query: { index: 3 },
  126. })
  127. "
  128. >
  129. <!-- <i class="iconfont icondaishouhuo order__icon"></i> -->
  130. <my-image
  131. v-if="theme === 2"
  132. class="order__icon"
  133. :src="'/static/user/icon3.png'"
  134. ></my-image>
  135. <my-image
  136. v-if="theme === 1"
  137. class="order__icon"
  138. :src="'/static/user/icon3_red.png'"
  139. ></my-image>
  140. <div class="order__text">配送中</div>
  141. <div
  142. class="order__num"
  143. v-if="info.orderCountInfo.waitReceivedOrderCount"
  144. >
  145. {{ info.orderCountInfo.waitReceivedOrderCount }}
  146. </div>
  147. </li>
  148. <li
  149. class="order__item"
  150. @click="
  151. jumpHandle({
  152. path: '/pages/order/index',
  153. query: { index: 4 },
  154. })
  155. "
  156. >
  157. <!-- <i class="iconfont icontrues order__icon"></i> -->
  158. <my-image
  159. v-if="theme === 2"
  160. class="order__icon"
  161. :src="'/static/user/icon4.png'"
  162. ></my-image>
  163. <my-image
  164. v-if="theme === 1"
  165. class="order__icon"
  166. :src="'/static/user/icon4_red.png'"
  167. ></my-image>
  168. <div class="order__text">待提/收货</div>
  169. </li>
  170. <li
  171. class="order__item"
  172. @click="
  173. jumpHandle({
  174. path: '/pages/order/index',
  175. query: { index: 5 },
  176. })
  177. "
  178. >
  179. <!-- <i class="iconfont iconshouhoutuikuan order__icon"></i> -->
  180. <my-image
  181. v-if="theme === 2"
  182. class="order__icon"
  183. :src="'/static/user/icon5.png'"
  184. ></my-image>
  185. <my-image
  186. v-if="theme === 1"
  187. class="order__icon"
  188. :src="'/static/user/icon5_red.png'"
  189. ></my-image>
  190. <div class="order__text">已完成</div>
  191. </li>
  192. <li
  193. class="order__item"
  194. @click="
  195. jumpHandle({
  196. path: '/pages/order/index',
  197. query: { index: 6 },
  198. })
  199. "
  200. >
  201. <!-- <i class="iconfont iconshouhoutuikuan order__icon"></i> -->
  202. <my-image
  203. v-if="theme === 2"
  204. class="order__icon"
  205. :src="'/static/user/icon6.png'"
  206. ></my-image>
  207. <my-image
  208. v-if="theme === 1"
  209. class="order__icon"
  210. :src="'/static/user/icon5_red.png'"
  211. ></my-image>
  212. <div class="order__text">售后</div>
  213. </li>
  214. </ul>
  215. </div>
  216. <div class="tool">
  217. <div class="tool__title">我的工具</div>
  218. <ul class="tool__list">
  219. <li
  220. class="tool__item"
  221. @click="jumpHandle('/pages/coupon/index')"
  222. >
  223. <my-image
  224. class="tool__icon"
  225. :src="'/static/user/tool1.png'"
  226. >
  227. <div
  228. class="tool__num"
  229. v-if="
  230. info.coupoonInfo && info.coupoonInfo.couponCount
  231. "
  232. >
  233. {{ info.coupoonInfo.couponCount }}
  234. </div>
  235. </my-image>
  236. <!-- <i
  237. class="iconfont iconyouhuiquan tool__icon"
  238. style="color: #ec7173"
  239. > -->
  240. <div class="tool__text">优惠券</div>
  241. </li>
  242. <li class="tool__item">
  243. <my-image
  244. class="tool__icon"
  245. :src="'/static/user/tool2.png'"
  246. ></my-image>
  247. <button class="button" @click="kefuTel">
  248. <div class="tool__text">联系客服</div>
  249. </button>
  250. </li>
  251. <li class="tool__item" @click="setAddress">
  252. <my-image
  253. class="tool__icon"
  254. :src="'/static/user/tool4.png'"
  255. ></my-image>
  256. <!-- <i
  257. class="iconfont icondizhi tool__icon"
  258. style="color: #fe866b"
  259. ></i> -->
  260. <div class="tool__text">收货地址</div>
  261. </li>
  262. <li
  263. class="tool__item"
  264. @click="jumpHandle('/pages/integral/index')"
  265. >
  266. <my-image
  267. class="tool__icon"
  268. :src="'/static/user/tool3.png'"
  269. ></my-image>
  270. <!-- <i
  271. class="iconfont iconlianxikefu tool__icon"
  272. style="color: #66bbfc"
  273. ></i> -->
  274. <div class="tool__text">我的积分</div>
  275. </li>
  276. </ul>
  277. </div>
  278. <div class="web-support">
  279. <p class="text">0.0.987</p>
  280. <!-- <div class="num" @click="makeCall">400-629-6782</div> -->
  281. </div>
  282. </div>
  283. </template>
  284. <script>
  285. import MyImage from "../../components/image/index";
  286. import NavBar from "../../components/layout/nav-bar";
  287. export default {
  288. name: "",
  289. components: { MyImage, NavBar },
  290. // 数据
  291. data() {
  292. return {
  293. info: "",
  294. layout: [],
  295. vipCodeImg: "",
  296. };
  297. },
  298. onLoad() {
  299. this.fn.shareMenu();
  300. },
  301. async onShow() {
  302. const self = this;
  303. await self.fn.init();
  304. self.fn.updateUserInfo();
  305. },
  306. // 函数
  307. methods: {
  308. // 获取信息
  309. getInfo() {
  310. const self = this;
  311. // self.api.get("/My/GetMy").then((res) => {
  312. // self.info = res.data;
  313. // });
  314. },
  315. // 未登录跳转处理
  316. jumpHandle(option) {
  317. const self = this;
  318. if (self.user.login) {
  319. self.router.push(option);
  320. } else {
  321. self.router.push("/pages/login/index");
  322. }
  323. },
  324. // 设置收货地址
  325. setAddress() {
  326. const self = this;
  327. self.router.push("/pages/address/index");
  328. // uni.getSetting({
  329. // success(res) {
  330. // if (res.authSetting["scope.address"] === false) {
  331. // self.fn
  332. // .showModal({
  333. // title: "设置地址",
  334. // content:
  335. // "需要打开小程序的设置重新授权获取你的收货地址",
  336. // confirmText: "去设置",
  337. // })
  338. // .then((res) => {
  339. // if (res.confirm) {
  340. // uni.openSetting();
  341. // }
  342. // });
  343. // } else {
  344. // uni.chooseAddress();
  345. // }
  346. // },
  347. // });
  348. },
  349. // 跳转到推广页面
  350. jumpGeneralize() {
  351. const self = this;
  352. if (self.user.login) {
  353. if (self.user.vip && self.user.vipStatus) {
  354. self.router.push({
  355. path: "/pages/generalize/index",
  356. });
  357. } else {
  358. self.router.push({
  359. path: "/pages/generalize/open",
  360. });
  361. }
  362. } else {
  363. self.router.push("/pages/login/index");
  364. }
  365. },
  366. makeCall() {
  367. uni.makePhoneCall({
  368. phoneNumber: "4006296782",
  369. });
  370. },
  371. kefuTel() {
  372. if (this.activeShop.managerTelephone) {
  373. uni.makePhoneCall({
  374. phoneNumber: this.activeShop.managerTelephone,
  375. });
  376. }else{
  377. this.fn.showToast('当前店铺未设置客服手机号');
  378. }
  379. },
  380. },
  381. onShareAppMessage() {
  382. let url = `/pages/goods/index?uid=${this.user.user.id}&shopId=${this.activeShop.id}`;
  383. if (this.activeShop.store) {
  384. url += `&storeId=${this.activeShop.store.id}`;
  385. }
  386. return {
  387. title: this.activeShop.name || "",
  388. path: url,
  389. imageUrl: this.activeShop.shopBanner || this.activeShop.logo,
  390. };
  391. },
  392. // 数据计算
  393. computed: {
  394. tabList() {
  395. return this.$store.state.common.tabList;
  396. },
  397. activeShop() {
  398. return this.$store.state.common.activeShop;
  399. },
  400. // 是否开启积分抵扣
  401. enablePoints() {
  402. return this.$store.state.common.enablePoints;
  403. },
  404. // 判断主题 1:红色 2:绿色
  405. theme() {
  406. return this.$store.state.common.theme;
  407. },
  408. customConfig() {
  409. return this.$store.state.common.customConfig;
  410. },
  411. cashCouponName() {
  412. return this.$store.state.common.cashCouponName || "";
  413. },
  414. writeOffCashCouponName() {
  415. return this.$store.state.common.writeOffCashCouponName || "";
  416. },
  417. user() {
  418. return this.$store.state.user;
  419. },
  420. userInfo() {
  421. return this.$store.state.user.userInfo || "";
  422. },
  423. writeOffUser() {
  424. return this.$store.state.user.writeOffUser || "";
  425. },
  426. distribution() {
  427. return this.$store.state.common.distribution;
  428. },
  429. },
  430. // 数据监听
  431. watch: {},
  432. };
  433. </script>
  434. <style lang="scss" scoped>
  435. .page {
  436. background-color: #f6f6f6;
  437. }
  438. .user {
  439. height: px(300);
  440. padding: px(15) px(30) 0;
  441. background-color: #27a34f;
  442. &__content {
  443. display: flex;
  444. justify-content: space-between;
  445. }
  446. &__left {
  447. display: flex;
  448. align-items: center;
  449. width: 100%;
  450. }
  451. &__img {
  452. display: flex;
  453. justify-content: center;
  454. align-items: center;
  455. width: px(170);
  456. height: px(170);
  457. border-radius: 50%;
  458. border: solid px(2) #fff;
  459. /deep/ img {
  460. width: px(160);
  461. height: px(160);
  462. border-radius: 50%;
  463. }
  464. }
  465. &__name {
  466. @include omits(1);
  467. margin-left: px(30);
  468. font-size: px(48);
  469. color: #fff;
  470. }
  471. &__info {
  472. display: flex;
  473. justify-content: space-between;
  474. align-items: center;
  475. }
  476. }
  477. .order {
  478. width: px(1020);
  479. overflow: hidden;
  480. margin: px(30) auto 0;
  481. border-radius: px(15);
  482. background-color: #fff;
  483. &__top {
  484. display: flex;
  485. justify-content: space-between;
  486. align-items: center;
  487. height: px(120);
  488. padding: 0 px(30);
  489. border-bottom: solid px(3) #ececec;
  490. }
  491. &__title {
  492. font-size: px(44);
  493. color: #333;
  494. }
  495. &__right {
  496. display: flex;
  497. align-items: center;
  498. }
  499. &__all {
  500. font-size: px(36);
  501. color: #999;
  502. }
  503. &__arrows {
  504. // margin-left: px(30);
  505. font-size: px(34);
  506. color: #999;
  507. }
  508. &__list {
  509. display: flex;
  510. justify-content: space-around;
  511. align-items: center;
  512. height: px(220);
  513. }
  514. &__item {
  515. position: relative;
  516. display: flex;
  517. flex-direction: column;
  518. justify-content: center;
  519. align-items: center;
  520. }
  521. &__icon {
  522. font-size: px(60);
  523. color: #666;
  524. /deep/ img {
  525. width: px(60);
  526. height: px(60);
  527. object-fit: contain !important;
  528. }
  529. }
  530. &__text {
  531. margin-top: px(20);
  532. font-size: px(36);
  533. color: #333;
  534. }
  535. &__num {
  536. position: absolute;
  537. top: px(10);
  538. right: px(20);
  539. z-index: 1;
  540. display: flex;
  541. justify-content: center;
  542. align-items: center;
  543. min-width: px(42);
  544. height: px(42);
  545. transform: translate(50%, -50%);
  546. padding: 0 px(15);
  547. font-size: px(30);
  548. color: #fff;
  549. border-radius: px(21);
  550. background-color: #27a34f;
  551. }
  552. }
  553. .tool {
  554. width: px(1020);
  555. margin: px(30) auto px(30);
  556. background-color: #fff;
  557. border-radius: px(15);
  558. &__title {
  559. display: flex;
  560. align-items: center;
  561. height: px(120);
  562. padding: 0 px(30);
  563. font-size: px(44);
  564. color: #333;
  565. border-bottom: solid px(3) #ececec;
  566. }
  567. &__list {
  568. display: flex;
  569. flex-wrap: wrap;
  570. padding: px(20) px(40);
  571. }
  572. &__item {
  573. display: flex;
  574. flex-direction: column;
  575. justify-content: center;
  576. align-items: center;
  577. width: 25%;
  578. height: px(220);
  579. position: relative;
  580. }
  581. &__num {
  582. position: absolute;
  583. top: px(0);
  584. right: px(0);
  585. z-index: 1;
  586. display: flex;
  587. justify-content: center;
  588. align-items: center;
  589. min-width: px(42);
  590. height: px(42);
  591. transform: translate(50%, -50%);
  592. padding: 0 px(15);
  593. font-size: px(30);
  594. color: #fff;
  595. border-radius: px(21);
  596. background-color: #f00;
  597. }
  598. &__icon {
  599. font-size: px(60);
  600. position: relative;
  601. /deep/ img {
  602. width: px(80);
  603. height: px(80);
  604. object-fit: contain !important;
  605. }
  606. }
  607. &__text {
  608. margin-top: px(20);
  609. font-size: px(36);
  610. color: #333;
  611. }
  612. }
  613. .vv {
  614. text-align: center;
  615. padding: px(20);
  616. color: #999;
  617. font-size: px(34);
  618. }
  619. .page_red {
  620. .user {
  621. background-color: #27a34f;
  622. }
  623. }
  624. .vip-code {
  625. width: px(60);
  626. height: px(60);
  627. /deep/ img {
  628. width: px(60);
  629. height: px(60);
  630. }
  631. }
  632. .code-box {
  633. margin-left: px(60);
  634. display: flex;
  635. align-items: center;
  636. padding: px(10);
  637. .text {
  638. margin-left: px(14);
  639. font-size: px(32);
  640. color: #fff;
  641. }
  642. }
  643. </style>