name: slide description: Use this skill as reference material when creating or editing presentation slide decks.
Slides Skill
Use this skill as reference material when creating or editing presentation slide decks.
Skill Folder Contents
Contents of the slides/ skill folder:
container_tools/: Standalone python scripts for slides and relevant asset manipulation.artifact_tool/: API documentation and coding examples for the artifact tool library.pptxgenjs_helpers/: JavaScript helpers for PptxGenJS.diagram_renderers/: Opinionated reusable diagram/chart renderers built on top of the helper bundle.slide_templates/: Optional slide templates to use; seeslide_templates/Overview.pngto get started.
Implementation
You MUST use PptxGenJS to implement the slide deck. Even when the user provides a template (or you use a built-in one), you MUST still generate the deck with PptxGenJS and adhere to the template’s visual style, typography, spacing, color palette, and layout conventions. The only exception is for trivial quick-edit requests, where you may use python-pptx or artifact_tool.
We also provide OpenAI-specific helper scripts under pptxgenjs_helpers/ to make it easier to use the upstream open-source library. Import and use these helpers; do not copy-paste their code into your deliverable source files.
Work in your own working directory while coding. Only copy artifacts to the requested locations after you finish building and validating the slides.
Container Tools
ensure_raster_image.py: Ensure images are rasterized; convert to PNG if needed; quick usage--input_files <img_path1> ....render_slides.py: render a PowerPoint file into a folder of PNG slides using default sizing; quick usage:<input.pptx>. Output files are namedslide-1.png,slide-2.png, ... in a directory with the same name as the input file.create_montage.py: build a tiled montage from images in a directory (for viewing multiple image assets or rendered slides at once); quick usage:--input_dir <imgs_dir> --output_file <montage.png>. It supports most image formats with auto conversion under the hood.slides_test.py: detect content overflowing the original slide canvas; usage:<input.pptx>.
Run each script with -h to view detailed usage info.
Demo screenshots
For high-resolution browser demo screenshots, use:
agent-browser --headed open http://127.0.0.1:3000 && agent-browser set viewport 2560 1440 && agent-browser wait --load networkidle && agent-browser screenshot --full artifacts/slide-demo.png
Helpers API
Version: 1.2.0 (from pptxgenjs_helpers/index.js)
- autoFontSize: Approximate a font size that fits text into a fixed box.
- Usage:
slide.addText(textOrRuns, autoFontSize(textOrRuns, fontFace, { x, y, w, h, fontSize?, minFontSize?, maxFontSize?, mode? }))
- Usage:
- calcTextBox: Measure text into a box and return
addTextoptions for a given font size.- Usage:
slide.addText(textOrRuns, calcTextBox(fontSizePt, { text: textOrRuns, w, fontFace, ...opts }))
- Usage:
- calcTextBoxHeightSimple: Estimate text-box height from font size and line count.
- Usage:
const h = calcTextBoxHeightSimple(fontSizePt, numLines, leading?, padding?)
- Usage:
- imageSizingCrop: Place an image by center-cropping to fill a target box. Accepts a filesystem
pathordata(data URI, raw SVG string, or Buffer), and likewise for the APIs below that takepathOrData- Usage:
slide.addImage({ path|data, ...imageSizingCrop(pathOrData, x, y, w, h) })
- Usage:
- imageSizingContain: Place an image fully visible within a target box, preserving aspect.
- Usage:
slide.addImage({ path|data, ...imageSizingContain(pathOrData, x, y, w, h) })
- Usage:
- svgToDataUri: Convert a sanitized SVG string to a data URI for
addImage.- Usage:
slide.addImage({ data: svgToDataUri(svgString), x, y, w, h })
- Usage:
- latexToSvgDataUri: Render LaTeX as SVG and return a data URI for vector text.
- Usage:
slide.addImage({ data: latexToSvgDataUri(texString), x, y, w })
- Usage:
- getImageDimensions: Return
{ width, height, aspectRatio, type }for a file path or data.- Usage:
const { aspectRatio } = getImageDimensions(pathOrData)
- Usage:
- safeOuterShadow: Return a safe outer shadow config that avoids invalid DrawingML.
- Usage:
slide.addText(text, { shadow: safeOuterShadow(), ... })
- Usage:
- codeToRuns: Convert source code into rich text runs for syntax-highlighted
addText.- Usage:
slide.addText(codeToRuns(code, lang), { x, y, w, h })
- Usage:
- warnIfSlideHasOverlaps: Log warnings when elements overlap on a slide.
- Usage:
warnIfSlideHasOverlaps(slide, pptx)
- Usage:
- warnIfSlideElementsOutOfBounds: Warn when elements are outside or touching slide bounds.
- Usage:
warnIfSlideElementsOutOfBounds(slide, pptx)
- Usage:
- alignSlideElements: Align selected elements to edges or centers.
- Usage:
alignSlideElements(slide, indices, "left"|"right"|"top"|"bottom"|"hcenter"|"vcenter")
- Usage:
- distributeSlideElements: Evenly space selected elements horizontally/vertically.
- Usage:
distributeSlideElements(slide, indices, "horizontal"|"vertical")
- Usage:
- diagramRendererRegistry / renderDiagramSlide: Registry and entrypoint for the built-in diagram pack.
- Usage:
const { renderDiagramSlide } = require(".../pptxgenjs_helpers"); renderDiagramSlide(slide, pptx, "process-flow", data)
- Usage:
Built-in diagram pack
diagram_renderers/ currently includes 7 reusable diagram types. Each type has a stable renderer kind and a corresponding visual pattern:
lean-value-tree: lean value tree / value hierarchy diagramprocess-flow: staged process flow diagramproject-plan: project plan timeline / gantt-like plan viewrisk-matrix: probability-impact risk matrixplanning-onion: agile planning onion diagramtesting-approach: testing approach / delivery workflow diagramintegrated-design: integrated design / layered ecosystem diagram
These diagram renderers are reference patterns rebuilt for this repository. Treat them as reusable composition examples, not as third-party branded templates. When adapting them for deliverables, use the local project palette and neutral/source-accurate footer and notes content.
Page size
- Set the page size to 16:9 (13 1/3 × 7.5 inches, PptxGenJS
LAYOUT_WIDE) by default, unless a different aspect ratio is explicitly required. For example, if the user uploads a 4:3 slide image and asks you to recreate it, set the page size to 4:3 (not 16:9). If you are not defining the page size, derive the page size usinggetSlideDimensions. Prefer(7.5 / 9) * 16over13.33for exact computation.
Visuals
- When using
addImage, avoid the built-insizingargument due to known bugs. - Instead, use these helpers for image placement:
- Crop (default):
imageSizingCropenlarges and center-crops to fit most images. Adjust crop parameters as needed if the subject is not centered in the frame. - Contain:
imageSizingContainkeeps important images (e.g., plots or text) fully visible. - Stretch: for textures or backgrounds, call
addImagedirectly without the helpers.
- Crop (default):
- Note: The helpers compute safe sizing/crop values; do not add a separate
sizingfield alongside them. - Inputs: helpers accept filesystem paths, data URIs, raw SVG strings, or Buffers. For remote images, download or data‑URI encode first.
- Mirroring (left–right flip): pass
flipH: truetoaddImage({ ..., flipH: true }).
Slide layout helpers
Strive for strong spatial consistency and balance. Use these helpers to detect and correct layout issues:
warnIfSlideHasOverlaps(slide, pptx): Detects overlapping elements; cropped images use the viewport; diagonal-line false positives filtered; no “pass” logs.warnIfSlideElementsOutOfBounds(slide, pptx): Flags items outside the canvas; uses EMU→inch conversion and throws if slide size is unknown.alignSlideElements(slide, indices, alignment): Precisely align selected elements (left/right/top/bottom/centers) to enforce tidy columns/rows for shapes (text boxes, images, icons).distributeSlideElements(slide, indices, direction): Evenly space elements horizontally or vertically to maintain consistent gaps and rhythm across a row/column.
You MUST fix ALL severe text overlap errors, ALL unintended overlap warnings, and ALL unintended elements out of bounds warnings before you deliver the slides!
- Establish consistent margins and a simple grid early; prefer equal spacing between peer elements.
- After each major placement pass, re-run the diagnostics above and adjust until clean.
Web search
- After downloading an image file, use
fileto verify that it downloaded successfully and is an image. - Note that thumbnails in the image search preview are center-cropped. If the downloaded image doesn't have the desired aspect ratio (e.g., you need a wide area to cover but got a tall image), try another image.
Citations
Include [Sources] blocks in the speaker notes for every externally sourced asset and every externally sourced non-trivial claim.