contentful-richtext-converter
TypeScript icon, indicating that this package has built-in type declarations

1.3.7 • Public • Published
Contentful RichText Converter Logo

Contentful RichText Converter

HTML to RichText and back again.

NPM Version Types Typescript NPM License
Playground on Netlify GitHub Stars



This is a module build to convert HTML data into the Contentful ready RichText JSON, and convert RichText back to HTML. It is intended to be used during migrations or when working with the Contentful Management API.

It handles all kinds of features and usecases to ensure full functionality with all of the aspects of the Contentful RichText Editor. Some are easy, some a quirky - but it's a working progress.

Use at your own risk :)

🚀 Playground

Want to try it out?

Jump to the Playground where you can "write" or "copy-paste" a chunk of HTML and instantly get RichText JSON back.

Try it out, and get busy coding :)

🔎 Current Status

The project is currently still a working progress with possible future changes, but currently set up to support both ESM (browser) and CommonJS with node. The functionality is somewhat feature complete, but further testing, typescript and even better implementations will be coming in the near future.

⚙️ Installation

Using npm:

npm i contentful-richtext-converter

Usage (HTML to RichText)

Node (CommonJS)

const { htmlToRichText } = require("contentful-richtext-converter");
const html = '<p>Hello <strong>World</strong></p>';
const result = htmlToRichText(html);

Browser (ESM)

import { htmlToRichText } from 'contentful-richtext-converter';
const html = '<p>Hello <strong>World</strong></p>';
const result = htmlToRichText(html);

Output:

{
    "nodeType": "document",
    "data": {},
    "content": [
        {
            "nodeType": "paragraph",
            "data": {},
            "content": [
                {
                    "nodeType": "text",
                    "value": "Hello ",
                    "marks": [],
                    "data": {}
                },
                {
                    "nodeType": "text",
                    "value": "World",
                    "marks": [
                        {
                            "type": "bold"
                        }
                    ],
                    "data": {}
                }
            ]
        }
    ]
}

You might also need to validate and test an HTML output from the RichText data. This is just a simple RichText to HTML output. It allows to output - and work with all basic HTML elements of the RichText editor and supports hyperlinks, but isn't the "current" solution for deeper outputs with Entry blocks, Assets and Inline Entries. This will be covered later on, but for now this is just a simple conversion.

Usage (RichText to HTML)

Node (CommonJS)

const { richTextToHtml } = require("contentful-richtext-converter");
const json = {"nodeType": "document", "data": {}, "content": [{"nodeType": "paragraph", "data": {}, "content": [{"nodeType": "text", "value": "Hello ", "marks": [], "data": {}}, {"nodeType": "text", "value": "World", "marks": [{"type": "bold"}], "data": {}}]}]};
const result = richTextToHtml(json);

Browser (ESM)

import { richTextToHtml } from 'contentful-richtext-converter';
const json = {"nodeType": "document", "data": {}, "content": [{"nodeType": "paragraph", "data": {}, "content": [{"nodeType": "text", "value": "Hello ", "marks": [], "data": {}}, {"nodeType": "text", "value": "World", "marks": [{"type": "bold"}], "data": {}}]}]};
const result = richTextToHtml(json);

Output:

<p>Hello <strong>World</strong></p>

Features

The htmlToRichText(html,options) function takes to parameters:

html is a string of HTML

options is an Object to enable or disable default settings for html manipulation.

The default settings:

{
    "fixTagsAndSpaces": true,
    "removeDivsAndSpan": true
}

These features are enabled by default, but can be set to false with the options parameter.

fixTagsAndSpaces does a basic cleanup, closing tags and removing unwanted spacing.

removeDivsAndSpan removes all elements of type DIV and SPAN - leaving only the flat valid HTML structure for the RichText JSON.

Though when a DIV or SPAN has a data-sys-id it can be used to automatically convert the element to a Entry Block or Inline Entry.

This will be covered later on, when thoroughly tested.


😺 Git Repository

https://github.com/t00bstAr/contentful-richtext-converter

Package Sidebar

Install

npm i contentful-richtext-converter

Weekly Downloads

17

Version

1.3.7

License

MIT

Unpacked Size

40.3 kB

Total Files

11

Last publish

Collaborators

  • t00bstar