2022-07-20 13:32:25 -07:00
|
|
|
import classNames from 'classnames';
|
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
/** Chat pane state. */
|
|
|
|
export type WindowState = 'open' | 'minimized';
|
|
|
|
|
|
|
|
interface IPane {
|
|
|
|
/** Whether the pane is open or minimized. */
|
|
|
|
windowState: WindowState,
|
|
|
|
/** Positions the pane on the screen, with 0 at the right. */
|
|
|
|
index: number,
|
|
|
|
/** Children to display in the pane. */
|
|
|
|
children: React.ReactNode,
|
|
|
|
/** Whether this is the main chat pane. */
|
|
|
|
main?: boolean,
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Chat pane UI component for desktop. */
|
|
|
|
const Pane: React.FC<IPane> = ({ windowState, index, children, main = false }) => {
|
2022-07-20 18:58:45 -07:00
|
|
|
const right = (404 * index) + 20;
|
2022-07-20 13:32:25 -07:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div
|
2022-08-10 05:38:49 -07:00
|
|
|
className={classNames('flex flex-col shadow-3xl bg-white dark:bg-gray-900 rounded-t-lg fixed bottom-0 right-1 w-96 z-[1000]', {
|
|
|
|
'h-[550px] max-h-[100vh]': windowState !== 'minimized',
|
|
|
|
'h-16': windowState === 'minimized',
|
2022-07-20 18:58:45 -07:00
|
|
|
})}
|
2022-07-20 13:32:25 -07:00
|
|
|
style={{ right: `${right}px` }}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export { Pane };
|