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/topics.query.ts | |
| parent | a208a8f314f697dbd6f85f8be8332bcea0204178 (diff) | |
refactor: rewrite API fetching method and GraphQL queries
Diffstat (limited to 'src/services/graphql/topics.query.ts')
| -rw-r--r-- | src/services/graphql/topics.query.ts | 117 | 
1 files changed, 117 insertions, 0 deletions
| diff --git a/src/services/graphql/topics.query.ts b/src/services/graphql/topics.query.ts new file mode 100644 index 0000000..8783799 --- /dev/null +++ b/src/services/graphql/topics.query.ts @@ -0,0 +1,117 @@ +/** + * Query the full topic data using its slug. + */ +export const topicBySlugQuery = `query TopicBy($slug: ID!) { +  topic(id: $slug, idType: SLUG) { +    acfTopics { +      officialWebsite +      postsInTopic { +        ... on Post { +          acfPosts { +            postsInThematic { +              ... on Thematic { +                databaseId +                slug +                title +              } +            } +          } +          commentCount +          contentParts { +            beforeMore +          } +          databaseId +          date +          featuredImage { +            node { +              altText +              mediaDetails { +                height +                width +              } +              sourceUrl +              title +            } +          } +          info { +            readingTime +            wordsCount +          } +          modified +          slug +          title +        } +      } +    } +    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 topics. + */ +export const topicsListQuery = `query TopicsList($after: String = "", $first: Int = 10) { +  topics( +    after: $after +    first: $first +    where: {orderby: {field: TITLE, order: ASC}, status: PUBLISH} +  ) { +    edges { +      cursor +      node { +        databaseId +        slug +        title +      } +    } +    pageInfo { +      endCursor +      hasNextPage +      total +    } +  } +}`; + +/** + * Query an array of topics slug. + */ +export const topicsSlugQuery = `query TopicsSlug($first: Int = 10, $after: String = "") { +  topics(after: $after, first: $first) { +    edges { +      cursor +      node { +        slug +      } +    } +    pageInfo { +      total +    } +  } +}`; | 
