66 lines
2.5 KiB
JavaScript
66 lines
2.5 KiB
JavaScript
import ContentThumbnailTemplate from "../components/ContentThumbnailTemplate";
|
|
import ContentLockup from "../components/ContentLockup";
|
|
import AskOrganizer from "../components/AskOrganizer";
|
|
import { getAllBlogPosts, getRecentBlogPosts } from "../../lib/content";
|
|
|
|
export default function LearnPage() {
|
|
// Get real blog posts from the content system
|
|
const allPosts = getAllBlogPosts();
|
|
const recentPosts = getRecentBlogPosts(3);
|
|
|
|
const contentLockupData = {
|
|
title: "Organizing is hard",
|
|
subtitle:
|
|
"Find answers to your questions and see how other groups have solved similar challenges.",
|
|
variant: "learn",
|
|
alignment: "left",
|
|
};
|
|
|
|
const askOrganizerData = {
|
|
title: "Still have questions?",
|
|
subtitle: "Get answers from an experienced organizer",
|
|
description:
|
|
"Our community of organizers is here to help you navigate the challenges of building and maintaining effective community organizations.",
|
|
buttonText: "Ask an organizer",
|
|
buttonHref: "/contact",
|
|
variant: "centered",
|
|
};
|
|
|
|
return (
|
|
<div className="min-h-screen bg-[var(--color-surface-default-primary)]">
|
|
<ContentLockup {...contentLockupData} />
|
|
|
|
{/* Horizontal list (below smd) */}
|
|
<div className="smd:hidden sm:pt-[var(--spacing-scale-024)] sm:pb-[var(--spacing-scale-024)] sm:px-[var(--spacing-scale-020)] space-y-[var(--spacing-scale-002)] sm:space-y-[var(--spacing-scale-008)]">
|
|
{allPosts.slice(0, 3).map((post, index) => (
|
|
<ContentThumbnailTemplate
|
|
key={`${post.slug}-${index}-${
|
|
post.frontmatter.thumbnail?.horizontal || "default"
|
|
}`}
|
|
post={post}
|
|
variant="horizontal"
|
|
/>
|
|
))}
|
|
</div>
|
|
|
|
{/* smd and up: 2x3 grid of vertical thumbnails, repeat posts as needed */}
|
|
<div className="hidden smd:grid smd:grid-cols-2 smd:gap-[var(--spacing-scale-008)] md:gap-[var(--spacing-scale-016)] smd:pt-[var(--spacing-scale-024)] smd:pb-[var(--spacing-scale-024)] smd:px-[var(--spacing-scale-020)] md:px-[var(--spacing-scale-032)]">
|
|
{Array.from({ length: 6 }).map((_, i) => {
|
|
const post = allPosts[i % allPosts.length];
|
|
return (
|
|
<ContentThumbnailTemplate
|
|
key={`grid-${post.slug}-${i}-${
|
|
post.frontmatter.thumbnail?.vertical || "default"
|
|
}`}
|
|
post={post}
|
|
variant="vertical"
|
|
/>
|
|
);
|
|
})}
|
|
</div>
|
|
|
|
<AskOrganizer {...askOrganizerData} />
|
|
</div>
|
|
);
|
|
}
|