X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/acceec90afa2a2b5007ab75795c911ac75446bc4..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 22247a8f..8130869f 100644 --- a/src/store/group-details-panel/group-details-panel-actions.ts +++ b/src/store/group-details-panel/group-details-panel-actions.ts @@ -6,22 +6,19 @@ import { bindDataExplorerActions } from 'store/data-explorer/data-explorer-actio import { Dispatch } from 'redux'; import { propertiesActions } from 'store/properties/properties-actions'; import { getProperty } from 'store/properties/properties'; -import { Participant } from 'views-components/sharing-dialog/participant-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 { 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 { 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 ADD_GROUP_MEMBERS_DIALOG = 'addGroupMembers'; -export const ADD_GROUP_MEMBERS_FORM = 'addGroupMembers'; -export const ADD_GROUP_MEMBERS_USERS_FIELD_NAME = 'users'; export const MEMBER_ATTRIBUTES_DIALOG = 'memberAttributesDialog'; export const MEMBER_REMOVE_DIALOG = 'memberRemoveDialog'; @@ -38,45 +35,28 @@ export const loadGroupDetailsPanel = (groupUuid: string) => export const getCurrentGroupDetailsPanelUuid = getProperty(GROUP_DETAILS_MEMBERS_PANEL_ID); -export interface AddGroupMembersFormData { - [ADD_GROUP_MEMBERS_USERS_FIELD_NAME]: Participant[]; -} - 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 })); +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, + })); } }; @@ -123,3 +103,46 @@ export const removeGroupMember = (uuid: string) => } }; + +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, + })); + } + } + };