Misskeyで使われているMarkdown風の書式をライブラリとして扱うことができます。
Misskeyのソースコードをほぼそのまま抜き出しています。
npm install mfmf
const mfm = require('mfmf')
const mfmstring = "**mfmf**"
const html = mfm.render(mfm.parse(mfmstring), [])
console.log(html)
// => `<p data-mfm="root"><b data-mfm="bold">mfmf</b></p>`
MfmForestを渡すと、HTML文字列が返ってきます。(toHtmlのエイリアスです。)
Misskey内部処理で必要だったものです。リモートのメンションに関係するものです。
オプションを指定します。
何も指定しないときでも空のオブジェクト{}を渡してください。
初期値は特記のない限り全てfalseまたは''です。
jmstyle boolean
true……joinmisskey用のHTML(付属のCSS/SASSで利用可)false……リモート送信用(ただしdata-mfm属性は自動で付加されます。不要な場合は取り除いてください。)url string : タグやリプライのリンクのプレフィクスです。不要なので?などのクエリを指定しておくとよいと思います。animate : trueに設定するとanimate.cssのクラスを出力します。codeTagAsDiv : trueに設定するとpre・codeタグだったものがdiv.pre・div.codeになります。rootTagName : ルート要素のタグを指定します。初期値はjmstyle ? 'div' : 'p'です。MFMテキストからMfmForestを生成します。
HTMLをMFMに変換します。fromHtmlのエイリアスです。
SASSで記述されており、src/styleにソースがあります。プレビュー用にdist/style/mfm.cssもあります。
mfmfは、mfmの実行に必要なpreludeやtypesなどもexportします。
npm run build
gulp test