mirror of
https://github.com/urbit/developers.urbit.org.git
synced 2024-10-26 15:49:50 +03:00
306 lines
11 KiB
JavaScript
306 lines
11 KiB
JavaScript
import Head from "next/head";
|
||
import Header from "../components/Header";
|
||
import Footer from "../components/Footer";
|
||
import BlogPreview from "../components/BlogPreview";
|
||
import EventPreview from "../components/EventPreview";
|
||
import {
|
||
Container,
|
||
SingleColumn,
|
||
Section,
|
||
TwoUp,
|
||
} from "foundation-design-system";
|
||
import Link from "next/link";
|
||
import {
|
||
Comms,
|
||
Database,
|
||
Distribution,
|
||
Functional,
|
||
Identity,
|
||
Interface,
|
||
MintFiller,
|
||
Peer,
|
||
} from "../components/icons";
|
||
import Card from "../components/Card";
|
||
import TallCard from "../components/TallCard";
|
||
import { getAllPosts, getAllEvents } from "../lib/lib";
|
||
import { eventKeys } from "../lib/constants";
|
||
import { DateTime } from "luxon";
|
||
import { formatDate, generateDisplayDate } from "../lib/lib";
|
||
|
||
export default function Home({ search, whatsNew }) {
|
||
return (
|
||
<div>
|
||
<Head>
|
||
<title>Urbit Developers</title>
|
||
</Head>
|
||
<Container>
|
||
<Header search={search} />
|
||
<SingleColumn>
|
||
<Section className="pb-72">
|
||
{/* Hero statement */}
|
||
<div className="flex flex-col space-y-4">
|
||
<h1 className="max-w-prose">
|
||
Discover the creative possibilities of a unified operating
|
||
system
|
||
</h1>
|
||
<div className="flex flex-col md:flex-row space-y-4 md:space-y-0 md:space-x-4 pt-4">
|
||
<Link href="/guides/quickstart/chat-guide" passHref>
|
||
<a className="button-lg bg-green-400 text-white">
|
||
Quickstart
|
||
</a>
|
||
</Link>
|
||
<Link href="/overview" passHref>
|
||
<a className="button-lg bg-blue-400 text-white">
|
||
Read the Overview
|
||
</a>
|
||
</Link>
|
||
<Link href="/guides" passHref>
|
||
<a className="button-lg bg-white border-wall-500 border-2">
|
||
Learn the Stack
|
||
</a>
|
||
</Link>
|
||
</div>
|
||
</div>
|
||
</Section>
|
||
<Section short>
|
||
<h2 className="font-normal">
|
||
Urbit provides{" "}
|
||
<span className="font-bold">foundational primitives</span> at the
|
||
operating system layer, serving as a better platform for building{" "}
|
||
<span className="font-bold">
|
||
networked, decentralized applications
|
||
</span>
|
||
.
|
||
</h2>
|
||
<div className="flex flex-wrap pt-12">
|
||
{pitch.map((each) => {
|
||
return (
|
||
<div
|
||
key={each.title}
|
||
className="basis-full md:basis-1/2 xl:basis-1/3 flex space-x-2 justify-start items-start my-8 pr-8"
|
||
>
|
||
{each.icon}
|
||
<div className="flex flex-col">
|
||
<p className="font-bold text-sm">{each.title}</p>
|
||
<p className="text-sm">{each.content}</p>
|
||
</div>
|
||
</div>
|
||
);
|
||
})}
|
||
</div>
|
||
<div className="pt-12">
|
||
<p>
|
||
Thanks to this architecture, you can take software into
|
||
production within weeks rather than months. Check out our
|
||
Lightning Tutorials below to jump right in and build an app in
|
||
15 minutes.
|
||
</p>
|
||
</div>
|
||
</Section>
|
||
<Section>
|
||
<h2 className="pt-12">Quickstart: Lightning Tutorials</h2>
|
||
<div className="flex flex-col space-y-8 md:space-y-0 md:flex-row md:space-x-8 pt-12">
|
||
<Card
|
||
icon={<Comms />}
|
||
title="Encrypted Chat Application"
|
||
text="Build your own secure comms tool"
|
||
className="basis-1/2"
|
||
href="/guides/quickstart/chat-guide"
|
||
/>
|
||
{/* <Card
|
||
icon={<MintFiller />}
|
||
title="Lorem Ipsum Dolorem"
|
||
text="Roll your own encrypted chat application in minutes"
|
||
className="basis-1/2"
|
||
/> */}
|
||
</div>
|
||
</Section>
|
||
<Section className="flex flex-col space-y-12">
|
||
<h2>Guides</h2>
|
||
<p className="text-lg">
|
||
Learn the foundations of software development on Urbit with our
|
||
core curriculum of guides.
|
||
</p>
|
||
<TwoUp>
|
||
<TallCard
|
||
title="Hoon School"
|
||
description="Learn the fundamentals of the Hoon programming language"
|
||
callout="View Guide"
|
||
href="/guides/core/hoon-school"
|
||
image="/images/hoon.svg"
|
||
className="h-full"
|
||
/>
|
||
<TallCard
|
||
title="App School"
|
||
description="Learn how to build Urbit userspace applications by writing your own Gall agents"
|
||
callout="View Guide"
|
||
href="/guides/core/app-school"
|
||
image="/images/app.svg"
|
||
className="h-full"
|
||
/>
|
||
</TwoUp>
|
||
<Link href="/guides" passHref>
|
||
<a className="button-lg bg-wall-600 text-white w-fit">
|
||
View All Guides
|
||
</a>
|
||
</Link>
|
||
</Section>
|
||
<Section className="flex flex-col space-y-12">
|
||
<h2>Courses</h2>
|
||
<p className="text-lg">
|
||
Want an interactive experience to truly learn software development
|
||
on Urbit? Join the next cohort for Hoon or App School Live and
|
||
learn with a group.
|
||
</p>
|
||
<Link href="/courses" passHref>
|
||
<a className="button-lg bg-green-400 text-white w-fit">
|
||
View Courses
|
||
</a>
|
||
</Link>
|
||
</Section>
|
||
<Section className="flex flex-col space-y-8">
|
||
<h2>Community</h2>
|
||
<p className="text-lg">
|
||
The developer community is friendly, helpful, and organized from
|
||
within Urbit itself.
|
||
</p>
|
||
<div className="flex flex-col space-y-4 md:space-y-0 md:flex-row md:space-x-4 pb-4">
|
||
<Card
|
||
title="Developer Events"
|
||
text="We regularly host livestreams, meetups, and hackathons"
|
||
href="/community/events"
|
||
callout="View Events"
|
||
className="basis-1/2"
|
||
/>
|
||
<Card
|
||
title="Opportunities"
|
||
text="Urbit is growing and there are many opportunities to find a job, grant, or funding for your great idea"
|
||
href="/community/opportunities"
|
||
callout="Explore Opportunities"
|
||
className="basis-1/2"
|
||
/>
|
||
</div>
|
||
|
||
<Link href="/community" passHref>
|
||
<a className="button-lg bg-wall-600 text-white w-fit">
|
||
Community Pages
|
||
</a>
|
||
</Link>
|
||
</Section>
|
||
<Section className="flex flex-col space-y-8">
|
||
<h2>What's New</h2>
|
||
<TwoUp>
|
||
{whatsNew.slice(0, 2).map((e) => {
|
||
if (e.type === "event") {
|
||
return (
|
||
<EventPreview event={e} className="basis-1/2 h-full" />
|
||
);
|
||
} else if (e.type === "blog") {
|
||
const date = generateDisplayDate(e.date);
|
||
return (
|
||
<Link href={`/blog/${e.slug}`}>
|
||
<div className="cursor-pointer bg-wall-100 rounded-xl basis-1/2 h-full">
|
||
<div className="flex flex-col p-6 justify-between items-between h-full relative">
|
||
<img
|
||
className="rounded-xl w-full flex-1 object-cover"
|
||
src={e.extra.image}
|
||
style={{ aspectRatio: "4 / 3" }}
|
||
/>
|
||
<div className="grow-1 shrink-0 flex flex-col h-full min-h-0 pt-4">
|
||
<h3 className="mb-2">{e.title}</h3>
|
||
<p className="text-sm">
|
||
{e.extra.author ? (
|
||
<span className="type-sub-bold mr-2">
|
||
{e.extra.author}
|
||
</span>
|
||
) : null}
|
||
{e.extra.ship ? (
|
||
<Link
|
||
href={`https://urbit.org/ids/${e.extra.ship}`}
|
||
passHref
|
||
>
|
||
<a className="type-sub-bold text-wall-500 font-mono">
|
||
{e.extra.ship}
|
||
</a>
|
||
</Link>
|
||
) : null}
|
||
</p>
|
||
<p className="text-wall-500 type-sub shrink-0">
|
||
{formatDate(date)}
|
||
</p>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</Link>
|
||
);
|
||
}
|
||
})}
|
||
</TwoUp>
|
||
</Section>
|
||
</SingleColumn>
|
||
<Footer />
|
||
</Container>
|
||
</div>
|
||
);
|
||
}
|
||
|
||
const pitch = [
|
||
{
|
||
icon: <Identity className="shrink-0" />,
|
||
title: "Identity",
|
||
content:
|
||
"Identity is built-in at the lowest level of the stack – say goodbye to auth systems.",
|
||
},
|
||
{
|
||
icon: <Functional className="shrink-0" />,
|
||
title: "Functional Network",
|
||
content:
|
||
"Immutable, functional programming across the entire OS and network",
|
||
},
|
||
{
|
||
icon: <Database className="shrink-0" />,
|
||
title: "Built-in Database",
|
||
content: "Every piece of state in your application is persistent, always",
|
||
},
|
||
{
|
||
icon: <Peer className="shrink-0" />,
|
||
title: "Peer-to-Peer Applications",
|
||
content: "Urbit makes robust peer-to-peer applications easy to build",
|
||
},
|
||
{
|
||
icon: <Distribution className="shrink-0" />,
|
||
title: "Open Distribution",
|
||
content:
|
||
"Distribute software directly to users — you are your own app store",
|
||
},
|
||
{
|
||
icon: <Interface className="shrink-0" />,
|
||
title: "Web Interfaces",
|
||
content:
|
||
"Urbit applications can be built on any interface framework, including the web",
|
||
},
|
||
];
|
||
|
||
export async function getStaticProps() {
|
||
const posts = getAllPosts(
|
||
["title", "slug", "date", "description", "extra"],
|
||
"blog",
|
||
"date"
|
||
).map((e) => ({ ...e, type: "blog" }));
|
||
const events = getAllEvents(eventKeys, "community/events").map((e) => ({
|
||
...e,
|
||
type: "event",
|
||
}));
|
||
const whatsNew = [...posts, ...events].sort((a, b) => {
|
||
return DateTime.fromISO(a.date || a.ends) >
|
||
DateTime.fromISO(b.date || b.ends)
|
||
? -1
|
||
: 1;
|
||
});
|
||
return {
|
||
props: {
|
||
whatsNew,
|
||
},
|
||
};
|
||
}
|