X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/0db26cfb0926f4f840d11bf85b66dfee921bf1f2..04ddc76f953ae6c61264a9c1fa5a8cade9e1773e:/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 6f594de0..e00ff773 100644 --- a/src/store/group-details-panel/group-details-panel-actions.ts +++ b/src/store/group-details-panel/group-details-panel-actions.ts @@ -6,30 +6,21 @@ 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 { initialize, 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 { Resource } from 'models/resource'; 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 { PermissionSelectValue, parsePermissionLevel, formatPermissionLevel } from 'views-components/sharing-dialog/permission-select'; +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'; -export const EDIT_PERMISSION_LEVEL_DIALOG = 'editPermissionLevel'; -export const EDIT_PERMISSION_LEVEL_FORM = 'editPermissionLevel'; -export const EDIT_PERMISSION_LEVEL_FIELD_NAME = 'name'; -export const EDIT_PERMISSION_LEVEL_UUID_FIELD_NAME = 'uuid'; export const GroupMembersPanelActions = bindDataExplorerActions(GROUP_DETAILS_MEMBERS_PANEL_ID); export const GroupPermissionsPanelActions = bindDataExplorerActions(GROUP_DETAILS_PERMISSIONS_PANEL_ID); @@ -44,70 +35,20 @@ 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 interface EditPermissionLevelFormData { - [EDIT_PERMISSION_LEVEL_UUID_FIELD_NAME]: string; - [EDIT_PERMISSION_LEVEL_FIELD_NAME]: PermissionSelectValue; -} - 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(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(GroupMembersPanelActions.REQUEST_ITEMS()); - - } - }; - -export const openEditPermissionLevelDialog = (linkUuid: string, resourceUuid: string) => - async (dispatch: Dispatch, getState: () => RootState) => { - const link = getResource(linkUuid)(getState().resources); - const resource = getResource(resourceUuid)(getState().resources); - - if (link) { - dispatch(reset(EDIT_PERMISSION_LEVEL_FORM)); - dispatch(initialize(EDIT_PERMISSION_LEVEL_FORM, {[EDIT_PERMISSION_LEVEL_UUID_FIELD_NAME]: link.uuid, [EDIT_PERMISSION_LEVEL_FIELD_NAME]: formatPermissionLevel(link.name as PermissionLevel)})); - dispatch(dialogActions.OPEN_DIALOG({ id: EDIT_PERMISSION_LEVEL_DIALOG, data: resource })); + dispatch(openSharingDialog(groupUuid, () => { + dispatch(GroupMembersPanelActions.REQUEST_ITEMS()); + })); } }; -export const editPermissionLevel = (data: EditPermissionLevelFormData) => +export const editPermissionLevel = (uuid: string, level: PermissionLevel) => async (dispatch: Dispatch, getState: () => RootState, { permissionService }: ServiceRepository) => { try { - await permissionService.update(data[EDIT_PERMISSION_LEVEL_UUID_FIELD_NAME], {name: parsePermissionLevel(data[EDIT_PERMISSION_LEVEL_FIELD_NAME])}); - dispatch(dialogActions.CLOSE_DIALOG({ id: EDIT_PERMISSION_LEVEL_DIALOG })); + await permissionService.update(uuid, {name: level}); dispatch(GroupMembersPanelActions.REQUEST_ITEMS()); dispatch(GroupPermissionsPanelActions.REQUEST_ITEMS()); dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Permission level changed.', hideDuration: 2000 })); @@ -162,3 +103,47 @@ export const removeGroupMember = (uuid: string) => } }; + +export const setMemberIsHidden = (memberLinkUuid: string, permissionLinkUuid: string, visible: boolean) => + async (dispatch: Dispatch, getState: () => RootState, { permissionService }: ServiceRepository) => { + const memberLink = getResource(memberLinkUuid)(getState().resources); + + if (!visible && permissionLinkUuid) { + // Remove read permission + try { + await permissionService.delete(permissionLinkUuid); + dispatch(deleteResources([permissionLinkUuid])); + dispatch(GroupPermissionsPanelActions.REQUEST_ITEMS()); + 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 (visible && 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, + })); + } + } + };