
* 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>
67 lines
2 KiB
TypeScript
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;
|