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, 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';
export const getCurrentGroupDetailsPanelUuid = getProperty<string>(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(startSubmit(ADD_GROUP_MEMBERS_FORM));
-
- const group = getResource<GroupResource>(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());
-
+ dispatch<any>(openSharingDialog(groupUuid, () => {
+ dispatch(GroupMembersPanelActions.REQUEST_ITEMS());
+ }));
}
};
};
-export const setMemberIsHidden = (memberLinkUuid: string, permissionLinkUuid: string, hide: boolean) =>
+export const setMemberIsHidden = (memberLinkUuid: string, permissionLinkUuid: string, visible: boolean) =>
async (dispatch: Dispatch, getState: () => RootState, { permissionService }: ServiceRepository) => {
const memberLink = getResource<LinkResource>(memberLinkUuid)(getState().resources);
- if (hide && permissionLinkUuid) {
+ if (!visible && permissionLinkUuid) {
// Remove read permission
try {
await permissionService.delete(permissionLinkUuid);
dispatch<any>(deleteResources([permissionLinkUuid]));
+ dispatch(GroupPermissionsPanelActions.REQUEST_ITEMS());
dispatch(snackbarActions.OPEN_SNACKBAR({
message: 'Removed read permission.',
hideDuration: 2000,
kind: SnackbarKind.ERROR,
}));
}
- } else if (!hide && memberLink) {
+ } else if (visible && memberLink) {
// Create read permission
try {
await permissionService.create({