diff --git a/.claude/settings.local.json b/.claude/settings.local.json index 013d11a..dea6ada 100644 --- a/.claude/settings.local.json +++ b/.claude/settings.local.json @@ -1,4 +1,11 @@ { + "permissions": { + "allow": [ + "Skill(shadcn)", + "Bash(npm run *)", + "Bash(node -e \"const d = require\\('date-fns'\\); console.log\\(typeof d.eachDayOfInterval, typeof d.eachWeekOfInterval, typeof d.eachMonthOfInterval, typeof d.startOfMonth\\)\")" + ] + }, "enabledMcpjsonServers": [ "langfuse-docs", "langfuse", diff --git a/.claude/skills/remotion-best-practices/SKILL.md b/.claude/skills/remotion-best-practices/SKILL.md deleted file mode 100644 index 3e07cb2..0000000 --- a/.claude/skills/remotion-best-practices/SKILL.md +++ /dev/null @@ -1,95 +0,0 @@ ---- -name: remotion-best-practices -description: Best practices for Remotion - Video creation in React -metadata: - tags: remotion, video, react, animation, composition ---- - -## When to use - -Use this skills whenever you are dealing with Remotion code to obtain the domain-specific knowledge. - -## New project setup - -When in an empty folder or workspace with no existing Remotion project, scaffold one using: - -```bash -npx create-video@latest --yes --blank --no-tailwind my-video -``` - -Replace `my-video` with a suitable project name. - -## Starting preview - -Stsrt the Remotion Studio to preview a video: - -```bash -npx remotion studio -``` - -## Optional: one-frame render check - -You can render a single frame with the CLI to sanity-check layout, colors, or timing. -Skip it for trivial edits, pure refactors, or when you already have enough confidence from Studio or prior renders. - -```bash -npx remotion still [composition-id] --scale=0.25 --frame=30 -``` - -At 30 fps, `--frame=30` is the one-second mark (`--frame` is zero-based). - -## Captions - -When dealing with captions or subtitles, load the [./rules/subtitles.md](./rules/subtitles.md) file for more information. - -## Using FFmpeg - -For some video operations, such as trimming videos or detecting silence, FFmpeg should be used. Load the [./rules/ffmpeg.md](./rules/ffmpeg.md) file for more information. - -## Silence detection - -When needing to detect and trim silent segments from video or audio files, load the [./rules/silence-detection.md](./rules/silence-detection.md) file. - -## Audio visualization - -When needing to visualize audio (spectrum bars, waveforms, bass-reactive effects), load the [./rules/audio-visualization.md](./rules/audio-visualization.md) file for more information. - -## Sound effects - -When needing to use sound effects, load the [./rules/sfx.md](./rules/sfx.md) file for more information. - -## How to use - -Read individual rule files for detailed explanations and code examples: - -- [rules/3d.md](rules/3d.md) - 3D content in Remotion using Three.js and React Three Fiber -- [rules/animations.md](rules/animations.md) - Fundamental animation skills for Remotion -- [rules/assets.md](rules/assets.md) - Importing images, videos, audio, and fonts into Remotion -- [rules/audio.md](rules/audio.md) - Using audio and sound in Remotion - importing, trimming, volume, speed, pitch -- [rules/calculate-metadata.md](rules/calculate-metadata.md) - Dynamically set composition duration, dimensions, and props -- [rules/can-decode.md](rules/can-decode.md) - Check if a video can be decoded by the browser using Mediabunny -- [rules/charts.md](rules/charts.md) - Chart and data visualization patterns for Remotion (bar, pie, line, stock charts) -- [rules/compositions.md](rules/compositions.md) - Defining compositions, stills, folders, default props and dynamic metadata -- [rules/extract-frames.md](rules/extract-frames.md) - Extract frames from videos at specific timestamps using Mediabunny -- [rules/fonts.md](rules/fonts.md) - Loading Google Fonts and local fonts in Remotion -- [rules/get-audio-duration.md](rules/get-audio-duration.md) - Getting the duration of an audio file in seconds with Mediabunny -- [rules/get-video-dimensions.md](rules/get-video-dimensions.md) - Getting the width and height of a video file with Mediabunny -- [rules/get-video-duration.md](rules/get-video-duration.md) - Getting the duration of a video file in seconds with Mediabunny -- [rules/gifs.md](rules/gifs.md) - Displaying GIFs synchronized with Remotion's timeline -- [rules/images.md](rules/images.md) - Embedding images in Remotion using the Img component -- [rules/light-leaks.md](rules/light-leaks.md) - Light leak overlay effects using @remotion/light-leaks -- [rules/lottie.md](rules/lottie.md) - Embedding Lottie animations in Remotion -- [rules/measuring-dom-nodes.md](rules/measuring-dom-nodes.md) - Measuring DOM element dimensions in Remotion -- [rules/measuring-text.md](rules/measuring-text.md) - Measuring text dimensions, fitting text to containers, and checking overflow -- [rules/sequencing.md](rules/sequencing.md) - Sequencing patterns for Remotion - delay, trim, limit duration of items -- [rules/tailwind.md](rules/tailwind.md) - Using TailwindCSS in Remotion -- [rules/text-animations.md](rules/text-animations.md) - Typography and text animation patterns for Remotion -- [rules/timing.md](rules/timing.md) - Timing with interpolate and Bézier easing, springs -- [rules/transitions.md](rules/transitions.md) - Scene transition patterns for Remotion -- [rules/transparent-videos.md](rules/transparent-videos.md) - Rendering out a video with transparency -- [rules/trimming.md](rules/trimming.md) - Trimming patterns for Remotion - cut the beginning or end of animations -- [rules/videos.md](rules/videos.md) - Embedding videos in Remotion - trimming, volume, speed, looping, pitch -- [rules/parameters.md](rules/parameters.md) - Make a video parametrizable by adding a Zod schema -- [rules/maps.md](rules/maps.md) - Add a map using Mapbox and animate it -- [rules/silence-detection.md](rules/silence-detection.md) - Adaptive silence detection using FFmpeg loudnorm and silencedetect -- [rules/voiceover.md](rules/voiceover.md) - Adding AI-generated voiceover to Remotion compositions using ElevenLabs TTS diff --git a/.claude/skills/remotion-best-practices/rules/3d.md b/.claude/skills/remotion-best-practices/rules/3d.md deleted file mode 100644 index c9d254f..0000000 --- a/.claude/skills/remotion-best-practices/rules/3d.md +++ /dev/null @@ -1,86 +0,0 @@ ---- -name: 3d -description: 3D content in Remotion using Three.js and React Three Fiber. -metadata: - tags: 3d, three, threejs ---- - -# Using Three.js and React Three Fiber in Remotion - -Follow React Three Fiber and Three.js best practices. -Only the following Remotion-specific rules need to be followed: - -## Prerequisites - -First, the `@remotion/three` package needs to be installed. -If it is not, use the following command: - -```bash -npx remotion add @remotion/three # If project uses npm -bunx remotion add @remotion/three # If project uses bun -yarn remotion add @remotion/three # If project uses yarn -pnpm exec remotion add @remotion/three # If project uses pnpm -``` - -## Using ThreeCanvas - -You MUST wrap 3D content in `` and include proper lighting. -`` MUST have a `width` and `height` prop. - -```tsx -import { ThreeCanvas } from "@remotion/three"; -import { useVideoConfig } from "remotion"; - -const { width, height } = useVideoConfig(); - - - - - - - - -; -``` - -## No animations not driven by `useCurrentFrame()` - -Shaders, models etc MUST NOT animate by themselves. -No animations are allowed unless they are driven by `useCurrentFrame()`. -Otherwise, it will cause flickering during rendering. - -Using `useFrame()` from `@react-three/fiber` is forbidden. - -## Animate using `useCurrentFrame()` - -Use `useCurrentFrame()` to perform animations. - -```tsx -const frame = useCurrentFrame(); -const rotationY = frame * 0.02; - - - - -; -``` - -## Using `` inside `` - -The `layout` prop of any `` inside a `` must be set to `none`. - -```tsx -import { Sequence } from "remotion"; -import { ThreeCanvas } from "@remotion/three"; - -const { width, height } = useVideoConfig(); - - - - - - - - -; -``` diff --git a/.claude/skills/remotion-best-practices/rules/animations.md b/.claude/skills/remotion-best-practices/rules/animations.md deleted file mode 100644 index 4a02e55..0000000 --- a/.claude/skills/remotion-best-practices/rules/animations.md +++ /dev/null @@ -1,31 +0,0 @@ ---- -name: animations -description: Fundamental animation skills for Remotion -metadata: - tags: animations, transitions, frames, useCurrentFrame ---- - -All animations MUST be driven by the `useCurrentFrame()` hook. -Write animations in seconds and multiply them by the `fps` value from `useVideoConfig()`. - -For eased motion, prefer `interpolate` with explicit frame ranges and an easing—especially `Easing.bezier`, which matches CSS `cubic-bezier` so timing can be shared with web specs and curve editors. See [timing](./timing.md). - -```tsx -import { useCurrentFrame, Easing } from "remotion"; - -export const FadeIn = () => { - const frame = useCurrentFrame(); - const { fps } = useVideoConfig(); - - const opacity = interpolate(frame, [0, 2 * fps], [0, 1], { - extrapolateRight: "clamp", - extrapolateLeft: "clamp", - easing: Easing.bezier(0.16, 1, 0.3, 1), - }); - - return
Hello World!
; -}; -``` - -CSS transitions or animations are FORBIDDEN - they will not render correctly. -Tailwind animation class names are FORBIDDEN - they will not render correctly. diff --git a/.claude/skills/remotion-best-practices/rules/assets.md b/.claude/skills/remotion-best-practices/rules/assets.md deleted file mode 100644 index a5d4015..0000000 --- a/.claude/skills/remotion-best-practices/rules/assets.md +++ /dev/null @@ -1,78 +0,0 @@ ---- -name: assets -description: Importing images, videos, audio, and fonts into Remotion -metadata: - tags: assets, staticFile, images, fonts, public ---- - -# Importing assets in Remotion - -## The public folder - -Place assets in the `public/` folder at your project root. - -## Using staticFile() - -You MUST use `staticFile()` to reference files from the `public/` folder: - -```tsx -import { Img, staticFile } from "remotion"; - -export const MyComposition = () => { - return ; -}; -``` - -The function returns an encoded URL that works correctly when deploying to subdirectories. - -## Using with components - -**Images:** - -```tsx -import { Img, staticFile } from "remotion"; - -; -``` - -**Videos:** - -```tsx -import { Video } from "@remotion/media"; -import { staticFile } from "remotion"; - -