You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
120 lines
3.9 KiB
TypeScript
120 lines
3.9 KiB
TypeScript
// Copyright (C) 2020-2022 Intel Corporation
|
|
// Copyright (C) 2023 CVAT.ai Corporation
|
|
//
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
import './styles.scss';
|
|
import React, { Dispatch, TransitionEvent } from 'react';
|
|
import { AnyAction } from 'redux';
|
|
import { connect } from 'react-redux';
|
|
import { MenuFoldOutlined, MenuUnfoldOutlined } from '@ant-design/icons';
|
|
import Text from 'antd/lib/typography/Text';
|
|
import Tabs from 'antd/lib/tabs';
|
|
import Layout from 'antd/lib/layout';
|
|
|
|
import { CombinedState, DimensionType } from 'reducers';
|
|
import LabelsList from 'components/annotation-page/standard-workspace/objects-side-bar/labels-list';
|
|
import { collapseSidebar as collapseSidebarAction } from 'actions/annotation-actions';
|
|
import AppearanceBlock from 'components/annotation-page/appearance-block';
|
|
import IssuesListComponent from 'components/annotation-page/standard-workspace/objects-side-bar/issues-list';
|
|
|
|
interface OwnProps {
|
|
objectsList: JSX.Element;
|
|
}
|
|
|
|
interface StateToProps {
|
|
sidebarCollapsed: boolean;
|
|
jobInstance: any;
|
|
}
|
|
|
|
interface DispatchToProps {
|
|
collapseSidebar(): void;
|
|
}
|
|
|
|
function mapStateToProps(state: CombinedState): StateToProps {
|
|
const {
|
|
annotation: {
|
|
sidebarCollapsed,
|
|
job: { instance: jobInstance },
|
|
},
|
|
} = state;
|
|
|
|
return {
|
|
sidebarCollapsed,
|
|
jobInstance,
|
|
};
|
|
}
|
|
|
|
function mapDispatchToProps(dispatch: Dispatch<AnyAction>): DispatchToProps {
|
|
return {
|
|
collapseSidebar(): void {
|
|
dispatch(collapseSidebarAction());
|
|
},
|
|
};
|
|
}
|
|
|
|
function ObjectsSideBar(props: StateToProps & DispatchToProps & OwnProps): JSX.Element {
|
|
const {
|
|
sidebarCollapsed, collapseSidebar, objectsList, jobInstance,
|
|
} = props;
|
|
|
|
const collapse = (): void => {
|
|
const [collapser] = window.document.getElementsByClassName('cvat-objects-sidebar');
|
|
const listener = (event: TransitionEvent): void => {
|
|
if (event.target && event.propertyName === 'width' && event.target === collapser) {
|
|
window.dispatchEvent(new Event('resize'));
|
|
(collapser as HTMLElement).removeEventListener('transitionend', listener as any);
|
|
}
|
|
};
|
|
|
|
if (collapser) {
|
|
(collapser as HTMLElement).addEventListener('transitionend', listener as any);
|
|
}
|
|
|
|
collapseSidebar();
|
|
};
|
|
|
|
const is2D = jobInstance ? jobInstance.dimension === DimensionType.DIM_2D : true;
|
|
return (
|
|
<Layout.Sider
|
|
className='cvat-objects-sidebar'
|
|
theme='light'
|
|
width={300}
|
|
collapsedWidth={0}
|
|
reverseArrow
|
|
collapsible
|
|
trigger={null}
|
|
collapsed={sidebarCollapsed}
|
|
>
|
|
{/* eslint-disable-next-line */}
|
|
<span
|
|
className={`cvat-objects-sidebar-sider
|
|
ant-layout-sider-zero-width-trigger
|
|
ant-layout-sider-zero-width-trigger-left`}
|
|
onClick={collapse}
|
|
>
|
|
{sidebarCollapsed ? <MenuFoldOutlined title='Show' /> : <MenuUnfoldOutlined title='Hide' />}
|
|
</span>
|
|
|
|
<Tabs type='card' defaultActiveKey='objects' className='cvat-objects-sidebar-tabs'>
|
|
<Tabs.TabPane tab={<Text strong>Objects</Text>} key='objects'>
|
|
{objectsList}
|
|
</Tabs.TabPane>
|
|
<Tabs.TabPane forceRender tab={<Text strong>Labels</Text>} key='labels'>
|
|
<LabelsList />
|
|
</Tabs.TabPane>
|
|
|
|
{is2D ? (
|
|
<Tabs.TabPane tab={<Text strong>Issues</Text>} key='issues'>
|
|
<IssuesListComponent />
|
|
</Tabs.TabPane>
|
|
) : null}
|
|
</Tabs>
|
|
|
|
{!sidebarCollapsed && <AppearanceBlock />}
|
|
</Layout.Sider>
|
|
);
|
|
}
|
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(React.memo(ObjectsSideBar));
|