ln-150-presentation-creator
π―Skillfrom levnikolaevich/claude-code-skills
Generates interactive HTML presentations with 6 tabs from project documentation, creating a professional, navigable web view for sharing project details.
Part of
levnikolaevich/claude-code-skills(85 items)
Installation
node build-presentation.jsSkill Details
Builds interactive HTML presentation with 6 tabs (Overview, Requirements, Architecture/C4, Tech Spec, Roadmap, Guides). Creates presentation/README.md hub. L2 Worker under ln-100-documents-pipeline.
Overview
# HTML Presentation Builder
This skill creates an interactive, self-contained HTML presentation from existing project documentation. It transforms Markdown documents into a professional, navigable web presentation with diagrams, collapsible sections, and modern UI.
When to Use This Skill
This skill is a L2 WORKER invoked by ln-100-documents-pipeline orchestrator OR used standalone.
Use this skill when:
- Building HTML presentation from existing documentation
- Rebuilding presentation after documentation updates
- Creating standalone presentation for sharing (no full documentation setup needed)
- Validating that source documentation is ready for presentation generation
Part of workflow: ln-100-documents-pipeline β ln-110-project-docs-coordinator β ln-120-reference-docs-creator β ln-130-tasks-docs-creator β ln-140-test-docs-creator (optional) β ln-150-presentation-creator
Prerequisites: Existing documentation in docs/ directory with required files:
docs/project/requirements.md(REQUIRED)docs/project/architecture.md(REQUIRED)docs/project/tech_stack.md(REQUIRED)
Optional files (enhance presentation but not blocking):
docs/project/api_spec.md,database_schema.md,design_guidelines.md,runbook.mddocs/reference/adrs/*.md(ADRs with Category: Strategic|Technical)docs/reference/guides/*.md(How-to guides)docs/tasks/kanban_board.md(Epic Story Counters for Roadmap)
How It Works
The skill follows a 7-phase workflow: READ DOCS β VALIDATE SOURCE EXISTS β VALIDATE SOURCE QUALITY β CREATE DIR β COPY TEMPLATES β INJECT CONTENT β BUILD HTML.
Phase 1: READ DOCS - Load all project documentation from docs/
Phase 2: VALIDATE SOURCE EXISTS - Check required files exist (requirements.md, architecture.md, tech_stack.md), warn if optional missing
Phase 3: VALIDATE SOURCE QUALITY - Check diagrams, placeholders, content length (read-only validation)
Phase 4: CREATE DIR - Create presentation/ directory + README.md navigation hub
Phase 5: COPY TEMPLATES - Copy HTML/CSS/JS templates to assets/
Phase 6: INJECT CONTENT - Parse MD docs β replace placeholders in tab files β delete example blocks
Phase 7: BUILD HTML - Assemble modular components into standalone presentation_final.html
---
Phase 1: Read Documentation
Objective: Load all project documentation for transformation.
When to execute: Always (first phase)
Process:
- Use docs/ as source:
- Read documentation from docs/project/, docs/reference/, docs/tasks/ directories
- Standard locations created by ln-114, ln-112, ln-113
- Read Core MD Documents:
- project/requirements.md - Functional Requirements
- project/architecture.md - Architecture design, C4 diagrams
- project/tech_stack.md - Technology versions, Docker configuration
- project/api_spec.md - API endpoints, authentication (if exists)
- project/database_schema.md - Database schema, ER diagrams (if exists)
- project/design_guidelines.md - UI/UX design system (if exists)
- project/runbook.md - Operational procedures (if exists)
- Read ADRs (if exist):
- reference/adrs/adr-001-.md through adr-NNN-.md
- Parse ADR metadata (status, date, title, Category: Strategic|Technical)
- Read Guides (if exist):
- reference/guides/*.md - How-to guides for Guides tab
- Read Kanban Board (if exists):
- tasks/kanban_board.md - Epic Story Counters table for Roadmap progress
- Extract metadata:
- Project name, date, version from documents
- Preserve Mermaid diagram blocks
Output: Loaded documentation data ready for validation and HTML generation
---
Phase 2: Validate Source Documentation Exists
Objective: Verify that required source documentation exists before building presentation. Prevent building incomplete presentations.
When to execute: After Phase 1 (documentation loaded)
Process:
2.1 Check required files
REQUIRED (must exist - block execution if missing):
- β
docs/project/requirements.md - β
docs/project/architecture.md - β
docs/project/tech_stack.md
For each required file:
- Use Glob tool:
pattern: "docs/project/{filename}" - If NOT found:
- Add to missing list
- If found:
- Check file size > 100 bytes (not empty)
If ANY required file missing or empty:
```
β ERROR: Cannot build presentation - missing required documentation:
- docs/project/requirements.md [missing/empty]
- docs/project/architecture.md [missing/empty]
Suggestion: Run ln-111-project-docs-creator to create missing files.
STOP execution.
```
2.2 Check optional files
OPTIONAL (enhance presentation - warn if missing but continue):
- β οΈ
docs/project/api_spec.md(for backend projects) - β οΈ
docs/project/database_schema.md(for projects with database) - β οΈ
docs/project/design_guidelines.md(for frontend projects) - β οΈ
docs/project/runbook.md(for operational projects)
For each optional file:
- Use Glob tool:
pattern: "docs/project/{filename}" - If NOT found:
- Add to optional missing list
If optional files missing:
```
β WARN: Optional files missing: [list]
Presentation will have reduced content in some tabs.
Continue execution.
```
2.3 Check optional directories
OPTIONAL directories:
docs/reference/adrs/- check if any ADR files exist (adrs/*.md)docs/reference/guides/- check if any guide files exist (guides/*.md)docs/tasks/kanban_board.md- check for Roadmap data
For each directory:
- Use Glob tool to find files
- If empty/missing:
- Log: βΉ Optional directory empty: {directory} - related tab will show placeholder
2.4 Report validation summary
Log summary:
```
β Source documentation validation completed:
Required files:
- β requirements.md (found, 8.5 KB)
- β architecture.md (found, 15.2 KB)
- β tech_stack.md (found, 3.1 KB)
Optional files:
- β οΈ api_spec.md (missing - Technical Spec tab will have reduced content)
- β database_schema.md (found, 4.7 KB)
- β οΈ design_guidelines.md (missing)
Optional directories:
- β adrs/ (5 ADR files found)
- β οΈ guides/ (empty - Guides tab will show placeholder)
- β kanban_board.md (found - Roadmap will show progress)
```
Output: Validation passed (all required files exist) OR error (stop execution)
---
Phase 3: Validate Source Content Quality
Objective: Verify source docs contain sufficient content. Warn about incomplete content but don't block execution.
When to execute: After Phase 2 (source files exist)
Checks performed (warnings only, non-blocking):
- Mermaid diagrams: architecture.md must have β₯1 diagram, database_schema.md must have ER diagram
- Placeholders: Detect
{{PLACEHOLDER}},[Add your ...],TODO:patterns - Content length: requirements.md >500 words, architecture.md >1000 words, tech_stack.md >200 words
Auto-fix: None - ln-115 is read-only. Run ln-111-project-docs-creator to fix issues.
Output: Content quality report with warnings
π Detailed workflow: See [references/phases_detailed.md](references/phases_detailed.md#phase-3-validate-source-content-quality)
---
Phase 4: Create Presentation Directory & README
Objective: Setup presentation directory structure and navigation hub.
When to execute: After Phase 3 (source validation complete, warnings logged)
Process:
- Create presentation directory:
```bash
mkdir -p docs/presentation/
```
- Check if presentation/README.md exists:
- Use Glob tool: pattern: "docs/presentation/README.md"
- If file exists:
- Skip creation
- Log: β docs/presentation/README.md already exists (preserved)
- Proceed to Phase 5
- If NOT exists:
- Continue to step 3
- Create presentation/README.md from template:
- Copy template: references/presentation_readme_template.md β docs/presentation/README.md
- Replace placeholders:
- {{PROJECT_NAME}} β from requirements.md
- {{LAST_UPDATED}} β current date (YYYY-MM-DD)
- Content structure:
- Purpose: What is this presentation
- Quick Navigation: Links to presentation_final.html and assets/
- Customization Guide: How to edit source files in assets/
- Build Instructions: How to rebuild after changes
- Maintenance: When to rebuild, verification checklist
- Notify user:
- If created: β Created docs/presentation/README.md (navigation hub)
- If skipped: β docs/presentation/README.md already exists (preserved)
Output: docs/presentation/README.md (created or existing)
---
Phase 5: Copy Templates to Project
Objective: Copy HTML/CSS/JS templates from skill references/ to presentation directory.
When to execute: After Phase 4 (presentation directory exists)
Process:
- Check if assets exist:
- Use Glob tool: pattern: "docs/presentation/assets/"
- If docs/presentation/assets/ exists:
- Skip copying (user may have customized files)
- Log: β Presentation assets already exist - preserving user customizations
- Proceed to Phase 6
- If NOT exists:
- Continue to step 2
- Copy template files:
```bash
cp references/presentation_template.html β docs/presentation/assets/
cp references/styles.css β docs/presentation/assets/
cp references/scripts.js β docs/presentation/assets/
cp references/build-presentation.js β docs/presentation/assets/
cp -r references/tabs/ β docs/presentation/assets/tabs/
```
- Verify copied structure:
```
docs/presentation/assets/
βββ presentation_template.html # Base HTML5 + 6 tab navigation
βββ styles.css # ~400-500 lines
βββ scripts.js # Tab switching + Mermaid init
βββ build-presentation.js # Node.js build script
βββ tabs/
βββ tab_overview.html # Landing page
βββ tab_requirements.html # FRs + ADRs
βββ tab_architecture.html # C4 diagrams
βββ tab_technical_spec.html # API + Data + Deployment
βββ tab_roadmap.html # Epic list
βββ tab_guides.html # How-to guides
```
Output: Template files copied to docs/presentation/assets/ (or skipped if already exist)
Note: Templates contain placeholders ({{VARIABLE_NAME}}) that will be replaced in Phase 6.
---
Phase 6: Content Injection & Example Cleanup
Objective: Parse MD docs, inject into HTML templates, remove example blocks.
When to execute: After Phase 5 (templates exist in assets/)
Process:
- Parse MD docs (10 sources): requirements, architecture, tech_stack, api_spec, database_schema, design_guidelines, runbook, adrs/.md, kanban_board, guides/.md
- Inject content: Replace
{{PLACEHOLDER}}in 6 tab files with parsed content - Delete examples: Remove
...blocks from all tabs
Tab placeholders: Overview (5), Requirements (4 + NFR ban), Architecture (5), Technical Spec (4), Roadmap (3), Guides (6)
Validation: No example markers, no hardcoded e-commerce data, only project-specific content
Output: Clean, project-specific tab files ready for build
π Placeholder reference & example transformation: See [references/phases_detailed.md](references/phases_detailed.md#phase-6-content-injection--example-cleanup)
---
Phase 7: Build Final Presentation
Objective: Assemble modular components into standalone HTML file.
When to execute: After Phase 6 (content injected, examples deleted)
Process:
- Check if presentation_final.html exists (Auto-rebuild for automation):
- Use Glob tool: pattern: "docs/presentation/presentation_final.html"
- If file exists:
- β Auto-rebuild (generated file, safe operation)
- Log: βΉ Rebuilding presentation_final.html (generated file, safe to rebuild)
- Continue to step 2
- If NOT exists:
- Log: Creating presentation_final.html
- Continue to step 2
Why auto-rebuild:
- presentation_final.html is a generated file (source of truth: assets/ directory)
- Rebuilding is safe - no data loss (source files preserved in assets/)
- Maintains fully automatic workflow when invoked by ln-110-documents-pipeline
- User customizations in assets/ are preserved (only final HTML is regenerated)
- Navigate to presentation assets directory:
```bash
cd docs/presentation/assets/
```
- Run build script:
```bash
node build-presentation.js
```
- Build Script Process:
- Step 1: Read presentation_template.html
- Step 2: Read and inline styles.css β tag
- Step 3: Read and inline scripts.js β tag
- Step 4: Read all 6 tab files β inject into empty - Step 5: Replace {{PLACEHOLDERS}} with actual values - Step 6: Write - Check file size (~120-150 KB expected) - Verify Mermaid diagrams syntax is valid - Log: - If rebuilt (file existed): - If created (file NOT existed): - Remind: Output: docs/presentation/presentation_final.html (self-contained, ~120-150 KB, no external dependencies except Mermaid.js CDN) β οΈ Important Note: ---../presentation_final.htmlβ Build completed successfullyβ Rebuilt docs/presentation/presentation_final.html (~120-150 KB)β Created docs/presentation/presentation_final.html (~120-150 KB)Test in browser: Double-click to open, or use http-serverpresentation_final.html is a generated file built from modular source files in assets/.presentation_final.html directly β changes will be lost on next rebuildassets/ directory (template, tabs, styles, scripts)cd assets/ && node build-presentation.js
Complete Output Structure
```
docs/
βββ project/ # Source documentation (input)
β βββ requirements.md
β βββ architecture.md
β βββ tech_stack.md
β βββ api_spec.md (conditional)
β βββ database_schema.md (conditional)
β βββ design_guidelines.md (conditional)
β βββ runbook.md (conditional)
βββ reference/ # Source documentation (input)
β βββ adrs/
β β βββ *.md (Category: Strategic | Technical)
β βββ guides/
β βββ *.md (optional)
βββ tasks/ # Source documentation (input)
β βββ kanban_board.md (Epic Story Counters)
βββ presentation/ # Output directory
βββ README.md # Navigation hub
βββ presentation_final.html # Final standalone HTML (~120-150 KB)
βββ assets/ # Modular HTML structure
βββ presentation_template.html # Base HTML5 + 6 tabs
βββ styles.css # ~400-500 lines
βββ scripts.js # Tab switching + Mermaid
βββ build-presentation.js # Node.js build script
βββ tabs/
βββ tab_overview.html # Landing page
βββ tab_requirements.html # FRs + ADRs
βββ tab_architecture.html # C4 diagrams
βββ tab_technical_spec.html # API + Data + Deployment
βββ tab_roadmap.html # Epic list
βββ tab_guides.html # How-to guides
```
Note: Presentation READS from docs/project/, docs/reference/, docs/tasks/ but OUTPUTS to docs/presentation/.
---
HTML Features
- Single Source of Truth: No information duplication - each piece lives in exactly ONE tab
- Landing Page (Overview): Problem/Solution/Business Value, Stakeholders, Documentation Guide, Quick Facts, Tech Stack badges
- Interactive Navigation: 6 tabs with SCOPE tags, state persistence (localStorage), smooth transitions
- Table-Based Layout: FRs table only (Non-Functional Requirements are forbidden), Architecture highlights table
- Roadmap Simplified: Vertical Epic list with In/Out Scope sections, status badges, Dependencies/Success Criteria
- ADR Organization: Grouped by category (Strategic/Technical) with accordion, full content inline
- Diagram Visualization: Mermaid.js with tab-switch rerender (C4, ER, Sequence, Deployment)
- Responsive Design: Mobile-first (320px/768px/1024px+ breakpoints)
- Collapsible Sections: Auto-collapse with scroll preservation
- Modern UI: Clean professional design, WCAG 2.1 Level AA compliant
- English Language: All presentation content in English
---
Best Practices
Idempotent operation: Preserves README.md, preserves assets/ (user customizations), auto-rebuilds presentation_final.html.
Key rules by phase:
- Phase 2: STOP if required files missing; Phase 3: WARN only (non-blocking)
- Phase 5: Don't overwrite existing assets (user customizations)
- Phase 6: Delete ALL example blocks, escape XSS, valid Mermaid syntax
- Phase 7: Warn if output >200 KB
---
Customization Options
Edit assets/styles.css (CSS variables for theming), assets/presentation_template.html (layout/tabs), or assets/tabs/*.html (tab content).
β οΈ After any customization: Always rebuild the presentation:
```bash
cd assets/
node build-presentation.js
```
Important: Never edit presentation_final.html directly β it's a generated file that gets overwritten on each build.
---
Prerequisites
Orchestrator: ln-110-documents-pipeline | Standalone: Yes (rebuild/validate existing docs)
Required files: requirements.md, architecture.md, tech_stack.md (in docs/project/)
Optional files: api_spec, database_schema, design_guidelines, runbook, adrs/.md, guides/.md, kanban_board.md
Dependencies: Node.js v18+, Modern browser, Internet (Mermaid CDN)
---
Definition of Done
| Phase | Critical Checkpoints |
|-------|---------------------|
| 1. READ DOCS | β All docs loaded from docs/project/, docs/reference/, docs/tasks/ β Metadata extracted β Mermaid blocks preserved |
| 2. VALIDATE EXISTS | β Required files exist (requirements.md, architecture.md, tech_stack.md) β ERROR if missing |
| 3. VALIDATE QUALITY | β Diagrams checked β Placeholders detected β Content length checked β WARN only (non-blocking) |
| 4. CREATE DIR | β docs/presentation/ created β README.md created/preserved |
| 5. COPY TEMPLATES | β assets/ created with all templates OR preserved if exists |
| 6. INJECT CONTENT | β
All 6 tabs populated β
CRITICAL: Example blocks deleted β
No markers β
No hardcoded e-commerce data |
| 7. BUILD HTML | β
node build-presentation.js executed β
presentation_final.html created (~120-150 KB) β
Tested in browser |
Output: docs/presentation/presentation_final.html + assets/ + README.md
---
Troubleshooting
- ERROR: Missing required files: Run ln-111-project-docs-creator to create requirements.md, architecture.md, tech_stack.md
- WARN: Missing diagrams: Add Mermaid diagrams to architecture.md (C4 Context/Container/Component) and database_schema.md (ER diagram)
- WARN: Placeholders found: Complete documentation in source MD files before building
- WARN: Sparse content: Expand documentation (requirements.md >500 words, architecture.md >1000 words, tech_stack.md >200 words)
- Build script fails: Check Node.js v18+, navigate to assets/, verify all files exist
- Mermaid diagrams not rendering: Check syntax with Mermaid Live Editor, verify CDN loaded
- Tabs not switching: Check JavaScript loaded, open browser console for errors
- File too large (>200 KB): Reduce diagrams, minify CSS/JS, remove unused rules
---
Version: 8.0.0
Last Updated: 2025-12-12
More from this repository10
Official marketplace for Agile Linear Workflow plugin - complete end-to-end automation for software development teams using Linear. Includes 7XX Project Bootstrap series for technology-agnostic project migration.
Generates comprehensive test documentation with testing strategy and test organization structure for software projects.
Coordinates project documentation by gathering context once, detecting project type, and delegating document creation to 5 specialized workers.
Generates design guidelines documentation for frontend projects with WCAG 2.1 compliance when a frontend framework is detected.
Generates backend documentation files (API spec and database schema) automatically when backend or database technologies are detected in a project.
Audits code comments and docstrings across 6 quality categories, generating a comprehensive compliance score and actionable recommendations for improvement.
Generates a comprehensive runbook.md for DevOps setup, dynamically tailored to project's Docker configuration and deployment specifics.
Configures global exception handling middleware for .NET and Python backend applications with standardized error responses.
Generates reference documentation structure and smart documents for project tech stack, creating only justified architectural decision records and guides.
Audits dependencies for outdated packages, unused imports, unnecessary libraries, and custom implementations, providing actionable recommendations.