戴艳蓉 3 anos atrás
pai
commit
cdbc460c11

Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/index.html


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/css/chunk-207c2a82.6d04cee7.css


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/css/chunk-2856d57d.1f14ee9a.css


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/css/chunk-448e9a62.da80477c.css


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/css/chunk-ce4fa5b4.fe12eee2.css


+ 1 - 0
dist/static/css/chunk-f9f144da.70b4c72f.css

@@ -0,0 +1 @@
+.reset[data-v-5b089d35]{position:relative;width:100%;height:100%;-webkit-box-sizing:border-box;box-sizing:border-box;background:#e6e6dc!important}.reset .reset-box[data-v-5b089d35]{width:calc(100% - 32px);margin:0 16px!important;overflow:hidden!important;border-radius:10px!important}.reset .reset-box .van-field__label[data-v-5b089d35]{margin:0!important}.reset .btn-box[data-v-5b089d35]{margin:30px 5% 0 5%}.reset .btn-box .van-button[data-v-5b089d35]{background:-webkit-gradient(linear,left bottom,left top,from(#a67e4b),to(#efc180));background:linear-gradient(0deg,#a67e4b,#efc180);border-radius:22px;overflow:hidden;color:#fff;border:0;font-weight:bolder}

Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/app.22aa301c.js


BIN
dist/static/js/app.22aa301c.js.gz


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/app.bf169ebf.js


BIN
dist/static/js/app.bf169ebf.js.gz


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/chunk-207c2a82.69df9584.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/chunk-2856d57d.cd260586.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/chunk-448e9a62.980d1447.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/chunk-ce4fa5b4.f3c3074e.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/static/js/chunk-f9f144da.b44bfcfd.js


+ 7 - 1
src/router/index.js

@@ -5,11 +5,17 @@ const routes = [
         path: "/",
         redirect: "/login"
     },
-    //默认跳转到登录页
+    // //默认跳转到登录页
     {
         path: '/login',
         component: () => import('@/views/login/index'),
         hidden: true
+    },
+     //重置密码
+     {
+        path: '/reset',
+        component: () => import('@/views/reset/index'),
+        hidden: true
     },
     {
         path: '/home',

+ 9 - 4
src/views/login/index.vue

@@ -63,7 +63,7 @@
           </van-form>
         </div>
       </div>
-      <div class="login-form-button">
+      <div class="login-form-button clear">
         <van-button
           block
           type="info"
@@ -75,6 +75,7 @@
         >
           登&nbsp;录
         </van-button>
+        <!-- <span class="fr reset-span" @click="loginSuccess('/reset')">重置密码</span> -->
       </div>
     </div>
   </div>
@@ -122,7 +123,7 @@ export default {
                       .then((res) => {
                         this.loadding = false;
                         if (res.code === 0) {
-                          this.loginSuccess();
+                          this.loginSuccess("/home/paddy");
                         } else {
                           this.show_title(res.msg);
                         }
@@ -148,9 +149,9 @@ export default {
           });
       }
     },
-    async loginSuccess(data) {
+    async loginSuccess(path) {
       window.vm.$router.push({
-        path: "/home/paddy",
+        path: path,
       });
     },
 
@@ -367,6 +368,10 @@ export default {
         border: 0;
         font-weight: bolder;
       }
+      .reset-span{
+        padding:10px;
+        color: #454545;
+      }
     }
   }
 }

+ 24 - 4
src/views/paddy/index.vue

@@ -7,7 +7,7 @@
         indicator-color="#DAAD71"
         @change="onChange"
       >
-        <van-swipe-item >
+        <van-swipe-item>
           <img
             src="@/assets/images/home/swipper/swipper1.png"
             alt=""
@@ -85,7 +85,7 @@
       <div class="middle-div clear">
         <ul>
           <li
-            v-for="(item, index) in list"
+            v-for="(item, index) in list1"
             :key="item.title + index"
             @click="goto(index === 0 ? '/live' : '/introduce', index + 3)"
             :class="{ left: index === 0 || index === 3, he: index === 0 }"
@@ -104,6 +104,24 @@
             </div>
           </li>
         </ul>
+        <ul>
+          <li
+            v-for="(item, index) in list2"
+            :key="item.title + index"
+            @click="goto('/introduce', index + 6)"
+            :class="{ left: index === 0, right: index !== 0 }"
+          >
+            <div class="first">
+              <div class="title">{{ item.title }}</div>
+              <div class="desc" v-for="test in item.desc" :key="test + index">
+                {{ test }}
+              </div>
+            </div>
+            <div class="second">
+              <img :src="item.img" alt="" />
+            </div>
+          </li>
+        </ul>
       </div>
     </div>
     <div class="bottom">
@@ -142,7 +160,7 @@ export default {
         },
       ],
       more: require("@/assets/images/home/more.png"),
-      list: [
+      list1: [
         {
           title: "实时监控",
           desc: ["全程溯源", "信赖保证"],
@@ -158,6 +176,8 @@ export default {
           desc: ["现磨现发", "随享鲜香"],
           img: require("@/assets/images/home/middle/freshRice.png"),
         },
+      ],
+      list2: [
         {
           title: "自然耕种",
           desc: ["农耕记忆", "山水乡愁"],
@@ -439,7 +459,7 @@ export default {
             .first {
               padding: 7px 0 0 0;
               .title {
-                font-size: 15px;
+                font-size: 14px;
                 line-height: 30px;
                 height: 30px;
                 margin: 0 0 5px 0;

+ 277 - 0
src/views/reset/index.vue

@@ -0,0 +1,277 @@
+<template>
+  <div class="reset" style="padding-top: 46px">
+    <van-nav-bar
+      class="van-nav-bar-my-fixed"
+      :title="'重置密码'"
+      fixed
+      left-arrow
+      @click-left="onClickLeft"
+    />
+    <div class="reset-box">
+      <van-cell-group>
+        <van-field
+          v-model="form.mobile"
+          label-width="62px"
+          label="卡号"
+          placeholder="卡号"
+          :rules="[{ validator: asyncmobileValidator }]"
+        />
+      </van-cell-group>
+
+      <van-cell-group>
+        <van-field
+          v-model="form.code"
+          label-width="62px"
+          label="原密码"
+          placeholder="原密码"
+          :rules="[{ validator: asyncpwodValidator1 }]"
+        />
+      </van-cell-group>
+
+      <van-cell-group>
+        <van-field
+          v-model="form.ncode"
+          label-width="62px"
+          label="新密码"
+          placeholder="新密码"
+          :rules="[{ validator: asyncpwodValidator2 }]"
+        />
+      </van-cell-group>
+      <van-cell-group>
+        <van-field
+          v-model="form.rcode"
+          label-width="62px"
+          label="确认密码"
+          placeholder="确认密码"
+          :rules="[{ validator: asyncpwodValidator3 }]"
+        />
+      </van-cell-group>
+    </div>
+
+    <div class="btn-box">
+      <van-button
+        block
+        type="info"
+        :disabled="loadding"
+        :loadding="loadding"
+        loadding-text="加载中..."
+        native-type="submit"
+        @click="onSubmit()"
+      >
+        保&nbsp;存
+      </van-button>
+    </div>
+  </div>
+</template>
+
+<script>
+import asyncRequest from "@/apis/address/index";
+import resToken from "@/mixins/resToken";
+import { isnumber, validAlphabets } from "@/utils/validate";
+export default {
+  mixins: [resToken],
+  data() {
+    return {
+      loadding: false,
+      form: {
+        mobile: "CJ1745",
+        code: "",
+        ncode: "",
+        rcode: "",
+      },
+    };
+  },
+  async created() {
+    this.loadding = false;
+    this.form = {
+      mobile: "CJ1745",
+      code: "",
+      ncode: "",
+      rcode: "",
+    };
+  },
+  methods: {
+    onClickLeft() {
+      window.history.back(-1);
+    },
+    async asyncmobileValidator(val) {
+      return new Promise((resolve) => {
+        let type = true;
+        if (val === "") {
+          this.show_title("请输入卡号!");
+          type = false;
+        } else {
+          if (val.length !== 12) {
+            this.show_title("卡号不正确!");
+            type = false;
+          } else {
+            let a = val.slice(0, 2);
+            let b = val.slice(2, 6);
+            let c = val.slice(6, 12);
+            if (a !== "CJ") {
+              this.show_title("卡号不正确!");
+              type = false;
+            } else if (b !== "1745") {
+              this.show_title("卡号不正确!");
+              type = false;
+            } else if (!isnumber(c)) {
+              this.show_title("卡号不正确!");
+              type = false;
+            }
+          }
+        }
+        resolve(type ? "ok" : "error");
+      });
+    },
+    async asyncpwodValidator1(val) {
+      return new Promise((resolve) => {
+        let type = true;
+        const { isok, msg } = this.pwdValidator(val, 1);
+        type = isok;
+        if (!type) {
+          this.show_title(msg);
+        }
+        resolve(type ? "ok" : "error");
+      });
+    },
+    async asyncpwodValidator2(val) {
+      return new Promise((resolve) => {
+        let type = true;
+        console.log(val)
+        const { isok, msg } = this.pwdValidator(val, 2);
+        console.log(isok, msg);
+        type = isok;
+        if (!type) {
+          this.show_title(msg);
+        }
+        resolve(type ? "ok" : "error");
+      });
+    },
+    async asyncpwodValidator3(val) {
+      return new Promise((resolve) => {
+        let type = true;
+        const { isok, msg } = this.pwdValidator(val, 3);
+        type = isok;
+        if (!type) {
+          this.show_title(msg);
+        }
+        resolve(type ? "ok" : "error");
+      });
+    },
+    pwdValidator(val, type) {
+      console.log(val,type);
+      let mt = type === 1 ? "原密码" : type === 2 ? "新密码" : "确认密码";
+      let msg = "";
+      let isok = true;
+      if (val === "") {
+        msg = `请输入${mt}!`;
+        isok = false;
+      } else {
+        if (val.length !== 6) {
+          msg = `${mt}为2位字母+4位数字!`;
+          isok = false;
+        } else {
+          let a = val.slice(0, 2);
+          let b = val.slice(2, 4);
+          if (!isnumber(b)) {
+            msg = `${mt}为2位字母+4位数字!`;
+            isok = false;
+          }
+          if (!validAlphabets(a)) {
+            msg = `${mt}为2位字母+4位数字!`;
+            isok = false;
+          }
+        }
+      }
+      let model = {
+        ok: isok,
+        msg: msg,
+      };
+      return model;
+    },
+    // 点击 登陆按钮 后执行提交
+    async onSubmit() {
+      if (!this.loadding) {
+        this.loadding = true;
+        const res1 = await this.asyncmobileValidator(this.form.mobile); //校验表单卡号
+        if (res1 === "error") {
+          this.loadding = false;
+          return;
+        }
+        const res2 = await this.asyncpwodValidator1(this.form.code);
+        if (res2 === "error") {
+          this.loadding = false;
+          return;
+        }
+        const res3 = await this.asyncpwodValidator2(this.form.ncode);
+        if (res3 === "error") {
+          this.loadding = false;
+          return;
+        }
+        const res4 = await this.asyncpwodValidator3(this.form.rcode);
+        if (res4 === "error") {
+          this.loadding = false;
+          return;
+        }
+        let model = JSON.parse(JSON.stringify(this.form));
+        delete model["rcode"];
+        const { code, msg } = await asyncRequest.list(model); //视频预览接口
+        if (code === 0) {
+          this.loadding = false;
+          this.show_title("密码重置成功!");
+          setTimeout(() => {
+            window.history.back(-1);
+          }, 3000);
+        } else {
+          this.show_title(msg);
+          this.loadding = false;
+        }
+      }
+    },
+  },
+};
+</script>
+
+<style lang="scss" scoped>
+.reset {
+  position: relative;
+  width: 100%;
+  height: 100%;
+
+  box-sizing: border-box;
+  background: rgb(230, 230, 220) !important;
+  .reset-box {
+    width: calc(100% - 32px);
+    margin: 0 16px !important;
+    // padding: 0 16px;
+    overflow: hidden !important;
+    border-radius: 10px !important;
+    .van-field__label {
+      margin: 0 !important;
+    }
+  }
+
+  .btn-box {
+    margin: 30px 5% 0 5%;
+    .van-button {
+      background: linear-gradient(0deg, #a67e4b, #efc180);
+      border-radius: 22px;
+      overflow: hidden;
+      color: #fff;
+      border: 0;
+      font-weight: bolder;
+    }
+    //
+    //   height: 44px;
+    //   text-align: center;
+    //   border-radius: 22px;
+    //   overflow: hidden;
+    //   background: linear-gradient(0deg, #f2c482, #a07947);
+    //   font-size: 14px;
+    //   line-height: 44px;
+    //
+    //   // linear-gradient(0deg, #ff6680 0%, #ffd490 100%);
+    //   border: 0;
+  }
+}
+</style>

Alguns arquivos não foram mostrados porque muitos arquivos mudaram nesse diff