17.0.0 • Published 12 months ago

@contentful/rich-text-html-renderer v17.0.0

Weekly downloads
64,764
License
MIT
Repository
github
Last release
12 months ago

rich-text-html-renderer

HTML renderer for the Contentful rich text field type.

Installation

Using npm:

npm install @contentful/rich-text-html-renderer

Using yarn:

yarn add @contentful/rich-text-html-renderer

Usage

import { documentToHtmlString } from '@contentful/rich-text-html-renderer';

const document = {
  nodeType: 'document',
  content: [
    {
      nodeType: 'paragraph',
      content: [
        {
          nodeType: 'text',
          value: 'Hello world!',
          marks: [],
        },
      ],
    },
  ],
};

documentToHtmlString(document); // -> <p>Hello world!</p>
import { documentToHtmlString } from '@contentful/rich-text-html-renderer';

const document = {
  nodeType: 'document',
  content: [
    {
      nodeType: 'paragraph',
      content: [
        {
          nodeType: 'text',
          value: 'Hello',
          marks: [{ type: 'bold' }],
        },
        {
          nodeType: 'text',
          value: ' world!',
          marks: [{ type: 'italic' }],
        },
      ],
    },
  ],
};

documentToHtmlString(document); // -> <p><b>Hello</b><u> world!</u></p>

You can also pass custom renderers for both marks and nodes as an optional parameter like so:

import { BLOCKS, MARKS } from '@contentful/rich-text-types';
import { documentToHtmlString } from '@contentful/rich-text-html-renderer';

const document = {
  nodeType: 'document',
  data: {},
  content: [
    {
      nodeType: 'paragraph',
      data:{},
      content: [
        {
          nodeType: 'text',
          value: 'Hello',
          marks: [{ type: 'bold' }],
          data: {}
        },
        {
          nodeType: 'text',
          value: ' world!',
          marks: [{ type: 'italic' }]
          data: {}
        },
      ],
    },
  ]
};

const options = {
  renderMark: {
    [MARKS.BOLD]: text => `<custom-bold>${text}<custom-bold>`
  },
  renderNode: {
    [BLOCKS.PARAGRAPH]: (node, next) => `<custom-paragraph>${next(node.content)}</custom-paragraph>`
  }
}

documentToHtmlString(document, options);
// -> <custom-paragraph><custom-bold>Hello</custom-bold><u> world!</u></custom-paragraph>

Last, but not least, you can pass a custom rendering component for an embedded entry:

import { BLOCKS } from '@contentful/rich-text-types';
import { documentToHtmlString } from '@contentful/rich-text-html-renderer';

const document = {
  nodeType: 'document',
  data: {},
  content: [
    {
      nodeType: 'embedded-entry-block',
      data: {
        target: (...)Link<'Entry'>(...);
      },
    },
  ]
};

const options = {
  renderNode: {
    [BLOCKS.EMBEDDED_ENTRY]: (node) => `<custom-component>${customComponentRenderer(node)}</custom-component>`
  }
}

documentToHtmlString(document, options);
// -> <custom-component>(...)Link<'Entry'>(...)</custom-component>

The renderNode keys should be one of the following BLOCKS and INLINES properties as defined in @contentful/rich-text-types:

  • BLOCKS

    • DOCUMENT
    • PARAGRAPH
    • HEADING_1
    • HEADING_2
    • HEADING_3
    • HEADING_4
    • HEADING_5
    • HEADING_6
    • UL_LIST
    • OL_LIST
    • LIST_ITEM
    • QUOTE
    • HR
    • EMBEDDED_ENTRY
    • EMBEDDED_ASSET
    • EMBEDDED_RESOURCE
  • INLINES

    • EMBEDDED_ENTRY (this is different from the BLOCKS.EMBEDDED_ENTRY)
    • EMBEDDED_RESOURCE
    • HYPERLINK
    • ENTRY_HYPERLINK
    • ASSET_HYPERLINK
    • RESOURCE_HYPERLINK

The renderMark keys should be one of the following MARKS properties as defined in @contentful/rich-text-types:

  • BOLD
  • ITALIC
  • UNDERLINE
  • CODE
  • SUPERSCRIPT
  • SUBSCRIPT
  • STRIKETHROUGH

Preserving Whitespace

In your HTML rendering options, you can utilize the preserveWhitespace boolean flag. When set to true, this flag ensures that spaces and line breaks in the Contentful rich text content are preserved in the rendered HTML. Specifically, it replaces consecutive spaces with &nbsp; entities and retains line breaks using <br /> tags. This capability is particularly beneficial for content that has specific formatting requirements involving spaces and line breaks.

import { documentToHtmlString } from '@contentful/rich-text-html-renderer';

const document = {
  nodeType: 'document',
  content: [
    {
      nodeType: 'paragraph',
      content: [
        {
          nodeType: 'text',
          value: 'Hello     world!',
          marks: [],
        },
      ],
    },
  ],
};

const options = {
  preserveWhitespace: true,
};

documentToHtmlString(document, options);
// -> <p>Hello&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;world!</p>

With this configuration, the HTML output retains the spaces found between "Hello" and "world!".

17.0.0

12 months ago

16.6.10

1 year ago

16.5.5

1 year ago

16.5.4

1 year ago

16.5.3

1 year ago

16.5.2

1 year ago

16.5.1

1 year ago

16.5.0

1 year ago

16.6.4

1 year ago

16.6.3

1 year ago

16.6.2

1 year ago

16.6.1

1 year ago

16.6.8

1 year ago

16.6.7

1 year ago

16.6.6

1 year ago

16.6.5

1 year ago

16.6.9

1 year ago

16.6.0

1 year ago

16.4.0

1 year ago

16.3.5

2 years ago

16.3.4

2 years ago

16.3.3

2 years ago

16.3.2

2 years ago

16.3.1

2 years ago

16.1.1

2 years ago

16.3.0

2 years ago

16.1.2

2 years ago

16.2.0

2 years ago

16.1.0

2 years ago

16.0.5

2 years ago

16.0.4

2 years ago

16.0.3

3 years ago

15.15.1

3 years ago

16.0.2

3 years ago

16.0.0

3 years ago

15.13.1

3 years ago

15.12.1

4 years ago

15.12.0

4 years ago

15.9.0

4 years ago

15.9.1

4 years ago

15.11.0

4 years ago

15.11.1

4 years ago

15.10.1

4 years ago

15.10.0

4 years ago

15.8.0

4 years ago

15.6.0

4 years ago

15.6.2

4 years ago

15.5.1

4 years ago

15.4.0

4 years ago

15.3.6

4 years ago

15.3.5

4 years ago

15.3.4

4 years ago

15.3.2

4 years ago

15.3.1

4 years ago

15.3.3

4 years ago

15.3.0

4 years ago

15.2.0

4 years ago

15.1.0

4 years ago

15.0.0

4 years ago

14.1.2

5 years ago

14.1.1

5 years ago

14.1.0

5 years ago

13.4.0

6 years ago

13.1.0

7 years ago

13.0.0

7 years ago

12.2.1

7 years ago

12.1.2

7 years ago

12.1.0

7 years ago

12.0.3

7 years ago

12.0.2

7 years ago

12.0.1

7 years ago

12.0.0

7 years ago

11.0.0

7 years ago

10.3.0

7 years ago

10.2.0

7 years ago

10.1.0

7 years ago

10.0.1

7 years ago

10.0.0

7 years ago

9.0.2

7 years ago

9.0.0

7 years ago

8.0.3

7 years ago

8.0.2

7 years ago

8.0.1

7 years ago

2.9.1

7 years ago

2.9.0

7 years ago

2.8.0

7 years ago