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"; 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"; 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"; 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"; 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"; 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"; import { defineComponent as _defineComponent } from "/node_modules/.vite/deps/vue.js?v=f9805ad8"; import { reactive, ref } from "/node_modules/.vite/deps/vue.js?v=f9805ad8"; import { useRouter } from "/node_modules/.vite/deps/vue-router.js?v=f9805ad8"; import { Lock, User, VideoPlay } from "/node_modules/.vite/deps/@element-plus_icons-vue.js?v=f9805ad8"; import { ElMessage } from "/node_modules/.vite/deps/element-plus.js?v=f9805ad8"; import AuthPageLayout from "/src/components/AuthPageLayout.vue?t=1776940473650"; import { useAuthStore } from "/src/stores/auth.ts?t=1776940473650"; import { useServerStore } from "/src/stores/server.ts"; const _sfc_main = /* @__PURE__ */ _defineComponent({ __name: "index", setup(__props, { expose: __expose }) { __expose(); const router = useRouter(); const authStore = useAuthStore(); const serverStore = useServerStore(); const formRef = ref(); const loading = ref(false); const form = reactive({ username: "", password: "", rememberMe: true }); const rules = { username: [{ required: true, message: "请输入用户名", trigger: "blur" }], password: [{ required: true, message: "请输入密码", trigger: "blur" }] }; async function handleLogin() { if (!formRef.value) return; const valid = await formRef.value.validate().catch(() => false); if (!valid) return; loading.value = true; try { await authStore.login({ username: form.username, password: form.password, rememberMe: form.rememberMe }); ElMessage.success("登录成功"); router.push("/"); } finally { loading.value = false; } } const __returned__ = { router, authStore, serverStore, formRef, loading, form, rules, handleLogin, get Lock() { return Lock; }, get User() { return User; }, get VideoPlay() { return VideoPlay; }, AuthPageLayout }; Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true }); return __returned__; } }); 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"; const _hoisted_1 = { class: "login-card" }; const _hoisted_2 = { class: "login-header" }; const _hoisted_3 = { class: "logo-mark" }; const _hoisted_4 = { class: "form-meta" }; const _hoisted_5 = { class: "server-panel" }; const _hoisted_6 = { class: "server-row" }; const _hoisted_7 = { class: "server-row compact" }; const _hoisted_8 = { class: "login-footer" }; function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { const _component_el_icon = __unplugin_components_0; const _component_el_input = __unplugin_components_1; const _component_el_form_item = __unplugin_components_2; const _component_el_checkbox = __unplugin_components_3; const _component_el_button = __unplugin_components_4; const _component_el_form = __unplugin_components_5; return _openBlock(), _createBlock($setup["AuthPageLayout"], null, { default: _withCtx(() => [ _createElementVNode("div", _hoisted_1, [ _createElementVNode("div", _hoisted_2, [ _cache[4] || (_cache[4] = _createElementVNode( "span", { class: "badge" }, "Workspace Access", -1 /* CACHED */ )), _createElementVNode("div", _hoisted_3, [ _createVNode(_component_el_icon, null, { default: _withCtx(() => [ _createVNode($setup["VideoPlay"]) ]), _: 1 /* STABLE */ }) ]), _cache[5] || (_cache[5] = _createElementVNode( "h2", null, "登录智媒通", -1 /* CACHED */ )), _cache[6] || (_cache[6] = _createElementVNode( "p", null, "进入本地 Node 工作台,继续账号运营、自动发布与数据分析。", -1 /* CACHED */ )) ]), _createVNode(_component_el_form, { ref: "formRef", model: $setup.form, rules: $setup.rules, class: "login-form", onSubmit: _withModifiers($setup.handleLogin, ["prevent"]) }, { default: _withCtx(() => [ _createVNode(_component_el_form_item, { prop: "username" }, { default: _withCtx(() => [ _createVNode(_component_el_input, { modelValue: $setup.form.username, "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $setup.form.username = $event), placeholder: "用户名或邮箱", size: "large", "prefix-icon": $setup.User }, null, 8, ["modelValue", "prefix-icon"]) ]), _: 1 /* STABLE */ }), _createVNode(_component_el_form_item, { prop: "password" }, { default: _withCtx(() => [ _createVNode(_component_el_input, { modelValue: $setup.form.password, "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $setup.form.password = $event), type: "password", placeholder: "密码", size: "large", "prefix-icon": $setup.Lock, "show-password": "" }, null, 8, ["modelValue", "prefix-icon"]) ]), _: 1 /* STABLE */ }), _createElementVNode("div", _hoisted_4, [ _createVNode(_component_el_checkbox, { modelValue: $setup.form.rememberMe, "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => $setup.form.rememberMe = $event) }, { default: _withCtx(() => [..._cache[7] || (_cache[7] = [ _createTextVNode( "保持登录", -1 /* CACHED */ ) ])]), _: 1 /* STABLE */ }, 8, ["modelValue"]), _cache[8] || (_cache[8] = _createElementVNode( "span", { class: "meta-hint" }, "服务地址自动跟随本地服务", -1 /* CACHED */ )) ]), _createVNode(_component_el_button, { type: "primary", size: "large", loading: $setup.loading, class: "login-btn", "native-type": "submit" }, { default: _withCtx(() => [..._cache[9] || (_cache[9] = [ _createTextVNode( " 进入工作台 ", -1 /* CACHED */ ) ])]), _: 1 /* STABLE */ }, 8, ["loading"]) ]), _: 1 /* STABLE */ }, 8, ["model"]), _createElementVNode("div", _hoisted_5, [ _createElementVNode("div", _hoisted_6, [ _cache[10] || (_cache[10] = _createElementVNode( "span", { class: "server-label" }, "当前服务", -1 /* CACHED */ )), _createElementVNode( "strong", null, _toDisplayString($setup.serverStore.currentServer?.name || "未配置"), 1 /* TEXT */ ) ]), _createElementVNode("div", _hoisted_7, [ _createElementVNode( "span", null, _toDisplayString($setup.serverStore.currentServer?.url || "未读取到地址"), 1 /* TEXT */ ) ]) ]), _createElementVNode("div", _hoisted_8, [ _cache[12] || (_cache[12] = _createElementVNode( "span", null, "还没有账号?", -1 /* CACHED */ )), _createVNode(_component_el_button, { type: "primary", link: "", onClick: _cache[3] || (_cache[3] = ($event) => _ctx.$router.push("/register")) }, { default: _withCtx(() => [..._cache[11] || (_cache[11] = [ _createTextVNode( "立即注册", -1 /* CACHED */ ) ])]), _: 1 /* STABLE */ }) ]) ]) ]), _: 1 /* STABLE */ }); } import "/src/views/Login/index.vue?vue&type=style&index=0&scoped=374a0b31&lang.scss"; _sfc_main.__hmrId = "374a0b31"; typeof __VUE_HMR_RUNTIME__ !== "undefined" && __VUE_HMR_RUNTIME__.createRecord(_sfc_main.__hmrId, _sfc_main); import.meta.hot.on("file-changed", ({ file }) => { __VUE_HMR_RUNTIME__.CHANGED_FILE = file; }); import.meta.hot.accept((mod) => { if (!mod) return; const { default: updated, _rerender_only } = mod; if (_rerender_only) { __VUE_HMR_RUNTIME__.rerender(updated.__hmrId, updated.render); } else { __VUE_HMR_RUNTIME__.reload(updated.__hmrId, updated); } }); import _export_sfc from "/@id/__x00__plugin-vue:export-helper"; 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"]]); //# 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"}