homepage/src/pages/index.js

75 lines
2.3 KiB
JavaScript
Raw Normal View History

2022-08-24 10:44:35 +03:00
import useSWR from "swr";
import Head from "next/head";
import dynamic from "next/dynamic";
import { ThemeProvider } from "utils/theme-context";
import ServicesGroup from "components/services/group";
import BookmarksGroup from "components/bookmarks/group";
import Widget from "components/widget";
2022-08-25 11:14:17 +03:00
import { ColorProvider } from "utils/color-context";
2022-08-24 10:44:35 +03:00
const ThemeToggle = dynamic(() => import("components/theme-toggle"), {
ssr: false,
});
2022-08-25 11:14:17 +03:00
const ColorToggle = dynamic(() => import("components/color-toggle"), {
ssr: false,
});
2022-08-24 10:44:35 +03:00
export default function Home() {
const { data: services, error: servicesError } = useSWR("/api/services");
const { data: bookmarks, error: bookmarksError } = useSWR("/api/bookmarks");
const { data: widgets, error: widgetsError } = useSWR("/api/widgets");
return (
2022-08-25 11:14:17 +03:00
<ColorProvider>
<ThemeProvider>
<Head>
<title>Welcome</title>
</Head>
<div className="w-full container m-auto flex flex-col h-screen justify-between">
<div className="flex flex-wrap space-x-4 m-8 pb-4 mt-10 border-b-2 border-theme-800 dark:border-theme-200">
2022-08-25 11:14:17 +03:00
{widgets && (
<>
2022-08-27 00:55:13 +03:00
{widgets
.filter((widget) => widget.type !== "weather")
.map((widget, i) => (
<Widget key={i} widget={widget} />
))}
<div className="grow"></div>
{widgets
.filter((widget) => widget.type === "weather")
.map((widget, i) => (
<Widget key={i} widget={widget} />
))}
2022-08-25 11:14:17 +03:00
</>
)}
</div>
{services && (
<div className="flex flex-wrap p-8 items-start">
{services.map((group) => (
<ServicesGroup key={group.name} services={group} />
2022-08-24 10:44:35 +03:00
))}
2022-08-25 11:14:17 +03:00
</div>
2022-08-24 10:44:35 +03:00
)}
2022-08-25 11:14:17 +03:00
{bookmarks && (
<div className="grow flex flex-wrap pt-0 p-8">
{bookmarks.map((group) => (
<BookmarksGroup key={group.name} group={group} />
))}
</div>
)}
2022-08-24 10:44:35 +03:00
2022-08-25 11:14:17 +03:00
<div className="rounded-full flex p-8 w-full justify-between">
<ColorToggle />
<ThemeToggle />
2022-08-24 10:44:35 +03:00
</div>
</div>
2022-08-25 11:14:17 +03:00
</ThemeProvider>
</ColorProvider>
2022-08-24 10:44:35 +03:00
);
}