Login.vue 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. <template>
  2. <div class="login-flex">
  3. <div class="login">
  4. <div class="logo"><img src="img/logo_blue.png" /></div>
  5. <a-form @submit="loginAction">
  6. <div class="form-item">
  7. <!-- <a-select
  8. style="width: 100%; text-align: left; padding: 0"
  9. mode="SECRET_COMBOBOX_MODE_DO_NOT_USE"
  10. v-model:value="server"
  11. :options="servers"
  12. placeholder="请选择服务地址(如 http://192.168.10.225:8000)"
  13. >
  14. </a-select> -->
  15. <a-select
  16. style="width: 100%; text-align: left"
  17. v-model:value="server"
  18. :options="servers"
  19. placeholder="请选择服务地址"
  20. >
  21. </a-select>
  22. </div>
  23. <div class="form-item">
  24. <a-input
  25. style="width: 100%"
  26. v-model:value="loginName"
  27. id="loginName-input"
  28. type="text"
  29. placeholder="请输入账号"
  30. />
  31. </div>
  32. <div class="form-item">
  33. <a-input
  34. style="width: 100%"
  35. v-model:value="password"
  36. id="password-input"
  37. type="password"
  38. placeholder="请输入密码"
  39. @press-enter="loginAction"
  40. />
  41. </div>
  42. <div class="form-item">
  43. <a href="##" id="login-button" @click="loginAction">登录</a>
  44. </div>
  45. </a-form>
  46. </div>
  47. <div class="ft">
  48. Copyright © 2011-2021 www.qmth.com.cn, All Rights Reserved
  49. </div>
  50. </div>
  51. </template>
  52. <script setup lang="ts">
  53. import { ref } from "vue";
  54. import { store } from "@/store";
  55. import { login } from "@/api/api";
  56. import { useRouter } from "vue-router";
  57. import { message } from "ant-design-vue";
  58. import { Store } from "@/types";
  59. const router = useRouter();
  60. store.pageInputs = {} as Store["pageInputs"];
  61. let server = ref("");
  62. const servers = store.config.servers.map((v) => {
  63. return { label: v.name, value: v.host };
  64. });
  65. // const servers = ref([
  66. // { label: "线上环境", value: "https://www.markingcloud.com" },
  67. // ]);
  68. let loginName = ref("");
  69. let password = ref("");
  70. // FIXME: restore original state
  71. // onMounted(() => {
  72. // window.localStorage.clear();
  73. // });
  74. // server.value = "http://192.168.10.224:80";
  75. // loginName.value = "admin-test";
  76. // password.value = "123456";
  77. // server.value = "https://www.markingcloud.com";
  78. // loginName.value = "admin-wdsx";
  79. // password.value = "wdsx!@#";
  80. // server.value = "http://192.168.10.221:80";
  81. // loginName.value = "admin-test";
  82. // password.value = "123456";
  83. // const loginAction = () => {
  84. // if (!server.value.startsWith("http")) {
  85. // server.value = `http://${server.value}`;
  86. // }
  87. // let curServer = servers.value.find((v: any) => v.host === server.value) || {
  88. // host: server.value,
  89. // name: "自定义环境",
  90. // };
  91. // Object.assign(store.env, {
  92. // server:
  93. // servers.value.find((v: any) => v.host === server.value) || curServer,
  94. // loginName: loginName.value,
  95. // password: password.value,
  96. // });
  97. // if (!server.value) {
  98. // message.info("请选择服务地址");
  99. // return;
  100. // }
  101. // if (!loginName.value) {
  102. // message.info("请输入账号");
  103. // return;
  104. // }
  105. // if (!password.value) {
  106. // message.info("请输入密码");
  107. // return;
  108. // }
  109. // login()
  110. // .then((res) => {
  111. // Object.assign(store.env.user, res.data);
  112. // router.push("/exam-list");
  113. // })
  114. // .catch((err) => {
  115. // if (!err.toString().includes("404")) {
  116. // message.error("登录失败,用户名或密码错误");
  117. // }
  118. // });
  119. // };
  120. const loginAction = () => {
  121. Object.assign(store.env, {
  122. server: store.config.servers.find((v) => v.host === server.value),
  123. loginName: loginName.value,
  124. password: password.value,
  125. });
  126. if (!server.value) {
  127. message.info("请选择服务地址");
  128. return;
  129. }
  130. if (!loginName.value) {
  131. message.info("请输入账号");
  132. return;
  133. }
  134. if (!password.value) {
  135. message.info("请输入密码");
  136. return;
  137. }
  138. login()
  139. .then((res) => {
  140. Object.assign(store.env.user, res.data);
  141. router.push("/exam-list");
  142. })
  143. .catch((err) => {
  144. console.log(err);
  145. message.error("登陆失败,用户名或密码错误");
  146. });
  147. };
  148. </script>