X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/fa9b3ce44a3a9315207852d1f182000a6166f9e9..e63239560b1393a8b306a4353719d4fe85698f04:/src/store/group-details-panel/group-details-panel-actions.ts diff --git a/src/store/group-details-panel/group-details-panel-actions.ts b/src/store/group-details-panel/group-details-panel-actions.ts index b73c3bbe..8130869f 100644 --- a/src/store/group-details-panel/group-details-panel-actions.ts +++ b/src/store/group-details-panel/group-details-panel-actions.ts @@ -2,79 +2,61 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { bindDataExplorerActions } from '~/store/data-explorer/data-explorer-action'; +import { bindDataExplorerActions } from 'store/data-explorer/data-explorer-action'; import { Dispatch } from 'redux'; -import { propertiesActions } from '~/store/properties/properties-actions'; -import { getProperty } from '~/store/properties/properties'; -import { Person } from '~/views-components/sharing-dialog/people-select'; -import { dialogActions } from '~/store/dialog/dialog-actions'; -import { reset, startSubmit } from 'redux-form'; -import { addGroupMember, deleteGroupMember } from '~/store/groups-panel/groups-panel-actions'; -import { getResource } from '~/store/resources/resources'; -import { GroupResource } from '~/models/group'; -import { RootState } from '~/store/store'; -import { ServiceRepository } from '~/services/services'; -import { PermissionResource } from '~/models/permission'; -import { GroupDetailsPanel } from '~/views/group-details-panel/group-details-panel'; -import { snackbarActions, SnackbarKind } from '~/store/snackbar/snackbar-actions'; -import { UserResource, getUserFullname } from '~/models/user'; - -export const GROUP_DETAILS_PANEL_ID = 'groupDetailsPanel'; -export const ADD_GROUP_MEMBERS_DIALOG = 'addGrupMembers'; -export const ADD_GROUP_MEMBERS_FORM = 'addGrupMembers'; -export const ADD_GROUP_MEMBERS_USERS_FIELD_NAME = 'users'; +import { propertiesActions } from 'store/properties/properties-actions'; +import { getProperty } from 'store/properties/properties'; +import { dialogActions } from 'store/dialog/dialog-actions'; +import { deleteGroupMember } from 'store/groups-panel/groups-panel-actions'; +import { getResource } from 'store/resources/resources'; +import { RootState } from 'store/store'; +import { ServiceRepository } from 'services/services'; +import { PermissionResource, PermissionLevel } from 'models/permission'; +import { snackbarActions, SnackbarKind } from 'store/snackbar/snackbar-actions'; +import { LinkResource } from 'models/link'; +import { deleteResources } from 'store/resources/resources-actions'; +import { openSharingDialog } from 'store/sharing-dialog/sharing-dialog-actions'; + +export const GROUP_DETAILS_MEMBERS_PANEL_ID = 'groupDetailsMembersPanel'; +export const GROUP_DETAILS_PERMISSIONS_PANEL_ID = 'groupDetailsPermissionsPanel'; export const MEMBER_ATTRIBUTES_DIALOG = 'memberAttributesDialog'; export const MEMBER_REMOVE_DIALOG = 'memberRemoveDialog'; -export const GroupDetailsPanelActions = bindDataExplorerActions(GROUP_DETAILS_PANEL_ID); +export const GroupMembersPanelActions = bindDataExplorerActions(GROUP_DETAILS_MEMBERS_PANEL_ID); +export const GroupPermissionsPanelActions = bindDataExplorerActions(GROUP_DETAILS_PERMISSIONS_PANEL_ID); export const loadGroupDetailsPanel = (groupUuid: string) => (dispatch: Dispatch) => { - dispatch(propertiesActions.SET_PROPERTY({ key: GROUP_DETAILS_PANEL_ID, value: groupUuid })); - dispatch(GroupDetailsPanelActions.REQUEST_ITEMS()); + dispatch(propertiesActions.SET_PROPERTY({ key: GROUP_DETAILS_MEMBERS_PANEL_ID, value: groupUuid })); + dispatch(GroupMembersPanelActions.REQUEST_ITEMS()); + dispatch(propertiesActions.SET_PROPERTY({ key: GROUP_DETAILS_PERMISSIONS_PANEL_ID, value: groupUuid })); + dispatch(GroupPermissionsPanelActions.REQUEST_ITEMS()); }; -export const getCurrentGroupDetailsPanelUuid = getProperty(GROUP_DETAILS_PANEL_ID); - -export interface AddGroupMembersFormData { - [ADD_GROUP_MEMBERS_USERS_FIELD_NAME]: Person[]; -} +export const getCurrentGroupDetailsPanelUuid = getProperty(GROUP_DETAILS_MEMBERS_PANEL_ID); export const openAddGroupMembersDialog = () => - (dispatch: Dispatch) => { - dispatch(dialogActions.OPEN_DIALOG({ id: ADD_GROUP_MEMBERS_DIALOG, data: {} })); - dispatch(reset(ADD_GROUP_MEMBERS_FORM)); - }; - -export const addGroupMembers = ({ users }: AddGroupMembersFormData) => - - async (dispatch: Dispatch, getState: () => RootState, { permissionService }: ServiceRepository) => { - + (dispatch: Dispatch, getState: () => RootState) => { const groupUuid = getCurrentGroupDetailsPanelUuid(getState().properties); - if (groupUuid) { + dispatch(openSharingDialog(groupUuid, () => { + dispatch(GroupMembersPanelActions.REQUEST_ITEMS()); + })); + } + }; - dispatch(startSubmit(ADD_GROUP_MEMBERS_FORM)); - - const group = getResource(groupUuid)(getState().resources); - - for (const user of users) { - - await addGroupMember({ - user, - group: { - uuid: groupUuid, - name: group ? group.name : groupUuid, - }, - dispatch, - permissionService, - }); - - } - - dispatch(dialogActions.CLOSE_DIALOG({ id: ADD_GROUP_MEMBERS_FORM })); - dispatch(GroupDetailsPanelActions.REQUEST_ITEMS()); - +export const editPermissionLevel = (uuid: string, level: PermissionLevel) => + async (dispatch: Dispatch, getState: () => RootState, { permissionService }: ServiceRepository) => { + try { + await permissionService.update(uuid, {name: level}); + dispatch(GroupMembersPanelActions.REQUEST_ITEMS()); + dispatch(GroupPermissionsPanelActions.REQUEST_ITEMS()); + dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Permission level changed.', hideDuration: 2000 })); + } catch (e) { + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: 'Failed to update permission', + kind: SnackbarKind.ERROR, + })); } }; @@ -105,28 +87,62 @@ export const removeGroupMember = (uuid: string) => const groupUuid = getCurrentGroupDetailsPanelUuid(getState().properties); if (groupUuid) { - - const group = getResource(groupUuid)(getState().resources); - const user = getResource(groupUuid)(getState().resources); - dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removing ...', kind: SnackbarKind.INFO })); await deleteGroupMember({ - user: { + link: { uuid, - name: user ? getUserFullname(user) : uuid, - }, - group: { - uuid: groupUuid, - name: group ? group.name : groupUuid, }, permissionService, dispatch, }); dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removed.', hideDuration: 2000, kind: SnackbarKind.SUCCESS })); - dispatch(GroupDetailsPanelActions.REQUEST_ITEMS()); + dispatch(GroupMembersPanelActions.REQUEST_ITEMS()); } }; + +export const setMemberIsHidden = (memberLinkUuid: string, permissionLinkUuid: string, hide: boolean) => + async (dispatch: Dispatch, getState: () => RootState, { permissionService }: ServiceRepository) => { + const memberLink = getResource(memberLinkUuid)(getState().resources); + + if (hide && permissionLinkUuid) { + // Remove read permission + try { + await permissionService.delete(permissionLinkUuid); + dispatch(deleteResources([permissionLinkUuid])); + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: 'Removed read permission.', + hideDuration: 2000, + kind: SnackbarKind.SUCCESS, + })); + } catch (e) { + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: 'Failed to remove permission', + kind: SnackbarKind.ERROR, + })); + } + } else if (!hide && memberLink) { + // Create read permission + try { + await permissionService.create({ + headUuid: memberLink.tailUuid, + tailUuid: memberLink.headUuid, + name: PermissionLevel.CAN_READ, + }); + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: 'Created read permission.', + hideDuration: 2000, + kind: SnackbarKind.SUCCESS, + })); + dispatch(GroupPermissionsPanelActions.REQUEST_ITEMS()); + } catch(e) { + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: 'Failed to create permission', + kind: SnackbarKind.ERROR, + })); + } + } + };