name: gallery description: Create photo galleries with AI-assisted layout curation. Orchestrates atomic scripts and sub-agents. Use when user wants to create a gallery from photos, mentions "/gallery", or asks about photo layout and sequencing.
Gallery Workflow
Composed skill that creates photo galleries by orchestrating atomic scripts and sub-agents.
Philosophy
This skill applies principles from masters of photo sequencing and curation:
- Keith Smith — Group/Series/Sequence taxonomy; the gallery as a unified experience
- Jörg Colberg — Ruthless editing; visual rhythm; pacing
- John Szarkowski — The Five Characteristics for image assessment
"The individual pages have to give up their independence in order to form a union." — Keith Smith
For detailed principles, see docs/photo-layout-principles.md.
Usage
/gallery {folder} "{title}" {slug}
Example: /gallery cabo-2025 "CABO 2025" cabo
Important: All paths are relative to the current project directory. The {folder} argument is a path within the project (e.g., ./photos/cabo-2025 or just cabo-2025). Do NOT search the filesystem for folders — assume the user's folder exists in the current working directory.
Gallery Modes
Before starting, identify the gallery's organizational mode:
| Mode | Definition | Implication |
|---|---|---|
| Series | Chronological journey (default) | Respect timestamp order; adjust only within temporal clusters |
| Group | Thematic collection | Order is flexible; optimize for visual rhythm |
| Sequence | Strict order with meaning | Order is sacred; only adjust layout, not arrangement |
Most travel/event galleries are Series.
Architecture
Atomic Scripts (reusable):
├── init-gallery-manifest.ts Create manifest from EXIF
├── merge-gallery-batches.ts Combine batch files
├── validate-gallery-manifest.ts Fix common errors
└── generate-gallery-files.ts Generate .astro pages
Sub-Agent Skill:
└── review-image-batch AI reviews images → batch-NN.json
Workflow
Phase 1: Initialize
bun scripts/init-gallery-manifest.ts {folder} "{title}" {slug}
Creates:
src/data/gallery-manifests/{folder}.json(images array, empty blocks)/tmp/gallery-batches/{folder}/(clean directory for batch files)
Phase 2: Batch Review
Spawn sub-agents to review images. Each writes to its own file (parallel-safe).
For batchIndex in 0..ceil(imageCount/8):
Task(
subagent_type: "general-purpose",
description: "Review gallery batch {batchIndex}",
prompt: <see below>
)
Sub-agent prompt template:
Review batch {batchIndex} for {folder} gallery.
Read:
- Manifest: src/data/gallery-manifests/{folder}.json
- Layout guide: {plugin_base_dir}/skills/review-image-batch/references/layout-guide.md
(The plugin base directory is provided in the skill invocation header)
Images to review: indices {startImage} to {endImage}
(Calculate: startImage = batchIndex * 8, endImage = min(startImage + 7, totalImages - 1))
Workflow:
1. Read manifest to get image filenames
2. Read layout guide for rules
3. View each image file with Read tool
4. Create layout blocks using your visual judgment
5. Write JSON to: /tmp/gallery-batches/{folder}/batch-{NN}.json
where NN = batchIndex padded to 2 digits (00, 01, 02...)
6. Return TEXT SUMMARY ONLY
Output file format:
{
"batchIndex": {batchIndex},
"startImage": {startImage},
"endImage": {endImage},
"blocks": [
{ "layout": "WideImage", "images": ["DSCF1234.jpeg"], "props": {}, "notes": "..." }
]
}
LAYOUT PHILOSOPHY:
Apply visual judgment, not mechanical rules. A gallery needs rhythm and variety.
Single-image (WideImage, OffsetImage, InsetImage, FullBleed):
- Strong standalones, portraits, quiet moments
Multi-image (TwoUp, ThreeUp):
- Use when juxtaposition creates meaning beyond either image alone
- Apply Lyons's test: Temporal? Spatial? Formal echo? Emotional pairing? Transformation?
- A good TwoUp is BETTER than two mediocre WideImages
- A true sequence (entering→through→emerging) deserves ThreeUp
Spacer: Add breathing room after powerful images
Chapter: Insert at location/theme changes
Parallel execution: Sub-agents can run in parallel since each writes to its own file.
Phase 3: Merge & Validate
After all batches complete:
bun scripts/merge-gallery-batches.ts {folder}
bun scripts/validate-gallery-manifest.ts src/data/gallery-manifests/{folder}.json
This combines all batch files and validates the result.
Phase 4: Global Arc Review (NEW)
Before generating, review the merged manifest for overall coherence:
- Count hero moments — If >4 FullBleeds, demote some to WideImage
- Check multi-image limits — Max 2-3 TwoUp, 1-2 ThreeUp across entire gallery
- Verify rhythm — No consecutive high-weight blocks
- Identify the climax — One clear emotional peak, not many
- Working backwards — Does the final image provide satisfying closure?
Phase 5: Generate
bun scripts/generate-gallery-files.ts {folder}
Creates:
src/data/{folder}.ts(data file with chapters)src/pages/photographing/{slug}/index.astro- Additional
.astrofiles for each chapter (if multi-chapter)
Resume Protocol
If interrupted, check /tmp/gallery-batches/{folder}/ for existing batch files:
ls /tmp/gallery-batches/{folder}/
Only run missing batches, then merge.
Layout Philosophy
A gallery needs rhythm and variety — loud moments, quiet moments, pairings that create meaning.
| Layout | Purpose |
|---|---|
| WideImage | Strong standalone landscapes |
| OffsetImage | Portraits, quiet moments, breathing room |
| FullBleed | Hero shots, climactic moments |
| InsetImage | Intimate details, visual whispers |
| Spacer | Pacing, section breaks |
| TwoUp | Images that speak to each other |
| ThreeUp | True sequences (entering→through→emerging) |
| SplitLayout | Asymmetric pairs, one frames the other |
| Chapter | Location/theme breaks |
Lyons's Juxtaposition Test
Pair images when juxtaposition creates meaning beyond either image alone:
- Temporal — Same moment, different angles
- Spatial — Same scene, complementary views
- Formal echo — Compositional rhyme (lines, shapes, colors)
- Emotional — Contrast or reinforcement
- Transformation — Together they say something neither says alone
A strong TwoUp is better than two mediocre WideImages.
Output
When complete:
- Gallery URL:
/photographing/{slug}/ - Files:
src/data/gallery-manifests/{folder}.jsonsrc/data/{folder}.tssrc/pages/photographing/{slug}/*.astro
Composability
Each piece is reusable:
# Just extract EXIF
bun scripts/init-gallery-manifest.ts photos "Photos" photos
# Just merge existing batches
bun scripts/merge-gallery-batches.ts photos
# Just regenerate pages from manifest
bun scripts/generate-gallery-files.ts photos
# Validate any manifest
bun scripts/validate-gallery-manifest.ts src/data/gallery-manifests/photos.json