The communications platform that puts data protection first.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Rocket.Chat/client/components/basic/Page.tsx

109 lines
3.0 KiB

import { Box, Scrollable, ScrollableProps } from '@rocket.chat/fuselage';
import { useMediaQuery } from '@rocket.chat/fuselage-hooks';
import React, { createContext, useContext, useState, FC, Dispatch, SetStateAction } from 'react';
import { useSidebar } from '../../contexts/SidebarContext';
import BurgerMenuButton from './burger/BurgerMenuButton';
import { useSession } from '../../contexts/SessionContext';
type PageContextValue = [
boolean,
Dispatch<SetStateAction<boolean>>,
];
const PageContext = createContext<PageContextValue>([false, (): void => undefined]);
const Page: FC = (props) => {
const [border, setBorder] = useState(false);
return <PageContext.Provider value={[border, setBorder]}>
<Box
backgroundColor='surface'
is='section'
display='flex'
flexDirection='column'
flexGrow={1}
flexShrink={1}
height='full'
overflow='hidden'
{...props}
/>
</PageContext.Provider>;
};
type PageHeaderProps = {
title: string;
};
const PageHeader: FC<PageHeaderProps> = ({ children = undefined, title, ...props }) => {
const [border] = useContext(PageContext);
const hasBurgerMenuButton = useMediaQuery('(max-width: 780px)');
const [isSidebarOpen, setSidebarOpen] = useSidebar();
const unreadMessagesBadge = useSession('unread');
const handleBurgerMenuButtonClick = (): void => {
setSidebarOpen((isSidebarOpen) => !isSidebarOpen);
};
return <Box borderBlockEndWidth='x2' borderBlockEndColor={border ? 'neutral-200' : 'transparent'}>
<Box
marginBlock='x16'
marginInline='x24'
minHeight='x40'
display='flex'
flexDirection='row'
flexWrap='nowrap'
alignItems='center'
color='neutral-800'
{...props}
>
{hasBurgerMenuButton && <BurgerMenuButton
open={isSidebarOpen}
badge={unreadMessagesBadge}
marginInlineEnd='x8'
onClick={handleBurgerMenuButtonClick}
/>}
<Box is='h1' fontScale='h1' flexGrow={1}>{title}</Box>
{children}
</Box>
</Box>;
};
const PageContent = React.forwardRef(function PageContent(props, ref) {
return <Box
ref={ref}
paddingInline='x24'
display='flex'
flexDirection='column'
overflowY='hidden'
height='full'
{...props}
/>;
});
type PageScrollableContentProps = {
onScrollContent?: ScrollableProps['onScrollContent'];
};
const PageScrollableContent: FC<PageScrollableContentProps> = ({ onScrollContent, ...props }) =>
<Scrollable onScrollContent={onScrollContent} >
[NEW] User profile and User card (#18194) * Handle Avatar on Error * User Status Component * User Card Component * More variations * More Variations * Loading State * useTimezoneTime Hook * UTCClock Component * Fix BaseAvatar * getStatus Helper * Rewrite User info to reuse + Stories * Changes to open on Channels * ??? * Fix reactAdapters * Translation Provider * Fix lint * Improve loading state * WIP * UserCard and UserInfo Actions * Lint * Review * wip * Fix user info * Update fuselage * Update fuselage 0.13.0 * sad * sad[2] * fix camelCase paths * Fix Ghost menu * Fix some weird behaviors * Fix missing user ID on actions * Fix visual * Fix VerticalBar * Opss missing email field * Missing some fields * Update Fuselage * Update app/theme/client/imports/components/contextual-bar.css Co-authored-by: Tasso Evangelista <tasso.evangelista@rocket.chat> * Remove Old userInfo template * UserCard Api * Update client/admin/customEmoji/CustomEmojiRoute.js Co-authored-by: Tasso Evangelista <tasso.evangelista@rocket.chat> * Remove unused variables * Fix contextual-bar CSS selectors * Destructure additional props in UserInfoWithData * Remove obsolete props from VerticalBar * Remove commented code * Place useSetModal hook * Apply suggestions from code review Co-authored-by: Tasso Evangelista <tasso.evangelista@rocket.chat> * Fiz markdown * Update client/components/basic/UserCard.js Co-authored-by: Tasso Evangelista <tasso.evangelista@rocket.chat> * Update client/components/basic/avatar/UserAvatar.js Co-authored-by: Tasso Evangelista <tasso.evangelista@rocket.chat> * rename base avatar Co-authored-by: Tasso Evangelista <tasso.evangelista@rocket.chat> Co-authored-by: Gabriel Henriques <gabriel.henriques@rocket.chat>
5 years ago
<Box p='x16' display='flex' flexDirection='column' flexGrow={1} {...props} />
</Scrollable>;
const PageScrollableContentWithShadow: FC<PageScrollableContentProps> = ({ onScrollContent, ...props }) => {
const [, setBorder] = useContext(PageContext);
return <PageScrollableContent
onScrollContent={({ top, ...args }): void => {
setBorder(!top);
onScrollContent && onScrollContent({ top, ...args });
}}
{ ...props }
/>;
};
export default Object.assign(Page, {
Header: PageHeader,
Content: PageContent,
ScrollableContent: PageScrollableContent,
ScrollableContentWithShadow: PageScrollableContentWithShadow,
});