import React, { useEffect } from "react";
import { connect } from "react-redux";
import { Icon } from "@blueprintjs/core";
import {
GridComponent,
ColumnsDirective,
ColumnDirective,
} from "@syncfusion/ej2-react-grids";
import { AppState } from "reducers";
import {
getAllUsers,
getAllRoles,
getOrgs,
} from "selectors/organizationSelectors";
import PageSectionDivider from "pages/common/PageSectionDivider";
import PageSectionHeader from "pages/common/PageSectionHeader";
import { ReduxActionTypes } from "constants/ReduxActionConstants";
import InviteUsersFormv2 from "pages/organization/InviteUsersFromv2";
import Button from "components/editorComponents/Button";
import { OrgUser, Organization } from "constants/orgConstants";
import { Menu, MenuItem, Popover, Position } from "@blueprintjs/core";
import styled from "styled-components";
import { FormIcons } from "icons/FormIcons";
import "@syncfusion/ej2-react-grids/styles/material.css";
import { RouteComponentProps } from "react-router";
import Spinner from "components/editorComponents/Spinner";
import FormDialogComponent from "components/editorComponents/form/FormDialogComponent";
type OrgProps = {
allOrgs: Organization[];
changeOrgName: (value: string) => void;
getAllApplication: () => void;
fetchUser: (orgId: string) => void;
fetchAllRoles: (orgId: string) => void;
deleteOrgUser: (orgId: string, username: string) => void;
changeOrgUserRole: (orgId: string, role: string, username: string) => void;
allUsers: OrgUser[];
allRole: object;
isFetchAllUsers: boolean;
isFetchAllRoles: boolean;
};
export type PageProps = OrgProps &
RouteComponentProps<{
orgId: string;
}>;
export type MenuItemProps = {
rolename: string;
};
type DropdownProps = {
activeItem: string;
userRoles: object;
username: string;
};
const StyledGridComponent = styled(GridComponent)`
&&& {
.e-altrow {
background-color: #fafafa;
}
.e-active {
background: #cccccc;
}
.e-gridcontent {
max-height: calc(
100vh - (100vh / 3) - ${props => props.theme.headerHeight}
);
overflow: auto;
}
}
`;
const StyledDropDown = styled.div`
cursor: pointer;
`;
const StyledMenu = styled(Menu)`
&&&&.bp3-menu {
max-width: 250px;
cursor: pointer;
}
`;
export const OrgSettings = (props: PageProps) => {
const {
match: {
params: { orgId },
},
deleteOrgUser,
changeOrgUserRole,
allOrgs,
fetchUser,
fetchAllRoles,
getAllApplication,
} = props;
const userTableData = props.allUsers.map(user => ({
...user,
roles: props.allRole,
}));
const currentOrg = allOrgs.find(org => org.organization.id === orgId);
const currentOrgName = currentOrg?.organization.name ?? "";
useEffect(() => {
fetchUser(orgId);
fetchAllRoles(orgId);
getAllApplication();
}, [orgId, fetchUser, fetchAllRoles, getAllApplication]);
const Dropdown = (props: DropdownProps) => {
return (
{Object.entries(props.userRoles).map((role, index) => {
const MenuContent = (
);
return (
);
};
return (
{currentOrgName}
Users
}
Form={InviteUsersFormv2}
orgId={orgId}
title={`Invite Users to ${currentOrgName}`}
setMaxWidth
/>
{props.isFetchAllUsers && props.isFetchAllRoles ? (
) : (
{
return (
}
position={Position.BOTTOM}
>
{props.roleName}
);
}}
/>
{
return (
deleteOrgUser(orgId, props.username)}
style={{ alignSelf: "center", cursor: "pointer" }}
/>
);
}}
/>
)}
);
};
const mapStateToProps = (state: AppState) => ({
allUsers: getAllUsers(state),
allRole: getAllRoles(state),
isFetchAllUsers: state.ui.orgs.loadingStates.isFetchAllUsers,
isFetchAllRoles: state.ui.orgs.loadingStates.isFetchAllRoles,
allOrgs: getOrgs(state),
});
const mapDispatchToProps = (dispatch: any) => ({
getAllApplication: () =>
dispatch({ type: ReduxActionTypes.GET_ALL_APPLICATION_INIT }),
changeOrgName: (name: string) =>
dispatch({
type: ReduxActionTypes.UPDATE_ORG_NAME_INIT,
payload: {
name,
},
}),
changeOrgUserRole: (orgId: string, role: string, username: string) =>
dispatch({
type: ReduxActionTypes.CHANGE_ORG_USER_ROLE_INIT,
payload: {
orgId,
role,
username,
},
}),
deleteOrgUser: (orgId: string, username: string) =>
dispatch({
type: ReduxActionTypes.DELETE_ORG_USER_INIT,
payload: {
orgId,
username,
},
}),
fetchUser: (orgId: string) =>
dispatch({
type: ReduxActionTypes.FETCH_ALL_USERS_INIT,
payload: {
orgId,
},
}),
fetchAllRoles: (orgId: string) =>
dispatch({
type: ReduxActionTypes.FETCH_ALL_ROLES_INIT,
payload: {
orgId,
},
}),
});
export default connect(mapStateToProps, mapDispatchToProps)(OrgSettings);