107 lines
3.0 KiB
JavaScript
Raw Normal View History

2024-12-11 16:11:27 +08:00
// contexts/User/index.jsx
import React, { useState, useEffect } from 'react';
import { isMobile } from '../../helpers/index.js';
export const StyleContext = React.createContext({
dispatch: () => null,
});
export const StyleProvider = ({ children }) => {
const [state, setState] = useState({
isMobile: isMobile(),
2024-12-11 16:11:27 +08:00
showSider: false,
siderCollapsed: false,
shouldInnerPadding: false,
2024-12-11 16:11:27 +08:00
});
const dispatch = (action) => {
if ('type' in action) {
switch (action.type) {
case 'TOGGLE_SIDER':
2025-04-04 12:00:38 +08:00
setState((prev) => ({ ...prev, showSider: !prev.showSider }));
2024-12-11 16:11:27 +08:00
break;
case 'SET_SIDER':
2025-04-04 12:00:38 +08:00
setState((prev) => ({ ...prev, showSider: action.payload }));
2024-12-11 16:11:27 +08:00
break;
case 'SET_MOBILE':
2025-04-04 12:00:38 +08:00
setState((prev) => ({ ...prev, isMobile: action.payload }));
2024-12-11 16:11:27 +08:00
break;
case 'SET_SIDER_COLLAPSED':
2025-04-04 12:00:38 +08:00
setState((prev) => ({ ...prev, siderCollapsed: action.payload }));
break;
case 'SET_INNER_PADDING':
2025-04-04 12:00:38 +08:00
setState((prev) => ({ ...prev, shouldInnerPadding: action.payload }));
break;
2024-12-11 16:11:27 +08:00
default:
2025-04-04 12:00:38 +08:00
setState((prev) => ({ ...prev, ...action }));
2024-12-11 16:11:27 +08:00
}
} else {
2025-04-04 12:00:38 +08:00
setState((prev) => ({ ...prev, ...action }));
2024-12-11 16:11:27 +08:00
}
};
useEffect(() => {
const updateIsMobile = () => {
const mobileDetected = isMobile();
dispatch({ type: 'SET_MOBILE', payload: mobileDetected });
2025-04-04 12:00:38 +08:00
// If on mobile, we might want to auto-hide the sidebar
if (mobileDetected && state.showSider) {
dispatch({ type: 'SET_SIDER', payload: false });
}
2024-12-11 16:11:27 +08:00
};
updateIsMobile();
const updateShowSider = () => {
// check pathname
const pathname = window.location.pathname;
2025-04-04 12:00:38 +08:00
if (
pathname === '' ||
pathname === '/' ||
pathname.includes('/home') ||
pathname.includes('/chat')
) {
dispatch({ type: 'SET_SIDER', payload: false });
dispatch({ type: 'SET_INNER_PADDING', payload: false });
} else if (pathname === '/setup') {
dispatch({ type: 'SET_SIDER', payload: false });
dispatch({ type: 'SET_INNER_PADDING', payload: false });
} else {
// Only show sidebar on non-mobile devices by default
dispatch({ type: 'SET_SIDER', payload: !isMobile() });
dispatch({ type: 'SET_INNER_PADDING', payload: true });
}
};
updateShowSider();
const updateSiderCollapsed = () => {
2025-04-04 12:00:38 +08:00
const isCollapsed =
localStorage.getItem('default_collapse_sidebar') === 'true';
dispatch({ type: 'SET_SIDER_COLLAPSED', payload: isCollapsed });
};
updateSiderCollapsed();
// Add event listeners to handle window resize
const handleResize = () => {
updateIsMobile();
};
2025-04-04 12:00:38 +08:00
window.addEventListener('resize', handleResize);
2024-12-11 16:11:27 +08:00
// Cleanup event listener on component unmount
return () => {
window.removeEventListener('resize', handleResize);
2024-12-11 16:11:27 +08:00
};
}, []);
return (
<StyleContext.Provider value={[state, dispatch]}>
{children}
</StyleContext.Provider>
);
};