Claude-skill-registry automating-pages
Automates Apple Pages using JXA with AppleScript dictionary discovery. Use when asked to "automate Pages documents", "create documents programmatically", "JXA Pages scripting", or "export Pages to PDF". Covers documents, templates, text, styles, export, tables, images, and AppleScript bridge fallbacks.
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/automating-pages" ~/.claude/skills/majiayu000-claude-skill-registry-automating-pages && rm -rf "$T"
manifest:
skills/data/automating-pages/SKILL.mdsource content
Automating Pages (JXA-first, AppleScript discovery)
Relationship to the macOS automation skill
- Standalone for Pages, aligned with
patterns.automating-mac-apps - Use
for permissions, shell, and UI scripting guidance.automating-mac-apps - PyXA Installation: To use PyXA examples in this skill, see the installation instructions in
skill (PyXA Installation section).automating-mac-apps
Core framing
- Pages dictionary is AppleScript-first; discover there.
- JXA provides the logic and data handling.
- Objects are specifiers: References to Pages elements that require methods for reads (e.g.,
) and assignments for writes (e.g.,doc.body.text()
).doc.body.text = 'new text'
Example: Create Document
const pages = Application('Pages'); const doc = pages.Document({templateName: 'Blank'}); pages.documents.push(doc); doc.body.text = "Hello World";
Workflow (default)
- Discover: Open Script Editor > File > Open Dictionary > Pages.
- Prototype: Write minimal AppleScript to verify the command works.
- Port to JXA: Convert AppleScript syntax to JXA objects.
- Example:
becomesmake new document
.pages.documents.push(pages.Document()) - Add error handling (try/catch blocks).
- Example:
- Optimize: Use batch text operations when possible to avoid performance penalties.
- Fallback: Use AppleScript bridge or UI scripting for dictionary gaps (e.g., specific layout changes).
Image Insertion (Critical Difference from Keynote)
IMPORTANT: Pages does NOT support direct image insertion like Keynote does:
// THIS WORKS IN KEYNOTE: Keynote.Image({ file: Path("/path/to/image.png"), position: {x: 100, y: 100} }); // THIS DOES NOT WORK IN PAGES! Pages.Image({ file: Path("/path/to/image.png") }); // ❌ Will fail
Solution: Use ObjC Pasteboard bridging (see
pages-advanced.md for details):
ObjC.import('AppKit'); const nsImage = $.NSImage.alloc.initWithContentsOfFile("/path/to/image.png"); const pb = $.NSPasteboard.generalPasteboard; pb.clearContents; pb.setDataForType(nsImage.TIFFRepresentation, $.NSPasteboardTypeTIFF); // Then use System Events to paste (Cmd+V)
Example Script: See
automating-pages/scripts/insert_images.js for a complete working example.
Common Pitfalls
- Image insertion: Pages lacks a native
constructor unlike Keynote. Use ObjC Pasteboard method.Image - Dictionary gaps: Some features (like sophisticated layout adjustments) aren't in the dictionary. Use the AppleScript bridge or UI scripting.
- Permissions: Ensure 'Accessibility' settings are enabled for UI scripting.
- Saving: Always use
with a valid path object.doc.save({in: file_path})
Validation Checklist
- Document opens without errors
- Text insertion and formatting succeeds
- Save operations complete with valid path objects
- Template application works if used
- Export to target format produces valid output (PDF, Word)
- Error handling covers missing files and permissions
When Not to Use
- Cross-platform document automation (use python-docx or pandoc)
- AppleScript alone suffices (skip JXA complexity)
- Web-based documents (Google Docs API)
- Non-macOS platforms
- Complex page layout requiring manual design tools
What to load
Level 1: Basics
- JXA Pages basics:
(Core objects and document lifecycle)automating-pages/references/pages-basics.md
Level 2: Recipes & Common Tasks
- Recipes (templates, export, text):
(Standard operations)automating-pages/references/pages-recipes.md - Export options matrix:
(PDF, Word, ePub formats)automating-pages/references/pages-export-matrix.md - Template strategy:
(Managing custom templates)automating-pages/references/pages-template-strategy.md
Level 3: Advanced
- Advanced patterns (tables, images, AppleScript bridge):
(Complex integrations)automating-pages/references/pages-advanced.md - UI scripting patterns:
(Fallbacks)automating-pages/references/pages-ui-scripting.md - Dictionary translation table:
(AppleScript to JXA mapping)automating-pages/references/pages-dictionary.md - PyXA (Python) alternative:
automating-pages/references/pages-pyxa.md
Example Scripts
- Image insertion:
(ObjC Pasteboard method for inserting images)automating-pages/scripts/insert_images.js