|
1 | 1 | import React from 'react'
|
2 | 2 | import { InstantSearch } from 'react-instantsearch-dom'
|
3 | 3 | import styled from 'styled-components'
|
4 |
| - |
5 | 4 | import { useMeilisearchClientContext } from 'context/MeilisearchClientContext'
|
| 5 | +import useLocalStorage from 'hooks/useLocalStorage' |
6 | 6 | import Box from 'components/Box'
|
7 | 7 | import Header from 'components/Header/index'
|
8 | 8 | import RightPanel from 'components/RightPanel'
|
@@ -45,11 +45,17 @@ const Body = ({
|
45 | 45 | }) => {
|
46 | 46 | const { meilisearchJsClient, instantMeilisearchClient } =
|
47 | 47 | useMeilisearchClientContext()
|
| 48 | + const [storedIsPanelOpen, setStoredIsPanelOpen] = useLocalStorage( |
| 49 | + 'meilisearch-panel-open', |
| 50 | + true |
| 51 | + ) |
48 | 52 |
|
49 | 53 | // Right-side panel
|
50 |
| - const [isRightPanelOpen, setIsRightPanelOpen] = React.useState(true) |
| 54 | + const [isRightPanelOpen, setIsRightPanelOpen] = |
| 55 | + React.useState(storedIsPanelOpen) |
51 | 56 | const handleTogglePanel = React.useCallback(() => {
|
52 | 57 | setIsRightPanelOpen((isOpen) => !isOpen)
|
| 58 | + setStoredIsPanelOpen((isOpen) => !isOpen) |
53 | 59 | }, [])
|
54 | 60 |
|
55 | 61 | return (
|
@@ -84,7 +90,10 @@ const Body = ({
|
84 | 90 | </ContentWrapper>
|
85 | 91 | <RightPanel
|
86 | 92 | isOpen={isRightPanelOpen}
|
87 |
| - onClose={() => setIsRightPanelOpen(false)} |
| 93 | + onClose={() => { |
| 94 | + setIsRightPanelOpen(false) |
| 95 | + setStoredIsPanelOpen(false) |
| 96 | + }} |
88 | 97 | />
|
89 | 98 | </InstantSearch>
|
90 | 99 | )
|
|
0 commit comments