Skip to content

keithwalsh/react-markdown-table-ts

Repository files navigation

⚛️ react-markdown-table-ts 🛡️

NPM Version codecov Build Code Climate GitHub branch status

Light Theme Example Dark Theme Example
'light' theme 'dark' theme

Overview

This library provides a React component for generating and displaying formatted Markdown tables with syntax highlighting. The core component is MarkdownTable which converts 2D array data into properly formatted Markdown table syntax. Columns of variable width maintain consistent spacing across all rows, ensuring vertical alignment of delimiters. For syntax highlighting and line numbering, Prism.js is used within a <pre> HTML element.

API

interface MarkdownTableProps {
    inputData?: string[][] | null;
    columnAlignments?: readonly Alignment[];
    isCompact?: boolean;
    hasPadding?: boolean;
    hasTabs?: boolean;
    hasHeader?: boolean;
    convertLineBreaks?: boolean;
    topPadding?: number;
    theme?: 'light' | 'dark';
    className?: string;
    preStyle?: React.CSSProperties;
    minWidth?: number;
    onGenerate?: (markdownTableString: string) => void;
}
Prop Type Default Description
inputData string[][] | null null The outer array represents rows. The inner array represent cells within each row.
columnAlignments readonly Alignment[] [] Acceptable values are 'left', 'center', 'right', 'justify', or 'none'. Defaults to 'none' when unspecified.
isCompact boolean false Disables column width alignment to provide a more compact markdown table string.
hasPadding boolean true One space added before and after the content in each cell.
hasTabs boolean false Adds a tab character after each | and before the content.
hasHeader boolean true Indicates whether the first row of data is a header.
convertLineBreaks boolean false Replace newlines with
tags in table cells.
topPadding number 16 Controls the padding-top (in pixels) of the <pre> element display.
theme 'light' | 'dark' light Controls the color scheme of the <pre> element display.
className string undefined Class will be applied to the <pre> element display.
preStyle React.CSSProperties undefined Allows direct styling of the display with CSS properties.
minWidth number undefined Optional minimum width in pixels for the table container.
onGenerate (markdownTableString: string) => void undefined Callback to receive the generated Markdown table string.

Usage Patterns

  1. Basic Table Generation:
<MarkdownTable
    inputData={[
        ["Header 1", "Header 2"],
        ["Row 1 Col 1", "Row 1 Col 2"]
    ]}
/>
  1. Column Alignment:
<MarkdownTable
    inputData={data}
    columnAlignments={['left', 'center', 'right', 'justify']}
/>
  1. Auto-Generated Headers:
<MarkdownTable
    inputData={data}
    hasHeader={false} // Will generate A, B, C... headers
/>
  1. Setting Minimum Width:
<MarkdownTable
    inputData={data}
    minWidth={500} // Sets the minimum width of the table container to 500 pixels
/>

Behaviors

  1. Input Validation:
  • Input must be non-null 2D string array
  • All rows should contain string values
  • Empty arrays are not allowed
  • Column alignments must be valid ('left', 'center', 'right', 'justify', 'none')
  1. Column Width Handling:
  • Default: Adjusts columns to fit content with 'none' alignment
  • isCompact={true}: Minimizes column widths
  • Maintains minimum width of 3 characters for alignment indicators
  • 'justify' alignment behaves same as 'none' for markdown compatibility
  1. Error Handling:
  • Returns error message string if validation fails
  • Wraps errors in MarkdownTableError class
  • Preserves stack traces for debugging
  1. Styling:
  • Uses Prism.js for syntax highlighting
  • Supports light/dark themes
  • Custom styles via className and preStyle props

Common Transformations

  1. Data Formatting:
  • Newlines can be converted to <br> tags with canReplaceNewlines
  • Padding can be controlled with hasPadding
  • Tab spacing available with hasTabs
  1. Header Generation:
  • Auto-generates A, B, C... headers when hasHeader={false}
  • Supports custom headers via first row when hasHeader={true}

About

A React component that converts structured data into Markdown table syntax and displays it within a <pre> tag.

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 2

  •  
  •