diff options
| author | Armand Philippot <git@armandphilippot.com> | 2022-05-02 12:55:13 +0200 | 
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2022-05-02 15:09:36 +0200 | 
| commit | 9308a6dce03bd0c616e0ba6fec227473aaa44b33 (patch) | |
| tree | a5b9232b6e15b298316383c13d94cd431d078a13 /src/services/graphql/articles.query.ts | |
| parent | a208a8f314f697dbd6f85f8be8332bcea0204178 (diff) | |
refactor: rewrite API fetching method and GraphQL queries
Diffstat (limited to 'src/services/graphql/articles.query.ts')
| -rw-r--r-- | src/services/graphql/articles.query.ts | 174 | 
1 files changed, 174 insertions, 0 deletions
| diff --git a/src/services/graphql/articles.query.ts b/src/services/graphql/articles.query.ts new file mode 100644 index 0000000..e384aba --- /dev/null +++ b/src/services/graphql/articles.query.ts @@ -0,0 +1,174 @@ +/** + * Query the full article data using its slug. + */ +export const articleBySlugQuery = `query PostBy($slug: ID!) { +  post(id: $slug, idType: SLUG) { +    acfPosts { +      postsInThematic { +        ... on Thematic { +          databaseId +          slug +          title +        } +      } +      postsInTopic { +        ... on Topic { +          databaseId +          slug +          title +        } +      } +    } +    author { +      node { +        gravatarUrl +        name +        url +      } +    } +    commentCount +    contentParts { +      afterMore +      beforeMore +    } +    databaseId +    date +    featuredImage { +      node { +        altText +        mediaDetails { +          height +          width +        } +        sourceUrl +        title +      } +    } +    info { +      readingTime +      wordsCount +    } +    modified +    seo { +      metaDesc +      title +    } +    slug +    title +  } +}`; + +/** + * Query an array of partial articles. + */ +export const articlesQuery = `query Articles($after: String = "", $first: Int = 10, $search: String = "") { +  posts( +    after: $after +    first: $first +    where: {orderby: {field: DATE, order: DESC}, search: $search, status: PUBLISH} +  ) { +    edges { +      cursor +      node { +        acfPosts { +          postsInThematic { +            ... on Thematic { +              databaseId +              slug +              title +            } +          } +        } +        author { +          node { +            name +          } +        } +        commentCount +        contentParts { +          beforeMore +        } +        databaseId +        featuredImage { +          node { +            altText +            mediaDetails { +              height +              width +            } +            sourceUrl +            title +          } +        } +        info { +          readingTime +          wordsCount +        } +        modified +        slug +        title +      } +    } +    pageInfo { +      endCursor +      hasNextPage +      total +    } +  } +}`; + +/** + * Query an array of articles with only the minimal data. + */ +export const articlesCardQuery = `query ArticlesCard($first: Int = 10) { +  posts( +    first: $first +    where: {orderby: {field: DATE, order: DESC}, status: PUBLISH} +  ) { +    nodes { +      databaseId +      date +      featuredImage { +        node { +          altText +          mediaDetails { +            height +            width +          } +          sourceUrl +          title +        } +      } +      slug +      title +    } +  } +}`; + +/** + * Query an array of articles slug. + */ +export const articlesSlugQuery = `query ArticlesSlug($first: Int = 10, $after: String = "") { +  posts(after: $after, first: $first) { +    edges { +      cursor +      node { +        slug +      } +    } +    pageInfo { +      total +    } +  } +}`; + +/** + * Query the total number of articles. + */ +export const totalArticlesQuery = `query PostsTotal { +  posts { +    pageInfo { +      total +    } +  } +}`; | 
