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: false,
|
|
|
|
|
showSider: false,
|
2024-12-11 23:08:52 +08:00
|
|
|
shouldInnerPadding: false,
|
2024-12-11 16:11:27 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const dispatch = (action) => {
|
|
|
|
|
if ('type' in action) {
|
|
|
|
|
switch (action.type) {
|
|
|
|
|
case 'TOGGLE_SIDER':
|
|
|
|
|
setState(prev => ({ ...prev, showSider: !prev.showSider }));
|
|
|
|
|
break;
|
|
|
|
|
case 'SET_SIDER':
|
|
|
|
|
setState(prev => ({ ...prev, showSider: action.payload }));
|
|
|
|
|
break;
|
|
|
|
|
case 'SET_MOBILE':
|
|
|
|
|
setState(prev => ({ ...prev, isMobile: action.payload }));
|
|
|
|
|
break;
|
2024-12-11 23:08:52 +08:00
|
|
|
case 'SET_INNER_PADDING':
|
|
|
|
|
setState(prev => ({ ...prev, shouldInnerPadding: action.payload }));
|
2024-12-11 21:17:46 +08:00
|
|
|
break;
|
2024-12-11 16:11:27 +08:00
|
|
|
default:
|
|
|
|
|
setState(prev => ({ ...prev, ...action }));
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
setState(prev => ({ ...prev, ...action }));
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
const updateIsMobile = () => {
|
|
|
|
|
dispatch({ type: 'SET_MOBILE', payload: isMobile() });
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
updateIsMobile();
|
|
|
|
|
|
2024-12-12 20:31:40 +08:00
|
|
|
const updateShowSider = () => {
|
|
|
|
|
if (isMobile()) {
|
|
|
|
|
dispatch({ type: 'SET_SIDER', payload: false });
|
|
|
|
|
} else {
|
|
|
|
|
// check pathname
|
|
|
|
|
const pathname = window.location.pathname;
|
|
|
|
|
console.log(pathname)
|
|
|
|
|
if (pathname === '' || pathname === '/' || pathname.includes('/home') || pathname.includes('/chat')) {
|
|
|
|
|
dispatch({ type: 'SET_SIDER', payload: false });
|
|
|
|
|
dispatch({ type: 'SET_INNER_PADDING', payload: false });
|
|
|
|
|
} else {
|
|
|
|
|
dispatch({ type: 'SET_SIDER', payload: true });
|
|
|
|
|
dispatch({ type: 'SET_INNER_PADDING', payload: true });
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
updateShowSider()
|
|
|
|
|
|
|
|
|
|
|
2024-12-11 16:11:27 +08:00
|
|
|
// Optionally, add event listeners to handle window resize
|
|
|
|
|
window.addEventListener('resize', updateIsMobile);
|
|
|
|
|
|
|
|
|
|
// Cleanup event listener on component unmount
|
|
|
|
|
return () => {
|
|
|
|
|
window.removeEventListener('resize', updateIsMobile);
|
|
|
|
|
};
|
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<StyleContext.Provider value={[state, dispatch]}>
|
|
|
|
|
{children}
|
|
|
|
|
</StyleContext.Provider>
|
|
|
|
|
);
|
|
|
|
|
};
|