login-module-5174.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. import { createHotContext as __vite__createHotContext } from "/@vite/client";import.meta.hot = __vite__createHotContext("/src/views/Login/index.vue");/* unplugin-vue-components disabled */import { ElForm as __unplugin_components_5 } from "/node_modules/.vite/deps/element-plus_es.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_base_style_css.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_form_style_css.js?v=f9805ad8";
  2. import { ElButton as __unplugin_components_4 } from "/node_modules/.vite/deps/element-plus_es.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_base_style_css.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_button_style_css.js?v=f9805ad8";
  3. import { ElCheckbox as __unplugin_components_3 } from "/node_modules/.vite/deps/element-plus_es.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_base_style_css.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_checkbox_style_css.js?v=f9805ad8";
  4. import { ElFormItem as __unplugin_components_2 } from "/node_modules/.vite/deps/element-plus_es.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_base_style_css.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_form-item_style_css.js?v=f9805ad8";
  5. import { ElInput as __unplugin_components_1 } from "/node_modules/.vite/deps/element-plus_es.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_base_style_css.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_input_style_css.js?v=f9805ad8";
  6. import { ElIcon as __unplugin_components_0 } from "/node_modules/.vite/deps/element-plus_es.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_base_style_css.js?v=f9805ad8";import "/node_modules/.vite/deps/element-plus_es_components_icon_style_css.js?v=f9805ad8";
  7. import { defineComponent as _defineComponent } from "/node_modules/.vite/deps/vue.js?v=f9805ad8";
  8. import { reactive, ref } from "/node_modules/.vite/deps/vue.js?v=f9805ad8";
  9. import { useRouter } from "/node_modules/.vite/deps/vue-router.js?v=f9805ad8";
  10. import { Lock, User, VideoPlay } from "/node_modules/.vite/deps/@element-plus_icons-vue.js?v=f9805ad8";
  11. import { ElMessage } from "/node_modules/.vite/deps/element-plus.js?v=f9805ad8";
  12. import AuthPageLayout from "/src/components/AuthPageLayout.vue?t=1776940473650";
  13. import { useAuthStore } from "/src/stores/auth.ts?t=1776940473650";
  14. import { useServerStore } from "/src/stores/server.ts";
  15. const _sfc_main = /* @__PURE__ */ _defineComponent({
  16. __name: "index",
  17. setup(__props, { expose: __expose }) {
  18. __expose();
  19. const router = useRouter();
  20. const authStore = useAuthStore();
  21. const serverStore = useServerStore();
  22. const formRef = ref();
  23. const loading = ref(false);
  24. const form = reactive({
  25. username: "",
  26. password: "",
  27. rememberMe: true
  28. });
  29. const rules = {
  30. username: [{ required: true, message: "请输入用户名", trigger: "blur" }],
  31. password: [{ required: true, message: "请输入密码", trigger: "blur" }]
  32. };
  33. async function handleLogin() {
  34. if (!formRef.value) return;
  35. const valid = await formRef.value.validate().catch(() => false);
  36. if (!valid) return;
  37. loading.value = true;
  38. try {
  39. await authStore.login({
  40. username: form.username,
  41. password: form.password,
  42. rememberMe: form.rememberMe
  43. });
  44. ElMessage.success("登录成功");
  45. router.push("/");
  46. } finally {
  47. loading.value = false;
  48. }
  49. }
  50. const __returned__ = { router, authStore, serverStore, formRef, loading, form, rules, handleLogin, get Lock() {
  51. return Lock;
  52. }, get User() {
  53. return User;
  54. }, get VideoPlay() {
  55. return VideoPlay;
  56. }, AuthPageLayout };
  57. Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
  58. return __returned__;
  59. }
  60. });
  61. import { createElementVNode as _createElementVNode, createVNode as _createVNode, resolveComponent as _resolveComponent, withCtx as _withCtx, createTextVNode as _createTextVNode, withModifiers as _withModifiers, toDisplayString as _toDisplayString, openBlock as _openBlock, createBlock as _createBlock } from "/node_modules/.vite/deps/vue.js?v=f9805ad8";
  62. const _hoisted_1 = { class: "login-card" };
  63. const _hoisted_2 = { class: "login-header" };
  64. const _hoisted_3 = { class: "logo-mark" };
  65. const _hoisted_4 = { class: "form-meta" };
  66. const _hoisted_5 = { class: "server-panel" };
  67. const _hoisted_6 = { class: "server-row" };
  68. const _hoisted_7 = { class: "server-row compact" };
  69. const _hoisted_8 = { class: "login-footer" };
  70. function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
  71. const _component_el_icon = __unplugin_components_0;
  72. const _component_el_input = __unplugin_components_1;
  73. const _component_el_form_item = __unplugin_components_2;
  74. const _component_el_checkbox = __unplugin_components_3;
  75. const _component_el_button = __unplugin_components_4;
  76. const _component_el_form = __unplugin_components_5;
  77. return _openBlock(), _createBlock($setup["AuthPageLayout"], null, {
  78. default: _withCtx(() => [
  79. _createElementVNode("div", _hoisted_1, [
  80. _createElementVNode("div", _hoisted_2, [
  81. _cache[4] || (_cache[4] = _createElementVNode(
  82. "span",
  83. { class: "badge" },
  84. "Workspace Access",
  85. -1
  86. /* CACHED */
  87. )),
  88. _createElementVNode("div", _hoisted_3, [
  89. _createVNode(_component_el_icon, null, {
  90. default: _withCtx(() => [
  91. _createVNode($setup["VideoPlay"])
  92. ]),
  93. _: 1
  94. /* STABLE */
  95. })
  96. ]),
  97. _cache[5] || (_cache[5] = _createElementVNode(
  98. "h2",
  99. null,
  100. "登录智媒通",
  101. -1
  102. /* CACHED */
  103. )),
  104. _cache[6] || (_cache[6] = _createElementVNode(
  105. "p",
  106. null,
  107. "进入本地 Node 工作台,继续账号运营、自动发布与数据分析。",
  108. -1
  109. /* CACHED */
  110. ))
  111. ]),
  112. _createVNode(_component_el_form, {
  113. ref: "formRef",
  114. model: $setup.form,
  115. rules: $setup.rules,
  116. class: "login-form",
  117. onSubmit: _withModifiers($setup.handleLogin, ["prevent"])
  118. }, {
  119. default: _withCtx(() => [
  120. _createVNode(_component_el_form_item, { prop: "username" }, {
  121. default: _withCtx(() => [
  122. _createVNode(_component_el_input, {
  123. modelValue: $setup.form.username,
  124. "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $setup.form.username = $event),
  125. placeholder: "用户名或邮箱",
  126. size: "large",
  127. "prefix-icon": $setup.User
  128. }, null, 8, ["modelValue", "prefix-icon"])
  129. ]),
  130. _: 1
  131. /* STABLE */
  132. }),
  133. _createVNode(_component_el_form_item, { prop: "password" }, {
  134. default: _withCtx(() => [
  135. _createVNode(_component_el_input, {
  136. modelValue: $setup.form.password,
  137. "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $setup.form.password = $event),
  138. type: "password",
  139. placeholder: "密码",
  140. size: "large",
  141. "prefix-icon": $setup.Lock,
  142. "show-password": ""
  143. }, null, 8, ["modelValue", "prefix-icon"])
  144. ]),
  145. _: 1
  146. /* STABLE */
  147. }),
  148. _createElementVNode("div", _hoisted_4, [
  149. _createVNode(_component_el_checkbox, {
  150. modelValue: $setup.form.rememberMe,
  151. "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => $setup.form.rememberMe = $event)
  152. }, {
  153. default: _withCtx(() => [..._cache[7] || (_cache[7] = [
  154. _createTextVNode(
  155. "保持登录",
  156. -1
  157. /* CACHED */
  158. )
  159. ])]),
  160. _: 1
  161. /* STABLE */
  162. }, 8, ["modelValue"]),
  163. _cache[8] || (_cache[8] = _createElementVNode(
  164. "span",
  165. { class: "meta-hint" },
  166. "服务地址自动跟随本地服务",
  167. -1
  168. /* CACHED */
  169. ))
  170. ]),
  171. _createVNode(_component_el_button, {
  172. type: "primary",
  173. size: "large",
  174. loading: $setup.loading,
  175. class: "login-btn",
  176. "native-type": "submit"
  177. }, {
  178. default: _withCtx(() => [..._cache[9] || (_cache[9] = [
  179. _createTextVNode(
  180. " 进入工作台 ",
  181. -1
  182. /* CACHED */
  183. )
  184. ])]),
  185. _: 1
  186. /* STABLE */
  187. }, 8, ["loading"])
  188. ]),
  189. _: 1
  190. /* STABLE */
  191. }, 8, ["model"]),
  192. _createElementVNode("div", _hoisted_5, [
  193. _createElementVNode("div", _hoisted_6, [
  194. _cache[10] || (_cache[10] = _createElementVNode(
  195. "span",
  196. { class: "server-label" },
  197. "当前服务",
  198. -1
  199. /* CACHED */
  200. )),
  201. _createElementVNode(
  202. "strong",
  203. null,
  204. _toDisplayString($setup.serverStore.currentServer?.name || "未配置"),
  205. 1
  206. /* TEXT */
  207. )
  208. ]),
  209. _createElementVNode("div", _hoisted_7, [
  210. _createElementVNode(
  211. "span",
  212. null,
  213. _toDisplayString($setup.serverStore.currentServer?.url || "未读取到地址"),
  214. 1
  215. /* TEXT */
  216. )
  217. ])
  218. ]),
  219. _createElementVNode("div", _hoisted_8, [
  220. _cache[12] || (_cache[12] = _createElementVNode(
  221. "span",
  222. null,
  223. "还没有账号?",
  224. -1
  225. /* CACHED */
  226. )),
  227. _createVNode(_component_el_button, {
  228. type: "primary",
  229. link: "",
  230. onClick: _cache[3] || (_cache[3] = ($event) => _ctx.$router.push("/register"))
  231. }, {
  232. default: _withCtx(() => [..._cache[11] || (_cache[11] = [
  233. _createTextVNode(
  234. "立即注册",
  235. -1
  236. /* CACHED */
  237. )
  238. ])]),
  239. _: 1
  240. /* STABLE */
  241. })
  242. ])
  243. ])
  244. ]),
  245. _: 1
  246. /* STABLE */
  247. });
  248. }
  249. import "/src/views/Login/index.vue?vue&type=style&index=0&scoped=374a0b31&lang.scss";
  250. _sfc_main.__hmrId = "374a0b31";
  251. typeof __VUE_HMR_RUNTIME__ !== "undefined" && __VUE_HMR_RUNTIME__.createRecord(_sfc_main.__hmrId, _sfc_main);
  252. import.meta.hot.on("file-changed", ({ file }) => {
  253. __VUE_HMR_RUNTIME__.CHANGED_FILE = file;
  254. });
  255. import.meta.hot.accept((mod) => {
  256. if (!mod) return;
  257. const { default: updated, _rerender_only } = mod;
  258. if (_rerender_only) {
  259. __VUE_HMR_RUNTIME__.rerender(updated.__hmrId, updated.render);
  260. } else {
  261. __VUE_HMR_RUNTIME__.reload(updated.__hmrId, updated);
  262. }
  263. });
  264. import _export_sfc from "/@id/__x00__plugin-vue:export-helper";
  265. export default /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-374a0b31"], ["__file", "C:/workspace/multi-platform-media-manage/client/src/views/Login/index.vue"]]);
  266. //# sourceMappingURL=data:application/json;base64,{"version":3,"mappings":"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","names":[],"ignoreList":[],"sources":["index.vue"],"sourcesContent":["﻿<template>\r\n  <AuthPageLayout>\r\n    <div class=\"login-card\">\r\n      <div class=\"login-header\">\r\n        <span class=\"badge\">Workspace Access</span>\r\n        <div class=\"logo-mark\">\r\n          <el-icon><VideoPlay /></el-icon>\r\n        </div>\r\n        <h2>登录智媒通</h2>\n        <p>进入本地 Node 工作台，继续账号运营、自动发布与数据分析。</p>\n      </div>\r\n\r\n      <el-form\r\n        ref=\"formRef\"\r\n        :model=\"form\"\r\n        :rules=\"rules\"\r\n        class=\"login-form\"\r\n        @submit.prevent=\"handleLogin\"\r\n      >\r\n        <el-form-item prop=\"username\">\r\n          <el-input\r\n            v-model=\"form.username\"\r\n            placeholder=\"用户名或邮箱\"\n            size=\"large\"\r\n            :prefix-icon=\"User\"\r\n          />\r\n        </el-form-item>\r\n\r\n        <el-form-item prop=\"password\">\r\n          <el-input\r\n            v-model=\"form.password\"\r\n            type=\"password\"\r\n            placeholder=\"密码\"\n            size=\"large\"\r\n            :prefix-icon=\"Lock\"\r\n            show-password\r\n          />\r\n        </el-form-item>\r\n\r\n        <div class=\"form-meta\">\r\n          <el-checkbox v-model=\"form.rememberMe\">保持登录</el-checkbox>\n          <span class=\"meta-hint\">服务地址自动跟随本地服务</span>\n        </div>\r\n\r\n        <el-button\r\n          type=\"primary\"\r\n          size=\"large\"\r\n          :loading=\"loading\"\r\n          class=\"login-btn\"\r\n          native-type=\"submit\"\r\n        >\r\n          进入工作台\n        </el-button>\n      </el-form>\r\n\r\n      <div class=\"server-panel\">\r\n        <div class=\"server-row\">\r\n          <span class=\"server-label\">当前服务</span>\n          <strong>{{ serverStore.currentServer?.name || '未配置' }}</strong>\r\n        </div>\r\n        <div class=\"server-row compact\">\r\n          <span>{{ serverStore.currentServer?.url || '未读取到地址' }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"login-footer\">\r\n        <span>还没有账号？</span>\n        <el-button type=\"primary\" link @click=\"$router.push('/register')\">立即注册</el-button>\n      </div>\r\n    </div>\r\n  </AuthPageLayout>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { reactive, ref } from 'vue';\r\nimport { useRouter } from 'vue-router';\r\nimport { Lock, User, VideoPlay } from '@element-plus/icons-vue';\r\nimport { ElMessage, type FormInstance, type FormRules } from 'element-plus';\r\nimport AuthPageLayout from '@/components/AuthPageLayout.vue';\r\nimport { useAuthStore } from '@/stores/auth';\r\nimport { useServerStore } from '@/stores/server';\r\n\r\nconst router = useRouter();\r\nconst authStore = useAuthStore();\r\nconst serverStore = useServerStore();\r\n\r\nconst formRef = ref<FormInstance>();\r\nconst loading = ref(false);\r\n\r\nconst form = reactive({\r\n  username: '',\r\n  password: '',\r\n  rememberMe: true,\r\n});\r\n\r\nconst rules: FormRules = {\r\n  username: [{ required: true, message: '请输入用户名', trigger: 'blur' }],\r\n  password: [{ required: true, message: '请输入密码', trigger: 'blur' }],\r\n};\r\n\r\nasync function handleLogin() {\r\n  if (!formRef.value) return;\r\n\r\n  const valid = await formRef.value.validate().catch(() => false);\r\n  if (!valid) return;\r\n\r\n  loading.value = true;\r\n  try {\r\n    await authStore.login({\r\n      username: form.username,\r\n      password: form.password,\r\n      rememberMe: form.rememberMe,\r\n    });\r\n    ElMessage.success('登录成功');\n    router.push('/');\r\n  } finally {\r\n    loading.value = false;\r\n  }\r\n}\r\n</script>\r\n\r\n<style scoped lang=\"scss\">\r\n@use '@/styles/variables.scss' as *;\r\n\r\n.login-card {\r\n  width: 100%;\r\n  max-width: 380px;\r\n  padding: 0;\r\n  border-radius: 0;\r\n  background: transparent;\r\n  border: none;\r\n  box-shadow: none;\r\n}\r\n\r\n.login-header {\r\n  text-align: left;\r\n\r\n  h2 {\r\n    margin: 18px 0 12px;\r\n    font-family: 'Newsreader', 'Noto Serif SC', serif;\r\n    font-size: 38px;\r\n    line-height: 0.98;\r\n    letter-spacing: -0.04em;\r\n    color: $text-primary;\r\n  }\r\n\r\n  p {\r\n    margin: 0;\r\n    color: $text-secondary;\r\n    line-height: 1.7;\r\n  }\r\n}\r\n\r\n.badge {\r\n  display: inline-flex;\r\n  min-height: 30px;\r\n  align-items: center;\r\n  padding: 0 12px;\r\n  border-radius: 999px;\r\n  background: rgba(255, 92, 0, 0.08);\r\n  color: $primary-color;\r\n  font-size: 12px;\r\n  font-weight: 700;\r\n  letter-spacing: 0.08em;\r\n  text-transform: uppercase;\r\n}\r\n\r\n.logo-mark {\r\n  width: 62px;\r\n  height: 62px;\r\n  margin-top: 18px;\r\n  border-radius: 22px;\r\n  display: grid;\r\n  place-items: center;\r\n  background: $gradient-primary;\r\n  box-shadow: 0 16px 36px rgba(255, 92, 0, 0.24);\r\n\r\n  .el-icon {\r\n    font-size: 30px;\r\n    color: white;\r\n  }\r\n}\r\n\r\n.login-form {\r\n  margin-top: 26px;\r\n\r\n  :deep(.el-form-item) {\r\n    margin-bottom: 18px;\r\n  }\r\n\r\n  :deep(.el-input__wrapper) {\r\n    min-height: 52px;\r\n    border-radius: 16px;\r\n    box-shadow: 0 0 0 1px rgba(26, 26, 26, 0.08) inset;\r\n\r\n    &.is-focus {\r\n      box-shadow:\r\n        0 0 0 1px rgba(255, 92, 0, 0.48) inset,\r\n        0 0 0 4px rgba(255, 92, 0, 0.1);\r\n    }\r\n  }\r\n}\r\n\r\n.form-meta {\r\n  display: flex;\r\n  align-items: center;\r\n  justify-content: space-between;\r\n  gap: 12px;\r\n  margin-bottom: 20px;\r\n  color: $text-secondary;\r\n  font-size: 13px;\r\n}\r\n\r\n.meta-hint {\r\n  text-align: right;\r\n}\r\n\r\n.login-btn {\r\n  width: 100%;\r\n  height: 52px;\r\n  border: none;\r\n  border-radius: 16px;\r\n  background: $gradient-primary;\r\n  box-shadow: 0 18px 34px rgba(255, 92, 0, 0.22);\r\n  font-size: 15px;\r\n  font-weight: 700;\r\n}\r\n\r\n.server-panel {\r\n  margin-top: 24px;\r\n  padding: 18px;\r\n  border-radius: 20px;\r\n  background: rgba(255, 92, 0, 0.04);\r\n  border: 1px solid rgba(255, 92, 0, 0.1);\r\n}\r\n\r\n.server-row {\r\n  display: flex;\r\n  align-items: center;\r\n  justify-content: space-between;\r\n  gap: 14px;\r\n  color: $text-primary;\r\n\r\n  &.compact {\r\n    margin-top: 8px;\r\n    color: $text-secondary;\r\n    font-size: 13px;\r\n    word-break: break-all;\r\n  }\r\n\r\n  strong {\r\n    font-size: 15px;\r\n  }\r\n}\r\n\r\n.server-label {\r\n  color: $text-secondary;\r\n  font-size: 12px;\r\n  letter-spacing: 0.08em;\r\n  text-transform: uppercase;\r\n}\r\n\r\n.login-footer {\r\n  display: flex;\r\n  justify-content: center;\r\n  gap: 4px;\r\n  margin-top: 18px;\r\n  color: $text-secondary;\r\n  font-size: 14px;\r\n}\r\n</style>\r\n\r\n\r\n\r\n"],"file":"C:/workspace/multi-platform-media-manage/client/src/views/Login/index.vue"}