387 lines
9.4 KiB
Vue
387 lines
9.4 KiB
Vue
<script setup lang="ts">
|
||
import { computed, onMounted } from 'vue';
|
||
import { useAuthStore } from '@/stores/auth';
|
||
|
||
const authStore = useAuthStore();
|
||
|
||
const isLoggedIn = computed(() => authStore.isLoggedIn);
|
||
|
||
onMounted(async () => {
|
||
await authStore.fetchLoginStatus();
|
||
});
|
||
</script>
|
||
|
||
<template>
|
||
<div class="home">
|
||
<div class="hero-section">
|
||
<div class="hero-content">
|
||
<h1 class="hero-title">Pixiv 作品管理器</h1>
|
||
<p class="hero-subtitle">
|
||
发现、收藏、下载你喜欢的 Pixiv 作品
|
||
</p>
|
||
|
||
<div class="hero-actions">
|
||
<router-link
|
||
v-if="!isLoggedIn"
|
||
to="/login"
|
||
class="btn btn-primary"
|
||
>
|
||
立即登录
|
||
</router-link>
|
||
<router-link
|
||
v-else
|
||
to="/search"
|
||
class="btn btn-primary"
|
||
>
|
||
开始搜索
|
||
</router-link>
|
||
|
||
<router-link
|
||
to="/downloads"
|
||
class="btn btn-secondary"
|
||
>
|
||
下载管理
|
||
</router-link>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<div class="features-section">
|
||
<div class="container">
|
||
<h2 class="section-title">主要功能</h2>
|
||
|
||
<div class="features-grid">
|
||
<div class="feature-card">
|
||
<div class="feature-icon">
|
||
<svg viewBox="0 0 24 24" fill="currentColor">
|
||
<path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"/>
|
||
</svg>
|
||
</div>
|
||
<h3 class="feature-title">作品搜索</h3>
|
||
<p class="feature-description">
|
||
通过关键词、标签、作者等多种方式搜索作品
|
||
</p>
|
||
</div>
|
||
|
||
<div class="feature-card">
|
||
<div class="feature-icon">
|
||
<svg viewBox="0 0 24 24" fill="currentColor">
|
||
<path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"/>
|
||
</svg>
|
||
</div>
|
||
<h3 class="feature-title">一键下载</h3>
|
||
<p class="feature-description">
|
||
支持单个作品、批量作品、作者作品下载
|
||
</p>
|
||
</div>
|
||
|
||
<div class="feature-card">
|
||
<div class="feature-icon">
|
||
<svg viewBox="0 0 24 24" fill="currentColor">
|
||
<path d="M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z"/>
|
||
</svg>
|
||
</div>
|
||
<h3 class="feature-title">作者管理</h3>
|
||
<p class="feature-description">
|
||
关注喜欢的作者,查看作品列表和统计信息
|
||
</p>
|
||
</div>
|
||
|
||
<div class="feature-card">
|
||
<div class="feature-icon">
|
||
<svg viewBox="0 0 24 24" fill="currentColor">
|
||
<path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V5h14v14z"/>
|
||
<path d="M7 12h2v5H7zm4-3h2v8h-2zm4-3h2v11h-2z"/>
|
||
</svg>
|
||
</div>
|
||
<h3 class="feature-title">下载管理</h3>
|
||
<p class="feature-description">
|
||
实时查看下载进度,管理下载历史和任务
|
||
</p>
|
||
</div>
|
||
|
||
<div class="feature-card">
|
||
<div class="feature-icon">
|
||
<svg viewBox="0 0 24 24" fill="currentColor">
|
||
<path d="M20 6h-8l-2-2H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm0 12H4V8h16v10z"/>
|
||
</svg>
|
||
</div>
|
||
<h3 class="feature-title">仓库管理</h3>
|
||
<p class="feature-description">
|
||
管理本地作品仓库,分类整理和快速检索
|
||
</p>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<div v-if="isLoggedIn" class="quick-actions">
|
||
<div class="container">
|
||
<h2 class="section-title">快速操作</h2>
|
||
|
||
<div class="quick-actions-grid">
|
||
<router-link to="/search" class="quick-action-card">
|
||
<div class="quick-action-icon">
|
||
<svg viewBox="0 0 24 24" fill="currentColor">
|
||
<path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"/>
|
||
</svg>
|
||
</div>
|
||
<span>搜索作品</span>
|
||
</router-link>
|
||
|
||
<router-link to="/downloads" class="quick-action-card">
|
||
<div class="quick-action-icon">
|
||
<svg viewBox="0 0 24 24" fill="currentColor">
|
||
<path d="M19 9h-4V3H9v6H5l7 7 7-7zM5 18v2h14v-2H5z"/>
|
||
</svg>
|
||
</div>
|
||
<span>下载管理</span>
|
||
</router-link>
|
||
|
||
<router-link to="/artists" class="quick-action-card">
|
||
<div class="quick-action-icon">
|
||
<svg viewBox="0 0 24 24" fill="currentColor">
|
||
<path d="M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z"/>
|
||
</svg>
|
||
</div>
|
||
<span>作者管理</span>
|
||
</router-link>
|
||
|
||
<router-link to="/repository" class="quick-action-card">
|
||
<div class="quick-action-icon">
|
||
<svg viewBox="0 0 24 24" fill="currentColor">
|
||
<path d="M20 6h-8l-2-2H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm0 12H4V8h16v10z"/>
|
||
</svg>
|
||
</div>
|
||
<span>仓库管理</span>
|
||
</router-link>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</template>
|
||
|
||
<style scoped>
|
||
.home {
|
||
min-height: 100vh;
|
||
}
|
||
|
||
.hero-section {
|
||
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
|
||
color: white;
|
||
padding: 4rem 0;
|
||
text-align: center;
|
||
}
|
||
|
||
.hero-content {
|
||
max-width: 800px;
|
||
margin: 0 auto;
|
||
padding: 0 2rem;
|
||
}
|
||
|
||
.hero-title {
|
||
font-size: 3rem;
|
||
font-weight: 700;
|
||
margin-bottom: 1rem;
|
||
line-height: 1.2;
|
||
}
|
||
|
||
.hero-subtitle {
|
||
font-size: 1.25rem;
|
||
margin-bottom: 2rem;
|
||
opacity: 0.9;
|
||
line-height: 1.6;
|
||
}
|
||
|
||
.hero-actions {
|
||
display: flex;
|
||
gap: 1rem;
|
||
justify-content: center;
|
||
flex-wrap: wrap;
|
||
}
|
||
|
||
.btn {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
padding: 0.75rem 1.5rem;
|
||
border-radius: 0.5rem;
|
||
font-weight: 600;
|
||
text-decoration: none;
|
||
transition: all 0.2s;
|
||
border: none;
|
||
cursor: pointer;
|
||
font-size: 1rem;
|
||
}
|
||
|
||
.btn-primary {
|
||
background: #3b82f6;
|
||
color: white;
|
||
}
|
||
|
||
.btn-primary:hover {
|
||
background: #2563eb;
|
||
transform: translateY(-1px);
|
||
}
|
||
|
||
.btn-secondary {
|
||
background: rgba(255, 255, 255, 0.1);
|
||
color: white;
|
||
border: 1px solid rgba(255, 255, 255, 0.2);
|
||
}
|
||
|
||
.btn-secondary:hover {
|
||
background: rgba(255, 255, 255, 0.2);
|
||
transform: translateY(-1px);
|
||
}
|
||
|
||
.container {
|
||
max-width: 1200px;
|
||
margin: 0 auto;
|
||
padding: 0 2rem;
|
||
}
|
||
|
||
.features-section {
|
||
padding: 4rem 0;
|
||
background: #f8fafc;
|
||
}
|
||
|
||
.section-title {
|
||
text-align: center;
|
||
font-size: 2.5rem;
|
||
font-weight: 700;
|
||
margin-bottom: 3rem;
|
||
color: #1f2937;
|
||
}
|
||
|
||
.features-grid {
|
||
display: grid;
|
||
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
|
||
gap: 2rem;
|
||
}
|
||
|
||
.feature-card {
|
||
background: white;
|
||
padding: 2rem;
|
||
border-radius: 1rem;
|
||
text-align: center;
|
||
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
|
||
transition: transform 0.2s;
|
||
}
|
||
|
||
.feature-card:hover {
|
||
transform: translateY(-4px);
|
||
}
|
||
|
||
.feature-icon {
|
||
width: 4rem;
|
||
height: 4rem;
|
||
margin: 0 auto 1.5rem;
|
||
background: #3b82f6;
|
||
border-radius: 50%;
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
color: white;
|
||
}
|
||
|
||
.feature-icon svg {
|
||
width: 2rem;
|
||
height: 2rem;
|
||
}
|
||
|
||
.feature-title {
|
||
font-size: 1.25rem;
|
||
font-weight: 600;
|
||
margin-bottom: 1rem;
|
||
color: #1f2937;
|
||
}
|
||
|
||
.feature-description {
|
||
color: #6b7280;
|
||
line-height: 1.6;
|
||
}
|
||
|
||
.quick-actions {
|
||
padding: 4rem 0;
|
||
}
|
||
|
||
.quick-actions-grid {
|
||
display: grid;
|
||
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
|
||
gap: 1.5rem;
|
||
max-width: 600px;
|
||
margin: 0 auto;
|
||
}
|
||
|
||
.quick-action-card {
|
||
display: flex;
|
||
flex-direction: column;
|
||
align-items: center;
|
||
gap: 1rem;
|
||
padding: 2rem;
|
||
background: white;
|
||
border-radius: 1rem;
|
||
text-decoration: none;
|
||
color: #374151;
|
||
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
|
||
transition: all 0.2s;
|
||
}
|
||
|
||
.quick-action-card:hover {
|
||
transform: translateY(-2px);
|
||
box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
|
||
color: #3b82f6;
|
||
}
|
||
|
||
.quick-action-icon {
|
||
width: 3rem;
|
||
height: 3rem;
|
||
background: #f3f4f6;
|
||
border-radius: 50%;
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
color: #6b7280;
|
||
transition: all 0.2s;
|
||
}
|
||
|
||
.quick-action-card:hover .quick-action-icon {
|
||
background: #3b82f6;
|
||
color: white;
|
||
}
|
||
|
||
.quick-action-icon svg {
|
||
width: 1.5rem;
|
||
height: 1.5rem;
|
||
}
|
||
|
||
@media (max-width: 768px) {
|
||
.hero-title {
|
||
font-size: 2rem;
|
||
}
|
||
|
||
.hero-subtitle {
|
||
font-size: 1rem;
|
||
}
|
||
|
||
.hero-actions {
|
||
flex-direction: column;
|
||
align-items: center;
|
||
}
|
||
|
||
.btn {
|
||
width: 100%;
|
||
max-width: 300px;
|
||
}
|
||
|
||
.features-grid {
|
||
grid-template-columns: 1fr;
|
||
}
|
||
|
||
.quick-actions-grid {
|
||
grid-template-columns: 1fr;
|
||
}
|
||
}
|
||
</style>
|