All files / components/organisms/LoginForm LoginForm.vue

78.04% Statements 64/82
100% Branches 6/6
0% Functions 0/6
78.04% Lines 64/82

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99  1x   1x 1x 1x   1x   1x   1x 1x 1x 1x   1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x   1x 1x   1x                                   1x             1x 1x 1x 1x 1x 1x 1x 1x   1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x   2x 1x 1x 1x    
<script lang="ts" setup>
import { reactive, ref } from "vue";
import type { FormInstance, FormRules } from "element-plus";
import axios from "axios";
import { useAuthStore } from "@/stores/useAuthStore";
import { useRouter } from "vue-router";
 
const router = useRouter();
 
const ruleFormRef = ref<FormInstance>();
 
const ruleForm = reactive({
  email: "",
  pass: "",
});
 
const rules = reactive<FormRules<typeof ruleForm>>({
  email: [
    {
      required: true,
      message: "Please input email address",
      trigger: "blur",
    },
    {
      type: "email",
      message: "Please input correct email address",
      trigger: ["blur", "change"],
    },
  ],
  pass: [
    {
      required: true,
      message: "Please input password",
      trigger: "blur",
    },
    {
      min: 8,
      message: "Length should be greater than 8",
      trigger: "blur",
    },
  ],
});
 
const authStore = useAuthStore();
const { login } = authStore;
 
const submitForm = (formEl: FormInstance | undefined) => {
  if (!formEl) return;
  formEl.validate((valid) => {
    if (valid) {
      axios.post("/msw/login", { post: ruleForm }).then((response) => {
        const data = response.data;
        login(data.accessToken, data.refreshToken);
        console.log(data);
 
        router.push("/index");
      });
      console.log("submit!");
    } else {
      console.error("error submit!");
    }
  });
};
 
const resetForm = (formEl: FormInstance | undefined) => {
  if (!formEl) return;
  formEl.resetFields();
};
</script>
 
<template>
  <el-form
    ref="ruleFormRef"
    style="max-width: 600px"
    :model="ruleForm"
    status-icon
    :rules="rules"
    label-width="auto"
    class="demo-ruleForm"
  >
    <el-form-item label="Email" prop="email">
      <el-input
        v-model="ruleForm.email"
        type="text"
        autocomplete="off"
      />
    </el-form-item>
    <el-form-item label="Password" prop="pass">
      <el-input v-model="ruleForm.pass" type="password" autocomplete="off" />
    </el-form-item>
    <el-form-item>
      <el-button type="primary" @click="submitForm(ruleFormRef)">
        Submit
      </el-button>
      <el-button @click="resetForm(ruleFormRef)">Reset</el-button>
    </el-form-item>
  </el-form>
</template>