feishin/src/renderer/layouts/default-layout/left-sidebar.tsx

39 lines
1.2 KiB
TypeScript
Raw Normal View History

2023-05-31 01:13:54 -07:00
import { useRef } from 'react';
import styled from 'styled-components';
import { ResizeHandle } from '/@/renderer/features/shared';
import { CollapsedSidebar } from '/@/renderer/features/sidebar/components/collapsed-sidebar';
import { Sidebar } from '/@/renderer/features/sidebar/components/sidebar';
import { useSidebarStore } from '/@/renderer/store';
const SidebarContainer = styled.aside`
2023-07-01 19:10:05 -07:00
position: relative;
grid-area: sidebar;
background: var(--sidebar-bg);
border-right: var(--sidebar-border);
2023-05-31 01:13:54 -07:00
`;
interface LeftSidebarProps {
2023-07-01 19:10:05 -07:00
isResizing: boolean;
startResizing: (direction: 'left' | 'right') => void;
2023-05-31 01:13:54 -07:00
}
export const LeftSidebar = ({ isResizing, startResizing }: LeftSidebarProps) => {
2023-07-01 19:10:05 -07:00
const sidebarRef = useRef<HTMLDivElement | null>(null);
const { collapsed } = useSidebarStore();
2023-05-31 01:13:54 -07:00
2023-07-01 19:10:05 -07:00
return (
<SidebarContainer id="sidebar">
<ResizeHandle
ref={sidebarRef}
$isResizing={isResizing}
$placement="right"
2023-07-01 19:10:05 -07:00
onMouseDown={(e) => {
e.preventDefault();
startResizing('left');
}}
/>
{collapsed ? <CollapsedSidebar /> : <Sidebar />}
</SidebarContainer>
);
2023-05-31 01:13:54 -07:00
};