Query Data PluginMeta Box
Meta Box
Contoh queries untuk berinteraksi dengan data dari plugin Meta Box.
Mengambil custom field Meta Box
Kita dapat menggunakan meta fields untuk melakukan query data custom field Meta Box, untuk tipe apa pun:
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")
}
}Jika nilai meta adalah sebuah relasi (misalnya: sebuah post, pengguna, taksonomi, dll.), kita dapat menggunakan nilai tersebut untuk melakukan query entitas yang sesuai dengan tipe Post, User, Taxonomy, dll.:
query GetPostWithRelationships($postId: ID!) {
post(by: { id: $postId }) {
id
title
# Export the relationship to a post
relationshipPostId: metaValue(key: "relationship_post_id")
@export(as: "relationshipPostId")
# Export the relationship to a list of posts
relationshipPostIds: metaValues(key: "relationship_post_ids")
@export(as: "relationshipPostIds")
}
}
query QueryPostRelationships @depends(on: "GetPostWithRelationships") {
# Query the relationship to a post
relationshipPost: post(by: { id: $relationshipPostId }) {
id
title
}
# Query the relationship to a list of posts
relationshipPosts: posts(filter: { ids: $relationshipPostIds }) {
id
title
}
}Memperbarui custom field Meta Box
Kita dapat menggunakan meta mutations untuk memperbarui data custom field Meta Box, dengan memasukkan nama field dan nilainya, untuk tipe apa pun:
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