No description
  • TypeScript 97.6%
  • CSS 2.2%
  • HTML 0.2%
Find a file
Jaro Heinonen 7dde781249 feat: add components from shadcn
Added components:
- Avatar
- Breadcrumbs
- ContextMenu
- Pagination
- Slider
- Textarea
- Toggle
2026-05-19 19:17:40 +03:00
.zed initial commit 2026-05-15 20:32:25 +03:00
apps feat: add components from shadcn 2026-05-19 19:17:40 +03:00
packages feat: add components from shadcn 2026-05-19 19:17:40 +03:00
.gitignore feat: add ytdlp integration with playback support 2026-05-18 20:51:30 +03:00
.oxfmtrc.json initial commit 2026-05-15 20:32:25 +03:00
.oxlintrc.json initial commit 2026-05-15 20:32:25 +03:00
AGENTS.md chore: add AGENTS.md 2026-05-18 20:37:16 +03:00
bts.jsonc initial commit 2026-05-15 20:32:25 +03:00
package.json initial commit 2026-05-15 20:32:25 +03:00
pnpm-lock.yaml initial commit 2026-05-15 20:32:25 +03:00
pnpm-workspace.yaml initial commit 2026-05-15 20:32:25 +03:00
README.md feat: add ytdlp integration with playback support 2026-05-18 20:51:30 +03:00
tsconfig.json initial commit 2026-05-15 20:32:25 +03:00
turbo.json initial commit 2026-05-15 20:32:25 +03:00

wiggle-music

This project was created with Better-T-Stack, a modern TypeScript stack that combines React, TanStack Router, Hono, TRPC, and more.

Features

  • TypeScript - For type safety and improved developer experience
  • TanStack Router - File-based routing with full type safety
  • TailwindCSS - Utility-first CSS for rapid UI development
  • Shared UI package - shadcn/ui primitives live in packages/ui
  • Hono - Lightweight, performant server framework
  • tRPC - End-to-end type-safe APIs
  • Node.js - Runtime environment
  • Drizzle - TypeScript-first ORM
  • PostgreSQL - Database engine
  • Authentication - Better-Auth
  • Oxlint - Oxlint + Oxfmt (linting & formatting)
  • Turborepo - Optimized monorepo build system

Getting Started

First, install the dependencies:

pnpm install

Database Setup

This project uses PostgreSQL with Drizzle ORM.

  1. Make sure you have a PostgreSQL database set up.

  2. Update your apps/server/.env file with your PostgreSQL connection details.

  3. Apply the schema to your database:

pnpm run db:push

Then, run the development server:

pnpm run dev

Open http://localhost:5173 in your browser to see the web application. The API is running at http://localhost:3000.

YouTube playback setup

The backend can use yt-dlp to resolve MusicBrainz recording MBIDs to YouTube audio, cache the result, and stream it from GET /api/music/play/:mbid. The music.play tRPC mutation accepts a MusicBrainz recording MBID and returns playback metadata plus the stream path. Install yt-dlp on the server host and make sure it is available on the server process PATH.

Optional server environment variables:

  • YTDLP_BINARY: path or executable name for yt-dlp; defaults to yt-dlp
  • YTDLP_STORAGE_DIR: audio cache directory; defaults to storage/ytdlp
  • YTDLP_TIMEOUT_MS: metadata/download timeout; defaults to 120000

UI Customization

React web apps in this stack share shadcn/ui primitives through packages/ui.

  • Change design tokens and global styles in packages/ui/src/styles/globals.css
  • Update shared primitives in packages/ui/src/components/*
  • Adjust shadcn aliases or style config in packages/ui/components.json and apps/web/components.json

Add more shared components

Run this from the project root to add more primitives to the shared UI package:

npx shadcn@latest add accordion dialog popover sheet table -c packages/ui

Import shared components like this:

import { Button } from "@wiggle-music/ui/components/button"

Add app-specific blocks

If you want to add app-specific blocks instead of shared primitives, run the shadcn CLI from apps/web.

Git Hooks and Formatting

  • Format and lint fix: pnpm run check

Project Structure

wiggle-music/
├── apps/
│   ├── web/         # Frontend application (React + TanStack Router)
│   └── server/      # Backend API (Hono, TRPC)
├── packages/
│   ├── ui/          # Shared shadcn/ui components and styles
│   ├── api/         # API layer / business logic
│   ├── auth/        # Authentication configuration & logic
│   └── db/          # Database schema & queries

Available Scripts

  • pnpm run dev: Start all applications in development mode
  • pnpm run build: Build all applications
  • pnpm run dev:web: Start only the web application
  • pnpm run dev:server: Start only the server
  • pnpm run check-types: Check TypeScript types across all apps
  • pnpm run db:push: Push schema changes to database
  • pnpm run db:generate: Generate database client/types
  • pnpm run db:migrate: Run database migrations
  • pnpm run db:studio: Open database studio UI
  • pnpm run check: Run Oxlint and Oxfmt