Requêter les données WordPressCommentaires
Commentaires
Voici des exemples de requêtes pour récupérer et ajouter des commentaires.
Récupérer des commentaires
Commentaires d'une entrée :
query {
post(by: { id: 1 }) {
comments {
id
content
author {
name
}
parent {
id
}
}
}
}Commentaires et leurs réponses, sur plusieurs niveaux :
query {
post(by: { id: 1499 }) {
comments(pagination: { limit: 5 }) {
...CommentFields
responses {
...CommentFields
responses {
...CommentFields
}
}
}
}
}
fragment CommentFields on Comment {
id
date
content
}Filtrer les commentaires :
{
posts {
title
comments(
filter: { search: "insight" }
) {
id
content
}
}
}Compter les résultats de commentaires :
{
posts {
id
commentCount
}
}Paginer les commentaires :
{
posts {
id
comments(
pagination: {
limit: 3,
offset: 3
}
) {
id
date
content
}
}
}Tous les commentaires du site d'un utilisateur spécifique :
{
commentCount(filter: { authorIDs: [1], parentID: null })
comments(filter: { authorIDs: [1], parentID: null }, pagination: { limit: -1 }) {
id
date
content
}
}Un commentaire spécifique :
{
comment(by: { id: 272 }) {
id
date
content
author {
id
name
}
}
}Récupérer des valeurs méta :
{
posts {
id
comments{
id
metaValue(
key:"someKey"
)
}
}
}Ajouter un commentaire
Les utilisateurs connectés ou non connectés peuvent ajouter des commentaires :
mutation {
addCommentToCustomPost(
input: { customPostID: 1459, commentAs: { html: "Lovely tango!" } }
) {
status
errors {
__typename
...on ErrorPayload {
message
}
}
commentID
comment {
date
content
author {
id
name
}
}
}
}Nous pouvons également utiliser des mutations imbriquées :
mutation {
post(by: { id: 1459 }) {
id
title
addComment(input: { commentAs: { html: "Lovely tango!" } }) {
status
errors {
__typename
...on ErrorPayload {
message
}
}
commentID
comment {
date
content
author {
id
name
}
}
}
}
}Répondre à un commentaire
Similaire à l'ajout d'un commentaire, mais en fournissant également l'argument parentCommentID :
mutation {
addCommentToCustomPost(
input: {
customPostID: 1459
parentCommentID: 272
commentAs: { html: "Hi to you too" }
}
) {
status
errors {
__typename
...on ErrorPayload {
message
}
}
commentID
comment {
date
content
author {
id
name
}
}
}
}Ou utiliser le champ plus spécifique replyComment :
mutation {
replyComment(input: { parentCommentID: 272, commentAs: { html: "Hi to you too" } }) {
status
errors {
__typename
...on ErrorPayload {
message
}
}
commentID
comment {
date
content
author {
id
name
}
}
}
}Ou naviguer vers le commentaire parent en utilisant des mutations imbriquées :
mutation {
post(by: { id: 1459 }) {
comments(filter: { ids: 272 }) {
id
content
reply(input: { commentAs: { html: "Everything good?" } }) {
status
errors {
__typename
...on ErrorPayload {
message
}
}
commentID
comment {
date
content
}
}
}
}
}