LoginView.vue 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. <template>
  2. <ElContainer class="h-full bg-cover bg-center" @keyup.enter="login" :style="{ backgroundImage: `url(${bg})` }">
  3. <ElMain class="backdrop-blur1 dark:backdrop-brightness-50 !flex flex-col items-center justify-center">
  4. <span class="text-3xl font-[sh] text-white [text-shadow:_0_1px_0_rgb(0_0_0_/_40%)]">Admin</span>
  5. <ElCard class="w-full max-w-lg !rounded-xl mt-8 mb-16">
  6. <ElForm :model="model" :rules="rules" label-position="top" ref="form">
  7. <ElFormItem prop="username" label="用户名">
  8. <ElInput v-model="model.username"></ElInput>
  9. </ElFormItem>
  10. <ElFormItem prop="username" label="密码">
  11. <ElInput type="password" v-model="model.password"></ElInput>
  12. </ElFormItem>
  13. </ElForm>
  14. <el-button class="mt-8 w-full !block" type="primary" @click="login" :loading="loading">登录</el-button>
  15. </ElCard>
  16. <div class="fixed top-0 right-0 px-4 py-4">
  17. <DarkSwitch />
  18. </div>
  19. </ElMain>
  20. </ElContainer>
  21. </template>
  22. <script setup>
  23. import { ref } from 'vue'
  24. import DarkSwitch from '@/components/DarkSwitch.vue'
  25. import { http } from '@/plugins/http'
  26. import { useUserStore } from '@/stores/user'
  27. import { storeToRefs } from 'pinia'
  28. import { useRouter } from 'vue-router'
  29. import { ElMessage } from 'element-plus'
  30. import bg from '@/assets/2.jpg'
  31. const router = useRouter()
  32. const { user, setUser } = storeToRefs(useUserStore())
  33. const model = ref({
  34. username: '',
  35. password: ''
  36. })
  37. const rules = {
  38. username: [{ required: true, message: '请输入用户名', trigger: 'blur' }],
  39. password: [{ required: true, message: '请输入密码', trigger: 'blur' }]
  40. }
  41. const form = ref(null)
  42. const loading = ref(false)
  43. function login() {
  44. form.value.validate().then(async () => {
  45. loading.value = true
  46. try {
  47. const res = await http.post('/auth/admin/login', model.value)
  48. http.setToken(res.token)
  49. router.replace({ name: 'home' })
  50. loading.value = false
  51. } catch (e) {
  52. loading.value = false
  53. ElMessage.error(e.errors?.[0].message || e.message)
  54. }
  55. })
  56. }
  57. </script>