diff options
| author | Armand Philippot <git@armandphilippot.com> | 2022-03-01 12:23:49 +0100 | 
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2022-03-01 12:23:49 +0100 | 
| commit | 69574a1db207706aa5b39030039bd578f9b0b67a (patch) | |
| tree | 61dc3fabcd1572320300291d0bfb5eaa7a15cd02 /src/components | |
| parent | 99ae0a9d3a923ca1e998dc9b504dad607fdfd768 (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.tsx | 19 | 
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>    ); | 
