diff --git a/src/assets/login_bg.png b/src/assets/login_bg.png new file mode 100644 index 0000000..138faf1 Binary files /dev/null and b/src/assets/login_bg.png differ diff --git a/src/assets/login_false.png b/src/assets/login_false.png new file mode 100644 index 0000000..35c123e Binary files /dev/null and b/src/assets/login_false.png differ diff --git a/src/assets/login_logo.png b/src/assets/login_logo.png new file mode 100644 index 0000000..085b9a2 Binary files /dev/null and b/src/assets/login_logo.png differ diff --git a/src/assets/login_true.png b/src/assets/login_true.png new file mode 100644 index 0000000..d8a8adf Binary files /dev/null and b/src/assets/login_true.png differ diff --git a/src/assets/mine/top_bg.png b/src/assets/mine/top_bg.png new file mode 100644 index 0000000..cf2b98b Binary files /dev/null and b/src/assets/mine/top_bg.png differ diff --git a/src/style.css b/src/style.css deleted file mode 100644 index 527d4fb..0000000 --- a/src/style.css +++ /dev/null @@ -1,296 +0,0 @@ -:root { - --text: #6b6375; - --text-h: #08060d; - --bg: #fff; - --border: #e5e4e7; - --code-bg: #f4f3ec; - --accent: #aa3bff; - --accent-bg: rgba(170, 59, 255, 0.1); - --accent-border: rgba(170, 59, 255, 0.5); - --social-bg: rgba(244, 243, 236, 0.5); - --shadow: - rgba(0, 0, 0, 0.1) 0 10px 15px -3px, rgba(0, 0, 0, 0.05) 0 4px 6px -2px; - - --sans: system-ui, 'Segoe UI', Roboto, sans-serif; - --heading: system-ui, 'Segoe UI', Roboto, sans-serif; - --mono: ui-monospace, Consolas, monospace; - - font: 18px/145% var(--sans); - letter-spacing: 0.18px; - color-scheme: light dark; - color: var(--text); - background: var(--bg); - font-synthesis: none; - text-rendering: optimizeLegibility; - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; - - @media (max-width: 1024px) { - font-size: 16px; - } -} - -@media (prefers-color-scheme: dark) { - :root { - --text: #9ca3af; - --text-h: #f3f4f6; - --bg: #16171d; - --border: #2e303a; - --code-bg: #1f2028; - --accent: #c084fc; - --accent-bg: rgba(192, 132, 252, 0.15); - --accent-border: rgba(192, 132, 252, 0.5); - --social-bg: rgba(47, 48, 58, 0.5); - --shadow: - rgba(0, 0, 0, 0.4) 0 10px 15px -3px, rgba(0, 0, 0, 0.25) 0 4px 6px -2px; - } - - #social .button-icon { - filter: invert(1) brightness(2); - } -} - -body { - margin: 0; -} - -h1, -h2 { - font-family: var(--heading); - font-weight: 500; - color: var(--text-h); -} - -h1 { - font-size: 56px; - letter-spacing: -1.68px; - margin: 32px 0; - @media (max-width: 1024px) { - font-size: 36px; - margin: 20px 0; - } -} -h2 { - font-size: 24px; - line-height: 118%; - letter-spacing: -0.24px; - margin: 0 0 8px; - @media (max-width: 1024px) { - font-size: 20px; - } -} -p { - margin: 0; -} - -code, -.counter { - font-family: var(--mono); - display: inline-flex; - border-radius: 4px; - color: var(--text-h); -} - -code { - font-size: 15px; - line-height: 135%; - padding: 4px 8px; - background: var(--code-bg); -} - -.counter { - font-size: 16px; - padding: 5px 10px; - border-radius: 5px; - color: var(--accent); - background: var(--accent-bg); - border: 2px solid transparent; - transition: border-color 0.3s; - margin-bottom: 24px; - - &:hover { - border-color: var(--accent-border); - } - &:focus-visible { - outline: 2px solid var(--accent); - outline-offset: 2px; - } -} - -.hero { - position: relative; - - .base, - .framework, - .vite { - inset-inline: 0; - margin: 0 auto; - } - - .base { - width: 170px; - position: relative; - z-index: 0; - } - - .framework, - .vite { - position: absolute; - } - - .framework { - z-index: 1; - top: 34px; - height: 28px; - transform: perspective(2000px) rotateZ(300deg) rotateX(44deg) rotateY(39deg) - scale(1.4); - } - - .vite { - z-index: 0; - top: 107px; - height: 26px; - width: auto; - transform: perspective(2000px) rotateZ(300deg) rotateX(40deg) rotateY(39deg) - scale(0.8); - } -} - -#app { - width: 1126px; - max-width: 100%; - margin: 0 auto; - text-align: center; - border-inline: 1px solid var(--border); - min-height: 100svh; - display: flex; - flex-direction: column; - box-sizing: border-box; -} - -#center { - display: flex; - flex-direction: column; - gap: 25px; - place-content: center; - place-items: center; - flex-grow: 1; - - @media (max-width: 1024px) { - padding: 32px 20px 24px; - gap: 18px; - } -} - -#next-steps { - display: flex; - border-top: 1px solid var(--border); - text-align: left; - - & > div { - flex: 1 1 0; - padding: 32px; - @media (max-width: 1024px) { - padding: 24px 20px; - } - } - - .icon { - margin-bottom: 16px; - width: 22px; - height: 22px; - } - - @media (max-width: 1024px) { - flex-direction: column; - text-align: center; - } -} - -#docs { - border-right: 1px solid var(--border); - - @media (max-width: 1024px) { - border-right: none; - border-bottom: 1px solid var(--border); - } -} - -#next-steps ul { - list-style: none; - padding: 0; - display: flex; - gap: 8px; - margin: 32px 0 0; - - .logo { - height: 18px; - } - - a { - color: var(--text-h); - font-size: 16px; - border-radius: 6px; - background: var(--social-bg); - display: flex; - padding: 6px 12px; - align-items: center; - gap: 8px; - text-decoration: none; - transition: box-shadow 0.3s; - - &:hover { - box-shadow: var(--shadow); - } - .button-icon { - height: 18px; - width: 18px; - } - } - - @media (max-width: 1024px) { - margin-top: 20px; - flex-wrap: wrap; - justify-content: center; - - li { - flex: 1 1 calc(50% - 8px); - } - - a { - width: 100%; - justify-content: center; - box-sizing: border-box; - } - } -} - -#spacer { - height: 88px; - border-top: 1px solid var(--border); - @media (max-width: 1024px) { - height: 48px; - } -} - -.ticks { - position: relative; - width: 100%; - - &::before, - &::after { - content: ''; - position: absolute; - top: -4.5px; - border: 5px solid transparent; - } - - &::before { - left: 0; - border-left-color: var(--border); - } - &::after { - right: 0; - border-right-color: var(--border); - } -} diff --git a/src/styles/index.scss b/src/styles/index.scss index d87e1fa..41510ac 100644 --- a/src/styles/index.scss +++ b/src/styles/index.scss @@ -215,9 +215,9 @@ table { // ── Card Component Base ───────────────────────────────────── .card { background: var(--color-bg-card); - border-radius: var(--radius-md); - box-shadow: var(--shadow-sm); - padding: $spacing-md; + border-radius: 10px; + box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06); + padding: 20px 16px; margin: $spacing-sm $spacing-md; &--elevated { diff --git a/src/styles/variables.scss b/src/styles/variables.scss index b3d85df..df536c4 100644 --- a/src/styles/variables.scss +++ b/src/styles/variables.scss @@ -4,9 +4,9 @@ // ============================================================ // ── Brand Colors ──────────────────────────────────────────── -$color-primary: #2196F3; +$color-primary: #1E74FF; $color-primary-light: #64B5F6; -$color-primary-dark: #1976D2; +$color-primary-dark: #1A3973; $color-primary-bg: #E3F2FD; $color-success: #07C160; @@ -45,7 +45,7 @@ $color-text-placeholder:$color-gray-5; $color-text-inverse: $color-white; // ── Background Colors ─────────────────────────────────────── -$color-bg-page: $color-gray-1; +$color-bg-page: #F4F7F8; $color-bg-card: $color-white; $color-bg-elevated: $color-white; $color-bg-mask: rgba(0, 0, 0, 0.6); diff --git a/src/views/home/index.vue b/src/views/home/index.vue index 276ed0f..d02c8b7 100644 --- a/src/views/home/index.vue +++ b/src/views/home/index.vue @@ -1,55 +1,241 @@ @@ -58,68 +244,192 @@ function onTabChange(index: number): void { .home-page { min-height: 100vh; background: var(--color-bg-page); + display: flex; + flex-direction: column; + // ── 导航栏 ── :deep(.van-nav-bar) { - background: var(--color-primary); - --van-nav-bar-title-text-color: #fff; + background: #1E74FF; + + .van-nav-bar__title { + color: #ffffff; + font-weight: 600; + font-size: 17px; + } + + .van-nav-bar__left, + .van-nav-bar__right { + .van-icon { + color: #ffffff; + } + } } } -.home-content { - padding: 16px; +.nav-left-brand { + font-size: 18px; + line-height: 1; } -.welcome-card { - background: var(--color-bg-card); - border-radius: 12px; - padding: 32px 24px; - text-align: center; - box-shadow: var(--shadow-sm); - margin-bottom: 16px; - - h2 { - font-size: 20px; - color: var(--color-text-primary); - margin-bottom: 8px; - } - - p { - font-size: 14px; - color: var(--color-text-secondary); - margin: 0; - } +// ── 页面主体 ── +.home-body { + flex: 1; + overflow-y: auto; + -webkit-overflow-scrolling: touch; } -.feature-grid { - display: grid; - grid-template-columns: repeat(2, 1fr); - gap: 12px; +// ── Banner ── +.banner-wrapper { + margin: 8px 12px; } -.feature-item { - background: var(--color-bg-card); - border-radius: 12px; - padding: 24px 16px; - text-align: center; - box-shadow: var(--shadow-sm); +.banner-swipe { + border-radius: 10px; + overflow: hidden; + box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05); +} + +.banner-slide { + width: 100%; + height: 180px; + background: linear-gradient(135deg, #1E74FF 0%, #64B5F6 100%); + display: flex; + align-items: center; + justify-content: center; +} + +.banner-content { + display: flex; + flex-direction: column; + align-items: center; + gap: 8px; + color: #ffffff; +} + +.banner-icon { + font-size: 36px; +} + +.banner-title { + font-size: 16px; + font-weight: 500; +} + +// ── 提示栏 ── +.alert-bar { + margin: 0 12px 8px; + padding: 10px 14px; + background: #ffffff; + border-radius: 10px; + display: flex; + align-items: center; + gap: 8px; cursor: pointer; - transition: background-color var(--transition-fast); + box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05); &:active { - background: var(--color-border-light); - } - - .feature-icon { - width: 48px; - height: 48px; - border-radius: 12px; - background: var(--color-primary-bg); - margin: 0 auto 8px; - } - - .feature-label { - font-size: 14px; - color: var(--color-text-regular); + background: #f7f8fa; } } + +.alert-text { + flex: 1; + font-size: 13px; + color: var(--color-text-regular); + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} + +// ── 菜单折叠面板 ── +.menu-collapse { + margin: 0 12px; + + :deep(.van-collapse-item) { + margin-bottom: 8px; + border-radius: 10px; + overflow: hidden; + background: #ffffff; + + .van-cell { + padding: 14px 16px; + background: #ffffff; + } + + .van-collapse-item__content { + padding: 0 16px 14px; + background: #ffffff; + } + } +} + +// ── 面板标题 ── +.panel-title { + display: flex; + align-items: center; + gap: 10px; +} + +.panel-accent { + width: 4px; + height: 18px; + background: #1E74FF; + border-radius: 2px; + flex-shrink: 0; +} + +.panel-label { + font-size: 15px; + font-weight: 600; + color: var(--color-text-primary); +} + +// ── 菜单网格 (4 列) ── +.menu-grid { + display: grid; + grid-template-columns: repeat(4, 1fr); + gap: 12px 8px; +} + +.menu-item { + display: flex; + flex-direction: column; + align-items: center; + gap: 6px; + cursor: pointer; + padding: 4px 0; + + &:active { + .menu-icon-box { + background: #e3f2fd; + } + } +} + +.menu-icon-box { + width: 50px; + height: 50px; + border-radius: 12px; + background: #f0f6ff; + display: flex; + align-items: center; + justify-content: center; + transition: background-color 0.15s ease; +} + +.menu-label { + font-size: 12px; + color: var(--color-text-regular); + text-align: center; + line-height: 1.3; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + max-width: 100%; +} + +// ── 底部安全区 ── +.safe-bottom { + height: 12px; +} diff --git a/src/views/login/index.vue b/src/views/login/index.vue index ceed395..4e3d893 100644 --- a/src/views/login/index.vue +++ b/src/views/login/index.vue @@ -1,153 +1,415 @@ diff --git a/src/views/mine/index.vue b/src/views/mine/index.vue index 2898dd7..49e8ad6 100644 --- a/src/views/mine/index.vue +++ b/src/views/mine/index.vue @@ -1,37 +1,183 @@ @@ -39,39 +185,184 @@ const router = useRouter()