X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/26e05f295b57de342d4cd13306ead196e2841a21..dc95b803fa84b3c9ef7c11a4f81dd0d86077d779:/src/views/user-panel/user-panel.tsx diff --git a/src/views/user-panel/user-panel.tsx b/src/views/user-panel/user-panel.tsx new file mode 100644 index 00000000..4b9a3396 --- /dev/null +++ b/src/views/user-panel/user-panel.tsx @@ -0,0 +1,172 @@ +// Copyright (C) The Arvados Authors. All rights reserved. +// +// SPDX-License-Identifier: AGPL-3.0 + +import * as React from 'react'; +import { WithStyles, withStyles, Typography } from '@material-ui/core'; +import { DataExplorer } from "~/views-components/data-explorer/data-explorer"; +import { connect, DispatchProp } from 'react-redux'; +import { DataColumns } from '~/components/data-table/data-table'; +import { RootState } from '~/store/store'; +import { SortDirection } from '~/components/data-table/data-column'; +import { openContextMenu } from "~/store/context-menu/context-menu-actions"; +import { getResource, ResourcesState } from "~/store/resources/resources"; +import { + ResourceFirstName, + ResourceLastName, + ResourceUuid, + ResourceEmail, + ResourceIsActive, + ResourceIsAdmin, + ResourceUsername +} from "~/views-components/data-explorer/renderers"; +import { navigateTo } from "~/store/navigation/navigation-action"; +import { loadDetailsPanel } from "~/store/details-panel/details-panel-action"; +import { ContextMenuKind } from "~/views-components/context-menu/context-menu"; +import { DataTableDefaultView } from '~/components/data-table-default-view/data-table-default-view'; +import { createTree } from '~/models/tree'; +import { compose } from 'redux'; +import { UserResource } from '~/models/user'; +import { ShareMeIcon } from '~/components/icon/icon'; +import { USERS_PANEL_ID } from '~/store/users/users-actions'; + +type UserPanelRules = "toolbar" | "button"; + +const styles = withStyles(theme => ({ + toolbar: { + paddingBottom: theme.spacing.unit * 3, + textAlign: "right" + }, + button: { + marginLeft: theme.spacing.unit + }, +})); + +export enum UserPanelColumnNames { + FIRST_NAME = "First Name", + LAST_NAME = "Last Name", + UUID = "Uuid", + EMAIL = "Email", + ACTIVE = "Active", + ADMIN = "Admin", + REDIRECT_TO_USER = "Redirect to user", + USERNAME = "Username" +} + +export const userPanelColumns: DataColumns = [ + { + name: UserPanelColumnNames.FIRST_NAME, + selected: true, + configurable: true, + sortDirection: SortDirection.NONE, + filters: createTree(), + render: uuid => + }, + { + name: UserPanelColumnNames.LAST_NAME, + selected: true, + configurable: true, + sortDirection: SortDirection.NONE, + filters: createTree(), + render: uuid => + }, + { + name: UserPanelColumnNames.UUID, + selected: true, + configurable: true, + sortDirection: SortDirection.NONE, + filters: createTree(), + render: uuid => + }, + { + name: UserPanelColumnNames.EMAIL, + selected: true, + configurable: true, + sortDirection: SortDirection.NONE, + filters: createTree(), + render: uuid => + }, + { + name: UserPanelColumnNames.ACTIVE, + selected: true, + configurable: true, + sortDirection: SortDirection.NONE, + filters: createTree(), + render: uuid => + }, + { + name: UserPanelColumnNames.ADMIN, + selected: true, + configurable: false, + sortDirection: SortDirection.NONE, + filters: createTree(), + render: uuid => + }, + { + name: UserPanelColumnNames.REDIRECT_TO_USER, + selected: true, + configurable: false, + sortDirection: SortDirection.NONE, + filters: createTree(), + render: () => (none) + }, + { + name: UserPanelColumnNames.USERNAME, + selected: true, + configurable: false, + sortDirection: SortDirection.NONE, + filters: createTree(), + render: uuid => + } +]; + +interface UserPanelDataProps { + resources: ResourcesState; +} + +type UserPanelProps = UserPanelDataProps & DispatchProp & WithStyles; + +export const UserPanel = compose( + styles, + connect((state: RootState) => ({ + resources: state.resources + })))( + class extends React.Component { + render() { + console.log(this.props.resources); + return + } />; + } + + handleContextMenu = (event: React.MouseEvent, resourceUuid: string) => { + const resource = getResource(resourceUuid)(this.props.resources); + if (resource) { + this.props.dispatch(openContextMenu(event, { + name: '', + uuid: resource.uuid, + ownerUuid: resource.ownerUuid, + kind: resource.kind, + menuKind: ContextMenuKind.TRASH + })); + } + } + + handleRowDoubleClick = (uuid: string) => { + this.props.dispatch(navigateTo(uuid)); + } + + handleRowClick = (uuid: string) => { + this.props.dispatch(loadDetailsPanel(uuid)); + } + } + );