mirror of
https://github.com/stackblitz-labs/bolt.diy
synced 2025-01-23 19:27:04 +00:00
73 lines
2.2 KiB
TypeScript
73 lines
2.2 KiB
TypeScript
|
import { useStore } from '@nanostores/react';
|
||
|
import { chatStore } from '~/lib/stores/chat';
|
||
|
import { workbenchStore } from '~/lib/stores/workbench';
|
||
|
import { classNames } from '~/utils/classNames';
|
||
|
import { OpenStackBlitz } from './OpenStackBlitz.client';
|
||
|
|
||
|
interface HeaderActionButtonsProps {}
|
||
|
|
||
|
export function HeaderActionButtons({}: HeaderActionButtonsProps) {
|
||
|
const showWorkbench = useStore(workbenchStore.showWorkbench);
|
||
|
const { showChat } = useStore(chatStore);
|
||
|
|
||
|
const canHideChat = showWorkbench || !showChat;
|
||
|
|
||
|
return (
|
||
|
<div className="flex">
|
||
|
<div className="flex border border-bolt-elements-borderColor rounded-md overflow-hidden">
|
||
|
<Button
|
||
|
active={showChat}
|
||
|
disabled={!canHideChat}
|
||
|
onClick={() => {
|
||
|
if (canHideChat) {
|
||
|
chatStore.setKey('showChat', !showChat);
|
||
|
}
|
||
|
}}
|
||
|
>
|
||
|
<div className="i-bolt:chat text-sm" />
|
||
|
</Button>
|
||
|
<div className="w-[1px] bg-bolt-elements-borderColor" />
|
||
|
<Button
|
||
|
active={showWorkbench}
|
||
|
onClick={() => {
|
||
|
if (showWorkbench && !showChat) {
|
||
|
chatStore.setKey('showChat', true);
|
||
|
}
|
||
|
|
||
|
workbenchStore.showWorkbench.set(!showWorkbench);
|
||
|
}}
|
||
|
>
|
||
|
<div className="i-ph:code-bold" />
|
||
|
</Button>
|
||
|
</div>
|
||
|
<div className="flex ml-2">
|
||
|
<OpenStackBlitz />
|
||
|
</div>
|
||
|
</div>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
interface ButtonProps {
|
||
|
active?: boolean;
|
||
|
disabled?: boolean;
|
||
|
children?: any;
|
||
|
onClick?: VoidFunction;
|
||
|
}
|
||
|
|
||
|
function Button({ active = false, disabled = false, children, onClick }: ButtonProps) {
|
||
|
return (
|
||
|
<button
|
||
|
className={classNames('flex items-center p-1.5', {
|
||
|
'bg-bolt-elements-item-backgroundDefault hover:bg-bolt-elements-item-backgroundActive text-bolt-elements-textTertiary hover:text-bolt-elements-textPrimary':
|
||
|
!active,
|
||
|
'bg-bolt-elements-item-backgroundAccent text-bolt-elements-item-contentAccent': active && !disabled,
|
||
|
'bg-bolt-elements-item-backgroundDefault text-alpha-gray-20 dark:text-alpha-white-20 cursor-not-allowed':
|
||
|
disabled,
|
||
|
})}
|
||
|
onClick={onClick}
|
||
|
>
|
||
|
{children}
|
||
|
</button>
|
||
|
);
|
||
|
}
|