1
0
mirror of https://github.com/checktheroads/hyperglass synced 2024-05-11 05:55:08 +00:00
Files
checktheroads-hyperglass/hyperglass/ui/components/layout/frame.tsx

66 lines
1.9 KiB
TypeScript
Raw Normal View History

import { useRef } from 'react';
import { Flex } from '@chakra-ui/react';
2021-01-02 12:54:00 -07:00
import { isSafari } from 'react-device-detect';
import { If, Debugger, Greeting, Footer, Header } from '~/components';
2020-12-29 02:07:42 -07:00
import { useConfig, useColorValue } from '~/context';
import { useLGState, useLGMethods } from '~/hooks';
2020-12-29 02:07:42 -07:00
import { ResetButton } from './resetButton';
import type { TFrame } from './types';
export const Frame = (props: TFrame) => {
const { developer_mode } = useConfig();
const { isSubmitting } = useLGState();
const { resetForm } = useLGMethods();
const bg = useColorValue('white', 'black');
const color = useColorValue('black', 'white');
const containerRef = useRef<HTMLDivElement>({} as HTMLDivElement);
function handleReset(): void {
containerRef.current.scrollIntoView({ behavior: 'smooth', block: 'start' });
isSubmitting.set(false);
resetForm();
}
return (
<>
2020-12-29 02:07:42 -07:00
<Flex
bg={bg}
w="100%"
color={color}
2021-01-02 12:54:00 -07:00
flex="1 0 auto"
2020-12-29 02:07:42 -07:00
flexDir="column"
2021-01-02 12:54:00 -07:00
id="__hyperglass"
ref={containerRef}
/** minHeight
* This is a Safari-specific fix. Without it, the footer will appear to be "under" the
* viewport. Safari needs `-webkit-fill-available`, but other browsers need `100vh`.
* @see https://allthingssmitty.com/2020/05/11/css-fix-for-100vh-in-mobile-webkit/
*/
minHeight={isSafari ? '-webkit-fill-available' : '100vh'}>
2020-12-29 02:07:42 -07:00
<Header resetForm={handleReset} />
<Flex
px={2}
py={0}
w="100%"
as="main"
align="center"
flex="1 1 auto"
justify="start"
flexDir="column"
textAlign="center"
{...props}
/>
<Footer />
<If c={developer_mode}>
<Debugger />
</If>
2020-12-29 02:07:42 -07:00
<ResetButton developerMode={developer_mode} resetForm={handleReset} />
</Flex>
<Greeting />
</>
);
};