Отфильтровать результат запроса по значению поля внутри массива объектов [Sanity.io & GROQ]
Я пытаюсь найти вариант продукта в моем списке продуктов (на sanity.io с использованием GROQ), для этого у меня есть номер артикула того варианта, который мне нужен.
Я использую запрос
*[_type == "product" && variants[].sku.current =="kit-kat-wasabi-5" ]
Но этот запрос возвращает пустой массив. Я уверен, что артикул правильный, потому что если я оставлю фильтр в стороне и получу все, что смогу найти. Я попытался заменить "==" на match, но результат тот же.
мои схемы
производить
export default {
name: 'product',
title: 'Product',
type: 'document',
fields: [
{
name: 'title',
title: 'Inner Title',
type: 'string'
},
{
title: 'SKU',
name: 'sku',
type: 'slug',
options: {
source: 'title',
maxLength: 96
},
validation: Rule => Rule.required()
},
{
name: 'titleWebsite',
title: 'Title Website',
type: 'localeString'
},
{
name: 'active',
title: 'Active',
type: 'boolean'
},
{
name: 'mainImage',
title: 'Imagem',
type:"image"
},
{
name: 'slug',
title: 'Slug',
type: 'slug',
options: {
source: 'title',
maxLength: 96
}
},
{
title: 'Base Price',
name: 'basePrice',
type: 'localeCurrency'
},
{
title: 'Quantidade',
name: 'qty',
type: 'number'
},
/* {
title: 'Default variant',
name: 'defaultProductVariant',
type: 'productVariant'
},*/
{
title: 'Variants',
name: 'variants',
type: 'array',
of: [
{
title: 'Variant',
type: 'productVariant'
}
]
},
{
title: 'Tags',
name: 'tags',
type: 'array',
of: [
{
type: 'string'
}
],
options: {
layout: 'tags'
}
},
{
name: 'vendor',
title: 'Vendor',
type: 'reference',
to: {type: 'vendor'}
},
{
name: 'blurb',
title: 'Blurb',
type: 'localeString'
},
{
name: 'categories',
title: 'Categories',
type: 'array',
of: [
{
type: 'reference',
to: {type: 'category'}
}
]
},
{
name: 'body',
title: 'Body',
type: 'localeBlockContent'
}
],
preview: {
select: {
title: 'title',
manufactor: 'manufactor.title',
media: 'mainImage'
}
}
}
И productVariant
export default {
title: 'Product variant',
name: 'productVariant',
type: 'object',
fields: [
{
title: 'Title',
name: 'title',
type: 'string'
},
{
title: 'Title Website',
name: 'titleWebsite',
type: 'localeString'
},
{
title: 'Weight in grams',
name: 'grams',
type: 'number'
},
{
title: 'Price',
name: 'price',
type: 'localeCurrency'
},
{
title: 'SKU',
name: 'sku',
type: 'slug',
options: {
source: 'title',
maxLength: 96
},
validation: Rule => Rule.required()
},
{
title: 'Taxable',
name: 'taxable',
type: 'boolean'
},
{
name: 'blurb',
title: 'Blurb',
type: 'localeString'
},
{
name: 'images',
title: 'Images',
type: 'array',
of: [
{
type: 'image',
options: {
hotspot: true
}
}
]
},
{
title: 'Quantidade',
name: 'qty',
type: 'number'
},
{
title: 'Bar code',
name: 'barcode',
type: 'barcode'
}
]
}
1 ответ
Это известная ошибка в GROQ при обходе массивов. Это приведет к критическим изменениям, если это будет исправлено в GROQ v1. Поэтому он будет исправлен в GROQ v2.
Вот отчет об ошибке, объясняющий проблему: https://github.com/sanity-io/sanity/issues/1557. Вы можете проявить интерес к этой проблеме здесь.
Здесь есть рабочий черновик для второй версии: https://github.com/sanity-io/groq.
Что касается вашей схемы, я бы подумал об изменении типа sku
поле быть чем-то другим, например string
, и создайте новое поле для заголовка, в котором source
для свойства установлен артикул, который будет автоматически сгенерирован этим полем. Документацию по этому поводу можно найти здесь: https://www.sanity.io/docs/slug-type.