Notre avis
Convertit des diapositives HTML en fichiers PowerPoint (PPTX) et permet d'éditer des présentations existantes ou de générer des vignettes.
Points forts
- Conversion directe de HTML en PPTX avec conservation de la mise en page 16:9.
- Prise en charge des graphiques, formes et images dans les diapositives.
- Génération de vignettes pour un aperçu visuel rapide.
- Outils de validation et de manipulation du format OOXML pour les utilisateurs avancés.
Limites
- Nécessite une demande explicite et une validation manuelle des diapositives avant conversion.
- Les codes couleur doivent être fournis sans '#' sous peine de corruption du fichier.
- La conversion ne gère pas les animations complexes ou les mises en page non standard.
Utilisez cette compétence lorsque vous devez générer automatiquement une présentation PowerPoint à partir de diapositives HTML structurées.
Évitez de l'utiliser si vous avez besoin d'animations avancées, de transitions personnalisées ou d'un contrôle pixel‑parfait sur le design.
Analyse de sécurité
PrudenceThe skill runs Node.js and Python scripts to convert HTML to PPTX, which is a legitimate use case but involves powerful tools that could be exploited if the input HTML is malicious. No exfiltration or destruction commands are present, but caution is warranted.
- •Skill executes external scripts (html2pptx.js, thumbnail.py, pack.py, validate.py) that could process user-provided HTML, potentially leading to code execution or SSRF if the HTML contains malicious content.
- •Uses Playwright browser rendering which may expose system resources.
Exemples
Convert the HTML slides in the 'slides' folder to a PowerPoint presentation named 'presentation.pptx'.Generate thumbnail images for my 'presentation.pptx' file with 4 columns and outline placeholders.Unpack the existing 'presentation.pptx' into a directory, add a new slide with a bar chart showing sales data, then repack it.name: pptx-skill description: Convert HTML slides to PowerPoint (PPTX) files. Use when PPTX generation, editing, or thumbnail creation is needed.
PPTX Skill - PowerPoint Conversion
Converts HTML slides into PowerPoint presentation files.
Feature Overview
1. New Presentation (HTML -> PPTX)
Convert HTML slide files to PowerPoint
2. Edit Existing Presentation
Modify contents of a PPTX file
3. Thumbnail Generation
Generate preview images of a presentation
Prerequisites (Stage 3)
This skill is Stage 3. It executes only when ALL of the following conditions are met:
- Explicit user request required: Only run when the user explicitly requests PPTX conversion ("convert to PPTX", "make a PowerPoint", etc.).
- HTML slides reviewed: All HTML slides must have been reviewed and approved by the user in
viewer.html. - No automatic execution: Do not automatically start PPTX conversion just because slide generation is complete.
If prerequisites are not met, guide the user to review slides in <slides-dir>/viewer.html first (default: slides/viewer.html).
Core Workflow
HTML -> PPTX Conversion
-
Prepare HTML slides
- Verify HTML files exist in selected
--slides-dir(default:slides/) - Validate each file is 720pt x 405pt (16:9) specification
- Verify HTML files exist in selected
-
Run html2pptx.js
slides-grab convert --slides-dir <path> --output presentation.pptx- Script-level alternative:
node .claude/skills/pptx-skill/scripts/html2pptx.js -
Verify results
- Check generated PPTX file
- Visual verification via thumbnail
Script Usage
html2pptx.js
Convert HTML files to PPTX
import { html2pptx } from './.claude/skills/pptx-skill/scripts/html2pptx.js';
import PptxGenJS from 'pptxgenjs';
const pres = new PptxGenJS();
pres.layout = 'LAYOUT_WIDE'; // 16:9
// Convert each slide
await html2pptx('<slides-dir>/slide-01.html', pres);
await html2pptx('<slides-dir>/slide-02.html', pres);
// Save
await pres.writeFile({ fileName: 'presentation.pptx' });
thumbnail.py
Generate presentation thumbnail grid
python .claude/skills/pptx-skill/scripts/thumbnail.py presentation.pptx output-thumbnail
Options:
--cols N: Number of columns (default 5, range 3-6)--outline-placeholders: Show placeholder regions
pack.py / unpack.py
PPTX file packaging/unpackaging
# Unpack
python .claude/skills/pptx-skill/ooxml/scripts/unpack.py presentation.pptx output_dir
# Pack
python .claude/skills/pptx-skill/ooxml/scripts/pack.py input_dir presentation.pptx
validate.py
PPTX structure validation
python .claude/skills/pptx-skill/ooxml/scripts/validate.py unpacked_dir --original presentation.pptx
Reference Documents
- html2pptx.md - HTML to PPTX conversion detailed guide
- ooxml.md - Office Open XML technical reference
PptxGenJS Key Rules
Color Codes
// Correct - without #
{ color: 'FF0000' }
// Wrong - causes file corruption
{ color: '#FF0000' }
Adding Slides
const slide = pres.addSlide();
// Add text
slide.addText('Title', {
x: 0.5,
y: 0.5,
w: 9,
h: 1,
fontSize: 36,
color: '1a1a2e',
bold: true
});
// Add image
slide.addImage({
path: 'image.png',
x: 1,
y: 2,
w: 4,
h: 3
});
// Add shape
slide.addShape(pres.ShapeType.rect, {
x: 0.5,
y: 1,
w: 3,
h: 2,
fill: { color: '1e3a5f' }
});
Adding Charts
// Bar chart
slide.addChart(pres.ChartType.bar, [
{
name: 'Series 1',
labels: ['A', 'B', 'C'],
values: [10, 20, 30]
}
], {
x: 1,
y: 2,
w: 8,
h: 4
});
// Pie chart
slide.addChart(pres.ChartType.pie, [...], {...});
// Line chart
slide.addChart(pres.ChartType.line, [...], {...});
Full Conversion Process
+-------------------+
| HTML Slides |
| <slides-dir>/*.html |
+---------+---------+
|
v
+-------------------+
| html2pptx.js |
| (Playwright + |
| PptxGenJS) |
+---------+---------+
|
v
+-------------------+
| PPTX File |
| presentation.pptx |
+---------+---------+
|
v
+-------------------+
| thumbnail.py |
| (Preview) |
+-------------------+
Dependencies
Node.js
- pptxgenjs: PowerPoint generation
- playwright: Browser rendering
- sharp: Image processing
Python
- markitdown: Markdown conversion
- defusedxml: XML parsing
- pillow: Image processing
System
- LibreOffice: PDF/image conversion (soffice)
- Poppler: PDF to image (pdftoppm)
Important Notes
- Color codes: No
#prefix in PptxGenJS - Fonts: Web-safe fonts only
- Text: Only p, h1-h6, ul, ol tags are converted
- Gradients: Replace CSS gradients with images
- Validation: Always verify with thumbnails after conversion
Priorisation de Tâches
Productivite
Priorise vos tâches avec les frameworks Eisenhower, ICE et RICE.
Generateur de Rapport Hebdomadaire
Productivite
Generez des rapports de statut hebdomadaires structures et concis.
Rapport de Daily Standup
Productivite
Génère des rapports de daily standup structurés et concis.