@pie-lib/editable-html-tip-tap 1.0.2 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/components/CharacterPicker.js +221 -0
- package/lib/components/EditableHtml.js +323 -0
- package/lib/components/MenuBar.js +693 -0
- package/lib/components/TiptapContainer.js +90 -0
- package/lib/components/buttons/done-button.js +53 -0
- package/lib/components/characters/characterUtils.js +112 -0
- package/lib/components/characters/custom-popper.js +73 -0
- package/lib/components/common/done-button.js +53 -0
- package/lib/components/icons/CssIcon.js +37 -0
- package/lib/components/icons/RespArea.js +95 -0
- package/lib/components/icons/TableIcons.js +69 -0
- package/lib/components/icons/TextAlign.js +194 -0
- package/lib/components/icons/index.js +194 -0
- package/lib/components/image/ImageToolbar.js +16 -0
- package/lib/components/image/InsertImageHandler.js +16 -0
- package/lib/components/media/MediaDialog.js +16 -0
- package/lib/components/media/MediaToolbar.js +16 -0
- package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js +94 -0
- package/lib/components/respArea/DragInTheBlank/choice.js +289 -0
- package/lib/components/respArea/DragInTheBlank.js +94 -0
- package/lib/components/respArea/ExplicitConstructedResponse.js +120 -0
- package/lib/components/respArea/InlineDropdown.js +126 -0
- package/lib/components/respArea/ToolbarIcon.js +105 -0
- package/lib/components/respArea/choice.js +2 -0
- package/lib/extensions/component.js +5 -5
- package/lib/extensions/custom-toolbar-wrapper.js +2 -4
- package/lib/extensions/extended-table.js +30 -0
- package/lib/extensions/index.js +52 -0
- package/lib/extensions/media.js +5 -5
- package/lib/extensions/responseArea.js +7 -7
- package/lib/index.js +16 -1481
- package/lib/plugins/index.js +8 -80
- package/lib/styles/editorContainerStyles.js +200 -0
- package/lib/utils/size.js +34 -0
- package/package.json +1 -1
- package/src/components/CharacterPicker.jsx +185 -0
- package/src/components/EditableHtml.jsx +306 -0
- package/src/components/MenuBar.jsx +630 -0
- package/src/components/TiptapContainer.jsx +96 -0
- package/src/components/characters/characterUtils.js +127 -0
- package/src/components/image/ImageToolbar.jsx +1 -0
- package/src/components/image/InsertImageHandler.js +1 -0
- package/src/components/media/MediaDialog.js +1 -0
- package/src/components/media/MediaToolbar.jsx +1 -0
- package/src/{plugins/respArea/drag-in-the-blank → components/respArea/DragInTheBlank}/choice.jsx +1 -1
- package/src/{plugins/respArea/inline-dropdown/index.jsx → components/respArea/InlineDropdown.jsx} +1 -1
- package/src/components/respArea/ToolbarIcon.jsx +68 -0
- package/src/extensions/component.jsx +2 -2
- package/src/extensions/custom-toolbar-wrapper.jsx +6 -7
- package/src/extensions/extended-table.js +27 -0
- package/src/extensions/index.js +76 -0
- package/src/extensions/media.js +10 -4
- package/src/extensions/responseArea.js +7 -7
- package/src/index.jsx +3 -1440
- package/src/styles/editorContainerStyles.js +203 -0
- package/src/utils/size.js +32 -0
- package/src/__tests__/editor.test.jsx +0 -363
- package/src/__tests__/serialization.test.js +0 -291
- package/src/block-tags.js +0 -17
- package/src/editor.jsx +0 -1197
- package/src/extensions/characters.js +0 -46
- package/src/old-index.jsx +0 -162
- package/src/parse-html.js +0 -8
- package/src/plugins/README.md +0 -27
- package/src/plugins/characters/index.jsx +0 -284
- package/src/plugins/characters/utils.js +0 -447
- package/src/plugins/css/index.jsx +0 -340
- package/src/plugins/customPlugin/index.jsx +0 -85
- package/src/plugins/html/icons/index.jsx +0 -19
- package/src/plugins/html/index.jsx +0 -72
- package/src/plugins/image/__tests__/__snapshots__/component.test.jsx.snap +0 -51
- package/src/plugins/image/__tests__/__snapshots__/image-toolbar-logic.test.jsx.snap +0 -27
- package/src/plugins/image/__tests__/__snapshots__/image-toolbar.test.jsx.snap +0 -44
- package/src/plugins/image/__tests__/component.test.jsx +0 -41
- package/src/plugins/image/__tests__/image-toolbar-logic.test.jsx +0 -42
- package/src/plugins/image/__tests__/image-toolbar.test.jsx +0 -11
- package/src/plugins/image/__tests__/index.test.js +0 -95
- package/src/plugins/image/__tests__/insert-image-handler.test.js +0 -113
- package/src/plugins/image/__tests__/mock-change.js +0 -15
- package/src/plugins/image/alt-dialog.jsx +0 -82
- package/src/plugins/image/component.jsx +0 -343
- package/src/plugins/image/image-toolbar.jsx +0 -100
- package/src/plugins/image/index.jsx +0 -227
- package/src/plugins/image/insert-image-handler.js +0 -79
- package/src/plugins/index.jsx +0 -377
- package/src/plugins/list/__tests__/index.test.js +0 -54
- package/src/plugins/list/index.jsx +0 -305
- package/src/plugins/math/__tests__/__snapshots__/index.test.jsx.snap +0 -48
- package/src/plugins/math/__tests__/index.test.jsx +0 -245
- package/src/plugins/math/index.jsx +0 -379
- package/src/plugins/media/__tests__/index.test.js +0 -75
- package/src/plugins/media/index.jsx +0 -325
- package/src/plugins/media/media-dialog.js +0 -624
- package/src/plugins/media/media-toolbar.jsx +0 -56
- package/src/plugins/media/media-wrapper.jsx +0 -43
- package/src/plugins/rendering/index.js +0 -31
- package/src/plugins/respArea/index.jsx +0 -299
- package/src/plugins/respArea/math-templated/index.jsx +0 -104
- package/src/plugins/respArea/utils.jsx +0 -90
- package/src/plugins/table/CustomTablePlugin.js +0 -113
- package/src/plugins/table/__tests__/__snapshots__/table-toolbar.test.jsx.snap +0 -44
- package/src/plugins/table/__tests__/index.test.jsx +0 -401
- package/src/plugins/table/__tests__/table-toolbar.test.jsx +0 -42
- package/src/plugins/table/index.jsx +0 -427
- package/src/plugins/table/table-toolbar.jsx +0 -136
- package/src/plugins/textAlign/index.jsx +0 -23
- package/src/plugins/toolbar/__tests__/__snapshots__/default-toolbar.test.jsx.snap +0 -923
- package/src/plugins/toolbar/__tests__/__snapshots__/editor-and-toolbar.test.jsx.snap +0 -20
- package/src/plugins/toolbar/__tests__/__snapshots__/toolbar-buttons.test.jsx.snap +0 -36
- package/src/plugins/toolbar/__tests__/__snapshots__/toolbar.test.jsx.snap +0 -46
- package/src/plugins/toolbar/__tests__/default-toolbar.test.jsx +0 -94
- package/src/plugins/toolbar/__tests__/editor-and-toolbar.test.jsx +0 -37
- package/src/plugins/toolbar/__tests__/toolbar-buttons.test.jsx +0 -51
- package/src/plugins/toolbar/__tests__/toolbar.test.jsx +0 -106
- package/src/plugins/toolbar/default-toolbar.jsx +0 -206
- package/src/plugins/toolbar/editor-and-toolbar.jsx +0 -257
- package/src/plugins/toolbar/index.jsx +0 -23
- package/src/plugins/toolbar/toolbar-buttons.jsx +0 -138
- package/src/plugins/toolbar/toolbar.jsx +0 -338
- package/src/plugins/utils.js +0 -31
- package/src/serialization.jsx +0 -621
- /package/src/{plugins → components}/characters/custom-popper.js +0 -0
- /package/src/{plugins/toolbar → components/common}/done-button.jsx +0 -0
- /package/src/{plugins/css/icons/index.jsx → components/icons/CssIcon.jsx} +0 -0
- /package/src/{plugins/respArea/icons/index.jsx → components/icons/RespArea.jsx} +0 -0
- /package/src/{plugins/table/icons/index.jsx → components/icons/TableIcons.jsx} +0 -0
- /package/src/{plugins/textAlign/icons/index.jsx → components/icons/TextAlign.jsx} +0 -0
- /package/src/{plugins/respArea/drag-in-the-blank/index.jsx → components/respArea/DragInTheBlank/DragInTheBlank.jsx} +0 -0
- /package/src/{plugins/respArea/explicit-constructed-response/index.jsx → components/respArea/ExplicitConstructedResponse.jsx} +0 -0
|
@@ -0,0 +1,693 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports["default"] = void 0;
|
|
11
|
+
|
|
12
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
13
|
+
|
|
14
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
+
|
|
16
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
17
|
+
|
|
18
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
19
|
+
|
|
20
|
+
var _styles = require("@material-ui/core/styles");
|
|
21
|
+
|
|
22
|
+
var _prosemirrorState = require("prosemirror-state");
|
|
23
|
+
|
|
24
|
+
var _FormatBold = _interopRequireDefault(require("@material-ui/icons/FormatBold"));
|
|
25
|
+
|
|
26
|
+
var _FormatItalic = _interopRequireDefault(require("@material-ui/icons/FormatItalic"));
|
|
27
|
+
|
|
28
|
+
var _FormatStrikethrough = _interopRequireDefault(require("@material-ui/icons/FormatStrikethrough"));
|
|
29
|
+
|
|
30
|
+
var _Code = _interopRequireDefault(require("@material-ui/icons/Code"));
|
|
31
|
+
|
|
32
|
+
var _GridOn = _interopRequireDefault(require("@material-ui/icons/GridOn"));
|
|
33
|
+
|
|
34
|
+
var _FormatListBulleted = _interopRequireDefault(require("@material-ui/icons/FormatListBulleted"));
|
|
35
|
+
|
|
36
|
+
var _FormatListNumbered = _interopRequireDefault(require("@material-ui/icons/FormatListNumbered"));
|
|
37
|
+
|
|
38
|
+
var _FormatUnderlined = _interopRequireDefault(require("@material-ui/icons/FormatUnderlined"));
|
|
39
|
+
|
|
40
|
+
var _Functions = _interopRequireDefault(require("@material-ui/icons/Functions"));
|
|
41
|
+
|
|
42
|
+
var _Image = _interopRequireDefault(require("@material-ui/icons/Image"));
|
|
43
|
+
|
|
44
|
+
var _Redo = _interopRequireDefault(require("@material-ui/icons/Redo"));
|
|
45
|
+
|
|
46
|
+
var _Undo = _interopRequireDefault(require("@material-ui/icons/Undo"));
|
|
47
|
+
|
|
48
|
+
var _Theaters = _interopRequireDefault(require("@material-ui/icons/Theaters"));
|
|
49
|
+
|
|
50
|
+
var _VolumeUp = _interopRequireDefault(require("@material-ui/icons/VolumeUp"));
|
|
51
|
+
|
|
52
|
+
var _BorderAll = _interopRequireDefault(require("@material-ui/icons/BorderAll"));
|
|
53
|
+
|
|
54
|
+
var _react2 = require("@tiptap/react");
|
|
55
|
+
|
|
56
|
+
var _constants = require("../constants");
|
|
57
|
+
|
|
58
|
+
var _ToolbarIcon = require("./respArea/ToolbarIcon");
|
|
59
|
+
|
|
60
|
+
var _characterUtils = require("./characters/characterUtils");
|
|
61
|
+
|
|
62
|
+
var _TextAlign = _interopRequireDefault(require("./icons/TextAlign"));
|
|
63
|
+
|
|
64
|
+
var _CssIcon = _interopRequireDefault(require("./icons/CssIcon"));
|
|
65
|
+
|
|
66
|
+
var _tableIcons = require("./icons/tableIcons");
|
|
67
|
+
|
|
68
|
+
var _CharacterPicker = require("./CharacterPicker");
|
|
69
|
+
|
|
70
|
+
var _doneButton = require("./common/done-button");
|
|
71
|
+
|
|
72
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
73
|
+
|
|
74
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
75
|
+
|
|
76
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
77
|
+
|
|
78
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
79
|
+
|
|
80
|
+
var SuperscriptIcon = function SuperscriptIcon() {
|
|
81
|
+
return /*#__PURE__*/_react["default"].createElement("svg", {
|
|
82
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
83
|
+
height: "24px",
|
|
84
|
+
viewBox: "0 0 24 24",
|
|
85
|
+
width: "24px",
|
|
86
|
+
fill: "none"
|
|
87
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
88
|
+
d: "M22,7h-2v1h3v1h-4V7c0-0.55,0.45-1,1-1h2V5h-3V4h3c0.55,0,1,0.45,1,1v1C23,6.55,22.55,7,22,7z M5.88,20h2.66l3.4-5.42h0.12 l3.4,5.42h2.66l-4.65-7.27L17.81,6h-2.68l-3.07,4.99h-0.12L8.85,6H6.19l4.32,6.73L5.88,20z",
|
|
89
|
+
fill: "currentColor"
|
|
90
|
+
}));
|
|
91
|
+
};
|
|
92
|
+
|
|
93
|
+
var SubscriptIcon = function SubscriptIcon() {
|
|
94
|
+
return /*#__PURE__*/_react["default"].createElement("svg", {
|
|
95
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
96
|
+
height: "24px",
|
|
97
|
+
viewBox: "0 0 24 24",
|
|
98
|
+
width: "24px",
|
|
99
|
+
fill: "none"
|
|
100
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
101
|
+
d: "M22,18h-2v1h3v1h-4v-2c0-0.55,0.45-1,1-1h2v-1h-3v-1h3c0.55,0,1,0.45,1,1v1C23,17.55,22.55,18,22,18z M5.88,18h2.66 l3.4-5.42h0.12l3.4,5.42h2.66l-4.65-7.27L17.81,4h-2.68l-3.07,4.99h-0.12L8.85,4H6.19l4.32,6.73L5.88,18z",
|
|
102
|
+
fill: "currentColor"
|
|
103
|
+
}));
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
var HeadingIcon = function HeadingIcon() {
|
|
107
|
+
return /*#__PURE__*/_react["default"].createElement("svg", {
|
|
108
|
+
width: "30",
|
|
109
|
+
height: "28",
|
|
110
|
+
viewBox: "0 0 30 28",
|
|
111
|
+
fill: "none",
|
|
112
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
113
|
+
style: {
|
|
114
|
+
width: '20px',
|
|
115
|
+
height: '18px'
|
|
116
|
+
}
|
|
117
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
118
|
+
d: "M27 4V24H29C29.5 24 30 24.5 30 25V27C30 27.5625 29.5 28 29 28H19C18.4375 28 18 27.5625 18 27V25C18 24.5 18.4375 24 19 24H21V16H9V24H11C11.5 24 12 24.5 12 25V27C12 27.5625 11.5 28 11 28H1C0.4375 28 0 27.5625 0 27V25C0 24.5 0.4375 24 1 24H3V4H1C0.4375 4 0 3.5625 0 3V1C0 0.5 0.4375 0 1 0H11C11.5 0 12 0.5 12 1V3C12 3.5625 11.5 4 11 4H9V12H21V4H19C18.4375 4 18 3.5625 18 3V1C18 0.5 18.4375 0 19 0H29C29.5 0 30 0.5 30 1V3C30 3.5625 29.5 4 29 4H27Z",
|
|
119
|
+
fill: "currentColor"
|
|
120
|
+
}));
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
function MenuBar(_ref) {
|
|
124
|
+
var _classNames;
|
|
125
|
+
|
|
126
|
+
var editor = _ref.editor,
|
|
127
|
+
classes = _ref.classes,
|
|
128
|
+
activePlugins = _ref.activePlugins,
|
|
129
|
+
toolOpts = _ref.toolbarOpts,
|
|
130
|
+
responseAreaProps = _ref.responseAreaProps,
|
|
131
|
+
onChange = _ref.onChange;
|
|
132
|
+
|
|
133
|
+
var _useState = (0, _react.useState)(false),
|
|
134
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
135
|
+
showPicker = _useState2[0],
|
|
136
|
+
setShowPicker = _useState2[1];
|
|
137
|
+
|
|
138
|
+
var toolbarOpts = toolOpts !== null && toolOpts !== void 0 ? toolOpts : {};
|
|
139
|
+
var editorState = (0, _react2.useEditorState)({
|
|
140
|
+
editor: editor,
|
|
141
|
+
selector: function selector(ctx) {
|
|
142
|
+
var _ctx$editor, _ctx$editor2, _ctx$editor3, _ctx$editor4, _ctx$editor5, _ctx$editor$isActive, _ctx$editor$can$chain, _ctx$editor$isActive2, _ref3, _ctx$editor$getAttrib, _ctx$editor$can$chain2, _ctx$editor$isActive3, _ctx$editor$can$chain3, _ctx$editor$isActive4, _ctx$editor$can$chain4, _ctx$editor$isActive5, _ctx$editor$can$chain5, _ctx$editor$can$chain6, _ctx$editor$isActive6, _ctx$editor$isActive7, _ctx$editor$isActive8, _ctx$editor$isActive9, _ctx$editor$isActive10, _ctx$editor$isActive11, _ctx$editor$isActive12, _ctx$editor$isActive13, _ctx$editor$isActive14, _ctx$editor$isActive15, _ctx$editor$isActive16, _ctx$editor$isActive17, _ctx$editor$isActive18, _ctx$editor$isActive19, _ctx$editor$can$chain7, _ctx$editor$can$chain8;
|
|
143
|
+
|
|
144
|
+
var _ref2 = ((_ctx$editor = ctx.editor) === null || _ctx$editor === void 0 ? void 0 : _ctx$editor.state) || {},
|
|
145
|
+
selection = _ref2.selection;
|
|
146
|
+
|
|
147
|
+
var currentNode;
|
|
148
|
+
|
|
149
|
+
if (selection instanceof _prosemirrorState.NodeSelection) {
|
|
150
|
+
currentNode = selection.node; // the selected node
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
var hideDefaultToolbar = ((_ctx$editor2 = ctx.editor) === null || _ctx$editor2 === void 0 ? void 0 : _ctx$editor2.isActive('math')) || ((_ctx$editor3 = ctx.editor) === null || _ctx$editor3 === void 0 ? void 0 : _ctx$editor3.isActive('explicit_constructed_response')) || ((_ctx$editor4 = ctx.editor) === null || _ctx$editor4 === void 0 ? void 0 : _ctx$editor4.isActive('imageUploadNode'));
|
|
154
|
+
return {
|
|
155
|
+
currentNode: currentNode,
|
|
156
|
+
hideDefaultToolbar: hideDefaultToolbar,
|
|
157
|
+
isFocused: (_ctx$editor5 = ctx.editor) === null || _ctx$editor5 === void 0 ? void 0 : _ctx$editor5.isFocused,
|
|
158
|
+
isBold: (_ctx$editor$isActive = ctx.editor.isActive('bold')) !== null && _ctx$editor$isActive !== void 0 ? _ctx$editor$isActive : false,
|
|
159
|
+
canBold: (_ctx$editor$can$chain = ctx.editor.can().chain().toggleBold().run()) !== null && _ctx$editor$can$chain !== void 0 ? _ctx$editor$can$chain : false,
|
|
160
|
+
isTable: (_ctx$editor$isActive2 = ctx.editor.isActive('table')) !== null && _ctx$editor$isActive2 !== void 0 ? _ctx$editor$isActive2 : false,
|
|
161
|
+
tableHasBorder: (_ref3 = ((_ctx$editor$getAttrib = ctx.editor.getAttributes('table')) === null || _ctx$editor$getAttrib === void 0 ? void 0 : _ctx$editor$getAttrib.border) === '1') !== null && _ref3 !== void 0 ? _ref3 : false,
|
|
162
|
+
canTable: (_ctx$editor$can$chain2 = ctx.editor.can().chain().insertTable().run()) !== null && _ctx$editor$can$chain2 !== void 0 ? _ctx$editor$can$chain2 : false,
|
|
163
|
+
isItalic: (_ctx$editor$isActive3 = ctx.editor.isActive('italic')) !== null && _ctx$editor$isActive3 !== void 0 ? _ctx$editor$isActive3 : false,
|
|
164
|
+
canItalic: (_ctx$editor$can$chain3 = ctx.editor.can().chain().toggleItalic().run()) !== null && _ctx$editor$can$chain3 !== void 0 ? _ctx$editor$can$chain3 : false,
|
|
165
|
+
isStrike: (_ctx$editor$isActive4 = ctx.editor.isActive('strike')) !== null && _ctx$editor$isActive4 !== void 0 ? _ctx$editor$isActive4 : false,
|
|
166
|
+
canStrike: (_ctx$editor$can$chain4 = ctx.editor.can().chain().toggleStrike().run()) !== null && _ctx$editor$can$chain4 !== void 0 ? _ctx$editor$can$chain4 : false,
|
|
167
|
+
isCode: (_ctx$editor$isActive5 = ctx.editor.isActive('code')) !== null && _ctx$editor$isActive5 !== void 0 ? _ctx$editor$isActive5 : false,
|
|
168
|
+
canCode: (_ctx$editor$can$chain5 = ctx.editor.can().chain().toggleCode().run()) !== null && _ctx$editor$can$chain5 !== void 0 ? _ctx$editor$can$chain5 : false,
|
|
169
|
+
canClearMarks: (_ctx$editor$can$chain6 = ctx.editor.can().chain().unsetAllMarks().run()) !== null && _ctx$editor$can$chain6 !== void 0 ? _ctx$editor$can$chain6 : false,
|
|
170
|
+
isUnderline: (_ctx$editor$isActive6 = ctx.editor.isActive('underline')) !== null && _ctx$editor$isActive6 !== void 0 ? _ctx$editor$isActive6 : false,
|
|
171
|
+
isSubScript: (_ctx$editor$isActive7 = ctx.editor.isActive('subscript')) !== null && _ctx$editor$isActive7 !== void 0 ? _ctx$editor$isActive7 : false,
|
|
172
|
+
isSuperScript: (_ctx$editor$isActive8 = ctx.editor.isActive('superscript')) !== null && _ctx$editor$isActive8 !== void 0 ? _ctx$editor$isActive8 : false,
|
|
173
|
+
isParagraph: (_ctx$editor$isActive9 = ctx.editor.isActive('paragraph')) !== null && _ctx$editor$isActive9 !== void 0 ? _ctx$editor$isActive9 : false,
|
|
174
|
+
isHeading1: (_ctx$editor$isActive10 = ctx.editor.isActive('heading', {
|
|
175
|
+
level: 1
|
|
176
|
+
})) !== null && _ctx$editor$isActive10 !== void 0 ? _ctx$editor$isActive10 : false,
|
|
177
|
+
isHeading2: (_ctx$editor$isActive11 = ctx.editor.isActive('heading', {
|
|
178
|
+
level: 2
|
|
179
|
+
})) !== null && _ctx$editor$isActive11 !== void 0 ? _ctx$editor$isActive11 : false,
|
|
180
|
+
isHeading3: (_ctx$editor$isActive12 = ctx.editor.isActive('heading', {
|
|
181
|
+
level: 3
|
|
182
|
+
})) !== null && _ctx$editor$isActive12 !== void 0 ? _ctx$editor$isActive12 : false,
|
|
183
|
+
isHeading4: (_ctx$editor$isActive13 = ctx.editor.isActive('heading', {
|
|
184
|
+
level: 4
|
|
185
|
+
})) !== null && _ctx$editor$isActive13 !== void 0 ? _ctx$editor$isActive13 : false,
|
|
186
|
+
isHeading5: (_ctx$editor$isActive14 = ctx.editor.isActive('heading', {
|
|
187
|
+
level: 5
|
|
188
|
+
})) !== null && _ctx$editor$isActive14 !== void 0 ? _ctx$editor$isActive14 : false,
|
|
189
|
+
isHeading6: (_ctx$editor$isActive15 = ctx.editor.isActive('heading', {
|
|
190
|
+
level: 6
|
|
191
|
+
})) !== null && _ctx$editor$isActive15 !== void 0 ? _ctx$editor$isActive15 : false,
|
|
192
|
+
isBulletList: (_ctx$editor$isActive16 = ctx.editor.isActive('bulletList')) !== null && _ctx$editor$isActive16 !== void 0 ? _ctx$editor$isActive16 : false,
|
|
193
|
+
isOrderedList: (_ctx$editor$isActive17 = ctx.editor.isActive('orderedList')) !== null && _ctx$editor$isActive17 !== void 0 ? _ctx$editor$isActive17 : false,
|
|
194
|
+
isCodeBlock: (_ctx$editor$isActive18 = ctx.editor.isActive('codeBlock')) !== null && _ctx$editor$isActive18 !== void 0 ? _ctx$editor$isActive18 : false,
|
|
195
|
+
isBlockquote: (_ctx$editor$isActive19 = ctx.editor.isActive('blockquote')) !== null && _ctx$editor$isActive19 !== void 0 ? _ctx$editor$isActive19 : false,
|
|
196
|
+
canUndo: (_ctx$editor$can$chain7 = ctx.editor.can().chain().undo().run()) !== null && _ctx$editor$can$chain7 !== void 0 ? _ctx$editor$can$chain7 : false,
|
|
197
|
+
canRedo: (_ctx$editor$can$chain8 = ctx.editor.can().chain().redo().run()) !== null && _ctx$editor$can$chain8 !== void 0 ? _ctx$editor$can$chain8 : false
|
|
198
|
+
};
|
|
199
|
+
}
|
|
200
|
+
});
|
|
201
|
+
var hasDoneButton = false;
|
|
202
|
+
var autoWidth = false;
|
|
203
|
+
var names = (0, _classnames["default"])(classes.toolbar, _constants.PIE_TOOLBAR__CLASS, (_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.toolbarWithNoDone, !hasDoneButton), (0, _defineProperty2["default"])(_classNames, classes.toolbarTop, toolbarOpts.position === 'top'), (0, _defineProperty2["default"])(_classNames, classes.toolbarRight, toolbarOpts.alignment === 'right'), (0, _defineProperty2["default"])(_classNames, classes.focused, toolbarOpts.alwaysVisible || editorState.isFocused && !editor._toolbarOpened), (0, _defineProperty2["default"])(_classNames, classes.autoWidth, autoWidth), (0, _defineProperty2["default"])(_classNames, classes.fullWidth, !autoWidth), (0, _defineProperty2["default"])(_classNames, classes.hidden, toolbarOpts.isHidden === true), _classNames));
|
|
204
|
+
var customStyles = toolbarOpts.minWidth !== undefined ? {
|
|
205
|
+
minWidth: toolbarOpts.minWidth
|
|
206
|
+
} : {};
|
|
207
|
+
|
|
208
|
+
var handleMouseDown = function handleMouseDown(e) {
|
|
209
|
+
e.preventDefault();
|
|
210
|
+
};
|
|
211
|
+
|
|
212
|
+
var toolbarButtons = (0, _react.useMemo)(function () {
|
|
213
|
+
return [{
|
|
214
|
+
icon: /*#__PURE__*/_react["default"].createElement(_GridOn["default"], null),
|
|
215
|
+
onClick: function onClick(editor) {
|
|
216
|
+
return editor.chain().focus().insertTable({
|
|
217
|
+
rows: 2,
|
|
218
|
+
cols: 2,
|
|
219
|
+
withHeaderRow: false
|
|
220
|
+
}).run();
|
|
221
|
+
},
|
|
222
|
+
hidden: function hidden(state) {
|
|
223
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('table')) || state.isTable;
|
|
224
|
+
},
|
|
225
|
+
isActive: function isActive(state) {
|
|
226
|
+
return state.isTable;
|
|
227
|
+
},
|
|
228
|
+
isDisabled: function isDisabled(state) {
|
|
229
|
+
return !state.canTable;
|
|
230
|
+
}
|
|
231
|
+
}, {
|
|
232
|
+
icon: /*#__PURE__*/_react["default"].createElement(_tableIcons.AddRow, null),
|
|
233
|
+
onClick: function onClick(editor) {
|
|
234
|
+
return editor.chain().focus().addRowAfter().run();
|
|
235
|
+
},
|
|
236
|
+
hidden: function hidden(state) {
|
|
237
|
+
return !state.isTable;
|
|
238
|
+
},
|
|
239
|
+
isActive: function isActive(state) {
|
|
240
|
+
return state.isTable;
|
|
241
|
+
},
|
|
242
|
+
isDisabled: function isDisabled(state) {
|
|
243
|
+
return !state.canTable;
|
|
244
|
+
}
|
|
245
|
+
}, {
|
|
246
|
+
icon: /*#__PURE__*/_react["default"].createElement(_tableIcons.RemoveRow, null),
|
|
247
|
+
onClick: function onClick(editor) {
|
|
248
|
+
return editor.chain().focus().deleteRow().run();
|
|
249
|
+
},
|
|
250
|
+
hidden: function hidden(state) {
|
|
251
|
+
return !state.isTable;
|
|
252
|
+
},
|
|
253
|
+
isActive: function isActive(state) {
|
|
254
|
+
return state.isTable;
|
|
255
|
+
},
|
|
256
|
+
isDisabled: function isDisabled(state) {
|
|
257
|
+
return !state.canTable;
|
|
258
|
+
}
|
|
259
|
+
}, {
|
|
260
|
+
icon: /*#__PURE__*/_react["default"].createElement(_tableIcons.AddColumn, null),
|
|
261
|
+
onClick: function onClick(editor) {
|
|
262
|
+
return editor.chain().focus().addColumnAfter().run();
|
|
263
|
+
},
|
|
264
|
+
hidden: function hidden(state) {
|
|
265
|
+
return !state.isTable;
|
|
266
|
+
},
|
|
267
|
+
isActive: function isActive(state) {
|
|
268
|
+
return state.isTable;
|
|
269
|
+
},
|
|
270
|
+
isDisabled: function isDisabled(state) {
|
|
271
|
+
return !state.canTable;
|
|
272
|
+
}
|
|
273
|
+
}, {
|
|
274
|
+
icon: /*#__PURE__*/_react["default"].createElement(_tableIcons.RemoveColumn, null),
|
|
275
|
+
onClick: function onClick(editor) {
|
|
276
|
+
return editor.chain().focus().deleteColumn().run();
|
|
277
|
+
},
|
|
278
|
+
hidden: function hidden(state) {
|
|
279
|
+
return !state.isTable;
|
|
280
|
+
},
|
|
281
|
+
isActive: function isActive(state) {
|
|
282
|
+
return state.isTable;
|
|
283
|
+
},
|
|
284
|
+
isDisabled: function isDisabled(state) {
|
|
285
|
+
return !state.canTable;
|
|
286
|
+
}
|
|
287
|
+
}, {
|
|
288
|
+
icon: /*#__PURE__*/_react["default"].createElement(_tableIcons.RemoveTable, null),
|
|
289
|
+
onClick: function onClick(editor) {
|
|
290
|
+
return editor.chain().focus().deleteTable().run();
|
|
291
|
+
},
|
|
292
|
+
hidden: function hidden(state) {
|
|
293
|
+
return !state.isTable;
|
|
294
|
+
},
|
|
295
|
+
isActive: function isActive(state) {
|
|
296
|
+
return state.isTable;
|
|
297
|
+
},
|
|
298
|
+
isDisabled: function isDisabled(state) {
|
|
299
|
+
return !state.canTable;
|
|
300
|
+
}
|
|
301
|
+
}, {
|
|
302
|
+
icon: /*#__PURE__*/_react["default"].createElement(_BorderAll["default"], null),
|
|
303
|
+
onClick: function onClick(editor) {
|
|
304
|
+
var tableAttrs = editor.getAttributes('table');
|
|
305
|
+
|
|
306
|
+
var update = _objectSpread(_objectSpread({}, tableAttrs), {}, {
|
|
307
|
+
border: tableAttrs.border !== '0' ? '0' : '1'
|
|
308
|
+
});
|
|
309
|
+
|
|
310
|
+
editor.commands.updateAttributes('table', update);
|
|
311
|
+
},
|
|
312
|
+
hidden: function hidden(state) {
|
|
313
|
+
return !state.isTable;
|
|
314
|
+
},
|
|
315
|
+
isActive: function isActive(state) {
|
|
316
|
+
return state.tableHasBorder;
|
|
317
|
+
},
|
|
318
|
+
isDisabled: function isDisabled(state) {
|
|
319
|
+
return !state.canTable;
|
|
320
|
+
}
|
|
321
|
+
}, {
|
|
322
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatBold["default"], null),
|
|
323
|
+
onClick: function onClick(editor) {
|
|
324
|
+
return editor.chain().focus().toggleBold().run();
|
|
325
|
+
},
|
|
326
|
+
hidden: function hidden(state) {
|
|
327
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('bold')) || state.isTable;
|
|
328
|
+
},
|
|
329
|
+
isActive: function isActive(state) {
|
|
330
|
+
return state.isBold;
|
|
331
|
+
},
|
|
332
|
+
isDisabled: function isDisabled(state) {
|
|
333
|
+
return !state.canBold;
|
|
334
|
+
}
|
|
335
|
+
}, {
|
|
336
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatItalic["default"], null),
|
|
337
|
+
onClick: function onClick(editor) {
|
|
338
|
+
return editor.chain().focus().toggleItalic().run();
|
|
339
|
+
},
|
|
340
|
+
hidden: function hidden(state) {
|
|
341
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('italic')) || state.isTable;
|
|
342
|
+
},
|
|
343
|
+
isActive: function isActive(state) {
|
|
344
|
+
return state.isItalic;
|
|
345
|
+
},
|
|
346
|
+
isDisabled: function isDisabled(state) {
|
|
347
|
+
return !state.canItalic;
|
|
348
|
+
}
|
|
349
|
+
}, {
|
|
350
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatStrikethrough["default"], null),
|
|
351
|
+
onClick: function onClick(editor) {
|
|
352
|
+
return editor.chain().focus().toggleStrike().run();
|
|
353
|
+
},
|
|
354
|
+
hidden: function hidden(state) {
|
|
355
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('strikethrough')) || state.isTable;
|
|
356
|
+
},
|
|
357
|
+
isActive: function isActive(state) {
|
|
358
|
+
return state.isStrike;
|
|
359
|
+
},
|
|
360
|
+
isDisabled: function isDisabled(state) {
|
|
361
|
+
return !state.canStrike;
|
|
362
|
+
}
|
|
363
|
+
}, {
|
|
364
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Code["default"], null),
|
|
365
|
+
onClick: function onClick(editor) {
|
|
366
|
+
return editor.chain().focus().toggleCode().run();
|
|
367
|
+
},
|
|
368
|
+
hidden: function hidden(state) {
|
|
369
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('code')) || state.isTable;
|
|
370
|
+
},
|
|
371
|
+
isActive: function isActive(state) {
|
|
372
|
+
return state.isCode;
|
|
373
|
+
},
|
|
374
|
+
isDisabled: function isDisabled(state) {
|
|
375
|
+
return !state.canCode;
|
|
376
|
+
}
|
|
377
|
+
}, {
|
|
378
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatUnderlined["default"], null),
|
|
379
|
+
onClick: function onClick(editor) {
|
|
380
|
+
return editor.chain().focus().toggleUnderline().run();
|
|
381
|
+
},
|
|
382
|
+
hidden: function hidden(state) {
|
|
383
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('underline')) || state.isTable;
|
|
384
|
+
},
|
|
385
|
+
isActive: function isActive(state) {
|
|
386
|
+
return state.isUnderline;
|
|
387
|
+
}
|
|
388
|
+
}, {
|
|
389
|
+
icon: /*#__PURE__*/_react["default"].createElement(SubscriptIcon, null),
|
|
390
|
+
onClick: function onClick(editor) {
|
|
391
|
+
return editor.chain().focus().toggleSubscript().run();
|
|
392
|
+
},
|
|
393
|
+
hidden: function hidden(state) {
|
|
394
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('subscript')) || state.isTable;
|
|
395
|
+
},
|
|
396
|
+
isActive: function isActive(state) {
|
|
397
|
+
return state.isSubScript;
|
|
398
|
+
}
|
|
399
|
+
}, {
|
|
400
|
+
icon: /*#__PURE__*/_react["default"].createElement(SuperscriptIcon, null),
|
|
401
|
+
onClick: function onClick(editor) {
|
|
402
|
+
return editor.chain().focus().toggleSuperscript().run();
|
|
403
|
+
},
|
|
404
|
+
hidden: function hidden(state) {
|
|
405
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('superscript')) || state.isTable;
|
|
406
|
+
},
|
|
407
|
+
isActive: function isActive(state) {
|
|
408
|
+
return state.isSuperScript;
|
|
409
|
+
}
|
|
410
|
+
}, {
|
|
411
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Image["default"], null),
|
|
412
|
+
hidden: function hidden(state) {
|
|
413
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('image')) || state.isTable;
|
|
414
|
+
},
|
|
415
|
+
onClick: function onClick(editor) {
|
|
416
|
+
return editor.chain().focus().setImageUploadNode().run();
|
|
417
|
+
}
|
|
418
|
+
}, {
|
|
419
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Theaters["default"], null),
|
|
420
|
+
hidden: function hidden(state) {
|
|
421
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('video')) || state.isTable;
|
|
422
|
+
},
|
|
423
|
+
onClick: function onClick(editor) {
|
|
424
|
+
return editor.chain().focus().insertMedia({
|
|
425
|
+
tag: 'video'
|
|
426
|
+
}).run();
|
|
427
|
+
}
|
|
428
|
+
}, {
|
|
429
|
+
icon: /*#__PURE__*/_react["default"].createElement(_VolumeUp["default"], null),
|
|
430
|
+
hidden: function hidden(state) {
|
|
431
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('audio')) || state.isTable;
|
|
432
|
+
},
|
|
433
|
+
onClick: function onClick(editor) {
|
|
434
|
+
return editor.chain().focus().insertMedia({
|
|
435
|
+
tag: 'audio'
|
|
436
|
+
}).run();
|
|
437
|
+
}
|
|
438
|
+
}, {
|
|
439
|
+
icon: /*#__PURE__*/_react["default"].createElement(_CssIcon["default"], null),
|
|
440
|
+
hidden: function hidden(state) {
|
|
441
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('css')) || state.isTable;
|
|
442
|
+
},
|
|
443
|
+
onClick: function onClick(editor) {
|
|
444
|
+
return editor.commands.openCSSClassDialog();
|
|
445
|
+
}
|
|
446
|
+
}, {
|
|
447
|
+
icon: /*#__PURE__*/_react["default"].createElement(HeadingIcon, null),
|
|
448
|
+
hidden: function hidden(state) {
|
|
449
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('h3')) || state.isTable;
|
|
450
|
+
},
|
|
451
|
+
onClick: function onClick(editor) {
|
|
452
|
+
return editor.chain().focus().toggleHeading({
|
|
453
|
+
level: 3
|
|
454
|
+
}).run();
|
|
455
|
+
},
|
|
456
|
+
isActive: function isActive(state) {
|
|
457
|
+
return state.isHeading3;
|
|
458
|
+
}
|
|
459
|
+
}, {
|
|
460
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Functions["default"], null),
|
|
461
|
+
hidden: function hidden() {
|
|
462
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('math'));
|
|
463
|
+
},
|
|
464
|
+
onClick: function onClick(editor) {
|
|
465
|
+
return editor.chain().focus().insertMath('').run();
|
|
466
|
+
}
|
|
467
|
+
}, {
|
|
468
|
+
icon: /*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterIcon, {
|
|
469
|
+
letter: "\xF1"
|
|
470
|
+
}),
|
|
471
|
+
hidden: function hidden(state) {
|
|
472
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('languageCharacters')) || state.isTable;
|
|
473
|
+
},
|
|
474
|
+
onClick: function onClick() {
|
|
475
|
+
return setShowPicker(_characterUtils.spanishConfig);
|
|
476
|
+
}
|
|
477
|
+
}, {
|
|
478
|
+
icon: /*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterIcon, {
|
|
479
|
+
letter: "\u20AC"
|
|
480
|
+
}),
|
|
481
|
+
hidden: function hidden(state) {
|
|
482
|
+
return (activePlugins === null || activePlugins === void 0 ? void 0 : activePlugins.filter(function (p) {
|
|
483
|
+
return p === 'languageCharacters';
|
|
484
|
+
}).length) !== 2 || state.isTable;
|
|
485
|
+
},
|
|
486
|
+
onClick: function onClick() {
|
|
487
|
+
return setShowPicker(_characterUtils.specialConfig);
|
|
488
|
+
}
|
|
489
|
+
}, {
|
|
490
|
+
icon: /*#__PURE__*/_react["default"].createElement(_TextAlign["default"], {
|
|
491
|
+
editor: editor
|
|
492
|
+
}),
|
|
493
|
+
hidden: function hidden(state) {
|
|
494
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('text-align')) || state.isTable;
|
|
495
|
+
},
|
|
496
|
+
onClick: function onClick() {}
|
|
497
|
+
}, {
|
|
498
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatListBulleted["default"], null),
|
|
499
|
+
hidden: function hidden(state) {
|
|
500
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('bulleted-list')) || state.isTable;
|
|
501
|
+
},
|
|
502
|
+
onClick: function onClick(editor) {
|
|
503
|
+
return editor.chain().focus().toggleBulletList().run();
|
|
504
|
+
},
|
|
505
|
+
isActive: function isActive(state) {
|
|
506
|
+
return state.isBulletList;
|
|
507
|
+
}
|
|
508
|
+
}, {
|
|
509
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatListNumbered["default"], null),
|
|
510
|
+
hidden: function hidden(state) {
|
|
511
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('numbered-list')) || state.isTable;
|
|
512
|
+
},
|
|
513
|
+
onClick: function onClick(editor) {
|
|
514
|
+
return editor.chain().focus().toggleOrderedList().run();
|
|
515
|
+
},
|
|
516
|
+
isActive: function isActive(state) {
|
|
517
|
+
return state.isOrderedList;
|
|
518
|
+
}
|
|
519
|
+
}, {
|
|
520
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Undo["default"], null),
|
|
521
|
+
hidden: function hidden(state) {
|
|
522
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('undo')) || state.isTable;
|
|
523
|
+
},
|
|
524
|
+
onClick: function onClick(editor) {
|
|
525
|
+
return editor.chain().focus().undo().run();
|
|
526
|
+
},
|
|
527
|
+
isDisabled: function isDisabled(state) {
|
|
528
|
+
return !state.canUndo;
|
|
529
|
+
}
|
|
530
|
+
}, {
|
|
531
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Redo["default"], null),
|
|
532
|
+
hidden: function hidden(state) {
|
|
533
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('redo')) || state.isTable;
|
|
534
|
+
},
|
|
535
|
+
onClick: function onClick(editor) {
|
|
536
|
+
return editor.chain().focus().redo().run();
|
|
537
|
+
},
|
|
538
|
+
isDisabled: function isDisabled(state) {
|
|
539
|
+
return !state.canRedo;
|
|
540
|
+
}
|
|
541
|
+
}];
|
|
542
|
+
}, [activePlugins, editor]);
|
|
543
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
544
|
+
className: names,
|
|
545
|
+
style: _objectSpread({}, customStyles),
|
|
546
|
+
onMouseDown: handleMouseDown
|
|
547
|
+
}, !editorState.hideDefaultToolbar && /*#__PURE__*/_react["default"].createElement("div", {
|
|
548
|
+
className: classes.defaultToolbar,
|
|
549
|
+
tabIndex: "1"
|
|
550
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
551
|
+
className: classes.buttonsContainer
|
|
552
|
+
}, toolbarButtons.filter(function (btn) {
|
|
553
|
+
var _btn$hidden;
|
|
554
|
+
|
|
555
|
+
return !((_btn$hidden = btn.hidden) !== null && _btn$hidden !== void 0 && _btn$hidden.call(btn, editorState));
|
|
556
|
+
}).map(function (btn, index) {
|
|
557
|
+
var _btn$isDisabled, _btn$isActive;
|
|
558
|
+
|
|
559
|
+
var disabled = (_btn$isDisabled = btn.isDisabled) === null || _btn$isDisabled === void 0 ? void 0 : _btn$isDisabled.call(btn, editorState);
|
|
560
|
+
var active = (_btn$isActive = btn.isActive) === null || _btn$isActive === void 0 ? void 0 : _btn$isActive.call(btn, editorState);
|
|
561
|
+
return /*#__PURE__*/_react["default"].createElement("button", {
|
|
562
|
+
key: index,
|
|
563
|
+
disabled: disabled,
|
|
564
|
+
onClick: function onClick(e) {
|
|
565
|
+
e.preventDefault();
|
|
566
|
+
btn.onClick(editor);
|
|
567
|
+
},
|
|
568
|
+
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, active))
|
|
569
|
+
}, btn.icon);
|
|
570
|
+
})), (activePlugins === null || activePlugins === void 0 ? void 0 : activePlugins.includes('responseArea')) && /*#__PURE__*/_react["default"].createElement("button", {
|
|
571
|
+
onClick: function onClick() {
|
|
572
|
+
editor.chain().focus().insertResponseArea(responseAreaProps.type).run();
|
|
573
|
+
},
|
|
574
|
+
className: classes.button
|
|
575
|
+
}, /*#__PURE__*/_react["default"].createElement(_ToolbarIcon.ToolbarIcon, null)), /*#__PURE__*/_react["default"].createElement(_doneButton.DoneButton, {
|
|
576
|
+
onClick: function onClick() {
|
|
577
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(editor.getHTML());
|
|
578
|
+
editor.commands.blur();
|
|
579
|
+
}
|
|
580
|
+
})), showPicker && /*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
581
|
+
editor: editor,
|
|
582
|
+
opts: _objectSpread(_objectSpread({}, showPicker), {}, {
|
|
583
|
+
renderPopOver: function renderPopOver(ev, ch) {
|
|
584
|
+
return console.log('Show popover', ch);
|
|
585
|
+
},
|
|
586
|
+
closePopOver: function closePopOver() {
|
|
587
|
+
return console.log('Close popover');
|
|
588
|
+
}
|
|
589
|
+
}),
|
|
590
|
+
onClose: function onClose() {
|
|
591
|
+
return setShowPicker(false);
|
|
592
|
+
}
|
|
593
|
+
}));
|
|
594
|
+
}
|
|
595
|
+
|
|
596
|
+
var style = function style(theme) {
|
|
597
|
+
return {
|
|
598
|
+
defaultToolbar: {
|
|
599
|
+
display: 'flex',
|
|
600
|
+
width: '100%',
|
|
601
|
+
justifyContent: 'space-between'
|
|
602
|
+
},
|
|
603
|
+
buttonsContainer: {
|
|
604
|
+
alignItems: 'center',
|
|
605
|
+
display: 'flex',
|
|
606
|
+
width: '100%'
|
|
607
|
+
},
|
|
608
|
+
button: {
|
|
609
|
+
color: 'grey',
|
|
610
|
+
display: 'inline-flex',
|
|
611
|
+
padding: '2px',
|
|
612
|
+
background: 'none',
|
|
613
|
+
border: 'none',
|
|
614
|
+
cursor: 'pointer',
|
|
615
|
+
'&:hover': {
|
|
616
|
+
color: 'black'
|
|
617
|
+
},
|
|
618
|
+
'&:focus': {
|
|
619
|
+
outline: "2px solid ".concat(theme.palette.grey[700])
|
|
620
|
+
}
|
|
621
|
+
},
|
|
622
|
+
active: {
|
|
623
|
+
color: 'black'
|
|
624
|
+
},
|
|
625
|
+
disabled: {
|
|
626
|
+
opacity: 0.7,
|
|
627
|
+
cursor: 'not-allowed',
|
|
628
|
+
'& :hover': {
|
|
629
|
+
color: 'grey'
|
|
630
|
+
}
|
|
631
|
+
},
|
|
632
|
+
isActive: {
|
|
633
|
+
background: 'var(--purple)',
|
|
634
|
+
color: 'var(--white)'
|
|
635
|
+
},
|
|
636
|
+
toolbar: {
|
|
637
|
+
position: 'absolute',
|
|
638
|
+
zIndex: 20,
|
|
639
|
+
cursor: 'pointer',
|
|
640
|
+
justifyContent: 'space-between',
|
|
641
|
+
background: 'var(--editable-html-toolbar-bg, #efefef)',
|
|
642
|
+
minWidth: '280px',
|
|
643
|
+
margin: '5px 0 0 0',
|
|
644
|
+
padding: '2px',
|
|
645
|
+
boxShadow: '0px 1px 5px 0px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 3px 1px -2px rgba(0, 0, 0, 0.12)',
|
|
646
|
+
boxSizing: 'border-box',
|
|
647
|
+
display: 'flex',
|
|
648
|
+
opacity: 0,
|
|
649
|
+
pointerEvents: 'none'
|
|
650
|
+
},
|
|
651
|
+
toolbarWithNoDone: {
|
|
652
|
+
minWidth: '265px'
|
|
653
|
+
},
|
|
654
|
+
toolbarTop: {
|
|
655
|
+
top: '-45px'
|
|
656
|
+
},
|
|
657
|
+
toolbarRight: {
|
|
658
|
+
right: 0
|
|
659
|
+
},
|
|
660
|
+
fullWidth: {
|
|
661
|
+
width: '100%'
|
|
662
|
+
},
|
|
663
|
+
hidden: {
|
|
664
|
+
visibility: 'hidden'
|
|
665
|
+
},
|
|
666
|
+
autoWidth: {
|
|
667
|
+
width: 'auto'
|
|
668
|
+
},
|
|
669
|
+
focused: {
|
|
670
|
+
opacity: 1,
|
|
671
|
+
pointerEvents: 'auto'
|
|
672
|
+
},
|
|
673
|
+
iconRoot: {
|
|
674
|
+
width: '28px',
|
|
675
|
+
height: '28px',
|
|
676
|
+
padding: '4px',
|
|
677
|
+
verticalAlign: 'top'
|
|
678
|
+
},
|
|
679
|
+
label: {
|
|
680
|
+
color: 'var(--editable-html-toolbar-check, #00bb00)'
|
|
681
|
+
},
|
|
682
|
+
shared: {
|
|
683
|
+
display: 'flex'
|
|
684
|
+
}
|
|
685
|
+
};
|
|
686
|
+
};
|
|
687
|
+
|
|
688
|
+
var StyledMenuBar = (0, _styles.withStyles)(style, {
|
|
689
|
+
index: 1000
|
|
690
|
+
})(MenuBar);
|
|
691
|
+
var _default = StyledMenuBar;
|
|
692
|
+
exports["default"] = _default;
|
|
693
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/MenuBar.jsx"],"names":["SuperscriptIcon","SubscriptIcon","HeadingIcon","width","height","MenuBar","editor","classes","activePlugins","toolOpts","toolbarOpts","responseAreaProps","onChange","showPicker","setShowPicker","editorState","selector","ctx","state","selection","currentNode","NodeSelection","node","hideDefaultToolbar","isActive","isFocused","isBold","canBold","can","chain","toggleBold","run","isTable","tableHasBorder","getAttributes","border","canTable","insertTable","isItalic","canItalic","toggleItalic","isStrike","canStrike","toggleStrike","isCode","canCode","toggleCode","canClearMarks","unsetAllMarks","isUnderline","isSubScript","isSuperScript","isParagraph","isHeading1","level","isHeading2","isHeading3","isHeading4","isHeading5","isHeading6","isBulletList","isOrderedList","isCodeBlock","isBlockquote","canUndo","undo","canRedo","redo","hasDoneButton","autoWidth","names","toolbar","PIE_TOOLBAR__CLASS","toolbarWithNoDone","toolbarTop","position","toolbarRight","alignment","focused","alwaysVisible","_toolbarOpened","fullWidth","hidden","isHidden","customStyles","minWidth","undefined","handleMouseDown","e","preventDefault","toolbarButtons","icon","onClick","focus","rows","cols","withHeaderRow","includes","isDisabled","addRowAfter","deleteRow","addColumnAfter","deleteColumn","deleteTable","tableAttrs","update","commands","updateAttributes","toggleUnderline","toggleSubscript","toggleSuperscript","setImageUploadNode","insertMedia","tag","openCSSClassDialog","toggleHeading","insertMath","spanishConfig","filter","p","length","specialConfig","toggleBulletList","toggleOrderedList","defaultToolbar","buttonsContainer","btn","map","index","disabled","active","button","insertResponseArea","type","getHTML","blur","renderPopOver","ev","ch","console","log","closePopOver","style","theme","display","justifyContent","alignItems","color","padding","background","cursor","outline","palette","grey","opacity","zIndex","margin","boxShadow","boxSizing","pointerEvents","top","right","visibility","iconRoot","verticalAlign","label","shared","StyledMenuBar"],"mappings":"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","sourcesContent":["import React, { useMemo, useState } from 'react';\nimport classNames from 'classnames';\nimport { withStyles } from '@material-ui/core/styles';\nimport { NodeSelection } from 'prosemirror-state';\n\nimport Bold from '@material-ui/icons/FormatBold';\nimport Italic from '@material-ui/icons/FormatItalic';\nimport Strikethrough from '@material-ui/icons/FormatStrikethrough';\nimport Code from '@material-ui/icons/Code';\nimport GridOn from '@material-ui/icons/GridOn';\nimport BulletedListIcon from '@material-ui/icons/FormatListBulleted';\nimport NumberedListIcon from '@material-ui/icons/FormatListNumbered';\nimport Underline from '@material-ui/icons/FormatUnderlined';\nimport Functions from '@material-ui/icons/Functions';\nimport ImageIcon from '@material-ui/icons/Image';\nimport Redo from '@material-ui/icons/Redo';\nimport Undo from '@material-ui/icons/Undo';\nimport TheatersIcon from '@material-ui/icons/Theaters';\nimport VolumeUpIcon from '@material-ui/icons/VolumeUp';\nimport BorderAll from '@material-ui/icons/BorderAll';\n\nimport { EditorContent, useEditorState } from '@tiptap/react';\n\nimport { PIE_TOOLBAR__CLASS } from '../constants';\nimport { ToolbarIcon } from './respArea/ToolbarIcon';\nimport { spanishConfig, specialConfig } from './characters/characterUtils';\nimport TextAlignIcon from './icons/TextAlign';\nimport CSSIcon from './icons/CssIcon';\nimport { AddColumn, AddRow, RemoveColumn, RemoveRow, RemoveTable } from './icons/tableIcons';\n\nimport { CharacterIcon, CharacterPicker } from './CharacterPicker';\nimport { DoneButton } from './common/done-button';\n\nconst SuperscriptIcon = () => (\n  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"none\">\n    <path\n      d=\"M22,7h-2v1h3v1h-4V7c0-0.55,0.45-1,1-1h2V5h-3V4h3c0.55,0,1,0.45,1,1v1C23,6.55,22.55,7,22,7z M5.88,20h2.66l3.4-5.42h0.12 l3.4,5.42h2.66l-4.65-7.27L17.81,6h-2.68l-3.07,4.99h-0.12L8.85,6H6.19l4.32,6.73L5.88,20z\"\n      fill=\"currentColor\"\n    />\n  </svg>\n);\n\nconst SubscriptIcon = () => (\n  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"none\">\n    <path\n      d=\"M22,18h-2v1h3v1h-4v-2c0-0.55,0.45-1,1-1h2v-1h-3v-1h3c0.55,0,1,0.45,1,1v1C23,17.55,22.55,18,22,18z M5.88,18h2.66 l3.4-5.42h0.12l3.4,5.42h2.66l-4.65-7.27L17.81,4h-2.68l-3.07,4.99h-0.12L8.85,4H6.19l4.32,6.73L5.88,18z\"\n      fill=\"currentColor\"\n    />\n  </svg>\n);\n\nconst HeadingIcon = () => (\n  <svg\n    width=\"30\"\n    height=\"28\"\n    viewBox=\"0 0 30 28\"\n    fill=\"none\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n    style={{ width: '20px', height: '18px' }}\n  >\n    <path\n      d=\"M27 4V24H29C29.5 24 30 24.5 30 25V27C30 27.5625 29.5 28 29 28H19C18.4375 28 18 27.5625 18 27V25C18 24.5 18.4375 24 19 24H21V16H9V24H11C11.5 24 12 24.5 12 25V27C12 27.5625 11.5 28 11 28H1C0.4375 28 0 27.5625 0 27V25C0 24.5 0.4375 24 1 24H3V4H1C0.4375 4 0 3.5625 0 3V1C0 0.5 0.4375 0 1 0H11C11.5 0 12 0.5 12 1V3C12 3.5625 11.5 4 11 4H9V12H21V4H19C18.4375 4 18 3.5625 18 3V1C18 0.5 18.4375 0 19 0H29C29.5 0 30 0.5 30 1V3C30 3.5625 29.5 4 29 4H27Z\"\n      fill=\"currentColor\"\n    />\n  </svg>\n);\n\nfunction MenuBar({ editor, classes, activePlugins, toolbarOpts: toolOpts, responseAreaProps, onChange }) {\n  const [showPicker, setShowPicker] = useState(false);\n  const toolbarOpts = toolOpts ?? {};\n\n  const editorState = useEditorState({\n    editor,\n    selector: (ctx) => {\n      const { selection } = ctx.editor?.state || {};\n\n      let currentNode;\n\n      if (selection instanceof NodeSelection) {\n        currentNode = selection.node; // the selected node\n      }\n\n      const hideDefaultToolbar =\n        ctx.editor?.isActive('math') ||\n        ctx.editor?.isActive('explicit_constructed_response') ||\n        ctx.editor?.isActive('imageUploadNode');\n\n      return {\n        currentNode,\n        hideDefaultToolbar,\n        isFocused: ctx.editor?.isFocused,\n        isBold: ctx.editor.isActive('bold') ?? false,\n        canBold:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleBold()\n            .run() ?? false,\n        isTable: ctx.editor.isActive('table') ?? false,\n        tableHasBorder: ctx.editor.getAttributes('table')?.border === '1' ?? false,\n        canTable:\n          ctx.editor\n            .can()\n            .chain()\n            .insertTable()\n            .run() ?? false,\n        isItalic: ctx.editor.isActive('italic') ?? false,\n        canItalic:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleItalic()\n            .run() ?? false,\n        isStrike: ctx.editor.isActive('strike') ?? false,\n        canStrike:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleStrike()\n            .run() ?? false,\n        isCode: ctx.editor.isActive('code') ?? false,\n        canCode:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleCode()\n            .run() ?? false,\n        canClearMarks:\n          ctx.editor\n            .can()\n            .chain()\n            .unsetAllMarks()\n            .run() ?? false,\n        isUnderline: ctx.editor.isActive('underline') ?? false,\n        isSubScript: ctx.editor.isActive('subscript') ?? false,\n        isSuperScript: ctx.editor.isActive('superscript') ?? false,\n        isParagraph: ctx.editor.isActive('paragraph') ?? false,\n        isHeading1: ctx.editor.isActive('heading', { level: 1 }) ?? false,\n        isHeading2: ctx.editor.isActive('heading', { level: 2 }) ?? false,\n        isHeading3: ctx.editor.isActive('heading', { level: 3 }) ?? false,\n        isHeading4: ctx.editor.isActive('heading', { level: 4 }) ?? false,\n        isHeading5: ctx.editor.isActive('heading', { level: 5 }) ?? false,\n        isHeading6: ctx.editor.isActive('heading', { level: 6 }) ?? false,\n        isBulletList: ctx.editor.isActive('bulletList') ?? false,\n        isOrderedList: ctx.editor.isActive('orderedList') ?? false,\n        isCodeBlock: ctx.editor.isActive('codeBlock') ?? false,\n        isBlockquote: ctx.editor.isActive('blockquote') ?? false,\n        canUndo:\n          ctx.editor\n            .can()\n            .chain()\n            .undo()\n            .run() ?? false,\n        canRedo:\n          ctx.editor\n            .can()\n            .chain()\n            .redo()\n            .run() ?? false,\n      };\n    },\n  });\n\n  const hasDoneButton = false;\n  const autoWidth = false;\n\n  const names = classNames(classes.toolbar, PIE_TOOLBAR__CLASS, {\n    [classes.toolbarWithNoDone]: !hasDoneButton,\n    [classes.toolbarTop]: toolbarOpts.position === 'top',\n    [classes.toolbarRight]: toolbarOpts.alignment === 'right',\n    [classes.focused]: toolbarOpts.alwaysVisible || (editorState.isFocused && !editor._toolbarOpened),\n    [classes.autoWidth]: autoWidth,\n    [classes.fullWidth]: !autoWidth,\n    [classes.hidden]: toolbarOpts.isHidden === true,\n  });\n\n  const customStyles = toolbarOpts.minWidth !== undefined ? { minWidth: toolbarOpts.minWidth } : {};\n\n  const handleMouseDown = (e) => {\n    e.preventDefault();\n  };\n\n  const toolbarButtons = useMemo(\n    () => [\n      {\n        icon: <GridOn />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .insertTable({ rows: 2, cols: 2, withHeaderRow: false })\n            .run(),\n        hidden: (state) => !activePlugins?.includes('table') || state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <AddRow />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .addRowAfter()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <RemoveRow />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .deleteRow()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <AddColumn />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .addColumnAfter()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <RemoveColumn />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .deleteColumn()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <RemoveTable />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .deleteTable()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <BorderAll />,\n        onClick: (editor) => {\n          const tableAttrs = editor.getAttributes('table');\n\n          const update = {\n            ...tableAttrs,\n            border: tableAttrs.border !== '0' ? '0' : '1',\n          };\n\n          editor.commands.updateAttributes('table', update);\n        },\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.tableHasBorder,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <Bold />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleBold()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('bold') || state.isTable,\n        isActive: (state) => state.isBold,\n        isDisabled: (state) => !state.canBold,\n      },\n      {\n        icon: <Italic />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleItalic()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('italic') || state.isTable,\n        isActive: (state) => state.isItalic,\n        isDisabled: (state) => !state.canItalic,\n      },\n      {\n        icon: <Strikethrough />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleStrike()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('strikethrough') || state.isTable,\n        isActive: (state) => state.isStrike,\n        isDisabled: (state) => !state.canStrike,\n      },\n      {\n        icon: <Code />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleCode()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('code') || state.isTable,\n        isActive: (state) => state.isCode,\n        isDisabled: (state) => !state.canCode,\n      },\n      {\n        icon: <Underline />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleUnderline()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('underline') || state.isTable,\n        isActive: (state) => state.isUnderline,\n      },\n      {\n        icon: <SubscriptIcon />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleSubscript()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('subscript') || state.isTable,\n        isActive: (state) => state.isSubScript,\n      },\n      {\n        icon: <SuperscriptIcon />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleSuperscript()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('superscript') || state.isTable,\n        isActive: (state) => state.isSuperScript,\n      },\n      {\n        icon: <ImageIcon />,\n        hidden: (state) => !activePlugins?.includes('image') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .setImageUploadNode()\n            .run(),\n      },\n      {\n        icon: <TheatersIcon />,\n        hidden: (state) => !activePlugins?.includes('video') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .insertMedia({ tag: 'video' })\n            .run(),\n      },\n      {\n        icon: <VolumeUpIcon />,\n        hidden: (state) => !activePlugins?.includes('audio') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .insertMedia({ tag: 'audio' })\n            .run(),\n      },\n      {\n        icon: <CSSIcon />,\n        hidden: (state) => !activePlugins?.includes('css') || state.isTable,\n        onClick: (editor) => editor.commands.openCSSClassDialog(),\n      },\n      {\n        icon: <HeadingIcon />,\n        hidden: (state) => !activePlugins?.includes('h3') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleHeading({ level: 3 })\n            .run(),\n        isActive: (state) => state.isHeading3,\n      },\n      {\n        icon: <Functions />,\n        hidden: () => !activePlugins?.includes('math'),\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .insertMath('')\n            .run(),\n      },\n      {\n        icon: <CharacterIcon letter=\"ñ\" />,\n        hidden: (state) => !activePlugins?.includes('languageCharacters') || state.isTable,\n        onClick: () => setShowPicker(spanishConfig),\n      },\n      {\n        icon: <CharacterIcon letter=\"€\" />,\n        hidden: (state) => activePlugins?.filter((p) => p === 'languageCharacters').length !== 2 || state.isTable,\n        onClick: () => setShowPicker(specialConfig),\n      },\n      {\n        icon: <TextAlignIcon editor={editor} />,\n        hidden: (state) => !activePlugins?.includes('text-align') || state.isTable,\n        onClick: () => {},\n      },\n      {\n        icon: <BulletedListIcon />,\n        hidden: (state) => !activePlugins?.includes('bulleted-list') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleBulletList()\n            .run(),\n        isActive: (state) => state.isBulletList,\n      },\n      {\n        icon: <NumberedListIcon />,\n        hidden: (state) => !activePlugins?.includes('numbered-list') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleOrderedList()\n            .run(),\n        isActive: (state) => state.isOrderedList,\n      },\n      {\n        icon: <Undo />,\n        hidden: (state) => !activePlugins?.includes('undo') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .undo()\n            .run(),\n        isDisabled: (state) => !state.canUndo,\n      },\n      {\n        icon: <Redo />,\n        hidden: (state) => !activePlugins?.includes('redo') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .redo()\n            .run(),\n        isDisabled: (state) => !state.canRedo,\n      },\n    ],\n    [activePlugins, editor],\n  );\n\n  return (\n    <div className={names} style={{ ...customStyles }} onMouseDown={handleMouseDown}>\n      {!editorState.hideDefaultToolbar && (\n        <div className={classes.defaultToolbar} tabIndex=\"1\">\n          <div className={classes.buttonsContainer}>\n            {toolbarButtons\n              .filter((btn) => !btn.hidden?.(editorState))\n              .map((btn, index) => {\n                const disabled = btn.isDisabled?.(editorState);\n                const active = btn.isActive?.(editorState);\n\n                return (\n                  <button\n                    key={index}\n                    disabled={disabled}\n                    onClick={(e) => {\n                      e.preventDefault();\n                      btn.onClick(editor);\n                    }}\n                    className={classNames(classes.button, { [classes.active]: active })}\n                  >\n                    {btn.icon}\n                  </button>\n                );\n              })}\n          </div>\n          {activePlugins?.includes('responseArea') && (\n            <button\n              onClick={() => {\n                editor\n                  .chain()\n                  .focus()\n                  .insertResponseArea(responseAreaProps.type)\n                  .run();\n              }}\n              className={classes.button}\n            >\n              <ToolbarIcon />\n            </button>\n          )}\n\n          <DoneButton\n            onClick={() => {\n              onChange?.(editor.getHTML());\n              editor.commands.blur();\n            }}\n          />\n        </div>\n      )}\n      {showPicker && (\n        <CharacterPicker\n          editor={editor}\n          opts={{\n            ...showPicker,\n            renderPopOver: (ev, ch) => console.log('Show popover', ch),\n            closePopOver: () => console.log('Close popover'),\n          }}\n          onClose={() => setShowPicker(false)}\n        />\n      )}\n    </div>\n  );\n}\n\nconst style = (theme) => ({\n  defaultToolbar: {\n    display: 'flex',\n    width: '100%',\n    justifyContent: 'space-between',\n  },\n  buttonsContainer: {\n    alignItems: 'center',\n    display: 'flex',\n    width: '100%',\n  },\n  button: {\n    color: 'grey',\n    display: 'inline-flex',\n    padding: '2px',\n    background: 'none',\n    border: 'none',\n    cursor: 'pointer',\n    '&:hover': {\n      color: 'black',\n    },\n    '&:focus': {\n      outline: `2px solid ${theme.palette.grey[700]}`,\n    },\n  },\n  active: {\n    color: 'black',\n  },\n  disabled: {\n    opacity: 0.7,\n    cursor: 'not-allowed',\n    '& :hover': {\n      color: 'grey',\n    },\n  },\n  isActive: {\n    background: 'var(--purple)',\n    color: 'var(--white)',\n  },\n  toolbar: {\n    position: 'absolute',\n    zIndex: 20,\n    cursor: 'pointer',\n    justifyContent: 'space-between',\n    background: 'var(--editable-html-toolbar-bg, #efefef)',\n    minWidth: '280px',\n    margin: '5px 0 0 0',\n    padding: '2px',\n    boxShadow:\n      '0px 1px 5px 0px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 3px 1px -2px rgba(0, 0, 0, 0.12)',\n    boxSizing: 'border-box',\n    display: 'flex',\n    opacity: 0,\n    pointerEvents: 'none',\n  },\n  toolbarWithNoDone: {\n    minWidth: '265px',\n  },\n  toolbarTop: {\n    top: '-45px',\n  },\n  toolbarRight: {\n    right: 0,\n  },\n  fullWidth: {\n    width: '100%',\n  },\n  hidden: {\n    visibility: 'hidden',\n  },\n  autoWidth: {\n    width: 'auto',\n  },\n  focused: {\n    opacity: 1,\n    pointerEvents: 'auto',\n  },\n  iconRoot: {\n    width: '28px',\n    height: '28px',\n    padding: '4px',\n    verticalAlign: 'top',\n  },\n  label: {\n    color: 'var(--editable-html-toolbar-check, #00bb00)',\n  },\n  shared: {\n    display: 'flex',\n  },\n});\n\nconst StyledMenuBar = withStyles(style, { index: 1000 })(MenuBar);\n\nexport default StyledMenuBar;\n"]}
|