summaryrefslogtreecommitdiffstats
path: root/src/components
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2022-03-01 12:23:49 +0100
committerArmand Philippot <git@armandphilippot.com>2022-03-01 12:23:49 +0100
commit69574a1db207706aa5b39030039bd578f9b0b67a (patch)
tree61dc3fabcd1572320300291d0bfb5eaa7a15cd02 /src/components
parent99ae0a9d3a923ca1e998dc9b504dad607fdfd768 (diff)
refactor: import dynamically SearchForm and Settings components
These components are only available after a click from the user, so using dynamic import should improve performances.
Diffstat (limited to 'src/components')
-rw-r--r--src/components/Toolbar/Toolbar.tsx19
1 files changed, 15 insertions, 4 deletions
diff --git a/src/components/Toolbar/Toolbar.tsx b/src/components/Toolbar/Toolbar.tsx
index 7b28757..17f9ef9 100644
--- a/src/components/Toolbar/Toolbar.tsx
+++ b/src/components/Toolbar/Toolbar.tsx
@@ -1,10 +1,21 @@
import { ButtonToolbar } from '@components/Buttons';
import MainNav from '@components/MainNav/MainNav';
-import SearchForm from '@components/SearchForm/SearchForm';
-import Settings from '@components/Settings/Settings';
+import Spinner from '@components/Spinner/Spinner';
+import dynamic from 'next/dynamic';
import { RefObject, useCallback, useEffect, useRef, useState } from 'react';
import styles from './Toolbar.module.scss';
+const DynamicSearchForm = dynamic(
+ () => import('@components/SearchForm/SearchForm'),
+ {
+ loading: () => <Spinner />,
+ }
+);
+
+const DynamicSettings = dynamic(() => import('@components/Settings/Settings'), {
+ loading: () => <Spinner />,
+});
+
const Toolbar = () => {
const [isNavOpened, setIsNavOpened] = useState<boolean>(false);
const [isSearchOpened, setIsSearchOpened] = useState<boolean>(false);
@@ -129,7 +140,7 @@ const Toolbar = () => {
setIsActivated={setIsSearchOpened}
/>
<div id="search-modal" className={searchClasses} ref={searchModalRef}>
- <SearchForm isOpened={isSearchOpened} />
+ <DynamicSearchForm isOpened={isSearchOpened} />
</div>
<ButtonToolbar
ref={settingsBtnRef}
@@ -142,7 +153,7 @@ const Toolbar = () => {
className={settingsClasses}
ref={settingsModalRef}
>
- <Settings />
+ <DynamicSettings />
</div>
</div>
);