/[sudobot]/branches/7.x/docs/components/Navigation/Navigator.tsx
ViewVC logotype

Contents of /branches/7.x/docs/components/Navigation/Navigator.tsx

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months, 1 week ago) by rakinar2
File MIME type: application/typescript
File size: 2619 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
1 "use client";
2
3 import useActualPathname from "@/hooks/useActualPathname";
4 import styles from "@/styles/Navigator.module.css";
5 import { getDocsPages, resolveDocsURL } from "@/utils/pages";
6 import Link from "next/link";
7 import { FC } from "react";
8 import { MdArrowBack, MdArrowForward } from "react-icons/md";
9
10 interface NavigatorProps {}
11
12 const flattenRoutes = () => {
13 const flatRoutes = [];
14
15 for (const page of getDocsPages()) {
16 if (page.url) {
17 flatRoutes.push({
18 name: page.name,
19 url: page.url,
20 });
21 }
22
23 if (page.children) {
24 for (const child of page.children) {
25 flatRoutes.push(child);
26 }
27 }
28 }
29
30 return flatRoutes;
31 };
32
33 const flatRoutes = flattenRoutes();
34
35 const Navigator: FC<NavigatorProps> = () => {
36 const pathname = useActualPathname();
37
38 const currentPage = flatRoutes.findIndex(page => {
39 if (!page.url) {
40 return false;
41 }
42
43 const url = resolveDocsURL(page.url);
44
45 return url === pathname;
46 });
47 const nextIndex = currentPage + 1;
48 const prevIndex = currentPage - 1;
49 const nextPage = flatRoutes[nextIndex];
50 const prevPage = flatRoutes[prevIndex];
51
52 return (
53 <div
54 className={styles.root}
55 data-wrap={!nextPage || !prevPage ? "true" : "false"}
56 >
57 {prevPage && (
58 <Link
59 href={prevPage.url ? resolveDocsURL(prevPage.url) : "#"}
60 className={`${styles.navigationControl} ${styles.navigationControlBack}`}
61 >
62 <div className={styles.iconWrapper}>
63 <MdArrowBack size={26} />
64 </div>
65 <div className={styles.text}>
66 <small>Back</small>
67 <span>{prevPage.name}</span>
68 </div>
69 </Link>
70 )}
71 {nextPage && (
72 <Link
73 href={nextPage.url ? resolveDocsURL(nextPage.url) : "#"}
74 className={`${styles.navigationControl} ${styles.navigationControlNext}`}
75 >
76 <div className={styles.text}>
77 <small>Next</small>
78 <span>{nextPage.name}</span>
79 </div>
80 <div className={styles.iconWrapper}>
81 <MdArrowForward size={26} />
82 </div>
83 </Link>
84 )}
85 </div>
86 );
87 };
88
89 export default Navigator;

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26