saleor-dashboard/src/shipping/components/ShippingZoneSettingsCard/ChannelsSection.tsx
mmarkusik 19b8d30565
Feature - channels per plugin (#1093)
* Update schema

* Update queries, mutations, and types

* Add render with dividers util function

* Add plugin details channels card component

* Update plugin details to use channels

* Update stories

* Update plugin configuration type across the app, fix some other types, temporarily comment some things out in plugins list so types match"

* Update schema

* Update types

* Update plugins list to show channels and global statuses, add plugin channel status, update status label component

* Add render with dividers util function

* Comment out some stuff for types to match - temporary

* Add useChannelsSearchWithLoadMore util to imitate loading more from backend for channels list with load more

* Change filters logic to be able to display multiple fields in a field section and add it to plugins view

* Add scroll option to plugin availability popup on plugin list

* Fix plugin list page story

* Temporarily comment some stuff out, fix some types

* Add filters errors WIP

* Fix filters not updating list

* Add error handling to plugins list filters and filters in general

* Rename some components according to review

* Move useChannelsSearch and useChannelsSearchWithLoadMore to hooks, change some imports accordingly

* Fix imports

* Move render collection with dividers to a component, fix usages

* Replace channels with load more and search query to base channels query

* Change render with dividers function to take in a component instead of render function

* Update tests

* Extract messages

* Remove unnecessary imports

* Fix filters - autocomplete messing items order sometimes & some fields not working

* Update plugin update mutation variables - change channelId to channel

* fix failing tests

* Add test ids

* fix failing tests

* fix failing tests

* Rename misc.tsx to ts

* Remove usage of render collection with diviers, change it to CollectionWithDividers component

* Remove unnecessary imports

* Update messages ids

* Update snapshots

Co-authored-by: Karolina Rakoczy <rakoczy.karolina@gmail.com>
2021-05-11 15:58:09 +02:00

67 lines
2 KiB
TypeScript

import { Channels_channels } from "@saleor/channels/types/Channels";
import CardSpacer from "@saleor/components/CardSpacer";
import MultiAutocompleteSelectField, {
MultiAutocompleteChoiceType
} from "@saleor/components/MultiAutocompleteSelectField";
import { useChannelsSearch } from "@saleor/hooks/useChannelsSearch";
import { FormChange } from "@saleor/hooks/useForm";
import { mapNodeToChoice } from "@saleor/utils/maps";
import React from "react";
import { useIntl } from "react-intl";
import { defineMessages, FormattedMessage } from "react-intl";
const messages = defineMessages({
subtitle: {
defaultMessage:
"Assign channels to this shipping zone so we know which orders will be supported",
description: "ChannelsSection subtitle"
},
selectFieldLabel: {
defaultMessage: "Channel",
description: "ChannelsSection select field label",
id: "shippingZoneChannels.autocomplete.label"
},
selectFieldPlaceholder: {
defaultMessage: "Add Channel",
description: "ChannelsSection select field placeholder"
}
});
interface ChannelsSectionProps {
onChange: FormChange;
selectedChannels: string[];
allChannels?: Channels_channels[];
channelsDisplayValues: MultiAutocompleteChoiceType[];
}
const ChannelsSection: React.FC<ChannelsSectionProps> = ({
onChange,
allChannels = [],
selectedChannels,
channelsDisplayValues
}) => {
const { onQueryChange, filteredChannels } = useChannelsSearch(allChannels);
const intl = useIntl();
return (
<>
<FormattedMessage {...messages.subtitle} />
<CardSpacer />
<MultiAutocompleteSelectField
choices={mapNodeToChoice(filteredChannels)}
displayValues={channelsDisplayValues}
fetchChoices={onQueryChange}
hasMore={false}
label={intl.formatMessage(messages.selectFieldLabel)}
loading={false}
name="channels"
onChange={onChange}
placeholder={intl.formatMessage(messages.selectFieldPlaceholder)}
value={selectedChannels}
/>
</>
);
};
export default ChannelsSection;