Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

draftjs-to-markdown

Package Overview
Dependencies
Maintainers
1
Versions
20
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

draftjs-to-markdown - npm Package Compare versions

Comparing version 0.4.3 to 0.4.4

2

lib/draftjs-to-markdown.js

@@ -1,1 +0,1 @@

module.exports=function(t){function e(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,e),o.l=!0,o.exports}var n={};return e.m=t,e.c=n,e.d=function(t,n,r){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:r})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=0)}([function(t,e,n){t.exports=n(1)},function(t,e,n){"use strict";function r(t){return!!(t.entityRanges.length>0&&(0,C.isEmptyString)(t.text))}function o(t,e,n,r){var o=t[e];if("function"==typeof r){var a=r(o,n);if(a)return a}return"MENTION"===o.type?"["+n+"]("+o.data.url+")":"LINK"===o.type?"["+n+"]("+o.data.url+")":"IMAGE"===o.type?"!["+(o.data.alt||"")+"]("+o.data.src+")":"EMBEDDED_LINK"===o.type?'<iframe width="'+o.data.width+'" height="'+o.data.height+'" src="'+o.data.src+'" frameBorder="0" allowFullScreen />':n}function a(t,e){var n=[];if(e)for(var r=0,o=0,a=t,i=e.trigger||"#",u=e.separator||" ";a.length>0&&o>=0;)if(a[0]===i?(o=0,r=0,a=a.substr(i.length)):(o=a.indexOf(u+i))>=0&&(a=a.substr(o+(u+i).length),r+=o+u.length),o>=0){var s=a.indexOf(u)>=0?a.indexOf(u):a.length,f=a.substr(0,s);f&&f.length>0&&n.push({offset:r,length:f.length+i.length,type:"HASHTAG"}),r+=i.length}return n}function i(t,e){var n=[],r=0,o=t.entityRanges.map(function(t){return{offset:t.offset,length:t.length,key:t.key,type:"ENTITY"}});return o=o.concat(a(t.text,e)),o=o.sort(function(t,e){return t.offset-e.offset}),o.forEach(function(t){t.offset>r&&n.push({start:r,end:t.offset-1}),n.push({start:t.offset,end:t.offset+t.length,entityKey:t.key,type:t.type}),r=t.offset+t.length}),r<t.text.length&&n.push({start:r,end:t.text.length}),n}function u(t){var e=t.text,n=t.inlineStyleRanges,r={COLOR:new Array(e.length),BGCOLOR:new Array(e.length),FONTSIZE:new Array(e.length),FONTFAMILY:new Array(e.length),SUBSCRIPT:new Array(e.length),SUPERSCRIPT:new Array(e.length),CODE:new Array(e.length),STRIKETHROUGH:new Array(e.length),UNDERLINE:new Array(e.length),ITALIC:new Array(e.length),BOLD:new Array(e.length),length:e.length};return n&&n.length>0&&n.forEach(function(t){for(var e=t.offset,n=e+t.length,o=e;o<n;o+=1)0===t.style.indexOf("color-")?r.COLOR[o]=t.style.substring(6):0===t.style.indexOf("bgcolor-")?r.BGCOLOR[o]=t.style.substring(8):0===t.style.indexOf("fontsize-")?r.FONTSIZE[o]=t.style.substring(9):0===t.style.indexOf("fontfamily-")?r.FONTFAMILY[o]=t.style.substring(11):r[t.style]&&(r[t.style][o]=!0)}),r}function s(t,e,n){var r=!0;return n>0&&n<t.length?e.forEach(function(e){r=r&&t[e][n]===t[e][n-1]}):r=!1,r}function f(t,e){var n={};return t.COLOR[e]&&(n.COLOR=t.COLOR[e]),t.BGCOLOR[e]&&(n.BGCOLOR=t.BGCOLOR[e]),t.FONTSIZE[e]&&(n.FONTSIZE=t.FONTSIZE[e]),t.FONTFAMILY[e]&&(n.FONTFAMILY=t.FONTFAMILY[e]),t.SUBSCRIPT[e]&&(n.SUBSCRIPT=!0),t.SUPERSCRIPT[e]&&(n.SUPERSCRIPT=!0),t.CODE[e]&&(n.CODE=!0),t.STRIKETHROUGH[e]&&(n.STRIKETHROUGH=!0),t.UNDERLINE[e]&&(n.UNDERLINE=!0),t.ITALIC[e]&&(n.ITALIC=!0),t.BOLD[e]&&(n.BOLD=!0),n}function l(t,e,n,r){var o=[],a=t.text;if(a.length>0)for(var i=u(t),l=void 0,c=n;c<r;c+=1)c!==n&&s(i,e,c)?(l.text.push(a[c]),l.end=c+1):(l={styles:f(i,c),text:[a[c]],start:c,end:c+1},o.push(l));return o}function c(t){if(t&&t.length>0){return t.map(function(t){switch(t){case"\n":return"\\s\\s\n";case"&":return"&amp;";case"<":return"&lt;";case">":return"&gt;";default:return t}}).join("")}return""}function O(t,e){return"BOLD"===t?"**"+e+"**":"ITALIC"===t?"*"+e+"*":"UNDERLINE"===t?"__"+e+"__":"STRIKETHROUGH"===t?"~~"+e+"~~":"CODE"===t?"`"+e+"`":"SUPERSCRIPT"===t?"<sup>"+e+"</sup>":"SUBSCRIPT"===t?"<sub>"+e+"</sub>":e}function h(t,e){var n=e;return(0,C.forEach)(t,function(t,e){n=O(t,n,e)}),n}function y(t){var e=t.styles,n=t.text,r=c(n);if(e&&(e.COLOR||e.BGCOLOR||e.FONTSIZE||e.FONTFAMILY)){var o='style="';return e.COLOR&&(o+="color: "+e.COLOR+";"),e.BGCOLOR&&(o+="background-color: "+e.BGCOLOR+";"),e.FONTSIZE&&(o+="font-size: "+e.FONTSIZE+"px;"),e.FONTFAMILY&&(o+="font-family: "+e.FONTFAMILY+";"),"<span "+(o+='"')+">"+r+"</span>"}return r}function g(t,e,n,r){var a=[],i=l(t,["BOLD","ITALIC","UNDERLINE","STRIKETHROUGH","CODE","SUPERSCRIPT","SUBSCRIPT"],n.start,n.end),u="";i.forEach(function(e){var n=l(t,["COLOR","BGCOLOR","FONTSIZE","FONTFAMILY"],e.start,e.end),r="";n.forEach(function(t){r+=y(t)}),u+=h(e.styles,r)}),a.push(u);var s=a.join("");return"ENTITY"===n.type?void 0!==n.entityKey&&null!==n.entityKey&&(s=o(e,n.entityKey,s,r)):"HASHTAG"===n.type&&(s="["+s+"]("+s+")"),s}function p(t){if(t){for(var e=t,n=0;n<e.length&&" "===t[n];n+=1)e=e.replace(" ","&nbsp;");return e}return t}function d(t){if(t){for(var e=t,n=e.length-1;n>=0&&" "===e[n];n-=1)e=e.substring(0,n)+"&nbsp;"+e.substring(n+1);return e}return t}function I(t,e,n,a){if(r(t))return o(e,t.entityRanges[0].key,void 0,a);var u=[],s=i(t,n);return s.forEach(function(n,r){var o=g(t,e,n,a);0===r&&(o=p(o)),r===s.length-1&&(o=d(o)),u.push(o)}),u.join("")}function E(t){var e="";return(0,C.forEach)(t,function(t,n){e+=t+":"+n+";"}),e}function T(t,e){var n=E(t);return n?'<span style="'+n+'">'+e+"</span>":e}function R(t,e,n,r,o,a){var i=[];i.push(e[t.type]);var u=I(t,n,r,o);return t.data&&(u=T(t.data,u)),i.push(u),i.push(a&&a.emptyLineBeforeBlock?"\n\n":"\n"),i.join("")}function L(t){for(var e="",n=0;n<4*t;n+=1)e+=" ";return e}function v(t,e,n,r){var o=[];if(t){var a=S({},N,r&&r.blockTypesMapping&&r.blockTypesMapping),i=t.blocks,u=t.entityMap;i&&i.length>0&&i.forEach(function(t){var i=R(t,a,u,e,n,r);(0,C.isList)(t.type)&&(i=L(t.depth)+i),o.push(i)})}return o.join("")}Object.defineProperty(e,"__esModule",{value:!0});var S=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(t[r]=n[r])}return t};e.sameStyleAsPrevious=s,e.getStylesAtOffset=f,e.addInlineStyleMarkdown=O,e.addStylePropertyMarkdown=y,e.trimLeadingZeros=p,e.trimTrailingZeros=d,e.getBlockContentMarkdown=I,e.getBlockStyle=E,e.default=v;var C=n(2),N={unstyled:"","header-one":"# ","header-two":"## ","header-three":"### ","header-four":"#### ","header-five":"##### ","header-six":"###### ","unordered-list-item":"- ","ordered-list-item":"1. ",blockquote:"> "}},function(t,e,n){"use strict";function r(t,e){if(t)for(var n in t)({}).hasOwnProperty.call(t,n)&&e(n,t[n])}function o(t){return void 0===t||null===t||0===t.length||0===t.trim().length}function a(t){return"unordered-list-item"===t||"ordered-list-item"===t}Object.defineProperty(e,"__esModule",{value:!0}),e.forEach=r,e.isEmptyString=o,e.isList=a}]);
module.exports=function(t){function e(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,e),o.l=!0,o.exports}var n={};return e.m=t,e.c=n,e.d=function(t,n,r){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:r})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=0)}([function(t,e,n){t.exports=n(1)},function(t,e,n){"use strict";function r(t){return!!(t.entityRanges.length>0&&(0,C.isEmptyString)(t.text))}function o(t,e,n,r){var o=t[e];if("function"==typeof r){var a=r(o,n);if(a)return a}return"MENTION"===o.type?"["+n+"]("+o.data.url+")":"LINK"===o.type?"["+n+"]("+o.data.url+")":"IMAGE"===o.type?"!["+(o.data.alt||"")+"]("+o.data.src+")":"EMBEDDED_LINK"===o.type?'<iframe width="'+o.data.width+'" height="'+o.data.height+'" src="'+o.data.src+'" frameBorder="0" allowFullScreen />':n}function a(t,e){var n=[];if(e)for(var r=0,o=0,a=t,i=e.trigger||"#",u=e.separator||" ";a.length>0&&o>=0;)if(a[0]===i?(o=0,r=0,a=a.substr(i.length)):(o=a.indexOf(u+i))>=0&&(a=a.substr(o+(u+i).length),r+=o+u.length),o>=0){var s=a.indexOf(u)>=0?a.indexOf(u):a.length,f=a.substr(0,s);f&&f.length>0&&n.push({offset:r,length:f.length+i.length,type:"HASHTAG"}),r+=i.length}return n}function i(t,e){var n=[],r=0,o=t.entityRanges.map(function(t){return{offset:t.offset,length:t.length,key:t.key,type:"ENTITY"}});return o=o.concat(a(t.text,e)),o=o.sort(function(t,e){return t.offset-e.offset}),o.forEach(function(t){t.offset>r&&n.push({start:r,end:t.offset-1}),n.push({start:t.offset,end:t.offset+t.length,entityKey:t.key,type:t.type}),r=t.offset+t.length}),r<t.text.length&&n.push({start:r,end:t.text.length}),n}function u(t){var e=t.text,n=t.inlineStyleRanges,r={COLOR:new Array(e.length),BGCOLOR:new Array(e.length),FONTSIZE:new Array(e.length),FONTFAMILY:new Array(e.length),SUBSCRIPT:new Array(e.length),SUPERSCRIPT:new Array(e.length),CODE:new Array(e.length),STRIKETHROUGH:new Array(e.length),UNDERLINE:new Array(e.length),ITALIC:new Array(e.length),BOLD:new Array(e.length),length:e.length};return n&&n.length>0&&n.forEach(function(t){for(var e=t.offset,n=e+t.length,o=e;o<n;o+=1)0===t.style.indexOf("color-")?r.COLOR[o]=t.style.substring(6):0===t.style.indexOf("bgcolor-")?r.BGCOLOR[o]=t.style.substring(8):0===t.style.indexOf("fontsize-")?r.FONTSIZE[o]=t.style.substring(9):0===t.style.indexOf("fontfamily-")?r.FONTFAMILY[o]=t.style.substring(11):r[t.style]&&(r[t.style][o]=!0)}),r}function s(t,e,n){var r=!0;return n>0&&n<t.length?e.forEach(function(e){r=r&&t[e][n]===t[e][n-1]}):r=!1,r}function f(t,e){var n={};return t.COLOR[e]&&(n.COLOR=t.COLOR[e]),t.BGCOLOR[e]&&(n.BGCOLOR=t.BGCOLOR[e]),t.FONTSIZE[e]&&(n.FONTSIZE=t.FONTSIZE[e]),t.FONTFAMILY[e]&&(n.FONTFAMILY=t.FONTFAMILY[e]),t.SUBSCRIPT[e]&&(n.SUBSCRIPT=!0),t.SUPERSCRIPT[e]&&(n.SUPERSCRIPT=!0),t.CODE[e]&&(n.CODE=!0),t.STRIKETHROUGH[e]&&(n.STRIKETHROUGH=!0),t.UNDERLINE[e]&&(n.UNDERLINE=!0),t.ITALIC[e]&&(n.ITALIC=!0),t.BOLD[e]&&(n.BOLD=!0),n}function l(t,e,n,r){var o=[],a=t.text;if(a.length>0)for(var i=u(t),l=void 0,c=n;c<r;c+=1)c!==n&&s(i,e,c)?(l.text.push(a[c]),l.end=c+1):(l={styles:f(i,c),text:[a[c]],start:c,end:c+1},o.push(l));return o}function c(t){if(t&&t.length>0){return t.map(function(t){switch(t){case"\n":return"\\s\\s\n";case"&":return"&amp;";case"<":return"&lt;";case">":return"&gt;";default:return t}}).join("")}return""}function O(t,e){return"BOLD"===t?"**"+e+"**":"ITALIC"===t?"*"+e+"*":"UNDERLINE"===t?"__"+e+"__":"STRIKETHROUGH"===t?"~~"+e+"~~":"CODE"===t?"`"+e+"`":"SUPERSCRIPT"===t?"<sup>"+e+"</sup>":"SUBSCRIPT"===t?"<sub>"+e+"</sub>":e}function h(t,e){var n=e;return(0,C.forEach)(t,function(t,e){n=O(t,n,e)}),n}function y(t){var e=t.styles,n=t.text,r=c(n);if(e&&(e.COLOR||e.BGCOLOR||e.FONTSIZE||e.FONTFAMILY)){var o='style="';return e.COLOR&&(o+="color: "+e.COLOR+";"),e.BGCOLOR&&(o+="background-color: "+e.BGCOLOR+";"),e.FONTSIZE&&(o+="font-size: "+e.FONTSIZE+"px;"),e.FONTFAMILY&&(o+="font-family: "+e.FONTFAMILY+";"),"<span "+(o+='"')+">"+r+"</span>"}return r}function g(t,e,n,r){var a=[],i=l(t,["BOLD","ITALIC","UNDERLINE","STRIKETHROUGH","CODE","SUPERSCRIPT","SUBSCRIPT"],n.start,n.end),u="";i.forEach(function(e){var n=l(t,["COLOR","BGCOLOR","FONTSIZE","FONTFAMILY"],e.start,e.end),r="";n.forEach(function(t){r+=y(t)}),u+=h(e.styles,r)}),a.push(u);var s=a.join("");return"ENTITY"===n.type?void 0!==n.entityKey&&null!==n.entityKey&&(s=o(e,n.entityKey,s,r)):"HASHTAG"===n.type&&(s="["+s+"]("+s+")"),s}function p(t){if(t){for(var e=t,n=0;n<e.length&&" "===t[n];n+=1)e=e.replace(" ","&nbsp;");return e}return t}function d(t){if(t){for(var e=t,n=e.length-1;n>=0&&" "===e[n];n-=1)e=e.substring(0,n)+"&nbsp;"+e.substring(n+1);return e}return t}function I(t,e,n,a){if(r(t))return o(e,t.entityRanges[0].key,void 0,a);var u=[],s=i(t,n);return s.forEach(function(n,r){var o=g(t,e,n,a);0===r&&(o=p(o)),r===s.length-1&&(o=d(o)),u.push(o)}),u.join("")}function E(t){var e="";return(0,C.forEach)(t,function(t,n){e+=t+":"+n+";"}),e}function T(t,e){var n=E(t);return n?'<span style="'+n+'">'+e+"</span>":e}function R(t,e,n,r,o,a){var i=[];i.push(e[t.type]);var u=I(t,n,r,o);return t.data&&(u=T(t.data,u)),i.push(u),i.push(a&&a.emptyLineBeforeBlock?"\n\n":"\n"),i.join("")}function L(t){for(var e="",n=0;n<4*t;n+=1)e+=" ";return e}function v(t,e,n,r){var o=[];if(t){var a=S({},N,r&&r.blockTypesMapping&&r.blockTypesMapping),i=t.blocks,u=t.entityMap;i&&i.length>0&&i.forEach(function(t){var i=R(t,a,u,e,n,r);(0,C.isList)(t.type)&&(i=L(t.depth)+i),o.push(i)})}return o.join("")}Object.defineProperty(e,"__esModule",{value:!0});var S=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(t[r]=n[r])}return t};e.sameStyleAsPrevious=s,e.getStylesAtOffset=f,e.addInlineStyleMarkdown=O,e.addStylePropertyMarkdown=y,e.trimLeadingZeros=p,e.trimTrailingZeros=d,e.getBlockContentMarkdown=I,e.getBlockStyle=E,e.default=v;var C=n(2),N={unstyled:"","header-one":"# ","header-two":"## ","header-three":"### ","header-four":"#### ","header-five":"##### ","header-six":"###### ","unordered-list-item":"- ","ordered-list-item":"1. ",blockquote:"> ",code:" "}},function(t,e,n){"use strict";function r(t,e){if(t)for(var n in t)({}).hasOwnProperty.call(t,n)&&e(n,t[n])}function o(t){return void 0===t||null===t||0===t.length||0===t.trim().length}function a(t){return"unordered-list-item"===t||"ordered-list-item"===t}Object.defineProperty(e,"__esModule",{value:!0}),e.forEach=r,e.isEmptyString=o,e.isList=a}]);
{
"name": "draftjs-to-markdown",
"version": "0.4.3",
"version": "0.4.4",
"description": "A library for draftjs to markdown conversion.",

@@ -5,0 +5,0 @@ "main": "lib/draftjs-to-markdown.js",

@@ -7,10 +7,11 @@ # DraftJS TO Markdown

## Installing
## Installation
`npm install draftjs-to-markdown`
## Using
## Usage
```
import draftToMarkdown from 'draftjs-to-markdown';
import { convertToRaw } from 'draft-js;

@@ -31,3 +32,3 @@ const rawContentState = convertToRaw(editorState.getCurrentContent());

```
Here trigger is character that marks starting of hashtag (default '#') and separator is character that separates characters (default ' ').
Here trigger is character that marks starting of hashtag (default '#') and separator is character that separates characters (default ' '). These fields are optional.

@@ -37,18 +38,21 @@ 3. **customEntityTransform**: Its function to render custom defined entities by user, its also optional.

4. **config**: Object to pass configuration options.
```
{
blockTypesMapping : {/* mappings */},
emptyLineBeforeBlock : true
}
```
blockTypesMapping overrides the default markdown syntax. For example, to use an asterisk rather than a dash for unordered-list-item:
```
{
blockTypesMapping : {
'unordered-list-item': '* '
}
}
```
By default only one line break is added before a block. Pass ```emptyLineBeforeBlock: true``` to add two line breaks before every block.
```
{
blockTypesMapping : {/* mappings */},
emptyLineBeforeBlock : true
}
```
blockTypesMapping overrides the default markdown syntax. For example, to use an asterisk rather than a dash for unordered-list-item:
```
{
blockTypesMapping : {
'unordered-list-item': '* '
}
}
```
By default only one line break is added before a block. Pass ```emptyLineBeforeBlock: true``` to add two line breaks before every block.
**editorState** is instance of DraftJS [EditorState](https://draftjs.org/docs/api-reference-editor-state.html#content).
## Supported conversions

@@ -59,16 +63,17 @@ Following is the list of conversions it supports:

|| Block Type | Markdown |
| -------- | -------- | -------- |
| 1 | header-one | # |
| 2 | header-two | ## |
| 3 | header-three | ### |
| 4 | header-four | #### |
| 5 | header-five | ##### |
| 6 | header-six | ###### |
| 7 | unordered-list-item | - |
| 8 | ordered-list-item | 1. |
| 9 | blockquote | > |
| 10 | unstyled | |
|| Block Type | Markdown |
| -------- | -------- | -------- |
| 1 | header-one | `#` |
| 2 | header-two | `##` |
| 3 | header-three | `###` |
| 4 | header-four | `####` |
| 5 | header-five | `#####` |
| 6 | header-six | `######` |
| 7 | unordered-list-item | `-` |
| 8 | ordered-list-item | `1.` |
| 9 | blockquote | `>` |
| 10 | code | ` ` |
| 11 | unstyled | `` |
It performs these additional changes to text of blocks:
It performs these additional changes to text of blocks:
- replace blank space in beginning and end of block with `&nbsp;`

@@ -84,3 +89,3 @@ - replace `\n` with `\s\s\n`

4. Converts inline styles color, background-color, font-size, font-family to a span tag with inline style details:
`<span style="color:xyz;font-size:xx">`. The inline styles should start with strings `color` or `font-size` like `color-red`, `color-green` or `fontsize-12`, `fontsize-20`.
`<span style="color:xyz;font-size:xx">`. (In the input JSON, inline styles should start with strings `color` or `font-size` like `color-red`, `color-green` or `fontsize-12`, `fontsize-20`).

@@ -91,11 +96,13 @@ 5. Converts entity range of type link to :`[Link Text](Link URL)`.

7. Converts atomic entity image to image tag using entity data src for image source: `!(Image Source)`.
7. Converts atomic entity image to image tag using entity data src for image source: `![alt text](Image Source)`.
8. Converts embedded links to HTML iframe tags <iframe ... />.
8. Converts embedded links to HTML iframe tags `<iframe ... />`.
9. For block level styles like text-alignment add `<span>` with `style` property around block content.
10. Supports using function `customEntityTransform` for custom draftjs entities.
10. Supports using function `customEntityTransform` for custom draftjs entities. If present its call to generate markdown for entity. It can take 2 parameter:
1. `entity` ( object with { type, mutalibity, data})
2. `text` text present in the block.
## License
MIT.
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc