1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as React from 'react';
6 import { connect } from 'react-redux';
8 import { DataExplorer } from "~/views-components/data-explorer/data-explorer";
9 import { DataColumns } from '~/components/data-table/data-table';
10 import { ResourceUuid, ResourceFirstName, ResourceLastName, ResourceEmail, ResourceUsername } from '~/views-components/data-explorer/renderers';
11 import { createTree } from '~/models/tree';
12 import { noop } from 'lodash/fp';
13 import { RootState } from '~/store/store';
14 import { GROUP_DETAILS_PANEL_ID } from '~/store/group-details-panel/group-details-panel-actions';
15 import { openContextMenu } from '~/store/context-menu/context-menu-actions';
16 import { ResourcesState, getResource } from '~/store/resources/resources';
17 import { ContextMenuKind } from '~/views-components/context-menu/context-menu';
18 import { PermissionResource } from '~/models/permission';
20 export enum GroupDetailsPanelColumnNames {
21 FIRST_NAME = "First name",
22 LAST_NAME = "Last name",
25 USERNAME = "Username",
28 export const groupDetailsPanelColumns: DataColumns<string> = [
30 name: GroupDetailsPanelColumnNames.FIRST_NAME,
33 filters: createTree(),
34 render: uuid => <ResourceFirstName uuid={uuid} />
37 name: GroupDetailsPanelColumnNames.LAST_NAME,
40 filters: createTree(),
41 render: uuid => <ResourceLastName uuid={uuid} />
44 name: GroupDetailsPanelColumnNames.UUID,
47 filters: createTree(),
48 render: uuid => <ResourceUuid uuid={uuid} />
51 name: GroupDetailsPanelColumnNames.EMAIL,
54 filters: createTree(),
55 render: uuid => <ResourceEmail uuid={uuid} />
58 name: GroupDetailsPanelColumnNames.USERNAME,
61 filters: createTree(),
62 render: uuid => <ResourceUsername uuid={uuid} />
66 const mapStateToProps = (state: RootState) => {
68 resources: state.resources
72 const mapDispatchToProps = {
73 onContextMenu: openContextMenu,
76 export interface GroupDetailsPanelProps {
77 onContextMenu: (event: React.MouseEvent<HTMLElement>, item: any) => void;
78 resources: ResourcesState;
81 export const GroupDetailsPanel = connect(
82 mapStateToProps, mapDispatchToProps
84 class GroupDetailsPanel extends React.Component<GroupDetailsPanelProps> {
89 id={GROUP_DETAILS_PANEL_ID}
91 onRowDoubleClick={noop}
92 onContextMenu={this.handleContextMenu}
93 contextMenuColumn={true}
98 handleContextMenu = (event: React.MouseEvent<HTMLElement>, resourceUuid: string) => {
99 const resource = getResource<PermissionResource>(resourceUuid)(this.props.resources);
101 this.props.onContextMenu(event, {
104 ownerUuid: resource.ownerUuid,
106 menuKind: ContextMenuKind.GROUP_MEMBER