2024-09-18 06:45:20 +03:00
|
|
|
import { useAppSettingHelper } from '@affine/core/components/hooks/affine/use-app-setting-helper';
|
2024-11-05 14:46:03 +03:00
|
|
|
import { WindowsAppControls } from '@affine/core/components/pure/header/windows-app-controls';
|
2024-11-04 07:38:03 +03:00
|
|
|
import { ThemeProvider } from '@affine/core/components/theme-provider';
|
2024-10-08 10:18:03 +03:00
|
|
|
import { configureAppSidebarModule } from '@affine/core/modules/app-sidebar';
|
2024-11-05 06:00:33 +03:00
|
|
|
import { ShellAppSidebarFallback } from '@affine/core/modules/app-sidebar/views';
|
2024-09-18 06:45:20 +03:00
|
|
|
import {
|
|
|
|
AppTabsHeader,
|
|
|
|
configureAppTabsHeaderModule,
|
|
|
|
} from '@affine/core/modules/app-tabs-header';
|
2024-10-30 12:16:20 +03:00
|
|
|
import { configureDesktopApiModule } from '@affine/core/modules/desktop-api';
|
2024-10-15 13:30:02 +03:00
|
|
|
import { configureI18nModule, I18nProvider } from '@affine/core/modules/i18n';
|
2024-09-18 06:45:20 +03:00
|
|
|
import { configureElectronStateStorageImpls } from '@affine/core/modules/storage';
|
2024-11-04 07:38:03 +03:00
|
|
|
import { configureAppThemeModule } from '@affine/core/modules/theme';
|
2024-09-18 06:45:20 +03:00
|
|
|
import {
|
|
|
|
configureGlobalStorageModule,
|
|
|
|
Framework,
|
|
|
|
FrameworkRoot,
|
|
|
|
} from '@toeverything/infra';
|
|
|
|
|
|
|
|
import * as styles from './app.css';
|
|
|
|
|
|
|
|
const framework = new Framework();
|
|
|
|
configureGlobalStorageModule(framework);
|
|
|
|
configureElectronStateStorageImpls(framework);
|
|
|
|
configureAppTabsHeaderModule(framework);
|
2024-10-08 10:18:03 +03:00
|
|
|
configureAppSidebarModule(framework);
|
2024-10-15 13:30:02 +03:00
|
|
|
configureI18nModule(framework);
|
2024-10-30 12:16:20 +03:00
|
|
|
configureDesktopApiModule(framework);
|
2024-11-01 10:23:37 +03:00
|
|
|
configureAppThemeModule(framework);
|
2024-09-18 06:45:20 +03:00
|
|
|
const frameworkProvider = framework.provider();
|
|
|
|
|
|
|
|
export function App() {
|
|
|
|
const { appSettings } = useAppSettingHelper();
|
|
|
|
const translucent =
|
|
|
|
BUILD_CONFIG.isElectron &&
|
|
|
|
environment.isMacOs &&
|
|
|
|
appSettings.enableBlurBackground;
|
|
|
|
return (
|
|
|
|
<FrameworkRoot framework={frameworkProvider}>
|
|
|
|
<ThemeProvider>
|
2024-10-15 13:30:02 +03:00
|
|
|
<I18nProvider>
|
|
|
|
<div className={styles.root} data-translucent={translucent}>
|
|
|
|
<AppTabsHeader mode="shell" className={styles.appTabsHeader} />
|
2024-11-05 06:00:33 +03:00
|
|
|
<div className={styles.body}>
|
|
|
|
<ShellAppSidebarFallback />
|
|
|
|
</div>
|
2024-11-05 14:46:03 +03:00
|
|
|
{environment.isWindows && (
|
|
|
|
<div style={{ position: 'fixed', right: 0, top: 0, zIndex: 5 }}>
|
|
|
|
<WindowsAppControls />
|
|
|
|
</div>
|
|
|
|
)}
|
2024-10-15 13:30:02 +03:00
|
|
|
</div>
|
|
|
|
</I18nProvider>
|
2024-09-18 06:45:20 +03:00
|
|
|
</ThemeProvider>
|
|
|
|
</FrameworkRoot>
|
|
|
|
);
|
|
|
|
}
|