decap-cms-widget-markdown 3.2.0 → 3.3.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.
Files changed (104) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/decap-cms-widget-markdown.js +4 -4
  3. package/dist/decap-cms-widget-markdown.js.map +1 -1
  4. package/dist/esm/MarkdownControl/RawEditor.js +36 -43
  5. package/dist/esm/MarkdownControl/Toolbar.js +52 -59
  6. package/dist/esm/MarkdownControl/ToolbarButton.js +16 -23
  7. package/dist/esm/MarkdownControl/VisualEditor.js +85 -92
  8. package/dist/esm/MarkdownControl/components/Shortcode.js +24 -31
  9. package/dist/esm/MarkdownControl/components/VoidBlock.js +18 -23
  10. package/dist/esm/MarkdownControl/index.js +30 -35
  11. package/dist/esm/MarkdownControl/plugins/BreakToDefaultBlock.js +3 -10
  12. package/dist/esm/MarkdownControl/plugins/CloseBlock.js +3 -10
  13. package/dist/esm/MarkdownControl/plugins/CommandsAndQueries.js +8 -15
  14. package/dist/esm/MarkdownControl/plugins/ForceInsert.js +1 -7
  15. package/dist/esm/MarkdownControl/plugins/Hotkey.js +4 -11
  16. package/dist/esm/MarkdownControl/plugins/LineBreak.js +3 -10
  17. package/dist/esm/MarkdownControl/plugins/Link.js +1 -7
  18. package/dist/esm/MarkdownControl/plugins/blocks/defaultEmptyBlock.js +1 -7
  19. package/dist/esm/MarkdownControl/plugins/blocks/events/keyDown.js +18 -25
  20. package/dist/esm/MarkdownControl/plugins/blocks/events/keyDownBackspace.js +11 -18
  21. package/dist/esm/MarkdownControl/plugins/blocks/events/keyDownEnter.js +9 -16
  22. package/dist/esm/MarkdownControl/plugins/blocks/events/toggleBlock.js +11 -18
  23. package/dist/esm/MarkdownControl/plugins/blocks/locations/areCurrentAndPreviousBlocksOfType.js +5 -12
  24. package/dist/esm/MarkdownControl/plugins/blocks/locations/getListTypeAtCursor.js +4 -11
  25. package/dist/esm/MarkdownControl/plugins/blocks/locations/isCursorAtEndOfParagraph.js +5 -12
  26. package/dist/esm/MarkdownControl/plugins/blocks/locations/isCursorAtStartOfBlockType.js +5 -12
  27. package/dist/esm/MarkdownControl/plugins/blocks/locations/isCursorAtStartOfNonEmptyHeading.js +5 -11
  28. package/dist/esm/MarkdownControl/plugins/blocks/locations/isCursorCollapsedAfterSoftBreak.js +4 -10
  29. package/dist/esm/MarkdownControl/plugins/blocks/locations/isCursorInBlockType.js +4 -10
  30. package/dist/esm/MarkdownControl/plugins/blocks/locations/isCursorInNonDefaultBlock.js +5 -11
  31. package/dist/esm/MarkdownControl/plugins/blocks/transforms/splitIntoParagraph.js +6 -12
  32. package/dist/esm/MarkdownControl/plugins/blocks/transforms/unwrapIfCursorAtStart.js +12 -19
  33. package/dist/esm/MarkdownControl/plugins/blocks/transforms/wrapListItemsInBlock.js +7 -13
  34. package/dist/esm/MarkdownControl/plugins/blocks/withBlocks.js +5 -12
  35. package/dist/esm/MarkdownControl/plugins/html/withHtml.js +29 -14
  36. package/dist/esm/MarkdownControl/plugins/inlines/events/keyDown.js +11 -18
  37. package/dist/esm/MarkdownControl/plugins/inlines/events/keyDownShiftEnter.js +5 -11
  38. package/dist/esm/MarkdownControl/plugins/inlines/events/toggleLink.js +7 -14
  39. package/dist/esm/MarkdownControl/plugins/inlines/events/toggleMark.js +6 -13
  40. package/dist/esm/MarkdownControl/plugins/inlines/locations/isMarkActive.js +3 -9
  41. package/dist/esm/MarkdownControl/plugins/inlines/selectors/getActiveLink.js +4 -11
  42. package/dist/esm/MarkdownControl/plugins/inlines/transforms/unwrapLink.js +4 -11
  43. package/dist/esm/MarkdownControl/plugins/inlines/transforms/wrapLink.js +11 -18
  44. package/dist/esm/MarkdownControl/plugins/inlines/withInlines.js +3 -10
  45. package/dist/esm/MarkdownControl/plugins/lists/events/keyDown.js +14 -21
  46. package/dist/esm/MarkdownControl/plugins/lists/events/keyDownBackspace.js +11 -18
  47. package/dist/esm/MarkdownControl/plugins/lists/events/keyDownEnter.js +18 -25
  48. package/dist/esm/MarkdownControl/plugins/lists/events/keyDownShiftTab.js +9 -16
  49. package/dist/esm/MarkdownControl/plugins/lists/events/keyDownTab.js +13 -20
  50. package/dist/esm/MarkdownControl/plugins/lists/events/toggleListType.js +11 -18
  51. package/dist/esm/MarkdownControl/plugins/lists/locations/isCursorAtListItemStart.js +3 -9
  52. package/dist/esm/MarkdownControl/plugins/lists/locations/isCursorAtNoninitialParagraphStart.js +3 -9
  53. package/dist/esm/MarkdownControl/plugins/lists/locations/isCursorInItemContainingNestedList.js +3 -10
  54. package/dist/esm/MarkdownControl/plugins/lists/locations/isCursorInListItem.js +4 -10
  55. package/dist/esm/MarkdownControl/plugins/lists/locations/isSelectionWithinNoninitialListItem.js +4 -10
  56. package/dist/esm/MarkdownControl/plugins/lists/selectors/getListContainedInListItem.js +5 -12
  57. package/dist/esm/MarkdownControl/plugins/lists/selectors/getLowestAncestorList.js +4 -11
  58. package/dist/esm/MarkdownControl/plugins/lists/selectors/getLowestAncestorQuote.js +4 -11
  59. package/dist/esm/MarkdownControl/plugins/lists/transforms/changeListType.js +8 -15
  60. package/dist/esm/MarkdownControl/plugins/lists/transforms/convertParagraphToListItem.js +8 -15
  61. package/dist/esm/MarkdownControl/plugins/lists/transforms/liftFirstMatchedParent.js +3 -9
  62. package/dist/esm/MarkdownControl/plugins/lists/transforms/liftListItem.js +13 -20
  63. package/dist/esm/MarkdownControl/plugins/lists/transforms/mergeWithPreviousListItem.js +6 -13
  64. package/dist/esm/MarkdownControl/plugins/lists/transforms/moveListToListItem.js +3 -9
  65. package/dist/esm/MarkdownControl/plugins/lists/transforms/splitListItem.js +12 -19
  66. package/dist/esm/MarkdownControl/plugins/lists/transforms/splitToNestedList.js +11 -18
  67. package/dist/esm/MarkdownControl/plugins/lists/transforms/unwrapFirstMatchedParent.js +4 -11
  68. package/dist/esm/MarkdownControl/plugins/lists/transforms/unwrapSelectionFromList.js +7 -14
  69. package/dist/esm/MarkdownControl/plugins/lists/transforms/wrapFirstMatchedParent.js +4 -11
  70. package/dist/esm/MarkdownControl/plugins/lists/transforms/wrapSelectionInList.js +8 -15
  71. package/dist/esm/MarkdownControl/plugins/lists/withLists.js +19 -26
  72. package/dist/esm/MarkdownControl/plugins/matchers/lowestMatchedAncestor.js +3 -10
  73. package/dist/esm/MarkdownControl/plugins/matchers/matchLink.js +3 -9
  74. package/dist/esm/MarkdownControl/plugins/matchers/matchedAncestors.js +3 -9
  75. package/dist/esm/MarkdownControl/plugins/shortcodes/insertShortcode.js +6 -13
  76. package/dist/esm/MarkdownControl/plugins/shortcodes/locations/isCursorInEmptyParagraph.js +5 -11
  77. package/dist/esm/MarkdownControl/plugins/shortcodes/withShortcodes.js +5 -12
  78. package/dist/esm/MarkdownControl/plugins/util.js +5 -12
  79. package/dist/esm/MarkdownControl/renderers.js +84 -91
  80. package/dist/esm/MarkdownPreview.js +14 -21
  81. package/dist/esm/index.js +10 -17
  82. package/dist/esm/regexHelper.js +6 -15
  83. package/dist/esm/schema.js +1 -7
  84. package/dist/esm/serializers/index.js +46 -57
  85. package/dist/esm/serializers/rehypePaperEmoji.js +1 -7
  86. package/dist/esm/serializers/remarkAllowHtmlEntities.js +1 -7
  87. package/dist/esm/serializers/remarkAssertParents.js +17 -23
  88. package/dist/esm/serializers/remarkEscapeMarkdownEntities.js +14 -20
  89. package/dist/esm/serializers/remarkImagesToText.js +1 -7
  90. package/dist/esm/serializers/remarkPaddedLinks.js +20 -26
  91. package/dist/esm/serializers/remarkRehypeShortcodes.js +12 -18
  92. package/dist/esm/serializers/remarkShortcodes.js +3 -11
  93. package/dist/esm/serializers/remarkSlate.js +18 -26
  94. package/dist/esm/serializers/remarkSquashReferences.js +13 -19
  95. package/dist/esm/serializers/remarkStripTrailingBreaks.js +3 -9
  96. package/dist/esm/serializers/remarkWrapHtml.js +3 -9
  97. package/dist/esm/serializers/slateRemark.js +35 -41
  98. package/dist/esm/styles.js +5 -12
  99. package/dist/esm/types.js +2 -8
  100. package/package.json +2 -2
  101. package/src/MarkdownControl/RawEditor.js +2 -1
  102. package/src/MarkdownControl/VisualEditor.js +2 -1
  103. package/src/MarkdownControl/index.js +4 -0
  104. package/src/MarkdownControl/plugins/html/withHtml.js +19 -0
@@ -1,19 +1,12 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
- var _react = _interopRequireDefault(require("react"));
9
- var _propTypes = _interopRequireDefault(require("prop-types"));
10
- var _decapCmsUiDefault = require("decap-cms-ui-default");
11
- var _react2 = require("@emotion/react");
12
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
- const StyledToolbarButton = /*#__PURE__*/(0, _base.default)("button", {
1
+ import _styled from "@emotion/styled/base";
2
+ import React from 'react';
3
+ import PropTypes from 'prop-types';
4
+ import { Icon, buttons } from 'decap-cms-ui-default';
5
+ import { jsx as ___EmotionJSX } from "@emotion/react";
6
+ const StyledToolbarButton = /*#__PURE__*/_styled("button", {
14
7
  target: "e1ps9s9m0",
15
8
  label: "StyledToolbarButton"
16
- })(_decapCmsUiDefault.buttons.button, ";display:inline-block;padding:6px;border:none;background-color:transparent;font-size:16px;color:", props => props.isActive ? '#1e2532' : 'inherit', ";cursor:pointer;&:disabled{cursor:auto;opacity:0.5;}", _decapCmsUiDefault.Icon, "{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9NYXJrZG93bkNvbnRyb2wvVG9vbGJhckJ1dHRvbi5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLeUMiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL01hcmtkb3duQ29udHJvbC9Ub29sYmFyQnV0dG9uLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBJY29uLCBidXR0b25zIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5jb25zdCBTdHlsZWRUb29sYmFyQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgJHtidXR0b25zLmJ1dHRvbn07XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcGFkZGluZzogNnB4O1xuICBib3JkZXI6IG5vbmU7XG4gIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBmb250LXNpemU6IDE2cHg7XG4gIGNvbG9yOiAke3Byb3BzID0+IChwcm9wcy5pc0FjdGl2ZSA/ICcjMWUyNTMyJyA6ICdpbmhlcml0Jyl9O1xuICBjdXJzb3I6IHBvaW50ZXI7XG5cbiAgJjpkaXNhYmxlZCB7XG4gICAgY3Vyc29yOiBhdXRvO1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuXG4gICR7SWNvbn0ge1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICB9XG5gO1xuXG5mdW5jdGlvbiBUb29sYmFyQnV0dG9uKHsgdHlwZSwgbGFiZWwsIGljb24sIG9uQ2xpY2ssIGlzQWN0aXZlLCBkaXNhYmxlZCB9KSB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFRvb2xiYXJCdXR0b25cbiAgICAgIGlzQWN0aXZlPXtpc0FjdGl2ZX1cbiAgICAgIG9uQ2xpY2s9e2UgPT4gb25DbGljayAmJiBvbkNsaWNrKGUsIHR5cGUpfVxuICAgICAgdGl0bGU9e2xhYmVsfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgID5cbiAgICAgIHtpY29uID8gPEljb24gdHlwZT17aWNvbn0gLz4gOiBsYWJlbH1cbiAgICA8L1N0eWxlZFRvb2xiYXJCdXR0b24+XG4gICk7XG59XG5cblRvb2xiYXJCdXR0b24ucHJvcFR5cGVzID0ge1xuICB0eXBlOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBsYWJlbDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICBpY29uOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbiAgaXNBY3RpdmU6IFByb3BUeXBlcy5ib29sLFxuICBkaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBUb29sYmFyQnV0dG9uO1xuIl19 */"));
9
+ })(buttons.button, ";display:inline-block;padding:6px;border:none;background-color:transparent;font-size:16px;color:", props => props.isActive ? '#1e2532' : 'inherit', ";cursor:pointer;&:disabled{cursor:auto;opacity:0.5;}", Icon, "{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9NYXJrZG93bkNvbnRyb2wvVG9vbGJhckJ1dHRvbi5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLeUMiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL01hcmtkb3duQ29udHJvbC9Ub29sYmFyQnV0dG9uLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBJY29uLCBidXR0b25zIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5jb25zdCBTdHlsZWRUb29sYmFyQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgJHtidXR0b25zLmJ1dHRvbn07XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcGFkZGluZzogNnB4O1xuICBib3JkZXI6IG5vbmU7XG4gIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBmb250LXNpemU6IDE2cHg7XG4gIGNvbG9yOiAke3Byb3BzID0+IChwcm9wcy5pc0FjdGl2ZSA/ICcjMWUyNTMyJyA6ICdpbmhlcml0Jyl9O1xuICBjdXJzb3I6IHBvaW50ZXI7XG5cbiAgJjpkaXNhYmxlZCB7XG4gICAgY3Vyc29yOiBhdXRvO1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuXG4gICR7SWNvbn0ge1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICB9XG5gO1xuXG5mdW5jdGlvbiBUb29sYmFyQnV0dG9uKHsgdHlwZSwgbGFiZWwsIGljb24sIG9uQ2xpY2ssIGlzQWN0aXZlLCBkaXNhYmxlZCB9KSB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFRvb2xiYXJCdXR0b25cbiAgICAgIGlzQWN0aXZlPXtpc0FjdGl2ZX1cbiAgICAgIG9uQ2xpY2s9e2UgPT4gb25DbGljayAmJiBvbkNsaWNrKGUsIHR5cGUpfVxuICAgICAgdGl0bGU9e2xhYmVsfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgID5cbiAgICAgIHtpY29uID8gPEljb24gdHlwZT17aWNvbn0gLz4gOiBsYWJlbH1cbiAgICA8L1N0eWxlZFRvb2xiYXJCdXR0b24+XG4gICk7XG59XG5cblRvb2xiYXJCdXR0b24ucHJvcFR5cGVzID0ge1xuICB0eXBlOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBsYWJlbDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICBpY29uOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbiAgaXNBY3RpdmU6IFByb3BUeXBlcy5ib29sLFxuICBkaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBUb29sYmFyQnV0dG9uO1xuIl19 */"));
17
10
  function ToolbarButton({
18
11
  type,
19
12
  label,
@@ -22,21 +15,21 @@ function ToolbarButton({
22
15
  isActive,
23
16
  disabled
24
17
  }) {
25
- return (0, _react2.jsx)(StyledToolbarButton, {
18
+ return ___EmotionJSX(StyledToolbarButton, {
26
19
  isActive: isActive,
27
20
  onClick: e => onClick && onClick(e, type),
28
21
  title: label,
29
22
  disabled: disabled
30
- }, icon ? (0, _react2.jsx)(_decapCmsUiDefault.Icon, {
23
+ }, icon ? ___EmotionJSX(Icon, {
31
24
  type: icon
32
25
  }) : label);
33
26
  }
34
27
  ToolbarButton.propTypes = {
35
- type: _propTypes.default.string,
36
- label: _propTypes.default.string.isRequired,
37
- icon: _propTypes.default.string,
38
- onClick: _propTypes.default.func,
39
- isActive: _propTypes.default.bool,
40
- disabled: _propTypes.default.bool
28
+ type: PropTypes.string,
29
+ label: PropTypes.string.isRequired,
30
+ icon: PropTypes.string,
31
+ onClick: PropTypes.func,
32
+ isActive: PropTypes.bool,
33
+ disabled: PropTypes.bool
41
34
  };
42
- var _default = exports.default = ToolbarButton;
35
+ export default ToolbarButton;
@@ -1,61 +1,53 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- exports.mergeMediaConfig = mergeMediaConfig;
8
- var _base = _interopRequireDefault(require("@emotion/styled/base"));
9
- var _isEqual2 = _interopRequireDefault(require("lodash/isEqual"));
10
- var _react = _interopRequireWildcard(require("react"));
11
- var _propTypes = _interopRequireDefault(require("prop-types"));
12
- var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
13
- var _react2 = require("@emotion/react");
14
- var _decapCmsUiDefault = require("decap-cms-ui-default");
15
- var _slate = require("slate");
16
- var _slateReact = require("slate-react");
17
- var _slateHistory = require("slate-history");
18
- var _immutable = require("immutable");
19
- var _styles = require("../styles");
20
- var _Toolbar = _interopRequireDefault(require("./Toolbar"));
21
- var _renderers = require("./renderers");
22
- var _withLists = _interopRequireDefault(require("./plugins/lists/withLists"));
23
- var _withBlocks = _interopRequireDefault(require("./plugins/blocks/withBlocks"));
24
- var _withInlines = _interopRequireDefault(require("./plugins/inlines/withInlines"));
25
- var _toggleMark = _interopRequireDefault(require("./plugins/inlines/events/toggleMark"));
26
- var _toggleLink = _interopRequireDefault(require("./plugins/inlines/events/toggleLink"));
27
- var _getActiveLink = _interopRequireDefault(require("./plugins/inlines/selectors/getActiveLink"));
28
- var _isMarkActive = _interopRequireDefault(require("./plugins/inlines/locations/isMarkActive"));
29
- var _isCursorInBlockType = _interopRequireDefault(require("./plugins/blocks/locations/isCursorInBlockType"));
30
- var _serializers = require("../serializers");
31
- var _withShortcodes = _interopRequireDefault(require("./plugins/shortcodes/withShortcodes"));
32
- var _insertShortcode = _interopRequireDefault(require("./plugins/shortcodes/insertShortcode"));
33
- var _defaultEmptyBlock = _interopRequireDefault(require("./plugins/blocks/defaultEmptyBlock"));
34
- var _withHtml = _interopRequireDefault(require("./plugins/html/withHtml"));
35
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
36
- function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
37
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
1
+ import _styled from "@emotion/styled/base";
2
+ import _isEqual from "lodash/isEqual";
38
3
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
39
- function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } // @refresh reset
4
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
5
+ // @refresh reset
6
+ import React, { useCallback, useEffect, useMemo, useState } from 'react';
7
+ import PropTypes from 'prop-types';
8
+ import ImmutablePropTypes from 'react-immutable-proptypes';
9
+ import { ClassNames, css as coreCss } from '@emotion/react';
10
+ import { lengths, fonts, zIndex } from 'decap-cms-ui-default';
11
+ import { createEditor, Transforms, Editor as SlateEditor } from 'slate';
12
+ import { Editable, ReactEditor, Slate, withReact } from 'slate-react';
13
+ import { withHistory } from 'slate-history';
14
+ import { fromJS } from 'immutable';
15
+ import { editorStyleVars, EditorControlBar } from '../styles';
16
+ import Toolbar from './Toolbar';
17
+ import { Element, Leaf } from './renderers';
18
+ import withLists from './plugins/lists/withLists';
19
+ import withBlocks from './plugins/blocks/withBlocks';
20
+ import withInlines from './plugins/inlines/withInlines';
21
+ import toggleMark from './plugins/inlines/events/toggleMark';
22
+ import toggleLink from './plugins/inlines/events/toggleLink';
23
+ import getActiveLink from './plugins/inlines/selectors/getActiveLink';
24
+ import isMarkActive from './plugins/inlines/locations/isMarkActive';
25
+ import isCursorInBlockType from './plugins/blocks/locations/isCursorInBlockType';
26
+ import { markdownToSlate, slateToMarkdown } from '../serializers';
27
+ import withShortcodes from './plugins/shortcodes/withShortcodes';
28
+ import insertShortcode from './plugins/shortcodes/insertShortcode';
29
+ import defaultEmptyBlock from './plugins/blocks/defaultEmptyBlock';
30
+ import withHtml from './plugins/html/withHtml';
31
+ import { jsx as ___EmotionJSX } from "@emotion/react";
40
32
  function visualEditorStyles({
41
33
  minimal
42
34
  }) {
43
35
  return `
44
36
  position: relative;
45
37
  overflow: auto;
46
- font-family: ${_decapCmsUiDefault.fonts.primary};
47
- min-height: ${minimal ? 'auto' : _decapCmsUiDefault.lengths.richTextEditorMinHeight};
38
+ font-family: ${fonts.primary};
39
+ min-height: ${minimal ? 'auto' : lengths.richTextEditorMinHeight};
48
40
  border-top-left-radius: 0;
49
41
  border-top-right-radius: 0;
50
42
  border-top: 0;
51
- margin-top: -${_styles.editorStyleVars.stickyDistanceBottom};
43
+ margin-top: -${editorStyleVars.stickyDistanceBottom};
52
44
  padding: 0;
53
45
  display: flex;
54
46
  flex-direction: column;
55
- z-index: ${_decapCmsUiDefault.zIndex.zIndex100};
47
+ z-index: ${zIndex.zIndex100};
56
48
  `;
57
49
  }
58
- const InsertionPoint = /*#__PURE__*/(0, _base.default)("div", {
50
+ const InsertionPoint = /*#__PURE__*/_styled("div", {
59
51
  target: "ebiot7z0",
60
52
  label: "InsertionPoint"
61
53
  })(process.env.NODE_ENV === "production" ? {
@@ -64,10 +56,10 @@ const InsertionPoint = /*#__PURE__*/(0, _base.default)("div", {
64
56
  } : {
65
57
  name: "ma7xbc",
66
58
  styles: "flex:1 1 auto;cursor:text",
67
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/VisualEditor.js"],"names":[],"mappings":"AA+CiC","file":"../../../src/MarkdownControl/VisualEditor.js","sourcesContent":["// @refresh reset\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { ClassNames, css as coreCss } from '@emotion/react';\nimport { lengths, fonts, zIndex } from 'decap-cms-ui-default';\nimport styled from '@emotion/styled';\nimport { createEditor, Transforms, Editor as SlateEditor } from 'slate';\nimport { Editable, ReactEditor, Slate, withReact } from 'slate-react';\nimport { withHistory } from 'slate-history';\nimport { fromJS } from 'immutable';\nimport { isEqual } from 'lodash';\n\nimport { editorStyleVars, EditorControlBar } from '../styles';\nimport Toolbar from './Toolbar';\nimport { Element, Leaf } from './renderers';\nimport withLists from './plugins/lists/withLists';\nimport withBlocks from './plugins/blocks/withBlocks';\nimport withInlines from './plugins/inlines/withInlines';\nimport toggleMark from './plugins/inlines/events/toggleMark';\nimport toggleLink from './plugins/inlines/events/toggleLink';\nimport getActiveLink from './plugins/inlines/selectors/getActiveLink';\nimport isMarkActive from './plugins/inlines/locations/isMarkActive';\nimport isCursorInBlockType from './plugins/blocks/locations/isCursorInBlockType';\nimport { markdownToSlate, slateToMarkdown } from '../serializers';\nimport withShortcodes from './plugins/shortcodes/withShortcodes';\nimport insertShortcode from './plugins/shortcodes/insertShortcode';\nimport defaultEmptyBlock from './plugins/blocks/defaultEmptyBlock';\nimport withHtml from './plugins/html/withHtml';\n\nfunction visualEditorStyles({ minimal }) {\n  return `\n  position: relative;\n  overflow: auto;\n  font-family: ${fonts.primary};\n  min-height: ${minimal ? 'auto' : lengths.richTextEditorMinHeight};\n  border-top-left-radius: 0;\n  border-top-right-radius: 0;\n  border-top: 0;\n  margin-top: -${editorStyleVars.stickyDistanceBottom};\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  z-index: ${zIndex.zIndex100};\n`;\n}\n\nconst InsertionPoint = styled.div`\n  flex: 1 1 auto;\n  cursor: text;\n`;\n\nexport function mergeMediaConfig(editorComponents, field) {\n  // merge editor media library config to image components\n  if (editorComponents.has('image')) {\n    const imageComponent = editorComponents.get('image');\n    const fields = imageComponent?.fields;\n\n    if (fields) {\n      imageComponent.fields = fields.update(\n        fields.findIndex(f => f.get('widget') === 'image'),\n        f => {\n          // merge `media_library` config\n          if (field.has('media_library')) {\n            f = f.set(\n              'media_library',\n              field.get('media_library').mergeDeep(f.get('media_library')),\n            );\n          }\n          // merge 'media_folder'\n          if (field.has('media_folder') && !f.has('media_folder')) {\n            f = f.set('media_folder', field.get('media_folder'));\n          }\n          // merge 'public_folder'\n          if (field.has('public_folder') && !f.has('public_folder')) {\n            f = f.set('public_folder', field.get('public_folder'));\n          }\n          return f;\n        },\n      );\n    }\n  }\n}\n\nfunction Editor(props) {\n  const {\n    onAddAsset,\n    getAsset,\n    className,\n    field,\n    isShowModeToggle,\n    t,\n    isDisabled,\n    getEditorComponents,\n    getRemarkPlugins,\n    onChange,\n  } = props;\n\n  const editor = useMemo(\n    () =>\n      withHtml(\n        withReact(withHistory(withShortcodes(withBlocks(withLists(withInlines(createEditor())))))),\n      ),\n    [],\n  );\n\n  const emptyValue = [defaultEmptyBlock()];\n  let editorComponents = getEditorComponents();\n  const codeBlockComponent = fromJS(editorComponents.find(({ type }) => type === 'code-block'));\n\n  editorComponents =\n    codeBlockComponent || editorComponents.has('code-block')\n      ? editorComponents\n      : editorComponents.set('code-block', { label: 'Code Block', type: 'code-block' });\n\n  mergeMediaConfig(editorComponents, field);\n\n  const [editorValue, setEditorValue] = useState(\n    props.value\n      ? markdownToSlate(props.value, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        })\n      : emptyValue,\n  );\n\n  const renderElement = useCallback(\n    props => (\n      <Element {...props} classNameWrapper={className} codeBlockComponent={codeBlockComponent} />\n    ),\n    [],\n  );\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n\n  useEffect(() => {\n    if (props.pendingFocus) {\n      ReactEditor.focus(editor);\n    }\n  }, []);\n\n  function handleMarkClick(format) {\n    ReactEditor.focus(editor);\n    toggleMark(editor, format);\n  }\n\n  function handleBlockClick(format) {\n    ReactEditor.focus(editor);\n    if (format.endsWith('-list')) {\n      editor.toggleList(format);\n    } else {\n      editor.toggleBlock(format);\n    }\n  }\n\n  function handleLinkClick() {\n    toggleLink(editor, t('editor.editorWidgets.markdown.linkPrompt'));\n    ReactEditor.focus(editor);\n  }\n\n  function handleToggleMode() {\n    props.onMode('raw');\n  }\n\n  function handleInsertShortcode(pluginConfig) {\n    insertShortcode(editor, pluginConfig);\n  }\n\n  function handleKeyDown(event) {\n    for (const handler of editor.keyDownHandlers || []) {\n      if (handler(event, editor) === false) {\n        break;\n      }\n    }\n    ReactEditor.focus(editor);\n  }\n\n  function handleClickBelowDocument() {\n    ReactEditor.focus(editor);\n    Transforms.select(editor, { path: [0, 0], offset: 0 });\n    Transforms.select(editor, SlateEditor.end(editor, []));\n  }\n  const [toolbarKey, setToolbarKey] = useState(0);\n\n  function handleChange(newValue) {\n    if (!isEqual(newValue, editorValue)) {\n      setEditorValue(() => newValue);\n      onChange(\n        slateToMarkdown(newValue, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        }),\n      );\n    }\n    setToolbarKey(prev => prev + 1);\n  }\n\n  function hasMark(format) {\n    return isMarkActive(editor, format);\n  }\n\n  function hasInline(format) {\n    if (format == 'link') {\n      return !!getActiveLink(editor);\n    }\n    return false;\n  }\n\n  function hasBlock(format) {\n    return isCursorInBlockType(editor, format);\n  }\n  function hasQuote() {\n    return isCursorInBlockType(editor, 'quote');\n  }\n  function hasListItems(type) {\n    return isCursorInBlockType(editor, type);\n  }\n\n  return (\n    <div\n      css={coreCss`\n        position: relative;\n      `}\n    >\n      <Slate editor={editor} value={editorValue} onChange={handleChange}>\n        <EditorControlBar>\n          {\n            <Toolbar\n              key={toolbarKey}\n              onMarkClick={handleMarkClick}\n              onBlockClick={handleBlockClick}\n              onLinkClick={handleLinkClick}\n              onToggleMode={handleToggleMode}\n              plugins={editorComponents}\n              onSubmit={handleInsertShortcode}\n              onAddAsset={onAddAsset}\n              getAsset={getAsset}\n              buttons={field.get('buttons')}\n              editorComponents={field.get('editor_components')}\n              hasMark={hasMark}\n              hasInline={hasInline}\n              hasBlock={hasBlock}\n              hasQuote={hasQuote}\n              hasListItems={hasListItems}\n              isShowModeToggle={isShowModeToggle}\n              t={t}\n              disabled={isDisabled}\n            />\n          }\n        </EditorControlBar>\n        {\n          <ClassNames>\n            {({ css, cx }) => (\n              <div\n                className={cx(\n                  className,\n                  css`\n                    ${visualEditorStyles({ minimal: field.get('minimal') })}\n                  `,\n                )}\n              >\n                {editorValue.length !== 0 && (\n                  <Editable\n                    className={css`\n                      padding: 16px 20px 0;\n                    `}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    onKeyDown={handleKeyDown}\n                    autoFocus={false}\n                  />\n                )}\n                <InsertionPoint onClick={handleClickBelowDocument} />\n              </div>\n            )}\n          </ClassNames>\n        }\n      </Slate>\n    </div>\n  );\n}\n\nEditor.propTypes = {\n  onAddAsset: PropTypes.func.isRequired,\n  getAsset: PropTypes.func.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onMode: PropTypes.func.isRequired,\n  className: PropTypes.string.isRequired,\n  value: PropTypes.string,\n  field: ImmutablePropTypes.map.isRequired,\n  getEditorComponents: PropTypes.func.isRequired,\n  getRemarkPlugins: PropTypes.func.isRequired,\n  isShowModeToggle: PropTypes.bool.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default Editor;\n"]} */",
59
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/VisualEditor.js"],"names":[],"mappings":"AA+CiC","file":"../../../src/MarkdownControl/VisualEditor.js","sourcesContent":["// @refresh reset\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { ClassNames, css as coreCss } from '@emotion/react';\nimport { lengths, fonts, zIndex } from 'decap-cms-ui-default';\nimport styled from '@emotion/styled';\nimport { createEditor, Transforms, Editor as SlateEditor } from 'slate';\nimport { Editable, ReactEditor, Slate, withReact } from 'slate-react';\nimport { withHistory } from 'slate-history';\nimport { fromJS } from 'immutable';\nimport { isEqual } from 'lodash';\n\nimport { editorStyleVars, EditorControlBar } from '../styles';\nimport Toolbar from './Toolbar';\nimport { Element, Leaf } from './renderers';\nimport withLists from './plugins/lists/withLists';\nimport withBlocks from './plugins/blocks/withBlocks';\nimport withInlines from './plugins/inlines/withInlines';\nimport toggleMark from './plugins/inlines/events/toggleMark';\nimport toggleLink from './plugins/inlines/events/toggleLink';\nimport getActiveLink from './plugins/inlines/selectors/getActiveLink';\nimport isMarkActive from './plugins/inlines/locations/isMarkActive';\nimport isCursorInBlockType from './plugins/blocks/locations/isCursorInBlockType';\nimport { markdownToSlate, slateToMarkdown } from '../serializers';\nimport withShortcodes from './plugins/shortcodes/withShortcodes';\nimport insertShortcode from './plugins/shortcodes/insertShortcode';\nimport defaultEmptyBlock from './plugins/blocks/defaultEmptyBlock';\nimport withHtml from './plugins/html/withHtml';\n\nfunction visualEditorStyles({ minimal }) {\n  return `\n  position: relative;\n  overflow: auto;\n  font-family: ${fonts.primary};\n  min-height: ${minimal ? 'auto' : lengths.richTextEditorMinHeight};\n  border-top-left-radius: 0;\n  border-top-right-radius: 0;\n  border-top: 0;\n  margin-top: -${editorStyleVars.stickyDistanceBottom};\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  z-index: ${zIndex.zIndex100};\n`;\n}\n\nconst InsertionPoint = styled.div`\n  flex: 1 1 auto;\n  cursor: text;\n`;\n\nexport function mergeMediaConfig(editorComponents, field) {\n  // merge editor media library config to image components\n  if (editorComponents.has('image')) {\n    const imageComponent = editorComponents.get('image');\n    const fields = imageComponent?.fields;\n\n    if (fields) {\n      imageComponent.fields = fields.update(\n        fields.findIndex(f => f.get('widget') === 'image'),\n        f => {\n          // merge `media_library` config\n          if (field.has('media_library')) {\n            f = f.set(\n              'media_library',\n              field.get('media_library').mergeDeep(f.get('media_library')),\n            );\n          }\n          // merge 'media_folder'\n          if (field.has('media_folder') && !f.has('media_folder')) {\n            f = f.set('media_folder', field.get('media_folder'));\n          }\n          // merge 'public_folder'\n          if (field.has('public_folder') && !f.has('public_folder')) {\n            f = f.set('public_folder', field.get('public_folder'));\n          }\n          return f;\n        },\n      );\n    }\n  }\n}\n\nfunction Editor(props) {\n  const {\n    onAddAsset,\n    getAsset,\n    className,\n    field,\n    isShowModeToggle,\n    t,\n    isDisabled,\n    getEditorComponents,\n    getRemarkPlugins,\n    onChange,\n  } = props;\n\n  const editor = useMemo(\n    () =>\n      withHtml(\n        withReact(withHistory(withShortcodes(withBlocks(withLists(withInlines(createEditor())))))),\n      ),\n    [],\n  );\n\n  const emptyValue = [defaultEmptyBlock()];\n  let editorComponents = getEditorComponents();\n  const codeBlockComponent = fromJS(editorComponents.find(({ type }) => type === 'code-block'));\n\n  editorComponents =\n    codeBlockComponent || editorComponents.has('code-block')\n      ? editorComponents\n      : editorComponents.set('code-block', { label: 'Code Block', type: 'code-block' });\n\n  mergeMediaConfig(editorComponents, field);\n\n  const [editorValue, setEditorValue] = useState(\n    props.value\n      ? markdownToSlate(props.value, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        })\n      : emptyValue,\n  );\n\n  const renderElement = useCallback(\n    props => (\n      <Element {...props} classNameWrapper={className} codeBlockComponent={codeBlockComponent} />\n    ),\n    [],\n  );\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n\n  useEffect(() => {\n    if (props.pendingFocus) {\n      ReactEditor.focus(editor);\n      props.pendingFocus();\n    }\n  }, [props.pendingFocus]);\n\n  function handleMarkClick(format) {\n    ReactEditor.focus(editor);\n    toggleMark(editor, format);\n  }\n\n  function handleBlockClick(format) {\n    ReactEditor.focus(editor);\n    if (format.endsWith('-list')) {\n      editor.toggleList(format);\n    } else {\n      editor.toggleBlock(format);\n    }\n  }\n\n  function handleLinkClick() {\n    toggleLink(editor, t('editor.editorWidgets.markdown.linkPrompt'));\n    ReactEditor.focus(editor);\n  }\n\n  function handleToggleMode() {\n    props.onMode('raw');\n  }\n\n  function handleInsertShortcode(pluginConfig) {\n    insertShortcode(editor, pluginConfig);\n  }\n\n  function handleKeyDown(event) {\n    for (const handler of editor.keyDownHandlers || []) {\n      if (handler(event, editor) === false) {\n        break;\n      }\n    }\n    ReactEditor.focus(editor);\n  }\n\n  function handleClickBelowDocument() {\n    ReactEditor.focus(editor);\n    Transforms.select(editor, { path: [0, 0], offset: 0 });\n    Transforms.select(editor, SlateEditor.end(editor, []));\n  }\n  const [toolbarKey, setToolbarKey] = useState(0);\n\n  function handleChange(newValue) {\n    if (!isEqual(newValue, editorValue)) {\n      setEditorValue(() => newValue);\n      onChange(\n        slateToMarkdown(newValue, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        }),\n      );\n    }\n    setToolbarKey(prev => prev + 1);\n  }\n\n  function hasMark(format) {\n    return isMarkActive(editor, format);\n  }\n\n  function hasInline(format) {\n    if (format == 'link') {\n      return !!getActiveLink(editor);\n    }\n    return false;\n  }\n\n  function hasBlock(format) {\n    return isCursorInBlockType(editor, format);\n  }\n  function hasQuote() {\n    return isCursorInBlockType(editor, 'quote');\n  }\n  function hasListItems(type) {\n    return isCursorInBlockType(editor, type);\n  }\n\n  return (\n    <div\n      css={coreCss`\n        position: relative;\n      `}\n    >\n      <Slate editor={editor} value={editorValue} onChange={handleChange}>\n        <EditorControlBar>\n          {\n            <Toolbar\n              key={toolbarKey}\n              onMarkClick={handleMarkClick}\n              onBlockClick={handleBlockClick}\n              onLinkClick={handleLinkClick}\n              onToggleMode={handleToggleMode}\n              plugins={editorComponents}\n              onSubmit={handleInsertShortcode}\n              onAddAsset={onAddAsset}\n              getAsset={getAsset}\n              buttons={field.get('buttons')}\n              editorComponents={field.get('editor_components')}\n              hasMark={hasMark}\n              hasInline={hasInline}\n              hasBlock={hasBlock}\n              hasQuote={hasQuote}\n              hasListItems={hasListItems}\n              isShowModeToggle={isShowModeToggle}\n              t={t}\n              disabled={isDisabled}\n            />\n          }\n        </EditorControlBar>\n        {\n          <ClassNames>\n            {({ css, cx }) => (\n              <div\n                className={cx(\n                  className,\n                  css`\n                    ${visualEditorStyles({ minimal: field.get('minimal') })}\n                  `,\n                )}\n              >\n                {editorValue.length !== 0 && (\n                  <Editable\n                    className={css`\n                      padding: 16px 20px 0;\n                    `}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    onKeyDown={handleKeyDown}\n                    autoFocus={false}\n                  />\n                )}\n                <InsertionPoint onClick={handleClickBelowDocument} />\n              </div>\n            )}\n          </ClassNames>\n        }\n      </Slate>\n    </div>\n  );\n}\n\nEditor.propTypes = {\n  onAddAsset: PropTypes.func.isRequired,\n  getAsset: PropTypes.func.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onMode: PropTypes.func.isRequired,\n  className: PropTypes.string.isRequired,\n  value: PropTypes.string,\n  field: ImmutablePropTypes.map.isRequired,\n  getEditorComponents: PropTypes.func.isRequired,\n  getRemarkPlugins: PropTypes.func.isRequired,\n  isShowModeToggle: PropTypes.bool.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default Editor;\n"]} */",
68
60
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
69
61
  });
70
- function mergeMediaConfig(editorComponents, field) {
62
+ export function mergeMediaConfig(editorComponents, field) {
71
63
  // merge editor media library config to image components
72
64
  if (editorComponents.has('image')) {
73
65
  const imageComponent = editorComponents.get('image');
@@ -97,7 +89,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
97
89
  } : {
98
90
  name: "j8ayvn-Editor",
99
91
  styles: "position:relative;label:Editor;",
100
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/VisualEditor.js"],"names":[],"mappings":"AA2NkB","file":"../../../src/MarkdownControl/VisualEditor.js","sourcesContent":["// @refresh reset\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { ClassNames, css as coreCss } from '@emotion/react';\nimport { lengths, fonts, zIndex } from 'decap-cms-ui-default';\nimport styled from '@emotion/styled';\nimport { createEditor, Transforms, Editor as SlateEditor } from 'slate';\nimport { Editable, ReactEditor, Slate, withReact } from 'slate-react';\nimport { withHistory } from 'slate-history';\nimport { fromJS } from 'immutable';\nimport { isEqual } from 'lodash';\n\nimport { editorStyleVars, EditorControlBar } from '../styles';\nimport Toolbar from './Toolbar';\nimport { Element, Leaf } from './renderers';\nimport withLists from './plugins/lists/withLists';\nimport withBlocks from './plugins/blocks/withBlocks';\nimport withInlines from './plugins/inlines/withInlines';\nimport toggleMark from './plugins/inlines/events/toggleMark';\nimport toggleLink from './plugins/inlines/events/toggleLink';\nimport getActiveLink from './plugins/inlines/selectors/getActiveLink';\nimport isMarkActive from './plugins/inlines/locations/isMarkActive';\nimport isCursorInBlockType from './plugins/blocks/locations/isCursorInBlockType';\nimport { markdownToSlate, slateToMarkdown } from '../serializers';\nimport withShortcodes from './plugins/shortcodes/withShortcodes';\nimport insertShortcode from './plugins/shortcodes/insertShortcode';\nimport defaultEmptyBlock from './plugins/blocks/defaultEmptyBlock';\nimport withHtml from './plugins/html/withHtml';\n\nfunction visualEditorStyles({ minimal }) {\n  return `\n  position: relative;\n  overflow: auto;\n  font-family: ${fonts.primary};\n  min-height: ${minimal ? 'auto' : lengths.richTextEditorMinHeight};\n  border-top-left-radius: 0;\n  border-top-right-radius: 0;\n  border-top: 0;\n  margin-top: -${editorStyleVars.stickyDistanceBottom};\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  z-index: ${zIndex.zIndex100};\n`;\n}\n\nconst InsertionPoint = styled.div`\n  flex: 1 1 auto;\n  cursor: text;\n`;\n\nexport function mergeMediaConfig(editorComponents, field) {\n  // merge editor media library config to image components\n  if (editorComponents.has('image')) {\n    const imageComponent = editorComponents.get('image');\n    const fields = imageComponent?.fields;\n\n    if (fields) {\n      imageComponent.fields = fields.update(\n        fields.findIndex(f => f.get('widget') === 'image'),\n        f => {\n          // merge `media_library` config\n          if (field.has('media_library')) {\n            f = f.set(\n              'media_library',\n              field.get('media_library').mergeDeep(f.get('media_library')),\n            );\n          }\n          // merge 'media_folder'\n          if (field.has('media_folder') && !f.has('media_folder')) {\n            f = f.set('media_folder', field.get('media_folder'));\n          }\n          // merge 'public_folder'\n          if (field.has('public_folder') && !f.has('public_folder')) {\n            f = f.set('public_folder', field.get('public_folder'));\n          }\n          return f;\n        },\n      );\n    }\n  }\n}\n\nfunction Editor(props) {\n  const {\n    onAddAsset,\n    getAsset,\n    className,\n    field,\n    isShowModeToggle,\n    t,\n    isDisabled,\n    getEditorComponents,\n    getRemarkPlugins,\n    onChange,\n  } = props;\n\n  const editor = useMemo(\n    () =>\n      withHtml(\n        withReact(withHistory(withShortcodes(withBlocks(withLists(withInlines(createEditor())))))),\n      ),\n    [],\n  );\n\n  const emptyValue = [defaultEmptyBlock()];\n  let editorComponents = getEditorComponents();\n  const codeBlockComponent = fromJS(editorComponents.find(({ type }) => type === 'code-block'));\n\n  editorComponents =\n    codeBlockComponent || editorComponents.has('code-block')\n      ? editorComponents\n      : editorComponents.set('code-block', { label: 'Code Block', type: 'code-block' });\n\n  mergeMediaConfig(editorComponents, field);\n\n  const [editorValue, setEditorValue] = useState(\n    props.value\n      ? markdownToSlate(props.value, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        })\n      : emptyValue,\n  );\n\n  const renderElement = useCallback(\n    props => (\n      <Element {...props} classNameWrapper={className} codeBlockComponent={codeBlockComponent} />\n    ),\n    [],\n  );\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n\n  useEffect(() => {\n    if (props.pendingFocus) {\n      ReactEditor.focus(editor);\n    }\n  }, []);\n\n  function handleMarkClick(format) {\n    ReactEditor.focus(editor);\n    toggleMark(editor, format);\n  }\n\n  function handleBlockClick(format) {\n    ReactEditor.focus(editor);\n    if (format.endsWith('-list')) {\n      editor.toggleList(format);\n    } else {\n      editor.toggleBlock(format);\n    }\n  }\n\n  function handleLinkClick() {\n    toggleLink(editor, t('editor.editorWidgets.markdown.linkPrompt'));\n    ReactEditor.focus(editor);\n  }\n\n  function handleToggleMode() {\n    props.onMode('raw');\n  }\n\n  function handleInsertShortcode(pluginConfig) {\n    insertShortcode(editor, pluginConfig);\n  }\n\n  function handleKeyDown(event) {\n    for (const handler of editor.keyDownHandlers || []) {\n      if (handler(event, editor) === false) {\n        break;\n      }\n    }\n    ReactEditor.focus(editor);\n  }\n\n  function handleClickBelowDocument() {\n    ReactEditor.focus(editor);\n    Transforms.select(editor, { path: [0, 0], offset: 0 });\n    Transforms.select(editor, SlateEditor.end(editor, []));\n  }\n  const [toolbarKey, setToolbarKey] = useState(0);\n\n  function handleChange(newValue) {\n    if (!isEqual(newValue, editorValue)) {\n      setEditorValue(() => newValue);\n      onChange(\n        slateToMarkdown(newValue, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        }),\n      );\n    }\n    setToolbarKey(prev => prev + 1);\n  }\n\n  function hasMark(format) {\n    return isMarkActive(editor, format);\n  }\n\n  function hasInline(format) {\n    if (format == 'link') {\n      return !!getActiveLink(editor);\n    }\n    return false;\n  }\n\n  function hasBlock(format) {\n    return isCursorInBlockType(editor, format);\n  }\n  function hasQuote() {\n    return isCursorInBlockType(editor, 'quote');\n  }\n  function hasListItems(type) {\n    return isCursorInBlockType(editor, type);\n  }\n\n  return (\n    <div\n      css={coreCss`\n        position: relative;\n      `}\n    >\n      <Slate editor={editor} value={editorValue} onChange={handleChange}>\n        <EditorControlBar>\n          {\n            <Toolbar\n              key={toolbarKey}\n              onMarkClick={handleMarkClick}\n              onBlockClick={handleBlockClick}\n              onLinkClick={handleLinkClick}\n              onToggleMode={handleToggleMode}\n              plugins={editorComponents}\n              onSubmit={handleInsertShortcode}\n              onAddAsset={onAddAsset}\n              getAsset={getAsset}\n              buttons={field.get('buttons')}\n              editorComponents={field.get('editor_components')}\n              hasMark={hasMark}\n              hasInline={hasInline}\n              hasBlock={hasBlock}\n              hasQuote={hasQuote}\n              hasListItems={hasListItems}\n              isShowModeToggle={isShowModeToggle}\n              t={t}\n              disabled={isDisabled}\n            />\n          }\n        </EditorControlBar>\n        {\n          <ClassNames>\n            {({ css, cx }) => (\n              <div\n                className={cx(\n                  className,\n                  css`\n                    ${visualEditorStyles({ minimal: field.get('minimal') })}\n                  `,\n                )}\n              >\n                {editorValue.length !== 0 && (\n                  <Editable\n                    className={css`\n                      padding: 16px 20px 0;\n                    `}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    onKeyDown={handleKeyDown}\n                    autoFocus={false}\n                  />\n                )}\n                <InsertionPoint onClick={handleClickBelowDocument} />\n              </div>\n            )}\n          </ClassNames>\n        }\n      </Slate>\n    </div>\n  );\n}\n\nEditor.propTypes = {\n  onAddAsset: PropTypes.func.isRequired,\n  getAsset: PropTypes.func.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onMode: PropTypes.func.isRequired,\n  className: PropTypes.string.isRequired,\n  value: PropTypes.string,\n  field: ImmutablePropTypes.map.isRequired,\n  getEditorComponents: PropTypes.func.isRequired,\n  getRemarkPlugins: PropTypes.func.isRequired,\n  isShowModeToggle: PropTypes.bool.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default Editor;\n"]} */",
92
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/VisualEditor.js"],"names":[],"mappings":"AA4NkB","file":"../../../src/MarkdownControl/VisualEditor.js","sourcesContent":["// @refresh reset\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { ClassNames, css as coreCss } from '@emotion/react';\nimport { lengths, fonts, zIndex } from 'decap-cms-ui-default';\nimport styled from '@emotion/styled';\nimport { createEditor, Transforms, Editor as SlateEditor } from 'slate';\nimport { Editable, ReactEditor, Slate, withReact } from 'slate-react';\nimport { withHistory } from 'slate-history';\nimport { fromJS } from 'immutable';\nimport { isEqual } from 'lodash';\n\nimport { editorStyleVars, EditorControlBar } from '../styles';\nimport Toolbar from './Toolbar';\nimport { Element, Leaf } from './renderers';\nimport withLists from './plugins/lists/withLists';\nimport withBlocks from './plugins/blocks/withBlocks';\nimport withInlines from './plugins/inlines/withInlines';\nimport toggleMark from './plugins/inlines/events/toggleMark';\nimport toggleLink from './plugins/inlines/events/toggleLink';\nimport getActiveLink from './plugins/inlines/selectors/getActiveLink';\nimport isMarkActive from './plugins/inlines/locations/isMarkActive';\nimport isCursorInBlockType from './plugins/blocks/locations/isCursorInBlockType';\nimport { markdownToSlate, slateToMarkdown } from '../serializers';\nimport withShortcodes from './plugins/shortcodes/withShortcodes';\nimport insertShortcode from './plugins/shortcodes/insertShortcode';\nimport defaultEmptyBlock from './plugins/blocks/defaultEmptyBlock';\nimport withHtml from './plugins/html/withHtml';\n\nfunction visualEditorStyles({ minimal }) {\n  return `\n  position: relative;\n  overflow: auto;\n  font-family: ${fonts.primary};\n  min-height: ${minimal ? 'auto' : lengths.richTextEditorMinHeight};\n  border-top-left-radius: 0;\n  border-top-right-radius: 0;\n  border-top: 0;\n  margin-top: -${editorStyleVars.stickyDistanceBottom};\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  z-index: ${zIndex.zIndex100};\n`;\n}\n\nconst InsertionPoint = styled.div`\n  flex: 1 1 auto;\n  cursor: text;\n`;\n\nexport function mergeMediaConfig(editorComponents, field) {\n  // merge editor media library config to image components\n  if (editorComponents.has('image')) {\n    const imageComponent = editorComponents.get('image');\n    const fields = imageComponent?.fields;\n\n    if (fields) {\n      imageComponent.fields = fields.update(\n        fields.findIndex(f => f.get('widget') === 'image'),\n        f => {\n          // merge `media_library` config\n          if (field.has('media_library')) {\n            f = f.set(\n              'media_library',\n              field.get('media_library').mergeDeep(f.get('media_library')),\n            );\n          }\n          // merge 'media_folder'\n          if (field.has('media_folder') && !f.has('media_folder')) {\n            f = f.set('media_folder', field.get('media_folder'));\n          }\n          // merge 'public_folder'\n          if (field.has('public_folder') && !f.has('public_folder')) {\n            f = f.set('public_folder', field.get('public_folder'));\n          }\n          return f;\n        },\n      );\n    }\n  }\n}\n\nfunction Editor(props) {\n  const {\n    onAddAsset,\n    getAsset,\n    className,\n    field,\n    isShowModeToggle,\n    t,\n    isDisabled,\n    getEditorComponents,\n    getRemarkPlugins,\n    onChange,\n  } = props;\n\n  const editor = useMemo(\n    () =>\n      withHtml(\n        withReact(withHistory(withShortcodes(withBlocks(withLists(withInlines(createEditor())))))),\n      ),\n    [],\n  );\n\n  const emptyValue = [defaultEmptyBlock()];\n  let editorComponents = getEditorComponents();\n  const codeBlockComponent = fromJS(editorComponents.find(({ type }) => type === 'code-block'));\n\n  editorComponents =\n    codeBlockComponent || editorComponents.has('code-block')\n      ? editorComponents\n      : editorComponents.set('code-block', { label: 'Code Block', type: 'code-block' });\n\n  mergeMediaConfig(editorComponents, field);\n\n  const [editorValue, setEditorValue] = useState(\n    props.value\n      ? markdownToSlate(props.value, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        })\n      : emptyValue,\n  );\n\n  const renderElement = useCallback(\n    props => (\n      <Element {...props} classNameWrapper={className} codeBlockComponent={codeBlockComponent} />\n    ),\n    [],\n  );\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n\n  useEffect(() => {\n    if (props.pendingFocus) {\n      ReactEditor.focus(editor);\n      props.pendingFocus();\n    }\n  }, [props.pendingFocus]);\n\n  function handleMarkClick(format) {\n    ReactEditor.focus(editor);\n    toggleMark(editor, format);\n  }\n\n  function handleBlockClick(format) {\n    ReactEditor.focus(editor);\n    if (format.endsWith('-list')) {\n      editor.toggleList(format);\n    } else {\n      editor.toggleBlock(format);\n    }\n  }\n\n  function handleLinkClick() {\n    toggleLink(editor, t('editor.editorWidgets.markdown.linkPrompt'));\n    ReactEditor.focus(editor);\n  }\n\n  function handleToggleMode() {\n    props.onMode('raw');\n  }\n\n  function handleInsertShortcode(pluginConfig) {\n    insertShortcode(editor, pluginConfig);\n  }\n\n  function handleKeyDown(event) {\n    for (const handler of editor.keyDownHandlers || []) {\n      if (handler(event, editor) === false) {\n        break;\n      }\n    }\n    ReactEditor.focus(editor);\n  }\n\n  function handleClickBelowDocument() {\n    ReactEditor.focus(editor);\n    Transforms.select(editor, { path: [0, 0], offset: 0 });\n    Transforms.select(editor, SlateEditor.end(editor, []));\n  }\n  const [toolbarKey, setToolbarKey] = useState(0);\n\n  function handleChange(newValue) {\n    if (!isEqual(newValue, editorValue)) {\n      setEditorValue(() => newValue);\n      onChange(\n        slateToMarkdown(newValue, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        }),\n      );\n    }\n    setToolbarKey(prev => prev + 1);\n  }\n\n  function hasMark(format) {\n    return isMarkActive(editor, format);\n  }\n\n  function hasInline(format) {\n    if (format == 'link') {\n      return !!getActiveLink(editor);\n    }\n    return false;\n  }\n\n  function hasBlock(format) {\n    return isCursorInBlockType(editor, format);\n  }\n  function hasQuote() {\n    return isCursorInBlockType(editor, 'quote');\n  }\n  function hasListItems(type) {\n    return isCursorInBlockType(editor, type);\n  }\n\n  return (\n    <div\n      css={coreCss`\n        position: relative;\n      `}\n    >\n      <Slate editor={editor} value={editorValue} onChange={handleChange}>\n        <EditorControlBar>\n          {\n            <Toolbar\n              key={toolbarKey}\n              onMarkClick={handleMarkClick}\n              onBlockClick={handleBlockClick}\n              onLinkClick={handleLinkClick}\n              onToggleMode={handleToggleMode}\n              plugins={editorComponents}\n              onSubmit={handleInsertShortcode}\n              onAddAsset={onAddAsset}\n              getAsset={getAsset}\n              buttons={field.get('buttons')}\n              editorComponents={field.get('editor_components')}\n              hasMark={hasMark}\n              hasInline={hasInline}\n              hasBlock={hasBlock}\n              hasQuote={hasQuote}\n              hasListItems={hasListItems}\n              isShowModeToggle={isShowModeToggle}\n              t={t}\n              disabled={isDisabled}\n            />\n          }\n        </EditorControlBar>\n        {\n          <ClassNames>\n            {({ css, cx }) => (\n              <div\n                className={cx(\n                  className,\n                  css`\n                    ${visualEditorStyles({ minimal: field.get('minimal') })}\n                  `,\n                )}\n              >\n                {editorValue.length !== 0 && (\n                  <Editable\n                    className={css`\n                      padding: 16px 20px 0;\n                    `}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    onKeyDown={handleKeyDown}\n                    autoFocus={false}\n                  />\n                )}\n                <InsertionPoint onClick={handleClickBelowDocument} />\n              </div>\n            )}\n          </ClassNames>\n        }\n      </Slate>\n    </div>\n  );\n}\n\nEditor.propTypes = {\n  onAddAsset: PropTypes.func.isRequired,\n  getAsset: PropTypes.func.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onMode: PropTypes.func.isRequired,\n  className: PropTypes.string.isRequired,\n  value: PropTypes.string,\n  field: ImmutablePropTypes.map.isRequired,\n  getEditorComponents: PropTypes.func.isRequired,\n  getRemarkPlugins: PropTypes.func.isRequired,\n  isShowModeToggle: PropTypes.bool.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default Editor;\n"]} */",
101
93
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
102
94
  };
103
95
  function Editor(props) {
@@ -113,10 +105,10 @@ function Editor(props) {
113
105
  getRemarkPlugins,
114
106
  onChange
115
107
  } = props;
116
- const editor = (0, _react.useMemo)(() => (0, _withHtml.default)((0, _slateReact.withReact)((0, _slateHistory.withHistory)((0, _withShortcodes.default)((0, _withBlocks.default)((0, _withLists.default)((0, _withInlines.default)((0, _slate.createEditor)()))))))), []);
117
- const emptyValue = [(0, _defaultEmptyBlock.default)()];
108
+ const editor = useMemo(() => withHtml(withReact(withHistory(withShortcodes(withBlocks(withLists(withInlines(createEditor()))))))), []);
109
+ const emptyValue = [defaultEmptyBlock()];
118
110
  let editorComponents = getEditorComponents();
119
- const codeBlockComponent = (0, _immutable.fromJS)(editorComponents.find(({
111
+ const codeBlockComponent = fromJS(editorComponents.find(({
120
112
  type
121
113
  }) => type === 'code-block'));
122
114
  editorComponents = codeBlockComponent || editorComponents.has('code-block') ? editorComponents : editorComponents.set('code-block', {
@@ -124,26 +116,27 @@ function Editor(props) {
124
116
  type: 'code-block'
125
117
  });
126
118
  mergeMediaConfig(editorComponents, field);
127
- const [editorValue, setEditorValue] = (0, _react.useState)(props.value ? (0, _serializers.markdownToSlate)(props.value, {
119
+ const [editorValue, setEditorValue] = useState(props.value ? markdownToSlate(props.value, {
128
120
  voidCodeBlock: !!codeBlockComponent,
129
121
  remarkPlugins: getRemarkPlugins()
130
122
  }) : emptyValue);
131
- const renderElement = (0, _react.useCallback)(props => (0, _react2.jsx)(_renderers.Element, _extends({}, props, {
123
+ const renderElement = useCallback(props => ___EmotionJSX(Element, _extends({}, props, {
132
124
  classNameWrapper: className,
133
125
  codeBlockComponent: codeBlockComponent
134
126
  })), []);
135
- const renderLeaf = (0, _react.useCallback)(props => (0, _react2.jsx)(_renderers.Leaf, props), []);
136
- (0, _react.useEffect)(() => {
127
+ const renderLeaf = useCallback(props => ___EmotionJSX(Leaf, props), []);
128
+ useEffect(() => {
137
129
  if (props.pendingFocus) {
138
- _slateReact.ReactEditor.focus(editor);
130
+ ReactEditor.focus(editor);
131
+ props.pendingFocus();
139
132
  }
140
- }, []);
133
+ }, [props.pendingFocus]);
141
134
  function handleMarkClick(format) {
142
- _slateReact.ReactEditor.focus(editor);
143
- (0, _toggleMark.default)(editor, format);
135
+ ReactEditor.focus(editor);
136
+ toggleMark(editor, format);
144
137
  }
145
138
  function handleBlockClick(format) {
146
- _slateReact.ReactEditor.focus(editor);
139
+ ReactEditor.focus(editor);
147
140
  if (format.endsWith('-list')) {
148
141
  editor.toggleList(format);
149
142
  } else {
@@ -151,14 +144,14 @@ function Editor(props) {
151
144
  }
152
145
  }
153
146
  function handleLinkClick() {
154
- (0, _toggleLink.default)(editor, t('editor.editorWidgets.markdown.linkPrompt'));
155
- _slateReact.ReactEditor.focus(editor);
147
+ toggleLink(editor, t('editor.editorWidgets.markdown.linkPrompt'));
148
+ ReactEditor.focus(editor);
156
149
  }
157
150
  function handleToggleMode() {
158
151
  props.onMode('raw');
159
152
  }
160
153
  function handleInsertShortcode(pluginConfig) {
161
- (0, _insertShortcode.default)(editor, pluginConfig);
154
+ insertShortcode(editor, pluginConfig);
162
155
  }
163
156
  function handleKeyDown(event) {
164
157
  for (const handler of editor.keyDownHandlers || []) {
@@ -166,21 +159,21 @@ function Editor(props) {
166
159
  break;
167
160
  }
168
161
  }
169
- _slateReact.ReactEditor.focus(editor);
162
+ ReactEditor.focus(editor);
170
163
  }
171
164
  function handleClickBelowDocument() {
172
- _slateReact.ReactEditor.focus(editor);
173
- _slate.Transforms.select(editor, {
165
+ ReactEditor.focus(editor);
166
+ Transforms.select(editor, {
174
167
  path: [0, 0],
175
168
  offset: 0
176
169
  });
177
- _slate.Transforms.select(editor, _slate.Editor.end(editor, []));
170
+ Transforms.select(editor, SlateEditor.end(editor, []));
178
171
  }
179
- const [toolbarKey, setToolbarKey] = (0, _react.useState)(0);
172
+ const [toolbarKey, setToolbarKey] = useState(0);
180
173
  function handleChange(newValue) {
181
- if (!(0, _isEqual2.default)(newValue, editorValue)) {
174
+ if (!_isEqual(newValue, editorValue)) {
182
175
  setEditorValue(() => newValue);
183
- onChange((0, _serializers.slateToMarkdown)(newValue, {
176
+ onChange(slateToMarkdown(newValue, {
184
177
  voidCodeBlock: !!codeBlockComponent,
185
178
  remarkPlugins: getRemarkPlugins()
186
179
  }));
@@ -188,30 +181,30 @@ function Editor(props) {
188
181
  setToolbarKey(prev => prev + 1);
189
182
  }
190
183
  function hasMark(format) {
191
- return (0, _isMarkActive.default)(editor, format);
184
+ return isMarkActive(editor, format);
192
185
  }
193
186
  function hasInline(format) {
194
187
  if (format == 'link') {
195
- return !!(0, _getActiveLink.default)(editor);
188
+ return !!getActiveLink(editor);
196
189
  }
197
190
  return false;
198
191
  }
199
192
  function hasBlock(format) {
200
- return (0, _isCursorInBlockType.default)(editor, format);
193
+ return isCursorInBlockType(editor, format);
201
194
  }
202
195
  function hasQuote() {
203
- return (0, _isCursorInBlockType.default)(editor, 'quote');
196
+ return isCursorInBlockType(editor, 'quote');
204
197
  }
205
198
  function hasListItems(type) {
206
- return (0, _isCursorInBlockType.default)(editor, type);
199
+ return isCursorInBlockType(editor, type);
207
200
  }
208
- return (0, _react2.jsx)("div", {
201
+ return ___EmotionJSX("div", {
209
202
  css: _ref
210
- }, (0, _react2.jsx)(_slateReact.Slate, {
203
+ }, ___EmotionJSX(Slate, {
211
204
  editor: editor,
212
205
  value: editorValue,
213
206
  onChange: handleChange
214
- }, (0, _react2.jsx)(_styles.EditorControlBar, null, (0, _react2.jsx)(_Toolbar.default, {
207
+ }, ___EmotionJSX(EditorControlBar, null, ___EmotionJSX(Toolbar, {
215
208
  key: toolbarKey,
216
209
  onMarkClick: handleMarkClick,
217
210
  onBlockClick: handleBlockClick,
@@ -231,16 +224,16 @@ function Editor(props) {
231
224
  isShowModeToggle: isShowModeToggle,
232
225
  t: t,
233
226
  disabled: isDisabled
234
- })), (0, _react2.jsx)(_react2.ClassNames, null, ({
227
+ })), ___EmotionJSX(ClassNames, null, ({
235
228
  css,
236
229
  cx
237
- }) => (0, _react2.jsx)("div", {
230
+ }) => ___EmotionJSX("div", {
238
231
  className: cx(className, css`
239
232
  ${visualEditorStyles({
240
233
  minimal: field.get('minimal')
241
234
  })}
242
235
  `)
243
- }, editorValue.length !== 0 && (0, _react2.jsx)(_slateReact.Editable, {
236
+ }, editorValue.length !== 0 && ___EmotionJSX(Editable, {
244
237
  className: css`
245
238
  padding: 16px 20px 0;
246
239
  `,
@@ -248,21 +241,21 @@ function Editor(props) {
248
241
  renderLeaf: renderLeaf,
249
242
  onKeyDown: handleKeyDown,
250
243
  autoFocus: false
251
- }), (0, _react2.jsx)(InsertionPoint, {
244
+ }), ___EmotionJSX(InsertionPoint, {
252
245
  onClick: handleClickBelowDocument
253
246
  })))));
254
247
  }
255
248
  Editor.propTypes = {
256
- onAddAsset: _propTypes.default.func.isRequired,
257
- getAsset: _propTypes.default.func.isRequired,
258
- onChange: _propTypes.default.func.isRequired,
259
- onMode: _propTypes.default.func.isRequired,
260
- className: _propTypes.default.string.isRequired,
261
- value: _propTypes.default.string,
262
- field: _reactImmutableProptypes.default.map.isRequired,
263
- getEditorComponents: _propTypes.default.func.isRequired,
264
- getRemarkPlugins: _propTypes.default.func.isRequired,
265
- isShowModeToggle: _propTypes.default.bool.isRequired,
266
- t: _propTypes.default.func.isRequired
249
+ onAddAsset: PropTypes.func.isRequired,
250
+ getAsset: PropTypes.func.isRequired,
251
+ onChange: PropTypes.func.isRequired,
252
+ onMode: PropTypes.func.isRequired,
253
+ className: PropTypes.string.isRequired,
254
+ value: PropTypes.string,
255
+ field: ImmutablePropTypes.map.isRequired,
256
+ getEditorComponents: PropTypes.func.isRequired,
257
+ getRemarkPlugins: PropTypes.func.isRequired,
258
+ isShowModeToggle: PropTypes.bool.isRequired,
259
+ t: PropTypes.func.isRequired
267
260
  };
268
- var _default = exports.default = Editor;
261
+ export default Editor;
@@ -1,25 +1,18 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _omit2 = _interopRequireDefault(require("lodash/omit"));
8
- var _react = _interopRequireWildcard(require("react"));
9
- var _react2 = require("@emotion/react");
10
- var _immutable = require("immutable");
11
- var _slateReact = require("slate-react");
12
- var _slate = require("slate");
13
- var _index = require("../index");
14
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
15
- function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
16
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
1
+ import _omit from "lodash/omit";
17
2
  function ownKeys(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; }
18
3
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
19
4
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
20
5
  function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
21
6
  function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
22
- function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } /* eslint-disable react/prop-types */
7
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
8
+ /* eslint-disable react/prop-types */
9
+ import React, { useState } from 'react';
10
+ import { css } from '@emotion/react';
11
+ import { fromJS } from 'immutable';
12
+ import { ReactEditor, useSlate } from 'slate-react';
13
+ import { Range, Transforms } from 'slate';
14
+ import { getEditorControl, getEditorComponents } from '../index';
15
+ import { jsx as ___EmotionJSX } from "@emotion/react";
23
16
  var _ref = process.env.NODE_ENV === "production" ? {
24
17
  name: "1xfnuhy-Shortcode",
25
18
  styles: "margin-top:0;margin-bottom:16px;&:first-of-type{margin-top:0;};label:Shortcode;"
@@ -30,40 +23,40 @@ var _ref = process.env.NODE_ENV === "production" ? {
30
23
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
31
24
  };
32
25
  function Shortcode(props) {
33
- const editor = (0, _slateReact.useSlate)();
26
+ const editor = useSlate();
34
27
  const {
35
28
  element,
36
29
  dataKey = 'shortcodeData',
37
30
  children
38
31
  } = props;
39
- const EditorControl = (0, _index.getEditorControl)();
40
- const plugin = (0, _index.getEditorComponents)().get(element.data.shortcode);
32
+ const EditorControl = getEditorControl();
33
+ const plugin = getEditorComponents().get(element.data.shortcode);
41
34
  const fieldKeys = ['id', 'fromBlock', 'toBlock', 'toPreview', 'pattern', 'icon'];
42
- const field = (0, _immutable.fromJS)((0, _omit2.default)(plugin, fieldKeys));
43
- const [value, setValue] = (0, _react.useState)((0, _immutable.fromJS)(element.data[dataKey]));
35
+ const field = fromJS(_omit(plugin, fieldKeys));
36
+ const [value, setValue] = useState(fromJS(element.data[dataKey]));
44
37
  function handleChange(fieldName, value, metadata) {
45
- const path = _slateReact.ReactEditor.findPath(editor, element);
38
+ const path = ReactEditor.findPath(editor, element);
46
39
  const newProperties = {
47
40
  data: _objectSpread(_objectSpread({}, element.data), {}, {
48
41
  [dataKey]: value.toJS(),
49
42
  metadata
50
43
  })
51
44
  };
52
- _slate.Transforms.setNodes(editor, newProperties, {
45
+ Transforms.setNodes(editor, newProperties, {
53
46
  at: path
54
47
  });
55
48
  setValue(value);
56
49
  }
57
50
  function handleFocus() {
58
- const path = _slateReact.ReactEditor.findPath(editor, element);
59
- _slate.Transforms.select(editor, path);
51
+ const path = ReactEditor.findPath(editor, element);
52
+ Transforms.select(editor, path);
60
53
  }
61
- const path = _slateReact.ReactEditor.findPath(editor, element);
62
- const isSelected = editor.selection && path && _slate.Range.isRange(editor.selection) && _slate.Range.includes(editor.selection, path);
63
- return !field.isEmpty() && (0, _react2.jsx)("div", {
54
+ const path = ReactEditor.findPath(editor, element);
55
+ const isSelected = editor.selection && path && Range.isRange(editor.selection) && Range.includes(editor.selection, path);
56
+ return !field.isEmpty() && ___EmotionJSX("div", {
64
57
  onClick: handleFocus,
65
58
  onFocus: handleFocus
66
- }, (0, _react2.jsx)(EditorControl, {
59
+ }, ___EmotionJSX(EditorControl, {
67
60
  css: _ref,
68
61
  value: value,
69
62
  field: field,
@@ -74,4 +67,4 @@ function Shortcode(props) {
74
67
  isSelected: isSelected
75
68
  }), children);
76
69
  }
77
- var _default = exports.default = Shortcode;
70
+ export default Shortcode;