diff --git a/src/components/controls/panelChevron.tsx b/src/components/controls/panelChevron.tsx new file mode 100644 index 000000000..43f1d9f81 --- /dev/null +++ b/src/components/controls/panelChevron.tsx @@ -0,0 +1,22 @@ +import React from "react"; +import styled from 'styled-components'; +import { FaChevronRight, FaChevronDown } from "react-icons/fa"; + +const Container = styled.span` + padding-right: 6px; + color: white; +` + +type Props = { + show: boolean +} + +export const PanelChevron = ({ show }: Props) => { + const icon = show ? : + + return ( + + {icon} + + ) +} diff --git a/src/components/controls/panelHeader.tsx b/src/components/controls/panelHeader.tsx index 23f022842..921dec176 100644 --- a/src/components/controls/panelHeader.tsx +++ b/src/components/controls/panelHeader.tsx @@ -2,22 +2,28 @@ import React from "react"; import { HeaderContainer } from "./styles"; import PanelToggle from "./panel-toggle"; import { AnnotatedTitle } from "./annotatedTitle"; +import { PanelChevron } from "./panelChevron"; type Props = { panel: string title: string panelIsVisible: boolean tooltip: JSX.Element + optionsAreVisible: boolean + setOptionsAreVisible: React.Dispatch> mobile: boolean } -export const PanelHeader = ({ panel, title, panelIsVisible, tooltip, mobile }: Props) => { +export const PanelHeader = ({ panel, title, panelIsVisible, tooltip, optionsAreVisible, setOptionsAreVisible, mobile }: Props) => { return ( - + setOptionsAreVisible(!optionsAreVisible)}> + + + diff --git a/src/components/controls/panelSection.tsx b/src/components/controls/panelSection.tsx index a7c0e48c2..5fa1036f1 100644 --- a/src/components/controls/panelSection.tsx +++ b/src/components/controls/panelSection.tsx @@ -4,6 +4,7 @@ import { PanelSectionContainer } from "./styles"; import { PanelHeader } from "./panelHeader"; import { RootState } from "../../store"; + type Props = { panel: string title: string @@ -18,6 +19,14 @@ export const PanelSection = ({ panel, title, tooltip, options, mobile }: Props) const panelIsVisible = panelsToDisplay.includes(panel) + // Initially, panel visibility determines options visibility. + const [optionsAreVisible, setOptionsAreVisible] = React.useState(panelIsVisible); + + // Subsequent panel visibility updates also determines options visibility. + React.useEffect(() => { + setOptionsAreVisible(panelIsVisible) + }, [panelIsVisible]) + return ( - {panelIsVisible && options} + {optionsAreVisible && options} ); };