saleor-dashboard/src/permissionGroups/components/PermissionGroupListPage/PermissionGroupListPage.tsx
2023-02-28 10:33:16 +01:00

55 lines
1.7 KiB
TypeScript

import { TopNav } from "@dashboard/components/AppLayout/TopNav";
import { Button } from "@dashboard/components/Button";
import { ListPageLayout } from "@dashboard/components/Layouts";
import { configurationMenuUrl } from "@dashboard/configuration";
import { PermissionGroupFragment } from "@dashboard/graphql";
import { sectionNames } from "@dashboard/intl";
import { Card } from "@material-ui/core";
import React from "react";
import { FormattedMessage, useIntl } from "react-intl";
import { PageListProps, SortPage } from "../../../types";
import {
permissionGroupAddUrl,
PermissionGroupListUrlSortField,
} from "../../urls";
import PermissionGroupList from "../PermissionGroupList";
export interface PermissionGroupListPageProps
extends PageListProps,
SortPage<PermissionGroupListUrlSortField> {
permissionGroups: PermissionGroupFragment[];
onDelete: (id: string) => void;
}
const PermissionGroupListPage: React.FC<
PermissionGroupListPageProps
> = listProps => {
const intl = useIntl();
return (
<ListPageLayout>
<TopNav
href={configurationMenuUrl}
title={intl.formatMessage(sectionNames.permissionGroups)}
>
<Button
variant="primary"
href={permissionGroupAddUrl}
data-test-id="create-permission-group"
>
<FormattedMessage
id="bRJD/v"
defaultMessage="Create permission group"
description="button"
/>
</Button>
</TopNav>
<Card>
<PermissionGroupList {...listProps} />
</Card>
</ListPageLayout>
);
};
PermissionGroupListPage.displayName = "PermissionGroupListPage";
export default PermissionGroupListPage;