2022-02-21 13:32:38 +00:00
|
|
|
import { gql } from "@apollo/client";
|
2021-05-28 09:59:25 +00:00
|
|
|
import {
|
2022-03-09 08:56:55 +00:00
|
|
|
SearchAttributeValuesDocument,
|
|
|
|
SearchAttributeValuesQuery,
|
2022-06-21 09:36:55 +00:00
|
|
|
SearchAttributeValuesQueryVariables,
|
2022-03-09 08:56:55 +00:00
|
|
|
} from "@saleor/graphql";
|
|
|
|
import makeSearch from "@saleor/hooks/makeSearch";
|
2021-05-28 09:59:25 +00:00
|
|
|
|
|
|
|
export const searchAttributeValues = gql`
|
|
|
|
query SearchAttributeValues(
|
|
|
|
$id: ID
|
|
|
|
$after: String
|
|
|
|
$first: Int!
|
|
|
|
$query: String!
|
|
|
|
) {
|
|
|
|
attribute(id: $id) {
|
|
|
|
id
|
2021-06-02 19:11:30 +00:00
|
|
|
choices(after: $after, first: $first, filter: { search: $query }) {
|
2021-05-28 09:59:25 +00:00
|
|
|
edges {
|
|
|
|
node {
|
2022-03-09 08:56:55 +00:00
|
|
|
...AttributeValueDetails
|
2021-05-28 09:59:25 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
pageInfo {
|
2022-03-09 08:56:55 +00:00
|
|
|
...PageInfo
|
2021-05-28 09:59:25 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`;
|
|
|
|
|
|
|
|
export default makeSearch<
|
2022-03-09 08:56:55 +00:00
|
|
|
SearchAttributeValuesQuery,
|
|
|
|
SearchAttributeValuesQueryVariables
|
|
|
|
>(SearchAttributeValuesDocument, result => {
|
2021-06-02 19:11:30 +00:00
|
|
|
if (result.data?.attribute.choices.pageInfo.hasNextPage) {
|
2021-05-28 09:59:25 +00:00
|
|
|
result.loadMore(
|
|
|
|
(prev, next) => {
|
|
|
|
if (
|
2021-06-02 19:11:30 +00:00
|
|
|
prev.attribute.choices.pageInfo.endCursor ===
|
|
|
|
next.attribute.choices.pageInfo.endCursor
|
2021-05-28 09:59:25 +00:00
|
|
|
) {
|
|
|
|
return prev;
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
...prev,
|
|
|
|
attribute: {
|
|
|
|
...prev.attribute,
|
2021-06-02 19:11:30 +00:00
|
|
|
choices: {
|
|
|
|
...prev.attribute.choices,
|
2021-05-28 09:59:25 +00:00
|
|
|
edges: [
|
2021-06-02 19:11:30 +00:00
|
|
|
...prev.attribute.choices.edges,
|
2022-06-21 09:36:55 +00:00
|
|
|
...next.attribute.choices.edges,
|
2021-05-28 09:59:25 +00:00
|
|
|
],
|
2022-06-21 09:36:55 +00:00
|
|
|
pageInfo: next.attribute.choices.pageInfo,
|
|
|
|
},
|
|
|
|
},
|
2021-05-28 09:59:25 +00:00
|
|
|
};
|
|
|
|
},
|
|
|
|
{
|
|
|
|
...result.variables,
|
2022-06-21 09:36:55 +00:00
|
|
|
after: result.data.attribute.choices.pageInfo.endCursor,
|
|
|
|
},
|
2021-05-28 09:59:25 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|