Fix missing attribute values in products (#147)
* Fix missing attribute values in products
This commit is contained in:
parent
c1dab0ba18
commit
ce17e45abe
2 changed files with 41 additions and 3 deletions
5
.changeset/wet-dogs-warn.md
Normal file
5
.changeset/wet-dogs-warn.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
"saleor-app-search": patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Fix missing attribute values in products
|
|
@ -1,4 +1,7 @@
|
||||||
import { ProductVariantWebhookPayloadFragment } from "../../../generated/graphql";
|
import {
|
||||||
|
ProductAttributesDataFragment,
|
||||||
|
ProductVariantWebhookPayloadFragment,
|
||||||
|
} from "../../../generated/graphql";
|
||||||
import { isNotNil } from "../isNotNil";
|
import { isNotNil } from "../isNotNil";
|
||||||
|
|
||||||
type PartialChannelListing = {
|
type PartialChannelListing = {
|
||||||
|
@ -55,6 +58,22 @@ export function formatMetadata({ product }: ProductVariantWebhookPayloadFragment
|
||||||
|
|
||||||
export type AlgoliaObject = ReturnType<typeof productAndVariantToAlgolia>;
|
export type AlgoliaObject = ReturnType<typeof productAndVariantToAlgolia>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns object with a key being attribute name and value of all attribute values
|
||||||
|
* separated by comma. If no value is selected, an empty string will be used instead.
|
||||||
|
*/
|
||||||
|
const mapSelectedAttributesToRecord = (attr: ProductAttributesDataFragment) => {
|
||||||
|
if (!attr.attribute.name?.length) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
const filteredValues = attr.values.filter((v) => !!v.name?.length);
|
||||||
|
|
||||||
|
return {
|
||||||
|
[attr.attribute.name]: filteredValues.map((v) => v.name).join(", ") || "",
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
export function productAndVariantToAlgolia({
|
export function productAndVariantToAlgolia({
|
||||||
variant,
|
variant,
|
||||||
channel,
|
channel,
|
||||||
|
@ -65,10 +84,24 @@ export function productAndVariantToAlgolia({
|
||||||
const product = variant.product;
|
const product = variant.product;
|
||||||
const attributes = {
|
const attributes = {
|
||||||
...product.attributes.reduce((acc, attr, idx) => {
|
...product.attributes.reduce((acc, attr, idx) => {
|
||||||
return { ...acc, [attr.attribute.name ?? ""]: attr.values[idx]?.name ?? "" };
|
const preparedAttr = mapSelectedAttributesToRecord(attr);
|
||||||
|
if (!preparedAttr) {
|
||||||
|
return acc;
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
...acc,
|
||||||
|
...preparedAttr,
|
||||||
|
};
|
||||||
}, {}),
|
}, {}),
|
||||||
...variant.attributes.reduce((acc, attr, idx) => {
|
...variant.attributes.reduce((acc, attr, idx) => {
|
||||||
return { ...acc, [attr.attribute.name ?? ""]: attr.values[idx]?.name ?? "" };
|
const preparedAttr = mapSelectedAttributesToRecord(attr);
|
||||||
|
if (!preparedAttr) {
|
||||||
|
return acc;
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
...acc,
|
||||||
|
...preparedAttr,
|
||||||
|
};
|
||||||
}, {}),
|
}, {}),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue