From d82863ff88e3085790dcaf187a0ff60c41f14efa Mon Sep 17 00:00:00 2001 From: Nikolaj Frey Date: Tue, 15 Aug 2023 11:01:05 +1000 Subject: [PATCH] feat: feature/mvp-sprint-1 Made settings menu more user friendly --- .../app/components/Thingtime/SettingsMenu.tsx | 241 ++++++++++-------- 1 file changed, 140 insertions(+), 101 deletions(-) diff --git a/remix/app/components/Thingtime/SettingsMenu.tsx b/remix/app/components/Thingtime/SettingsMenu.tsx index 4371203..6823e24 100644 --- a/remix/app/components/Thingtime/SettingsMenu.tsx +++ b/remix/app/components/Thingtime/SettingsMenu.tsx @@ -1,10 +1,42 @@ import React, { useState } from "react" +import ClickAwayListener from "react-click-away-listener" import { Center, Flex, Text } from "@chakra-ui/react" import { Icon } from "../Icon/Icon" export const SettingsMenu = (props) => { const [show, setShow] = useState(false) + const hideRef = React.useRef(null) + const [opacity, setOpacity] = React.useState(props?.opacity === 0 ? 0 : 1) + + const opacityRef = React.useRef(null) + + const waitTime = 1555 + + React.useEffect(() => { + clearInterval(opacityRef?.current) + if (props?.opacity) { + setOpacity(props?.opacity) + } else { + opacityRef.current = setInterval(() => { + setOpacity(props?.opacity) + setShow(false) + }, waitTime) + } + }, [props?.opacity]) + + React.useEffect(() => { + if (show || props?.opacity) { + clearInterval(hideRef?.current) + } + }, [show, props?.opacity]) + + const maybeHide = React.useCallback(() => { + clearInterval(hideRef?.current) + hideRef.current = setTimeout(() => { + setShow(false) + }, waitTime) + }, []) const showMenu = React.useCallback(() => { setShow(true) @@ -46,117 +78,124 @@ export const SettingsMenu = (props) => { const iconSize = 10 return ( -
- - - - +
+ + + - {!props?.readonly && ( - - - - Types - - - )} - {!props?.readonly && - types.map((type, idx) => { - const ret = ( - div": { - background: "greys.light", - }, - }} - onClick={() => onChangeType(type?.key || type)} - paddingY={1} - > - - - - {type?.label || type?.key || type} - - - - ) - return ret - })} - - {!props?.readonly && ( + {!props?.readonly && ( + + + + Types + + + )} - - - Recycle - + {!props?.readonly && + types.map((type, idx) => { + const ret = ( + div": { + background: "greys.light", + }, + }} + cursor="pointer" + onClick={() => onChangeType(type?.key || type)} + paddingY={1} + > + + + + {type?.label || type?.key || type} + + + + ) + return ret + })} - )} + {!props?.readonly && ( + + + + Recycle + + + )} + - -
+
+ ) }