Happy New Year

This commit is contained in:
CaIon 2023-12-27 18:04:02 +08:00
parent c09f3b9282
commit 1a8a24698f
2 changed files with 34 additions and 10 deletions

View File

@ -10,6 +10,7 @@
"react": "^18.2.0", "react": "^18.2.0",
"react-dom": "^18.2.0", "react-dom": "^18.2.0",
"react-dropzone": "^14.2.3", "react-dropzone": "^14.2.3",
"react-fireworks": "^1.0.4",
"react-router-dom": "^6.3.0", "react-router-dom": "^6.3.0",
"react-scripts": "5.0.1", "react-scripts": "5.0.1",
"react-toastify": "^9.0.8", "react-toastify": "^9.0.8",

View File

@ -1,4 +1,4 @@
import React, {useContext, useEffect, useState} from 'react'; import React, {useContext, useEffect, useRef, useState} from 'react';
import {Link, useNavigate} from 'react-router-dom'; import {Link, useNavigate} from 'react-router-dom';
import {UserContext} from '../context/User'; import {UserContext} from '../context/User';
@ -6,18 +6,12 @@ import {Button, Container, Icon, Menu, Segment} from 'semantic-ui-react';
import {API, getLogo, getSystemName, isAdmin, isMobile, showSuccess} from '../helpers'; import {API, getLogo, getSystemName, isAdmin, isMobile, showSuccess} from '../helpers';
import '../index.css'; import '../index.css';
import fireworks from 'react-fireworks';
import { import {
IconAt,
IconHistogram,
IconGift,
IconKey, IconKey,
IconUser, IconUser,
IconLayers, IconHelpCircle
IconHelpCircle,
IconCreditCard,
IconSemiLogo,
IconHome,
IconImage
} from '@douyinfe/semi-icons'; } from '@douyinfe/semi-icons';
import {Nav, Avatar, Dropdown, Layout, Switch} from '@douyinfe/semi-ui'; import {Nav, Avatar, Dropdown, Layout, Switch} from '@douyinfe/semi-ui';
import {stringToColor} from "../helpers/render"; import {stringToColor} from "../helpers/render";
@ -49,6 +43,8 @@ const HeaderBar = () => {
const systemName = getSystemName(); const systemName = getSystemName();
const logo = getLogo(); const logo = getLogo();
var themeMode = localStorage.getItem('theme-mode'); var themeMode = localStorage.getItem('theme-mode');
const currentDate = new Date();
const isNewYear = currentDate.getMonth() === 0 && currentDate.getDate() === 1;
async function logout() { async function logout() {
setShowSidebar(false); setShowSidebar(false);
@ -59,10 +55,24 @@ const HeaderBar = () => {
navigate('/login'); navigate('/login');
} }
const handleNewYearClick = () => {
fireworks.init("root",{});
fireworks.start();
setTimeout(() => {
fireworks.stop();
setTimeout(() => {
window.location.reload();
}, 10000);
}, 3000);
};
useEffect(() => { useEffect(() => {
if (themeMode === 'dark') { if (themeMode === 'dark') {
switchMode(true); switchMode(true);
} }
if (isNewYear) {
console.log('Happy New Year!');
}
}, []); }, []);
const switchMode = (model) => { const switchMode = (model) => {
@ -105,6 +115,19 @@ const HeaderBar = () => {
}} }}
footer={ footer={
<> <>
{isNewYear &&
// happy new year
<Dropdown
position="bottomRight"
render={
<Dropdown.Menu>
<Dropdown.Item onClick={handleNewYearClick}>Happy New Year!!!</Dropdown.Item>
</Dropdown.Menu>
}
>
<Nav.Item itemKey={'new-year'} text={'🏮'}/>
</Dropdown>
}
<Nav.Item itemKey={'about'} icon={<IconHelpCircle />} /> <Nav.Item itemKey={'about'} icon={<IconHelpCircle />} />
<Switch checkedText="🌞" size={'large'} checked={dark} uncheckedText="🌙" onChange={switchMode} /> <Switch checkedText="🌞" size={'large'} checked={dark} uncheckedText="🌙" onChange={switchMode} />
{userState.user ? {userState.user ?