@bigbinary/neeto-editor 1.47.112 → 1.47.113

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.
Files changed (107) hide show
  1. package/dist/Attachments.js +1 -2
  2. package/dist/Attachments.js.map +1 -1
  3. package/dist/Editor.js +11 -6
  4. package/dist/Editor.js.map +1 -1
  5. package/dist/EditorContent.js +4 -2
  6. package/dist/EditorContent.js.map +1 -1
  7. package/dist/FormikEditor.js +5 -6
  8. package/dist/FormikEditor.js.map +1 -1
  9. package/dist/Menu.js +8 -8
  10. package/dist/{chunk-kSsvM8aH.js → chunk--BjpQHaY.js} +2 -3
  11. package/dist/chunk--BjpQHaY.js.map +1 -0
  12. package/dist/{chunk-C26VPEID.js → chunk-3JO2B_HR.js} +2 -3
  13. package/dist/{chunk-C26VPEID.js.map → chunk-3JO2B_HR.js.map} +1 -1
  14. package/dist/{chunk-BDcN2CWH.js → chunk-BKsyn0lE.js} +6 -2
  15. package/dist/chunk-BKsyn0lE.js.map +1 -0
  16. package/dist/{chunk-BOSqhXe9.js → chunk-BLXUWWgi.js} +1 -5
  17. package/dist/{chunk-BOSqhXe9.js.map → chunk-BLXUWWgi.js.map} +1 -1
  18. package/dist/{chunk-0yZ5QmzV.js → chunk-BO6bjSuY.js} +6 -3
  19. package/dist/chunk-BO6bjSuY.js.map +1 -0
  20. package/dist/{chunk-Zi-ccf09.js → chunk-C9Hjlrrk.js} +2 -2
  21. package/dist/chunk-C9Hjlrrk.js.map +1 -0
  22. package/dist/{chunk-DVrXh89W.js → chunk-CNWsmIz_.js} +1 -2
  23. package/dist/chunk-CNWsmIz_.js.map +1 -0
  24. package/dist/{chunk-DRyQ5gRT.js → chunk-Dj7lS7Cs.js} +2 -9
  25. package/dist/{chunk-DRyQ5gRT.js.map → chunk-Dj7lS7Cs.js.map} +1 -1
  26. package/dist/{chunk-B5ZO6MSb.js → chunk-DtQctlVh.js} +2 -4
  27. package/dist/{chunk-B5ZO6MSb.js.map → chunk-DtQctlVh.js.map} +1 -1
  28. package/dist/cjs/Attachments.cjs.js +1 -2
  29. package/dist/cjs/Attachments.cjs.js.map +1 -1
  30. package/dist/cjs/Editor.cjs.js +82 -77
  31. package/dist/cjs/Editor.cjs.js.map +1 -1
  32. package/dist/cjs/EditorContent.cjs.js +4 -2
  33. package/dist/cjs/EditorContent.cjs.js.map +1 -1
  34. package/dist/cjs/FormikEditor.cjs.js +5 -6
  35. package/dist/cjs/FormikEditor.cjs.js.map +1 -1
  36. package/dist/cjs/Menu.cjs.js +8 -8
  37. package/dist/cjs/{chunk-ByqRrEfj.cjs.js → chunk-BYyLrDTW.cjs.js} +2 -3
  38. package/dist/cjs/{chunk-ByqRrEfj.cjs.js.map → chunk-BYyLrDTW.cjs.js.map} +1 -1
  39. package/dist/cjs/{chunk-BE_JvlHl.cjs.js → chunk-B_ZuTQG9.cjs.js} +11 -11
  40. package/dist/cjs/chunk-B_ZuTQG9.cjs.js.map +1 -0
  41. package/dist/cjs/{chunk-UnFuCCxl.cjs.js → chunk-BrQjqeiG.cjs.js} +15 -11
  42. package/dist/cjs/chunk-BrQjqeiG.cjs.js.map +1 -0
  43. package/dist/cjs/{chunk-BJo6VB1g.cjs.js → chunk-CIuJ_EMY.cjs.js} +1 -2
  44. package/dist/cjs/chunk-CIuJ_EMY.cjs.js.map +1 -0
  45. package/dist/cjs/{chunk-Cv7rmxCK.cjs.js → chunk-Cv0ocaVh.cjs.js} +1 -5
  46. package/dist/cjs/{chunk-Cv7rmxCK.cjs.js.map → chunk-Cv0ocaVh.cjs.js.map} +1 -1
  47. package/dist/cjs/{chunk-LeproQrc.cjs.js → chunk-Cvxaj__T.cjs.js} +2 -3
  48. package/dist/cjs/chunk-Cvxaj__T.cjs.js.map +1 -0
  49. package/dist/cjs/{chunk-DQYVBQIk.cjs.js → chunk-DOxH3Agq.cjs.js} +159 -166
  50. package/dist/cjs/{chunk-DQYVBQIk.cjs.js.map → chunk-DOxH3Agq.cjs.js.map} +1 -1
  51. package/dist/cjs/{chunk-Gl_OXcUl.cjs.js → chunk-DRB71ojr.cjs.js} +6 -3
  52. package/dist/cjs/chunk-DRB71ojr.cjs.js.map +1 -0
  53. package/dist/cjs/{chunk-ColwAO4n.cjs.js → chunk-n7U2G1az.cjs.js} +2 -4
  54. package/dist/cjs/{chunk-ColwAO4n.cjs.js.map → chunk-n7U2G1az.cjs.js.map} +1 -1
  55. package/dist/cjs/index.cjs.js +4 -6
  56. package/dist/cjs/index.cjs.js.map +1 -1
  57. package/dist/cjs/v2/Attachments.cjs.js +1 -3
  58. package/dist/cjs/v2/Attachments.cjs.js.map +1 -1
  59. package/dist/cjs/v2/Editor.cjs.js +75 -77
  60. package/dist/cjs/v2/Editor.cjs.js.map +1 -1
  61. package/dist/cjs/v2/EditorContent.cjs.js +1 -3
  62. package/dist/cjs/v2/EditorContent.cjs.js.map +1 -1
  63. package/dist/cjs/v2/FormikEditor.cjs.js +4 -6
  64. package/dist/cjs/v2/FormikEditor.cjs.js.map +1 -1
  65. package/dist/cjs/v2/Menu.cjs.js +6 -7
  66. package/dist/cjs/v2/Menu.cjs.js.map +1 -1
  67. package/dist/cjs/v2/index.cjs.js +8 -11
  68. package/dist/cjs/v2/index.cjs.js.map +1 -1
  69. package/dist/editor-stats.html +19 -1
  70. package/dist/index.js +4 -6
  71. package/dist/index.js.map +1 -1
  72. package/dist/v2/Attachments.js +1 -3
  73. package/dist/v2/Attachments.js.map +1 -1
  74. package/dist/v2/Editor.js +4 -6
  75. package/dist/v2/Editor.js.map +1 -1
  76. package/dist/v2/EditorContent.js +1 -3
  77. package/dist/v2/EditorContent.js.map +1 -1
  78. package/dist/v2/FormikEditor.js +4 -6
  79. package/dist/v2/FormikEditor.js.map +1 -1
  80. package/dist/v2/Menu.js +6 -7
  81. package/dist/v2/Menu.js.map +1 -1
  82. package/dist/v2/index.js +8 -11
  83. package/dist/v2/index.js.map +1 -1
  84. package/dist/v2/styles.css +1 -1
  85. package/dist/v2/styles.js +4 -0
  86. package/dist/v2/styles.js.map +1 -0
  87. package/package.json +3 -1
  88. package/dist/chunk-0yZ5QmzV.js.map +0 -1
  89. package/dist/chunk-3C7ZroSh.js +0 -5
  90. package/dist/chunk-3C7ZroSh.js.map +0 -1
  91. package/dist/chunk-BDcN2CWH.js.map +0 -1
  92. package/dist/chunk-CVfGOKt4.js +0 -5
  93. package/dist/chunk-CVfGOKt4.js.map +0 -1
  94. package/dist/chunk-DVrXh89W.js.map +0 -1
  95. package/dist/chunk-Zi-ccf09.js.map +0 -1
  96. package/dist/chunk-kSsvM8aH.js.map +0 -1
  97. package/dist/cjs/chunk-BE_JvlHl.cjs.js.map +0 -1
  98. package/dist/cjs/chunk-BJo6VB1g.cjs.js.map +0 -1
  99. package/dist/cjs/chunk-BaJ2GldN.cjs.js +0 -7
  100. package/dist/cjs/chunk-BaJ2GldN.cjs.js.map +0 -1
  101. package/dist/cjs/chunk-DcAwRABD.cjs.js +0 -7
  102. package/dist/cjs/chunk-DcAwRABD.cjs.js.map +0 -1
  103. package/dist/cjs/chunk-Gl_OXcUl.cjs.js.map +0 -1
  104. package/dist/cjs/chunk-LeproQrc.cjs.js.map +0 -1
  105. package/dist/cjs/chunk-UnFuCCxl.cjs.js.map +0 -1
  106. package/dist/v2/_styles-bundle.js +0 -4
  107. package/dist/v2/_styles-bundle.js.map +0 -1
@@ -6,19 +6,19 @@ var _slicedToArray = require('@babel/runtime/helpers/slicedToArray');
6
6
  var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProperties');
7
7
  var React = require('react');
8
8
  var neetoAtoms = require('@bigbinary/neeto-atoms');
9
- var menu = require('../chunk-Cv7rmxCK.cjs.js');
9
+ var useEditorStore = require('../chunk-Cv0ocaVh.cjs.js');
10
10
  var classnames = require('classnames');
11
11
  var neetoCist = require('@bigbinary/neeto-cist');
12
12
  var reactUtils = require('@bigbinary/neeto-commons-frontend/v2/react-utils');
13
13
  var ReactDOM$1 = require('react-dom');
14
- var index = require('../chunk-DQYVBQIk.cjs.js');
14
+ var index = require('../chunk-DOxH3Agq.cjs.js');
15
15
  var constants = require('../chunk-2HrSPdAV.cjs.js');
16
16
  require('../chunk-BGy3NmZC.cjs.js');
17
17
  var ramda = require('ramda');
18
18
  var ReactDOM = require('react-dom/server');
19
19
  var common = require('../chunk-De3nCFAF.cjs.js');
20
20
  var jsxRuntime = require('react/jsx-runtime');
21
- var v2_Menu = require('../chunk-BE_JvlHl.cjs.js');
21
+ var v2_Menu = require('../chunk-B_ZuTQG9.cjs.js');
22
22
  var Megaphone = require('@bigbinary/neeto-icons/misc/Megaphone');
23
23
  var index$1 = require('../chunk-eyfbjfPH.cjs.js');
24
24
  var lucideReact = require('lucide-react');
@@ -73,11 +73,10 @@ var InsertColumn = require('@bigbinary/neeto-icons/InsertColumn');
73
73
  var MergeSplit = require('@bigbinary/neeto-icons/MergeSplit');
74
74
  var ToggleHeaderRow = require('@bigbinary/neeto-icons/ToggleHeaderRow');
75
75
  var formik = require('@bigbinary/neeto-atoms/formik');
76
- var v2_Attachments = require('../chunk-LeproQrc.cjs.js');
76
+ var v2_Attachments = require('../chunk-Cvxaj__T.cjs.js');
77
77
  require('axios');
78
78
  require('@bigbinary/neeto-commons-frontend/react-utils');
79
79
  require('zustand');
80
- require('../chunk-B6qYtOJe.cjs.js');
81
80
  require('@bigbinary/neeto-commons-frontend/initializers');
82
81
  require('@tanstack/react-query');
83
82
  require('yjs');
@@ -101,7 +100,6 @@ require('@bigbinary/neeto-icons/AspectRatio169');
101
100
  require('@bigbinary/neeto-icons/AspectRatio916');
102
101
  require('@bigbinary/neeto-icons/AspectRatio43');
103
102
  require('@bigbinary/neeto-icons/AspectRatio32');
104
- require('../chunk-DcAwRABD.cjs.js');
105
103
  require('@bigbinary/neeto-commons-frontend/v2/react-utils/useOnClickOutside');
106
104
 
107
105
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
@@ -205,7 +203,7 @@ var CharacterCountWrapper = function CharacterCountWrapper(_ref) {
205
203
  });
206
204
  };
207
205
 
208
- var HighlightInternal = menu.Extension.create({
206
+ var HighlightInternal = useEditorStore.Extension.create({
209
207
  name: "HighlightInternal",
210
208
  addOptions: function addOptions() {
211
209
  return {
@@ -269,7 +267,7 @@ var CalloutComponent = function CalloutComponent(_ref) {
269
267
  var Icon = ((_findBy = neetoCist.findBy({
270
268
  type: type
271
269
  }, v2_Menu.CALLOUT_TYPES)) === null || _findBy === void 0 ? void 0 : _findBy.icon) || Megaphone__default.default;
272
- return /*#__PURE__*/jsxRuntime.jsx(menu.NodeViewWrapper, {
270
+ return /*#__PURE__*/jsxRuntime.jsx(useEditorStore.NodeViewWrapper, {
273
271
  className: "neeto-editor__callout neeto-editor__callout--".concat(type, " group"),
274
272
  "data-emoji": type,
275
273
  children: /*#__PURE__*/jsxRuntime.jsxs("div", {
@@ -277,7 +275,7 @@ var CalloutComponent = function CalloutComponent(_ref) {
277
275
  children: [/*#__PURE__*/jsxRuntime.jsx("span", {
278
276
  className: "callout-emoji",
279
277
  children: /*#__PURE__*/jsxRuntime.jsx(Icon, {})
280
- }), /*#__PURE__*/jsxRuntime.jsx(menu.NodeViewContent, {
278
+ }), /*#__PURE__*/jsxRuntime.jsx(useEditorStore.NodeViewContent, {
281
279
  className: "callout-content",
282
280
  "data-testid": "callout-content"
283
281
  })]
@@ -285,7 +283,7 @@ var CalloutComponent = function CalloutComponent(_ref) {
285
283
  });
286
284
  };
287
285
 
288
- var Callout = menu.Node.create({
286
+ var Callout = useEditorStore.Node.create({
289
287
  name: "callout",
290
288
  inline: false,
291
289
  group: "block",
@@ -326,7 +324,7 @@ var Callout = menu.Node.create({
326
324
  var svgContainer = document.createElement("div");
327
325
  svgContainer.innerHTML = svgString;
328
326
  var svgNode = svgContainer.firstChild;
329
- return ["div", menu.mergeAttributes(this.options.HTMLAttributes, HTMLAttributes, {
327
+ return ["div", useEditorStore.mergeAttributes(this.options.HTMLAttributes, HTMLAttributes, {
330
328
  "class": "neeto-editor__callout neeto-editor__callout--".concat(type),
331
329
  "data-emoji": type
332
330
  }), ["div", {
@@ -338,7 +336,7 @@ var Callout = menu.Node.create({
338
336
  }, 0]]];
339
337
  },
340
338
  addNodeView: function addNodeView() {
341
- return menu.ReactNodeViewRenderer(CalloutComponent);
339
+ return useEditorStore.ReactNodeViewRenderer(CalloutComponent);
342
340
  },
343
341
  addCommands: function addCommands() {
344
342
  var _this = this;
@@ -436,7 +434,7 @@ var Callout = menu.Node.create({
436
434
  /* eslint-disable @bigbinary/neeto/file-name-and-export-name-standards */
437
435
  var codeBlockHighlightKey = new index$1.PluginKey("codeBlockHighlight");
438
436
  function createLineDecoration(from, lineNumber) {
439
- return menu.Decoration.widget(from, function (view) {
437
+ return useEditorStore.Decoration.widget(from, function (view) {
440
438
  var line = document.createElement("div");
441
439
  line.className = "highlighted-line";
442
440
  line.setAttribute("data-line-number", lineNumber.toString());
@@ -469,7 +467,7 @@ var codeBlockHighlightPlugin = new index$1.Plugin({
469
467
  key: codeBlockHighlightKey,
470
468
  state: {
471
469
  init: function init() {
472
- return menu.DecorationSet.empty;
470
+ return useEditorStore.DecorationSet.empty;
473
471
  },
474
472
  apply: function apply(tr, set) {
475
473
  set = set.map(tr.mapping, tr.doc);
@@ -487,7 +485,7 @@ var codeBlockHighlightPlugin = new index$1.Plugin({
487
485
  }
488
486
  });
489
487
  });
490
- return menu.DecorationSet.create(tr.doc, decorations);
488
+ return useEditorStore.DecorationSet.create(tr.doc, decorations);
491
489
  }
492
490
  return set;
493
491
  }
@@ -589,7 +587,7 @@ var CodeBlockComponent = function CodeBlockComponent(_ref) {
589
587
  });
590
588
  editor.view.dispatch(editor.state.tr.setMeta(codeBlockHighlightKey, true));
591
589
  };
592
- return /*#__PURE__*/jsxRuntime.jsx(menu.NodeViewWrapper, {
590
+ return /*#__PURE__*/jsxRuntime.jsx(useEditorStore.NodeViewWrapper, {
593
591
  className: "ne-codeblock-nodeview-wrapper ne-codeblock--v2",
594
592
  "data-testid": "neeto-editor-code-block",
595
593
  children: /*#__PURE__*/jsxRuntime.jsx("div", {
@@ -672,7 +670,7 @@ var CodeBlockComponent = function CodeBlockComponent(_ref) {
672
670
  variant: "secondary",
673
671
  onClick: handleHighlight
674
672
  })]
675
- }), /*#__PURE__*/jsxRuntime.jsx(menu.NodeViewContent, {
673
+ }), /*#__PURE__*/jsxRuntime.jsx(useEditorStore.NodeViewContent, {
676
674
  as: "code"
677
675
  })]
678
676
  })
@@ -717,14 +715,14 @@ var CodeBlock = index.CodeBlockLowlight.extend({
717
715
  return [].concat(_toConsumableArray__default.default(((_this$parent2 = this.parent) === null || _this$parent2 === void 0 ? void 0 : _this$parent2.call(this)) || []), [codeBlockHighlightPlugin]);
718
716
  },
719
717
  addNodeView: function addNodeView() {
720
- return menu.ReactNodeViewRenderer(CodeBlockComponent);
718
+ return useEditorStore.ReactNodeViewRenderer(CodeBlockComponent);
721
719
  }
722
720
  }).configure({
723
721
  lowlight: common.lowlight,
724
722
  defaultLanguage: "plaintext"
725
723
  });
726
724
 
727
- var CustomCommands = menu.Extension.create({
725
+ var CustomCommands = useEditorStore.Extension.create({
728
726
  name: "paste-unformatted",
729
727
  addCommands: function addCommands() {
730
728
  return {
@@ -756,7 +754,7 @@ var CustomCommands = menu.Extension.create({
756
754
  }
757
755
  });
758
756
 
759
- var DeletedArticleDecoration = menu.Extension.create({
757
+ var DeletedArticleDecoration = useEditorStore.Extension.create({
760
758
  name: "deletedArticleDecoration",
761
759
  addOptions: function addOptions() {
762
760
  return {
@@ -779,14 +777,14 @@ var DeletedArticleDecoration = menu.Extension.create({
779
777
  }
780
778
  var articleId = mark.attrs["data-article-id"];
781
779
  if (!_this.options.deletedArticleIds.has(articleId)) return;
782
- var decoration = menu.Decoration.inline(pos, pos + node.nodeSize, {
780
+ var decoration = useEditorStore.Decoration.inline(pos, pos + node.nodeSize, {
783
781
  "data-article-deleted": "true",
784
782
  "class": "neeto-kb-article-deleted"
785
783
  });
786
784
  decorations.push(decoration);
787
785
  });
788
786
  });
789
- return menu.DecorationSet.create(doc, decorations);
787
+ return useEditorStore.DecorationSet.create(doc, decorations);
790
788
  }
791
789
  }
792
790
  })];
@@ -808,7 +806,7 @@ var DeletedArticleDecoration = menu.Extension.create({
808
806
  function ownKeys$i(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
809
807
  function _objectSpread$i(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$i(Object(t), true).forEach(function (r) { _defineProperty__default.default(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$i(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
810
808
  var EmojiPickerPluginKey = new index$1.PluginKey("emoji-picker");
811
- var EmojiPicker = menu.Node.create({
809
+ var EmojiPicker = useEditorStore.Node.create({
812
810
  name: "emojiPicker",
813
811
  group: "inline",
814
812
  inline: true,
@@ -828,7 +826,7 @@ var EmojiPicker = menu.Node.create({
828
826
  var popup;
829
827
  return {
830
828
  onStart: function onStart(props) {
831
- reactRenderer = new menu.ReactRenderer(v2_Menu.EmojiPickerMenu, {
829
+ reactRenderer = new useEditorStore.ReactRenderer(v2_Menu.EmojiPickerMenu, {
832
830
  props: props,
833
831
  editor: props.editor
834
832
  });
@@ -913,7 +911,7 @@ var EmojiSuggestionMenu = /*#__PURE__*/function (_React$Component) {
913
911
  });
914
912
  _context.prev = 1;
915
913
  _context.next = 4;
916
- return menu.emojiPickerApi.fetch();
914
+ return useEditorStore.emojiPickerApi.fetch();
917
915
  case 4:
918
916
  _yield$emojiPickerApi = _context.sent;
919
917
  data = _yield$emojiPickerApi.data;
@@ -1084,7 +1082,7 @@ var EmojiSuggestionMenu = /*#__PURE__*/function (_React$Component) {
1084
1082
  function ownKeys$h(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
1085
1083
  function _objectSpread$h(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$h(Object(t), true).forEach(function (r) { _defineProperty__default.default(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$h(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
1086
1084
  var EmojiSuggestionPluginKey = new index$1.PluginKey("emoji-suggestion");
1087
- var EmojiSuggestion$1 = menu.Node.create({
1085
+ var EmojiSuggestion$1 = useEditorStore.Node.create({
1088
1086
  name: "emojiSuggestion",
1089
1087
  group: "inline",
1090
1088
  inline: true,
@@ -1128,7 +1126,7 @@ var EmojiSuggestion$1 = menu.Node.create({
1128
1126
  renderHTML: function renderHTML(_ref2) {
1129
1127
  var node = _ref2.node,
1130
1128
  HTMLAttributes = _ref2.HTMLAttributes;
1131
- return ["span", menu.mergeAttributes({
1129
+ return ["span", useEditorStore.mergeAttributes({
1132
1130
  "data-emoji": ""
1133
1131
  }, this.options.HTMLAttributes, HTMLAttributes), this.options.renderEmoji({
1134
1132
  node: node
@@ -1193,7 +1191,7 @@ var suggestionConfig = {
1193
1191
  var _popup$;
1194
1192
  var isArrowNavigation = props.editor.view.input.lastKeyCode === 39 || props.editor.view.input.lastKeyCode === 37;
1195
1193
  if (!isArrowNavigation && props.query.length === 1 && EMOJI_QUERY_REGEX.test(props.query)) {
1196
- reactRenderer = new menu.ReactRenderer(EmojiSuggestionMenu, {
1194
+ reactRenderer = new useEditorStore.ReactRenderer(EmojiSuggestionMenu, {
1197
1195
  props: props,
1198
1196
  editor: props.editor
1199
1197
  });
@@ -1501,7 +1499,7 @@ var ImageComponent = function ImageComponent(_ref) {
1501
1499
  editor.commands.focus();
1502
1500
  };
1503
1501
  if (neetoCist.isNotPresent(src) && neetoCist.isNotPresent(alt)) return null;
1504
- return /*#__PURE__*/jsxRuntime.jsxs(menu.NodeViewWrapper, {
1502
+ return /*#__PURE__*/jsxRuntime.jsxs(useEditorStore.NodeViewWrapper, {
1505
1503
  "data-testid": "neeto-editor-image-wrapper",
1506
1504
  className: classnames__default.default("neeto-editor__image-wrapper", "neeto-editor__image--".concat(align), {
1507
1505
  "neeto-editor__image--bordered": border
@@ -1539,7 +1537,7 @@ var ImageComponent = function ImageComponent(_ref) {
1539
1537
  }) : /*#__PURE__*/jsxRuntime.jsx("div", {
1540
1538
  className: "neeto-editor__image-placeholder",
1541
1539
  children: /*#__PURE__*/jsxRuntime.jsx(neetoAtoms.Spinner, {})
1542
- }), /*#__PURE__*/jsxRuntime.jsx(menu.NodeViewContent, {
1540
+ }), /*#__PURE__*/jsxRuntime.jsx(useEditorStore.NodeViewContent, {
1543
1541
  as: "figcaption",
1544
1542
  className: classnames__default.default({
1545
1543
  "is-empty": ramda.isEmpty(caption)
@@ -1597,7 +1595,7 @@ var findNextTextPos = function findNextTextPos(editor, pos) {
1597
1595
  });
1598
1596
  return foundPos;
1599
1597
  };
1600
- var ImageExtension = menu.Node.create({
1598
+ var ImageExtension = useEditorStore.Node.create({
1601
1599
  name: "image",
1602
1600
  addOptions: function addOptions() {
1603
1601
  return {
@@ -1694,14 +1692,14 @@ var ImageExtension = menu.Node.create({
1694
1692
  var captionAttrs = {
1695
1693
  style: "width:".concat(figwidth, "px;")
1696
1694
  };
1697
- return ["div", wrapperDivAttrs, ["figure", this.options.HTMLAttributes, ["a", wrapperLinkAttrs, ["img", menu.mergeAttributes(HTMLAttributes, {
1695
+ return ["div", wrapperDivAttrs, ["figure", this.options.HTMLAttributes, ["a", wrapperLinkAttrs, ["img", useEditorStore.mergeAttributes(HTMLAttributes, {
1698
1696
  draggable: false,
1699
1697
  contenteditable: false,
1700
1698
  "data-border": border
1701
1699
  })]], ["figcaption", captionAttrs, 0]]];
1702
1700
  },
1703
1701
  addNodeView: function addNodeView() {
1704
- return menu.ReactNodeViewRenderer(ImageComponent);
1702
+ return useEditorStore.ReactNodeViewRenderer(ImageComponent);
1705
1703
  },
1706
1704
  addCommands: function addCommands() {
1707
1705
  var _this = this;
@@ -1855,7 +1853,7 @@ var ImageExtension = menu.Node.create({
1855
1853
  }
1856
1854
  });
1857
1855
 
1858
- var FigCaption = menu.Node.create({
1856
+ var FigCaption = useEditorStore.Node.create({
1859
1857
  name: "figcaption",
1860
1858
  content: "text*",
1861
1859
  selectable: false,
@@ -1867,7 +1865,7 @@ var FigCaption = menu.Node.create({
1867
1865
  },
1868
1866
  renderHTML: function renderHTML(_ref) {
1869
1867
  var HTMLAttributes = _ref.HTMLAttributes;
1870
- return ["figcaption", menu.mergeAttributes(HTMLAttributes), 0];
1868
+ return ["figcaption", useEditorStore.mergeAttributes(HTMLAttributes), 0];
1871
1869
  }
1872
1870
  });
1873
1871
 
@@ -1886,7 +1884,7 @@ var KeyboardShortcuts$1 = function KeyboardShortcuts(_ref) {
1886
1884
  var onSubmit = _ref.onSubmit,
1887
1885
  shortcuts = _ref.shortcuts,
1888
1886
  isBlockQuoteActive = _ref.isBlockQuoteActive;
1889
- return menu.Extension.create({
1887
+ return useEditorStore.Extension.create({
1890
1888
  name: "keyboard-shortcuts",
1891
1889
  addKeyboardShortcuts: function addKeyboardShortcuts() {
1892
1890
  var _this = this;
@@ -1924,8 +1922,8 @@ var LINK_MARKDOWN_INPUT_REGEX = /(?:^|\s)\[([^\]]*)?\]\((\S+)(?: ["“](.+)["”
1924
1922
  function ownKeys$e(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
1925
1923
  function _objectSpread$e(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$e(Object(t), true).forEach(function (r) { _defineProperty__default.default(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$e(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
1926
1924
  var linkInputRule = function linkInputRule(config) {
1927
- var defaultMarkInputRule = menu.markInputRule(config);
1928
- return new menu.InputRule({
1925
+ var defaultMarkInputRule = useEditorStore.markInputRule(config);
1926
+ return new useEditorStore.InputRule({
1929
1927
  find: config.find,
1930
1928
  handler: function handler(props) {
1931
1929
  try {
@@ -1989,7 +1987,7 @@ var Link = index.Link.extend({
1989
1987
  },
1990
1988
  renderHTML: function renderHTML(_ref) {
1991
1989
  var HTMLAttributes = _ref.HTMLAttributes;
1992
- return ["a", menu.mergeAttributes(this.options.HTMLAttributes, HTMLAttributes, {
1990
+ return ["a", useEditorStore.mergeAttributes(this.options.HTMLAttributes, HTMLAttributes, {
1993
1991
  "class": "link"
1994
1992
  }), 0];
1995
1993
  },
@@ -2168,7 +2166,7 @@ var suggestion$1 = {
2168
2166
  var popup;
2169
2167
  return {
2170
2168
  onStart: function onStart(props) {
2171
- reactRenderer = new menu.ReactRenderer(MentionList, {
2169
+ reactRenderer = new useEditorStore.ReactRenderer(MentionList, {
2172
2170
  props: props,
2173
2171
  editor: props.editor
2174
2172
  });
@@ -2251,7 +2249,7 @@ var OrderedList = index.OrderedList.configure({
2251
2249
  itemTypeName: "listItem"
2252
2250
  });
2253
2251
 
2254
- var Placeholder = menu.Extension.create({
2252
+ var Placeholder = useEditorStore.Extension.create({
2255
2253
  name: "placeholder",
2256
2254
  addOptions: function addOptions() {
2257
2255
  return {
@@ -2294,7 +2292,7 @@ var Placeholder = menu.Extension.create({
2294
2292
  classes.push("is-current-slash-placeholder");
2295
2293
  placeholderText = _this.options.slashCommandsPlaceholder;
2296
2294
  }
2297
- var decoration = menu.Decoration.node(pos, pos + node.nodeSize, {
2295
+ var decoration = useEditorStore.Decoration.node(pos, pos + node.nodeSize, {
2298
2296
  "class": classes.join(" "),
2299
2297
  "data-placeholder": placeholderText
2300
2298
  });
@@ -2302,7 +2300,7 @@ var Placeholder = menu.Extension.create({
2302
2300
  }
2303
2301
  return _this.options.includeChildren;
2304
2302
  });
2305
- return menu.DecorationSet.create(doc, decorations);
2303
+ return useEditorStore.DecorationSet.create(doc, decorations);
2306
2304
  }
2307
2305
  }
2308
2306
  })];
@@ -2317,7 +2315,7 @@ var SelectionDecoration = index.Document.extend({
2317
2315
  state: {
2318
2316
  init: function init() {
2319
2317
  return {
2320
- decorations: menu.DecorationSet.empty,
2318
+ decorations: useEditorStore.DecorationSet.empty,
2321
2319
  selectedTextDecoration: null
2322
2320
  };
2323
2321
  },
@@ -2330,7 +2328,7 @@ var SelectionDecoration = index.Document.extend({
2330
2328
  decorations = decorations.remove([selectedTextDecoration]);
2331
2329
  }
2332
2330
  if (!selection.empty) {
2333
- selectedTextDecoration = menu.Decoration.inline(selection.from, selection.to, {
2331
+ selectedTextDecoration = useEditorStore.Decoration.inline(selection.from, selection.to, {
2334
2332
  "class": "selected-text"
2335
2333
  });
2336
2334
  decorations = decorations.add(doc, [selectedTextDecoration]);
@@ -2988,7 +2986,7 @@ var SlashCommands = {
2988
2986
  attachmentProps: attachmentProps,
2989
2987
  setIsNeetoKbArticleActive: setIsNeetoKbArticleActive
2990
2988
  });
2991
- return menu.Extension.create({
2989
+ return useEditorStore.Extension.create({
2992
2990
  name: "slash-commands",
2993
2991
  addOptions: function addOptions() {
2994
2992
  return {
@@ -3022,7 +3020,7 @@ var SlashCommands = {
3022
3020
  if (props.editor.isActive("image") || props.editor.isActive("codeBlock")) {
3023
3021
  return;
3024
3022
  }
3025
- reactRenderer = new menu.ReactRenderer(CommandsList, {
3023
+ reactRenderer = new useEditorStore.ReactRenderer(CommandsList, {
3026
3024
  props: props,
3027
3025
  editor: props.editor
3028
3026
  });
@@ -3041,7 +3039,7 @@ var SlashCommands = {
3041
3039
  role: "dropdown",
3042
3040
  theme: "light neeto-editor-slash-commands-tippy"
3043
3041
  });
3044
- menu.highlightFocussedNode();
3042
+ useEditorStore.highlightFocussedNode();
3045
3043
  },
3046
3044
  onUpdate: function onUpdate(props) {
3047
3045
  var _reactRenderer;
@@ -3064,7 +3062,7 @@ var SlashCommands = {
3064
3062
  onExit: function onExit() {
3065
3063
  popup && popup[0].destroy();
3066
3064
  reactRenderer && reactRenderer.destroy();
3067
- menu.resetFocussedNode();
3065
+ useEditorStore.resetFocussedNode();
3068
3066
  }
3069
3067
  };
3070
3068
  }
@@ -3098,7 +3096,7 @@ var suggestion = {
3098
3096
  var popup;
3099
3097
  return {
3100
3098
  onStart: function onStart(props) {
3101
- reactRenderer = new menu.ReactRenderer(MentionList, {
3099
+ reactRenderer = new useEditorStore.ReactRenderer(MentionList, {
3102
3100
  props: props,
3103
3101
  editor: props.editor
3104
3102
  });
@@ -3143,7 +3141,7 @@ var SpecialMentions$1 = index.Mention.extend({
3143
3141
  renderHTML: function renderHTML(_ref2) {
3144
3142
  var node = _ref2.node,
3145
3143
  HTMLAttributes = _ref2.HTMLAttributes;
3146
- return ["span", menu.mergeAttributes({
3144
+ return ["span", useEditorStore.mergeAttributes({
3147
3145
  "data-type": this.name
3148
3146
  }, this.options.HTMLAttributes, HTMLAttributes), renderLabel({
3149
3147
  options: this.options,
@@ -3446,7 +3444,7 @@ var VariableComponent = function VariableComponent(_ref) {
3446
3444
  label = _node$attrs.label;
3447
3445
  var variableName = label || id;
3448
3446
  var shouldTruncate = variableName.length > MAX_VARIABLE_NAME_DISPLAY_LENGTH;
3449
- return /*#__PURE__*/jsxRuntime.jsxs(menu.NodeViewWrapper, {
3447
+ return /*#__PURE__*/jsxRuntime.jsxs(useEditorStore.NodeViewWrapper, {
3450
3448
  as: "span",
3451
3449
  className: "neeto-editor-variable",
3452
3450
  "data-label": id,
@@ -3461,7 +3459,7 @@ var VariableComponent = function VariableComponent(_ref) {
3461
3459
  };
3462
3460
 
3463
3461
  new index$1.PluginKey("variables");
3464
- var Variable = menu.Node.create({
3462
+ var Variable = useEditorStore.Node.create({
3465
3463
  name: "variable",
3466
3464
  addOptions: function addOptions() {
3467
3465
  return {
@@ -3518,7 +3516,7 @@ var Variable = menu.Node.create({
3518
3516
  renderHTML: function renderHTML(_ref2) {
3519
3517
  var node = _ref2.node,
3520
3518
  HTMLAttributes = _ref2.HTMLAttributes;
3521
- return ["span", menu.mergeAttributes({
3519
+ return ["span", useEditorStore.mergeAttributes({
3522
3520
  "data-variable": ""
3523
3521
  }, this.options.HTMLAttributes, HTMLAttributes), this.options.renderLabel({
3524
3522
  options: this.options,
@@ -3533,7 +3531,7 @@ var Variable = menu.Node.create({
3533
3531
  });
3534
3532
  },
3535
3533
  addNodeView: function addNodeView() {
3536
- return menu.ReactNodeViewRenderer(VariableComponent);
3534
+ return useEditorStore.ReactNodeViewRenderer(VariableComponent);
3537
3535
  },
3538
3536
  addCommands: function addCommands() {
3539
3537
  var _this = this;
@@ -3598,7 +3596,7 @@ var VideoComponent = function VideoComponent(_ref) {
3598
3596
  editor.commands.focus();
3599
3597
  };
3600
3598
  if (neetoCist.isNotPresent(src)) return null;
3601
- return /*#__PURE__*/jsxRuntime.jsx(menu.NodeViewWrapper, {
3599
+ return /*#__PURE__*/jsxRuntime.jsx(useEditorStore.NodeViewWrapper, {
3602
3600
  className: classnames__default.default("neeto-editor__image-wrapper", "neeto-editor__image--".concat(align), {
3603
3601
  "neeto-editor__image--bordered": border
3604
3602
  }),
@@ -3630,7 +3628,7 @@ var VideoComponent = function VideoComponent(_ref) {
3630
3628
  "data-border": border,
3631
3629
  preload: "metadata"
3632
3630
  }))
3633
- }), /*#__PURE__*/jsxRuntime.jsx(menu.NodeViewContent, {
3631
+ }), /*#__PURE__*/jsxRuntime.jsx(useEditorStore.NodeViewContent, {
3634
3632
  as: "figcaption",
3635
3633
  className: classnames__default.default({
3636
3634
  "is-empty": ramda.isEmpty(caption)
@@ -3671,7 +3669,7 @@ var EmbedComponent = function EmbedComponent(_ref) {
3671
3669
  })));
3672
3670
  editor.commands.focus();
3673
3671
  };
3674
- return /*#__PURE__*/jsxRuntime.jsx(menu.NodeViewWrapper, {
3672
+ return /*#__PURE__*/jsxRuntime.jsx(useEditorStore.NodeViewWrapper, {
3675
3673
  "data-testid": "neeto-editor-video-wrapper",
3676
3674
  className: classnames__default.default("neeto-editor__video-wrapper", "neeto-editor__video--".concat(align), {
3677
3675
  "neeto-editor__video--bordered": border
@@ -3817,7 +3815,7 @@ var renderEmbedHTML = function renderEmbedHTML(node, HTMLAttributes, options) {
3817
3815
  }),
3818
3816
  style: "width: ".concat(figwidth, "px; height: ").concat(figheight, "px;"),
3819
3817
  "data-aspect-ratio": aspectRatio
3820
- }, ["iframe", menu.mergeAttributes(options.HTMLAttributes, _objectSpread$4(_objectSpread$4({}, HTMLAttributes), {}, {
3818
+ }, ["iframe", useEditorStore.mergeAttributes(options.HTMLAttributes, _objectSpread$4(_objectSpread$4({}, HTMLAttributes), {}, {
3821
3819
  allowfullscreen: true,
3822
3820
  "data-border": border
3823
3821
  }))]]];
@@ -3842,9 +3840,9 @@ var renderUploadHTML = function renderUploadHTML(node, HTMLAttributes, options)
3842
3840
  var captionAttrs = {
3843
3841
  style: "width:".concat(vidwidth, "px;")
3844
3842
  };
3845
- return ["div", wrapperDivAttrs, ["figure", menu.mergeAttributes(options.HTMLAttributes, {
3843
+ return ["div", wrapperDivAttrs, ["figure", useEditorStore.mergeAttributes(options.HTMLAttributes, {
3846
3844
  "data-video": ""
3847
- }), ["a", wrapperLinkAttrs, ["video", menu.mergeAttributes(HTMLAttributes, {
3845
+ }), ["a", wrapperLinkAttrs, ["video", useEditorStore.mergeAttributes(HTMLAttributes, {
3848
3846
  preload: "metadata",
3849
3847
  controls: true,
3850
3848
  draggable: false,
@@ -3869,7 +3867,7 @@ var handleVideoPaste = function handleVideoPaste(_ref) {
3869
3867
  state.tr.setSelection(index$1.TextSelection.create(state.tr.doc, range.from + node.nodeSize + 1));
3870
3868
  }
3871
3869
  };
3872
- var UnifiedVideoExtension = menu.Node.create({
3870
+ var UnifiedVideoExtension = useEditorStore.Node.create({
3873
3871
  name: "unified-video",
3874
3872
  addOptions: function addOptions() {
3875
3873
  return {
@@ -3908,7 +3906,7 @@ var UnifiedVideoExtension = menu.Node.create({
3908
3906
  return videoType === "embed" ? renderEmbedHTML(node, HTMLAttributes, this.options) : renderUploadHTML(node, HTMLAttributes, this.options);
3909
3907
  },
3910
3908
  addNodeView: function addNodeView() {
3911
- return menu.ReactNodeViewRenderer(function (_ref3) {
3909
+ return useEditorStore.ReactNodeViewRenderer(function (_ref3) {
3912
3910
  var node = _ref3.node,
3913
3911
  props = _objectWithoutProperties__default.default(_ref3, _excluded$1);
3914
3912
  var videoType = node.attrs.videoType;
@@ -3960,7 +3958,7 @@ var UnifiedVideoExtension = menu.Node.create({
3960
3958
  };
3961
3959
  },
3962
3960
  addPasteRules: function addPasteRules() {
3963
- return [new menu.PasteRule({
3961
+ return [new useEditorStore.PasteRule({
3964
3962
  find: constants.COMBINED_REGEX,
3965
3963
  handler: handleVideoPaste
3966
3964
  })];
@@ -4539,7 +4537,7 @@ var TableActionMenu = function TableActionMenu(_ref) {
4539
4537
  return (editor === null || editor === void 0 ? void 0 : editor.isFocused) && (editor === null || editor === void 0 ? void 0 : editor.isActive("table"));
4540
4538
  }, [editor]);
4541
4539
  if (!editor) return null;
4542
- return /*#__PURE__*/jsxRuntime.jsx(menu.BubbleMenu, {
4540
+ return /*#__PURE__*/jsxRuntime.jsx(useEditorStore.BubbleMenu, {
4543
4541
  editor: editor,
4544
4542
  shouldShow: shouldShow,
4545
4543
  className: "neeto-editor-bubble-menu",
@@ -4888,9 +4886,9 @@ var LinkPopOver = function LinkPopOver(_ref) {
4888
4886
  var _editor$view = editor.view,
4889
4887
  state = _editor$view.state,
4890
4888
  dispatch = _editor$view.dispatch;
4891
- var type = menu.getMarkType("link", state.schema);
4889
+ var type = useEditorStore.getMarkType("link", state.schema);
4892
4890
  var $to = state.selection.$to;
4893
- var _ref5 = menu.getMarkRange($to, type) || {},
4891
+ var _ref5 = useEditorStore.getMarkRange($to, type) || {},
4894
4892
  _ref5$from = _ref5.from,
4895
4893
  from = _ref5$from === void 0 ? null : _ref5$from,
4896
4894
  _ref5$to = _ref5.to,
@@ -4915,9 +4913,9 @@ var LinkPopOver = function LinkPopOver(_ref) {
4915
4913
  var _editor$view2 = editor.view,
4916
4914
  state = _editor$view2.state,
4917
4915
  dispatch = _editor$view2.dispatch;
4918
- var type = menu.getMarkType("link", state.schema);
4916
+ var type = useEditorStore.getMarkType("link", state.schema);
4919
4917
  var $to = state.selection.$to;
4920
- var _ref7 = menu.getMarkRange($to, type) || {},
4918
+ var _ref7 = useEditorStore.getMarkRange($to, type) || {},
4921
4919
  _ref7$from = _ref7.from,
4922
4920
  _from = _ref7$from === void 0 ? null : _ref7$from,
4923
4921
  _ref7$to = _ref7.to,
@@ -4952,9 +4950,9 @@ var LinkPopOver = function LinkPopOver(_ref) {
4952
4950
  var _editor$view3 = editor.view,
4953
4951
  _state = _editor$view3.state,
4954
4952
  _dispatch = _editor$view3.dispatch;
4955
- var _type = menu.getMarkType("link", _state.schema);
4953
+ var _type = useEditorStore.getMarkType("link", _state.schema);
4956
4954
  var _$to = _state.selection.$to;
4957
- var _ref8 = menu.getMarkRange(_$to, _type) || {},
4955
+ var _ref8 = useEditorStore.getMarkRange(_$to, _type) || {},
4958
4956
  _ref8$from = _ref8.from,
4959
4957
  _from2 = _ref8$from === void 0 ? null : _ref8$from,
4960
4958
  _ref8$to = _ref8.to,
@@ -5012,9 +5010,9 @@ var LinkPopOver = function LinkPopOver(_ref) {
5012
5010
  };
5013
5011
  var getCurrentTextContent = function getCurrentTextContent() {
5014
5012
  var state = editor.view.state;
5015
- var type = menu.getMarkType("link", state.schema);
5013
+ var type = useEditorStore.getMarkType("link", state.schema);
5016
5014
  var $to = state.selection.$to;
5017
- var _ref9 = menu.getMarkRange($to, type) || {},
5015
+ var _ref9 = useEditorStore.getMarkRange($to, type) || {},
5018
5016
  _ref9$from = _ref9.from,
5019
5017
  from = _ref9$from === void 0 ? null : _ref9$from,
5020
5018
  _ref9$to = _ref9.to,
@@ -5357,7 +5355,7 @@ var Editor$1 = function Editor(_ref, ref) {
5357
5355
  "aria-required": required,
5358
5356
  "aria-roledescription": "editor"
5359
5357
  };
5360
- var editor = menu.useEditor({
5358
+ var editor = useEditorStore.useEditor({
5361
5359
  extensions: customExtensions,
5362
5360
  content: initialValue,
5363
5361
  injectCSS: false,
@@ -5386,7 +5384,7 @@ var Editor$1 = function Editor(_ref, ref) {
5386
5384
  onFocus: onFocus,
5387
5385
  onBlur: handleBlur
5388
5386
  });
5389
- menu.useEditorState({
5387
+ useEditorStore.useEditorState({
5390
5388
  editor: editor,
5391
5389
  selector: function selector() {
5392
5390
  return {
@@ -5419,7 +5417,7 @@ var Editor$1 = function Editor(_ref, ref) {
5419
5417
  if (!editor || !deletedArticlesHook.deletedArticleIds.size) return;
5420
5418
  editor.commands.updateDeletedArticles(deletedArticlesHook.deletedArticleIds);
5421
5419
  }, [editor, deletedArticlesHook.deletedArticleIds]);
5422
- menu.EditorView.prototype.updateState = function updateState(state) {
5420
+ useEditorStore.EditorView.prototype.updateState = function updateState(state) {
5423
5421
  if (!this.docView) return;
5424
5422
  this.updateStateInner(state, this.state.plugins !== state.plugins);
5425
5423
  };
@@ -5460,7 +5458,7 @@ var Editor$1 = function Editor(_ref, ref) {
5460
5458
  variables: variables,
5461
5459
  standalone: true
5462
5460
  })
5463
- }), /*#__PURE__*/jsxRuntime.jsx(menu.EditorContent, _objectSpread({
5461
+ }), /*#__PURE__*/jsxRuntime.jsx(useEditorStore.EditorContent, _objectSpread({
5464
5462
  className: contentWrapperClassName
5465
5463
  }, _objectSpread({
5466
5464
  editor: editor