Skip to content

add 30 presets from issue #333 - Transitions Brightest Pixels First Organic (Batch 7/8)#359

Open
github-actions[bot] wants to merge 1 commit intomainfrom
presets/batch-333-1764360052458
Open

add 30 presets from issue #333 - Transitions Brightest Pixels First Organic (Batch 7/8)#359
github-actions[bot] wants to merge 1 commit intomainfrom
presets/batch-333-1764360052458

Conversation

@github-actions
Copy link
Contributor

@github-actions github-actions bot commented Nov 28, 2025

This PR was automatically generated from issue #333

✅ Generation Complete

Final Status: 0/30 presets successfully generated

⚠️ 30 preset(s) failed - see details below

❌ Failed Presets (30)

  1. Preset 1 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create a 'Luma Burn Dissolve' transition preset that dissolves the outgoing media by fading out the brightest pixels first, simulating a luminance-keyed burn effect. The transition should analyze the visual brightness and create an animated gradient map that progressively reveals the incoming media starting from the darkest areas of the outgoing frame. Use a 1.2-second overlap period where the outgoing media's opacity is driven by a custom filter animation (brightness + contrast shift from 1.0/1.0 to 2.5/0.3), causing highlights to 'burn out' first. The incoming media fades in with a complementary exposure ramp (brightness 0.5 to 1.0). Single BaseLayout container with absolute positioning, outgoing media at z-index 1, incoming media at z-index 2. BaseLayout duration = media1.duration + media2.duration - 1200ms overlap.

Technical Specifications:
BaseLayout: containerProps={{ className: 'absolute inset-0 overflow-hidden bg-black' }}, fitDurationTo='scenes'. Media atoms: absolute inset-0 positioning, object-fit cover. Outgoing VideoAtom/ImageAtom: generic effects with AnimationRange for filter (brightness(1) contrast(1) to brightness(2.5) contrast(0.3)) over final 1200ms, opacity 1 to 0 with easeInQuad. Incoming media: starts at (media1.duration - 1200ms), filter animation brightness(0.5) to brightness(1), opacity 0 to 1 with easeOutQuad. Provider mode with targetIds for each media atom. Duration calculation: totalDuration = scene1.duration + scene2.duration - 1200."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c74d5ae9afa7e-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:17 GMT',
'request-id': 'req_011CVatAB5DTZyoTpcJsxVAB',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '50',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatAB5DTZyoTpcJsxVAB"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 2 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Build a 'Highlight Cascade Fade' transition where the brightest pixels of the outgoing media dissolve in a cascading pattern from top to bottom, creating a luminance-driven waterfall effect. The transition uses exposure manipulation to progressively overexpose the outgoing media (brightness ramping from 1.0 to 3.0) while simultaneously applying a vertical gradient mask effect. The incoming media emerges with a contrast boost that settles to normal. 800ms overlap with staggered timing - brightness shift begins 200ms before opacity fade starts. Both media use blend mode 'screen' during the overlap to enhance the bright pixel interaction.

Technical Specifications:
BaseLayout: single container, fitDurationTo='scenes', containerProps={{ className: 'absolute inset-0 bg-black' }}. Outgoing media: generic effects - filter animation (brightness(1) to brightness(3)) from relativeStart (duration - 1000ms) over 800ms, opacity 1 to 0 delayed 200ms into filter animation, easeInExpo curve. Incoming media: relativeStart at (media1.duration - 800ms), initial brightness(1.5) contrast(1.3) animating to brightness(1) contrast(1), opacity 0 to 1. Both atoms: blendMode 'screen' during overlap. Z-index: outgoing 1, incoming 2. Provider mode targeting each atom ID."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c74d3cc6b8acf-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:17 GMT',
'request-id': 'req_011CVatA9n5aREjEe4G44nrg',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '54',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatA9n5aREjEe4G44nrg"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 3 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create an 'Exposure Gradient Map Wipe' transition that uses a horizontal gradient map to progressively reveal the incoming media based on luminance values. The outgoing media's exposure increases from left to right, causing bright areas to 'burn through' and reveal the underlying incoming media. Implement using a combination of brightness filter animation and opacity gradient simulation. 1.5-second overlap with the exposure shift creating a sweeping reveal effect. The incoming media starts slightly underexposed and normalizes as the wipe completes, maintaining visual continuity for YouTube content.

Technical Specifications:
BaseLayout: containerProps={{ className: 'absolute inset-0' }}, duration calculated as media1.duration + media2.duration - 1500ms. Outgoing media: positioned absolute inset-0, generic effects with filter animation brightness(1) to brightness(4) over 1500ms with easeInQuart, paired with opacity 1 to 0. Transform animation translateX(0%) to translateX(5%) for subtle drift. Incoming media: z-index 2, relativeStart at (media1.duration - 1500ms), filter brightness(0.7) contrast(0.9) to brightness(1) contrast(1), opacity 0 to 1 with easeOutCubic. Both use object-fit cover. Provider mode with distinct targetIds."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c74d52bbf25c3-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:17 GMT',
'request-id': 'req_011CVatAAit2oN5iZVFndCP5',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '25',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatAAit2oN5iZVFndCP5"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 4 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Design a 'Contrast Shift Dissolve' transition that manipulates contrast values to create a dramatic reveal effect. The outgoing media's contrast drops to near-zero (creating a flat, washed-out look) while brightness peaks, causing the image to essentially 'white out'. Simultaneously, the incoming media emerges from high contrast (punchy, dramatic) settling to normal values. This creates a YouTube-friendly energetic transition suitable for dynamic content. 1-second overlap with synchronized filter animations creating a push-pull effect between the two media items.

Technical Specifications:
BaseLayout: fitDurationTo='scenes', containerProps={{ className: 'absolute inset-0 bg-white' }}. Background white to enhance the white-out effect. Outgoing VideoAtom: generic effects filter(contrast(1) brightness(1)) to filter(contrast(0.1) brightness(2.5)) over 1000ms, opacity 1 to 0 with easeInQuad starting at 300ms into transition. Incoming media: relativeStart (media1.duration - 1000ms), filter contrast(1.8) brightness(0.8) to contrast(1) brightness(1), opacity 0 to 1 with easeOutQuad. Z-indexing: outgoing 1, incoming 2 with 3 for the final 500ms. Duration = scene1 + scene2 - 1000ms."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c74d29b0cfc54-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:17 GMT',
'request-id': 'req_011CVatA91CRzvEbG5sayzrj',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '18',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatA91CRzvEbG5sayzrj"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 5 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Build a 'Luminance Key Fade with Shake' transition that combines the luma-keyed dissolve effect with a subtle camera shake during the transition moment for added energy. The brightest pixels fade first using brightness manipulation, while both media items receive a synchronized shake effect (small translateX/Y oscillations) during the 600ms overlap. The shake intensity peaks at the midpoint of the transition and settles as the incoming media stabilizes. Perfect for YouTube vlogs and energetic content where transitions need punch.

Technical Specifications:
BaseLayout: containerProps={{ className: 'absolute inset-0 overflow-hidden' }}, duration = media1.duration + media2.duration - 600ms. Outgoing media: filter brightness(1) to brightness(2.2), opacity 1 to 0, transform includes shake keyframes - translateX(0) translateY(0) at 0%, translateX(-3px) translateY(2px) at 25%, translateX(4px) translateY(-2px) at 50%, translateX(-2px) translateY(3px) at 75%, translateX(0) translateY(0) at 100%. Incoming media: relativeStart (media1.duration - 600ms), same shake pattern, brightness(0.6) to brightness(1), opacity 0 to 1. Shake applied via transform AnimationRange with multiple keyframes. Provider mode with separate effect targeting."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c74d139e758f1-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:17 GMT',
'request-id': 'req_011CVatA839hHUU2YVhTPpih',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '19',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatA839hHUU2YVhTPpih"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 6 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create a 'Slow Burn Exposure Dissolve' transition designed for cinematic YouTube content with a longer, more contemplative transition period. The 2.5-second overlap creates a gradual luminance-based dissolve where the outgoing media's exposure slowly climbs (brightness 1.0 to 1.8) over the full duration, with opacity beginning its descent only in the final 1.5 seconds. The incoming media has a long fade-in with a subtle warm-to-neutral color temperature shift simulated through filter adjustments. Smooth easing curves (easeInOutSine) throughout for an elegant, film-like quality.

Technical Specifications:
BaseLayout: containerProps={{ className: 'absolute inset-0 bg-black' }}, fitDurationTo='scenes', totalDuration = media1.duration + media2.duration - 2500ms. Outgoing media: filter animation brightness(1) to brightness(1.8) over full 2500ms, opacity animation 1 to 0 starting at 1000ms into transition (1500ms duration), easeInOutSine. Incoming media: relativeStart (media1.duration - 2500ms), filter sepia(0.15) brightness(0.9) to sepia(0) brightness(1) for warm-to-neutral shift, opacity 0 to 1 over full 2500ms with easeInOutSine. Both absolute inset-0, object-fit cover. Z-index: outgoing 1, incoming 2."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c758aeb2625c3-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:46 GMT',
'request-id': 'req_011CVatCK6xspRiWiaTUvMvj',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '22',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatCK6xspRiWiaTUvMvj"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 7 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Design a 'Gradient Map Flash Transition' with a brief, intense brightness flash at the transition point. The outgoing media rapidly increases in brightness (1.0 to 4.0) over 300ms creating a flash effect, holds briefly, then the incoming media emerges from the flash with decreasing brightness (3.0 to 1.0). Total overlap of 500ms with the peak brightness occurring at the exact midpoint. This creates a punchy, high-energy transition ideal for YouTube gaming content, music videos, or action sequences. Opacity changes are secondary to the dramatic brightness manipulation.

Technical Specifications:
BaseLayout: containerProps={{ className: 'absolute inset-0 bg-white' }}, white background enhances flash. Duration = media1.duration + media2.duration - 500ms. Outgoing media: filter brightness(1) to brightness(4) over 300ms with easeInExpo, opacity 1 to 0 from 200ms-500ms. Incoming media: relativeStart (media1.duration - 500ms), filter brightness(3) to brightness(1) over 400ms starting at 100ms into its appearance, easeOutExpo, opacity 0 to 1 from 0-300ms with easeOutQuad. Z-index: both at same level (2) with opacity controlling visibility. Provider mode with synchronized timing."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c7586fda158f1-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:46 GMT',
'request-id': 'req_011CVatCGNWipSVXU5C3mYiS',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '17',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatCGNWipSVXU5C3mYiS"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 8 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Build a 'Multi-Stage Luma Dissolve' transition with three distinct phases: initial brightness ramp on outgoing (400ms), crossfade period with both visible (400ms), and incoming brightness normalization (400ms). Total 1.2-second transition with true crossfade in the middle third. The outgoing media's brightness increases from 1.0 to 2.0 in phase 1, then opacity fades 1.0 to 0 in phase 2. Incoming media's opacity goes 0 to 1 in phase 2, then brightness normalizes from 1.3 to 1.0 in phase 3. This staged approach creates a more controlled, professional-looking transition suitable for corporate YouTube content.

Technical Specifications:
BaseLayout: fitDurationTo='scenes', containerProps={{ className: 'absolute inset-0' }}, duration = media1.duration + media2.duration - 1200ms. Outgoing media: Phase 1 (0-400ms of overlap): filter brightness(1) to brightness(2), easeOutQuad. Phase 2 (400-800ms): opacity 1 to 0, easeInOutSine. Incoming media: relativeStart (media1.duration - 1200ms). Phase 2 (400-800ms of its visible time): opacity 0 to 1. Phase 3 (800-1200ms): filter brightness(1.3) to brightness(1), easeInOutSine. Use multiple AnimationRange entries for each phase. Provider mode with targetIds. Z-index: outgoing 1, incoming 2."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c75898c648acf-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:46 GMT',
'request-id': 'req_011CVatCJ6CD1hbqcxveZpEw',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '18',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatCJ6CD1hbqcxveZpEw"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 9 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create a 'Bloom Fade Dissolve' transition that simulates a lens bloom effect during the transition. The outgoing media's filter combines brightness increase with blur (brightness 1.0 to 2.2, blur 0px to 8px), creating a soft, glowing dissolution. The incoming media emerges sharp against the blooming outgoing image, with its own subtle brightness adjustment (0.85 to 1.0). 900ms overlap with the bloom peaking at 600ms, then settling. The blur creates depth separation between the two media items, making the incoming media pop. Ideal for beauty, lifestyle, and travel YouTube content.

Technical Specifications:
BaseLayout: containerProps={{ className: 'absolute inset-0 overflow-hidden' }}, duration = media1.duration + media2.duration - 900ms. Outgoing media: generic effects with compound filter animation - 'brightness(1) blur(0px)' to 'brightness(2.2) blur(8px)' over 900ms, opacity 1 to 0 starting at 300ms (600ms duration), easeInQuad for opacity. Incoming media: relativeStart (media1.duration - 900ms), filter brightness(0.85) to brightness(1) over 900ms, opacity 0 to 1 with easeOutCubic. Z-index: outgoing 1, incoming 2 (incoming always sharp above bloomy outgoing). Object-fit cover on both. Provider mode."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c758b9edbfa7e-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:46 GMT',
'request-id': 'req_011CVatCKZzg3gaG41hsNmi3',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '24',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatCKZzg3gaG41hsNmi3"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 10 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Design an 'Alternating Exposure Strobe' transition that creates a rhythmic strobe-like effect by rapidly alternating the exposure levels of both media during the overlap. The outgoing media pulses between brightness 1.0 and 2.5 three times while fading out, and the incoming media pulses inversely (2.5 to 1.0 pattern) while fading in. Total 800ms overlap with 4 strobe cycles (200ms each). This creates an energetic, music-video-style transition perfect for YouTube content with strong musical beats or high-energy editing. Synchronized to feel like flash cuts between scenes.

Technical Specifications:
BaseLayout: containerProps={{ className: 'absolute inset-0 bg-black' }}, duration = media1.duration + media2.duration - 800ms. Outgoing media: compound animation - brightness keyframes at 0%:1, 12.5%:2.5, 25%:1, 37.5%:2.5, 50%:1, 62.5%:2.5, 75%:1, 100%:2.5 (4 pulses), opacity 1 to 0 linear. Incoming media: relativeStart (media1.duration - 800ms), inverse brightness pattern starting at 2.5, ending at 1 with pulses, opacity 0 to 1 linear. Use AnimationRange with multiple percentage-based keyframes for strobe effect. Z-index: outgoing 1, incoming 2. Provider mode. Steps easing or linear for sharp strobe cuts."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c75897c6dfc54-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:01:46 GMT',
'request-id': 'req_011CVatCJ6hFwvcmmmJdWpeB',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '27',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatCJ6hFwvcmmmJdWpeB"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 11 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create a typokinetic preset that mimics a Highcharts streamgraph where each word from caption data forms an organic flowing layer. Words should appear as horizontal bands that undulate vertically like liquid streams, with their heights (volume) expanding and contracting based on word impact metadata. Stack 5-7 words vertically using flex layout, each word contained in a BaseLayout with clip-path: polygon() that morphs smoothly to create the streamgraph's characteristic organic curves. The animation timeline should show words entering from the left with zero height, swelling to full prominence at their timing peak, then gracefully tapering as new words flow in. Use custom CSS keyframes with cubic-bezier(0.4, 0, 0.2, 1) easing for the liquid organic motion feel. Each layer should have a subtle translateY oscillation (±5px) with staggered timing to create the flowing river effect. Color each layer with gradient backgrounds that shift hue over the timeline.

Technical Specifications:
Structure: Single BaseLayout container with 'flex flex-col w-full h-full relative overflow-hidden' containing multiple child BaseLayouts for each word stream layer. Each word layer uses TextAtom with effects array for translateY oscillation and scale transforms. Use generic effects with AnimationRange for clip-path morphing simulation via scaleY and translateY combinations. Timing: Each word's timing derived from caption data with 200ms overlap for smooth transitions. Effects: opacity 0→1→1→0.3, scaleY 0.1→1→0.8 with ease-in-out. Performance: Use transform-only animations, avoid clip-path animations in effects (simulate with scale). ContainerProps: Apply 'items-stretch justify-center' for vertical stacking. Consider internal effect preset for reusable 'stream-swell' animation pattern."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c763e5aa3fc54-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:15 GMT',
'request-id': 'req_011CVatERor8MMpxHMxfyCF2',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '47',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatERor8MMpxHMxfyCF2"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 12 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Design a streamgraph-inspired typography preset where caption words are rendered as SVG-like curved paths using creative CSS transforms. Each word appears on its own horizontal 'stream' that flows left-to-right across the viewport. The key visual is words that seem to ride on invisible waves - use translateY with sine-wave-like keyframe progressions (0→15→0→-15→0 pattern over timeline). Multiple word streams stack vertically with varying wave phases creating the characteristic streamgraph layered appearance. As each word's timing progresses, apply a 'volume swell' effect where fontSize scales from 80% to 120% and back, synchronized with the wave motion. Background shapes behind each word should use ShapeAtom rectangles with rounded corners and blur filters to create soft organic layer boundaries.

Technical Specifications:
Structure: BaseLayout root with 'relative w-full h-screen' containing 5-6 horizontal stream rows using 'absolute' positioning at different top percentages (10%, 25%, 40%, 55%, 70%, 85%). Each row is a BaseLayout with 'flex items-center w-full'. TextAtom for each word with effects: translateY using 5+ keyframe ranges for wave motion (0%:0, 25%:15, 50%:0, 75%:-15, 100%:0), fontSize scaling for volume effect. ShapeAtom behind each text with 'rounded-full' blur-sm styling, lower opacity (0.3-0.5). Timing: Words flow sequentially per row with 300ms stagger. Easing: spring for bouncy organic feel. Use repeatChildrenProps for consistent wave animation across all word containers. Performance: Batch transforms, use will-change on animated elements."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c763e0d0058f1-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:15 GMT',
'request-id': 'req_011CVatERahqUiTkAs5KDGwj',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '20',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatERahqUiTkAs5KDGwj"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 13 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Build a data-visualization-meets-typography preset that interprets the streamgraph concept as words emerging from and dissolving into liquid pools. The viewport is divided into horizontal bands, each representing a 'data stream'. Words rise up from the bottom of their band (like bubbles in liquid), reach peak visibility at center, then sink into the top of the band. Use opacity gradients combined with translateY and scaleX to create the illusion of words being part of a flowing, shape-shifting liquid mass. The 'organic liquid flow' aspect comes from applying slight skewX transforms that shift direction mid-animation, making words appear to bend with current. Layer multiple TextAtoms at different z-indices with varying blur amounts to create depth in the liquid layers.

Technical Specifications:
Structure: BaseLayout grid container with 'grid grid-rows-5 w-full h-full gap-0' for stream bands. Each band is BaseLayout with 'relative overflow-hidden flex items-center justify-center'. TextAtom per word with multi-phase effects: Phase 1 (0-30%): translateY 100→0, opacity 0→1, scaleX 0.5→1. Phase 2 (30-70%): stable with subtle skewX oscillation ±3deg. Phase 3 (70-100%): translateY 0→-100, opacity 1→0, scaleX 1→0.5. Add blurred duplicate TextAtoms behind main text (blur-md, opacity-30) for liquid depth. Timing: Use caption word timing with fitDurationTo: 'children'. Easing: ease-in-out for smooth liquid motion. ContainerProps.style for band background colors with low opacity gradients. Consider sub-preset for reusable 'liquid-word' animation module."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c7641098a25c3-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:15 GMT',
'request-id': 'req_011CVatETdyo48TwYgEFPijm',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '27',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatETdyo48TwYgEFPijm"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 14 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create an audio-reactive streamgraph typography preset where word layers respond to audio waveform data. Each word from captions occupies a horizontal stream band that pulses and flows based on audio intensity. Use waveform effects with bass sensitivity for lower stream bands and treble for upper bands, creating frequency-separated visual layers like a true streamgraph visualization. The 'shape-shifting' comes from scaleY transformations driven by audio - words compress and expand vertically as audio peaks hit. Combine this with continuous horizontal translateX drift to simulate the timeline progression of a streamgraph. Words should have soft glow effects that intensify with audio beats.

Technical Specifications:
Structure: BaseLayout with 'flex flex-col w-full h-full' containing 6 stream band BaseLayouts, each with 'flex-1 flex items-center overflow-hidden'. TextAtom per word within bands. Effects: Combine generic effects for base animations with waveform effects for audio reactivity. Waveform config: type 'scale', property 'bass' for bottom bands (sensitivity 1.5), 'treble' for top bands. Add waveform 'exposure' effect for glow intensification on beats. Generic effects: continuous translateX -100→100 over duration for timeline flow. TextAtom styling: 'text-4xl font-bold' with textShadow effect animated via waveform. AudioAtom required as audio source for waveform analysis. Timing: fitDurationTo audio source. Use internal effect preset for 'audio-glow-pulse' reusability. Performance: Limit waveform effect frequency updates to 30fps equivalent."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c763eafdb8acf-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:15 GMT',
'request-id': 'req_011CVatES1W3h4Lm2UKhYmsJ',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '22',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatES1W3h4Lm2UKhYmsJ"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 15 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Design a streamgraph preset with emphasis on the 'evolving volume changes' aspect. Words are displayed in a vertical stack where each word's visual weight (size, opacity, boldness) represents its 'volume' in the data stream metaphor. Use word metadata (impact score) from caption data to drive initial volume, then animate smooth transitions between words as timeline progresses. High-impact words swell dramatically with scale and bold weight, while low-impact words remain subtle streams. The organic flow comes from staggered ease-in-out animations with overlapping transition windows - as one word's volume decreases, the next increases, creating continuous flowing motion.

Technical Specifications:
Structure: BaseLayout with 'flex flex-col items-center justify-center w-full h-full gap-2 p-8'. Map caption words to TextAtom array, each wrapped in BaseLayout for individual effects. Effects per word: scale based on word.metadata.impact (0.5 + impact * 0.5 range), opacity curves 0→1→1→0 with timing offset per word. Use letterSpacing effect (tight→wide→tight) for breathing feel. Font weight simulation via textShadow intensity changes. Timing: Calculate each word's active window from caption timing, add 500ms overlap transitions between adjacent words. Easing: cubic-bezier(0.25, 0.46, 0.45, 0.94) for organic feel. ContainerProps: Background gradient that slowly shifts hue over timeline. Helper function to map impact scores to animation parameters. Use childrenProps for consistent text styling across all words."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c76418972fa7e-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:16 GMT',
'request-id': 'req_011CVatEU2nq9eMRovi9XDgj',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '76',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatEU2nq9eMRovi9XDgj"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 16 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Build a layered streamgraph typography preset using CSS blend modes to create the organic flowing appearance. Multiple TextAtom layers are stacked at the same position but with different colors, scales, and timing offsets. As words animate, these layers blend together creating rich, evolving color mixtures that mimic the layered streams of a streamgraph. The 'liquid' effect comes from applying different animation speeds to each layer - the bottom layer moves slowly (deep current), middle layers at medium speed, top layer fastest (surface flow). Use screen and overlay blend modes for luminous liquid appearance.

Technical Specifications:
Structure: BaseLayout with 'relative w-full h-full flex items-center justify-center' as container. For each caption word, create 3 stacked TextAtom instances in nested BaseLayout with 'absolute inset-0 flex items-center justify-center'. Layer 1: scale 1.1, blue tint, slowest timing (1.2x duration). Layer 2: scale 1.0, purple tint, normal timing. Layer 3: scale 0.9, pink tint, fastest timing (0.8x duration). Apply blend modes via containerProps.style: {mixBlendMode: 'screen'} for layers 2-3. Effects: Each layer has translateX wave motion with different phases, opacity fade curves. Use relative timing with parent to handle duration multipliers. Performance: Blend modes are GPU-accelerated, safe for animation. Tailwind: Use 'mix-blend-screen' or 'mix-blend-overlay' classes where available. Consider internal effect preset for 'blend-layer-float' pattern."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c76f35ec88acf-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:44 GMT',
'request-id': 'req_011CVatGZfBQKy3zYfU6b99F',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '51',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatGZfBQKy3zYfU6b99F"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 17 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create a minimalist streamgraph typography preset focusing on smooth curves through CSS transform interpolation. Display words along horizontal paths that curve up and down like streamgraph lines. Each word follows a bezier-like path using combined translateX and translateY keyframes with many intermediate steps to create smooth curves. The path curvature changes per word based on position in the sentence - early words curve upward (rising stream), middle words stay level (plateau), ending words curve downward (falling stream). This creates the characteristic streamgraph shape over the timeline. Keep visuals clean with monochrome text and subtle opacity variations.

Technical Specifications:
Structure: BaseLayout with 'relative w-full h-full bg-black' containing absolutely positioned TextAtom elements. Calculate word positions based on index in caption array - distribute horizontally across viewport width. Effects: Complex translateX/translateY keyframe sequences - for rising words: translateY starts at 20%, curves through 0% (peak), for falling words: starts at 0%, curves to 20%. Use 8-10 keyframe points for smooth bezier approximation. Example rising: 0%:50, 15%:35, 30%:20, 50%:10, 70%:5, 85%:3, 100%:0. Opacity: subtle 0.7→1→0.7 curve synchronized with vertical position. Font: 'Inter:300' for clean minimal aesthetic. Tailwind: 'text-white text-2xl tracking-wide'. Timing: Sequential word reveals with 200ms gaps. Easing: linear for keyframes (curve built into values), ease-out for opacity. Helper function to generate path keyframes based on word index and total count."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c76f2ae2e58f1-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:44 GMT',
'request-id': 'req_011CVatGZ9RpAwTcsS74pVLW',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '27',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatGZ9RpAwTcsS74pVLW"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 18 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Design an immersive full-screen streamgraph preset where words are treated as particles flowing through liquid layers. Words drift horizontally with varying speeds creating depth parallax. Front layer words (larger, faster) overlap back layer words (smaller, slower, blurred). The 'shape-shifting' manifests as words rotating slightly as they flow, as if caught in liquid currents. Use 3-4 depth layers with consistent motion direction but varying parameters. Words fade in from right edge, drift across, fade out at left edge. The overall effect should feel like looking into a flowing river with words as floating debris.

Technical Specifications:
Structure: BaseLayout with 'relative w-full h-full overflow-hidden bg-gradient-to-b from-slate-900 to-slate-800'. Create 4 layer BaseLayouts with 'absolute inset-0'. Distribute caption words across layers based on index % 4. Layer properties - Layer 0 (back): scale 0.6, opacity 0.4, blur-sm, translateX speed 0.5x. Layer 1: scale 0.75, opacity 0.6, translateX speed 0.75x. Layer 2: scale 0.9, opacity 0.8, translateX speed 1x. Layer 3 (front): scale 1.1, opacity 1, translateX speed 1.25x. Effects per word: translateX 110%→-10% (right to left flow), rotate oscillation ±5deg using sine pattern, opacity fade at edges. Timing: Stagger word start times within each layer by 400ms. Use fitDurationTo: 'scene' for consistent flow. ContainerProps.style for z-index layering. Tailwind: 'text-white font-light'. Consider sub-preset for 'parallax-layer' component."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c76f3fbb225c3-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:44 GMT',
'request-id': 'req_011CVatGa7UAd8prGwMyfkhb',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '19',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatGa7UAd8prGwMyfkhb"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 19 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Build a streamgraph preset with emphasis on timeline progression visualization. Display a horizontal timeline bar at the bottom showing overall progress. Above it, words stack and animate like a live-updating streamgraph - completed words compress into thin archived streams on the left, current word displays prominently in center, upcoming words appear as thin anticipatory streams on the right. This creates a dynamic visualization where the 'graph' builds over time. Use color coding: past words in cool blues, current word warm orange, future words in neutral grays. The organic flow comes from smooth width/opacity transitions as words move through states.

Technical Specifications:
Structure: BaseLayout with 'flex flex-col w-full h-full'. Timeline bar: BaseLayout with 'h-2 w-full bg-slate-700 mt-auto' containing progress indicator ShapeAtom. Word area: BaseLayout with 'flex-1 flex items-center justify-center relative'. For each word: BaseLayout with dynamic width - past words 'w-8', current 'w-auto px-8', future 'w-4'. TextAtom inside with opacity/scale effects. Effects: width transition simulation via scaleX (0.1 for compressed, 1 for active), opacity (0.5→1→0.5), backgroundColor transitions via style. Color scheme: past 'text-blue-400', current 'text-orange-400 text-4xl font-bold', future 'text-gray-500'. Timing: Use word timing from captions, calculate state (past/current/future) dynamically. Progress bar: effect with scaleX 0→1 over total duration. Tailwind: 'transition-all duration-500' concept via effect easing. Helper function to determine word state based on current time."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c76f4df2efa7e-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:44 GMT',
'request-id': 'req_011CVatGahSk5LdvV1LaTrVC',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '63',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatGahSk5LdvV1LaTrVC"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 20 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create a vertical streamgraph typography preset where words flow from top to bottom like a waterfall of data streams. Each word appears at the top, flows downward while undulating horizontally (the stream's lateral movement), and exits at bottom. Multiple words visible simultaneously at different vertical positions create the layered streamgraph appearance. The 'organic liquid' quality comes from applying perlin-noise-like horizontal oscillation - each word has unique oscillation frequency and amplitude based on its length or impact score. Use transparency and blur to show words at different depths in the liquid.

Technical Specifications:
Structure: BaseLayout with 'relative w-full h-full overflow-hidden' as viewport. Each caption word gets BaseLayout container with 'absolute' positioning. Distribute words across horizontal positions (left: 10%, 30%, 50%, 70%, 90%). Effects: translateY -20%→120% for top-to-bottom flow, translateX oscillation using multi-point keyframes (simulate noise: 0%:0, 20%:10, 40%:-15, 60%:8, 80%:-5, 100%:0 - vary per word). Opacity curve: 0→1 (first 15%), 1 (middle), 1→0 (last 15%). Scale: 0.8→1→0.8 curve for depth variation. Blur: words with lower impact get blur-sm effect. Timing: Calculate oscillation frequency from word.length (longer words = slower oscillation). Stagger word start times by caption timing. Easing: ease-in-out for vertical, linear for oscillation. Tailwind: 'text-white text-3xl font-medium drop-shadow-lg'. Use repeatChildrenProps for consistent base styling, individual effects for unique oscillation patterns."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c76f3389bfc54-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:02:44 GMT',
'request-id': 'req_011CVatGZcCpGV7fktJZFwHL',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '82',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatGZcCpGV7fktJZFwHL"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 21 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create a ZOOM CRASH DOLLY-IN transition preset for YouTube images with extreme fast-forward tunnel vision impact. The transition should feature the outgoing image rapidly scaling up from 100% to 300% while simultaneously applying an intense radial blur that increases from 0 to 20px, creating a tunnel vision effect. The incoming image enters already scaled at 150% and quickly snaps to 100% with a sharp deceleration ease. Use a very short overlap of 200-300ms for maximum impact. The outgoing image should have decreasing opacity from 100% to 0% during the scale-up, while incoming starts at 0% opacity and snaps to 100% at the midpoint. Add a subtle screen shake effect (translateX oscillation ±5px) during the transition peak for visceral impact. Both images use ImageAtom with objectFit 'cover' and absolute positioning within a single BaseLayout container.

Technical Specifications:
BaseLayout: duration = media1.duration + media2.duration - 0.25s overlap. Container: className='relative w-full h-full overflow-hidden'. Outgoing ImageAtom: absolute inset-0, z-index-10, generic effects with AnimationRange for scale [1,1] to [3,3] over 0-250ms with easeIn, opacity 1 to 0, filter blur(0px) to blur(20px). Incoming ImageAtom: absolute inset-0, z-index-20, starts at (media1.duration - 0.25s) relative, scale [1.5,1.5] to [1,1] with easeOutExpo over 250ms, opacity 0 to 1 with step function at 125ms. Shake effect: translateX keyframes [0, 5, -5, 3, -3, 0] over 200ms centered on overlap. Use provider mode with targetIds for each ImageAtom."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c77a8da8a8acf-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:13 GMT',
'request-id': 'req_011CVatJhnPrLBMnV6FsJhm7',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '25',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatJhnPrLBMnV6FsJhm7"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 22 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Build a RADIAL BLUR SPEED TUNNEL transition preset that simulates a camera dolly crash into the screen. The outgoing YouTube image should appear to rush toward the viewer with progressive radial blur emanating from center, scaling from 1x to 2.5x while blur increases exponentially. The incoming image emerges from the blur tunnel, starting extremely blurred (25px) and scaled at 0.5x, then rapidly sharpening and scaling to normal over 350ms. Use an aggressive easeInExpo for outgoing and easeOutBack for incoming to create the snap-back impact feel. The transition overlap should be 350ms with the outgoing image fading to 0% opacity in the last 150ms while incoming fades in from 0% over the first 200ms. Add a brightness flash effect that peaks at 150% during the transition midpoint for that cinematic impact moment.

Technical Specifications:
BaseLayout: duration = image1.duration + image2.duration - 0.35s. Container: className='relative w-full h-full bg-black overflow-hidden'. Outgoing ImageAtom: absolute inset-0, z-10, effects AnimationRange scale [1,1] to [2.5,2.5] 0-350ms easeInExpo, blur 0px to 25px same timing, opacity 1 to 0 from 200ms-350ms easeOut. Incoming ImageAtom: absolute inset-0, z-20, start time (image1.duration - 0.35s), scale [0.5,0.5] to [1,1] 0-350ms easeOutBack, blur 25px to 0px 0-300ms, opacity 0 to 1 0-200ms. Brightness filter: add to both, outgoing peaks 1 to 1.5 at 175ms then holds, incoming 1.5 to 1 from 175ms-350ms. Provider mode targeting both atoms."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c77a75d2bfc54-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:13 GMT',
'request-id': 'req_011CVatJgkP15tUaNjuBE3WK',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '28',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatJgkP15tUaNjuBE3WK"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 23 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Design a FAST DOLLY ZOOM VERTIGO transition preset inspired by the classic Hitchcock dolly zoom effect for YouTube thumbnail sequences. The outgoing image simultaneously scales up to 180% while applying a perspective transform that creates a depth distortion feeling. Use CSS perspective and translateZ to enhance the 3D rushing effect. The incoming image does the reverse - starting pushed back in Z-space and rushing forward while scaling down from 120% to 100%. Overlap duration of 400ms with a smooth cross-fade. Add motion blur simulation using a subtle horizontal blur (3px) that peaks at transition midpoint. The effect should feel like the background is rushing toward you while you're pulling back, creating disorientation and visual impact.

Technical Specifications:
BaseLayout: duration = img1.duration + img2.duration - 0.4s. Container: className='relative w-full h-full overflow-hidden' style={{perspective: '1000px', perspectiveOrigin: '50% 50%'}}. Outgoing ImageAtom: absolute inset-0, z-10, transform effects scale [1,1] to [1.8,1.8], translateZ 0px to 200px over 400ms easeInQuad, opacity 1 to 0 from 200ms-400ms. Incoming ImageAtom: absolute inset-0, z-20, start at (img1.duration - 0.4s), translateZ -300px to 0px, scale [1.2,1.2] to [1,1] over 400ms easeOutQuad, opacity 0 to 1 from 0-200ms. Motion blur: filter blur(0 3px) peaking at 200ms for both. Use easeInOutQuad for synchronized feel."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c77a70b9c58f1-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:13 GMT',
'request-id': 'req_011CVatJgegTLDsp3UBsjWt1',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '201',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatJgegTLDsp3UBsjWt1"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 24 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create an IMPACT CRASH ZOOM transition with violent screen shake for high-energy YouTube content. The outgoing image rapidly punches toward the viewer with scale 1x to 4x in just 200ms using easeInQuart, paired with increasing radial blur. At the exact moment of 'impact' (transition midpoint), trigger a sharp 150ms screen shake effect on the entire container with decreasing intensity. The incoming image appears instantly at the shake moment, already at full opacity but with residual motion blur that clears over 200ms. The shake pattern should be: translateX [0, 15, -12, 8, -5, 2, 0] and translateY [0, 8, -6, 4, -2, 1, 0] with rotation [-2deg, 1.5deg, -1deg, 0.5deg, 0deg]. Very short 250ms overlap for maximum punch.

Technical Specifications:
BaseLayout: duration = img1.duration + img2.duration - 0.25s. Container: className='relative w-full h-full overflow-hidden', container receives shake animation via wrapper. Outgoing ImageAtom: absolute inset-0, z-10, scale [1,1] to [4,4] 0-200ms easeInQuart, blur 0 to 30px, opacity 1 to 0 from 150ms-250ms. Incoming ImageAtom: absolute inset-0, z-20, start (img1.duration - 0.25s), opacity 0 to 1 step at 125ms (instant), blur 8px to 0px 125ms-250ms, scale [1.05,1.05] to [1,1] slight settle. Container shake: generic effect on BaseLayout translateX/Y/rotate keyframes from 125ms-275ms. Provider mode, shake effect targets container, blur/scale target atoms."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c77ac0946fa7e-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:14 GMT',
'request-id': 'req_011CVatJjzqefKXFLyMfqAAe',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '35',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatJjzqefKXFLyMfqAAe"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 25 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Build a TUNNEL VISION VIGNETTE ZOOM transition that creates a cinematic focus-pull crash effect. The outgoing image scales up with heavy vignette darkening from edges, simulating tunnel vision as if rushing through a corridor. Use radial gradient overlay that intensifies during transition, combined with 1x to 2x scale and 0 to 15px blur. The incoming image fades in from pure black center-point, with the vignette reversing (opening up from center). Overlap of 500ms for a more cinematic feel. Add subtle chromatic aberration simulation by slightly offsetting RGB channels (use multiple overlapping images with blend modes and slight position offsets in red/blue). The overall feel should be like consciousness fading and refocusing.

Technical Specifications:
BaseLayout: duration = img1.duration + img2.duration - 0.5s. Container: className='relative w-full h-full overflow-hidden bg-black'. Outgoing ImageAtom: absolute inset-0, z-10, scale [1,1] to [2,2] 0-500ms easeInQuad, blur 0-15px, opacity 1 to 0 300ms-500ms. Vignette overlay: ShapeAtom with radial gradient rgba(0,0,0,0) center to rgba(0,0,0,1) edges, opacity 0 to 1 over 0-400ms, z-15. Incoming ImageAtom: absolute inset-0, z-20, start (img1.duration - 0.5s), opacity 0 to 1 200ms-500ms easeOutQuad, scale [1.3,1.3] to [1,1], blur 10px to 0px. Chromatic: optional duplicate ImageAtom with mix-blend-mode screen, slight translateX offset, tinted. Provider mode for all effects."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c77aa3f1225c3-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:13 GMT',
'request-id': 'req_011CVatJijwHgQgigrzaGo7G',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '20',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatJijwHgQgigrzaGo7G"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 26 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Design a WHIP PAN SPEED BLUR transition that simulates an ultra-fast camera whip between YouTube images. The outgoing image should blur horizontally (motion blur effect with 40px horizontal, 0 vertical blur) while translating rapidly to the left (-150% translateX) over 300ms. Simultaneously, the incoming image enters from the right (+150% translateX) with matching horizontal blur, sweeping into frame and decelerating with blur clearing. Use easeInOutCubic for smooth acceleration/deceleration. The overlap should be 300ms with both images visible during the whip motion. Add a subtle brightness increase during peak motion (1.0 to 1.3 to 1.0) and slight vertical squeeze (scaleY 1 to 0.95 to 1) to enhance the speed feeling.

Technical Specifications:
BaseLayout: duration = img1.duration + img2.duration - 0.3s. Container: className='relative w-full h-full overflow-hidden'. Outgoing ImageAtom: absolute inset-0, z-10, translateX 0% to -150% 0-300ms easeInCubic, filter blur(0 0) to blur(40px 0) 0-150ms then blur(40px 0) 150-300ms, opacity 1 throughout until 250ms then to 0, scaleY [1, 0.95, 1]. Incoming ImageAtom: absolute inset-0, z-20, start (img1.duration - 0.3s), translateX 150% to 0% 0-300ms easeOutCubic, blur(40px 0) to blur(0 0) 150ms-300ms, opacity 0 to 1 step at 50ms. Brightness: both atoms 1.0 to 1.3 at 150ms to 1.0 at 300ms. Provider mode with separate targetIds."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c785fae7658f1-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:42 GMT',
'request-id': 'req_011CVatLroRSYDRrMoQsbFJg',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '23',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatLroRSYDRrMoQsbFJg"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 27 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create a ZOOM BURST EXPLOSION transition with radial speed lines effect for dynamic YouTube content. The outgoing image explodes outward with scale 1x to 3x and radial blur 0 to 25px, while animated radial speed lines (using multiple thin ShapeAtom rectangles or a Lottie animation) emanate from center, enhancing the burst feeling. The incoming image materializes from the center as a small point (scale 0.1) and rapidly expands to full size with easeOutBack overshoot. Very aggressive 200ms overlap. Add a white flash overlay (ShapeAtom with white fill, opacity 0 to 0.8 to 0) that peaks at the transition midpoint. The speed lines should rotate slightly during the burst for dynamic energy.

Technical Specifications:
BaseLayout: duration = img1.duration + img2.duration - 0.2s. Container: className='relative w-full h-full overflow-hidden bg-black'. Outgoing ImageAtom: absolute inset-0, z-10, scale [1,1] to [3,3] 0-200ms easeInQuad, blur 0-25px, opacity 1 to 0 100ms-200ms. Incoming ImageAtom: absolute inset-0, z-30, start (img1.duration - 0.2s), scale [0.1,0.1] to [1,1] 0-200ms easeOutBack with overshoot 1.1, opacity 0 to 1 step at 0ms. Flash overlay: ShapeAtom z-25, fill white, absolute inset-0, opacity [0, 0.8, 0] keyframes at [0ms, 100ms, 200ms]. Speed lines: LottieAtom or multiple ShapeAtoms z-20, radial pattern, scale/rotate animation 0-200ms. Provider mode."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c78601a068acf-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:42 GMT',
'request-id': 'req_011CVatLs9kwQUqmmNuPLM7R',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '44',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatLs9kwQUqmmNuPLM7R"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 28 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Build a GLITCH CRASH ZOOM transition combining digital glitch artifacts with aggressive zoom for tech/gaming YouTube content. The outgoing image rapidly zooms (1x to 2.5x) while glitch effects activate: RGB split (simulated with three offset image copies), horizontal slice displacement, and brief static noise overlay. The incoming image assembles from glitched state, starting with heavy RGB separation and slice artifacts that resolve to clean image. Use very short 250ms overlap with harsh, non-eased timing (linear or step functions) for that digital breaking feel. Add scanline overlay and occasional horizontal offset jumps (translateX jumping between -10px, 0, 10px randomly).

Technical Specifications:
BaseLayout: duration = img1.duration + img2.duration - 0.25s. Container: className='relative w-full h-full overflow-hidden bg-black'. Outgoing ImageAtom: absolute inset-0, z-10, scale [1,1] to [2.5,2.5] 0-250ms linear, opacity 1 to 0 from 200ms-250ms. RGB split simulation: two additional ImageAtom copies at z-11, z-12 with mix-blend-mode screen/multiply, translateX offsets [-5px, +5px] increasing during transition, tinted via filter hue-rotate. Glitch slices: clipPath animations on segments. Incoming ImageAtom: z-20, start (img1.duration - 0.25s), scale [1.2,1.2] to [1,1], starts with RGB split copies that converge to 0 offset. Scanlines: ShapeAtom overlay with repeating linear gradient. TranslateX: step keyframes [0, 10, -8, 5, 0] at random intervals. Provider mode."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c78605e7e25c3-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:42 GMT',
'request-id': 'req_011CVatLsPeSKCNqLPaLQ5nX',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '26',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatLsPeSKCNqLPaLQ5nX"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 29 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Design a HYPERDRIVE WARP SPEED transition inspired by sci-fi jump-to-lightspeed effects for YouTube space/gaming content. The outgoing image stretches vertically and horizontally from center (scaleX 1 to 3, scaleY 1 to 0.3 creating streak effect) while applying heavy motion blur and increasing brightness to white-out. Star streak overlays (thin white ShapeAtom lines) extend from center. The incoming image emerges from the warp tunnel, initially as a bright point that expands with reverse stretch animation (scaleY 3 to 1, scaleX 0.3 to 1). 400ms overlap for the full hyperspace jump feel. Add chromatic aberration and lens flare effect at peak moment.

Technical Specifications:
BaseLayout: duration = img1.duration + img2.duration - 0.4s. Container: className='relative w-full h-full overflow-hidden bg-black'. Outgoing ImageAtom: absolute inset-0, z-10, scaleX [1] to [3], scaleY [1] to [0.3] creating horizontal stretch, 0-400ms easeInExpo, blur 0 to 30px, brightness 1 to 3 (white-out), opacity 1 to 0 from 300ms-400ms. Star streaks: multiple ShapeAtom thin rectangles z-15, white fill, scale from center [1,1] to [10, 1] creating outward lines. Incoming ImageAtom: z-20, start (img1.duration - 0.4s), reverse warp scaleX [0.3] to [1], scaleY [3] to [1] with easeOutExpo, brightness 3 to 1 over 0-300ms, blur 20px to 0. Lens flare: positioned ShapeAtom or LottieAtom at center, opacity peak at 200ms. Provider mode."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c785faf14fc54-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:42 GMT',
'request-id': 'req_011CVatLrqex1PdgBM2szC4m',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '19',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatLrqex1PdgBM2szC4m"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry
  1. Preset 30 - Command failed: npx tsx "/home/runner/work/mediamake/mediamake/apps/mediamake/scripts/generate-preset.ts" "Create a PUNCH-IN IMPACT ZOOM with shockwave ripple effect for explosive YouTube transitions. The outgoing image zooms in aggressively (1x to 3x) with radial blur while a circular shockwave ripple emanates from center (expanding ring using ShapeAtom with border-only styling, scaling from 0 to 200%). At impact peak, the entire frame shakes violently for 100ms. The incoming image slams into view at full scale with a subtle bounce settle (scale 1.05 to 0.98 to 1). Multiple shockwave rings with staggered timing create layered impact effect. Add dust particle overlay and screen crack effect (ShapeAtom with crack pattern) that appears briefly at impact. 300ms overlap with the impact precisely at 150ms mark.

Technical Specifications:
BaseLayout: duration = img1.duration + img2.duration - 0.3s. Container: className='relative w-full h-full overflow-hidden'. Outgoing ImageAtom: absolute inset-0, z-10, scale [1,1] to [3,3] 0-300ms easeInQuart, radial blur 0-20px, opacity 1 to 0 200ms-300ms. Shockwave rings: 3x ShapeAtom circles z-25, border-2 border-white rounded-full, positioned center, scale [0,0] to [3,3] staggered at 100ms, 150ms, 200ms starts, opacity 1 to 0. Incoming ImageAtom: z-20, start (img1.duration - 0.3s), opacity step to 1 at 150ms, scale [1.05,1.05] at 150ms to [0.98,0.98] at 220ms to [1,1] at 300ms easeOutElastic. Screen shake: container translateX/Y/rotate keyframes 150ms-250ms. Crack overlay: ShapeAtom z-30 with crack SVG path, opacity 0 to 0.8 to 0 around 150ms. Provider mode."

═══════════════════════════════════════════════════════════════
❌ PRESET GENERATION FAILED
═══════════════════════════════════════════════════════════════
APICallError [AI_APICallError]: Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.
at (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/response-handler.ts:57:16)
at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
at async postToApi (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/node_modules/@ai-sdk/provider-utils/src/post-to-api.ts:118:28)
at async AnthropicMessagesLanguageModel.doGenerate (/home/runner/work/mediamake/mediamake/node_modules/@ai-sdk/anthropic/src/anthropic-messages-language-model.ts:470:9)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:357:30)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async _retryWithExponentialBackoff (/home/runner/work/mediamake/mediamake/node_modules/ai/src/util/retry-with-exponential-backoff.ts:96:12)
at async fn (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:328:32)
at async (/home/runner/work/mediamake/mediamake/node_modules/ai/src/telemetry/record-span.ts:18:22)
at async generateObject (/home/runner/work/mediamake/mediamake/node_modules/ai/src/generate-object/generate-object.ts:282:12) {
cause: undefined,
url: 'https://api.anthropic.com/v1/messages',
requestBodyValues: {
model: 'claude-sonnet-4-5',
max_tokens: 64000,
temperature: undefined,
top_k: undefined,
top_p: undefined,
stop_sequences: undefined,
system: undefined,
messages: [ [Object] ],
tools: [ [Object] ],
tool_choice: { type: 'tool', name: 'json', disable_parallel_tool_use: true }
},
statusCode: 400,
responseHeaders: {
'anthropic-organization-id': 'da777878-4d25-4f8d-bdf4-13c228122e17',
'cf-cache-status': 'DYNAMIC',
'cf-ray': '9a5c7860ba99fa7e-SJC',
connection: 'keep-alive',
'content-length': '234',
'content-type': 'application/json',
date: 'Fri, 28 Nov 2025 20:03:42 GMT',
'request-id': 'req_011CVatLsZZoFpEFt2Evsw2k',
server: 'cloudflare',
'strict-transport-security': 'max-age=31536000; includeSubDomains; preload',
'x-envoy-upstream-service-time': '24',
'x-robots-tag': 'none',
'x-should-retry': 'false'
},
responseBody: '{"type":"error","error":{"type":"invalid_request_error","message":"Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits."},"request_id":"req_011CVatLsZZoFpEFt2Evsw2k"}',
isRetryable: false,
data: {
type: 'error',
error: {
type: 'invalid_request_error',
message: 'Your credit balance is too low to access the Anthropic API. Please go to Plans & Billing to upgrade or purchase credits.'
}
},
[Symbol(vercel.ai.error)]: true,
[Symbol(vercel.ai.error.AI_APICallError)]: true
}

  • Failed after 1 retry

Closes #333

@vercel
Copy link

vercel bot commented Nov 28, 2025

Deployment failed with the following error:

Resource is limited - try again in 4 hours (more than 100, code: "api-deployments-free-per-day").

Learn More: https://vercel.com/karcreativeworks-projects?upgradeToPro=build-rate-limit

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

New Presets - Transitions Brightest Pixels First Organic (Batch 7/8)

0 participants