UNPKG

1.25 kBJavaScriptView Raw
1var domToReact = require('./lib/dom-to-react');
2var attributesToProps = require('./lib/attributes-to-props');
3var htmlToDOM = require('html-dom-parser');
4
5var domParserOptions = { lowerCaseAttributeNames: false };
6
7/**
8 * Converts HTML string to React elements.
9 *
10 * @param {String} html - HTML string.
11 * @param {Object} [options] - Parser options.
12 * @param {Object} [options.htmlparser2] - htmlparser2 options.
13 * @param {Object} [options.library] - Library for React, Preact, etc.
14 * @param {Function} [options.replace] - Replace method.
15 * @return {JSX.Element|JSX.Element[]|String} - React element(s), empty array, or string.
16 */
17function HTMLReactParser(html, options) {
18 if (typeof html !== 'string') {
19 throw new TypeError('First argument must be a string');
20 }
21 if (html === '') {
22 return [];
23 }
24 options = options || {};
25 return domToReact(
26 htmlToDOM(html, options.htmlparser2 || domParserOptions),
27 options
28 );
29}
30
31HTMLReactParser.domToReact = domToReact;
32HTMLReactParser.htmlToDOM = htmlToDOM;
33HTMLReactParser.attributesToProps = attributesToProps;
34
35// support CommonJS and ES Modules
36module.exports = HTMLReactParser;
37module.exports.default = HTMLReactParser;