saleor-dashboard/src/customers/components/CustomerListPage/CustomerListPage.tsx

182 lines
5.9 KiB
TypeScript
Raw Normal View History

// @ts-strict-ignore
2023-03-06 09:57:25 +00:00
import {
extensionMountPoints,
mapToMenuItems,
mapToMenuItemsForCustomerOverviewActions,
useExtensions,
} from "@dashboard/apps/hooks/useExtensions";
import { useUserPermissions } from "@dashboard/auth/hooks/useUserPermissions";
import { ListFilters } from "@dashboard/components/AppLayout/ListFilters";
import { TopNav } from "@dashboard/components/AppLayout/TopNav";
import { BulkDeleteButton } from "@dashboard/components/BulkDeleteButton";
import { ButtonWithDropdown } from "@dashboard/components/ButtonWithDropdown";
import { FilterPresetsSelect } from "@dashboard/components/FilterPresetsSelect";
import { Customers } from "@dashboard/customers/types";
import {
customerAddUrl,
CustomerListUrlSortField,
customerUrl,
} from "@dashboard/customers/urls";
import useNavigator from "@dashboard/hooks/useNavigator";
import { sectionNames } from "@dashboard/intl";
2019-09-11 14:39:52 +00:00
import {
FilterPagePropsWithPresets,
2019-09-11 14:39:52 +00:00
PageListProps,
2020-01-02 12:22:12 +00:00
SortPage,
} from "@dashboard/types";
import { Box, Button, ChevronRightIcon } from "@saleor/macaw-ui/next";
import React, { useState } from "react";
import { FormattedMessage, useIntl } from "react-intl";
import { CustomerListDatagrid } from "../CustomerListDatagrid/CustomerListDatagrid";
import {
createFilterStructure,
CustomerFilterKeys,
CustomerListFilterOpts,
} from "./filters";
2019-06-19 14:40:52 +00:00
2019-09-11 14:39:52 +00:00
export interface CustomerListPageProps
extends PageListProps,
FilterPagePropsWithPresets<CustomerFilterKeys, CustomerListFilterOpts>,
SortPage<CustomerListUrlSortField> {
customers: Customers | undefined;
selectedCustomerIds: string[];
loading: boolean;
onSelectCustomerIds: (rows: number[], clearSelection: () => void) => void;
onCustomersDelete: () => void;
2019-06-19 14:40:52 +00:00
}
const CustomerListPage: React.FC<CustomerListPageProps> = ({
selectedFilterPreset,
2020-01-02 12:22:12 +00:00
filterOpts,
2019-09-11 14:39:52 +00:00
initialSearch,
onFilterPresetsAll,
2020-01-02 12:22:12 +00:00
onFilterChange,
onFilterPresetDelete,
onFilterPresetUpdate,
2019-09-11 14:39:52 +00:00
onSearchChange,
onFilterPresetChange,
onFilterPresetPresetSave,
filterPresets,
selectedCustomerIds,
hasPresetsChanged,
onCustomersDelete,
2019-06-19 14:40:52 +00:00
...customerListProps
}) => {
const intl = useIntl();
const navigate = useNavigator();
const userPermissions = useUserPermissions();
const structure = createFilterStructure(intl, filterOpts, userPermissions);
const [isFilterPresetOpen, setFilterPresetOpen] = useState(false);
2020-01-02 12:22:12 +00:00
2023-02-28 09:50:54 +00:00
const { CUSTOMER_OVERVIEW_CREATE, CUSTOMER_OVERVIEW_MORE_ACTIONS } =
useExtensions(extensionMountPoints.CUSTOMER_LIST);
const extensionMenuItems = mapToMenuItemsForCustomerOverviewActions(
CUSTOMER_OVERVIEW_MORE_ACTIONS,
selectedCustomerIds,
);
const extensionCreateButtonItems = mapToMenuItems(CUSTOMER_OVERVIEW_CREATE);
return (
<>
<TopNav
title={intl.formatMessage(sectionNames.customers)}
withoutBorder
isAlignToRight={false}
>
<Box
__flex={1}
display="flex"
justifyContent="space-between"
alignItems="center"
>
<Box display="flex">
<Box marginX={5} display="flex" alignItems="center">
<ChevronRightIcon />
</Box>
<FilterPresetsSelect
presetsChanged={hasPresetsChanged()}
onSelect={onFilterPresetChange}
onRemove={onFilterPresetDelete}
onUpdate={onFilterPresetUpdate}
savedPresets={filterPresets}
activePreset={selectedFilterPreset}
onSelectAll={onFilterPresetsAll}
onSave={onFilterPresetPresetSave}
isOpen={isFilterPresetOpen}
onOpenChange={setFilterPresetOpen}
selectAllLabel={intl.formatMessage({
id: "D95l71",
defaultMessage: "All customers",
description: "tab name",
})}
/>
</Box>
<Box display="flex" alignItems="center" gap={2}>
{extensionMenuItems.length > 0 && (
<TopNav.Menu items={extensionMenuItems} />
)}
{extensionCreateButtonItems.length > 0 ? (
<ButtonWithDropdown
options={extensionCreateButtonItems}
data-test-id="create-customer"
onClick={() => navigate(customerAddUrl)}
>
<FormattedMessage
id="QLVddq"
defaultMessage="Create customer"
description="button"
/>
</ButtonWithDropdown>
) : (
<Button
data-test-id="create-customer"
onClick={() => navigate(customerAddUrl)}
>
<FormattedMessage
id="QLVddq"
defaultMessage="Create customer"
description="button"
/>
</Button>
)}
</Box>
</Box>
</TopNav>
<Box>
<ListFilters
2020-01-02 12:22:12 +00:00
filterStructure={structure}
2019-09-11 14:39:52 +00:00
initialSearch={initialSearch}
searchPlaceholder={intl.formatMessage({
id: "kdRcqU",
defaultMessage: "Search customers...",
2019-09-11 14:39:52 +00:00
})}
2020-01-02 12:22:12 +00:00
onFilterChange={onFilterChange}
2019-09-11 14:39:52 +00:00
onSearchChange={onSearchChange}
actions={
<Box display="flex" gap={4}>
{selectedCustomerIds.length > 0 && (
<BulkDeleteButton onClick={onCustomersDelete}>
<FormattedMessage
defaultMessage="Delete customers"
id="kFsTMN"
/>
</BulkDeleteButton>
)}
</Box>
}
/>
<CustomerListDatagrid
{...customerListProps}
hasRowHover={!isFilterPresetOpen}
rowAnchor={customerUrl}
onRowClick={id => navigate(customerUrl(id))}
2019-09-11 14:39:52 +00:00
/>
</Box>
</>
);
};
2019-06-19 14:40:52 +00:00
CustomerListPage.displayName = "CustomerListPage";
export default CustomerListPage;