Total Complexity | 8 |
Complexity/F | 0 |
Lines of Code | 55 |
Function Count | 0 |
Duplicated Lines | 0 |
Ratio | 0 % |
Changes | 0 |
1 | import React, { FunctionComponent } from "react" |
||
2 | import { CardTeaser } from "./Card" |
||
3 | import RelatedNewsProps, { RelatedNewsItem } from "./RelatedNews.types" |
||
4 | import fallbackImg from "../images/kcvv-player-bg.png" |
||
5 | |||
6 | import "./RelatedNews.scss" |
||
7 | import { getImage, getImageData, getSrc } from "gatsby-plugin-image" |
||
8 | |||
9 | const shuffle = (array: RelatedNewsItem[]): RelatedNewsItem[] => { |
||
10 | for (let i = array.length - 1; i > 0; i--) { |
||
11 | const j = Math.floor(Math.random() * (i + 1)) |
||
12 | const temp = array[i] |
||
13 | array[i] = array[j] |
||
14 | array[j] = temp |
||
15 | } |
||
16 | return array |
||
17 | } |
||
18 | |||
19 | const RelatedNews: FunctionComponent<RelatedNewsProps> = ({ items, limit = -1 }) => { |
||
20 | if (limit <= 0) { |
||
21 | limit = items.length |
||
22 | } |
||
23 | |||
24 | return ( |
||
25 | <section className="related_news__wrapper"> |
||
26 | {items.length > 0 && <h2 className="featured-border">Gerelateerde inhoud</h2>} |
||
27 | |||
28 | <main className="related_news__items"> |
||
29 | {items |
||
30 | .sort((a, b) => { |
||
31 | if (a.timestamp && b.timestamp) { |
||
32 | return b.timestamp - a.timestamp |
||
33 | } else { |
||
34 | return 0 |
||
35 | } |
||
36 | }) |
||
37 | .splice(0, limit) |
||
38 | .map((item, i) => { |
||
39 | const picture = |
||
40 | item.relationships?.field_media_article_image?.relationships?.field_media_image?.localFile |
||
41 | ?.childImageSharp.gatsbyImageData || null |
||
42 | |||
43 | return <CardTeaser key={i} title={item.title} picture={picture} link={item.path.alias} /> |
||
44 | })} |
||
45 | </main> |
||
46 | </section> |
||
47 | ) |
||
48 | } |
||
49 | |||
50 | RelatedNews.defaultProps = { |
||
51 | limit: -1, |
||
52 | } |
||
53 | |||
54 | export default RelatedNews |
||
55 |