2023-02-06 10:01:03 -08:00
|
|
|
import clsx from 'clsx';
|
2023-01-06 09:51:47 -08:00
|
|
|
import React, { useEffect, useLayoutEffect, useRef, useState } from 'react';
|
2022-11-11 04:16:53 -08:00
|
|
|
import { matchPath, Route, Switch, useHistory } from 'react-router-dom';
|
2022-09-13 08:18:46 -07:00
|
|
|
|
2022-09-22 11:03:12 -07:00
|
|
|
import { Stack } from 'soapbox/components/ui';
|
2022-10-31 09:14:22 -07:00
|
|
|
import { useOwnAccount } from 'soapbox/hooks';
|
2022-09-13 08:18:46 -07:00
|
|
|
|
2022-09-16 07:22:43 -07:00
|
|
|
import ChatPageMain from './components/chat-page-main';
|
2022-09-28 17:26:49 -07:00
|
|
|
import ChatPageNew from './components/chat-page-new';
|
2022-11-01 04:59:30 -07:00
|
|
|
import ChatPageSettings from './components/chat-page-settings';
|
2022-09-16 07:22:43 -07:00
|
|
|
import ChatPageSidebar from './components/chat-page-sidebar';
|
2022-09-28 17:39:22 -07:00
|
|
|
import Welcome from './components/welcome';
|
2022-09-13 08:18:46 -07:00
|
|
|
|
2022-09-28 13:38:05 -07:00
|
|
|
interface IChatPage {
|
2023-02-15 13:26:27 -08:00
|
|
|
chatId?: string
|
2022-09-28 13:38:05 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
const ChatPage: React.FC<IChatPage> = ({ chatId }) => {
|
2023-06-25 10:35:09 -07:00
|
|
|
const { account } = useOwnAccount();
|
2022-11-11 04:16:53 -08:00
|
|
|
const history = useHistory();
|
|
|
|
|
2023-06-20 12:24:39 -07:00
|
|
|
const isOnboarded = account?.source?.chats_onboarded ?? true;
|
2022-10-31 09:14:22 -07:00
|
|
|
|
2022-11-11 04:16:53 -08:00
|
|
|
const path = history.location.pathname;
|
|
|
|
const isSidebarHidden = matchPath(path, {
|
|
|
|
path: ['/chats/settings', '/chats/new', '/chats/:chatId'],
|
|
|
|
exact: true,
|
|
|
|
});
|
2022-09-19 13:12:18 -07:00
|
|
|
|
2022-09-22 11:03:12 -07:00
|
|
|
const containerRef = useRef<HTMLDivElement>(null);
|
|
|
|
const [height, setHeight] = useState<string | number>('100%');
|
|
|
|
|
|
|
|
const calculateHeight = () => {
|
|
|
|
if (!containerRef.current) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
const { top } = containerRef.current.getBoundingClientRect();
|
|
|
|
const fullHeight = document.body.offsetHeight;
|
|
|
|
|
2022-09-22 15:38:00 -07:00
|
|
|
// On mobile, account for bottom navigation.
|
|
|
|
const offset = document.body.clientWidth < 976 ? -61 : 0;
|
|
|
|
|
|
|
|
setHeight(fullHeight - top + offset);
|
2022-09-22 11:03:12 -07:00
|
|
|
};
|
|
|
|
|
2023-01-06 09:51:47 -08:00
|
|
|
useLayoutEffect(() => {
|
2022-09-22 11:03:12 -07:00
|
|
|
calculateHeight();
|
|
|
|
}, [containerRef.current]);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
window.addEventListener('resize', calculateHeight);
|
|
|
|
|
|
|
|
return () => {
|
|
|
|
window.removeEventListener('resize', calculateHeight);
|
|
|
|
};
|
|
|
|
}, []);
|
|
|
|
|
2022-09-13 08:18:46 -07:00
|
|
|
return (
|
2022-09-22 11:03:12 -07:00
|
|
|
<div
|
|
|
|
ref={containerRef}
|
|
|
|
style={{ height }}
|
2023-02-01 14:13:42 -08:00
|
|
|
className='h-screen overflow-hidden bg-white text-gray-900 shadow-lg dark:bg-primary-900 dark:text-gray-100 dark:shadow-none sm:rounded-t-xl'
|
2022-09-22 11:03:12 -07:00
|
|
|
>
|
2022-10-31 09:14:22 -07:00
|
|
|
{isOnboarded ? (
|
2022-11-14 13:09:07 -08:00
|
|
|
<div
|
2023-02-01 14:13:42 -08:00
|
|
|
className='grid h-full grid-cols-9 overflow-hidden dark:divide-x-2 dark:divide-solid dark:divide-gray-800'
|
2022-11-14 13:09:07 -08:00
|
|
|
data-testid='chat-page'
|
|
|
|
>
|
2022-10-31 09:14:22 -07:00
|
|
|
<Stack
|
2023-02-06 10:06:44 -08:00
|
|
|
className={clsx('dark:inset col-span-9 overflow-hidden bg-gradient-to-r from-white to-gray-100 dark:bg-gray-900 dark:bg-none sm:col-span-3', {
|
2022-11-11 04:16:53 -08:00
|
|
|
'hidden sm:block': isSidebarHidden,
|
2022-10-31 09:14:22 -07:00
|
|
|
})}
|
|
|
|
>
|
|
|
|
<ChatPageSidebar />
|
|
|
|
</Stack>
|
|
|
|
|
2022-11-03 10:33:33 -07:00
|
|
|
<Stack
|
2023-02-06 10:06:44 -08:00
|
|
|
className={clsx('col-span-9 h-full overflow-hidden sm:col-span-6', {
|
2022-11-11 04:16:53 -08:00
|
|
|
'hidden sm:block': !isSidebarHidden,
|
2022-11-03 10:33:33 -07:00
|
|
|
})}
|
2022-10-31 09:14:22 -07:00
|
|
|
>
|
|
|
|
<Switch>
|
|
|
|
<Route path='/chats/new'>
|
|
|
|
<ChatPageNew />
|
|
|
|
</Route>
|
|
|
|
<Route path='/chats/settings'>
|
2022-11-01 04:59:30 -07:00
|
|
|
<ChatPageSettings />
|
2022-10-31 09:14:22 -07:00
|
|
|
</Route>
|
2022-11-14 13:09:07 -08:00
|
|
|
<Route>
|
2022-10-31 09:14:22 -07:00
|
|
|
<ChatPageMain />
|
|
|
|
</Route>
|
|
|
|
</Switch>
|
|
|
|
</Stack>
|
|
|
|
</div>
|
|
|
|
) : (
|
|
|
|
<Welcome />
|
|
|
|
)}
|
2022-09-22 11:03:12 -07:00
|
|
|
</div>
|
2022-09-13 08:18:46 -07:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2022-09-13 11:11:22 -07:00
|
|
|
export default ChatPage;
|