1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
|
import { ArticlePreview } from '@ts/types/articles';
import {
AllPostsSlugResponse,
FetchAllPostsSlugReturn,
FetchPostsListReturn,
GetPostsListReturn,
PostsListResponse,
} from '@ts/types/blog';
import { gql } from 'graphql-request';
import { getGraphQLClient } from './client';
export const fetchPublishedPosts: FetchPostsListReturn = async (
first = 10,
after = ''
) => {
const client = getGraphQLClient();
const query = gql`
query AllPublishedPosts($first: Int, $after: String) {
posts(
after: $after
first: $first
where: { status: PUBLISH, orderby: { field: DATE, order: DESC } }
) {
edges {
cursor
node {
acfPosts {
postsInSubject {
... on Subject {
databaseId
featuredImage {
node {
altText
sourceUrl
title
}
}
id
slug
title
}
}
postsInThematic {
... on Thematic {
databaseId
id
slug
title
}
}
}
commentCount
contentParts {
beforeMore
}
date
featuredImage {
node {
altText
sourceUrl
title
}
}
id
databaseId
modified
slug
title
}
}
pageInfo {
endCursor
hasNextPage
}
}
}
`;
const variables = { first, after };
try {
const response: PostsListResponse = await client.request(query, variables);
return response;
} catch (error) {
console.error(JSON.stringify(error, undefined, 2));
process.exit(1);
}
};
export const getPublishedPosts: GetPostsListReturn = async ({
first = 10,
after = '',
}) => {
const rawPostsList = await fetchPublishedPosts(first, after);
const postsList: ArticlePreview[] = rawPostsList.posts.edges.map((post) => {
const {
acfPosts,
commentCount,
contentParts,
databaseId,
date,
featuredImage,
id,
modified,
slug,
title,
} = post.node;
const content = contentParts.beforeMore;
const cover = featuredImage ? featuredImage.node : null;
const dates = { publication: date, update: modified };
const subjects =
acfPosts.postsInSubject && acfPosts.postsInSubject?.length > 0
? acfPosts.postsInSubject
: [];
const thematics =
acfPosts.postsInThematic && acfPosts.postsInThematic?.length > 0
? acfPosts.postsInThematic
: [];
return {
commentCount,
content,
databaseId,
date: dates,
featuredImage: cover,
id,
slug,
subjects,
thematics,
title,
};
});
return { posts: postsList, pageInfo: rawPostsList.posts.pageInfo };
};
export const fetchAllPostsSlug: FetchAllPostsSlugReturn = async () => {
const client = getGraphQLClient();
// 10 000 is an arbitrary number for small websites.
const query = gql`
query AllPostsSlug {
posts(first: 10000) {
nodes {
slug
}
}
}
`;
try {
const response: AllPostsSlugResponse = await client.request(query);
return response.posts.nodes;
} catch (error) {
console.error(JSON.stringify(error, undefined, 2));
process.exit(1);
}
};
|