Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 4 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -47,4 +47,7 @@ yarn-error.log*
*.tsbuildinfo

# idea files
.idea
.idea

# codex
.codex
3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,17 +14,18 @@
"check:fix": "biome check --write --unsafe"
},
"dependencies": {
"@radix-ui/react-accordion": "^1.2.12",
"@radix-ui/react-select": "^2.2.6",
"@radix-ui/react-separator": "^1.1.8",
"@radix-ui/react-slot": "^1.2.4",
"@radix-ui/react-accordion": "^1.2.12",
"@radix-ui/react-tabs": "^1.1.13",
"@t3-oss/env-nextjs": "^0.13.10",
"@tanstack/react-table": "^8.21.3",
"babel-plugin-react-compiler": "^1.0.0",
"class-variance-authority": "^0.7.1",
"clsx": "^2.1.1",
"cmdk": "1.1.1",
"embla-carousel-react": "^8.6.0",
"geist": "^1.5.1",
"next": "^15.5.15",
"next-themes": "^0.4.6",
Expand Down
28 changes: 28 additions & 0 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 6 additions & 1 deletion src/app/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,9 @@ import { FiFacebook, FiGithub, FiInstagram, FiLinkedin } from "react-icons/fi"
import discord from "@/assets/icons/discord.svg"
import telegram from "@/assets/icons/telegram.svg"
import { CardMultipleIcons } from "@/components/card-multiple-icons"
import { CardSplit } from "@/components/card-split"
import { AboutUs } from "@/components/home/about-us"
import { CarouselMock } from "@/components/home/carousel-mock"
import { Hero } from "@/components/home/hero"
import { Materials } from "@/components/home/materials"

Expand All @@ -12,8 +14,10 @@ export default function Home() {
<main className="w-full">
<Hero />
<Materials />
{/* TODO: delete this when merging */}
<CarouselMock />
<AboutUs />
<div className="mx-auto w-fit py-12">
<div className="mx-auto flex w-fit flex-col items-center gap-5 py-12">
<CardMultipleIcons
icons={[
<Image key="telegram" src={telegram} alt="Telegram" />,
Expand All @@ -24,6 +28,7 @@ export default function Home() {
<FiGithub key="github" />,
]}
/>
<CardSplit textPrimary="5x1000" textSecondary="Sostienici!" textSecondarySmall="CF: 97927490157" />
</div>
</main>
)
Expand Down
9 changes: 9 additions & 0 deletions src/app/projects/page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import { CommunityNews } from "@/components/projects/community-news"

export default function Home() {
return (
<main className="w-full">
<CommunityNews />
</main>
)
}
4 changes: 2 additions & 2 deletions src/components/gradient-icon.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { type FunctionComponent, type SVGProps, useId } from "react"

export type GradientIconType = FunctionComponent<SVGProps<SVGSVGElement>>
export type GradientIconType = FunctionComponent<SVGProps<SVGSVGElement> & { size?: string }>

type GradientIconProps = {
icon: GradientIconType
Expand All @@ -20,7 +20,7 @@ export function GradientIcon({ icon: Icon, className }: GradientIconProps) {
<stop offset="100%" stopColor="var(--color-blue-primary)" />
</linearGradient>
<mask id={maskId} maskUnits="userSpaceOnUse" x="0" y="0" width="16" height="16">
<Icon className={className} stroke="white" fill="none" />
<Icon stroke="white" fill="none" size="16" />
</mask>
</defs>
<rect x="0" y="0" width="16" height="16" fill={`url(#${gradientId})`} mask={`url(#${maskId})`} />
Expand Down
49 changes: 49 additions & 0 deletions src/components/home/carousel-mock.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
"use client"

import { CardCaption } from "@/components/card-caption"
import { Carousel, CarouselContent, CarouselDots, CarouselItem } from "@/components/ui/carousel"

const mockCards = [
{
title: "WeBeepSync",
caption:
"WeBeep Sync è una semplice app, user-friendly e senza compromessi che serve per tenere sincronizzati tutti i tuoi file di WeBeep.",
},
{
title: "PolimiSchedule",
caption:
"Genera un file iCalendar (.ics) a partire dal formato testuale dell’Orario delle lezioni. Possibilità di importare su Google Calendar.",
},
{
title: "WiFiLinux",
caption: "Scarica ed esegui lo script Python per attivare la connessione permanente al WiFi Polimi.",
},
{
title: "The TOL Project",
caption: "Un simulatore gratuito del test di ammissione per le aspiranti matricole di Ingegneria del PoliMi.",
},
] as const

// TODO: delete this when merging
export function CarouselMock() {
return (
<section className="mx-auto flex min-h-screen w-full max-w-4xl flex-col items-center justify-center gap-16 px-7.5">
<h1 className="typo-headline-medium sm:typo-display-large bg-linear-to-r from-text-primary via-blue-secondary to-blue-primary bg-clip-text text-transparent">
PoliNetwork
</h1>

<Carousel className="w-full">
<CarouselContent>
{mockCards.map((card) => (
<CarouselItem key={card.title}>
<div className="flex justify-center">
<CardCaption {...card} />
</div>
</CarouselItem>
))}
</CarouselContent>
<CarouselDots className="mt-8" />
</Carousel>
</section>
)
}
83 changes: 83 additions & 0 deletions src/components/projects/community-news.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
import { FiCrop } from "react-icons/fi"
import { CardCaption } from "../card-caption"
import { Carousel, CarouselContent, CarouselDots, CarouselItem } from "../ui/carousel"

const communityCards = [
{
title: "Title 1",
caption:
"description: Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incidunt ut labore et dolore magna aliqua.",
icon: FiCrop,
iconPosition: "right",
},
{
title: "Title 2",
caption:
"description: Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incidunt ut labore et dolore magna aliqua.",
icon: FiCrop,
iconPosition: "right",
},
{
title: "Title 3",
caption:
"description: Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incidunt ut labore et dolore magna aliqua.",
icon: FiCrop,
iconPosition: "right",
},
{
title: "Title 4",
caption:
"description: Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incidunt ut labore et dolore magna aliqua.",
icon: FiCrop,
iconPosition: "right",
},
] as const
Comment thread
BIA3IA marked this conversation as resolved.

export function CommunityNews() {
return (
<section className="mx-auto flex min-h-screen max-w-400 flex-col items-center justify-center gap-48 px-4 py-49">
<div className="flex flex-col items-center gap-6">
<h2 className="typo-display-large sm:typo-display-extralarge w-fit bg-linear-to-b from-text-primary to-text-secondary bg-clip-text py-4 text-transparent sm:py-14">
Projects
</h2>
<p className="typo-title-large sm:typo-headline-small max-w-xl text-center">
Esplora e contribuisci ai progetti degli studenti
</p>
</div>

<div className="mx-auto flex w-full flex-col gap-14 sm:w-fit">
<div className="flex flex-col items-center gap-2 sm:items-start">
<h3 className="typo-headline-medium sm:typo-display-medium text-center sm:text-left">
Le novità della community
</h3>
<p className="typo-body-large text-center sm:text-left">
Rimani aggiornato sulle idee appena condivise dagli studenti del Politecnico
</p>
</div>

{/* Desktop Grid */}
<div className="hidden grid-cols-2 justify-items-center gap-6 sm:grid xl:grid-cols-4">
{communityCards.map((card) => (
<CardCaption key={card.title} {...card} />
))}
</div>

{/* Mobile Carousel */}
<div className="sm:hidden">
<Carousel className="w-full">
<CarouselContent>
{communityCards.map((card) => (
<CarouselItem key={card.title}>
<div className="flex justify-center">
<CardCaption {...card} />
</div>
</CarouselItem>
))}
</CarouselContent>
<CarouselDots className="mt-8" />
</Carousel>
</div>
</div>
</section>
)
}
10 changes: 0 additions & 10 deletions src/components/ui/card.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,22 +70,12 @@ function CardAction({
gradient?: boolean
}) {
const gradientId = React.useId()

return (
<div
data-slot="card-action"
className={cn("col-start-2 row-span-2 row-start-1 self-auto justify-self-end", className)}
{...props}
>
{gradient && (
<svg width="0" height="0" className="absolute" aria-hidden="true" focusable="false">
<linearGradient id={gradientId} x1="0%" y1="100%" x2="0%" y2="0%">
<stop offset="0%" className="text-blue-secondary" stopColor="currentColor" />
<stop offset="100%" className="text-blue-primary" stopColor="currentColor" />
</linearGradient>
</svg>
)}

<Icon
size={
iconSize === "xs"
Expand Down
Loading
Loading