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
|
import { type Post } from '@components/organisms/layout/posts-list';
import { type LinksListItems } from '@components/organisms/widgets/links-list-widget';
import { getArticleFromRawData } from '@services/graphql/articles';
import { type Article, type PageLink } from '@ts/types/app';
import { EdgesResponse } from '@ts/types/graphql/queries';
import {
type RawArticle,
type RawThematicPreview,
type RawTopicPreview,
} from '@ts/types/raw-data';
import { getImageFromRawData } from './images';
/**
* Convert raw data to a Link object.
*
* @param data - An object.
* @param {number} data.databaseId - The data id.
* @param {number} [data.logo] - The data logo.
* @param {string} data.slug - The data slug.
* @param {string} data.title - The data name.
* @returns {PageLink} The link data (id, slug and title).
*/
export const getPageLinkFromRawData = (
data: RawThematicPreview | RawTopicPreview,
kind: 'thematic' | 'topic'
): PageLink => {
const { databaseId, featuredImage, slug, title } = data;
const baseUrl = kind === 'thematic' ? '/thematique/' : '/sujet/';
return {
id: databaseId,
logo: featuredImage ? getImageFromRawData(featuredImage?.node) : undefined,
name: title,
url: `${baseUrl}${slug}`,
};
};
/**
* Method to sort PageLink objects by name.
*
* @param {PageLink} a - A PageLink object.
* @param {PageLink} b - Another PageLink object.
* @returns {1 | -1 | 0}
*/
export const sortPageLinksByName = (a: PageLink, b: PageLink) => {
const nameA = a.name.toUpperCase();
const nameB = b.name.toUpperCase();
if (nameA < nameB) return -1;
if (nameA > nameB) return 1;
return 0;
};
/**
* Convert page link data to an array of links items.
*
* @param {PageLink[]} links - An array of page links.
* @returns {LinksListItem[]} An array of links items.
*/
export const getLinksListItems = (links: PageLink[]): LinksListItems[] => {
return links.map((link) => {
return {
name: link.name,
url: link.url,
};
});
};
/**
* Retrieve the posts list with the article URL.
*
* @param {Article[]} posts - An array of articles.
* @returns {Post[]} An array of posts with full article URL.
*/
export const getPostsWithUrl = (posts: Article[]): Post[] => {
return posts.map((post) => {
return {
...post,
url: `/article/${post.slug}`,
};
});
};
/**
* Retrieve the posts list from raw data.
*
* @param {EdgesResponse<RawArticle>[]} rawData - The raw data.
* @returns {Post[]} An array of posts.
*/
export const getPostsList = (rawData: EdgesResponse<RawArticle>[]): Post[] => {
const articlesList: RawArticle[] = [];
rawData.forEach((articleData) =>
articleData.edges.forEach((edge) => {
articlesList.push(edge.node);
})
);
return getPostsWithUrl(
articlesList.map((article) => getArticleFromRawData(article))
);
};
|