@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.
- Original Creator: Pablo Berganza (2020-2024)
- Current Maintainer: Humanspeak, Inc. (2024-present)
- Full markdown syntax support through Marked
- Custom component overrides
- HTML parsing capabilities via HTMLParser2
- GitHub-style slug generation for headers
- Full TypeScript definitions
- Type-safe component props
- Svelte 5 compatibility
- 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
-
Core Dependencies:
- marked: ^15.0.5
- github-slugger: ^2.0.0
- htmlparser2: ^10.0.0
-
Peer Dependencies:
- svelte: ^5.0.0
- Vite-based build system
- SvelteKit package preparation
- Source map generation
- TypeScript compilation
- Distribution via NPM
- ESM module format
- Side effects declared for CSS files
- Source maps included
- 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
-
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
- 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
- ESLint for code quality
- Prettier for code formatting
- TypeScript for type safety
- Scoped under @humanspeak
- Type definitions included
- ESM format
- Svelte component exports
- Public package under @humanspeak scope
- Automated versioning and releases
- Source maps included for debugging
MIT License with dual copyright:
- Copyright (c) 2024-2025 Humanspeak, Inc.
- Copyright (c) 2020-2024 Pablo Berganza
- Development: npm run dev
- Testing: npm run test
- Building: npm run build
- Publishing: Automated via GitHub Actions
- Pull requests welcome
- Tests required for new features
- Automated CI/CD pipeline
- Code formatting enforced via Prettier
- Enhanced HTML parsing capabilities
- Additional markdown extensions
- Performance optimizations
- Extended component customization options
- Regular dependency updates via Dependabot
- Continuous security monitoring
- Documentation improvements
- Community engagement
- GitHub Issues
- NPM Package Page
- Documentation Website
Available through Humanspeak, Inc. for enterprise customers
- Update to Svelte 5
- Review component bindings
- Check custom component implementations
- Verify TypeScript types
- Review component structure
- Adapt custom renderers
- Update event handlers
- Migrate styling approaches
- 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
- 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
- Extended plugin library(?)
- Developer tool
- Performance monitoring
- Automated performance benchmarking
- Bundle size monitoring
- Runtime performance tracking
- Memory usage analysis
- Rendering performance metrics
- 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
- 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
- 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)