Skip to content

A modern skateboard customization web application built with Next.js, Prismic CMS, and Three.js. Features include an interactive 3D skateboard builder, team showcase, and dynamic content management through Prismic. The application demonstrates advanced React patterns, 3D rendering, and seamless CMS integration.

License

Notifications You must be signed in to change notification settings

MinhOmega/suburbia-skate

Repository files navigation

Suburbia Skate - Interactive Skateboard Customizer

A modern skateboard customization web application featuring an interactive 3D builder, team showcase, and dynamic content management through Prismic CMS.

Suburbia Skate

🚀 Features

  • Interactive 3D skateboard customizer with real-time previews
  • Dynamic product catalog with customizable skateboards
  • Team member showcase with animated profiles
  • Responsive design optimized for all devices
  • Content management through Prismic CMS
  • Physics-based animations and interactions
  • SEO optimized with meta tags and structured data

🛠️ Tech Stack

  • Framework: Next.js 15 with App Router
  • 3D Rendering: Three.js with React Three Fiber
  • CMS: Prismic
  • Styling: TailwindCSS
  • Animations: GSAP
  • Physics: Matter.js
  • Language: TypeScript

🏁 Getting Started

  1. Clone the repository:
git clone https://github.com/minhomega/suburbia-skate.git
cd suburbia-skate
  1. Install dependencies:
npm install
# or
yarn install
# or
pnpm install
  1. Set up environment variables:
NEXT_PUBLIC_PRISMIC_ENVIRONMENT=your-prismic-repo-name
  1. Run the development server:
npm run dev
# or
yarn dev
# or
pnpm dev

Open http://localhost:3000 with your browser to see the result.

📝 CMS Setup

  1. Create a Prismic account and repository
  2. Configure the following Custom Types:
    • Board Customizer
    • Homepage
    • Settings
    • Skateboard
    • Skater

🎮 Key Components

  • Interactive 3D Skateboard Customizer
  • Team Grid with Animated Profiles
  • Product Grid with Dynamic Loading
  • Physics-based Footer Animation
  • Responsive Navigation

🔧 Development

  • Run tests: npm run test
  • Run linting: npm run lint
  • Start Slice Machine: npm run slicemachine

📦 Project Structure

src/
  ├── app/              # Next.js app router pages
  ├── components/       # Reusable components
  ├── slices/          # Prismic slice components
  ├── prismicio.ts     # Prismic configuration
  └── types/           # TypeScript type definitions

🚀 Deployment

The project is optimized for deployment on Vercel. Follow these steps:

  1. Push your code to GitHub
  2. Import your repository to Vercel
  3. Configure environment variables
  4. Deploy!

📄 License

This project is licensed under the GNU Affero General Public License v3.0 - see the LICENSE file for details.

About

A modern skateboard customization web application built with Next.js, Prismic CMS, and Three.js. Features include an interactive 3D skateboard builder, team showcase, and dynamic content management through Prismic. The application demonstrates advanced React patterns, 3D rendering, and seamless CMS integration.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published