173 lines
5.7 KiB
TypeScript
Raw Normal View History

2024-03-23 22:19:49 +00:00
import React from 'react';
import { Box, Center, Flex } from '@chakra-ui/react';
import { Link, useLocation, useNavigate } from '@remix-run/react';
2023-06-28 01:12:17 +00:00
2024-03-23 22:19:49 +00:00
import { Commander } from '../Commander/Commander';
import { CommanderV1 } from '../Commander/CommanderV2';
import { Icon } from '../Icon/Icon';
import { RainbowSkeleton } from '../Skeleton/RainbowSkeleton';
import { ProfileDrawer } from './ProfileDrawer';
export const Nav = (props) => {
2024-03-23 22:19:49 +00:00
const [profileDrawerOpen, setProfileDrawerOpen] = React.useState(false);
2024-03-23 22:19:49 +00:00
const { pathname } = useLocation();
2024-03-23 22:19:49 +00:00
const navigate = useNavigate();
const toggleProfileDrawer = React.useCallback(() => {
2024-03-23 22:19:49 +00:00
setProfileDrawerOpen(!profileDrawerOpen);
}, [profileDrawerOpen]);
const inEditorMode = React.useMemo(() => {
2024-03-23 22:19:49 +00:00
if (pathname.slice(0, 7) === '/editor') {
return true;
}
2024-03-23 22:19:49 +00:00
return false;
}, [pathname]);
const inEditMode = React.useMemo(() => {
2024-03-23 22:19:49 +00:00
if (pathname.slice(0, 5) === '/edit') {
return true;
}
2024-03-23 22:19:49 +00:00
return false;
}, [pathname]);
const editorToggleable = React.useMemo(() => {
2024-03-23 22:19:49 +00:00
if (pathname.slice(0, 7) === '/things') {
return true;
} else if (pathname.slice(0, 5) === '/edit') {
return true;
}
2024-03-23 22:19:49 +00:00
return false;
}, [pathname]);
const toggleEdit = React.useCallback(
(e) => {
// if first characters of pathname are /things replace with /edit
// or if first characters of pathname are /edit replace with /things
2024-03-23 22:19:49 +00:00
if (pathname.slice(0, 7) === '/things') {
const newPathname = pathname.replace('/things', '/edit');
navigate(newPathname);
} else if (pathname.slice(0, 7) === '/editor') {
const newPathname = pathname.replace('/editor', '/things');
navigate(newPathname);
} else if (pathname.slice(0, 5) === '/edit') {
const newPathname = pathname.replace('/edit', '/things');
navigate(newPathname);
}
},
[pathname, navigate]
2024-03-23 22:19:49 +00:00
);
const toggleEditor = React.useCallback(
(e) => {
// if first characters of pathname are /things replace with /edit
// or if first characters of pathname are /edit replace with /things
2024-03-23 22:19:49 +00:00
if (pathname.slice(0, 7) === '/editor') {
const newPathname = pathname.replace('/editor', '/edit');
navigate(newPathname);
} else if (pathname.slice(0, 5) === '/edit') {
const newPathname = pathname.replace('/edit', '/editor');
navigate(newPathname);
}
},
[pathname, navigate]
2024-03-23 22:19:49 +00:00
);
2023-06-28 01:12:17 +00:00
return (
<>
2024-03-23 22:19:49 +00:00
<Box position="fixed" zIndex={9999} top={0} right={0} left={0} maxWidth="100vw">
<Flex
as="nav"
position="relative"
alignItems="center"
justifyContent="center"
flexDirection="row"
width="100%"
maxWidth="100%"
marginY={1}
paddingX="18px"
paddingY="14px"
// bg='white'
// boxShadow={'0px 0px 10px rgba(0,0,0,0.1)'}
>
2024-03-23 22:19:49 +00:00
<Center className="nav-left-section" display={['none', 'flex']} height="100%" marginRight="auto">
<Center transform="scaleX(-100%)" cursor="pointer">
<Link to="/">
2024-03-23 22:19:49 +00:00
<Icon size="12px" name="🦄"></Icon>
</Link>
</Center>
</Center>
<CommanderV1 global id="nav" rainbow={false}></CommanderV1>
2024-03-23 22:19:49 +00:00
<Center className="nav-right-section" columnGap={[3, 8]} height="100%" marginLeft="auto">
{inEditMode && (
<Center
// transform="scaleX(-100%)"
cursor="pointer"
onClick={toggleEditor}
>
<Icon
chakras={{
2024-03-23 22:19:49 +00:00
opacity: inEditorMode ? 1 : 0.3
}}
size="12px"
2024-03-23 22:19:49 +00:00
name="👀"
></Icon>
{/* <Icon
size="12px"
name={inEditorMode ? "glowing star" : "star"}
></Icon> */}
</Center>
)}
{editorToggleable && (
2024-03-23 22:19:49 +00:00
<Center transform="scaleX(-100%)" cursor="pointer" onClick={toggleEdit}>
<Icon
chakras={{
2024-03-23 22:19:49 +00:00
opacity: inEditMode ? 1 : 0.3
}}
size="12px"
2024-03-23 22:19:49 +00:00
name="🎨"
></Icon>
{/* <Icon
size="12px"
name={inEditMode ? "glowing star" : "star"}
></Icon> */}
</Center>
)}
{/* TODO - Add conditional only show if loggedIn */}
2024-07-16 09:11:03 +00:00
{/* <Center transform={['', 'scaleX(-100%)']} cursor="pointer">
<Link to="/logout">
<Icon size="12px" name="🗝️"></Icon>
</Link>
2024-07-16 09:11:03 +00:00
</Center> */}
2024-03-23 22:19:49 +00:00
<Center transform={['', 'scaleX(-100%)']} cursor="pointer">
2024-04-20 13:43:55 +00:00
<Link to="/login">
<Icon size="12px" name="🌈"></Icon>
</Link>
</Center>
2024-03-23 22:19:49 +00:00
<Center display={['flex', 'none']} cursor="pointer">
<Link to="/">
2024-03-23 22:19:49 +00:00
<Icon size="12px" name="🦄"></Icon>
</Link>
</Center>
</Center>
{/* <RainbowSkeleton
marginLeft="auto"
width="25px"
height="25px"
cursor="pointer"
onClick={toggleProfileDrawer}
background="rgba(0,0,0,0.1)"
sx={{}}
borderRadius="999px"
></RainbowSkeleton> */}
{/* <RainbowSkeleton w='40px' ml='auto' mr={"4px"}></RainbowSkeleton>
<RainbowSkeleton></RainbowSkeleton> */}
</Flex>
</Box>
{/* <ProfileDrawer isOpen={profileDrawerOpen}></ProfileDrawer> */}
2023-06-28 01:12:17 +00:00
</>
2024-03-23 22:19:49 +00:00
);
};