Skip to content

Latest commit

 

History

History
298 lines (221 loc) · 7.23 KB

PRD.md

File metadata and controls

298 lines (221 loc) · 7.23 KB

Svelte Markdown Package

Overview

@humanspeak/svelte-markdown is a powerful, customizable markdown renderer for Svelte with TypeScript support. It's built as a successor to the original svelte-markdown package by Pablo Berganza, now maintained and enhanced by Humanspeak, Inc.

Lineage

  1. Original Creator: Pablo Berganza (2020-2024)
  2. Current Maintainer: Humanspeak, Inc. (2024-present)

Core Features

1. Markdown Rendering

  • Full markdown syntax support through Marked
  • Custom component overrides
  • HTML parsing capabilities via HTMLParser2
  • GitHub-style slug generation for headers

2. TypeScript Support

  • Full TypeScript definitions
  • Type-safe component props
  • Svelte 5 compatibility

3. Testing Infrastructure

  • Comprehensive unit testing with Vitest
  • Coverage reporting via Coveralls
  • Browser environment testing with JSDOM
  • End-to-end testing with Playwright
    • Cross-browser compatibility validation
    • Version migration testing
    • Visual regression testing
    • Accessibility compliance checks

Technical Specifications

Dependencies

  • Core Dependencies:

    • marked: ^15.0.5
    • github-slugger: ^2.0.0
    • htmlparser2: ^10.0.0
  • Peer Dependencies:

    • svelte: ^5.0.0

Build Configuration

  • Vite-based build system
  • SvelteKit package preparation
  • Source map generation
  • TypeScript compilation

Package Structure

  • Distribution via NPM
  • ESM module format
  • Side effects declared for CSS files
  • Source maps included

Testing Setup

  • Vitest configuration with extensive edge case coverage
  • JSDOM environment for DOM manipulation testing
  • Testing Library integration for component testing
  • Coverage reporting with minimum 90% threshold
  • Playwright E2E test suites for:
    • Cross-version compatibility
    • Browser compatibility matrix
    • Visual regression snapshots
    • Accessibility compliance (WCAG 2.1)
  • Specialized test suites for:
    • Malformed markdown input
    • Unicode and special character handling
    • Nested component scenarios
    • Memory leak prevention
    • Large document performance
    • Concurrent rendering scenarios

Edge Case Handling

  • Input Validation

    • Empty markdown strings
    • Non-string inputs
    • Malformed HTML within markdown
    • Extended Unicode characters
    • Zero-width spaces and invisible characters
  • Component Behavior

    • Recursive component rendering
    • Circular reference detection
    • Dynamic component loading
    • Error boundary implementation
    • Memory management for large documents
  • Performance Considerations

    • Chunked rendering for large documents
    • Lazy loading for complex syntax
    • Resource cleanup on unmount
    • Debounced updates for live editing

Quality Assurance

Automated Testing

  • Unit tests for core functionality
  • Browser environment testing
  • End-to-end testing with Playwright
    • Automated visual regression
    • Cross-browser testing pipeline
    • Accessibility validation
  • Continuous Integration via GitHub Actions

Code Quality

  • ESLint for code quality
  • Prettier for code formatting
  • TypeScript for type safety

Distribution

Package Configuration

  • Scoped under @humanspeak
  • Type definitions included
  • ESM format
  • Svelte component exports

NPM Publishing

  • Public package under @humanspeak scope
  • Automated versioning and releases
  • Source maps included for debugging

License

MIT License with dual copyright:

  • Copyright (c) 2024-2025 Humanspeak, Inc.
  • Copyright (c) 2020-2024 Pablo Berganza

Development Workflow

Build Process

  1. Development: npm run dev
  2. Testing: npm run test
  3. Building: npm run build
  4. Publishing: Automated via GitHub Actions

Contribution Guidelines

  • Pull requests welcome
  • Tests required for new features
  • Automated CI/CD pipeline
  • Code formatting enforced via Prettier

Future Roadmap

Planned Features

  1. Enhanced HTML parsing capabilities
  2. Additional markdown extensions
  3. Performance optimizations
  4. Extended component customization options

Maintenance Goals

  1. Regular dependency updates via Dependabot
  2. Continuous security monitoring
  3. Documentation improvements
  4. Community engagement

Support

Official Channels

  • GitHub Issues
  • NPM Package Page
  • Documentation Website

Commercial Support

Available through Humanspeak, Inc. for enterprise customers

Migration Guide

From Svelte 4

  • Update to Svelte 5
  • Review component bindings
  • Check custom component implementations
  • Verify TypeScript types

From Other Markdown Libraries

  • Review component structure
  • Adapt custom renderers
  • Update event handlers
  • Migrate styling approaches

Implementation Priorities

Phase 1: Foundation (Completed)

  • Core markdown rendering with edge case handling
  • Robust syntax highlighting with fallback modes
  • Comprehensive component override system
  • Full TypeScript support with strict type checking
  • Edge case test suite implementation
  • Performance baseline measurements

Phase 2: Advanced Features (In Progress)

  • Math and diagram support with error handling
  • Interactive elements with accessibility support
  • Performance optimizations for large documents
  • Plugin system foundation with validation
  • Extended edge case coverage
  • Load testing infrastructure
  • Automated migration testing between versions
  • Visual regression monitoring

Phase 5: Ecosystem

  • Extended plugin library(?)
  • Developer tool
  • Performance monitoring

Performance Monitoring

  • Automated performance benchmarking
  • Bundle size monitoring
  • Runtime performance tracking
  • Memory usage analysis
  • Rendering performance metrics

Implementation Status Updates

Completed Features

  • Core markdown rendering with edge case handling
    • Full test coverage for basic and complex scenarios
    • Table rendering with alignment support
    • Nested content handling
  • Full TypeScript support with strict type checking
    • Comprehensive type definitions for renderers
    • Component-level type safety
    • Generic component type support
    • Flexible renderer component types
  • HTML parsing capabilities
    • Nested HTML element support
    • Attribute preservation
    • Mixed markdown/HTML content
    • Table cell HTML rendering
  • Edge case test suite implementation
    • Complex table structures
    • Mixed content scenarios
    • Nested component testing
    • Malformed content handling

In Progress Features

  • Deep nested lists (>10 levels)
  • Math and diagram support with error handling
  • Interactive elements with accessibility support
    • ARIA role implementation
    • Semantic HTML structure
    • Heading navigation support
  • Performance optimizations
    • Derived state handling
    • Token cleanup utilities
    • Efficient HTML parsing
  • Plugin system foundation
  • Extended edge case coverage
    • Table cell alignment
    • Complex nested structures
    • Mixed content handling
  • Visual regression monitoring
    • Cross-browser testing
    • Component rendering validation

Phase 2 Progress: 75% Complete

  • Table rendering with mixed content ✓
  • HTML parsing and nesting ✓
  • Type safety improvements ✓
  • Edge case handling ✓
  • Performance optimizations ✓
  • Accessibility support ✓
  • Plugin system (pending)
  • Math/diagram support (pending)