mirror of
https://github.com/datahub-project/datahub.git
synced 2025-10-20 21:45:16 +00:00
82 lines
2.4 KiB
TypeScript
82 lines
2.4 KiB
TypeScript
![]() |
import React, { useState } from 'react';
|
||
|
import { UserOutlined } from '@ant-design/icons';
|
||
|
import { Select } from 'antd';
|
||
|
import styled from 'styled-components';
|
||
|
import { CorpUser, DataHubRole } from '../../../types.generated';
|
||
|
import AssignRoleConfirmation from './AssignRoleConfirmation';
|
||
|
import { mapRoleIcon } from './UserUtils';
|
||
|
|
||
|
type Props = {
|
||
|
user: CorpUser;
|
||
|
userRoleUrn: string;
|
||
|
selectRoleOptions: Array<DataHubRole>;
|
||
|
refetch?: () => void;
|
||
|
};
|
||
|
|
||
|
const RoleSelect = styled(Select)`
|
||
|
min-width: 105px;
|
||
|
`;
|
||
|
|
||
|
const RoleIcon = styled.span`
|
||
|
margin-right: 6px;
|
||
|
font-size: 12px;
|
||
|
`;
|
||
|
|
||
|
export default function SelectRole({ user, userRoleUrn, selectRoleOptions, refetch }: Props) {
|
||
|
const [isViewingAssignRole, setIsViewingAssignRole] = useState(false);
|
||
|
const [roleToAssign, setRoleToAssign] = useState<DataHubRole>();
|
||
|
|
||
|
const rolesMap: Map<string, DataHubRole> = new Map();
|
||
|
selectRoleOptions.forEach((role) => {
|
||
|
rolesMap.set(role.urn, role);
|
||
|
});
|
||
|
|
||
|
const selectOptions = () =>
|
||
|
selectRoleOptions.map((role) => {
|
||
|
return (
|
||
|
<Select.Option value={role.urn}>
|
||
|
<RoleIcon>{mapRoleIcon(role.name)}</RoleIcon>
|
||
|
{role.name}
|
||
|
</Select.Option>
|
||
|
);
|
||
|
});
|
||
|
|
||
|
const onSelectRole = (roleUrn: string) => {
|
||
|
const roleFromMap: DataHubRole = rolesMap.get(roleUrn) as DataHubRole;
|
||
|
setRoleToAssign(roleFromMap);
|
||
|
setIsViewingAssignRole(true);
|
||
|
};
|
||
|
|
||
|
const noRoleText = 'No Role';
|
||
|
|
||
|
return (
|
||
|
<>
|
||
|
<RoleSelect
|
||
|
placeholder={
|
||
|
<>
|
||
|
<UserOutlined style={{ marginRight: 6, fontSize: 12 }} />
|
||
|
{noRoleText}
|
||
|
</>
|
||
|
}
|
||
|
value={userRoleUrn || undefined}
|
||
|
onChange={(e) => onSelectRole(e as string)}
|
||
|
>
|
||
|
{selectOptions()}
|
||
|
</RoleSelect>
|
||
|
<AssignRoleConfirmation
|
||
|
visible={isViewingAssignRole}
|
||
|
roleToAssign={roleToAssign}
|
||
|
userUrn={user.urn}
|
||
|
username={user.username}
|
||
|
onClose={() => setIsViewingAssignRole(false)}
|
||
|
onConfirm={() => {
|
||
|
setIsViewingAssignRole(false);
|
||
|
setTimeout(function () {
|
||
|
refetch?.();
|
||
|
}, 3000);
|
||
|
}}
|
||
|
/>
|
||
|
</>
|
||
|
);
|
||
|
}
|