feishin/src/renderer/app.tsx

105 lines
3.2 KiB
TypeScript
Raw Normal View History

2022-12-19 15:59:14 -08:00
import { useEffect } from 'react';
import { ClientSideRowModelModule } from '@ag-grid-community/client-side-row-model';
import { ModuleRegistry } from '@ag-grid-community/core';
import { InfiniteRowModelModule } from '@ag-grid-community/infinite-row-model';
import { MantineProvider } from '@mantine/core';
import { ModalsProvider } from '@mantine/modals';
import { initSimpleImg } from 'react-simple-img';
import { BaseContextModal } from './components';
import { useTheme } from './hooks';
import { Notifications } from '@mantine/notifications';
2022-12-19 15:59:14 -08:00
import { AppRouter } from './router/app-router';
import { useSettingsStore } from './store/settings.store';
import './styles/global.scss';
import '@ag-grid-community/styles/ag-grid.css';
import { ContextMenuProvider } from '/@/renderer/features/context-menu';
2022-12-31 19:26:58 -08:00
import { useHandlePlayQueueAdd } from '/@/renderer/features/player/hooks/use-handle-playqueue-add';
import { PlayQueueHandlerContext } from '/@/renderer/features/player';
2022-12-19 15:59:14 -08:00
ModuleRegistry.registerModules([ClientSideRowModelModule, InfiniteRowModelModule]);
initSimpleImg({ threshold: 0.05 }, true);
export const App = () => {
const theme = useTheme();
const contentFont = useSettingsStore((state) => state.general.fontContent);
2022-12-31 19:26:58 -08:00
const handlePlayQueueAdd = useHandlePlayQueueAdd();
2022-12-19 15:59:14 -08:00
useEffect(() => {
const root = document.documentElement;
root.style.setProperty('--content-font-family', contentFont);
2022-12-19 16:37:21 -08:00
}, [contentFont]);
2022-12-19 15:59:14 -08:00
return (
2022-12-31 19:26:58 -08:00
<MantineProvider
withGlobalStyles
withNormalizeCSS
theme={{
colorScheme: theme as 'light' | 'dark',
components: { Modal: { styles: { body: { padding: '.5rem' } } } },
defaultRadius: 'xs',
dir: 'ltr',
focusRing: 'auto',
focusRingStyles: {
inputStyles: () => ({
border: '1px solid var(--primary-color)',
}),
resetStyles: () => ({ outline: 'none' }),
styles: () => ({
outline: '1px solid var(--primary-color)',
outlineOffset: '-1px',
}),
},
fontFamily: 'var(--content-font-family)',
fontSizes: {
lg: '1.5rem',
md: '1.1rem',
sm: '0.9rem',
xl: '2rem',
xs: '0.8rem',
},
headings: {
fontFamily: 'var(--content-font-family)',
fontWeight: 700,
sizes: {
h1: '6rem',
h2: '4rem',
h3: '3rem',
h4: '1.5rem',
h5: '1.2rem',
h6: '1rem',
},
2022-12-31 19:26:58 -08:00
},
other: {},
spacing: {
lg: '2rem',
md: '1rem',
sm: '0.5rem',
xl: '4rem',
xs: '0rem',
2022-12-31 19:26:58 -08:00
},
}}
>
<ModalsProvider
modalProps={{
centered: true,
transitionDuration: 300,
transitionProps: {
exitDuration: 300,
transition: 'slide-down',
},
2022-12-19 15:59:14 -08:00
}}
modals={{ base: BaseContextModal }}
2022-12-19 15:59:14 -08:00
>
<PlayQueueHandlerContext.Provider value={{ handlePlayQueueAdd }}>
<ContextMenuProvider>
<Notifications />
<AppRouter />
</ContextMenuProvider>
</PlayQueueHandlerContext.Provider>
</ModalsProvider>
2022-12-31 19:26:58 -08:00
</MantineProvider>
2022-12-19 15:59:14 -08:00
);
};