Files

261 lines
10 KiB
HTML
Raw Permalink Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>玩玩云 - 企业网盘</title>
<script>
(function() {
const search = window.location.search;
if (!search) return;
if (search.includes('verifyToken')) {
window.location.replace(`verify.html${search}`);
} else if (search.includes('resetToken')) {
window.location.replace(`reset-password.html${search}`);
}
})();
</script>
<link rel="stylesheet" href="libs/fontawesome/css/all.min.css">
<link rel="stylesheet" href="landing.css?v=20260212008">
</head>
<body>
<div class="page">
<header class="site-header">
<div class="container site-header-inner">
<a class="brand" href="index.html">
<i class="fas fa-cloud"></i>
<span>玩玩云</span>
</a>
<nav class="top-nav">
<a href="product.html">产品能力</a>
<a href="scenes.html">应用场景</a>
<a href="start.html">快速开始</a>
</nav>
<div class="header-actions">
<a href="app.html?action=login" class="btn btn-secondary">
<i class="fas fa-circle-user"></i>
登录
</a>
<a href="app.html?action=register" class="btn btn-primary">
<i class="fas fa-user-plus"></i>
免费注册
</a>
</div>
</div>
</header>
<main class="main">
<div class="container">
<section class="hero">
<div>
<div class="hero-tag">
<i class="fas fa-shield-halved"></i>
企业网盘 · 稳定可控
</div>
<h1 class="hero-title">像主流网盘一样好用,
<br>更适合你的私有部署场景</h1>
<p class="hero-desc">
玩玩云提供文件上传、在线预览、分享权限、存储配额与后台管理能力,支持本地与 OSS 双模式,满足团队长期文件管理与协作需求。
</p>
<div class="hero-actions">
<a href="app.html?action=register" class="btn btn-primary">
<i class="fas fa-rocket"></i>
立即开始
</a>
<a href="app.html?action=login" class="btn btn-secondary">
<i class="fas fa-circle-user"></i>
已有账号,去登录
</a>
</div>
<div class="hero-points">
<span><i class="fas fa-check-circle"></i> 单文件分享 / 密码访问 / 时效控制</span>
<span><i class="fas fa-check-circle"></i> 用户存储策略与配额可按人精细化配置</span>
<span><i class="fas fa-check-circle"></i> 网页端与移动端统一体验,开箱即用</span>
</div>
</div>
<div class="carousel" id="netdiskCarousel">
<div class="carousel-viewport">
<article class="carousel-slide is-active" data-title="文件管理">
<div class="slide-head">
<div class="slide-title">文件管理界面</div>
<span class="slide-tag">目录组织</span>
</div>
<div class="slide-body">
<div class="slide-row"><span>当前目录</span><strong>/项目文档/交付包</strong></div>
<div class="slide-row"><span>文件数量</span><strong>128 项</strong></div>
<div class="slide-row"><span>总容量</span><strong>7.6 GB</strong></div>
<div class="slide-progress"><span style="width: 62%;"></span></div>
<div class="slide-row"><span>最近上传</span><strong>需求说明-v3.pdf</strong></div>
</div>
</article>
<article class="carousel-slide" data-title="分享控制">
<div class="slide-head">
<div class="slide-title">分享权限控制</div>
<span class="slide-tag">安全分享</span>
</div>
<div class="slide-body">
<div class="slide-row"><span>分享链接</span><strong>/s/Ab8K9Q</strong></div>
<div class="slide-row"><span>访问方式</span><strong>密码 + 有效期</strong></div>
<div class="slide-row"><span>访问次数</span><strong>剩余 9 / 10</strong></div>
<div class="slide-progress"><span style="width: 90%; background: linear-gradient(90deg,#f59e0b,#ef4444);"></span></div>
<div class="slide-row"><span>过期时间</span><strong>2026-02-20 23:59</strong></div>
</div>
</article>
<article class="carousel-slide" data-title="存储策略">
<div class="slide-head">
<div class="slide-title">双存储模式</div>
<span class="slide-tag">本地 + OSS</span>
</div>
<div class="slide-body">
<div class="slide-row"><span>当前存储</span><strong>OSS 存储</strong></div>
<div class="slide-row"><span>已使用</span><strong>408.99 MB / 1 GB</strong></div>
<div class="slide-row"><span>用户配额</span><strong>默认 1 GB可调整</strong></div>
<div class="slide-progress"><span style="width: 41%; background: linear-gradient(90deg,#22c55e,#2468f2);"></span></div>
<div class="slide-row"><span>策略状态</span><strong>管理员可统一下发</strong></div>
</div>
</article>
</div>
<div class="carousel-footer">
<div class="carousel-dots" id="carouselDots">
<button class="carousel-dot active" data-index="0" aria-label="切换到第1张"></button>
<button class="carousel-dot" data-index="1" aria-label="切换到第2张"></button>
<button class="carousel-dot" data-index="2" aria-label="切换到第3张"></button>
</div>
<div class="carousel-nav">
<button class="carousel-btn" id="carouselPrev" aria-label="上一张"><i class="fas fa-angle-left"></i></button>
<button class="carousel-btn" id="carouselNext" aria-label="下一张"><i class="fas fa-angle-right"></i></button>
</div>
</div>
</div>
</section>
<section class="section">
<h2 class="section-title"><i class="fas fa-layer-group"></i>核心能力</h2>
<div class="feature-grid">
<article class="feature-card">
<div class="feature-icon"><i class="fas fa-cloud-arrow-up"></i></div>
<div class="feature-name">高效上传</div>
<p class="feature-desc">支持多文件上传、拖拽上传与进度反馈,日常资料归档更高效。</p>
</article>
<article class="feature-card">
<div class="feature-icon"><i class="fas fa-folder-tree"></i></div>
<div class="feature-name">目录管理</div>
<p class="feature-desc">支持目录层级导航、重命名、删除等管理操作,结构清晰。</p>
</article>
<article class="feature-card">
<div class="feature-icon"><i class="fas fa-share-nodes"></i></div>
<div class="feature-name">可控分享</div>
<p class="feature-desc">可设置密码、有效期、访问次数,外发资料更安全。</p>
</article>
<article class="feature-card">
<div class="feature-icon"><i class="fas fa-user-shield"></i></div>
<div class="feature-name">后台管控</div>
<p class="feature-desc">支持用户权限、配额策略、存储类型管理,维护成本低。</p>
</article>
</div>
</section>
</div>
</main>
<footer class="footer">
<div class="container footer-inner">
<div>玩玩云 © 2026</div>
<div class="footer-tech">
<span><i class="fab fa-node-js"></i> Node.js</span>
<span><i class="fab fa-vuejs"></i> Vue.js</span>
<span><i class="fas fa-database"></i> SQLite</span>
<span><i class="fab fa-docker"></i> Docker</span>
</div>
</div>
</footer>
</div>
<script>
(function() {
const carousel = document.getElementById('netdiskCarousel');
if (!carousel) return;
const slides = Array.from(carousel.querySelectorAll('.carousel-slide'));
const dots = Array.from(document.querySelectorAll('#carouselDots .carousel-dot'));
const prevBtn = document.getElementById('carouselPrev');
const nextBtn = document.getElementById('carouselNext');
let currentIndex = 0;
let timer = null;
function render(index) {
currentIndex = (index + slides.length) % slides.length;
slides.forEach((slide, idx) => {
slide.classList.toggle('is-active', idx === currentIndex);
});
dots.forEach((dot, idx) => {
dot.classList.toggle('active', idx === currentIndex);
});
}
function next() {
render(currentIndex + 1);
}
function startAuto() {
stopAuto();
timer = setInterval(next, 4500);
}
function stopAuto() {
if (timer) {
clearInterval(timer);
timer = null;
}
}
dots.forEach((dot, idx) => {
dot.addEventListener('click', () => {
render(idx);
startAuto();
});
});
if (prevBtn) {
prevBtn.addEventListener('click', () => {
render(currentIndex - 1);
startAuto();
});
}
if (nextBtn) {
nextBtn.addEventListener('click', () => {
render(currentIndex + 1);
startAuto();
});
}
carousel.addEventListener('mouseenter', stopAuto);
carousel.addEventListener('mouseleave', startAuto);
carousel.addEventListener('touchstart', stopAuto, { passive: true });
carousel.addEventListener('touchend', startAuto, { passive: true });
render(0);
startAuto();
})();
(async function() {
try {
const response = await fetch('/api/public/theme');
const data = await response.json();
if (data.success && data.theme === 'dark') {
document.body.classList.add('theme-dark');
}
} catch (error) {
console.log('主题加载失败,使用默认主题');
}
})();
</script>
</body>
</html>