Запрос данных плагиновMeta Box
Meta Box
Примеры queries для взаимодействия с данными плагина Meta Box.
Получение пользовательских полей Meta Box
Мы можем использовать мета-поля для запроса данных пользовательских полей Meta Box, независимо от их типа:
query GetPost($postId: ID!) {
post(by: { id: $postId }) {
id
title
text: metaValue(key: "text_field")
textarea: metaValue(key: "textarea_field")
select: metaValue(key: "select_field")
multiSelect: metaValues(key: "multi_select_field")
}
}Если мета-значение является связью (например: запись, пользователь, таксономия и т. д.), мы можем использовать это значение для запроса соответствующей сущности типа Post, User, Taxonomy и т. д.:
query GetPostWithRelationships($postId: ID!) {
post(by: { id: $postId }) {
id
title
# Экспортировать связь с записью
relationshipPostId: metaValue(key: "relationship_post_id")
@export(as: "relationshipPostId")
# Экспортировать связь со списком записей
relationshipPostIds: metaValues(key: "relationship_post_ids")
@export(as: "relationshipPostIds")
}
}
query QueryPostRelationships @depends(on: "GetPostWithRelationships") {
# Запросить связанную запись
relationshipPost: post(by: { id: $relationshipPostId }) {
id
title
}
# Запросить список связанных записей
relationshipPosts: posts(filter: { ids: $relationshipPostIds }) {
id
title
}
}Обновление пользовательских полей Meta Box
Мы можем использовать мета-мутации для обновления данных пользовательских полей Meta Box, передавая имена полей и значения, независимо от их типа:
mutation UpdatePost($postId: ID!) {
updatePost(
input: {
id: $postId
meta: {
text_field: ["New text value"],
textarea_field: ["New textarea value"],
select_field: ["New select value"],
multi_select_field: ["Choice 1", "Choice 2"],
}
}
) {
status
errors {
__typename
...on ErrorPayload {
message
}
}
post {
id
text: metaValue(key: "text_field")
textarea: metaValue(key: "textarea_field")
select: metaValue(key: "select_field")
multiSelect: metaValues(key: "multi_select_field")
}
}
}Prev