import { Flex, FlexProps } from '@mantine/core'; import { AnimatePresence, motion, Variants } from 'framer-motion'; import { useRef } from 'react'; import styled from 'styled-components'; import { useShouldPadTitlebar } from '/@/renderer/hooks'; const Container = styled(motion(Flex))<{ height?: string; position?: string; }>` position: ${(props) => props.position || 'relative'}; z-index: 2000; width: 100%; height: ${(props) => props.height || '60px'}; `; const Header = styled(motion.div)<{ $isHidden?: boolean; $padRight?: boolean }>` position: relative; z-index: 15; width: 100%; height: 100%; margin-right: ${(props) => props.$padRight && '170px'}; user-select: ${(props) => (props.$isHidden ? 'none' : 'auto')}; pointer-events: ${(props) => (props.$isHidden ? 'none' : 'auto')}; -webkit-app-region: drag; button { -webkit-app-region: no-drag; } input { -webkit-app-region: no-drag; } `; const BackgroundImage = styled.div<{ background: string }>` position: absolute; top: 0; z-index: 1; width: 100%; height: 100%; background: ${(props) => props.background || 'var(--titlebar-bg)'}; `; const BackgroundImageOverlay = styled.div` position: absolute; top: 0; left: 0; z-index: 10; width: 100%; height: 100%; background: linear-gradient(rgba(0, 0, 0, 30%), rgba(0, 0, 0, 30%)); `; export interface PageHeaderProps extends Omit { backgroundColor?: string; children?: React.ReactNode; height?: string; isHidden?: boolean; position?: string; } const TitleWrapper = styled(motion.div)` width: 100%; height: 100%; `; const variants: Variants = { animate: { opacity: 1 }, exit: { opacity: 0 }, initial: { opacity: 0 }, }; export const PageHeader = ({ position, height, backgroundColor, isHidden, children, ...props }: PageHeaderProps) => { const ref = useRef(null); const padRight = useShouldPadTitlebar(); return (
{!isHidden && ( {children} )}
{backgroundColor && ( <> )}
); };