91 lines
3.3 KiB
JavaScript
91 lines
3.3 KiB
JavaScript
'use client';
|
||
|
||
import { useState, useEffect } from 'react';
|
||
import { motion, AnimatePresence } from 'framer-motion';
|
||
|
||
const ANNOUNCEMENT_KEY = 'hasClosedAnnouncement_v4';
|
||
|
||
export default function Announcement() {
|
||
const [isVisible, setIsVisible] = useState(false);
|
||
|
||
useEffect(() => {
|
||
const hasClosed = localStorage.getItem(ANNOUNCEMENT_KEY);
|
||
if (!hasClosed) {
|
||
setIsVisible(true);
|
||
}
|
||
}, []);
|
||
|
||
const handleClose = () => {
|
||
localStorage.setItem(ANNOUNCEMENT_KEY, 'true');
|
||
setIsVisible(false);
|
||
};
|
||
|
||
return (
|
||
<AnimatePresence>
|
||
{isVisible && (
|
||
<motion.div
|
||
initial={{ opacity: 0 }}
|
||
animate={{ opacity: 1 }}
|
||
exit={{ opacity: 0 }}
|
||
style={{
|
||
position: 'fixed',
|
||
inset: 0,
|
||
zIndex: 100,
|
||
display: 'flex',
|
||
alignItems: 'center',
|
||
justifyContent: 'center',
|
||
background: 'rgba(0, 0, 0, 0.6)',
|
||
backdropFilter: 'blur(4px)',
|
||
padding: '20px',
|
||
}}
|
||
>
|
||
<motion.div
|
||
initial={{ scale: 0.95, opacity: 0, y: 10 }}
|
||
animate={{ scale: 1, opacity: 1, y: 0 }}
|
||
exit={{ scale: 0.95, opacity: 0, y: 10 }}
|
||
className="glass"
|
||
style={{
|
||
width: '100%',
|
||
maxWidth: '400px',
|
||
padding: '24px',
|
||
position: 'relative',
|
||
display: 'flex',
|
||
flexDirection: 'column',
|
||
gap: '16px',
|
||
}}
|
||
>
|
||
<div className="title" style={{ display: 'flex', alignItems: 'center', gap: '12px', fontWeight: 700, fontSize: '18px', color: 'var(--accent)' }}>
|
||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round">
|
||
<path d="M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z"></path>
|
||
<line x1="12" y1="9" x2="12" y2="13"></line>
|
||
<line x1="12" y1="17" x2="12.01" y2="17"></line>
|
||
</svg>
|
||
<span>公告</span>
|
||
</div>
|
||
|
||
<div style={{ color: 'var(--text)', lineHeight: '1.6', fontSize: '15px' }}>
|
||
感谢大家反馈的需求,现已增加如下功能:
|
||
<p>1. 持仓金额。</p>
|
||
<p>2. 更新当日最新净值,方便和估值数据作对比。</p>
|
||
以下功能会在下一个版本上线:
|
||
<p>1. 加、减仓。</p>
|
||
<p>2. 获取不到估值数据的基金能正常添加,仅展示最新净值数据。</p>
|
||
每一个功能的加入都会去精细设计它的UI和交互,以符合项目整体的简约风格,所以请大家敬请期待。
|
||
</div>
|
||
|
||
<div style={{ display: 'flex', justifyContent: 'flex-end', marginTop: '8px' }}>
|
||
<button
|
||
className="button"
|
||
onClick={handleClose}
|
||
style={{ width: '100%', justifyContent: 'center', display: 'flex', alignItems: 'center' }}
|
||
>
|
||
我知道了
|
||
</button>
|
||
</div>
|
||
</motion.div>
|
||
</motion.div>
|
||
)}
|
||
</AnimatePresence>
|
||
);
|
||
}
|