Browse Source

增加开通店铺

cr 4 years ago
parent
commit
7138dc40c4

+ 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 = http://localhost:8076
10
+VUE_APP_API_BASE_URL = http://localhost:8096
11 11
 
12 12
 # 接口请求基地址
13 13
 VUE_APP_WEBSOCKET_BASE_URL = 
14 14
 
15 15
 # 图片基地址
16
-VUE_APP_IMAGE_BASE_URL = http://localhost:8076
16
+VUE_APP_IMAGE_BASE_URL = http://localhost:8096
17 17
 VUE_APP_IMAGE_RESOURCE_URL = https://oss.ixiaokejia.com
18 18
 
19 19
 # 微信小程序appId

+ 2 - 2
a.txt

@@ -8,14 +8,14 @@ http://localhost:8076
8 8
 商家端登录密码:lqHtOkG3b3
9 9
 
10 10
 
11
-05caf6e0-9069-4da0-9d7e-92d27ce2b7be 配送员 门店下的配送人员,该人员可登录配送助
11
+05caf6e0-9069-4da0-9d7e-92d27ce2b7be 配送员 门店下的配送人员,该人员可登录手机管理端  
12 12
 26b2d3be-be4a-489f-839b-d50fdac0f2f4 客服 客服人员  
13 13
 50c41c5d-b54c-43ed-b587-10dcb60e72e5 店铺管理员 店铺管理员用户  (切换们门店)
14 14
 731d7667-d68c-4b15-9080-4a96775a5606 门店管理员 门店管理员用户  
15 15
 75b71b24-25de-40ac-a866-c8f5555b8b92 系统管理员 管理整个系统的用户  (切换们门店) 
16 16
 bfbde5df-9922-410f-bab2-158402d3d98d 财务 财务工作人员  
17 17
 c67011ac-f79c-4d0b-a7c3-24e5b8319056 运营 运营工作人员  
18
-cab1e08c-c0ca-4485-9bc9-658f866be9ae 配送员 门店下的配送人员,该人员可登录配送助
18
+cab1e08c-c0ca-4485-9bc9-658f866be9ae 配送员 门店下的配送人员,该人员可登录手机管理端  
19 19
 f68b8e48-c681-467b-af76-e1612c26d62e 主播 主播人员  
20 20
 
21 21
 分配门店时间:2020-11-27 10:23:39

+ 4 - 0
releaselog.md

@@ -1,4 +1,8 @@
1 1
 
2
+# 0.4.7 (21.03.3 18:00) 
3
+### 增加群助理
4
+
5
+
2 6
 # 0.4.6 (21.02.27 16:00) 
3 7
 ### 增加群助理
4 8
 

+ 47 - 47
src/App.vue

@@ -35,53 +35,53 @@ export default {
35 35
         console.log(user);
36 36
 
37 37
         // 判断用户是否验证团长号
38
-        if (user.roleId && user.bundleId !== 0) {
39
-        } else {
40
-            this.api
41
-                .get(
42
-                    "/Group/CheckCode",
43
-                    {
44
-                        platform: user.fromPlatform,
45
-                    },
46
-                    { pass: true }
47
-                )
48
-                .then((res) => {
49
-                    if (res.success) {
50
-                        if (res.data.verified) {
51
-                            if (!res.data.storeId) {
52
-                                this.router.push({
53
-                                    isTabBar: true,
54
-                                    path: "/pages/assistant/index",
55
-                                });
56
-                                this.fn.setTabBar([3]);
57
-                            } else {
58
-                                this.router.push({
59
-                                    isTabBar: true,
60
-                                    path: "/pages/index/index",
61
-                                });
62
-                                this.fn.setTabBar([1, 2]);
63
-                            }
64
-                        } else {
65
-                            this.router.push({
66
-                                path: "/pages/index/register",
67
-                                query: {
68
-                                    pidCode: res.data.code,
69
-                                    step: 3,
70
-                                },
71
-                            });
72
-                            this.fn.setTabBar([3]);
73
-                        }
74
-                    } else {
75
-                        this.router.push({
76
-                            path: "/pages/index/register",
77
-                            query: {
78
-                                step: 2,
79
-                            },
80
-                        });
81
-                        this.fn.setTabBar([3]);
82
-                    }
83
-                });
84
-        }
38
+        // if (user.roleId && user.bundleId !== 0) {
39
+        // } else {
40
+        //     this.api
41
+        //         .get(
42
+        //             "/Group/CheckCode",
43
+        //             {
44
+        //                 platform: user.fromPlatform,
45
+        //             },
46
+        //             { pass: true }
47
+        //         )
48
+        //         .then((res) => {
49
+        //             if (res.success) {
50
+        //                 if (res.data.verified) {
51
+        //                     if (!res.data.storeId) {
52
+        //                         this.router.push({
53
+        //                             isTabBar: true,
54
+        //                             path: "/pages/assistant/index",
55
+        //                         });
56
+        //                         this.fn.setTabBar([3]);
57
+        //                     } else {
58
+        //                         this.router.push({
59
+        //                             isTabBar: true,
60
+        //                             path: "/pages/index/index",
61
+        //                         });
62
+        //                         this.fn.setTabBar([1, 2]);
63
+        //                     }
64
+        //                 } else {
65
+        //                     this.router.push({
66
+        //                         path: "/pages/index/register",
67
+        //                         query: {
68
+        //                             pidCode: res.data.code,
69
+        //                             step: 3,
70
+        //                         },
71
+        //                     });
72
+        //                     this.fn.setTabBar([3]);
73
+        //                 }
74
+        //             } else {
75
+        //                 this.router.push({
76
+        //                     path: "/pages/index/register",
77
+        //                     query: {
78
+        //                         step: 2,
79
+        //                     },
80
+        //                 });
81
+        //                 this.fn.setTabBar([3]);
82
+        //             }
83
+        //         });
84
+        // }
85 85
     },
86 86
 
87 87
     onShow: async function (option) {

+ 43 - 17
src/components/wyg-bottom-tab/wyg-bottom-tab.vue

@@ -2,9 +2,8 @@
2 2
     <view class="bottom-tab">
3 3
         <block v-for="(item, index) in tabList" :key="index">
4 4
             <view
5
-                v-if="!item.hide"
6 5
                 class="bottom-tab-item"
7
-                :class="{ one: itemShowNum === 1,two: itemShowNum === 2 }"
6
+                :class="{ one: itemShowNum === 1, two: itemShowNum === 2 }"
8 7
                 @click="changeTap(item)"
9 8
             >
10 9
                 <image
@@ -38,16 +37,15 @@ export default {
38 37
             //图片的尺寸
39 38
             type: String,
40 39
             default: "1",
41
-        }
40
+        },
42 41
     },
43 42
     data() {
44 43
         return {
45
-            curTab: 1
44
+            curTab: 1,
46 45
         };
47 46
     },
48 47
     created() {
49 48
         this.curTab = new Number(this.tabIndex);
50
-
51 49
     },
52 50
     methods: {
53 51
         $redirect(_url) {
@@ -66,21 +64,49 @@ export default {
66 64
         },
67 65
     },
68 66
     computed: {
69
-        tabList(){
67
+        tabList() {
68
+            // let page = getCurrentPages();
69
+            // let curPage = page[page.length-1];
70
+            // console.log(curPage.route,this.$store.state.common.tabList,234)
71
+            // if(curPage.route === 'pages/index/index'){
72
+            //     for(let item of this.$store.state.common.tabList){
73
+            //         if(item.url === '/pages/index/index' && item.hide){
74
+            //             this.router.push({
75
+            //                 path:'/pages/assistant/index',
76
+            //                 isTabBar:true
77
+            //             })
78
+            //         }
79
+            //     }
80
+            // }
81
+
70 82
             let page = getCurrentPages();
71
-            let curPage = page[page.length-1];
72
-            console.log(curPage.route,this.$store.state.common.tabList,234)
73
-            if(curPage.route === 'pages/index/index'){
74
-                for(let item of this.$store.state.common.tabList){
75
-                    if(item.url === '/pages/index/index' && item.hide){
76
-                        this.router.push({
77
-                            path:'/pages/assistant/index',
78
-                            isTabBar:true
79
-                        })
83
+            let curPage = page[page.length - 1];
84
+            let tabList = this.$store.state.common.tabList;
85
+            let user = this.$store.state.user.user;
86
+
87
+            if (
88
+                curPage.route === "pages/index/index" ||
89
+                curPage.route === "pages/manage/index"
90
+            ) {
91
+                if (user.roleId && user.bundleId !== 0) {
92
+                } else {
93
+                    this.router.push({
94
+                        path: "/pages/guide/index",
95
+                        isTabBar: true,
96
+                    });
97
+                }
98
+            }
99
+
100
+            if (user.roleId && user.bundleId !== 0) {
101
+            } else {
102
+                tabList = JSON.parse(JSON.stringify(tabList));
103
+                for (let item of tabList) {
104
+                    if (item.id === 1 || item.id === 2) {
105
+                        item.url = "/pages/guide/index";
80 106
                     }
81 107
                 }
82 108
             }
83
-            return this.$store.state.common.tabList;
109
+            return tabList;
84 110
         },
85 111
         itemShowNum() {
86 112
             let i = 0;
@@ -122,7 +148,7 @@ export default {
122 148
         &.one {
123 149
             width: 100%;
124 150
         }
125
-        &.two{
151
+        &.two {
126 152
             width: 50%;
127 153
         }
128 154
 

+ 1 - 1
src/manifest.json

@@ -1,5 +1,5 @@
1 1
 {
2
-    "name" : "配送助手",
2
+    "name" : "手机管理端",
3 3
     "appid" : "__UNI__F283109",
4 4
     "description" : "",
5 5
     "versionName" : "1.0.0",

+ 20 - 2
src/pages.json

@@ -1,6 +1,6 @@
1 1
 {
2 2
     "globalStyle": {
3
-        "navigationBarTitleText": "配送助手",
3
+        "navigationBarTitleText": "手机管理端",
4 4
         "navigationBarTextStyle": "black",
5 5
         "navigationBarBackgroundColor": "#fff",
6 6
         "backgroundColor": "#fff"
@@ -35,6 +35,12 @@
35 35
                 "pagePath": "pages/index/login",
36 36
                 "iconPath": "static/tabBar/icon_green_4.png",
37 37
                 "selectedIconPath": "static/tabBar/icon_green_4_select.png"
38
+            },
39
+            {
40
+                "text": "开通店铺",
41
+                "pagePath": "pages/guide/index",
42
+                "iconPath": "static/tabBar/icon_green_4.png",
43
+                "selectedIconPath": "static/tabBar/icon_green_4_select.png"
38 44
             }
39 45
         ]
40 46
     },
@@ -42,7 +48,7 @@
42 48
         {
43 49
             "path": "pages/index/index",
44 50
             "style": {
45
-                "navigationBarTitleText": "配送助手"
51
+                "navigationBarTitleText": "手机管理端"
46 52
             }
47 53
         },
48 54
         {
@@ -359,6 +365,18 @@
359 365
             "style": {
360 366
                 "navigationBarTitleText": "找回密码"
361 367
             }
368
+        },
369
+        {
370
+            "path": "pages/guide/index",
371
+            "style": {
372
+                "navigationBarTitleText": "申请店铺"
373
+            }
374
+        },
375
+        {
376
+            "path": "pages/guide/form",
377
+            "style": {
378
+                "navigationBarTitleText": "申请店铺"
379
+            }
362 380
         }
363 381
     ]
364 382
 }

+ 48 - 43
src/pages/assistant/index.vue

@@ -1,51 +1,51 @@
1 1
 <template>
2 2
     <div class="page tabbar-page">
3
-        <div class="filter">
4
-            <ul class="date-list">
5
-                <li @click="tabClick(0)" :class="{ on: tabIndex === 0 }">
6
-                    我的群
7
-                </li>
8
-                <li @click="tabClick(1)" :class="{ on: tabIndex === 1 }">
9
-                    我的平台
10
-                </li>
3
+        <div class="page-main">
4
+            <div class="filter">
5
+                <ul class="date-list">
6
+                    <li @click="tabClick(0)" :class="{ on: tabIndex === 0 }">
7
+                        我的群
8
+                    </li>
9
+                    <li @click="tabClick(1)" :class="{ on: tabIndex === 1 }">
10
+                        我的平台
11
+                    </li>
12
+                </ul>
13
+            </div>
14
+            <!-- 群 -->
15
+            <ul class="group-list" v-if="tabIndex === 0">
16
+                <block v-for="data of dataList" :key="data._id">
17
+                    <li class="item" @click="jumpGroup(data)">
18
+                        <div class="name">
19
+                            {{ data.name | maxTit }}
20
+                        </div>
21
+                        <my-image
22
+                            class="arrow"
23
+                            src="/static/common/arrows_left.png"
24
+                        ></my-image>
25
+                    </li>
26
+                </block>
11 27
             </ul>
12
-        </div>
13
-        <!-- 群 -->
14
-        <ul class="group-list" v-if="tabIndex === 0">
15
-            <block v-for="data of dataList" :key="data._id">
16
-                <li class="item" @click="jumpGroup(data)">
28
+
29
+            <!-- 平台 -->
30
+            <ul class="group-list" v-if="tabIndex === 1">
31
+                <li
32
+                    class="item"
33
+                    v-for="item of platformList"
34
+                    :key="item.name"
35
+                    @click="jumpPlatform(item)"
36
+                >
17 37
                     <div class="name">
18
-                        {{ data.name | maxTit }}
38
+                        {{ item.name | maxTit }}
19 39
                     </div>
20 40
                     <my-image
21 41
                         class="arrow"
22 42
                         src="/static/common/arrows_left.png"
23 43
                     ></my-image>
24 44
                 </li>
25
-            </block>
26
-        </ul>
27
-
28
-        <!-- 平台 -->
29
-        <ul class="group-list" v-if="tabIndex === 1">
30
-            <li
31
-                class="item"
32
-                v-for="item of platformList"
33
-                :key="item.name"
34
-                @click="jumpPlatform(item)"
35
-            >
36
-                <div class="name">
37
-                    {{ item.name | maxTit }}
38
-                </div>
39
-                <my-image
40
-                    class="arrow"
41
-                    src="/static/common/arrows_left.png"
42
-                ></my-image>
43
-            </li>
44
-        </ul>
45
-        
46
-        <div class="layout"  @click="layout">
47
-            退出登录
45
+            </ul>
48 46
         </div>
47
+
48
+        <div class="layout" @click="layout">退出登录</div>
49 49
         <wyg-bottom-tab
50 50
             ref="tabbar"
51 51
             :tabIndex="3"
@@ -147,7 +147,6 @@ export default {
147 147
         addGroup() {},
148 148
 
149 149
         jumpGroup(val) {
150
-            
151 150
             this.$store.commit("common/update", {
152 151
                 groupData: val,
153 152
             });
@@ -155,8 +154,8 @@ export default {
155 154
                 path: "/pages/assistant/setting",
156 155
             });
157 156
         },
158
-        jumpPlatform(val){
159
-            console.log(val)
157
+        jumpPlatform(val) {
158
+            console.log(val);
160 159
             this.$store.commit("common/update", {
161 160
                 platformData: val,
162 161
             });
@@ -182,12 +181,19 @@ export default {
182 181
     },
183 182
 
184 183
     // 数据监听
185
-    watch: {}
184
+    watch: {},
186 185
 };
187 186
 </script>
188 187
 
189 188
 
190 189
 <style lang="scss" scoped>
190
+.tabbar-page {
191
+    height: 100vh;
192
+}
193
+.page-main{
194
+    overflow: auto;
195
+    max-height: 100%;
196
+}
191 197
 .filter {
192 198
     padding: px(30);
193 199
 }
@@ -247,7 +253,7 @@ export default {
247 253
     background-color: rgb(0, 188, 38);
248 254
     font-size: px(44);
249 255
 }
250
-.layout{
256
+.layout {
251 257
     color: #666;
252 258
     position: fixed;
253 259
     bottom: 3.5rem;
@@ -257,7 +263,6 @@ export default {
257 263
     font-size: px(44);
258 264
     text-align: center;
259 265
     height: px(80);
260
-
261 266
 }
262 267
 .page {
263 268
     padding-bottom: 6rem;

+ 508 - 0
src/pages/guide/form.vue

@@ -0,0 +1,508 @@
1
+<template>
2
+    <div class="page" :class="{ 'page--iphoneX': iphoneX }">
3
+        <div class="form-card">
4
+            <section class="form-item">
5
+                <div class="label">
6
+                    <span class="required">*</span>
7
+                    店铺名称:
8
+                </div>
9
+                <div class="box">
10
+                    <input
11
+                        type="text"
12
+                        v-model="form.appName"
13
+                        placeholder="请填写店铺名称"
14
+                    />
15
+                </div>
16
+            </section>
17
+            <section class="form-item">
18
+                <div class="label">
19
+                    <span class="required">*</span>
20
+                    联系方式:
21
+                </div>
22
+                <div class="box">
23
+                    <input
24
+                        type="text"
25
+                        v-model="form.mobile"
26
+                        placeholder="请填写联系方式"
27
+                    />
28
+                </div>
29
+            </section>
30
+            <section class="form-item">
31
+                <div class="label">
32
+                    <span class="required">*</span>
33
+                    姓名:
34
+                </div>
35
+                <div class="box">
36
+                    <input
37
+                        type="text"
38
+                        v-model="form.name"
39
+                        placeholder="请填写姓名"
40
+                    />
41
+                </div>
42
+            </section>
43
+            <section class="form-item">
44
+                <div class="label">
45
+                    <span class="required">*</span>
46
+                    提货点地址:
47
+                </div>
48
+                <div class="box" @click="mapClick">
49
+                    <input
50
+                        type="text"
51
+                        v-model="form.pickUpAddress"
52
+                        :disabled="true"
53
+                        placeholder="请选择地址"
54
+                    />
55
+                </div>
56
+                <div class="tool" @click="mapClick">
57
+                    <my-image
58
+                        class="address-icon"
59
+                        src="/static/common/address.png"
60
+                    ></my-image>
61
+                </div>
62
+            </section>
63
+            <section class="form-item">
64
+                <div class="label">
65
+                    <span class="required">*</span>
66
+                    详细地址:
67
+                </div>
68
+                <div class="box">
69
+                    <input
70
+                        type="text"
71
+                        v-model="form.address"
72
+                        placeholder="请填写详细地址"
73
+                    />
74
+                </div>
75
+            </section>
76
+            <!-- <section class="form-item">
77
+                <div class="label">
78
+                    <span class="required">*</span>
79
+                    身份证照 (正反面):
80
+                </div>
81
+                <div class="box">
82
+                    <easy-upload
83
+                        :types="'image'"
84
+                        v-model="mainImage"
85
+                        :uploadCount="2"
86
+                        @change="minImgChange"
87
+                    ></easy-upload>
88
+                </div>
89
+            </section>
90
+            <section class="form-item">
91
+                <div class="label">
92
+                    店铺营业执照:
93
+                </div>
94
+                <div class="box">
95
+                    <easy-upload
96
+                        :types="'image'"
97
+                        v-model="mainImage2"
98
+                        :uploadCount="1"
99
+                        @change="minImgChange2"
100
+                    ></easy-upload>
101
+                </div>
102
+            </section>
103
+            <section class="form-item">
104
+                <div class="label">食品许可证:</div>
105
+                <div class="box">
106
+                    <easy-upload
107
+                        :types="'image'"
108
+                        v-model="mainImage3"
109
+                        :uploadCount="1"
110
+                        @change="minImgChange3"
111
+                    ></easy-upload>
112
+                </div>
113
+            </section> -->
114
+            <section class="form-item">
115
+                <div class="label">
116
+                    <!-- <span class="required">*</span> -->
117
+                    推荐人:
118
+                </div>
119
+                <div class="box">
120
+                    <input type="text" v-model="form.recommendName" />
121
+                </div>
122
+            </section>
123
+            <section class="form-item">
124
+                <div class="label">
125
+                    <!-- <span class="required">*</span> -->
126
+                    邀请码:
127
+                </div>
128
+                <div class="box">
129
+                    <input type="text" v-model="form.invitedCode" />
130
+                </div>
131
+            </section>
132
+        </div>
133
+        <div class="btns">
134
+            <div class="btn" @click="saveOk">保存</div>
135
+        </div>
136
+    </div>
137
+</template>
138
+
139
+<script>
140
+import MyImage from "../../components/image/index";
141
+import DateTimePicker from "../../components/biaofun-datetime-picker/biaofun-datetime-picker";
142
+import easyUpload from "../../components/easy-upload/easy-upload";
143
+
144
+export default {
145
+    name: "",
146
+    components: { MyImage, DateTimePicker, easyUpload },
147
+    // 数据
148
+    data() {
149
+        return {
150
+            form: {
151
+                appName: "",
152
+                mobile: "",
153
+                name: "",
154
+                pickUpAddress: "",
155
+                address: "",
156
+                foodLicense: "",
157
+                businessLicense: "",
158
+                iDCard: "",
159
+                recommendName: "",
160
+                invitedCode: "",
161
+            },
162
+            mainImage: [],
163
+            mainImage2: [],
164
+            mainImage3: [],
165
+            submitLoading: false,
166
+        };
167
+    },
168
+
169
+    onLoad(opts) {},
170
+
171
+    onShow() {},
172
+
173
+    // 函数
174
+    methods: {
175
+        mapClick() {
176
+            let self = this;
177
+            // 判断定位权限
178
+            uni.getSetting({
179
+                success: function (res) {
180
+                    if (res.authSetting["scope.userLocation"] === false) {
181
+                        self.fn
182
+                            .showModal({
183
+                                content: "请授权位置信息后使用",
184
+                                showCancel: false,
185
+                            })
186
+                            .then((res) => {
187
+                                uni.openSetting({});
188
+                            });
189
+                    } else {
190
+                        self.userLocation = true;
191
+                        self.chooseLocation();
192
+                    }
193
+                },
194
+            });
195
+        },
196
+
197
+        chooseLocation() {
198
+            let self = this;
199
+            uni.chooseLocation({
200
+                type: "gcj02", //返回可以用于uni.openLocation的经纬度
201
+                success: function (res) {
202
+                    self.form.pickUpAddress = res.address;
203
+                    console.log("定位ok", res);
204
+                },
205
+                fail(e) {
206
+                    console.log("定位no", e);
207
+                },
208
+            });
209
+        },
210
+
211
+        minImgChange(e) {
212
+            this.form.iDCard = e;
213
+        },
214
+        minImgChange2(e) {
215
+            this.form.businessLicense = e[0] || "";
216
+        },
217
+        minImgChange3(e) {
218
+            this.form.foodLicense = e[0] || "";
219
+        },
220
+        saveOk() {
221
+            if (this.submitLoading) {
222
+                return;
223
+            }
224
+            if (!this.form.appName) {
225
+                return this.fn.showToast("请输入店铺名称");
226
+            }
227
+            if (!this.form.mobile) {
228
+                return this.fn.showToast("请输入联系方式");
229
+            }
230
+            if (!this.form.name) {
231
+                return this.fn.showToast("请输入姓名");
232
+            }
233
+            if (!this.form.pickUpAddress) {
234
+                return this.fn.showToast("请选择提货地址");
235
+            }
236
+            if (!this.form.address) {
237
+                return this.fn.showToast("请输入详细地址");
238
+            }
239
+            // if (!this.form.iDCard) {
240
+            //     return this.fn.showToast("请上传身份证照");
241
+            // }
242
+            // if (this.form.iDCard.length !== 2) {
243
+            //     return this.fn.showToast("请分别上传身份证照正反面");
244
+            // }
245
+            this.submitLoading = true;
246
+            uni.showLoading({
247
+                title: "提交中...",
248
+            });
249
+            let data = { ...this.form };
250
+            this.api
251
+                .post("/Shop/SubmitApply", data, { pass: true })
252
+                .then((res) => {
253
+                    this.submitLoading = false;
254
+                    uni.hideLoading();
255
+                    if (res.success) {
256
+                        this.fn.showToast("保存成功");
257
+                        let user = this.$store.state.user.user;
258
+                        user.storeStatus = 2;
259
+                        this.$store.commit("user/update", {
260
+                            user,
261
+                        });
262
+                        this.router.back();
263
+                    } else {
264
+                        this.fn.showModal({
265
+                            content:
266
+                                "错误码:" +
267
+                                res.code +
268
+                                ",错误信息:" +
269
+                                res.message,
270
+                            showCancel: false,
271
+                        });
272
+                    }
273
+                });
274
+        },
275
+    },
276
+
277
+    // 数据计算
278
+    computed: {},
279
+
280
+    // 数据监听
281
+    watch: {},
282
+};
283
+</script>
284
+
285
+
286
+<style lang="scss" scoped>
287
+.page {
288
+    padding-bottom: px(120);
289
+    min-height: 100vh;
290
+    background-color: #fff;
291
+}
292
+.page--iphoneX {
293
+    padding-bottom: px(150);
294
+    .btn {
295
+        padding-bottom: px(30);
296
+        background-color: rgb(0, 188, 38);
297
+    }
298
+}
299
+.form-card {
300
+    background-color: #fff;
301
+    padding: 0 px(30);
302
+    & ~ .form-card {
303
+        margin-top: px(25);
304
+    }
305
+    .head {
306
+        display: flex;
307
+        align-items: center;
308
+        justify-content: space-between;
309
+        height: px(140);
310
+        background-color: #fbfbfb;
311
+        border-bottom: 1px solid #f1f1f1;
312
+        border-top: 1px solid #f1f1f1;
313
+        font-size: px(44);
314
+    }
315
+}
316
+.form-item {
317
+    display: flex;
318
+    min-height: px(140);
319
+    padding: px(30) 0;
320
+    box-sizing: border-box;
321
+    align-items: center;
322
+    font-size: px(44);
323
+    border-top: 1px solid #f1f1f1;
324
+    &.dis-item {
325
+        color: #999;
326
+        background: #f9f9f9;
327
+    }
328
+    .label {
329
+        width: px(280);
330
+        flex-shrink: 0;
331
+        color: #999;
332
+        margin-right: px(10);
333
+    }
334
+    .box {
335
+        width: 100%;
336
+        position: relative;
337
+        input {
338
+            width: 100%;
339
+        }
340
+    }
341
+    .tool {
342
+        flex-shrink: 0;
343
+        color: #999;
344
+        margin-left: px(10);
345
+    }
346
+    textarea,
347
+    input {
348
+        max-width: 100%;
349
+        width: 100%;
350
+    }
351
+}
352
+.list {
353
+    // min-height: 100vh;
354
+    // background-color: #fff;
355
+    // border-bottom: 1px solid #f1f1f1;
356
+    li {
357
+        padding: px(0) px(35);
358
+        height: px(140);
359
+        line-height: px(140);
360
+        font-size: px(44);
361
+        border-top: 1px solid #f1f1f1;
362
+        display: flex;
363
+        justify-content: space-between;
364
+        align-items: center;
365
+    }
366
+    .tools {
367
+        display: flex;
368
+        align-items: center;
369
+        flex-shrink: 0;
370
+        span {
371
+            display: inline-block;
372
+            border: 1px solid #f1f1f1;
373
+            font-size: px(36);
374
+            height: px(80);
375
+            width: px(120);
376
+            display: flex;
377
+            justify-content: center;
378
+            align-items: center;
379
+            & ~ span {
380
+                margin-left: px(30);
381
+            }
382
+        }
383
+        .remove {
384
+            color: #f00;
385
+        }
386
+    }
387
+}
388
+.btn {
389
+    width: 100%;
390
+    height: px(120);
391
+    background-color: rgb(0, 188, 38);
392
+    color: #fff;
393
+    display: flex;
394
+    align-items: center;
395
+    justify-content: center;
396
+}
397
+.btns {
398
+    position: fixed;
399
+    bottom: 0;
400
+    left: 0;
401
+    right: 0;
402
+    z-index: 100;
403
+}
404
+.layout {
405
+    background-color: #eee;
406
+    color: #666;
407
+}
408
+.add-btn {
409
+    height: px(120);
410
+    color: #333;
411
+    display: flex;
412
+    align-items: center;
413
+    justify-content: center;
414
+    margin: px(50) px(35) 0;
415
+    border: 1px solid #ccc;
416
+    border-radius: px(10);
417
+}
418
+.code-tool {
419
+    display: flex;
420
+    justify-content: flex-start;
421
+    align-items: center;
422
+    .scan-img {
423
+        flex-shrink: 0;
424
+        width: px(80);
425
+        height: px(80);
426
+        /deep/ img {
427
+            width: px(80);
428
+            height: px(80);
429
+        }
430
+    }
431
+    .generate {
432
+        color: #0097d1;
433
+        margin-right: px(30);
434
+        flex-shrink: 0;
435
+    }
436
+}
437
+.required {
438
+    color: #f00;
439
+    font-size: px(44);
440
+    &.hide {
441
+        visibility: hidden;
442
+    }
443
+}
444
+.inp-dis {
445
+    color: #999;
446
+}
447
+
448
+.img-card {
449
+    padding-top: px(30);
450
+    padding-bottom: px(30);
451
+}
452
+.form-img-item {
453
+    .tit {
454
+        padding: px(30);
455
+        font-size: px(44);
456
+    }
457
+}
458
+
459
+.spec-list {
460
+    width: 100%;
461
+    display: flex;
462
+    justify-content: space-between;
463
+    align-items: center;
464
+    li {
465
+        width: 33.333333%;
466
+        font-size: px(40);
467
+        height: px(100);
468
+        border: 1px solid #f1f1f1;
469
+        display: flex;
470
+        align-items: center;
471
+        justify-content: center;
472
+        color: #999;
473
+        & ~ li {
474
+            // border-left: none;
475
+        }
476
+        &.on {
477
+            color: rgb(0, 188, 38);
478
+            border-color: rgb(0, 188, 38);
479
+        }
480
+    }
481
+}
482
+.mo-date {
483
+    margin-top: px(20);
484
+    border-bottom: 1px solid #f1f1f1;
485
+    background: #fbfbfb;
486
+    font-size: px(40);
487
+    padding: px(10);
488
+}
489
+.n-date-box {
490
+    margin-top: px(20);
491
+    font-size: px(40);
492
+}
493
+.n-date {
494
+    border-bottom: 1px solid #f1f1f1;
495
+    background: #fbfbfb;
496
+    padding: 0 px(20);
497
+    display: inline-block;
498
+    width: px(200);
499
+    font-size: px(44);
500
+    vertical-align: bottom;
501
+}
502
+.address-icon {
503
+    /deep/ img {
504
+        width: px(60);
505
+        height: px(60);
506
+    }
507
+}
508
+</style>

+ 144 - 0
src/pages/guide/index.vue

@@ -0,0 +1,144 @@
1
+<template>
2
+    <div class="page tabbar-page">
3
+        <div v-if="!loading">
4
+            <h2 class="tit1">您还没有开通店铺,无法使用该模块</h2>
5
+            <h1 class="tit2">开通店铺您可以</h1>
6
+            <div class="box">
7
+                <ul class="list">
8
+                    <li>
9
+                        <span class="index">1、</span>
10
+                        在店铺和群内销售您自己的门店的商品
11
+                    </li>
12
+                    <li><span class="index">2、</span> 在群内开启签到送积分</li>
13
+                    <li>
14
+                        <span class="index">3、</span>
15
+                        在群内开启邀请好友入群送积分
16
+                    </li>
17
+                    <li>
18
+                        <span class="index">4、</span>
19
+                        用户群内获取的积分可以在店铺使用
20
+                    </li>
21
+                </ul>
22
+            </div>
23
+            <button class="btn" @click="jump('/pages/guide/form')">
24
+                立即申请
25
+            </button>
26
+        </div>
27
+        <div class="load" v-if="loading">
28
+            <!-- 待审核 -->
29
+            <block v-if="user.storeStatus === 2">
30
+                <h1 class="tit2">提交成功</h1>
31
+                <div class="text">
32
+                    您的店铺开通申请提交成功,在审核通过后,我们将为您开通店铺并通知
33
+                </div>
34
+            </block>
35
+        </div>
36
+        <wyg-bottom-tab ref="tabbar"></wyg-bottom-tab>
37
+    </div>
38
+</template>
39
+
40
+<script>
41
+import MyImage from "../../components/image/index";
42
+import wygBottomTab from "../../components/wyg-bottom-tab/wyg-bottom-tab";
43
+
44
+export default {
45
+    name: "",
46
+    components: { MyImage, wygBottomTab },
47
+    // 数据
48
+    data() {
49
+        return {
50
+            loading: false,
51
+        };
52
+    },
53
+    filters: {},
54
+    onLoad() {},
55
+    async onShow() {
56
+        if (this.user.storeStatus ===2) {
57
+            this.loading = true;
58
+        } else {
59
+            this.loading = false;
60
+        }
61
+        this.$refs.tabbar.setIndex(2);
62
+    },
63
+
64
+    // onPullDownRefresh() {
65
+    //     this.getList();
66
+    // },
67
+
68
+    // 函数
69
+    methods: {},
70
+
71
+    // 数据计算
72
+    computed: {
73
+        user() {
74
+            return this.$store.state.user.user;
75
+        },
76
+    },
77
+
78
+    // 数据监听
79
+    watch: {},
80
+};
81
+</script>
82
+
83
+
84
+<style lang="scss" scoped>
85
+.page {
86
+    padding-bottom: 2rem;
87
+    padding-top: px(250);
88
+    min-height: 100vh;
89
+    background-color: #fff;
90
+}
91
+.btn {
92
+    position: fixed;
93
+    bottom: 3rem;
94
+    left: 0;
95
+    right: 0;
96
+    z-index: 10;
97
+    color: #fff;
98
+    background-color: rgb(0, 188, 38);
99
+    font-size: px(44);
100
+    border-radius: 0;
101
+}
102
+.tit1 {
103
+    font-size: px(48);
104
+    font-weight: bold;
105
+    // color: rgb(0, 188, 38);
106
+    padding-bottom: px(40);
107
+    text-align: center;
108
+}
109
+.tit2 {
110
+    font-size: px(54);
111
+    font-weight: bold;
112
+    // color: rgb(0, 188, 38);
113
+    padding-bottom: px(120);
114
+    text-align: center;
115
+}
116
+.box {
117
+    border: 1px solid rgb(0, 188, 38);
118
+    padding: px(60) px(40);
119
+    margin: 0 px(80);
120
+    li {
121
+        font-size: px(44);
122
+        .index {
123
+            color: red;
124
+        }
125
+    }
126
+    li ~ li {
127
+        padding-top: px(50);
128
+    }
129
+}
130
+.load {
131
+    height: 100%;
132
+    padding-top: px(300);
133
+    .text {
134
+        width: px(700);
135
+        margin: 0 auto;
136
+        line-height: 1.6;
137
+        text-align: center;
138
+        font-size: px(44);
139
+    }
140
+}
141
+.link {
142
+    color: #409eff;
143
+}
144
+</style>

+ 2 - 2
src/pages/index/register.vue

@@ -66,9 +66,9 @@
66 66
             </div>
67 67
             <button class="btn" @click="saveTeamNum">下一步</button>
68 68
             <div class="team-num-des">
69
-                <h1 class="tit">在哪里看京东团长号?</h1>
69
+                <h1 class="tit">在哪里看京东区区购团长号?</h1>
70 70
                 <p class="text">
71
-                    在京东店长版后台,个人中心,点击头像进去就可以看到
71
+                    在京东区区购店长版后台,个人中心,点击头像进去就可以看到
72 72
                 </p>
73 73
                 <div class="video">
74 74
                     <video

+ 2 - 1
src/pages/manage/index.vue

@@ -62,7 +62,7 @@
62 62
 
63 63
         <button class="btn" @click="layout">退出登录</button>
64 64
 
65
-        <div class="ver">0.4.67</div>
65
+        <div class="ver">0.4.7</div>
66 66
         <wyg-bottom-tab ref="tabbar" :tabIndex="2" :tabListParent="tabList"></wyg-bottom-tab>
67 67
     </div>
68 68
 </template>
@@ -82,6 +82,7 @@ export default {
82 82
             shopErr: false,
83 83
             menuList: [],
84 84
             menuLoading: true,
85
+            loading:false,
85 86
         };
86 87
     },
87 88
 

BIN
src/static/common/address.png