+// Copyright (C) The Arvados Authors. All rights reserved.
+//
+// SPDX-License-Identifier: AGPL-3.0
-
-import * as React from 'react';
-import { ProjectResource } from "../../models/project";
-import { CollectionResource } from "../../models/collection";
-import { ProcessResource } from "../../models/process";
import { ResourceKind } from '../../models/kinds';
import ProjectItem from './items/project-item';
import CollectionItem from './items/collection-item';
import ProcessItem from './items/process-item';
-import { AbstractItem } from './items/abstract-item';
-
-// TODO: move to models
-export type DetailsPanelResource = ProjectResource | CollectionResource | ProcessResource;
+import AbstractItem from './items/abstract-item';
+import EmptyItem from './items/empty-item';
+import { DetailsPanelResource } from '../../views-components/details-panel/details-panel';
export default class DetailsPanelFactory {
static createItem(res: DetailsPanelResource): AbstractItem {
return new ProjectItem(res);
case ResourceKind.Collection:
return new CollectionItem(res);
- case ResourceKind.Collection:
+ case ResourceKind.Process:
return new ProcessItem(res);
default:
- return new ProjectItem(res);
+ return new EmptyItem(res);
}
}
}
\ No newline at end of file
// SPDX-License-Identifier: AGPL-3.0
import * as React from 'react';
-import { DetailsPanelResource } from "./../details-panel-factory";
import { IconTypes } from '../../icon/icon';
+import { DetailsPanelResource } from '../../../views-components/details-panel/details-panel';
-export abstract class AbstractItem {
+export default abstract class AbstractItem {
protected item: DetailsPanelResource;
constructor(item: DetailsPanelResource) {
// SPDX-License-Identifier: AGPL-3.0
import * as React from 'react';
-import { DetailsPanelResource } from "./../details-panel-factory";
import IconBase, { IconTypes } from '../../icon/icon';
import Attribute from '../../attribute/attribute';
-import { AbstractItem } from './abstract-item';
+import AbstractItem from './abstract-item';
+import { CollectionResource } from '../../../models/collection';
export default class CollectionItem extends AbstractItem {
- constructor(item: DetailsPanelResource) {
+ constructor(item: CollectionResource) {
super(item);
}
--- /dev/null
+// Copyright (C) The Arvados Authors. All rights reserved.
+//
+// SPDX-License-Identifier: AGPL-3.0
+
+import * as React from 'react';
+import { IconTypes } from '../../icon/icon';
+import AbstractItem from './abstract-item';
+import EmptyState from '../../empty-state/empty-state';
+import { EmptyResource } from '../../../models/empty';
+
+export default class EmptyItem extends AbstractItem {
+
+ constructor(item: EmptyResource) {
+ super(item);
+ }
+
+ getIcon(): IconTypes {
+ return IconTypes.FOLDER;
+ }
+
+ buildDetails(): React.ReactElement<any> {
+ return <EmptyState icon={IconTypes.ANNOUNCEMENT}
+ message='Select a file or folder to view its details.' />;
+ }
+}
\ No newline at end of file
// SPDX-License-Identifier: AGPL-3.0
import * as React from 'react';
-import { DetailsPanelResource } from "./../details-panel-factory";
import IconBase, { IconTypes } from '../../icon/icon';
import Attribute from '../../attribute/attribute';
-import { AbstractItem } from './abstract-item';
+import AbstractItem from './abstract-item';
+import { ProcessResource } from '../../../models/process';
export default class ProcessItem extends AbstractItem {
- constructor(item: DetailsPanelResource) {
+ constructor(item: ProcessResource) {
super(item);
}
// SPDX-License-Identifier: AGPL-3.0
import * as React from 'react';
-import { DetailsPanelResource } from "./../details-panel-factory";
import IconBase, { IconTypes } from '../../icon/icon';
import Attribute from '../../attribute/attribute';
-import { AbstractItem } from './abstract-item';
+import AbstractItem from './abstract-item';
+import { ProjectResource } from '../../../models/project';
export default class ProjectItem extends AbstractItem {
- constructor(item: DetailsPanelResource) {
+ constructor(item: ProjectResource) {
super(item);
}
--- /dev/null
+// Copyright (C) The Arvados Authors. All rights reserved.
+//
+// SPDX-License-Identifier: AGPL-3.0
+
+import { ResourceKind } from "./resource";
+
+export interface EmptyResource {
+ name: string;
+ kind: ResourceKind;
+}
\ No newline at end of file
import Grid from '@material-ui/core/Grid';
import * as classnames from "classnames";
import { connect, Dispatch } from 'react-redux';
-import EmptyState from '../../components/empty-state/empty-state';
import { RootState } from '../../store/store';
import actions from "../../store/details-panel/details-panel-action";
import { ProjectResource } from '../../models/project';
import IconBase, { IconTypes } from '../../components/icon/icon';
import { ProcessResource } from '../../models/process';
import DetailsPanelFactory from '../../components/details-panel-factory/details-panel-factory';
+import AbstractItem from '../../components/details-panel-factory/items/abstract-item';
+import { ResourceKind } from '../../models/resource';
+import { EmptyResource } from '../../models/empty';
export interface DetailsPanelDataProps {
onCloseDrawer: () => void;
isOpened: boolean;
- icon: IconTypes;
- title: string;
- details: React.ReactElement<any>;
+ item: AbstractItem;
}
type DetailsPanelProps = DetailsPanelDataProps & WithStyles<CssRules>;
</Typography>
render() {
- const { classes, onCloseDrawer, isOpened, icon, title, details } = this.props;
+ const { classes, onCloseDrawer, isOpened, item } = this.props;
const { tabsValue } = this.state;
return (
<Typography component="div" className={classnames([classes.container, { [classes.opened]: isOpened }])}>
<Drawer variant="permanent" anchor="right" classes={{ paper: classes.drawerPaper }}>
<Typography component="div" className={classes.headerContainer}>
<Grid container alignItems='center' justify='space-around'>
- <IconBase className={classes.headerIcon} icon={icon} />
+ <IconBase className={classes.headerIcon} icon={item.getIcon()} />
<Typography variant="title">
- {title}
+ {item.getTitle()}
</Typography>
<IconButton color="inherit" onClick={onCloseDrawer}>
<IconBase icon={IconTypes.CLOSE} />
</Tabs>
{tabsValue === 0 && this.renderTabContainer(
<Grid container direction="column">
- {details}
+ {item.buildDetails()}
</Grid>
)}
{tabsValue === 1 && this.renderTabContainer(
});
// TODO: move to models
-type DetailsPanelResource = ProjectResource | CollectionResource | ProcessResource;
-
-const getEmptyState = () => {
- return <EmptyState icon={ IconTypes.ANNOUNCEMENT }
- message='Select a file or folder to view its details.' />;
-};
+export type DetailsPanelResource = ProjectResource | CollectionResource | ProcessResource | EmptyResource;
const getItem = (res: DetailsPanelResource) => {
- const item = DetailsPanelFactory.createItem(res);
- return {
- title: item.getTitle(),
- icon: item.getIcon(),
- details: item.buildDetails()
- };
+ return DetailsPanelFactory.createItem(res);
};
const getDefaultItem = () => {
- return {
- title: 'Projects',
- icon: IconTypes.FOLDER,
- details: getEmptyState()
- };
+ return DetailsPanelFactory.createItem({ kind: ResourceKind.UNKNOWN, name: 'Projects'});
};
const mapStateToProps = ({ detailsPanel }: RootState) => {
const { isOpened, item } = detailsPanel;
- const newItem = item ? getItem(item as DetailsPanelResource) : getDefaultItem();
return {
isOpened,
- ...newItem
+ item: item ? getItem(item as DetailsPanelResource) : getDefaultItem()
};
};