Browse Source

赚积分

cr 3 years ago
parent
commit
f6de5650a6
5 changed files with 1030 additions and 40 deletions
  1. 2 2
      .env
  2. 6 0
      src/pages.json
  3. 585 0
      src/pages/pay/order-share.vue
  4. 437 38
      src/pages/pay/result.vue
  5. BIN
      src/static/icon/error.png

+ 2 - 2
.env

@@ -7,13 +7,13 @@ NODE_ENV = 'production'
7 7
 VUE_APP_ENV = develop
8 8
 
9 9
 # 接口请求基地址
10
-VUE_APP_API_BASE_URL =  https://youxuan.ixiaokejia.com
10
+VUE_APP_API_BASE_URL =  http://localhost:8077
11 11
 
12 12
 # 接口请求基地址
13 13
 VUE_APP_WEBSOCKET_BASE_URL = 
14 14
 
15 15
 # 图片基地址
16
-VUE_APP_IMAGE_BASE_URL =  https://youxuan.ixiaokejia.com
16
+VUE_APP_IMAGE_BASE_URL =  http://localhost:8077
17 17
 VUE_APP_IMAGE_RESOURCE_URL = https://oss.ixiaokejia.com
18 18
 
19 19
 # 微信小程序appId

+ 6 - 0
src/pages.json

@@ -231,6 +231,12 @@
231 231
                 "navigationBarTextStyle": "white",
232 232
                 "navigationBarBackgroundColor": "#262626"
233 233
             }
234
+        },
235
+        {
236
+            "path": "pages/pay/order-share",
237
+            "style": {
238
+                "navigationBarTitleText": "订单分享"
239
+            }
234 240
         }
235 241
     ]
236 242
 }

+ 585 - 0
src/pages/pay/order-share.vue

@@ -0,0 +1,585 @@
1
+<template>
2
+    <div class="page">
3
+        <div class="head-main">
4
+            <div class="user-info">
5
+                <my-image
6
+                    class="user-head"
7
+                    :src="orderData.user.headIcon"
8
+                ></my-image>
9
+                <span class="name"
10
+                    >{{ orderData.user.nickName }}向您推荐了订单</span
11
+                >
12
+            </div>
13
+            <div class="line">
14
+                <span class="line-ele"></span>
15
+                <span class="text">大家都在抢</span>
16
+                <span class="line-ele"></span>
17
+            </div>
18
+            <ul class="good-list">
19
+                <li
20
+                    class="item"
21
+                    v-for="(item, index) of orderData.productList"
22
+                    :key="index"
23
+                >
24
+                    <my-image
25
+                        class="good-img"
26
+                        @click="goDetail(item)"
27
+                        :src="item.image"
28
+                    ></my-image>
29
+                    <div class="con">
30
+                        <div class="info">
31
+                            <div class="name" @click="goDetail(item)">
32
+                                {{ item.name }}
33
+                            </div>
34
+                            <div
35
+                                class="tag-price"
36
+                                @click="goDetail(item)"
37
+                                v-if="item.tagPrice"
38
+                            >
39
+                                <span class="symbol">¥</span>
40
+                                {{ item.tagPrice / 100 }}
41
+                            </div>
42
+                            <div class="price" @click="goDetail(item)">
43
+                                <span class="symbol">¥</span>
44
+                                {{ item.price / 100 }}
45
+                            </div>
46
+                        </div>
47
+                        <div class="tool">
48
+                            <div class="btn" @click="addCart(item)">
49
+                                加入购物车
50
+                            </div>
51
+                        </div>
52
+                    </div>
53
+                </li>
54
+            </ul>
55
+        </div>
56
+
57
+        <div class="more-list">
58
+            <div class="more-tit">精品推荐</div>
59
+            <ul class="good-list">
60
+                <li
61
+                    class="item"
62
+                    v-for="(item, index) of goodsList"
63
+                    :key="index"
64
+                >
65
+                    <my-image
66
+                        class="good-img"
67
+                        @click="goDetail(item)"
68
+                        :src="item.pictureUrls[0]"
69
+                    ></my-image>
70
+                    <div class="con">
71
+                        <div class="info" @click="goDetail(item)">
72
+                            <div class="name">{{ item.name }}</div>
73
+                            <!-- <div class="des">
74
+                                <span>5月14日提货</span>
75
+                                <span>已售5.6万件</span>
76
+                            </div> -->
77
+                            <div
78
+                                class="tag-price"
79
+                                @click="goDetail(item)"
80
+                                v-if="item.tagPrice"
81
+                            >
82
+                                <span class="symbol">¥</span>
83
+                                {{ item.tagPrice / 100 }}
84
+                            </div>
85
+                            <div class="price" @click="goDetail(item)">
86
+                                <span class="symbol">¥</span>
87
+                                {{ item.minPrice / 100 }}
88
+                            </div>
89
+                        </div>
90
+                        <div class="tool" @click="addCart(item)">
91
+                            <div class="btn">加入购物车</div>
92
+                        </div>
93
+                    </div>
94
+                </li>
95
+            </ul>
96
+            <div class="more-loading">加载中...</div>
97
+        </div>
98
+        <div class="navigation">
99
+            <ul class="navigation__list">
100
+                <!-- <button class="button">
101
+                    <li class="navigation__item">
102
+                        <i class="iconfont iconkefu navigation__icon"></i>
103
+                        <div class="navigation__text">找客服</div>
104
+                    </li>
105
+                </button> -->
106
+                <li
107
+                    class="navigation__item"
108
+                    @click="
109
+                        jump({ isTabBer: true, path: '/pages/goods/index' })
110
+                    "
111
+                >
112
+                    <i class="iconfont icondianpu navigation__icon"></i>
113
+                    <div class="navigation__text">首页</div>
114
+                </li>
115
+                <li class="navigation__item">
116
+                    <button v-if="user.login" class="button" @click="jumpCart">
117
+                        <i class="iconfont icongouwuche navigation__icon"></i>
118
+                        <div class="navigation__text">购物车</div>
119
+                    </button>
120
+
121
+                    <div class="navigation__num" v-if="cartInfo.count">
122
+                        {{ cartInfo.count }}
123
+                    </div>
124
+                </li>
125
+            </ul>
126
+            <div class="navigation__right">
127
+                <div class="price">
128
+                    总价:<span class="symbol">¥</span
129
+                    ><span class="num">{{cartInfo.amount / 100}}</span>
130
+                </div>
131
+                <button class="button" @click="submit">
132
+                    <div class="navigation__btn">去结算</div>
133
+                </button>
134
+            </div>
135
+        </div>
136
+        <g-spec ref="spec" :goods="goods" :spec.sync="spec"></g-spec>
137
+    </div>
138
+</template>
139
+
140
+<script>
141
+import MyImage from "../../components/image/index";
142
+import GSpec from "../recommend/spec";
143
+export default {
144
+    name: "",
145
+    components: { MyImage, GSpec },
146
+    // 数据
147
+    data() {
148
+        return {
149
+            orderId: "",
150
+            orderData: {},
151
+            cartInfo: {},
152
+            goods: {},
153
+
154
+            isHaveMore: true, // 是否有更多数据
155
+            loading: false, // 是否加载完成
156
+            goodsList: [], // 详情数据 加入购物车时用
157
+            page: 1,
158
+            moreLoading: true,
159
+        };
160
+    },
161
+
162
+    async onShow() {},
163
+    onLoad(opts) {
164
+        this.orderId = opts.orderId;
165
+        this.getCartNumber();
166
+        this.getOrderData();
167
+        this.getGoodsList();
168
+    },
169
+
170
+    onReachBottom() {
171
+        this.getMoreGoods();
172
+    },
173
+    // 函数
174
+    methods: {
175
+        getOrderData() {
176
+            this.api
177
+                .get("/Order/GetOrderInfo", {
178
+                    id: this.orderId,
179
+                })
180
+                .then((res) => {
181
+                    this.orderData = res.data;
182
+                    console.log(this.orderData);
183
+                    // this.orderProuct = this.orderData.
184
+                    this.fn.shareMenu();
185
+                    console.log(this.orderData);
186
+                });
187
+        },
188
+
189
+        // 获取商品列表
190
+        getGoodsList() {
191
+            const self = this;
192
+
193
+            self.page = 1;
194
+            uni.showLoading({
195
+                title: "加载中...",
196
+            });
197
+            self.api
198
+                .get("/Product/GetHHSGProductList", {
199
+                    pageIndex: self.page,
200
+                    pageSize: 20,
201
+                    aid: "1391692975070859265",
202
+                })
203
+                .then((res) => {
204
+                    uni.hideLoading();
205
+                    uni.stopPullDownRefresh();
206
+                    let data = JSON.parse(res.data.list);
207
+                    if (data.length) {
208
+                        self.page++;
209
+                    } else {
210
+                        self.isHaveMore = false;
211
+                    }
212
+
213
+                    self.goodsList = data;
214
+                    console.log(data);
215
+                    // self.loading = true;
216
+                    uni.hideLoading();
217
+                });
218
+        },
219
+
220
+        // 加入购物车
221
+        addCart(val) {
222
+            const self = this;
223
+            let pid = val.id || val.pid;
224
+            uni.showLoading({
225
+                title: "处理中...",
226
+            });
227
+            self.api
228
+                .get(
229
+                    "/Product/GetHHSGProduct",
230
+                    {
231
+                        pid,
232
+                    },
233
+                    {
234
+                        pass: true,
235
+                    }
236
+                )
237
+                .then((res) => {
238
+                    self.goods = JSON.parse(res.data);
239
+                    console.log(self.goods);
240
+                    if (self.goods.skuList.length === 1) {
241
+                        self.api
242
+                            .post("/Order/AddCart", {
243
+                                productId: pid,
244
+                                count: 1,
245
+                                skuId: self.goods.skuList[0].skuNo,
246
+                                productSource: 1, // 优选,
247
+                            })
248
+                            .then((res) => {
249
+                                uni.hideLoading();
250
+                                this.fn.showToast("已成功加入购物车");
251
+                                this.getCartNumber();
252
+                            });
253
+                    } else {
254
+                        uni.hideLoading();
255
+                        this.openSpec();
256
+                    }
257
+                });
258
+        },
259
+        goDetail(val) {
260
+            const self = this;
261
+
262
+            self.router.push({
263
+                path: "/pages/recommend/detail",
264
+                query: {
265
+                    goodsId: val.id || val.pid,
266
+                },
267
+            });
268
+        },
269
+        // 打开规则选项
270
+        openSpec() {
271
+            this.$refs.spec.open("cart", (res) => {
272
+                this.getCartNumber();
273
+                this.fn.showToast("已成功加入购物车");
274
+            });
275
+        },
276
+
277
+        // 获取购物车数量
278
+        getCartNumber() {
279
+            const self = this;
280
+            self.api.get("/Order/GetCartInfo",{productSource:1}).then((res) => {
281
+                this.cartInfo = res.data;
282
+            });
283
+        },
284
+
285
+        // 获取更多商品
286
+        getMoreGoods() {
287
+            const self = this;
288
+            this.moreLoading = true;
289
+            self.api
290
+                .get("/Product/GetHHSGProductList", {
291
+                    pageIndex: self.page,
292
+                    pageSize: 20,
293
+                    aid: "1391692975070859265",
294
+                })
295
+                .then((res) => {
296
+                    this.moreLoading = false;
297
+                    let data = JSON.parse(res.data.list);
298
+                    if (data.length) {
299
+                        self.page++;
300
+                    } else {
301
+                        self.isHaveMore = false;
302
+                    }
303
+
304
+                    self.goodsList = self.goodsList.concat(data);
305
+                });
306
+        },
307
+
308
+        // 跳转到购物车
309
+        jumpCart() {
310
+            this.router.push({
311
+                isTabBer: true,
312
+                path: "/pages/cart/index",
313
+            });
314
+        },
315
+    },
316
+
317
+    // 数据计算
318
+    computed: {
319
+        user() {
320
+            return this.$store.state.user;
321
+        },
322
+    },
323
+
324
+    // 数据监听
325
+    watch: {},
326
+};
327
+</script>
328
+
329
+<style lang="scss" scoped>
330
+.page {
331
+    height: 100vh;
332
+    overflow: auto;
333
+    padding-bottom: px(185);
334
+}
335
+.head-main {
336
+    padding: px(45);
337
+    background: linear-gradient(#27a34f, #78d197);
338
+    font-size: px(44);
339
+    .user-info {
340
+        display: flex;
341
+        align-items: center;
342
+        justify-content: center;
343
+    }
344
+    .user-head {
345
+        width: px(70);
346
+        height: px(70);
347
+        border-radius: 50%;
348
+        background-color: #eee;
349
+        flex-shrink: 0;
350
+        margin-right: px(20);
351
+        /deep/ img {
352
+            width: px(60);
353
+            height: px(60);
354
+        }
355
+    }
356
+    .name {
357
+        color: #fff;
358
+    }
359
+    .line {
360
+        display: flex;
361
+        align-items: center;
362
+        justify-content: center;
363
+        margin-top: px(30);
364
+    }
365
+    .text {
366
+        font-size: px(40);
367
+        color: #fff;
368
+        padding: 0 px(20);
369
+    }
370
+    .line-ele {
371
+        height: 1px;
372
+        width: 35%;
373
+        background-color: #fff;
374
+    }
375
+}
376
+.good-list {
377
+    margin-top: px(60);
378
+    .item {
379
+        display: flex;
380
+        justify-content: space-between;
381
+        align-items: stretch;
382
+        background-color: #fff;
383
+        border-radius: px(20);
384
+        padding: px(30);
385
+        .good-img {
386
+            background-color: pink;
387
+            width: px(440);
388
+            height: px(440);
389
+            flex-shrink: 0;
390
+            margin-right: px(30);
391
+            /deep/ img {
392
+                width: px(440);
393
+                height: px(440);
394
+            }
395
+        }
396
+        .con {
397
+            width: 100%;
398
+            display: flex;
399
+            flex-direction: column;
400
+            justify-content: space-between;
401
+            .name {
402
+                font-size: px(44);
403
+                color: #333;
404
+                font-weight: bold;
405
+                @include omits(2);
406
+            }
407
+            .des {
408
+                font-size: px(40);
409
+                color: #888;
410
+                margin-top: px(20);
411
+                span ~ span {
412
+                    margin-left: px(10);
413
+                    padding-left: px(10);
414
+                    border-left: 1px solid #f1f1f1;
415
+                }
416
+            }
417
+            .price {
418
+                color: #e30b00;
419
+                font-size: px(54);
420
+                margin-top: px(20);
421
+                .symbol {
422
+                    font-size: px(40);
423
+                }
424
+            }
425
+            .tag-price {
426
+                margin-top: px(20);
427
+                color: #999;
428
+                text-decoration: line-through;
429
+                font-size: px(42);
430
+                .symbol {
431
+                    font-size: px(40);
432
+                }
433
+            }
434
+            .tool {
435
+                display: flex;
436
+                justify-content: space-between;
437
+                align-items: center;
438
+                .btn {
439
+                    width: 100%;
440
+                    height: px(100);
441
+                    border-radius: px(50);
442
+                    display: flex;
443
+                    align-items: center;
444
+                    justify-content: center;
445
+                    color: #fff;
446
+                    font-size: px(40);
447
+                    background-color: #27a34f;
448
+                }
449
+            }
450
+        }
451
+    }
452
+    .item ~ .item {
453
+        margin-top: px(30);
454
+    }
455
+}
456
+.navigation {
457
+    position: absolute;
458
+    bottom: 0;
459
+    left: 0;
460
+    z-index: 995;
461
+    display: flex;
462
+    justify-content: space-between;
463
+    align-items: center;
464
+    width: 100%;
465
+    height: px(185);
466
+    padding: 0 px(40);
467
+    background-color: #fff;
468
+    border-top: 1px solid #f1f1f1;
469
+
470
+    &--iphoneX {
471
+        height: px(215);
472
+        padding-bottom: px(30);
473
+    }
474
+
475
+    &__list {
476
+        display: flex;
477
+        justify-content: space-between;
478
+        align-items: center;
479
+        width: px(200);
480
+    }
481
+
482
+    &__item {
483
+        position: relative;
484
+        display: flex;
485
+        flex-direction: column;
486
+        justify-content: center;
487
+        align-items: center;
488
+    }
489
+
490
+    &__icon {
491
+        font-size: px(54);
492
+        color: #666;
493
+    }
494
+
495
+    &__text {
496
+        margin-top: px(20);
497
+        font-size: px(32);
498
+        color: #666;
499
+    }
500
+
501
+    &__num {
502
+        position: absolute;
503
+        top: 0;
504
+        right: 0;
505
+        z-index: 0;
506
+        display: flex;
507
+        justify-content: center;
508
+        align-items: center;
509
+        min-width: px(40);
510
+        height: px(40);
511
+        padding: 0 px(15);
512
+        transform: translate(30%, -30%);
513
+        font-size: px(26);
514
+        color: #fff;
515
+        border-radius: px(20);
516
+        background-color: #ff4421;
517
+    }
518
+
519
+    &__right {
520
+        display: flex;
521
+        justify-content: flex-end;
522
+        align-items: center;
523
+        flex: 1;
524
+        margin-left: px(40);
525
+    }
526
+
527
+    &__btn {
528
+        display: flex;
529
+        justify-content: center;
530
+        align-items: center;
531
+        width: px(270);
532
+        height: px(110);
533
+        font-size: px(40);
534
+        color: #fff;
535
+        border-radius: px(55);
536
+        background-color: #27a34f;
537
+        margin-left: px(20);
538
+        &--cart {
539
+            color: #262626;
540
+            background-color: #e5e5e5;
541
+        }
542
+    }
543
+
544
+    &__null {
545
+        display: flex;
546
+        justify-content: center;
547
+        align-items: center;
548
+        width: 100%;
549
+        height: px(110);
550
+        font-size: px(40);
551
+        color: #fff;
552
+        border-radius: px(55);
553
+        background-color: #e5e5e5;
554
+    }
555
+    .price {
556
+        font-size: px(40);
557
+    }
558
+    .symbol {
559
+    }
560
+    .symbol,
561
+    .num {
562
+        color: red;
563
+    }
564
+    .num {
565
+        font-size: px(50);
566
+    }
567
+}
568
+
569
+.more-loading {
570
+    font-size: px(40);
571
+    color: #999;
572
+    text-align: center;
573
+    padding: px(30);
574
+}
575
+.more-list {
576
+    padding: px(45);
577
+    background-color: #f1f1f1;
578
+}
579
+.more-tit {
580
+    font-size: px(50);
581
+    font-weight: bold;
582
+    text-align: center;
583
+    padding-top: px(30);
584
+}
585
+</style>

+ 437 - 38
src/pages/pay/result.vue

@@ -1,41 +1,107 @@
1 1
 <template>
2 2
     <div class="page">
3 3
         <div class="pay">
4
+            <div class="status-img">
5
+                <my-image
6
+                    v-if="type === 'success'"
7
+                    src="/static/icon/select.png"
8
+                ></my-image>
9
+                <my-image v-else src="/static/icon/error.png"></my-image>
10
+            </div>
4 11
             <div class="pay__title" v-if="type === 'success'">订单支付成功</div>
5 12
             <div class="pay__title" v-else>支付已取消</div>
6 13
             <div class="pay__content">
7
-                <div class="pay__sub-title">订单金额:</div>
14
+                <div class="pay__sub-title">支付金额:</div>
8 15
                 <div class="pay__price">{{ "¥" + (price || "0.00") }}</div>
9 16
             </div>
10
-            <div class="pay__btns">
11
-                <div class="pay__btn" @click="jumpOrderDetail">查看订单</div>
12
-                <div
13
-                    class="pay__btn"
14
-                    v-if="type === 'success'"
15
-                    @click="
16
-                        jump({ isTabBer: true, path: '/pages/goods/index' })
17
-                    "
18
-                >
19
-                    去逛首页
17
+
18
+            <div class="btn-box">
19
+                <button open-type="share" class="big__btn" v-if="type === 'success'">
20
+                    {{enablePoints?'分享到群,赚积分':'分享到群,提醒群主接单'}}
21
+                </button>
22
+                <div class="pay__btns">
23
+                    <div class="pay__btn" @click="jumpOrderDetail">
24
+                        查看订单
25
+                    </div>
26
+                    <div
27
+                        class="pay__btn"
28
+                        v-if="type === 'success'"
29
+                        @click="
30
+                            jump({ isTabBer: true, path: '/pages/goods/index' })
31
+                        "
32
+                    >
33
+                        去逛首页
34
+                    </div>
35
+                    <div class="pay__btn" v-else @click="pay">立即支付</div>
20 36
                 </div>
21
-                <div class="pay__btn" v-else @click="pay">立即支付</div>
22
-                <div
23
-                    class="pay__btn"
24
-                    v-if="IsVoucher"
25
-                    @click="jump('/pages/voucher/index')"
37
+            </div>
38
+        </div>
39
+
40
+        <!-- yx -->
41
+        <div v-if="goodsList && goodsList.length">
42
+            <div class="more-title">买了又买</div>
43
+            <ul class="goods">
44
+                <li
45
+                    class="goods__item"
46
+                    v-for="(item, index) in goodsList"
47
+                    :key="index"
26 48
                 >
27
-                    {{ cashCouponName }}
28
-                </div>
49
+                    <my-image
50
+                        class="goods__img"
51
+                        :src="item.pictureUrls[0]"
52
+                        @click="jumpGoodsDetail(item)"
53
+                    ></my-image>
54
+                    <div class="goods__title" @click="jumpGoodsDetail(item)">
55
+                        {{ item.name }}
56
+                    </div>
57
+                    <div
58
+                        class="goods__coupon"
59
+                        v-if="item.coupon"
60
+                        @click="jumpGoodsDetail(item)"
61
+                    >
62
+                        {{ item.coupon }}
63
+                    </div>
64
+                    <div class="goods__price">
65
+                        <div
66
+                            class="goods__present"
67
+                            @click="jumpGoodsDetail(item)"
68
+                        >
69
+                            <span class="goods__rmb">¥</span>
70
+                            <span class="goods__big">{{
71
+                                item.minPrice / 100
72
+                            }}</span>
73
+                        </div>
74
+                        <div
75
+                            class="goods__original"
76
+                            @click="jumpGoodsDetail(item)"
77
+                            v-if="item.tagPrice !== 0"
78
+                        >
79
+                            {{ "¥" + item.tagPrice / 100 }}
80
+                        </div>
81
+                    </div>
82
+                </li>
83
+            </ul>
84
+            <div class="more-text" v-if="moreLoading">- 加载中... -</div>
85
+            <div class="more-text" v-else-if="goodsList.length && !isHaveMore">
86
+                - {{ moreLoading ? "加载中..." : "没有更多了" }} -
87
+            </div>
88
+            <div class="null" v-if="loading && !goodsList.length">
89
+                <img
90
+                    class="null__img"
91
+                    src="/static/common/goods_null_2.jpg"
92
+                    alt
93
+                />
94
+                <div class="null__title">抱歉!没有找到相关商品~</div>
29 95
             </div>
30 96
         </div>
31 97
     </div>
32 98
 </template>
33 99
 
34 100
 <script>
35
-
101
+import MyImage from "../../components/image/index";
36 102
 export default {
37 103
     name: "",
38
-    components: {  },
104
+    components: { MyImage },
39 105
     // 数据
40 106
     data() {
41 107
         return {
@@ -43,8 +109,15 @@ export default {
43 109
             orderId: "",
44 110
             price: "",
45 111
             layout: [],
46
-            IsVoucher: false,
47 112
             sub: "",
113
+            orderData: {},
114
+
115
+            isHaveMore: true, // 是否有更多数据
116
+            loading: false, // 是否加载完成
117
+            goodsList: [], // 详情数据 加入购物车时用
118
+            page: 1,
119
+            moreLoading: true,
120
+            enablePoints:false,
48 121
         };
49 122
     },
50 123
 
@@ -55,25 +128,49 @@ export default {
55 128
         self.orderId = self.$mp.query.orderId;
56 129
         self.price = self.$mp.query.price;
57 130
         self.sub = self.$mp.query.sub;
58
-            self.fn.getMsgTpls(self.orderId, self.type === 'success'?2:1);
59
-
131
+        self.fn.getMsgTpls(self.orderId, self.type === "success" ? 2 : 1);
132
+        if (this.orderId && self.type === "success") {
133
+            this.getOrderData();
134
+            this.getEnablePoints();
135
+        }
60 136
         await self.fn.init();
61
-        // self.getIsVoucher();
137
+        this.getGoodsList();
138
+    },
139
+
140
+    onReachBottom() {
141
+        this.getMoreGoods();
62 142
     },
143
+    onShareAppMessage() {
144
+        let url = `/pages/pay/order-share?orderId=${this.orderId}`;
63 145
 
146
+        return {
147
+            title: `来自${this.orderData.user.nickName}的订单分享`,
148
+            path: url,
149
+            imageUrl: this.orderData.productList.image,
150
+        };
151
+    },
64 152
     // 函数
65 153
     methods: {
66 154
 
67
-        // 是否是代金券
68
-        getIsVoucher() {
69
-            const self = this;
155
+        getEnablePoints(){
156
+            this.api
157
+                .get("/Shop/GetEnablePoints", {
158
+                    id: this.orderId,
159
+                })
160
+                .then((res) => {
161
+                    this.enablePoints = res.data;
162
+                });
163
+        },
70 164
 
71
-            self.api
72
-                .get("/Order/GetHadCashCoupon", {
73
-                    orderId: self.orderId,
165
+        getOrderData() {
166
+            this.api
167
+                 .get("/Order/GetOrderInfo", {
168
+                    id: this.orderId,
74 169
                 })
75 170
                 .then((res) => {
76
-                    self.IsVoucher = res.data;
171
+                    this.orderData = res.data;
172
+                    this.fn.shareMenu();
173
+                    console.log(this.orderData)
77 174
                 });
78 175
         },
79 176
 
@@ -82,6 +179,8 @@ export default {
82 179
             const self = this;
83 180
 
84 181
             self.fn.pay(self.orderId, self.price);
182
+
183
+            
85 184
         },
86 185
 
87 186
         // 跳转到订单详情
@@ -99,6 +198,72 @@ export default {
99 198
                 self.fn.showToast("暂不支持查看订单");
100 199
             }
101 200
         },
201
+
202
+        // 获取商品列表
203
+        getGoodsList() {
204
+            const self = this;
205
+
206
+            self.page = 1;
207
+            uni.showLoading({
208
+                title: "加载中...",
209
+            });
210
+            self.api
211
+                .get("/Product/GetHHSGProductList", {
212
+                    pageIndex: self.page,
213
+                    pageSize: 20,
214
+                    aid: "1391692975070859265",
215
+                })
216
+                .then((res) => {
217
+                    uni.hideLoading();
218
+                    uni.stopPullDownRefresh();
219
+                    let data = JSON.parse(res.data.list);
220
+                    if (data.length) {
221
+                        self.page++;
222
+                    } else {
223
+                        self.isHaveMore = false;
224
+                    }
225
+
226
+                    self.goodsList = data;
227
+                    console.log(data);
228
+                    // self.loading = true;
229
+                    uni.hideLoading();
230
+                });
231
+        },
232
+
233
+        // 获取更多商品
234
+        getMoreGoods() {
235
+            const self = this;
236
+            this.moreLoading = true;
237
+            self.api
238
+                .get("/Product/GetHHSGProductList", {
239
+                    pageIndex: self.page,
240
+                    pageSize: 20,
241
+                    aid: "1391692975070859265",
242
+                })
243
+                .then((res) => {
244
+                    this.moreLoading = false;
245
+                    let data = JSON.parse(res.data.list);
246
+                    if (data.length) {
247
+                        self.page++;
248
+                    } else {
249
+                        self.isHaveMore = false;
250
+                    }
251
+
252
+                    self.goodsList = self.goodsList.concat(data);
253
+                });
254
+        },
255
+
256
+        // 跳转到商品详情
257
+        jumpGoodsDetail(val) {
258
+            const self = this;
259
+
260
+            self.router.push({
261
+                path: "/pages/recommend/detail",
262
+                query: {
263
+                    goodsId: val.pid,
264
+                },
265
+            });
266
+        },
102 267
     },
103 268
 
104 269
     // 数据计算
@@ -121,9 +286,9 @@ export default {
121 286
     display: flex;
122 287
     flex-direction: column;
123 288
     align-items: center;
124
-    height: px(385);
125 289
     background-color: #fff;
126
-
290
+    // min-height: 100vh;
291
+    padding-bottom: px(50);
127 292
     &__title {
128 293
         margin-top: px(60);
129 294
         font-size: px(50);
@@ -149,20 +314,254 @@ export default {
149 314
 
150 315
     &__btns {
151 316
         display: flex;
152
-        margin-top: px(60);
317
+        margin-top: px(40);
153 318
     }
154 319
 
155 320
     &__btn {
156 321
         display: flex;
157 322
         justify-content: center;
158 323
         align-items: center;
159
-        width: px(190);
160
-        height: px(80);
324
+        width: 48%;
325
+        height: px(120);
161 326
         margin: 0 px(15);
162
-        font-size: px(38);
327
+        font-size: px(44);
163 328
         color: #666;
164
-        border-radius: px(40);
329
+        border-radius: px(60);
165 330
         border: solid px(3) #ddd;
166 331
     }
167 332
 }
333
+.btn-box {
334
+    padding: 0 px(60);
335
+    width: 100%;
336
+}
337
+.big__btn {
338
+    display: flex;
339
+    justify-content: center;
340
+    align-items: center;
341
+    width: 100%;
342
+    height: px(120);
343
+    margin: 0 px(15);
344
+    font-size: px(44);
345
+    color: #fff;
346
+    border-radius: px(60);
347
+    border: solid px(3) #ddd;
348
+    background-color: #27a34f;
349
+    margin-top: px(60);
350
+}
351
+.status-img {
352
+    width: px(200);
353
+    height: px(230);
354
+    margin: 0 auto;
355
+    padding-top: px(30);
356
+    /deep/ img {
357
+        display: block;
358
+        width: px(200);
359
+        height: px(200);
360
+    }
361
+}
362
+
363
+.goods {
364
+    display: flex;
365
+    flex-wrap: wrap;
366
+    justify-content: space-between;
367
+    padding: 0 px(25) px(30);
368
+
369
+    &__item {
370
+        width: px(500);
371
+        padding-bottom: px(30);
372
+        margin-top: px(25);
373
+        overflow: hidden;
374
+        border-radius: px(15);
375
+        background-color: #fff;
376
+        position: relative;
377
+
378
+        &:nth-child(2n + 1) {
379
+            margin-right: px(30);
380
+        }
381
+    }
382
+    .button {
383
+        // overflow: visible;
384
+        // position: absolute;
385
+        // bottom: 0;
386
+        // right: 0;
387
+        // z-index: 1;
388
+        // padding: px(10) px(30) px(30) px(10);
389
+    }
390
+    .btns {
391
+        overflow: visible;
392
+        position: absolute;
393
+        bottom: px(30);
394
+        right: px(30);
395
+        z-index: 1;
396
+        display: flex;
397
+        align-items: center;
398
+    }
399
+    .cart-num {
400
+        // padding: px(30) px(10) px(10) px(30);
401
+        padding: 0 px(30);
402
+        box-sizing: border-box;
403
+        min-width: px(60);
404
+    }
405
+    .num-input {
406
+        overflow: visible;
407
+        position: absolute;
408
+        bottom: px(20);
409
+        right: px(20);
410
+        z-index: 1;
411
+    }
412
+    &__add-text {
413
+        height: px(60);
414
+        line-height: px(60);
415
+        background-color: #27a34f;
416
+        color: #fff;
417
+        font-size: px(30);
418
+        padding: 0 px(20);
419
+        border-radius: px(30);
420
+    }
421
+    &__add {
422
+        background-color: #27a34f;
423
+        width: px(60);
424
+        height: px(60);
425
+        border-radius: 50%;
426
+        // box-shadow: px(1) px(2) px(6) #27A34F;
427
+        position: relative;
428
+        &::after,
429
+        &::before {
430
+            content: "";
431
+            position: absolute;
432
+            top: 50%;
433
+            left: 50%;
434
+            z-index: 1;
435
+            width: 60%;
436
+            height: px(6);
437
+            border-radius: px(6);
438
+            background: #fff;
439
+        }
440
+        &::after {
441
+            transform: translate(-50%, -50%);
442
+        }
443
+        &::before {
444
+            transform-origin: center;
445
+            transform: translate(-50%, -50%) rotate(90deg);
446
+        }
447
+    }
448
+
449
+    &__remove {
450
+        background-color: #fff;
451
+        width: px(60);
452
+        height: px(60);
453
+        border-radius: 50%;
454
+        border: 1px solid #999;
455
+        position: relative;
456
+        &::after {
457
+            content: "";
458
+            position: absolute;
459
+            top: 50%;
460
+            left: 50%;
461
+            z-index: 1;
462
+            width: 60%;
463
+            height: px(6);
464
+            border-radius: px(6);
465
+            background: #999;
466
+            transform: translate(-50%, -50%);
467
+        }
468
+    }
469
+
470
+    &__img /deep/ img {
471
+        width: px(500);
472
+        height: px(500);
473
+    }
474
+
475
+    &__title {
476
+        @include omits(2);
477
+        height: px(110);
478
+        margin: px(20);
479
+        font-size: px(40);
480
+        color: #333;
481
+    }
482
+
483
+    &__coupon {
484
+        display: inline-flex;
485
+        justify-content: center;
486
+        align-items: center;
487
+        height: px(40);
488
+        padding: 0 px(15);
489
+        margin: 0 px(20);
490
+        font-size: px(30);
491
+        color: #27a34f;
492
+        border-radius: px(20);
493
+        border: solid px(3) #27a34f;
494
+    }
495
+
496
+    &__price {
497
+        display: flex;
498
+        align-items: flex-end;
499
+        padding: 0 px(20);
500
+        margin-top: px(20);
501
+    }
502
+
503
+    &__present {
504
+        color: #000;
505
+    }
506
+
507
+    &__rmb {
508
+        font-size: px(30);
509
+    }
510
+
511
+    &__big {
512
+        font-size: px(38);
513
+    }
514
+
515
+    &__original {
516
+        position: relative;
517
+        margin-left: px(20);
518
+        font-size: px(32);
519
+        color: #999;
520
+
521
+        &:after {
522
+            content: "";
523
+            position: absolute;
524
+            top: 50%;
525
+            left: 0;
526
+            z-index: 1;
527
+            width: 100%;
528
+            height: px(1);
529
+            transform: translateY(-100%);
530
+            background-color: #999;
531
+        }
532
+    }
533
+}
534
+
535
+.more-title {
536
+    margin-top: px(60);
537
+    margin-bottom: px(30);
538
+    text-align: center;
539
+    font-size: px(50);
540
+    font-weight: bold;
541
+}
542
+.more-text {
543
+    display: flex;
544
+    justify-content: center;
545
+    padding-bottom: px(60);
546
+    font-size: px(34);
547
+    color: #999;
548
+}
549
+.null {
550
+    display: flex;
551
+    flex-direction: column;
552
+    justify-content: center;
553
+    align-items: center;
554
+    padding-top: px(115);
555
+
556
+    &__img {
557
+        width: px(741);
558
+        height: px(340);
559
+    }
560
+
561
+    &__title {
562
+        margin-top: px(60);
563
+        font-size: px(42);
564
+        color: #666;
565
+    }
566
+}
168 567
 </style>

BIN
src/static/icon/error.png