mirror of
https://github.com/DerTyp7/explainegy-nextjs.git
synced 2025-10-29 21:02:13 +01:00
34 lines
1.2 KiB
TypeScript
34 lines
1.2 KiB
TypeScript
import styles from "../../styles/modules/CategoryList.module.scss";
|
|
import Link from "next/link";
|
|
|
|
import { FetchManager } from "../../manager/fetchManager";
|
|
|
|
export default async function CategoryList() {
|
|
const categories = await FetchManager.Category.list();
|
|
return (
|
|
<div className={styles.categoryList}>
|
|
<h1>Overview</h1>
|
|
<div className={styles.content}>
|
|
<div className={styles.grid}>
|
|
{categories?.length > 0
|
|
? categories.map((cat, i) => {
|
|
return (
|
|
<div key={i} className={styles.linkContainer}>
|
|
<Link href={`/articles/${cat.name.toLowerCase()}`} style={{ backgroundColor: cat.color }}>
|
|
<div className={styles.svgContainer}>
|
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox={cat?.svg?.viewbox}>
|
|
<path d={cat?.svg?.path} />
|
|
</svg>
|
|
</div>
|
|
{cat.title}
|
|
</Link>
|
|
</div>
|
|
);
|
|
})
|
|
: "We did not find any categories"}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|