From f111685c5886f3e77edfd3621c98d8ac1b9bcce4 Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Fri, 24 Nov 2023 20:00:08 +0100 Subject: refactor(services, types): reorganize GraphQL fetchers and data types The Typescript mapped types was useful for autocompletion in fetchers but their are harder to maintain. I think it's better to keep each query close to its fetcher to have a better understanding of the fetched data. So I: * colocate queries with their own fetcher * colocate mutations with their own mutator * remove Typescript mapped types for queries and mutations * move data convertors inside graphql services * rename most of data types and fetchers --- src/services/graphql/topics.query.ts | 137 ----------------------------------- 1 file changed, 137 deletions(-) delete mode 100644 src/services/graphql/topics.query.ts (limited to 'src/services/graphql/topics.query.ts') diff --git a/src/services/graphql/topics.query.ts b/src/services/graphql/topics.query.ts deleted file mode 100644 index 57b2569..0000000 --- a/src/services/graphql/topics.query.ts +++ /dev/null @@ -1,137 +0,0 @@ -/** - * 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 { - wordsCount - } - modified - slug - title - } - } - } - contentParts { - afterMore - beforeMore - } - databaseId - date - featuredImage { - node { - altText - mediaDetails { - height - width - } - sourceUrl - title - } - } - info { - 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 - featuredImage { - node { - altText - mediaDetails { - height - width - } - sourceUrl - title - } - } - 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 - } - } -}`; - -/** - * Query the total number of topics. - */ -export const totalTopicsQuery = `query TopicsTotal { - topics { - pageInfo { - total - } - } -}`; -- cgit v1.2.3