mirror of
https://github.com/grafana/grafana.git
synced 2025-02-16 18:34:52 -06:00
62 lines
2.1 KiB
TypeScript
62 lines
2.1 KiB
TypeScript
import React from 'react';
|
|
|
|
import { selectors as e2eSelectors } from '@grafana/e2e-selectors/src';
|
|
import { HorizontalGroup, Icon, Tag, Tooltip } from '@grafana/ui/src';
|
|
import { Page } from 'app/core/components/Page/Page';
|
|
|
|
import { useGetActiveUsersQuery } from '../../dashboard/api/publicDashboardApi';
|
|
|
|
import { DashboardsListModalButton } from './DashboardsListModalButton';
|
|
import { DeleteUserModalButton } from './DeleteUserModalButton';
|
|
|
|
const selectors = e2eSelectors.pages.UserListPage.publicDashboards;
|
|
|
|
export const UserListPublicDashboardPage = () => {
|
|
const { data: users, isLoading } = useGetActiveUsersQuery();
|
|
|
|
return (
|
|
<Page.Contents isLoading={isLoading}>
|
|
<table className="filter-table form-inline" data-testid={selectors.container}>
|
|
<thead>
|
|
<tr>
|
|
<th>Email</th>
|
|
<th>
|
|
<span>Activated </span>
|
|
<Tooltip placement="top" content={'Earliest time user has been an active user to a dashboard'}>
|
|
<Icon name="question-circle" />
|
|
</Tooltip>
|
|
</th>
|
|
<th>Origin</th>
|
|
<th>Role</th>
|
|
<th></th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{users?.map((user) => (
|
|
<tr key={user.email}>
|
|
<td className="max-width-10">
|
|
<span className="ellipsis" title={user.email}>
|
|
{user.email}
|
|
</span>
|
|
</td>
|
|
<td className="max-width-10">{user.firstSeenAtAge}</td>
|
|
<td className="max-width-10">
|
|
<HorizontalGroup spacing="sm">
|
|
<span>{user.totalDashboards} dashboard(s)</span>
|
|
<DashboardsListModalButton email={user.email} />
|
|
</HorizontalGroup>
|
|
</td>
|
|
<td className="max-width-10">
|
|
<Tag name="Viewer" colorIndex={19} />
|
|
</td>
|
|
<td className="text-right">
|
|
<DeleteUserModalButton user={user} />
|
|
</td>
|
|
</tr>
|
|
))}
|
|
</tbody>
|
|
</table>
|
|
</Page.Contents>
|
|
);
|
|
};
|