@milkdown/preset-commonmark 6.0.0-next.1 → 6.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/index.es.js CHANGED
@@ -19,7 +19,7 @@ var __spreadValues = (a, b) => {
19
19
  var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
20
  import { createMark, createShortcut, createNode, createPlugin, AtomList } from "@milkdown/utils";
21
21
  import { createCmdKey, createCmd, schemaCtx, commandsCtx, editorViewCtx } from "@milkdown/core";
22
- import { markRule, toggleMark, PluginKey, TextSelection, InputRule, Plugin, wrappingInputRule, wrapIn, textblockTypeInputRule, setBlockType, ReplaceStep, AddMarkStep, Selection, findSelectedNodeOfType, splitListItem, sinkListItem, liftListItem } from "@milkdown/prose";
22
+ import { markRule, toggleMark, PluginKey, TextSelection, InputRule, Plugin, wrappingInputRule, wrapIn, Fragment, textblockTypeInputRule, setBlockType, ReplaceStep, AddMarkStep, Selection, findSelectedNodeOfType, splitListItem, sinkListItem, liftListItem } from "@milkdown/prose";
23
23
  import links from "remark-inline-links";
24
24
  const SupportedKeys = {
25
25
  HardBreak: "HardBreak",
@@ -196,54 +196,56 @@ const link = createMark((utils, options) => {
196
196
  })
197
197
  ],
198
198
  prosePlugins: (type, ctx) => {
199
- var _a, _b, _c;
200
- const inputChipRenderer = utils.themeManager.get("input-chip", {
201
- placeholder: (_b = (_a = options == null ? void 0 : options.input) == null ? void 0 : _a.placeholder) != null ? _b : "Input Web Link",
202
- buttonText: (_c = options == null ? void 0 : options.input) == null ? void 0 : _c.buttonText,
203
- onUpdate: (value) => {
204
- ctx.get(commandsCtx).call(ModifyLink, value);
205
- }
206
- });
207
- const shouldDisplay = (view) => {
208
- const { selection, doc: doc2 } = view.state;
209
- const { from, to } = selection;
210
- return selection.empty && selection instanceof TextSelection && doc2.rangeHasMark(from, from === to ? to + 1 : to, type);
211
- };
212
- const getCurrentLink = (view) => {
213
- const { selection } = view.state;
214
- let node;
215
- const { from, to } = selection;
216
- view.state.doc.nodesBetween(from, from === to ? to + 1 : to, (n) => {
217
- if (type.isInSet(n.marks)) {
218
- node = n;
219
- return false;
220
- }
221
- return;
222
- });
223
- if (!node)
224
- return;
225
- const mark = node.marks.find((m) => m.type === type);
226
- if (!mark)
227
- return;
228
- const value = mark.attrs["href"];
229
- return value;
230
- };
231
- const renderByView = (view) => {
232
- if (!view.editable) {
233
- return;
234
- }
235
- const display = shouldDisplay(view);
236
- if (display) {
237
- inputChipRenderer.show(view);
238
- inputChipRenderer.update(getCurrentLink(view));
239
- } else {
240
- inputChipRenderer.hide();
241
- }
242
- };
243
199
  return [
244
200
  new Plugin({
245
201
  key: key$1,
246
202
  view: (editorView) => {
203
+ var _a, _b, _c;
204
+ const inputChipRenderer = utils.themeManager.get("input-chip", {
205
+ placeholder: (_b = (_a = options == null ? void 0 : options.input) == null ? void 0 : _a.placeholder) != null ? _b : "Input Web Link",
206
+ buttonText: (_c = options == null ? void 0 : options.input) == null ? void 0 : _c.buttonText,
207
+ onUpdate: (value) => {
208
+ ctx.get(commandsCtx).call(ModifyLink, value);
209
+ }
210
+ });
211
+ if (!inputChipRenderer)
212
+ return {};
213
+ const shouldDisplay = (view) => {
214
+ const { selection, doc: doc2 } = view.state;
215
+ const { from, to } = selection;
216
+ return selection.empty && selection instanceof TextSelection && doc2.rangeHasMark(from, from === to ? to + 1 : to, type);
217
+ };
218
+ const getCurrentLink = (view) => {
219
+ const { selection } = view.state;
220
+ let node;
221
+ const { from, to } = selection;
222
+ view.state.doc.nodesBetween(from, from === to ? to + 1 : to, (n) => {
223
+ if (type.isInSet(n.marks)) {
224
+ node = n;
225
+ return false;
226
+ }
227
+ return;
228
+ });
229
+ if (!node)
230
+ return;
231
+ const mark = node.marks.find((m) => m.type === type);
232
+ if (!mark)
233
+ return;
234
+ const value = mark.attrs["href"];
235
+ return value;
236
+ };
237
+ const renderByView = (view) => {
238
+ if (!view.editable) {
239
+ return;
240
+ }
241
+ const display = shouldDisplay(view);
242
+ if (display) {
243
+ inputChipRenderer.show(view);
244
+ inputChipRenderer.update(getCurrentLink(view));
245
+ } else {
246
+ inputChipRenderer.hide();
247
+ }
248
+ };
247
249
  inputChipRenderer.init(editorView);
248
250
  renderByView(editorView);
249
251
  return {
@@ -405,6 +407,25 @@ const codeFence = createNode((utils, options) => {
405
407
  }
406
408
  },
407
409
  parseDOM: [
410
+ {
411
+ tag: "div.code-fence-container",
412
+ preserveWhitespace: "full",
413
+ getAttrs: (dom) => {
414
+ var _a;
415
+ if (!(dom instanceof HTMLElement)) {
416
+ throw new Error("Parse DOM error.");
417
+ }
418
+ return { language: (_a = dom.querySelector("pre")) == null ? void 0 : _a.dataset["language"] };
419
+ },
420
+ getContent: (dom, schema) => {
421
+ var _a, _b;
422
+ if (!(dom instanceof HTMLElement)) {
423
+ throw new Error("Parse DOM error.");
424
+ }
425
+ const textNode = schema.text((_b = (_a = dom.querySelector("pre")) == null ? void 0 : _a.textContent) != null ? _b : "");
426
+ return Fragment.from(textNode);
427
+ }
428
+ },
408
429
  {
409
430
  tag: "pre",
410
431
  preserveWhitespace: "full",
@@ -946,40 +967,42 @@ const image = createNode((utils, options) => {
946
967
  };
947
968
  },
948
969
  prosePlugins: (type, ctx) => {
949
- var _a, _b, _c;
950
- const inputChipRenderer = utils.themeManager.get("input-chip", {
951
- placeholder: (_b = (_a = options == null ? void 0 : options.input) == null ? void 0 : _a.placeholder) != null ? _b : "Input Image Link",
952
- buttonText: (_c = options == null ? void 0 : options.input) == null ? void 0 : _c.buttonText,
953
- onUpdate: (value) => {
954
- ctx.get(commandsCtx).call(ModifyImage, value);
955
- }
956
- });
957
- const shouldDisplay = (view) => {
958
- return Boolean(type && findSelectedNodeOfType(view.state.selection, type));
959
- };
960
- const getCurrentLink = (view) => {
961
- const result = findSelectedNodeOfType(view.state.selection, type);
962
- if (!result)
963
- return;
964
- const value = result.node.attrs["src"];
965
- return value;
966
- };
967
- const renderByView = (view) => {
968
- if (!view.editable) {
969
- return;
970
- }
971
- const display = shouldDisplay(view);
972
- if (display) {
973
- inputChipRenderer.show(view);
974
- inputChipRenderer.update(getCurrentLink(view));
975
- } else {
976
- inputChipRenderer.hide();
977
- }
978
- };
979
970
  return [
980
971
  new Plugin({
981
972
  key,
982
973
  view: (editorView) => {
974
+ var _a, _b, _c;
975
+ const inputChipRenderer = utils.themeManager.get("input-chip", {
976
+ placeholder: (_b = (_a = options == null ? void 0 : options.input) == null ? void 0 : _a.placeholder) != null ? _b : "Input Image Link",
977
+ buttonText: (_c = options == null ? void 0 : options.input) == null ? void 0 : _c.buttonText,
978
+ onUpdate: (value) => {
979
+ ctx.get(commandsCtx).call(ModifyImage, value);
980
+ }
981
+ });
982
+ if (!inputChipRenderer)
983
+ return {};
984
+ const shouldDisplay = (view) => {
985
+ return Boolean(type && findSelectedNodeOfType(view.state.selection, type));
986
+ };
987
+ const getCurrentLink = (view) => {
988
+ const result = findSelectedNodeOfType(view.state.selection, type);
989
+ if (!result)
990
+ return;
991
+ const value = result.node.attrs["src"];
992
+ return value;
993
+ };
994
+ const renderByView = (view) => {
995
+ if (!view.editable) {
996
+ return;
997
+ }
998
+ const display = shouldDisplay(view);
999
+ if (display) {
1000
+ inputChipRenderer.show(view);
1001
+ inputChipRenderer.update(getCurrentLink(view));
1002
+ } else {
1003
+ inputChipRenderer.hide();
1004
+ }
1005
+ };
983
1006
  inputChipRenderer.init(editorView);
984
1007
  renderByView(editorView);
985
1008
  return {
@@ -1 +1 @@
1
- {"version":3,"file":"index.es.js","sources":["../src/supported-keys.ts","../src/mark/code-inline.ts","../src/mark/em.ts","../src/mark/link.ts","../src/mark/strong.ts","../src/mark/index.ts","../src/node/blockquote.ts","../src/node/bullet-list.ts","../src/node/code-fence.ts","../src/node/doc.ts","../src/node/hardbreak.ts","../src/node/heading.ts","../src/node/hr.ts","../src/node/image.ts","../src/node/list-item.ts","../src/node/ordered-list.ts","../src/node/paragraph.ts","../src/node/text.ts","../src/node/index.ts","../src/plugin/filter-html.ts","../src/plugin/index.ts","../src/index.ts"],"sourcesContent":["/* Copyright 2021, Milkdown by Mirone. */\nexport const SupportedKeys = {\n HardBreak: 'HardBreak',\n Blockquote: 'Blockquote',\n BulletList: 'BulletList',\n OrderedList: 'OrderedList',\n CodeFence: 'CodeFence',\n H1: 'H1',\n H2: 'H2',\n H3: 'H3',\n H4: 'H4',\n H5: 'H5',\n H6: 'H6',\n Text: 'Text',\n CodeInline: 'CodeInline',\n Em: 'Em',\n Bold: 'Bold',\n NextListItem: 'NextListItem',\n SinkListItem: 'SinkListItem',\n LiftListItem: 'LiftListItem',\n} as const;\n\nexport type SupportedKeys = typeof SupportedKeys;\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { markRule, toggleMark } from '@milkdown/prose';\nimport { createMark, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['CodeInline'];\nconst id = 'code_inline';\n\nexport const ToggleInlineCode = createCmdKey('ToggleInlineCode');\n\nexport const codeInline = createMark<Keys>((utils) => {\n return {\n id,\n schema: () => ({\n priority: 100,\n code: true,\n inclusive: false,\n parseDOM: [{ tag: 'code' }],\n toDOM: (mark) => ['code', { class: utils.getClassName(mark.attrs, 'code-inline') }],\n parseMarkdown: {\n match: (node) => node.type === 'inlineCode',\n runner: (state, node, markType) => {\n state.openMark(markType);\n state.addText(node['value'] as string);\n state.closeMark(markType);\n },\n },\n toMarkdown: {\n match: (mark) => mark.type.name === id,\n runner: (state, mark, node) => {\n state.withMark(mark, 'inlineCode', node.text || '');\n },\n },\n }),\n inputRules: (markType) => [markRule(/(?:^|[^`])(`([^`]+)`)$/, markType)],\n commands: (markType) => [createCmd(ToggleInlineCode, () => toggleMark(markType))],\n shortcuts: {\n [SupportedKeys.CodeInline]: createShortcut(ToggleInlineCode, 'Mod-e'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { markRule, toggleMark } from '@milkdown/prose';\nimport { createMark, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['Em'];\n\nconst id = 'em';\n\nexport const ToggleItalic = createCmdKey('ToggleItalic');\n\nexport const em = createMark<Keys>((utils) => ({\n id,\n schema: () => ({\n parseDOM: [\n { tag: 'i' },\n { tag: 'em' },\n { style: 'font-style', getAttrs: (value) => (value === 'italic') as false },\n ],\n toDOM: (mark) => ['em', { class: utils.getClassName(mark.attrs, id) }],\n parseMarkdown: {\n match: (node) => node.type === 'emphasis',\n runner: (state, node, markType) => {\n state.openMark(markType);\n state.next(node.children);\n state.closeMark(markType);\n },\n },\n toMarkdown: {\n match: (mark) => mark.type.name === id,\n runner: (state, mark) => {\n state.withMark(mark, 'emphasis');\n },\n },\n }),\n inputRules: (markType) => [\n markRule(/(?:^|[^_])(_([^_]+)_)$/, markType),\n markRule(/(?:^|[^*])(\\*([^*]+)\\*)$/, markType),\n ],\n commands: (markType) => [createCmd(ToggleItalic, () => toggleMark(markType))],\n shortcuts: {\n [SupportedKeys.Em]: createShortcut(ToggleItalic, 'Mod-i'),\n },\n}));\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { commandsCtx, createCmd, createCmdKey, schemaCtx, ThemeInputChipType } from '@milkdown/core';\nimport {\n EditorView,\n InputRule,\n Node as ProseNode,\n Plugin,\n PluginKey,\n TextSelection,\n toggleMark,\n} from '@milkdown/prose';\nimport { createMark } from '@milkdown/utils';\n\nconst key = new PluginKey('MILKDOWN_PLUGIN_LINK_INPUT');\n\nexport const ToggleLink = createCmdKey<string>('ToggleLink');\nexport const ModifyLink = createCmdKey<string>('ModifyLink');\nconst id = 'link';\nexport type LinkOptions = {\n input: {\n placeholder: string;\n buttonText?: string;\n };\n};\nexport const link = createMark<string, LinkOptions>((utils, options) => {\n return {\n id,\n schema: () => ({\n attrs: {\n href: {},\n title: { default: null },\n },\n inclusive: false,\n parseDOM: [\n {\n tag: 'a[href]',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error();\n }\n return { href: dom.getAttribute('href'), title: dom.getAttribute('title') };\n },\n },\n ],\n toDOM: (mark) => ['a', { ...mark.attrs, class: utils.getClassName(mark.attrs, id) }],\n parseMarkdown: {\n match: (node) => node.type === 'link',\n runner: (state, node, markType) => {\n const url = node['url'] as string;\n const title = node['title'] as string;\n state.openMark(markType, { href: url, title });\n state.next(node.children);\n state.closeMark(markType);\n },\n },\n toMarkdown: {\n match: (mark) => mark.type.name === id,\n runner: (state, mark) => {\n state.withMark(mark, 'link', undefined, {\n title: mark.attrs['title'],\n url: mark.attrs['href'],\n });\n },\n },\n }),\n commands: (markType) => [\n createCmd(ToggleLink, (href = '') => toggleMark(markType, { href })),\n createCmd(ModifyLink, (href = '') => (state, dispatch) => {\n if (!dispatch) return false;\n\n const { marks } = state.schema;\n\n let node: ProseNode | undefined;\n let pos = -1;\n const { selection } = state;\n state.doc.nodesBetween(selection.from, selection.to, (n, p) => {\n if (marks.link.isInSet(n.marks)) {\n node = n;\n pos = p;\n return false;\n }\n return;\n });\n if (!node) return false;\n\n const mark = node.marks.find(({ type }) => type === markType);\n if (!mark) return false;\n\n const start = pos;\n const end = pos + node.nodeSize;\n const { tr } = state;\n const linkMark = marks.link.create({ ...mark.attrs, href });\n dispatch(\n tr\n .removeMark(start, end, mark)\n .addMark(start, end, linkMark)\n .setSelection(new TextSelection(tr.selection.$anchor))\n .scrollIntoView(),\n );\n\n return true;\n }),\n ],\n inputRules: (markType, ctx) => [\n new InputRule(/\\[(?<text>.*?)]\\((?<href>.*?)(?=“|\\))\"?(?<title>[^\"]+)?\"?\\)/, (state, match, start, end) => {\n const [okay, text = '', href, title] = match;\n const { tr } = state;\n if (okay) {\n const content = text || 'link';\n tr.replaceWith(start, end, ctx.get(schemaCtx).text(content)).addMark(\n start,\n content.length + start,\n markType.create({ title, href }),\n );\n }\n\n return tr;\n }),\n ],\n prosePlugins: (type, ctx) => {\n const inputChipRenderer = utils.themeManager.get<ThemeInputChipType>('input-chip', {\n placeholder: options?.input?.placeholder ?? 'Input Web Link',\n buttonText: options?.input?.buttonText,\n onUpdate: (value) => {\n ctx.get(commandsCtx).call(ModifyLink, value);\n },\n });\n const shouldDisplay = (view: EditorView) => {\n const { selection, doc } = view.state;\n const { from, to } = selection;\n\n return (\n selection.empty &&\n selection instanceof TextSelection &&\n doc.rangeHasMark(from, from === to ? to + 1 : to, type)\n );\n };\n const getCurrentLink = (view: EditorView) => {\n const { selection } = view.state;\n let node: ProseNode | undefined;\n const { from, to } = selection;\n view.state.doc.nodesBetween(from, from === to ? to + 1 : to, (n) => {\n if (type.isInSet(n.marks)) {\n node = n;\n return false;\n }\n return;\n });\n if (!node) return;\n\n const mark = node.marks.find((m) => m.type === type);\n if (!mark) return;\n\n const value = mark.attrs['href'];\n return value;\n };\n const renderByView = (view: EditorView) => {\n if (!view.editable) {\n return;\n }\n const display = shouldDisplay(view);\n if (display) {\n inputChipRenderer.show(view);\n inputChipRenderer.update(getCurrentLink(view));\n } else {\n inputChipRenderer.hide();\n }\n };\n return [\n new Plugin({\n key,\n view: (editorView) => {\n inputChipRenderer.init(editorView);\n renderByView(editorView);\n\n return {\n update: (view, prevState) => {\n const isEqualSelection =\n prevState?.doc.eq(view.state.doc) && prevState.selection.eq(view.state.selection);\n if (isEqualSelection) return;\n\n renderByView(view);\n },\n destroy: () => {\n inputChipRenderer.destroy();\n },\n };\n },\n }),\n ];\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { markRule, toggleMark } from '@milkdown/prose';\nimport { createMark, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['Bold'];\nconst id = 'strong';\nexport const ToggleBold = createCmdKey('ToggleBold');\nexport const strong = createMark<Keys>((utils) => {\n return {\n id,\n schema: () => ({\n parseDOM: [\n { tag: 'b' },\n { tag: 'strong' },\n { style: 'font-style', getAttrs: (value) => (value === 'bold') as false },\n ],\n toDOM: (mark) => ['strong', { class: utils.getClassName(mark.attrs, id) }],\n parseMarkdown: {\n match: (node) => node.type === 'strong',\n runner: (state, node, markType) => {\n state.openMark(markType);\n state.next(node.children);\n state.closeMark(markType);\n },\n },\n toMarkdown: {\n match: (mark) => mark.type.name === id,\n runner: (state, mark) => {\n state.withMark(mark, 'strong');\n },\n },\n }),\n inputRules: (markType) => [\n markRule(/(?:__)([^_]+)(?:__)$/, markType),\n markRule(/(?:\\*\\*)([^*]+)(?:\\*\\*)$/, markType),\n ],\n commands: (markType) => [createCmd(ToggleBold, () => toggleMark(markType))],\n shortcuts: {\n [SupportedKeys.Bold]: createShortcut(ToggleBold, 'Mod-b'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { codeInline } from './code-inline';\nimport { em } from './em';\nimport { link } from './link';\nimport { strong } from './strong';\n\nexport const marks = [codeInline(), em(), strong(), link()];\n\nexport * from './code-inline';\nexport * from './em';\nexport * from './link';\nexport * from './strong';\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { wrapIn, wrappingInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['Blockquote'];\n\nconst id = 'blockquote';\n\nexport const WrapInBlockquote = createCmdKey('WrapInBlockquote');\n\nexport const blockquote = createNode<Keys>((utils) => {\n return {\n id,\n schema: () => ({\n content: 'block+',\n group: 'block',\n defining: true,\n parseDOM: [{ tag: 'blockquote' }],\n toDOM: (node) => ['blockquote', { class: utils.getClassName(node.attrs, id) }, 0],\n parseMarkdown: {\n match: ({ type }) => type === id,\n runner: (state, node, type) => {\n state.openNode(type).next(node.children).closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('blockquote').next(node.content).closeNode();\n },\n },\n }),\n inputRules: (nodeType) => [wrappingInputRule(/^\\s*>\\s$/, nodeType)],\n commands: (nodeType) => [createCmd(WrapInBlockquote, () => wrapIn(nodeType))],\n shortcuts: {\n [SupportedKeys.Blockquote]: createShortcut(WrapInBlockquote, 'Mod-Shift-b'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { wrapIn, wrappingInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['BulletList'];\n\nexport const WrapInBulletList = createCmdKey('WrapInBulletList');\n\nexport const bulletList = createNode<Keys>((utils) => {\n const id = 'bullet_list';\n return {\n id,\n schema: () => ({\n content: 'listItem+',\n group: 'block',\n parseDOM: [{ tag: 'ul' }],\n toDOM: (node) => {\n return ['ul', { class: utils.getClassName(node.attrs, 'bullet-list') }, 0];\n },\n parseMarkdown: {\n match: ({ type, ordered }) => type === 'list' && !ordered,\n runner: (state, node, type) => {\n state.openNode(type).next(node.children).closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('list', undefined, { ordered: false }).next(node.content).closeNode();\n },\n },\n }),\n inputRules: (nodeType) => [wrappingInputRule(/^\\s*([-+*])\\s$/, nodeType)],\n commands: (nodeType) => [createCmd(WrapInBulletList, () => wrapIn(nodeType))],\n shortcuts: {\n [SupportedKeys.BulletList]: createShortcut(WrapInBulletList, 'Mod-Alt-8'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey, editorViewCtx, ThemeCodeFenceType } from '@milkdown/core';\nimport { setBlockType, textblockTypeInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['CodeFence'];\n\nconst languageOptions = [\n '',\n 'javascript',\n 'typescript',\n 'bash',\n 'sql',\n 'json',\n 'html',\n 'css',\n 'c',\n 'cpp',\n 'java',\n 'ruby',\n 'python',\n 'go',\n 'rust',\n 'markdown',\n];\n\nexport const backtickInputRegex = /^```(?<language>[a-z]*)?[\\s\\n]$/;\nexport const tildeInputRegex = /^~~~(?<language>[a-z]*)?[\\s\\n]$/;\n\nexport const TurnIntoCodeFence = createCmdKey('TurnIntoCodeFence');\n\nconst id = 'fence';\nexport const codeFence = createNode<Keys, { languageList?: string[] }>((utils, options) => {\n const languageList = options?.languageList || languageOptions;\n\n return {\n id,\n schema: (ctx) => ({\n content: 'text*',\n group: 'block',\n marks: '',\n defining: true,\n code: true,\n attrs: {\n language: {\n default: '',\n },\n fold: {\n default: true,\n },\n },\n parseDOM: [\n {\n tag: 'pre',\n preserveWhitespace: 'full',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error('Parse DOM error.');\n }\n return { language: dom.dataset['language'] };\n },\n },\n ],\n toDOM: (node) => {\n const select = document.createElement('select');\n languageList.forEach((lang) => {\n const option = document.createElement('option');\n option.value = lang;\n option.innerText = !lang ? '--' : lang;\n if (lang === node.attrs['language']) {\n option.selected = true;\n }\n select.appendChild(option);\n });\n select.onchange = (e) => {\n const target = e.target;\n if (!(target instanceof HTMLSelectElement)) {\n return;\n }\n const view = ctx.get(editorViewCtx);\n if (!view.editable) {\n target.value = node.attrs['language'];\n return;\n }\n\n const { top, left } = target.getBoundingClientRect();\n const result = view.posAtCoords({ top, left });\n if (!result) return;\n\n const { tr } = view.state;\n\n view.dispatch(\n tr.setNodeMarkup(result.inside, undefined, {\n ...node.attrs,\n language: target.value,\n }),\n );\n };\n return [\n 'div',\n {\n class: 'code-fence-container',\n },\n select,\n [\n 'pre',\n {\n 'data-language': node.attrs['language'],\n class: utils.getClassName(node.attrs, 'code-fence'),\n },\n ['code', { spellCheck: 'false' }, 0],\n ],\n ];\n },\n parseMarkdown: {\n match: ({ type }) => type === 'code',\n runner: (state, node, type) => {\n const language = node['lang'] as string;\n const value = node['value'] as string;\n state.openNode(type, { language });\n if (value) {\n state.addText(value);\n }\n state.closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.addNode('code', undefined, node.content.firstChild?.text || '', {\n lang: node.attrs['language'],\n });\n },\n },\n }),\n inputRules: (nodeType) => [\n textblockTypeInputRule(backtickInputRegex, nodeType, (match) => {\n const [ok, language] = match;\n if (!ok) return;\n return { language };\n }),\n textblockTypeInputRule(tildeInputRegex, nodeType, (match) => {\n const [ok, language] = match;\n if (!ok) return;\n return { language };\n }),\n ],\n commands: (nodeType) => [createCmd(TurnIntoCodeFence, () => setBlockType(nodeType))],\n shortcuts: {\n [SupportedKeys.CodeFence]: createShortcut(TurnIntoCodeFence, 'Mod-Alt-c'),\n },\n view: () => (node, view, getPos) => {\n let currNode = node;\n\n const onSelectLanguage = (language: string) => {\n const { tr } = view.state;\n view.dispatch(\n tr.setNodeMarkup(getPos(), undefined, {\n fold: true,\n language,\n }),\n );\n };\n const onBlur = () => {\n const { tr } = view.state;\n\n view.dispatch(\n tr.setNodeMarkup(getPos(), undefined, {\n ...currNode.attrs,\n fold: true,\n }),\n );\n };\n const onFocus = () => {\n const { tr } = view.state;\n\n view.dispatch(\n tr.setNodeMarkup(getPos(), undefined, {\n ...currNode.attrs,\n fold: false,\n }),\n );\n };\n\n const renderer = utils.themeManager.get<ThemeCodeFenceType>('code-fence', {\n onBlur,\n onFocus,\n onSelectLanguage,\n editable: () => view.editable,\n languageList,\n });\n if (!renderer) return {};\n\n const { dom, contentDOM, onUpdate, onDestroy } = renderer;\n onUpdate(currNode);\n\n return {\n dom,\n contentDOM,\n update: (updatedNode) => {\n if (updatedNode.type.name !== id) return false;\n currNode = updatedNode;\n onUpdate(currNode);\n\n return true;\n },\n destroy: onDestroy,\n };\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createNode } from '@milkdown/utils';\n\nexport const doc = createNode(() => {\n return {\n id: 'doc',\n schema: () => ({\n content: 'block+',\n parseMarkdown: {\n match: ({ type }) => type === 'root',\n runner: (state, node, type) => {\n state.injectRoot(node, type);\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === 'doc',\n runner: (state, node) => {\n state.openNode('root');\n state.next(node.content);\n },\n },\n }),\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { AddMarkStep, Plugin, PluginKey, ReplaceStep } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['HardBreak'];\n\nexport const InsertHardbreak = createCmdKey('InsertHardbreak');\n\nexport const hardbreak = createNode<Keys>((utils) => {\n return {\n id: 'hardbreak',\n schema: () => ({\n inline: true,\n group: 'inline',\n selectable: false,\n parseDOM: [{ tag: 'br' }],\n toDOM: (node) => ['br', { class: utils.getClassName(node.attrs, 'hardbreak') }],\n parseMarkdown: {\n match: ({ type }) => type === 'break',\n runner: (state, _, type) => {\n state.addNode(type);\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === 'hardbreak',\n runner: (state) => {\n state.addNode('break');\n },\n },\n }),\n commands: (type) => [\n createCmd(InsertHardbreak, () => (state, dispatch) => {\n dispatch?.(state.tr.setMeta('hardbreak', true).replaceSelectionWith(type.create()).scrollIntoView());\n return true;\n }),\n ],\n shortcuts: {\n [SupportedKeys.HardBreak]: createShortcut(InsertHardbreak, 'Shift-Enter'),\n },\n prosePlugins: (type) => [\n new Plugin({\n key: new PluginKey('MILKDOWN_PLUGIN_HARDBREAK_MARKS'),\n appendTransaction: (trs, _oldState, newState) => {\n if (!trs.length) return;\n const [tr] = trs;\n if (!tr) return;\n\n const [step] = tr.steps;\n\n const isInsertHr = tr.getMeta('hardbreak');\n if (isInsertHr) {\n if (!(step instanceof ReplaceStep)) {\n return;\n }\n const { from } = step as unknown as { from: number };\n return newState.tr.setNodeMarkup(from, type, undefined, []);\n }\n\n const isAddMarkStep = step instanceof AddMarkStep;\n if (isAddMarkStep) {\n let _tr = newState.tr;\n const { from, to } = step as unknown as { from: number; to: number };\n newState.doc.nodesBetween(from, to, (node, pos) => {\n if (node.type === type) {\n _tr = _tr.setNodeMarkup(pos, type, undefined, []);\n }\n });\n\n return _tr;\n }\n\n return;\n },\n }),\n ],\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey, editorViewCtx } from '@milkdown/core';\nimport {\n EditorState,\n Node,\n Plugin,\n PluginKey,\n setBlockType,\n textblockTypeInputRule,\n Transaction,\n} from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\nconst headingIndex = Array(6)\n .fill(0)\n .map((_, i) => i + 1);\n\ntype Keys =\n | SupportedKeys['H1']\n | SupportedKeys['H2']\n | SupportedKeys['H3']\n | SupportedKeys['H4']\n | SupportedKeys['H5']\n | SupportedKeys['H6'];\n\nexport const TurnIntoHeading = createCmdKey<number>('TurnIntoHeading');\n\nexport const headingPluginKey = new PluginKey('MILKDOWN_PLUGIN_ID');\n\nexport const heading = createNode<Keys>((utils) => {\n const id = 'heading';\n\n return {\n id,\n schema: () => ({\n content: 'inline*',\n group: 'block',\n defining: true,\n attrs: {\n id: {\n default: '',\n },\n level: {\n default: 1,\n },\n },\n parseDOM: headingIndex.map((x) => ({\n tag: `h${x}`,\n getAttrs: (node) => {\n if (!(node instanceof HTMLElement)) {\n throw new Error();\n }\n return { level: x, id: node.id };\n },\n })),\n toDOM: (node) => {\n return [\n `h${node.attrs['level']}`,\n {\n id: node.attrs['id'] || node.textContent.split(' ').join('-').toLocaleLowerCase(),\n class: utils.getClassName(node.attrs, `heading h${node.attrs['level']}`),\n },\n 0,\n ];\n },\n parseMarkdown: {\n match: ({ type }) => type === id,\n runner: (state, node, type) => {\n const depth = node['depth'] as number;\n state.openNode(type, { level: depth });\n state.next(node.children);\n state.closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('heading', undefined, { depth: node.attrs['level'] });\n state.next(node.content);\n state.closeNode();\n },\n },\n }),\n inputRules: (type) =>\n headingIndex.map((x) =>\n textblockTypeInputRule(new RegExp(`^(#{1,${x}})\\\\s$`), type, () => ({\n level: x,\n })),\n ),\n commands: (type) => [createCmd(TurnIntoHeading, (level = 1) => setBlockType(type, { level }))],\n shortcuts: {\n [SupportedKeys.H1]: createShortcut(TurnIntoHeading, 'Mod-Alt-1', 1),\n [SupportedKeys.H2]: createShortcut(TurnIntoHeading, 'Mod-Alt-2', 2),\n [SupportedKeys.H3]: createShortcut(TurnIntoHeading, 'Mod-Alt-3', 3),\n [SupportedKeys.H4]: createShortcut(TurnIntoHeading, 'Mod-Alt-4', 4),\n [SupportedKeys.H5]: createShortcut(TurnIntoHeading, 'Mod-Alt-5', 5),\n [SupportedKeys.H6]: createShortcut(TurnIntoHeading, 'Mod-Alt-6', 6),\n },\n prosePlugins: (type, ctx) => {\n let lock = false;\n const createId = (node: Node) => {\n return node.textContent\n .replace(/[\\p{P}\\p{S}]/gu, '')\n .replace(/\\s/g, '')\n .trim();\n };\n const walkThrough = (state: EditorState, callback: (tr: Transaction) => void) => {\n const tr = state.tr;\n state.doc.descendants((node, pos) => {\n if (node.type === type && !lock) {\n if (node.textContent.trim().length === 0) {\n return;\n }\n const attrs = node.attrs;\n const id = createId(node);\n\n if (attrs['id'] !== id) {\n tr.setMeta(headingPluginKey, true).setNodeMarkup(pos, undefined, {\n ...attrs,\n id,\n });\n }\n }\n });\n callback(tr);\n };\n return [\n new Plugin({\n key: headingPluginKey,\n props: {\n handleDOMEvents: {\n compositionstart: () => {\n lock = true;\n return false;\n },\n compositionend: () => {\n lock = false;\n const view = ctx.get(editorViewCtx);\n setTimeout(() => {\n walkThrough(view.state, (tr) => view.dispatch(tr));\n }, 0);\n return false;\n },\n },\n },\n appendTransaction: (transactions, _, nextState) => {\n let tr: Transaction | null = null;\n\n if (\n transactions.every((transaction) => !transaction.getMeta(headingPluginKey)) &&\n transactions.some((transaction) => transaction.docChanged)\n ) {\n walkThrough(nextState, (t) => {\n tr = t;\n });\n }\n\n return tr;\n },\n }),\n ];\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey, schemaCtx } from '@milkdown/core';\nimport { InputRule, Selection } from '@milkdown/prose';\nimport { createNode } from '@milkdown/utils';\n\nconst id = 'hr';\nexport const InsertHr = createCmdKey<string>('InsertHr');\nexport const hr = createNode((utils) => {\n return {\n id,\n schema: () => ({\n group: 'block',\n parseDOM: [{ tag: 'hr' }],\n toDOM: (node) => ['hr', { class: utils.getClassName(node.attrs, id) }],\n parseMarkdown: {\n match: ({ type }) => type === 'thematicBreak',\n runner: (state, _, type) => {\n state.addNode(type);\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state) => {\n state.addNode('thematicBreak');\n },\n },\n }),\n inputRules: (type) => [\n new InputRule(/^(?:---|___\\s|\\*\\*\\*\\s)$/, (state, match, start, end) => {\n const { tr } = state;\n\n if (match[0]) {\n tr.replaceWith(start - 1, end, type.create());\n }\n\n return tr;\n }),\n ],\n commands: (type, ctx) => [\n createCmd(InsertHr, () => (state, dispatch) => {\n if (!dispatch) return true;\n const { tr, selection } = state;\n const from = selection.from;\n const node = type.create();\n if (!node) {\n return true;\n }\n const _tr = tr.replaceSelectionWith(node).insert(from, ctx.get(schemaCtx).node('paragraph'));\n const sel = Selection.findFrom(_tr.doc.resolve(from), 1, true);\n if (!sel) {\n return true;\n }\n dispatch(_tr.setSelection(sel).scrollIntoView());\n return true;\n }),\n ],\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { commandsCtx, createCmd, createCmdKey, ThemeImageType, ThemeInputChipType } from '@milkdown/core';\nimport { EditorView, findSelectedNodeOfType, InputRule, Plugin, PluginKey } from '@milkdown/prose';\nimport { createNode } from '@milkdown/utils';\n\nexport const ModifyImage = createCmdKey<string>('ModifyImage');\nexport const InsertImage = createCmdKey<string>('InsertImage');\nconst id = 'image';\nexport type ImageOptions = {\n isBlock: boolean;\n placeholder: string;\n input: {\n placeholder: string;\n buttonText?: string;\n };\n};\nconst key = new PluginKey('MILKDOWN_PLUGIN_IMAGE_INPUT');\n\nexport const image = createNode<string, ImageOptions>((utils, options) => {\n return {\n id: 'image',\n schema: () => ({\n inline: true,\n group: 'inline',\n selectable: true,\n draggable: true,\n marks: '',\n atom: true,\n defining: true,\n isolating: true,\n attrs: {\n src: { default: '' },\n alt: { default: null },\n title: { default: null },\n },\n parseDOM: [\n {\n tag: 'img[src]',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error();\n }\n return {\n src: dom.getAttribute('src') || '',\n alt: dom.getAttribute('alt'),\n title: dom.getAttribute('title') || dom.getAttribute('alt'),\n width: dom.getAttribute('width'),\n };\n },\n },\n ],\n toDOM: (node) => {\n return [\n 'img',\n {\n ...node.attrs,\n class: utils.getClassName(node.attrs, id),\n },\n ];\n },\n parseMarkdown: {\n match: ({ type }) => type === id,\n runner: (state, node, type) => {\n const url = node['url'] as string;\n const alt = node['alt'] as string;\n const title = node['title'] as string;\n state.addNode(type, {\n src: url,\n alt,\n title,\n });\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.addNode('image', undefined, undefined, {\n title: node.attrs['title'],\n url: node.attrs['src'],\n alt: node.attrs['alt'],\n });\n },\n },\n }),\n commands: (type) => [\n createCmd(InsertImage, (src = '') => (state, dispatch) => {\n if (!dispatch) return true;\n const { tr } = state;\n const node = type.create({ src });\n if (!node) {\n return true;\n }\n const _tr = tr.replaceSelectionWith(node);\n dispatch(_tr.scrollIntoView());\n return true;\n }),\n createCmd(ModifyImage, (src = '') => (state, dispatch) => {\n const node = findSelectedNodeOfType(state.selection, type);\n if (!node) return false;\n\n const { tr } = state;\n dispatch?.(\n tr.setNodeMarkup(node.pos, undefined, { ...node.node.attrs, loading: true, src }).scrollIntoView(),\n );\n\n return true;\n }),\n ],\n inputRules: (type) => [\n new InputRule(\n /!\\[(?<alt>.*?)]\\((?<filename>.*?)\\s*(?=\"|\\))\"?(?<title>[^\"]+)?\"?\\)/,\n (state, match, start, end) => {\n const [okay, alt, src = '', title] = match;\n const { tr } = state;\n if (okay) {\n tr.replaceWith(start, end, type.create({ src, alt, title }));\n }\n\n return tr;\n },\n ),\n ],\n view: () => (node) => {\n let currNode = node;\n\n const placeholder = options?.placeholder ?? 'Add an Image';\n const isBlock = options?.isBlock ?? false;\n const renderer = utils.themeManager.get<ThemeImageType>('image', {\n placeholder,\n isBlock,\n });\n\n if (!renderer) {\n return {};\n }\n\n const { dom, onUpdate } = renderer;\n onUpdate(currNode);\n\n return {\n dom,\n update: (updatedNode) => {\n if (updatedNode.type.name !== id) return false;\n\n currNode = updatedNode;\n onUpdate(currNode);\n\n return true;\n },\n selectNode: () => {\n dom.classList.add('ProseMirror-selectednode');\n },\n deselectNode: () => {\n dom.classList.remove('ProseMirror-selectednode');\n },\n };\n },\n prosePlugins: (type, ctx) => {\n const inputChipRenderer = utils.themeManager.get<ThemeInputChipType>('input-chip', {\n placeholder: options?.input?.placeholder ?? 'Input Image Link',\n buttonText: options?.input?.buttonText,\n onUpdate: (value) => {\n ctx.get(commandsCtx).call(ModifyImage, value);\n },\n });\n const shouldDisplay = (view: EditorView) => {\n return Boolean(type && findSelectedNodeOfType(view.state.selection, type));\n };\n const getCurrentLink = (view: EditorView) => {\n const result = findSelectedNodeOfType(view.state.selection, type);\n if (!result) return;\n\n const value = result.node.attrs['src'];\n return value;\n };\n const renderByView = (view: EditorView) => {\n if (!view.editable) {\n return;\n }\n const display = shouldDisplay(view);\n if (display) {\n inputChipRenderer.show(view);\n inputChipRenderer.update(getCurrentLink(view));\n } else {\n inputChipRenderer.hide();\n }\n };\n return [\n new Plugin({\n key,\n view: (editorView) => {\n inputChipRenderer.init(editorView);\n renderByView(editorView);\n\n return {\n update: (view, prevState) => {\n const isEqualSelection =\n prevState?.doc.eq(view.state.doc) && prevState.selection.eq(view.state.selection);\n if (isEqualSelection) return;\n\n renderByView(view);\n },\n destroy: () => {\n inputChipRenderer.destroy();\n },\n };\n },\n }),\n ];\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { liftListItem, sinkListItem, splitListItem, wrappingInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['SinkListItem'] | SupportedKeys['LiftListItem'] | SupportedKeys['NextListItem'];\n\nconst id = 'list_item';\n\nexport const SplitListItem = createCmdKey('SplitListItem');\nexport const SinkListItem = createCmdKey('SinkListItem');\nexport const LiftListItem = createCmdKey('LiftListItem');\n\nexport const listItem = createNode<Keys>((utils) => ({\n id,\n schema: () => ({\n group: 'listItem',\n content: 'paragraph block*',\n defining: true,\n parseDOM: [{ tag: 'li' }],\n toDOM: (node) => ['li', { class: utils.getClassName(node.attrs, 'list-item') }, 0],\n parseMarkdown: {\n match: ({ type, checked }) => type === 'listItem' && checked === null,\n runner: (state, node, type) => {\n state.openNode(type);\n state.next(node.children);\n state.closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('listItem');\n state.next(node.content);\n state.closeNode();\n },\n },\n }),\n inputRules: (nodeType) => [wrappingInputRule(/^\\s*([-+*])\\s$/, nodeType)],\n commands: (nodeType) => [\n createCmd(SplitListItem, () => splitListItem(nodeType)),\n createCmd(SinkListItem, () => sinkListItem(nodeType)),\n createCmd(LiftListItem, () => liftListItem(nodeType)),\n ],\n shortcuts: {\n [SupportedKeys.NextListItem]: createShortcut(SplitListItem, 'Enter'),\n [SupportedKeys.SinkListItem]: createShortcut(SinkListItem, 'Mod-]'),\n [SupportedKeys.LiftListItem]: createShortcut(LiftListItem, 'Mod-['),\n },\n}));\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { wrapIn, wrappingInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['OrderedList'];\n\nexport const WrapInOrderedList = createCmdKey('WrapInOrderedList');\n\nconst id = 'ordered_list';\nexport const orderedList = createNode<Keys>((utils) => ({\n id,\n schema: () => ({\n content: 'listItem+',\n group: 'block',\n attrs: {\n order: {\n default: 1,\n },\n },\n parseDOM: [\n {\n tag: 'ol',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error();\n }\n return { order: dom.hasAttribute('start') ? Number(dom.getAttribute('start')) : 1 };\n },\n },\n ],\n toDOM: (node) => [\n 'ol',\n {\n ...(node.attrs['order'] === 1 ? {} : node.attrs['order']),\n class: utils.getClassName(node.attrs, 'ordered-list'),\n },\n 0,\n ],\n parseMarkdown: {\n match: ({ type, ordered }) => type === 'list' && !!ordered,\n runner: (state, node, type) => {\n state.openNode(type).next(node.children).closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('list', undefined, { ordered: true, start: 1 });\n state.next(node.content);\n state.closeNode();\n },\n },\n }),\n inputRules: (nodeType) => [\n wrappingInputRule(\n /^(\\d+)\\.\\s$/,\n nodeType,\n (match) => ({ order: Number(match[1]) }),\n (match, node) => node.childCount + node.attrs['order'] === Number(match[1]),\n ),\n ],\n commands: (nodeType) => [createCmd(WrapInOrderedList, () => wrapIn(nodeType))],\n shortcuts: {\n [SupportedKeys.OrderedList]: createShortcut(WrapInOrderedList, 'Mod-Alt-7'),\n },\n}));\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { setBlockType } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['Text'];\n\nexport const TurnIntoText = createCmdKey('TurnIntoText');\n\nconst id = 'paragraph';\nexport const paragraph = createNode<Keys>((utils) => {\n return {\n id,\n schema: () => ({\n content: 'inline*',\n group: 'block',\n parseDOM: [{ tag: 'p' }],\n toDOM: (node) => ['p', { class: utils.getClassName(node.attrs, id) }, 0],\n parseMarkdown: {\n match: (node) => node.type === 'paragraph',\n runner: (state, node, type) => {\n state.openNode(type);\n if (node.children) {\n state.next(node.children);\n } else {\n state.addText(node['value'] as string);\n }\n state.closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === 'paragraph',\n runner: (state, node) => {\n state.openNode('paragraph');\n state.next(node.content);\n state.closeNode();\n },\n },\n }),\n commands: (nodeType) => [createCmd(TurnIntoText, () => setBlockType(nodeType))],\n shortcuts: {\n [SupportedKeys.Text]: createShortcut(TurnIntoText, 'Mod-Alt-0'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createNode } from '@milkdown/utils';\n\nexport const text = createNode(() => ({\n id: 'text',\n schema: () => ({\n group: 'inline',\n parseMarkdown: {\n match: ({ type }) => type === 'text',\n runner: (state, node) => {\n state.addText(node['value'] as string);\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === 'text',\n runner: (state, node) => {\n state.addNode('text', undefined, node.text as string);\n },\n },\n }),\n}));\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { blockquote } from './blockquote';\nimport { bulletList } from './bullet-list';\nimport { codeFence } from './code-fence';\nimport { doc } from './doc';\nimport { hardbreak } from './hardbreak';\nimport { heading } from './heading';\nimport { hr } from './hr';\nimport { image } from './image';\nimport { listItem } from './list-item';\nimport { orderedList } from './ordered-list';\nimport { paragraph } from './paragraph';\nimport { text } from './text';\n\nexport const nodes = [\n doc(),\n paragraph(),\n hardbreak(),\n blockquote(),\n codeFence(),\n bulletList(),\n orderedList(),\n listItem(),\n heading(),\n hr(),\n image(),\n text(),\n];\n\nexport * from './blockquote';\nexport * from './bullet-list';\nexport * from './code-fence';\nexport * from './doc';\nexport * from './hardbreak';\nexport * from './heading';\nexport * from './hr';\nexport * from './image';\nexport * from './list-item';\nexport * from './ordered-list';\nexport * from './paragraph';\nexport * from './text';\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { Literal, Node, Parent } from 'unist';\n\nconst isParent = (node: Node): node is Parent => !!(node as Parent).children;\nconst isHTML = (node: Node): node is Literal<string> => node.type === 'html';\n\nfunction flatMapWithDepth(ast: Node, fn: (node: Node, index: number, parent: Node | null) => Node[]) {\n return transform(ast, 0, null)[0];\n\n function transform(node: Node, index: number, parent: Node | null) {\n if (isParent(node)) {\n const out = [];\n for (let i = 0, n = node.children.length; i < n; i++) {\n const nthChild = node.children[i];\n if (nthChild) {\n const xs = transform(nthChild, i, node);\n if (xs) {\n for (let j = 0, m = xs.length; j < m; j++) {\n const item = xs[j];\n if (item) {\n out.push(item);\n }\n }\n }\n }\n }\n node.children = out;\n }\n\n return fn(node, index, parent);\n }\n}\n\nexport const filterHTMLPlugin = () => {\n function transformer(tree: Node) {\n flatMapWithDepth(tree, (node) => {\n if (!isHTML(node)) {\n return [node];\n }\n\n return [];\n });\n }\n return transformer;\n};\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createPlugin } from '@milkdown/utils';\nimport links from 'remark-inline-links';\n\nimport { filterHTMLPlugin } from './filter-html';\n\nexport const commonmarkPlugins = [\n createPlugin(() => ({\n remarkPlugins: () => [links, filterHTMLPlugin],\n }))(),\n];\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { AtomList } from '@milkdown/utils';\n\nimport { marks, ModifyLink, ToggleBold, ToggleInlineCode, ToggleItalic, ToggleLink } from './mark';\nimport {\n InsertHardbreak,\n InsertHr,\n InsertImage,\n LiftListItem,\n ModifyImage,\n nodes,\n SinkListItem,\n SplitListItem,\n TurnIntoCodeFence,\n TurnIntoHeading,\n TurnIntoText,\n WrapInBlockquote,\n WrapInBulletList,\n WrapInOrderedList,\n} from './node';\nimport { commonmarkPlugins } from './plugin';\n\nexport * from './mark';\nexport * from './node';\nexport * from './supported-keys';\n\nexport const commonmarkNodes = AtomList.create([...nodes, ...marks]);\nexport { commonmarkPlugins };\nexport const commonmark = AtomList.create([...commonmarkPlugins, ...commonmarkNodes]);\n\nexport const commands = {\n ToggleInlineCode,\n ToggleItalic,\n ToggleLink,\n ToggleBold,\n\n ModifyLink,\n ModifyImage,\n\n WrapInBlockquote,\n WrapInBulletList,\n WrapInOrderedList,\n\n TurnIntoCodeFence,\n TurnIntoHeading,\n TurnIntoText,\n\n InsertHardbreak,\n InsertHr,\n InsertImage,\n\n SplitListItem,\n SinkListItem,\n LiftListItem,\n} as const;\nexport type Commands = typeof commands;\n"],"names":["id","key"],"mappings":"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"}
1
+ {"version":3,"file":"index.es.js","sources":["../src/supported-keys.ts","../src/mark/code-inline.ts","../src/mark/em.ts","../src/mark/link.ts","../src/mark/strong.ts","../src/mark/index.ts","../src/node/blockquote.ts","../src/node/bullet-list.ts","../src/node/code-fence.ts","../src/node/doc.ts","../src/node/hardbreak.ts","../src/node/heading.ts","../src/node/hr.ts","../src/node/image.ts","../src/node/list-item.ts","../src/node/ordered-list.ts","../src/node/paragraph.ts","../src/node/text.ts","../src/node/index.ts","../src/plugin/filter-html.ts","../src/plugin/index.ts","../src/index.ts"],"sourcesContent":["/* Copyright 2021, Milkdown by Mirone. */\nexport const SupportedKeys = {\n HardBreak: 'HardBreak',\n Blockquote: 'Blockquote',\n BulletList: 'BulletList',\n OrderedList: 'OrderedList',\n CodeFence: 'CodeFence',\n H1: 'H1',\n H2: 'H2',\n H3: 'H3',\n H4: 'H4',\n H5: 'H5',\n H6: 'H6',\n Text: 'Text',\n CodeInline: 'CodeInline',\n Em: 'Em',\n Bold: 'Bold',\n NextListItem: 'NextListItem',\n SinkListItem: 'SinkListItem',\n LiftListItem: 'LiftListItem',\n} as const;\n\nexport type SupportedKeys = typeof SupportedKeys;\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { markRule, toggleMark } from '@milkdown/prose';\nimport { createMark, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['CodeInline'];\nconst id = 'code_inline';\n\nexport const ToggleInlineCode = createCmdKey('ToggleInlineCode');\n\nexport const codeInline = createMark<Keys>((utils) => {\n return {\n id,\n schema: () => ({\n priority: 100,\n code: true,\n inclusive: false,\n parseDOM: [{ tag: 'code' }],\n toDOM: (mark) => ['code', { class: utils.getClassName(mark.attrs, 'code-inline') }],\n parseMarkdown: {\n match: (node) => node.type === 'inlineCode',\n runner: (state, node, markType) => {\n state.openMark(markType);\n state.addText(node['value'] as string);\n state.closeMark(markType);\n },\n },\n toMarkdown: {\n match: (mark) => mark.type.name === id,\n runner: (state, mark, node) => {\n state.withMark(mark, 'inlineCode', node.text || '');\n },\n },\n }),\n inputRules: (markType) => [markRule(/(?:^|[^`])(`([^`]+)`)$/, markType)],\n commands: (markType) => [createCmd(ToggleInlineCode, () => toggleMark(markType))],\n shortcuts: {\n [SupportedKeys.CodeInline]: createShortcut(ToggleInlineCode, 'Mod-e'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { markRule, toggleMark } from '@milkdown/prose';\nimport { createMark, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['Em'];\n\nconst id = 'em';\n\nexport const ToggleItalic = createCmdKey('ToggleItalic');\n\nexport const em = createMark<Keys>((utils) => ({\n id,\n schema: () => ({\n parseDOM: [\n { tag: 'i' },\n { tag: 'em' },\n { style: 'font-style', getAttrs: (value) => (value === 'italic') as false },\n ],\n toDOM: (mark) => ['em', { class: utils.getClassName(mark.attrs, id) }],\n parseMarkdown: {\n match: (node) => node.type === 'emphasis',\n runner: (state, node, markType) => {\n state.openMark(markType);\n state.next(node.children);\n state.closeMark(markType);\n },\n },\n toMarkdown: {\n match: (mark) => mark.type.name === id,\n runner: (state, mark) => {\n state.withMark(mark, 'emphasis');\n },\n },\n }),\n inputRules: (markType) => [\n markRule(/(?:^|[^_])(_([^_]+)_)$/, markType),\n markRule(/(?:^|[^*])(\\*([^*]+)\\*)$/, markType),\n ],\n commands: (markType) => [createCmd(ToggleItalic, () => toggleMark(markType))],\n shortcuts: {\n [SupportedKeys.Em]: createShortcut(ToggleItalic, 'Mod-i'),\n },\n}));\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { commandsCtx, createCmd, createCmdKey, schemaCtx, ThemeInputChipType } from '@milkdown/core';\nimport {\n EditorView,\n InputRule,\n Node as ProseNode,\n Plugin,\n PluginKey,\n TextSelection,\n toggleMark,\n} from '@milkdown/prose';\nimport { createMark } from '@milkdown/utils';\n\nconst key = new PluginKey('MILKDOWN_PLUGIN_LINK_INPUT');\n\nexport const ToggleLink = createCmdKey<string>('ToggleLink');\nexport const ModifyLink = createCmdKey<string>('ModifyLink');\nconst id = 'link';\nexport type LinkOptions = {\n input: {\n placeholder: string;\n buttonText?: string;\n };\n};\nexport const link = createMark<string, LinkOptions>((utils, options) => {\n return {\n id,\n schema: () => ({\n attrs: {\n href: {},\n title: { default: null },\n },\n inclusive: false,\n parseDOM: [\n {\n tag: 'a[href]',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error();\n }\n return { href: dom.getAttribute('href'), title: dom.getAttribute('title') };\n },\n },\n ],\n toDOM: (mark) => ['a', { ...mark.attrs, class: utils.getClassName(mark.attrs, id) }],\n parseMarkdown: {\n match: (node) => node.type === 'link',\n runner: (state, node, markType) => {\n const url = node['url'] as string;\n const title = node['title'] as string;\n state.openMark(markType, { href: url, title });\n state.next(node.children);\n state.closeMark(markType);\n },\n },\n toMarkdown: {\n match: (mark) => mark.type.name === id,\n runner: (state, mark) => {\n state.withMark(mark, 'link', undefined, {\n title: mark.attrs['title'],\n url: mark.attrs['href'],\n });\n },\n },\n }),\n commands: (markType) => [\n createCmd(ToggleLink, (href = '') => toggleMark(markType, { href })),\n createCmd(ModifyLink, (href = '') => (state, dispatch) => {\n if (!dispatch) return false;\n\n const { marks } = state.schema;\n\n let node: ProseNode | undefined;\n let pos = -1;\n const { selection } = state;\n state.doc.nodesBetween(selection.from, selection.to, (n, p) => {\n if (marks.link.isInSet(n.marks)) {\n node = n;\n pos = p;\n return false;\n }\n return;\n });\n if (!node) return false;\n\n const mark = node.marks.find(({ type }) => type === markType);\n if (!mark) return false;\n\n const start = pos;\n const end = pos + node.nodeSize;\n const { tr } = state;\n const linkMark = marks.link.create({ ...mark.attrs, href });\n dispatch(\n tr\n .removeMark(start, end, mark)\n .addMark(start, end, linkMark)\n .setSelection(new TextSelection(tr.selection.$anchor))\n .scrollIntoView(),\n );\n\n return true;\n }),\n ],\n inputRules: (markType, ctx) => [\n new InputRule(/\\[(?<text>.*?)]\\((?<href>.*?)(?=“|\\))\"?(?<title>[^\"]+)?\"?\\)/, (state, match, start, end) => {\n const [okay, text = '', href, title] = match;\n const { tr } = state;\n if (okay) {\n const content = text || 'link';\n tr.replaceWith(start, end, ctx.get(schemaCtx).text(content)).addMark(\n start,\n content.length + start,\n markType.create({ title, href }),\n );\n }\n\n return tr;\n }),\n ],\n prosePlugins: (type, ctx) => {\n return [\n new Plugin({\n key,\n view: (editorView) => {\n const inputChipRenderer = utils.themeManager.get<ThemeInputChipType>('input-chip', {\n placeholder: options?.input?.placeholder ?? 'Input Web Link',\n buttonText: options?.input?.buttonText,\n onUpdate: (value) => {\n ctx.get(commandsCtx).call(ModifyLink, value);\n },\n });\n if (!inputChipRenderer) return {};\n const shouldDisplay = (view: EditorView) => {\n const { selection, doc } = view.state;\n const { from, to } = selection;\n\n return (\n selection.empty &&\n selection instanceof TextSelection &&\n doc.rangeHasMark(from, from === to ? to + 1 : to, type)\n );\n };\n const getCurrentLink = (view: EditorView) => {\n const { selection } = view.state;\n let node: ProseNode | undefined;\n const { from, to } = selection;\n view.state.doc.nodesBetween(from, from === to ? to + 1 : to, (n) => {\n if (type.isInSet(n.marks)) {\n node = n;\n return false;\n }\n return;\n });\n if (!node) return;\n\n const mark = node.marks.find((m) => m.type === type);\n if (!mark) return;\n\n const value = mark.attrs['href'];\n return value;\n };\n const renderByView = (view: EditorView) => {\n if (!view.editable) {\n return;\n }\n const display = shouldDisplay(view);\n if (display) {\n inputChipRenderer.show(view);\n inputChipRenderer.update(getCurrentLink(view));\n } else {\n inputChipRenderer.hide();\n }\n };\n inputChipRenderer.init(editorView);\n renderByView(editorView);\n\n return {\n update: (view, prevState) => {\n const isEqualSelection =\n prevState?.doc.eq(view.state.doc) && prevState.selection.eq(view.state.selection);\n if (isEqualSelection) return;\n\n renderByView(view);\n },\n destroy: () => {\n inputChipRenderer.destroy();\n },\n };\n },\n }),\n ];\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { markRule, toggleMark } from '@milkdown/prose';\nimport { createMark, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['Bold'];\nconst id = 'strong';\nexport const ToggleBold = createCmdKey('ToggleBold');\nexport const strong = createMark<Keys>((utils) => {\n return {\n id,\n schema: () => ({\n parseDOM: [\n { tag: 'b' },\n { tag: 'strong' },\n { style: 'font-style', getAttrs: (value) => (value === 'bold') as false },\n ],\n toDOM: (mark) => ['strong', { class: utils.getClassName(mark.attrs, id) }],\n parseMarkdown: {\n match: (node) => node.type === 'strong',\n runner: (state, node, markType) => {\n state.openMark(markType);\n state.next(node.children);\n state.closeMark(markType);\n },\n },\n toMarkdown: {\n match: (mark) => mark.type.name === id,\n runner: (state, mark) => {\n state.withMark(mark, 'strong');\n },\n },\n }),\n inputRules: (markType) => [\n markRule(/(?:__)([^_]+)(?:__)$/, markType),\n markRule(/(?:\\*\\*)([^*]+)(?:\\*\\*)$/, markType),\n ],\n commands: (markType) => [createCmd(ToggleBold, () => toggleMark(markType))],\n shortcuts: {\n [SupportedKeys.Bold]: createShortcut(ToggleBold, 'Mod-b'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { codeInline } from './code-inline';\nimport { em } from './em';\nimport { link } from './link';\nimport { strong } from './strong';\n\nexport const marks = [codeInline(), em(), strong(), link()];\n\nexport * from './code-inline';\nexport * from './em';\nexport * from './link';\nexport * from './strong';\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { wrapIn, wrappingInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['Blockquote'];\n\nconst id = 'blockquote';\n\nexport const WrapInBlockquote = createCmdKey('WrapInBlockquote');\n\nexport const blockquote = createNode<Keys>((utils) => {\n return {\n id,\n schema: () => ({\n content: 'block+',\n group: 'block',\n defining: true,\n parseDOM: [{ tag: 'blockquote' }],\n toDOM: (node) => ['blockquote', { class: utils.getClassName(node.attrs, id) }, 0],\n parseMarkdown: {\n match: ({ type }) => type === id,\n runner: (state, node, type) => {\n state.openNode(type).next(node.children).closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('blockquote').next(node.content).closeNode();\n },\n },\n }),\n inputRules: (nodeType) => [wrappingInputRule(/^\\s*>\\s$/, nodeType)],\n commands: (nodeType) => [createCmd(WrapInBlockquote, () => wrapIn(nodeType))],\n shortcuts: {\n [SupportedKeys.Blockquote]: createShortcut(WrapInBlockquote, 'Mod-Shift-b'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { wrapIn, wrappingInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['BulletList'];\n\nexport const WrapInBulletList = createCmdKey('WrapInBulletList');\n\nexport const bulletList = createNode<Keys>((utils) => {\n const id = 'bullet_list';\n return {\n id,\n schema: () => ({\n content: 'listItem+',\n group: 'block',\n parseDOM: [{ tag: 'ul' }],\n toDOM: (node) => {\n return ['ul', { class: utils.getClassName(node.attrs, 'bullet-list') }, 0];\n },\n parseMarkdown: {\n match: ({ type, ordered }) => type === 'list' && !ordered,\n runner: (state, node, type) => {\n state.openNode(type).next(node.children).closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('list', undefined, { ordered: false }).next(node.content).closeNode();\n },\n },\n }),\n inputRules: (nodeType) => [wrappingInputRule(/^\\s*([-+*])\\s$/, nodeType)],\n commands: (nodeType) => [createCmd(WrapInBulletList, () => wrapIn(nodeType))],\n shortcuts: {\n [SupportedKeys.BulletList]: createShortcut(WrapInBulletList, 'Mod-Alt-8'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey, editorViewCtx, ThemeCodeFenceType } from '@milkdown/core';\nimport { Fragment, setBlockType, textblockTypeInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['CodeFence'];\n\nconst languageOptions = [\n '',\n 'javascript',\n 'typescript',\n 'bash',\n 'sql',\n 'json',\n 'html',\n 'css',\n 'c',\n 'cpp',\n 'java',\n 'ruby',\n 'python',\n 'go',\n 'rust',\n 'markdown',\n];\n\nexport const backtickInputRegex = /^```(?<language>[a-z]*)?[\\s\\n]$/;\nexport const tildeInputRegex = /^~~~(?<language>[a-z]*)?[\\s\\n]$/;\n\nexport const TurnIntoCodeFence = createCmdKey('TurnIntoCodeFence');\n\nconst id = 'fence';\nexport const codeFence = createNode<Keys, { languageList?: string[] }>((utils, options) => {\n const languageList = options?.languageList || languageOptions;\n\n return {\n id,\n schema: (ctx) => ({\n content: 'text*',\n group: 'block',\n marks: '',\n defining: true,\n code: true,\n attrs: {\n language: {\n default: '',\n },\n fold: {\n default: true,\n },\n },\n parseDOM: [\n {\n tag: 'div.code-fence-container',\n preserveWhitespace: 'full',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error('Parse DOM error.');\n }\n return { language: dom.querySelector('pre')?.dataset['language'] };\n },\n getContent: (dom, schema) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error('Parse DOM error.');\n }\n const textNode = schema.text(dom.querySelector('pre')?.textContent ?? '');\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return Fragment.from<any>(textNode);\n },\n },\n {\n tag: 'pre',\n preserveWhitespace: 'full',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error('Parse DOM error.');\n }\n return { language: dom.dataset['language'] };\n },\n },\n ],\n toDOM: (node) => {\n const select = document.createElement('select');\n languageList.forEach((lang) => {\n const option = document.createElement('option');\n option.value = lang;\n option.innerText = !lang ? '--' : lang;\n if (lang === node.attrs['language']) {\n option.selected = true;\n }\n select.appendChild(option);\n });\n select.onchange = (e) => {\n const target = e.target;\n if (!(target instanceof HTMLSelectElement)) {\n return;\n }\n const view = ctx.get(editorViewCtx);\n if (!view.editable) {\n target.value = node.attrs['language'];\n return;\n }\n\n const { top, left } = target.getBoundingClientRect();\n const result = view.posAtCoords({ top, left });\n if (!result) return;\n\n const { tr } = view.state;\n\n view.dispatch(\n tr.setNodeMarkup(result.inside, undefined, {\n ...node.attrs,\n language: target.value,\n }),\n );\n };\n return [\n 'div',\n {\n class: 'code-fence-container',\n },\n select,\n [\n 'pre',\n {\n 'data-language': node.attrs['language'],\n class: utils.getClassName(node.attrs, 'code-fence'),\n },\n ['code', { spellCheck: 'false' }, 0],\n ],\n ];\n },\n parseMarkdown: {\n match: ({ type }) => type === 'code',\n runner: (state, node, type) => {\n const language = node['lang'] as string;\n const value = node['value'] as string;\n state.openNode(type, { language });\n if (value) {\n state.addText(value);\n }\n state.closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.addNode('code', undefined, node.content.firstChild?.text || '', {\n lang: node.attrs['language'],\n });\n },\n },\n }),\n inputRules: (nodeType) => [\n textblockTypeInputRule(backtickInputRegex, nodeType, (match) => {\n const [ok, language] = match;\n if (!ok) return;\n return { language };\n }),\n textblockTypeInputRule(tildeInputRegex, nodeType, (match) => {\n const [ok, language] = match;\n if (!ok) return;\n return { language };\n }),\n ],\n commands: (nodeType) => [createCmd(TurnIntoCodeFence, () => setBlockType(nodeType))],\n shortcuts: {\n [SupportedKeys.CodeFence]: createShortcut(TurnIntoCodeFence, 'Mod-Alt-c'),\n },\n view: () => (node, view, getPos) => {\n let currNode = node;\n\n const onSelectLanguage = (language: string) => {\n const { tr } = view.state;\n view.dispatch(\n tr.setNodeMarkup(getPos(), undefined, {\n fold: true,\n language,\n }),\n );\n };\n const onBlur = () => {\n const { tr } = view.state;\n\n view.dispatch(\n tr.setNodeMarkup(getPos(), undefined, {\n ...currNode.attrs,\n fold: true,\n }),\n );\n };\n const onFocus = () => {\n const { tr } = view.state;\n\n view.dispatch(\n tr.setNodeMarkup(getPos(), undefined, {\n ...currNode.attrs,\n fold: false,\n }),\n );\n };\n\n const renderer = utils.themeManager.get<ThemeCodeFenceType>('code-fence', {\n onBlur,\n onFocus,\n onSelectLanguage,\n editable: () => view.editable,\n languageList,\n });\n if (!renderer) return {};\n\n const { dom, contentDOM, onUpdate, onDestroy } = renderer;\n onUpdate(currNode);\n\n return {\n dom,\n contentDOM,\n update: (updatedNode) => {\n if (updatedNode.type.name !== id) return false;\n currNode = updatedNode;\n onUpdate(currNode);\n\n return true;\n },\n destroy: onDestroy,\n };\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createNode } from '@milkdown/utils';\n\nexport const doc = createNode(() => {\n return {\n id: 'doc',\n schema: () => ({\n content: 'block+',\n parseMarkdown: {\n match: ({ type }) => type === 'root',\n runner: (state, node, type) => {\n state.injectRoot(node, type);\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === 'doc',\n runner: (state, node) => {\n state.openNode('root');\n state.next(node.content);\n },\n },\n }),\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { AddMarkStep, Plugin, PluginKey, ReplaceStep } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['HardBreak'];\n\nexport const InsertHardbreak = createCmdKey('InsertHardbreak');\n\nexport const hardbreak = createNode<Keys>((utils) => {\n return {\n id: 'hardbreak',\n schema: () => ({\n inline: true,\n group: 'inline',\n selectable: false,\n parseDOM: [{ tag: 'br' }],\n toDOM: (node) => ['br', { class: utils.getClassName(node.attrs, 'hardbreak') }],\n parseMarkdown: {\n match: ({ type }) => type === 'break',\n runner: (state, _, type) => {\n state.addNode(type);\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === 'hardbreak',\n runner: (state) => {\n state.addNode('break');\n },\n },\n }),\n commands: (type) => [\n createCmd(InsertHardbreak, () => (state, dispatch) => {\n dispatch?.(state.tr.setMeta('hardbreak', true).replaceSelectionWith(type.create()).scrollIntoView());\n return true;\n }),\n ],\n shortcuts: {\n [SupportedKeys.HardBreak]: createShortcut(InsertHardbreak, 'Shift-Enter'),\n },\n prosePlugins: (type) => [\n new Plugin({\n key: new PluginKey('MILKDOWN_PLUGIN_HARDBREAK_MARKS'),\n appendTransaction: (trs, _oldState, newState) => {\n if (!trs.length) return;\n const [tr] = trs;\n if (!tr) return;\n\n const [step] = tr.steps;\n\n const isInsertHr = tr.getMeta('hardbreak');\n if (isInsertHr) {\n if (!(step instanceof ReplaceStep)) {\n return;\n }\n const { from } = step as unknown as { from: number };\n return newState.tr.setNodeMarkup(from, type, undefined, []);\n }\n\n const isAddMarkStep = step instanceof AddMarkStep;\n if (isAddMarkStep) {\n let _tr = newState.tr;\n const { from, to } = step as unknown as { from: number; to: number };\n newState.doc.nodesBetween(from, to, (node, pos) => {\n if (node.type === type) {\n _tr = _tr.setNodeMarkup(pos, type, undefined, []);\n }\n });\n\n return _tr;\n }\n\n return;\n },\n }),\n ],\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey, editorViewCtx } from '@milkdown/core';\nimport {\n EditorState,\n Node,\n Plugin,\n PluginKey,\n setBlockType,\n textblockTypeInputRule,\n Transaction,\n} from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\nconst headingIndex = Array(6)\n .fill(0)\n .map((_, i) => i + 1);\n\ntype Keys =\n | SupportedKeys['H1']\n | SupportedKeys['H2']\n | SupportedKeys['H3']\n | SupportedKeys['H4']\n | SupportedKeys['H5']\n | SupportedKeys['H6'];\n\nexport const TurnIntoHeading = createCmdKey<number>('TurnIntoHeading');\n\nexport const headingPluginKey = new PluginKey('MILKDOWN_PLUGIN_ID');\n\nexport const heading = createNode<Keys>((utils) => {\n const id = 'heading';\n\n return {\n id,\n schema: () => ({\n content: 'inline*',\n group: 'block',\n defining: true,\n attrs: {\n id: {\n default: '',\n },\n level: {\n default: 1,\n },\n },\n parseDOM: headingIndex.map((x) => ({\n tag: `h${x}`,\n getAttrs: (node) => {\n if (!(node instanceof HTMLElement)) {\n throw new Error();\n }\n return { level: x, id: node.id };\n },\n })),\n toDOM: (node) => {\n return [\n `h${node.attrs['level']}`,\n {\n id: node.attrs['id'] || node.textContent.split(' ').join('-').toLocaleLowerCase(),\n class: utils.getClassName(node.attrs, `heading h${node.attrs['level']}`),\n },\n 0,\n ];\n },\n parseMarkdown: {\n match: ({ type }) => type === id,\n runner: (state, node, type) => {\n const depth = node['depth'] as number;\n state.openNode(type, { level: depth });\n state.next(node.children);\n state.closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('heading', undefined, { depth: node.attrs['level'] });\n state.next(node.content);\n state.closeNode();\n },\n },\n }),\n inputRules: (type) =>\n headingIndex.map((x) =>\n textblockTypeInputRule(new RegExp(`^(#{1,${x}})\\\\s$`), type, () => ({\n level: x,\n })),\n ),\n commands: (type) => [createCmd(TurnIntoHeading, (level = 1) => setBlockType(type, { level }))],\n shortcuts: {\n [SupportedKeys.H1]: createShortcut(TurnIntoHeading, 'Mod-Alt-1', 1),\n [SupportedKeys.H2]: createShortcut(TurnIntoHeading, 'Mod-Alt-2', 2),\n [SupportedKeys.H3]: createShortcut(TurnIntoHeading, 'Mod-Alt-3', 3),\n [SupportedKeys.H4]: createShortcut(TurnIntoHeading, 'Mod-Alt-4', 4),\n [SupportedKeys.H5]: createShortcut(TurnIntoHeading, 'Mod-Alt-5', 5),\n [SupportedKeys.H6]: createShortcut(TurnIntoHeading, 'Mod-Alt-6', 6),\n },\n prosePlugins: (type, ctx) => {\n let lock = false;\n const createId = (node: Node) => {\n return node.textContent\n .replace(/[\\p{P}\\p{S}]/gu, '')\n .replace(/\\s/g, '')\n .trim();\n };\n const walkThrough = (state: EditorState, callback: (tr: Transaction) => void) => {\n const tr = state.tr;\n state.doc.descendants((node, pos) => {\n if (node.type === type && !lock) {\n if (node.textContent.trim().length === 0) {\n return;\n }\n const attrs = node.attrs;\n const id = createId(node);\n\n if (attrs['id'] !== id) {\n tr.setMeta(headingPluginKey, true).setNodeMarkup(pos, undefined, {\n ...attrs,\n id,\n });\n }\n }\n });\n callback(tr);\n };\n return [\n new Plugin({\n key: headingPluginKey,\n props: {\n handleDOMEvents: {\n compositionstart: () => {\n lock = true;\n return false;\n },\n compositionend: () => {\n lock = false;\n const view = ctx.get(editorViewCtx);\n setTimeout(() => {\n walkThrough(view.state, (tr) => view.dispatch(tr));\n }, 0);\n return false;\n },\n },\n },\n appendTransaction: (transactions, _, nextState) => {\n let tr: Transaction | null = null;\n\n if (\n transactions.every((transaction) => !transaction.getMeta(headingPluginKey)) &&\n transactions.some((transaction) => transaction.docChanged)\n ) {\n walkThrough(nextState, (t) => {\n tr = t;\n });\n }\n\n return tr;\n },\n }),\n ];\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey, schemaCtx } from '@milkdown/core';\nimport { InputRule, Selection } from '@milkdown/prose';\nimport { createNode } from '@milkdown/utils';\n\nconst id = 'hr';\nexport const InsertHr = createCmdKey<string>('InsertHr');\nexport const hr = createNode((utils) => {\n return {\n id,\n schema: () => ({\n group: 'block',\n parseDOM: [{ tag: 'hr' }],\n toDOM: (node) => ['hr', { class: utils.getClassName(node.attrs, id) }],\n parseMarkdown: {\n match: ({ type }) => type === 'thematicBreak',\n runner: (state, _, type) => {\n state.addNode(type);\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state) => {\n state.addNode('thematicBreak');\n },\n },\n }),\n inputRules: (type) => [\n new InputRule(/^(?:---|___\\s|\\*\\*\\*\\s)$/, (state, match, start, end) => {\n const { tr } = state;\n\n if (match[0]) {\n tr.replaceWith(start - 1, end, type.create());\n }\n\n return tr;\n }),\n ],\n commands: (type, ctx) => [\n createCmd(InsertHr, () => (state, dispatch) => {\n if (!dispatch) return true;\n const { tr, selection } = state;\n const from = selection.from;\n const node = type.create();\n if (!node) {\n return true;\n }\n const _tr = tr.replaceSelectionWith(node).insert(from, ctx.get(schemaCtx).node('paragraph'));\n const sel = Selection.findFrom(_tr.doc.resolve(from), 1, true);\n if (!sel) {\n return true;\n }\n dispatch(_tr.setSelection(sel).scrollIntoView());\n return true;\n }),\n ],\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { commandsCtx, createCmd, createCmdKey, ThemeImageType, ThemeInputChipType } from '@milkdown/core';\nimport { EditorView, findSelectedNodeOfType, InputRule, Plugin, PluginKey } from '@milkdown/prose';\nimport { createNode } from '@milkdown/utils';\n\nexport const ModifyImage = createCmdKey<string>('ModifyImage');\nexport const InsertImage = createCmdKey<string>('InsertImage');\nconst id = 'image';\nexport type ImageOptions = {\n isBlock: boolean;\n placeholder: string;\n input: {\n placeholder: string;\n buttonText?: string;\n };\n};\nconst key = new PluginKey('MILKDOWN_PLUGIN_IMAGE_INPUT');\n\nexport const image = createNode<string, ImageOptions>((utils, options) => {\n return {\n id: 'image',\n schema: () => ({\n inline: true,\n group: 'inline',\n selectable: true,\n draggable: true,\n marks: '',\n atom: true,\n defining: true,\n isolating: true,\n attrs: {\n src: { default: '' },\n alt: { default: null },\n title: { default: null },\n },\n parseDOM: [\n {\n tag: 'img[src]',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error();\n }\n return {\n src: dom.getAttribute('src') || '',\n alt: dom.getAttribute('alt'),\n title: dom.getAttribute('title') || dom.getAttribute('alt'),\n width: dom.getAttribute('width'),\n };\n },\n },\n ],\n toDOM: (node) => {\n return [\n 'img',\n {\n ...node.attrs,\n class: utils.getClassName(node.attrs, id),\n },\n ];\n },\n parseMarkdown: {\n match: ({ type }) => type === id,\n runner: (state, node, type) => {\n const url = node['url'] as string;\n const alt = node['alt'] as string;\n const title = node['title'] as string;\n state.addNode(type, {\n src: url,\n alt,\n title,\n });\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.addNode('image', undefined, undefined, {\n title: node.attrs['title'],\n url: node.attrs['src'],\n alt: node.attrs['alt'],\n });\n },\n },\n }),\n commands: (type) => [\n createCmd(InsertImage, (src = '') => (state, dispatch) => {\n if (!dispatch) return true;\n const { tr } = state;\n const node = type.create({ src });\n if (!node) {\n return true;\n }\n const _tr = tr.replaceSelectionWith(node);\n dispatch(_tr.scrollIntoView());\n return true;\n }),\n createCmd(ModifyImage, (src = '') => (state, dispatch) => {\n const node = findSelectedNodeOfType(state.selection, type);\n if (!node) return false;\n\n const { tr } = state;\n dispatch?.(\n tr.setNodeMarkup(node.pos, undefined, { ...node.node.attrs, loading: true, src }).scrollIntoView(),\n );\n\n return true;\n }),\n ],\n inputRules: (type) => [\n new InputRule(\n /!\\[(?<alt>.*?)]\\((?<filename>.*?)\\s*(?=\"|\\))\"?(?<title>[^\"]+)?\"?\\)/,\n (state, match, start, end) => {\n const [okay, alt, src = '', title] = match;\n const { tr } = state;\n if (okay) {\n tr.replaceWith(start, end, type.create({ src, alt, title }));\n }\n\n return tr;\n },\n ),\n ],\n view: () => (node) => {\n let currNode = node;\n\n const placeholder = options?.placeholder ?? 'Add an Image';\n const isBlock = options?.isBlock ?? false;\n const renderer = utils.themeManager.get<ThemeImageType>('image', {\n placeholder,\n isBlock,\n });\n\n if (!renderer) {\n return {};\n }\n\n const { dom, onUpdate } = renderer;\n onUpdate(currNode);\n\n return {\n dom,\n update: (updatedNode) => {\n if (updatedNode.type.name !== id) return false;\n\n currNode = updatedNode;\n onUpdate(currNode);\n\n return true;\n },\n selectNode: () => {\n dom.classList.add('ProseMirror-selectednode');\n },\n deselectNode: () => {\n dom.classList.remove('ProseMirror-selectednode');\n },\n };\n },\n prosePlugins: (type, ctx) => {\n return [\n new Plugin({\n key,\n view: (editorView) => {\n const inputChipRenderer = utils.themeManager.get<ThemeInputChipType>('input-chip', {\n placeholder: options?.input?.placeholder ?? 'Input Image Link',\n buttonText: options?.input?.buttonText,\n onUpdate: (value) => {\n ctx.get(commandsCtx).call(ModifyImage, value);\n },\n });\n if (!inputChipRenderer) return {};\n const shouldDisplay = (view: EditorView) => {\n return Boolean(type && findSelectedNodeOfType(view.state.selection, type));\n };\n const getCurrentLink = (view: EditorView) => {\n const result = findSelectedNodeOfType(view.state.selection, type);\n if (!result) return;\n\n const value = result.node.attrs['src'];\n return value;\n };\n const renderByView = (view: EditorView) => {\n if (!view.editable) {\n return;\n }\n const display = shouldDisplay(view);\n if (display) {\n inputChipRenderer.show(view);\n inputChipRenderer.update(getCurrentLink(view));\n } else {\n inputChipRenderer.hide();\n }\n };\n inputChipRenderer.init(editorView);\n renderByView(editorView);\n\n return {\n update: (view, prevState) => {\n const isEqualSelection =\n prevState?.doc.eq(view.state.doc) && prevState.selection.eq(view.state.selection);\n if (isEqualSelection) return;\n\n renderByView(view);\n },\n destroy: () => {\n inputChipRenderer.destroy();\n },\n };\n },\n }),\n ];\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { liftListItem, sinkListItem, splitListItem, wrappingInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['SinkListItem'] | SupportedKeys['LiftListItem'] | SupportedKeys['NextListItem'];\n\nconst id = 'list_item';\n\nexport const SplitListItem = createCmdKey('SplitListItem');\nexport const SinkListItem = createCmdKey('SinkListItem');\nexport const LiftListItem = createCmdKey('LiftListItem');\n\nexport const listItem = createNode<Keys>((utils) => ({\n id,\n schema: () => ({\n group: 'listItem',\n content: 'paragraph block*',\n defining: true,\n parseDOM: [{ tag: 'li' }],\n toDOM: (node) => ['li', { class: utils.getClassName(node.attrs, 'list-item') }, 0],\n parseMarkdown: {\n match: ({ type, checked }) => type === 'listItem' && checked === null,\n runner: (state, node, type) => {\n state.openNode(type);\n state.next(node.children);\n state.closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('listItem');\n state.next(node.content);\n state.closeNode();\n },\n },\n }),\n inputRules: (nodeType) => [wrappingInputRule(/^\\s*([-+*])\\s$/, nodeType)],\n commands: (nodeType) => [\n createCmd(SplitListItem, () => splitListItem(nodeType)),\n createCmd(SinkListItem, () => sinkListItem(nodeType)),\n createCmd(LiftListItem, () => liftListItem(nodeType)),\n ],\n shortcuts: {\n [SupportedKeys.NextListItem]: createShortcut(SplitListItem, 'Enter'),\n [SupportedKeys.SinkListItem]: createShortcut(SinkListItem, 'Mod-]'),\n [SupportedKeys.LiftListItem]: createShortcut(LiftListItem, 'Mod-['),\n },\n}));\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { wrapIn, wrappingInputRule } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['OrderedList'];\n\nexport const WrapInOrderedList = createCmdKey('WrapInOrderedList');\n\nconst id = 'ordered_list';\nexport const orderedList = createNode<Keys>((utils) => ({\n id,\n schema: () => ({\n content: 'listItem+',\n group: 'block',\n attrs: {\n order: {\n default: 1,\n },\n },\n parseDOM: [\n {\n tag: 'ol',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error();\n }\n return { order: dom.hasAttribute('start') ? Number(dom.getAttribute('start')) : 1 };\n },\n },\n ],\n toDOM: (node) => [\n 'ol',\n {\n ...(node.attrs['order'] === 1 ? {} : node.attrs['order']),\n class: utils.getClassName(node.attrs, 'ordered-list'),\n },\n 0,\n ],\n parseMarkdown: {\n match: ({ type, ordered }) => type === 'list' && !!ordered,\n runner: (state, node, type) => {\n state.openNode(type).next(node.children).closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === id,\n runner: (state, node) => {\n state.openNode('list', undefined, { ordered: true, start: 1 });\n state.next(node.content);\n state.closeNode();\n },\n },\n }),\n inputRules: (nodeType) => [\n wrappingInputRule(\n /^(\\d+)\\.\\s$/,\n nodeType,\n (match) => ({ order: Number(match[1]) }),\n (match, node) => node.childCount + node.attrs['order'] === Number(match[1]),\n ),\n ],\n commands: (nodeType) => [createCmd(WrapInOrderedList, () => wrapIn(nodeType))],\n shortcuts: {\n [SupportedKeys.OrderedList]: createShortcut(WrapInOrderedList, 'Mod-Alt-7'),\n },\n}));\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createCmd, createCmdKey } from '@milkdown/core';\nimport { setBlockType } from '@milkdown/prose';\nimport { createNode, createShortcut } from '@milkdown/utils';\n\nimport { SupportedKeys } from '../supported-keys';\n\ntype Keys = SupportedKeys['Text'];\n\nexport const TurnIntoText = createCmdKey('TurnIntoText');\n\nconst id = 'paragraph';\nexport const paragraph = createNode<Keys>((utils) => {\n return {\n id,\n schema: () => ({\n content: 'inline*',\n group: 'block',\n parseDOM: [{ tag: 'p' }],\n toDOM: (node) => ['p', { class: utils.getClassName(node.attrs, id) }, 0],\n parseMarkdown: {\n match: (node) => node.type === 'paragraph',\n runner: (state, node, type) => {\n state.openNode(type);\n if (node.children) {\n state.next(node.children);\n } else {\n state.addText(node['value'] as string);\n }\n state.closeNode();\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === 'paragraph',\n runner: (state, node) => {\n state.openNode('paragraph');\n state.next(node.content);\n state.closeNode();\n },\n },\n }),\n commands: (nodeType) => [createCmd(TurnIntoText, () => setBlockType(nodeType))],\n shortcuts: {\n [SupportedKeys.Text]: createShortcut(TurnIntoText, 'Mod-Alt-0'),\n },\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createNode } from '@milkdown/utils';\n\nexport const text = createNode(() => ({\n id: 'text',\n schema: () => ({\n group: 'inline',\n parseMarkdown: {\n match: ({ type }) => type === 'text',\n runner: (state, node) => {\n state.addText(node['value'] as string);\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === 'text',\n runner: (state, node) => {\n state.addNode('text', undefined, node.text as string);\n },\n },\n }),\n}));\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { blockquote } from './blockquote';\nimport { bulletList } from './bullet-list';\nimport { codeFence } from './code-fence';\nimport { doc } from './doc';\nimport { hardbreak } from './hardbreak';\nimport { heading } from './heading';\nimport { hr } from './hr';\nimport { image } from './image';\nimport { listItem } from './list-item';\nimport { orderedList } from './ordered-list';\nimport { paragraph } from './paragraph';\nimport { text } from './text';\n\nexport const nodes = [\n doc(),\n paragraph(),\n hardbreak(),\n blockquote(),\n codeFence(),\n bulletList(),\n orderedList(),\n listItem(),\n heading(),\n hr(),\n image(),\n text(),\n];\n\nexport * from './blockquote';\nexport * from './bullet-list';\nexport * from './code-fence';\nexport * from './doc';\nexport * from './hardbreak';\nexport * from './heading';\nexport * from './hr';\nexport * from './image';\nexport * from './list-item';\nexport * from './ordered-list';\nexport * from './paragraph';\nexport * from './text';\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { Literal, Node, Parent } from 'unist';\n\nconst isParent = (node: Node): node is Parent => !!(node as Parent).children;\nconst isHTML = (node: Node): node is Literal<string> => node.type === 'html';\n\nfunction flatMapWithDepth(ast: Node, fn: (node: Node, index: number, parent: Node | null) => Node[]) {\n return transform(ast, 0, null)[0];\n\n function transform(node: Node, index: number, parent: Node | null) {\n if (isParent(node)) {\n const out = [];\n for (let i = 0, n = node.children.length; i < n; i++) {\n const nthChild = node.children[i];\n if (nthChild) {\n const xs = transform(nthChild, i, node);\n if (xs) {\n for (let j = 0, m = xs.length; j < m; j++) {\n const item = xs[j];\n if (item) {\n out.push(item);\n }\n }\n }\n }\n }\n node.children = out;\n }\n\n return fn(node, index, parent);\n }\n}\n\nexport const filterHTMLPlugin = () => {\n function transformer(tree: Node) {\n flatMapWithDepth(tree, (node) => {\n if (!isHTML(node)) {\n return [node];\n }\n\n return [];\n });\n }\n return transformer;\n};\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { createPlugin } from '@milkdown/utils';\nimport links from 'remark-inline-links';\n\nimport { filterHTMLPlugin } from './filter-html';\n\nexport const commonmarkPlugins = [\n createPlugin(() => ({\n remarkPlugins: () => [links, filterHTMLPlugin],\n }))(),\n];\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { AtomList } from '@milkdown/utils';\n\nimport { marks, ModifyLink, ToggleBold, ToggleInlineCode, ToggleItalic, ToggleLink } from './mark';\nimport {\n InsertHardbreak,\n InsertHr,\n InsertImage,\n LiftListItem,\n ModifyImage,\n nodes,\n SinkListItem,\n SplitListItem,\n TurnIntoCodeFence,\n TurnIntoHeading,\n TurnIntoText,\n WrapInBlockquote,\n WrapInBulletList,\n WrapInOrderedList,\n} from './node';\nimport { commonmarkPlugins } from './plugin';\n\nexport * from './mark';\nexport * from './node';\nexport * from './supported-keys';\n\nexport const commonmarkNodes = AtomList.create([...nodes, ...marks]);\nexport { commonmarkPlugins };\nexport const commonmark = AtomList.create([...commonmarkPlugins, ...commonmarkNodes]);\n\nexport const commands = {\n ToggleInlineCode,\n ToggleItalic,\n ToggleLink,\n ToggleBold,\n\n ModifyLink,\n ModifyImage,\n\n WrapInBlockquote,\n WrapInBulletList,\n WrapInOrderedList,\n\n TurnIntoCodeFence,\n TurnIntoHeading,\n TurnIntoText,\n\n InsertHardbreak,\n InsertHr,\n InsertImage,\n\n SplitListItem,\n SinkListItem,\n LiftListItem,\n} as const;\nexport type Commands = typeof commands;\n"],"names":["id","key"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"link.d.ts","sourceRoot":"","sources":["../../src/mark/link.ts"],"names":[],"mappings":"AAeA,eAAO,MAAM,UAAU,yCAAqC,CAAC;AAC7D,eAAO,MAAM,UAAU,yCAAqC,CAAC;AAE7D,oBAAY,WAAW,GAAG;IACtB,KAAK,EAAE;QACH,WAAW,EAAE,MAAM,CAAC;QACpB,UAAU,CAAC,EAAE,MAAM,CAAC;KACvB,CAAC;CACL,CAAC;AACF,eAAO,MAAM,IAAI;;;;EAwKf,CAAC"}
1
+ {"version":3,"file":"link.d.ts","sourceRoot":"","sources":["../../src/mark/link.ts"],"names":[],"mappings":"AAeA,eAAO,MAAM,UAAU,yCAAqC,CAAC;AAC7D,eAAO,MAAM,UAAU,yCAAqC,CAAC;AAE7D,oBAAY,WAAW,GAAG;IACtB,KAAK,EAAE;QACH,WAAW,EAAE,MAAM,CAAC;QACpB,UAAU,CAAC,EAAE,MAAM,CAAC;KACvB,CAAC;CACL,CAAC;AACF,eAAO,MAAM,IAAI;;;;EAyKf,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"code-fence.d.ts","sourceRoot":"","sources":["../../src/node/code-fence.ts"],"names":[],"mappings":"AA4BA,eAAO,MAAM,kBAAkB,QAAoC,CAAC;AACpE,eAAO,MAAM,eAAe,QAAoC,CAAC;AAEjE,eAAO,MAAM,iBAAiB,4CAAoC,CAAC;AAGnE,eAAO,MAAM,SAAS;;;;;;EAkLpB,CAAC"}
1
+ {"version":3,"file":"code-fence.d.ts","sourceRoot":"","sources":["../../src/node/code-fence.ts"],"names":[],"mappings":"AA4BA,eAAO,MAAM,kBAAkB,QAAoC,CAAC;AACpE,eAAO,MAAM,eAAe,QAAoC,CAAC;AAEjE,eAAO,MAAM,iBAAiB,4CAAoC,CAAC;AAGnE,eAAO,MAAM,SAAS;;;;;;EAoMpB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"image.d.ts","sourceRoot":"","sources":["../../src/node/image.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,WAAW,yCAAsC,CAAC;AAC/D,eAAO,MAAM,WAAW,yCAAsC,CAAC;AAE/D,oBAAY,YAAY,GAAG;IACvB,OAAO,EAAE,OAAO,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE;QACH,WAAW,EAAE,MAAM,CAAC;QACpB,UAAU,CAAC,EAAE,MAAM,CAAC;KACvB,CAAC;CACL,CAAC;AAGF,eAAO,MAAM,KAAK;;;;EAiMhB,CAAC"}
1
+ {"version":3,"file":"image.d.ts","sourceRoot":"","sources":["../../src/node/image.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,WAAW,yCAAsC,CAAC;AAC/D,eAAO,MAAM,WAAW,yCAAsC,CAAC;AAE/D,oBAAY,YAAY,GAAG;IACvB,OAAO,EAAE,OAAO,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE;QACH,WAAW,EAAE,MAAM,CAAC;QACpB,UAAU,CAAC,EAAE,MAAM,CAAC;KACvB,CAAC;CACL,CAAC;AAGF,eAAO,MAAM,KAAK;;;;EAkMhB,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@milkdown/preset-commonmark",
3
- "version": "6.0.0-next.1",
3
+ "version": "6.0.0",
4
4
  "type": "module",
5
5
  "main": "./lib/index.es.js",
6
6
  "types": "./lib/index.d.ts",
@@ -17,15 +17,15 @@
17
17
  "commonmark"
18
18
  ],
19
19
  "devDependencies": {
20
- "@milkdown/core": "6.0.0-next.1",
21
- "@milkdown/prose": "6.0.0-next.1"
20
+ "@milkdown/core": "6.0.0",
21
+ "@milkdown/prose": "6.0.0"
22
22
  },
23
23
  "peerDependencies": {
24
24
  "@milkdown/core": "^6.0.0-next.0",
25
25
  "@milkdown/prose": "^6.0.0-next.0"
26
26
  },
27
27
  "dependencies": {
28
- "@milkdown/utils": "6.0.0-next.1",
28
+ "@milkdown/utils": "6.0.0",
29
29
  "remark-inline-links": "^6.0.0",
30
30
  "tslib": "^2.3.1"
31
31
  },
package/src/mark/link.ts CHANGED
@@ -118,58 +118,59 @@ export const link = createMark<string, LinkOptions>((utils, options) => {
118
118
  }),
119
119
  ],
120
120
  prosePlugins: (type, ctx) => {
121
- const inputChipRenderer = utils.themeManager.get<ThemeInputChipType>('input-chip', {
122
- placeholder: options?.input?.placeholder ?? 'Input Web Link',
123
- buttonText: options?.input?.buttonText,
124
- onUpdate: (value) => {
125
- ctx.get(commandsCtx).call(ModifyLink, value);
126
- },
127
- });
128
- const shouldDisplay = (view: EditorView) => {
129
- const { selection, doc } = view.state;
130
- const { from, to } = selection;
131
-
132
- return (
133
- selection.empty &&
134
- selection instanceof TextSelection &&
135
- doc.rangeHasMark(from, from === to ? to + 1 : to, type)
136
- );
137
- };
138
- const getCurrentLink = (view: EditorView) => {
139
- const { selection } = view.state;
140
- let node: ProseNode | undefined;
141
- const { from, to } = selection;
142
- view.state.doc.nodesBetween(from, from === to ? to + 1 : to, (n) => {
143
- if (type.isInSet(n.marks)) {
144
- node = n;
145
- return false;
146
- }
147
- return;
148
- });
149
- if (!node) return;
150
-
151
- const mark = node.marks.find((m) => m.type === type);
152
- if (!mark) return;
153
-
154
- const value = mark.attrs['href'];
155
- return value;
156
- };
157
- const renderByView = (view: EditorView) => {
158
- if (!view.editable) {
159
- return;
160
- }
161
- const display = shouldDisplay(view);
162
- if (display) {
163
- inputChipRenderer.show(view);
164
- inputChipRenderer.update(getCurrentLink(view));
165
- } else {
166
- inputChipRenderer.hide();
167
- }
168
- };
169
121
  return [
170
122
  new Plugin({
171
123
  key,
172
124
  view: (editorView) => {
125
+ const inputChipRenderer = utils.themeManager.get<ThemeInputChipType>('input-chip', {
126
+ placeholder: options?.input?.placeholder ?? 'Input Web Link',
127
+ buttonText: options?.input?.buttonText,
128
+ onUpdate: (value) => {
129
+ ctx.get(commandsCtx).call(ModifyLink, value);
130
+ },
131
+ });
132
+ if (!inputChipRenderer) return {};
133
+ const shouldDisplay = (view: EditorView) => {
134
+ const { selection, doc } = view.state;
135
+ const { from, to } = selection;
136
+
137
+ return (
138
+ selection.empty &&
139
+ selection instanceof TextSelection &&
140
+ doc.rangeHasMark(from, from === to ? to + 1 : to, type)
141
+ );
142
+ };
143
+ const getCurrentLink = (view: EditorView) => {
144
+ const { selection } = view.state;
145
+ let node: ProseNode | undefined;
146
+ const { from, to } = selection;
147
+ view.state.doc.nodesBetween(from, from === to ? to + 1 : to, (n) => {
148
+ if (type.isInSet(n.marks)) {
149
+ node = n;
150
+ return false;
151
+ }
152
+ return;
153
+ });
154
+ if (!node) return;
155
+
156
+ const mark = node.marks.find((m) => m.type === type);
157
+ if (!mark) return;
158
+
159
+ const value = mark.attrs['href'];
160
+ return value;
161
+ };
162
+ const renderByView = (view: EditorView) => {
163
+ if (!view.editable) {
164
+ return;
165
+ }
166
+ const display = shouldDisplay(view);
167
+ if (display) {
168
+ inputChipRenderer.show(view);
169
+ inputChipRenderer.update(getCurrentLink(view));
170
+ } else {
171
+ inputChipRenderer.hide();
172
+ }
173
+ };
173
174
  inputChipRenderer.init(editorView);
174
175
  renderByView(editorView);
175
176
 
@@ -1,6 +1,6 @@
1
1
  /* Copyright 2021, Milkdown by Mirone. */
2
2
  import { createCmd, createCmdKey, editorViewCtx, ThemeCodeFenceType } from '@milkdown/core';
3
- import { setBlockType, textblockTypeInputRule } from '@milkdown/prose';
3
+ import { Fragment, setBlockType, textblockTypeInputRule } from '@milkdown/prose';
4
4
  import { createNode, createShortcut } from '@milkdown/utils';
5
5
 
6
6
  import { SupportedKeys } from '../supported-keys';
@@ -52,6 +52,24 @@ export const codeFence = createNode<Keys, { languageList?: string[] }>((utils, o
52
52
  },
53
53
  },
54
54
  parseDOM: [
55
+ {
56
+ tag: 'div.code-fence-container',
57
+ preserveWhitespace: 'full',
58
+ getAttrs: (dom) => {
59
+ if (!(dom instanceof HTMLElement)) {
60
+ throw new Error('Parse DOM error.');
61
+ }
62
+ return { language: dom.querySelector('pre')?.dataset['language'] };
63
+ },
64
+ getContent: (dom, schema) => {
65
+ if (!(dom instanceof HTMLElement)) {
66
+ throw new Error('Parse DOM error.');
67
+ }
68
+ const textNode = schema.text(dom.querySelector('pre')?.textContent ?? '');
69
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
70
+ return Fragment.from<any>(textNode);
71
+ },
72
+ },
55
73
  {
56
74
  tag: 'pre',
57
75
  preserveWhitespace: 'full',
package/src/node/image.ts CHANGED
@@ -156,39 +156,40 @@ export const image = createNode<string, ImageOptions>((utils, options) => {
156
156
  };
157
157
  },
158
158
  prosePlugins: (type, ctx) => {
159
- const inputChipRenderer = utils.themeManager.get<ThemeInputChipType>('input-chip', {
160
- placeholder: options?.input?.placeholder ?? 'Input Image Link',
161
- buttonText: options?.input?.buttonText,
162
- onUpdate: (value) => {
163
- ctx.get(commandsCtx).call(ModifyImage, value);
164
- },
165
- });
166
- const shouldDisplay = (view: EditorView) => {
167
- return Boolean(type && findSelectedNodeOfType(view.state.selection, type));
168
- };
169
- const getCurrentLink = (view: EditorView) => {
170
- const result = findSelectedNodeOfType(view.state.selection, type);
171
- if (!result) return;
172
-
173
- const value = result.node.attrs['src'];
174
- return value;
175
- };
176
- const renderByView = (view: EditorView) => {
177
- if (!view.editable) {
178
- return;
179
- }
180
- const display = shouldDisplay(view);
181
- if (display) {
182
- inputChipRenderer.show(view);
183
- inputChipRenderer.update(getCurrentLink(view));
184
- } else {
185
- inputChipRenderer.hide();
186
- }
187
- };
188
159
  return [
189
160
  new Plugin({
190
161
  key,
191
162
  view: (editorView) => {
163
+ const inputChipRenderer = utils.themeManager.get<ThemeInputChipType>('input-chip', {
164
+ placeholder: options?.input?.placeholder ?? 'Input Image Link',
165
+ buttonText: options?.input?.buttonText,
166
+ onUpdate: (value) => {
167
+ ctx.get(commandsCtx).call(ModifyImage, value);
168
+ },
169
+ });
170
+ if (!inputChipRenderer) return {};
171
+ const shouldDisplay = (view: EditorView) => {
172
+ return Boolean(type && findSelectedNodeOfType(view.state.selection, type));
173
+ };
174
+ const getCurrentLink = (view: EditorView) => {
175
+ const result = findSelectedNodeOfType(view.state.selection, type);
176
+ if (!result) return;
177
+
178
+ const value = result.node.attrs['src'];
179
+ return value;
180
+ };
181
+ const renderByView = (view: EditorView) => {
182
+ if (!view.editable) {
183
+ return;
184
+ }
185
+ const display = shouldDisplay(view);
186
+ if (display) {
187
+ inputChipRenderer.show(view);
188
+ inputChipRenderer.update(getCurrentLink(view));
189
+ } else {
190
+ inputChipRenderer.hide();
191
+ }
192
+ };
192
193
  inputChipRenderer.init(editorView);
193
194
  renderByView(editorView);
194
195