@pie-lib/editable-html 12.1.0-next.2 → 12.1.0-next.5

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 (103) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/lib/block-tags.js +24 -0
  3. package/lib/block-tags.js.map +1 -0
  4. package/lib/constants.js +11 -0
  5. package/lib/constants.js.map +1 -0
  6. package/lib/editor.js +1224 -0
  7. package/lib/editor.js.map +1 -0
  8. package/lib/index.js +208 -0
  9. package/lib/index.js.map +1 -0
  10. package/lib/parse-html.js +16 -0
  11. package/lib/parse-html.js.map +1 -0
  12. package/lib/plugins/characters/custom-popper.js +57 -0
  13. package/lib/plugins/characters/custom-popper.js.map +1 -0
  14. package/lib/plugins/characters/index.js +265 -0
  15. package/lib/plugins/characters/index.js.map +1 -0
  16. package/lib/plugins/characters/utils.js +378 -0
  17. package/lib/plugins/characters/utils.js.map +1 -0
  18. package/lib/plugins/css/icons/index.js +25 -0
  19. package/lib/plugins/css/icons/index.js.map +1 -0
  20. package/lib/plugins/css/index.js +338 -0
  21. package/lib/plugins/css/index.js.map +1 -0
  22. package/lib/plugins/customPlugin/index.js +98 -0
  23. package/lib/plugins/customPlugin/index.js.map +1 -0
  24. package/lib/plugins/html/icons/index.js +30 -0
  25. package/lib/plugins/html/icons/index.js.map +1 -0
  26. package/lib/plugins/html/index.js +71 -0
  27. package/lib/plugins/html/index.js.map +1 -0
  28. package/lib/plugins/image/alt-dialog.js +100 -0
  29. package/lib/plugins/image/alt-dialog.js.map +1 -0
  30. package/lib/plugins/image/component.js +343 -0
  31. package/lib/plugins/image/component.js.map +1 -0
  32. package/lib/plugins/image/image-toolbar.js +137 -0
  33. package/lib/plugins/image/image-toolbar.js.map +1 -0
  34. package/lib/plugins/image/index.js +223 -0
  35. package/lib/plugins/image/index.js.map +1 -0
  36. package/lib/plugins/image/insert-image-handler.js +140 -0
  37. package/lib/plugins/image/insert-image-handler.js.map +1 -0
  38. package/lib/plugins/index.js +342 -0
  39. package/lib/plugins/index.js.map +1 -0
  40. package/lib/plugins/list/index.js +288 -0
  41. package/lib/plugins/list/index.js.map +1 -0
  42. package/lib/plugins/math/index.js +402 -0
  43. package/lib/plugins/math/index.js.map +1 -0
  44. package/lib/plugins/media/index.js +330 -0
  45. package/lib/plugins/media/index.js.map +1 -0
  46. package/lib/plugins/media/media-dialog.js +594 -0
  47. package/lib/plugins/media/media-dialog.js.map +1 -0
  48. package/lib/plugins/media/media-toolbar.js +76 -0
  49. package/lib/plugins/media/media-toolbar.js.map +1 -0
  50. package/lib/plugins/media/media-wrapper.js +64 -0
  51. package/lib/plugins/media/media-wrapper.js.map +1 -0
  52. package/lib/plugins/rendering/index.js +36 -0
  53. package/lib/plugins/rendering/index.js.map +1 -0
  54. package/lib/plugins/respArea/drag-in-the-blank/choice.js +271 -0
  55. package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -0
  56. package/lib/plugins/respArea/drag-in-the-blank/index.js +55 -0
  57. package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -0
  58. package/lib/plugins/respArea/drag-in-the-blank/utils.js +38 -0
  59. package/lib/plugins/respArea/drag-in-the-blank/utils.js.map +1 -0
  60. package/lib/plugins/respArea/explicit-constructed-response/index.js +50 -0
  61. package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -0
  62. package/lib/plugins/respArea/icons/index.js +72 -0
  63. package/lib/plugins/respArea/icons/index.js.map +1 -0
  64. package/lib/plugins/respArea/index.js +287 -0
  65. package/lib/plugins/respArea/index.js.map +1 -0
  66. package/lib/plugins/respArea/inline-dropdown/index.js +67 -0
  67. package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -0
  68. package/lib/plugins/respArea/math-templated/index.js +112 -0
  69. package/lib/plugins/respArea/math-templated/index.js.map +1 -0
  70. package/lib/plugins/respArea/utils.js +95 -0
  71. package/lib/plugins/respArea/utils.js.map +1 -0
  72. package/lib/plugins/table/CustomTablePlugin.js +116 -0
  73. package/lib/plugins/table/CustomTablePlugin.js.map +1 -0
  74. package/lib/plugins/table/icons/index.js +55 -0
  75. package/lib/plugins/table/icons/index.js.map +1 -0
  76. package/lib/plugins/table/index.js +413 -0
  77. package/lib/plugins/table/index.js.map +1 -0
  78. package/lib/plugins/table/table-toolbar.js +138 -0
  79. package/lib/plugins/table/table-toolbar.js.map +1 -0
  80. package/lib/plugins/textAlign/icons/index.js +187 -0
  81. package/lib/plugins/textAlign/icons/index.js.map +1 -0
  82. package/lib/plugins/textAlign/index.js +26 -0
  83. package/lib/plugins/textAlign/index.js.map +1 -0
  84. package/lib/plugins/toolbar/default-toolbar.js +180 -0
  85. package/lib/plugins/toolbar/default-toolbar.js.map +1 -0
  86. package/lib/plugins/toolbar/done-button.js +35 -0
  87. package/lib/plugins/toolbar/done-button.js.map +1 -0
  88. package/lib/plugins/toolbar/editor-and-toolbar.js +258 -0
  89. package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -0
  90. package/lib/plugins/toolbar/index.js +29 -0
  91. package/lib/plugins/toolbar/index.js.map +1 -0
  92. package/lib/plugins/toolbar/toolbar-buttons.js +145 -0
  93. package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -0
  94. package/lib/plugins/toolbar/toolbar.js +307 -0
  95. package/lib/plugins/toolbar/toolbar.js.map +1 -0
  96. package/lib/plugins/utils.js +42 -0
  97. package/lib/plugins/utils.js.map +1 -0
  98. package/lib/serialization.js +571 -0
  99. package/lib/serialization.js.map +1 -0
  100. package/lib/shared/alert-dialog.js +68 -0
  101. package/lib/theme.js +8 -0
  102. package/lib/theme.js.map +1 -0
  103. package/package.json +7 -7
@@ -0,0 +1,187 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = exports.AlignRight = exports.AlignLeft = exports.AlignJustify = exports.AlignCenter = void 0;
9
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ var _propTypes = _interopRequireDefault(require("prop-types"));
13
+ var _Collapse = _interopRequireDefault(require("@mui/material/Collapse"));
14
+ var _List = _interopRequireDefault(require("@mui/material/List"));
15
+ var _ListItem = _interopRequireDefault(require("@mui/material/ListItem"));
16
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
17
+ 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
+ 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) { (0, _defineProperty2["default"])(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
+ var AlignLeft = exports.AlignLeft = function AlignLeft() {
20
+ return /*#__PURE__*/_react["default"].createElement("svg", {
21
+ width: "20",
22
+ height: "20",
23
+ viewBox: "0 0 66 66",
24
+ fill: "none",
25
+ xmlns: "http://www.w3.org/2000/svg"
26
+ }, /*#__PURE__*/_react["default"].createElement("path", {
27
+ d: "M42.1875 4.75C42.1875 7.38672 39.9902 9.4375 37.5 9.4375H4.6875C2.05078 9.4375 0 7.38672 0 4.75C0 2.25977 2.05078 0.0625 4.6875 0.0625H37.5C39.9902 0.0625 42.1875 2.25977 42.1875 4.75ZM42.1875 42.25C42.1875 44.8867 39.9902 46.9375 37.5 46.9375H4.6875C2.05078 46.9375 0 44.8867 0 42.25C0 39.7598 2.05078 37.5625 4.6875 37.5625H37.5C39.9902 37.5625 42.1875 39.7598 42.1875 42.25ZM0 23.5C0 21.0098 2.05078 18.8125 4.6875 18.8125H60.9375C63.4277 18.8125 65.625 21.0098 65.625 23.5C65.625 26.1367 63.4277 28.1875 60.9375 28.1875H4.6875C2.05078 28.1875 0 26.1367 0 23.5ZM65.625 61C65.625 63.6367 63.4277 65.6875 60.9375 65.6875H4.6875C2.05078 65.6875 0 63.6367 0 61C0 58.5098 2.05078 56.3125 4.6875 56.3125H60.9375C63.4277 56.3125 65.625 58.5098 65.625 61Z",
28
+ fill: "currentColor"
29
+ }));
30
+ };
31
+ var AlignRight = exports.AlignRight = function AlignRight() {
32
+ return /*#__PURE__*/_react["default"].createElement("svg", {
33
+ width: "20",
34
+ height: "20",
35
+ viewBox: "0 0 66 66",
36
+ fill: "none",
37
+ xmlns: "http://www.w3.org/2000/svg"
38
+ }, /*#__PURE__*/_react["default"].createElement("path", {
39
+ d: "M65.625 4.75C65.625 7.38672 63.4277 9.4375 60.9375 9.4375H28.125C25.4883 9.4375 23.4375 7.38672 23.4375 4.75C23.4375 2.25977 25.4883 0.0625 28.125 0.0625H60.9375C63.4277 0.0625 65.625 2.25977 65.625 4.75ZM65.625 42.25C65.625 44.8867 63.4277 46.9375 60.9375 46.9375H28.125C25.4883 46.9375 23.4375 44.8867 23.4375 42.25C23.4375 39.7598 25.4883 37.5625 28.125 37.5625H60.9375C63.4277 37.5625 65.625 39.7598 65.625 42.25ZM0 23.5C0 21.0098 2.05078 18.8125 4.6875 18.8125H60.9375C63.4277 18.8125 65.625 21.0098 65.625 23.5C65.625 26.1367 63.4277 28.1875 60.9375 28.1875H4.6875C2.05078 28.1875 0 26.1367 0 23.5ZM65.625 61C65.625 63.6367 63.4277 65.6875 60.9375 65.6875H4.6875C2.05078 65.6875 0 63.6367 0 61C0 58.5098 2.05078 56.3125 4.6875 56.3125H60.9375C63.4277 56.3125 65.625 58.5098 65.625 61Z",
40
+ fill: "currentColor"
41
+ }));
42
+ };
43
+ var AlignCenter = exports.AlignCenter = function AlignCenter() {
44
+ return /*#__PURE__*/_react["default"].createElement("svg", {
45
+ width: "20",
46
+ height: "20",
47
+ viewBox: "0 0 66 66",
48
+ fill: "none",
49
+ xmlns: "http://www.w3.org/2000/svg"
50
+ }, /*#__PURE__*/_react["default"].createElement("path", {
51
+ d: "M51.5625 4.75C51.5625 7.38672 49.3652 9.4375 46.875 9.4375H18.75C16.1133 9.4375 14.0625 7.38672 14.0625 4.75C14.0625 2.25977 16.1133 0.0625 18.75 0.0625H46.875C49.3652 0.0625 51.5625 2.25977 51.5625 4.75ZM65.625 23.5C65.625 26.1367 63.4277 28.1875 60.9375 28.1875H4.6875C2.05078 28.1875 0 26.1367 0 23.5C0 21.0098 2.05078 18.8125 4.6875 18.8125H60.9375C63.4277 18.8125 65.625 21.0098 65.625 23.5ZM0 61C0 58.5098 2.05078 56.3125 4.6875 56.3125H60.9375C63.4277 56.3125 65.625 58.5098 65.625 61C65.625 63.6367 63.4277 65.6875 60.9375 65.6875H4.6875C2.05078 65.6875 0 63.6367 0 61ZM51.5625 42.25C51.5625 44.8867 49.3652 46.9375 46.875 46.9375H18.75C16.1133 46.9375 14.0625 44.8867 14.0625 42.25C14.0625 39.7598 16.1133 37.5625 18.75 37.5625H46.875C49.3652 37.5625 51.5625 39.7598 51.5625 42.25Z",
52
+ fill: "currentColor"
53
+ }));
54
+ };
55
+ var AlignJustify = exports.AlignJustify = function AlignJustify() {
56
+ return /*#__PURE__*/_react["default"].createElement("svg", {
57
+ width: "20",
58
+ height: "20",
59
+ viewBox: "0 0 66 66",
60
+ fill: "none",
61
+ xmlns: "http://www.w3.org/2000/svg"
62
+ }, /*#__PURE__*/_react["default"].createElement("path", {
63
+ d: "M65.625 4.75C65.625 7.38672 63.4277 9.4375 60.9375 9.4375H4.6875C2.05078 9.4375 0 7.38672 0 4.75C0 2.25977 2.05078 0.0625 4.6875 0.0625H60.9375C63.4277 0.0625 65.625 2.25977 65.625 4.75ZM65.625 42.25C65.625 44.8867 63.4277 46.9375 60.9375 46.9375H4.6875C2.05078 46.9375 0 44.8867 0 42.25C0 39.7598 2.05078 37.5625 4.6875 37.5625H60.9375C63.4277 37.5625 65.625 39.7598 65.625 42.25ZM0 23.5C0 21.0098 2.05078 18.8125 4.6875 18.8125H60.9375C63.4277 18.8125 65.625 21.0098 65.625 23.5C65.625 26.1367 63.4277 28.1875 60.9375 28.1875H4.6875C2.05078 28.1875 0 26.1367 0 23.5ZM65.625 61C65.625 63.6367 63.4277 65.6875 60.9375 65.6875H4.6875C2.05078 65.6875 0 63.6367 0 61C0 58.5098 2.05078 56.3125 4.6875 56.3125H60.9375C63.4277 56.3125 65.625 58.5098 65.625 61Z",
64
+ fill: "currentColor"
65
+ }));
66
+ };
67
+ var TextAlignIcon = function TextAlignIcon(_ref) {
68
+ var getValue = _ref.getValue,
69
+ onChange = _ref.onChange;
70
+ var _useState = (0, _react.useState)(false),
71
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
72
+ open = _useState2[0],
73
+ setOpen = _useState2[1];
74
+ var value = getValue();
75
+ var text = value.texts.get(0);
76
+ var type;
77
+ if (text) {
78
+ var _data$attributes;
79
+ var blockParent = value.document.getParent(text.key);
80
+ var data = blockParent.data.toJSON();
81
+ if (data !== null && data !== void 0 && (_data$attributes = data.attributes) !== null && _data$attributes !== void 0 && _data$attributes.align) {
82
+ var _data$attributes2;
83
+ type = data === null || data === void 0 || (_data$attributes2 = data.attributes) === null || _data$attributes2 === void 0 ? void 0 : _data$attributes2.align;
84
+ }
85
+ }
86
+ var icon;
87
+ switch (type) {
88
+ case 'right':
89
+ icon = /*#__PURE__*/_react["default"].createElement(AlignRight, null);
90
+ break;
91
+ case 'center':
92
+ icon = /*#__PURE__*/_react["default"].createElement(AlignCenter, null);
93
+ break;
94
+ case 'justify':
95
+ icon = /*#__PURE__*/_react["default"].createElement(AlignJustify, null);
96
+ break;
97
+ default:
98
+ icon = /*#__PURE__*/_react["default"].createElement(AlignLeft, null);
99
+ break;
100
+ }
101
+ var applyAlignment = function applyAlignment(event) {
102
+ if (value.texts.size) {
103
+ var _event$target;
104
+ var alignType = (_event$target = event.target) === null || _event$target === void 0 || (_event$target = _event$target.closest('div')) === null || _event$target === void 0 ? void 0 : _event$target.getAttribute('value');
105
+ if (alignType) {
106
+ var c = value.change();
107
+ value.texts.forEach(function (text) {
108
+ var _blockParent$data;
109
+ var blockParent = value.document.getParent(text.key);
110
+ c = c.setNodeByKey(blockParent.key, {
111
+ data: _objectSpread(_objectSpread({}, blockParent.data), {}, {
112
+ attributes: _objectSpread(_objectSpread({}, (_blockParent$data = blockParent.data) === null || _blockParent$data === void 0 ? void 0 : _blockParent$data.attributes), {}, {
113
+ align: alignType
114
+ })
115
+ })
116
+ });
117
+ });
118
+ onChange(c);
119
+ }
120
+ }
121
+ setOpen(false);
122
+ };
123
+ var onMouseDown = function onMouseDown(event) {
124
+ event.preventDefault();
125
+ event.stopPropagation();
126
+ setOpen(!open);
127
+ };
128
+ return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("div", {
129
+ style: {
130
+ display: 'flex',
131
+ alignItems: 'center'
132
+ },
133
+ onClick: onMouseDown
134
+ }, icon, /*#__PURE__*/_react["default"].createElement("span", {
135
+ style: {
136
+ marginLeft: '5px',
137
+ fontSize: '8px'
138
+ }
139
+ }, "\u25BC")), /*#__PURE__*/_react["default"].createElement(_Collapse["default"], {
140
+ "in": open,
141
+ timeout: "auto",
142
+ unmountOnExit: true,
143
+ style: {
144
+ position: 'absolute'
145
+ }
146
+ }, /*#__PURE__*/_react["default"].createElement(_List["default"], {
147
+ component: "div",
148
+ disablePadding: true,
149
+ style: {
150
+ background: '#fff',
151
+ display: 'flex',
152
+ flexDirection: 'row',
153
+ padding: 0
154
+ }
155
+ }, /*#__PURE__*/_react["default"].createElement(_ListItem["default"], {
156
+ button: true,
157
+ type: "submit",
158
+ value: "left",
159
+ "aria-label": "Align text left",
160
+ onClick: applyAlignment
161
+ }, /*#__PURE__*/_react["default"].createElement(AlignLeft, null)), /*#__PURE__*/_react["default"].createElement(_ListItem["default"], {
162
+ button: true,
163
+ type: "submit",
164
+ value: "center",
165
+ "aria-label": "Align text center",
166
+ onClick: applyAlignment
167
+ }, /*#__PURE__*/_react["default"].createElement(AlignCenter, null)), /*#__PURE__*/_react["default"].createElement(_ListItem["default"], {
168
+ button: true,
169
+ type: "submit",
170
+ value: "right",
171
+ "aria-label": "Align text right",
172
+ onClick: applyAlignment
173
+ }, /*#__PURE__*/_react["default"].createElement(AlignRight, null)), /*#__PURE__*/_react["default"].createElement(_ListItem["default"], {
174
+ button: true,
175
+ type: "submit",
176
+ value: "justify",
177
+ "aria-label": "Justify text",
178
+ onClick: applyAlignment
179
+ }, /*#__PURE__*/_react["default"].createElement(AlignJustify, null)))));
180
+ };
181
+ TextAlignIcon.displayName = 'TextAlignIcon';
182
+ TextAlignIcon.propTypes = {
183
+ getValue: _propTypes["default"].func.isRequired,
184
+ onChange: _propTypes["default"].func.isRequired
185
+ };
186
+ var _default = exports["default"] = TextAlignIcon;
187
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_Collapse","_List","_ListItem","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","AlignLeft","exports","createElement","width","height","viewBox","fill","xmlns","d","AlignRight","AlignCenter","AlignJustify","TextAlignIcon","_ref","getValue","onChange","_useState","useState","_useState2","_slicedToArray2","open","setOpen","value","text","texts","type","_data$attributes","blockParent","document","getParent","key","data","toJSON","attributes","align","_data$attributes2","icon","applyAlignment","event","size","_event$target","alignType","target","closest","getAttribute","c","change","_blockParent$data","setNodeByKey","onMouseDown","preventDefault","stopPropagation","style","display","alignItems","onClick","marginLeft","fontSize","timeout","unmountOnExit","position","component","disablePadding","background","flexDirection","padding","button","displayName","propTypes","PropTypes","func","isRequired","_default"],"sources":["../../../../src/plugins/textAlign/icons/index.jsx"],"sourcesContent":["import React, { useState } from 'react';\nimport PropTypes from 'prop-types';\nimport Collapse from '@mui/material/Collapse';\nimport List from '@mui/material/List';\nimport ListItem from '@mui/material/ListItem';\n\nexport const AlignLeft = () => (\n <svg width=\"20\" height=\"20\" viewBox=\"0 0 66 66\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M42.1875 4.75C42.1875 7.38672 39.9902 9.4375 37.5 9.4375H4.6875C2.05078 9.4375 0 7.38672 0 4.75C0 2.25977 2.05078 0.0625 4.6875 0.0625H37.5C39.9902 0.0625 42.1875 2.25977 42.1875 4.75ZM42.1875 42.25C42.1875 44.8867 39.9902 46.9375 37.5 46.9375H4.6875C2.05078 46.9375 0 44.8867 0 42.25C0 39.7598 2.05078 37.5625 4.6875 37.5625H37.5C39.9902 37.5625 42.1875 39.7598 42.1875 42.25ZM0 23.5C0 21.0098 2.05078 18.8125 4.6875 18.8125H60.9375C63.4277 18.8125 65.625 21.0098 65.625 23.5C65.625 26.1367 63.4277 28.1875 60.9375 28.1875H4.6875C2.05078 28.1875 0 26.1367 0 23.5ZM65.625 61C65.625 63.6367 63.4277 65.6875 60.9375 65.6875H4.6875C2.05078 65.6875 0 63.6367 0 61C0 58.5098 2.05078 56.3125 4.6875 56.3125H60.9375C63.4277 56.3125 65.625 58.5098 65.625 61Z\"\n fill=\"currentColor\"\n />\n </svg>\n);\n\nexport const AlignRight = () => (\n <svg width=\"20\" height=\"20\" viewBox=\"0 0 66 66\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M65.625 4.75C65.625 7.38672 63.4277 9.4375 60.9375 9.4375H28.125C25.4883 9.4375 23.4375 7.38672 23.4375 4.75C23.4375 2.25977 25.4883 0.0625 28.125 0.0625H60.9375C63.4277 0.0625 65.625 2.25977 65.625 4.75ZM65.625 42.25C65.625 44.8867 63.4277 46.9375 60.9375 46.9375H28.125C25.4883 46.9375 23.4375 44.8867 23.4375 42.25C23.4375 39.7598 25.4883 37.5625 28.125 37.5625H60.9375C63.4277 37.5625 65.625 39.7598 65.625 42.25ZM0 23.5C0 21.0098 2.05078 18.8125 4.6875 18.8125H60.9375C63.4277 18.8125 65.625 21.0098 65.625 23.5C65.625 26.1367 63.4277 28.1875 60.9375 28.1875H4.6875C2.05078 28.1875 0 26.1367 0 23.5ZM65.625 61C65.625 63.6367 63.4277 65.6875 60.9375 65.6875H4.6875C2.05078 65.6875 0 63.6367 0 61C0 58.5098 2.05078 56.3125 4.6875 56.3125H60.9375C63.4277 56.3125 65.625 58.5098 65.625 61Z\"\n fill=\"currentColor\"\n />\n </svg>\n);\n\nexport const AlignCenter = () => (\n <svg width=\"20\" height=\"20\" viewBox=\"0 0 66 66\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M51.5625 4.75C51.5625 7.38672 49.3652 9.4375 46.875 9.4375H18.75C16.1133 9.4375 14.0625 7.38672 14.0625 4.75C14.0625 2.25977 16.1133 0.0625 18.75 0.0625H46.875C49.3652 0.0625 51.5625 2.25977 51.5625 4.75ZM65.625 23.5C65.625 26.1367 63.4277 28.1875 60.9375 28.1875H4.6875C2.05078 28.1875 0 26.1367 0 23.5C0 21.0098 2.05078 18.8125 4.6875 18.8125H60.9375C63.4277 18.8125 65.625 21.0098 65.625 23.5ZM0 61C0 58.5098 2.05078 56.3125 4.6875 56.3125H60.9375C63.4277 56.3125 65.625 58.5098 65.625 61C65.625 63.6367 63.4277 65.6875 60.9375 65.6875H4.6875C2.05078 65.6875 0 63.6367 0 61ZM51.5625 42.25C51.5625 44.8867 49.3652 46.9375 46.875 46.9375H18.75C16.1133 46.9375 14.0625 44.8867 14.0625 42.25C14.0625 39.7598 16.1133 37.5625 18.75 37.5625H46.875C49.3652 37.5625 51.5625 39.7598 51.5625 42.25Z\"\n fill=\"currentColor\"\n />\n </svg>\n);\n\nexport const AlignJustify = () => (\n <svg width=\"20\" height=\"20\" viewBox=\"0 0 66 66\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M65.625 4.75C65.625 7.38672 63.4277 9.4375 60.9375 9.4375H4.6875C2.05078 9.4375 0 7.38672 0 4.75C0 2.25977 2.05078 0.0625 4.6875 0.0625H60.9375C63.4277 0.0625 65.625 2.25977 65.625 4.75ZM65.625 42.25C65.625 44.8867 63.4277 46.9375 60.9375 46.9375H4.6875C2.05078 46.9375 0 44.8867 0 42.25C0 39.7598 2.05078 37.5625 4.6875 37.5625H60.9375C63.4277 37.5625 65.625 39.7598 65.625 42.25ZM0 23.5C0 21.0098 2.05078 18.8125 4.6875 18.8125H60.9375C63.4277 18.8125 65.625 21.0098 65.625 23.5C65.625 26.1367 63.4277 28.1875 60.9375 28.1875H4.6875C2.05078 28.1875 0 26.1367 0 23.5ZM65.625 61C65.625 63.6367 63.4277 65.6875 60.9375 65.6875H4.6875C2.05078 65.6875 0 63.6367 0 61C0 58.5098 2.05078 56.3125 4.6875 56.3125H60.9375C63.4277 56.3125 65.625 58.5098 65.625 61Z\"\n fill=\"currentColor\"\n />\n </svg>\n);\n\nconst TextAlignIcon = ({ getValue, onChange }) => {\n const [open, setOpen] = useState(false);\n const value = getValue();\n const text = value.texts.get(0);\n\n let type;\n\n if (text) {\n const blockParent = value.document.getParent(text.key);\n const data = blockParent.data.toJSON();\n\n if (data?.attributes?.align) {\n type = data?.attributes?.align;\n }\n }\n\n let icon;\n\n switch (type) {\n case 'right':\n icon = <AlignRight />;\n break;\n case 'center':\n icon = <AlignCenter />;\n break;\n case 'justify':\n icon = <AlignJustify />;\n break;\n default:\n icon = <AlignLeft />;\n break;\n }\n\n const applyAlignment = (event) => {\n if (value.texts.size) {\n const alignType = event.target?.closest('div')?.getAttribute('value');\n\n if (alignType) {\n let c = value.change();\n\n value.texts.forEach((text) => {\n const blockParent = value.document.getParent(text.key);\n\n c = c.setNodeByKey(blockParent.key, {\n data: { ...blockParent.data, attributes: { ...blockParent.data?.attributes, align: alignType } },\n });\n });\n\n onChange(c);\n }\n }\n\n setOpen(false);\n };\n\n const onMouseDown = (event) => {\n event.preventDefault();\n event.stopPropagation();\n setOpen(!open);\n };\n\n return (\n <div>\n <div style={{ display: 'flex', alignItems: 'center' }} onClick={onMouseDown}>\n {icon}\n <span style={{ marginLeft: '5px', fontSize: '8px' }}>&#9660;</span>\n </div>\n <Collapse in={open} timeout=\"auto\" unmountOnExit style={{ position: 'absolute' }}>\n <List\n component=\"div\"\n disablePadding\n style={{\n background: '#fff',\n display: 'flex',\n flexDirection: 'row',\n padding: 0,\n }}\n >\n <ListItem button type=\"submit\" value=\"left\" aria-label=\"Align text left\" onClick={applyAlignment}>\n <AlignLeft />\n </ListItem>\n\n <ListItem button type=\"submit\" value=\"center\" aria-label=\"Align text center\" onClick={applyAlignment}>\n <AlignCenter />\n </ListItem>\n\n <ListItem button type=\"submit\" value=\"right\" aria-label=\"Align text right\" onClick={applyAlignment}>\n <AlignRight />\n </ListItem>\n\n <ListItem button type=\"submit\" value=\"justify\" aria-label=\"Justify text\" onClick={applyAlignment}>\n <AlignJustify />\n </ListItem>\n </List>\n </Collapse>\n </div>\n );\n};\n\nTextAlignIcon.displayName = 'TextAlignIcon';\nTextAlignIcon.propTypes = {\n getValue: PropTypes.func.isRequired,\n onChange: PropTypes.func.isRequired,\n};\n\nexport default TextAlignIcon;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = TextAlign;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _icons = _interopRequireDefault(require("./icons"));
10
+ /**
11
+ * Plugin in order to be able to change alignment for the selected text(s) element(s).
12
+ * @param opts
13
+ * @constructor
14
+ */
15
+ function TextAlign(opts) {
16
+ var plugin = {
17
+ name: 'textAlign',
18
+ toolbar: {
19
+ icon: /*#__PURE__*/_react["default"].createElement(_icons["default"], opts),
20
+ ariaLabel: 'Text Align',
21
+ onClick: function onClick() {}
22
+ }
23
+ };
24
+ return plugin;
25
+ }
26
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["_react","_interopRequireDefault","require","_icons","TextAlign","opts","plugin","name","toolbar","icon","createElement","ariaLabel","onClick"],"sources":["../../../src/plugins/textAlign/index.jsx"],"sourcesContent":["import React from 'react';\nimport TextAlignIcon from './icons';\n\n/**\n * Plugin in order to be able to change alignment for the selected text(s) element(s).\n * @param opts\n * @constructor\n */\nexport default function TextAlign(opts) {\n const plugin = {\n name: 'textAlign',\n toolbar: {\n icon: <TextAlignIcon {...opts} />,\n ariaLabel: 'Text Align',\n onClick: () => {},\n },\n };\n\n return plugin;\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAF,sBAAA,CAAAC,OAAA;AAEA;AACA;AACA;AACA;AACA;AACe,SAASE,SAASA,CAACC,IAAI,EAAE;EACtC,IAAMC,MAAM,GAAG;IACbC,IAAI,EAAE,WAAW;IACjBC,OAAO,EAAE;MACPC,IAAI,eAAET,MAAA,YAAAU,aAAA,CAACP,MAAA,WAAa,EAAKE,IAAO,CAAC;MACjCM,SAAS,EAAE,YAAY;MACvBC,OAAO,EAAE,SAATA,OAAOA,CAAA,EAAQ,CAAC;IAClB;EACF,CAAC;EAED,OAAON,MAAM;AACf","ignoreList":[]}
@@ -0,0 +1,180 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = exports.ToolbarButton = exports.DefaultToolbar = void 0;
8
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
+ var _doneButton = require("./done-button");
11
+ var _propTypes = _interopRequireDefault(require("prop-types"));
12
+ var _react = _interopRequireDefault(require("react"));
13
+ var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
14
+ var _utils = require("../utils");
15
+ var _styles = require("@mui/material/styles");
16
+ var _toolbarButtons = require("./toolbar-buttons");
17
+ var _debug = _interopRequireDefault(require("debug"));
18
+ 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; }
19
+ 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) { (0, _defineProperty2["default"])(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; }
20
+ var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:toolbar');
21
+ var DefaultToolbarContainer = (0, _styles.styled)('div')({
22
+ display: 'flex',
23
+ width: '100%',
24
+ justifyContent: 'space-between'
25
+ });
26
+ var ButtonsContainer = (0, _styles.styled)('div')({
27
+ alignItems: 'center',
28
+ display: 'flex',
29
+ width: '100%'
30
+ });
31
+ var ToolbarButton = exports.ToolbarButton = function ToolbarButton(props) {
32
+ var onToggle = function onToggle() {
33
+ var c = props.onToggle(props.value.change(), props);
34
+ props.onChange(c);
35
+ };
36
+ if (props.isMark) {
37
+ var _isActive = (0, _utils.hasMark)(props.value, props.type);
38
+ var fnToCall = props.type === 'css' ? function () {
39
+ return props.onClick(props.value, props.onChange, props.getFocusedValue);
40
+ } : onToggle;
41
+ log('[ToolbarButton] mark:isActive: ', _isActive);
42
+ var ariaLabel;
43
+ if (props.type === 'sup') {
44
+ ariaLabel = 'Superscript (marks text as superscripted)';
45
+ } else if (props.type === 'sub') {
46
+ ariaLabel = 'Subscript (marks text as subscripted)';
47
+ } else {
48
+ ariaLabel = props.type;
49
+ }
50
+ return /*#__PURE__*/_react["default"].createElement(_toolbarButtons.MarkButton, {
51
+ active: _isActive,
52
+ onToggle: fnToCall,
53
+ mark: props.type,
54
+ label: ariaLabel
55
+ }, props.icon);
56
+ }
57
+ var disabled = props.disabled;
58
+ var isActive = props.isActive ? props.isActive(props.value, props.type) : (0, _utils.hasBlock)(props.value, props.type);
59
+ log('[ToolbarButton] block:isActive: ', isActive);
60
+ var newIcon = /*#__PURE__*/_react["default"].cloneElement(props.icon);
61
+ return /*#__PURE__*/_react["default"].createElement(_toolbarButtons.Button, {
62
+ ariaLabel: props.ariaLabel,
63
+ active: isActive,
64
+ disabled: disabled,
65
+ onClick: function onClick(event) {
66
+ return props.onClick(props.value, props.onChange, props.getFocusedValue, event);
67
+ },
68
+ extraStyles: props.buttonStyles
69
+ }, newIcon);
70
+ };
71
+ ToolbarButton.propTypes = {
72
+ buttonStyles: _propTypes["default"].object,
73
+ disabled: _propTypes["default"].bool,
74
+ icon: _propTypes["default"].any,
75
+ isActive: _propTypes["default"].bool,
76
+ isMark: _propTypes["default"].bool,
77
+ getFocusedValue: _propTypes["default"].func,
78
+ onToggle: _propTypes["default"].func,
79
+ onChange: _propTypes["default"].func,
80
+ onClick: _propTypes["default"].func,
81
+ type: _propTypes["default"].string,
82
+ value: _propTypes["default"].object,
83
+ ariaLabel: _propTypes["default"].string
84
+ };
85
+ var isActiveToolbarPlugin = function isActiveToolbarPlugin(props) {
86
+ return function (plugin) {
87
+ var isDisabled = (props[plugin.name] || {}).disabled;
88
+ return plugin && plugin.toolbar && !isDisabled;
89
+ };
90
+ };
91
+ var DefaultToolbar = exports.DefaultToolbar = function DefaultToolbar(_ref) {
92
+ var plugins = _ref.plugins,
93
+ pluginProps = _ref.pluginProps,
94
+ value = _ref.value,
95
+ onChange = _ref.onChange,
96
+ getFocusedValue = _ref.getFocusedValue,
97
+ onDone = _ref.onDone,
98
+ showDone = _ref.showDone,
99
+ deletable = _ref.deletable,
100
+ isHtmlMode = _ref.isHtmlMode,
101
+ doneButtonRef = _ref.doneButtonRef,
102
+ onBlur = _ref.onBlur,
103
+ onFocus = _ref.onFocus;
104
+ pluginProps = _objectSpread({
105
+ // disable HTML plugin by default, at least for now
106
+ html: {
107
+ disabled: true
108
+ }
109
+ }, pluginProps);
110
+ var filtered;
111
+ var handleFocus = function handleFocus(event) {
112
+ var _doneButtonRef$curren, _event$target;
113
+ var doneButtonClassName = doneButtonRef === null || doneButtonRef === void 0 || (_doneButtonRef$curren = doneButtonRef.current) === null || _doneButtonRef$curren === void 0 ? void 0 : _doneButtonRef$curren.className;
114
+ var isRawDoneButton = doneButtonClassName && ((_event$target = event.target) === null || _event$target === void 0 ? void 0 : _event$target.closest("[class*=\"".concat(doneButtonClassName, "\"]")));
115
+ if (onFocus && !isRawDoneButton) {
116
+ onFocus(event);
117
+ }
118
+ };
119
+ if (isHtmlMode) {
120
+ filtered = plugins.filter(function (plugin) {
121
+ return isActiveToolbarPlugin(pluginProps)(plugin) && (plugin.name === 'characters' || plugin.name === 'html');
122
+ }).map(function (p) {
123
+ return p.toolbar;
124
+ });
125
+ } else {
126
+ filtered = plugins.filter(isActiveToolbarPlugin(pluginProps)).map(function (p) {
127
+ return p.toolbar;
128
+ });
129
+ }
130
+ var isListActive = plugins.some(function (plugin) {
131
+ return isActiveToolbarPlugin(pluginProps)(plugin) && ['ul_list', 'ol_list'].includes(plugin.name) && plugin.toolbar.isActive(value, plugin.name);
132
+ });
133
+ var isTableActive = plugins.some(function (plugin) {
134
+ return isActiveToolbarPlugin(pluginProps)(plugin) && plugin.name === 'table' && plugin.utils && plugin.utils.isSelectionInTable && plugin.utils.isSelectionInTable(value);
135
+ });
136
+ var isToolbarButtonDisabled = function isToolbarButtonDisabled(plugin) {
137
+ if (plugin.type === 'table') {
138
+ return isListActive;
139
+ } else if (plugin.type === 'ul_list' || plugin.type === 'ol_list') {
140
+ return isTableActive;
141
+ }
142
+ return plugin.disabled;
143
+ };
144
+ return /*#__PURE__*/_react["default"].createElement(DefaultToolbarContainer, {
145
+ onFocus: handleFocus,
146
+ tabIndex: "1",
147
+ onBlur: onBlur
148
+ }, /*#__PURE__*/_react["default"].createElement(ButtonsContainer, null, filtered.map(function (p, index) {
149
+ return /*#__PURE__*/_react["default"].createElement(ToolbarButton, (0, _extends2["default"])({}, p, {
150
+ key: index,
151
+ value: value,
152
+ onChange: onChange,
153
+ getFocusedValue: getFocusedValue,
154
+ disabled: isToolbarButtonDisabled(p)
155
+ }));
156
+ })), showDone && !deletable && /*#__PURE__*/_react["default"].createElement(_doneButton.DoneButton, {
157
+ doneButtonRef: doneButtonRef,
158
+ onClick: onDone
159
+ }));
160
+ };
161
+ DefaultToolbar.propTypes = {
162
+ plugins: _propTypes["default"].array.isRequired,
163
+ pluginProps: _propTypes["default"].object,
164
+ value: _slatePropTypes["default"].value.isRequired,
165
+ onChange: _propTypes["default"].func.isRequired,
166
+ getFocusedValue: _propTypes["default"].func.isRequired,
167
+ onDone: _propTypes["default"].func.isRequired,
168
+ showDone: _propTypes["default"].bool,
169
+ addArea: _propTypes["default"].bool,
170
+ deletable: _propTypes["default"].bool,
171
+ isHtmlMode: _propTypes["default"].bool,
172
+ doneButtonRef: _propTypes["default"].func,
173
+ onBlur: _propTypes["default"].func,
174
+ onFocus: _propTypes["default"].func
175
+ };
176
+ DefaultToolbar.defaultProps = {
177
+ pluginProps: {}
178
+ };
179
+ var _default = exports["default"] = DefaultToolbar;
180
+ //# sourceMappingURL=default-toolbar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-toolbar.js","names":["_doneButton","require","_propTypes","_interopRequireDefault","_react","_slatePropTypes","_utils","_styles","_toolbarButtons","_debug","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","log","debug","DefaultToolbarContainer","styled","display","width","justifyContent","ButtonsContainer","alignItems","ToolbarButton","exports","props","onToggle","c","value","change","onChange","isMark","isActive","hasMark","type","fnToCall","onClick","getFocusedValue","ariaLabel","createElement","MarkButton","active","mark","label","icon","disabled","hasBlock","newIcon","React","cloneElement","Button","event","extraStyles","buttonStyles","propTypes","PropTypes","object","bool","any","func","string","isActiveToolbarPlugin","plugin","isDisabled","name","toolbar","DefaultToolbar","_ref","plugins","pluginProps","onDone","showDone","deletable","isHtmlMode","doneButtonRef","onBlur","onFocus","html","filtered","handleFocus","_doneButtonRef$curren","_event$target","doneButtonClassName","current","className","isRawDoneButton","target","closest","concat","map","p","isListActive","some","includes","isTableActive","utils","isSelectionInTable","isToolbarButtonDisabled","tabIndex","index","_extends2","key","DoneButton","array","isRequired","SlatePropTypes","addArea","defaultProps","_default"],"sources":["../../../src/plugins/toolbar/default-toolbar.jsx"],"sourcesContent":["import { DoneButton } from './done-button';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport SlatePropTypes from 'slate-prop-types';\n\nimport { hasBlock, hasMark } from '../utils';\nimport { styled } from '@mui/material/styles';\n\nimport { Button, MarkButton } from './toolbar-buttons';\nimport debug from 'debug';\n\nconst log = debug('@pie-lib:editable-html:plugins:toolbar');\n\nconst DefaultToolbarContainer = styled('div')({\n display: 'flex',\n width: '100%',\n justifyContent: 'space-between',\n});\n\nconst ButtonsContainer = styled('div')({\n alignItems: 'center',\n display: 'flex',\n width: '100%',\n});\n\nexport const ToolbarButton = (props) => {\n const onToggle = () => {\n const c = props.onToggle(props.value.change(), props);\n\n props.onChange(c);\n };\n\n if (props.isMark) {\n const isActive = hasMark(props.value, props.type);\n const fnToCall =\n props.type === 'css' ? () => props.onClick(props.value, props.onChange, props.getFocusedValue) : onToggle;\n\n log('[ToolbarButton] mark:isActive: ', isActive);\n\n let ariaLabel;\n\n if (props.type === 'sup') {\n ariaLabel = 'Superscript (marks text as superscripted)';\n } else if (props.type === 'sub') {\n ariaLabel = 'Subscript (marks text as subscripted)';\n } else {\n ariaLabel = props.type;\n }\n\n return (\n <MarkButton active={isActive} onToggle={fnToCall} mark={props.type} label={ariaLabel}>\n {props.icon}\n </MarkButton>\n );\n }\n\n const { disabled } = props;\n const isActive = props.isActive ? props.isActive(props.value, props.type) : hasBlock(props.value, props.type);\n\n log('[ToolbarButton] block:isActive: ', isActive);\n const newIcon = React.cloneElement(props.icon);\n\n return (\n <Button\n ariaLabel={props.ariaLabel}\n active={isActive}\n disabled={disabled}\n onClick={(event) => props.onClick(props.value, props.onChange, props.getFocusedValue, event)}\n extraStyles={props.buttonStyles}\n >\n {newIcon}\n </Button>\n );\n};\n\nToolbarButton.propTypes = {\n buttonStyles: PropTypes.object,\n disabled: PropTypes.bool,\n icon: PropTypes.any,\n isActive: PropTypes.bool,\n isMark: PropTypes.bool,\n getFocusedValue: PropTypes.func,\n onToggle: PropTypes.func,\n onChange: PropTypes.func,\n onClick: PropTypes.func,\n type: PropTypes.string,\n value: PropTypes.object,\n ariaLabel: PropTypes.string,\n};\n\nconst isActiveToolbarPlugin = (props) => (plugin) => {\n const isDisabled = (props[plugin.name] || {}).disabled;\n\n return plugin && plugin.toolbar && !isDisabled;\n};\n\nexport const DefaultToolbar = ({\n plugins,\n pluginProps,\n value,\n onChange,\n getFocusedValue,\n onDone,\n showDone,\n deletable,\n isHtmlMode,\n doneButtonRef,\n onBlur,\n onFocus,\n}) => {\n pluginProps = {\n // disable HTML plugin by default, at least for now\n html: { disabled: true },\n ...pluginProps,\n };\n let filtered;\n\n const handleFocus = (event) => {\n const doneButtonClassName = doneButtonRef?.current?.className;\n const isRawDoneButton = doneButtonClassName && event.target?.closest(`[class*=\"${doneButtonClassName}\"]`);\n\n if (onFocus && !isRawDoneButton) {\n onFocus(event);\n }\n };\n\n if (isHtmlMode) {\n filtered = plugins\n .filter((plugin) => {\n return isActiveToolbarPlugin(pluginProps)(plugin) && (plugin.name === 'characters' || plugin.name === 'html');\n })\n .map((p) => p.toolbar);\n } else {\n filtered = plugins.filter(isActiveToolbarPlugin(pluginProps)).map((p) => p.toolbar);\n }\n\n const isListActive = plugins.some(\n (plugin) =>\n isActiveToolbarPlugin(pluginProps)(plugin) &&\n ['ul_list', 'ol_list'].includes(plugin.name) &&\n plugin.toolbar.isActive(value, plugin.name),\n );\n\n const isTableActive = plugins.some(\n (plugin) =>\n isActiveToolbarPlugin(pluginProps)(plugin) &&\n plugin.name === 'table' &&\n plugin.utils &&\n plugin.utils.isSelectionInTable &&\n plugin.utils.isSelectionInTable(value),\n );\n\n const isToolbarButtonDisabled = (plugin) => {\n if (plugin.type === 'table') {\n return isListActive;\n } else if (plugin.type === 'ul_list' || plugin.type === 'ol_list') {\n return isTableActive;\n }\n return plugin.disabled;\n };\n\n return (\n <DefaultToolbarContainer onFocus={handleFocus} tabIndex=\"1\" onBlur={onBlur}>\n <ButtonsContainer>\n {filtered.map((p, index) => {\n return (\n <ToolbarButton\n {...p}\n key={index}\n value={value}\n onChange={onChange}\n getFocusedValue={getFocusedValue}\n disabled={isToolbarButtonDisabled(p)}\n />\n );\n })}\n </ButtonsContainer>\n {showDone && !deletable && <DoneButton doneButtonRef={doneButtonRef} onClick={onDone} />}\n </DefaultToolbarContainer>\n );\n};\n\nDefaultToolbar.propTypes = {\n plugins: PropTypes.array.isRequired,\n pluginProps: PropTypes.object,\n value: SlatePropTypes.value.isRequired,\n onChange: PropTypes.func.isRequired,\n getFocusedValue: PropTypes.func.isRequired,\n onDone: PropTypes.func.isRequired,\n showDone: PropTypes.bool,\n addArea: PropTypes.bool,\n deletable: PropTypes.bool,\n isHtmlMode: PropTypes.bool,\n doneButtonRef: PropTypes.func,\n onBlur: PropTypes.func,\n onFocus: PropTypes.func,\n};\n\nDefaultToolbar.defaultProps = {\n pluginProps: {},\n};\n\nexport default DefaultToolbar;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.RawDoneButton = exports.DoneButton = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _IconButton = _interopRequireDefault(require("@mui/material/IconButton"));
10
+ var _Check = _interopRequireDefault(require("@mui/icons-material/Check"));
11
+ var _styles = require("@mui/material/styles");
12
+ var _propTypes = _interopRequireDefault(require("prop-types"));
13
+ var StyledIconButton = (0, _styles.styled)(_IconButton["default"])({
14
+ verticalAlign: 'top',
15
+ width: '28px',
16
+ height: '28px',
17
+ color: 'var(--editable-html-toolbar-check, #00bb00)',
18
+ padding: '4px'
19
+ });
20
+ var RawDoneButton = exports.RawDoneButton = function RawDoneButton(_ref) {
21
+ var onClick = _ref.onClick,
22
+ doneButtonRef = _ref.doneButtonRef;
23
+ return /*#__PURE__*/_react["default"].createElement(StyledIconButton, {
24
+ "aria-label": "Done",
25
+ buttonRef: doneButtonRef,
26
+ onClick: onClick,
27
+ size: "large"
28
+ }, /*#__PURE__*/_react["default"].createElement(_Check["default"], null));
29
+ };
30
+ RawDoneButton.propTypes = {
31
+ onClick: _propTypes["default"].func,
32
+ doneButtonRef: _propTypes["default"].func
33
+ };
34
+ var DoneButton = exports.DoneButton = RawDoneButton;
35
+ //# sourceMappingURL=done-button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"done-button.js","names":["_react","_interopRequireDefault","require","_IconButton","_Check","_styles","_propTypes","StyledIconButton","styled","IconButton","verticalAlign","width","height","color","padding","RawDoneButton","exports","_ref","onClick","doneButtonRef","createElement","buttonRef","size","propTypes","PropTypes","func","DoneButton"],"sources":["../../../src/plugins/toolbar/done-button.jsx"],"sourcesContent":["import React from 'react';\n\nimport IconButton from '@mui/material/IconButton';\nimport Check from '@mui/icons-material/Check';\nimport { styled } from '@mui/material/styles';\nimport PropTypes from 'prop-types';\n\nconst StyledIconButton = styled(IconButton)({\n verticalAlign: 'top',\n width: '28px',\n height: '28px',\n color: 'var(--editable-html-toolbar-check, #00bb00)',\n padding: '4px',\n});\n\nexport const RawDoneButton = ({ onClick, doneButtonRef }) => (\n <StyledIconButton\n aria-label=\"Done\"\n buttonRef={doneButtonRef}\n onClick={onClick}\n size=\"large\"\n >\n <Check />\n </StyledIconButton>\n);\n\nRawDoneButton.propTypes = {\n onClick: PropTypes.func,\n doneButtonRef: PropTypes.func,\n};\n\nexport const DoneButton = RawDoneButton;\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,WAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,MAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,OAAA,GAAAH,OAAA;AACA,IAAAI,UAAA,GAAAL,sBAAA,CAAAC,OAAA;AAEA,IAAMK,gBAAgB,GAAG,IAAAC,cAAM,EAACC,sBAAU,CAAC,CAAC;EAC1CC,aAAa,EAAE,KAAK;EACpBC,KAAK,EAAE,MAAM;EACbC,MAAM,EAAE,MAAM;EACdC,KAAK,EAAE,6CAA6C;EACpDC,OAAO,EAAE;AACX,CAAC,CAAC;AAEK,IAAMC,aAAa,GAAAC,OAAA,CAAAD,aAAA,GAAG,SAAhBA,aAAaA,CAAAE,IAAA;EAAA,IAAMC,OAAO,GAAAD,IAAA,CAAPC,OAAO;IAAEC,aAAa,GAAAF,IAAA,CAAbE,aAAa;EAAA,oBACpDnB,MAAA,YAAAoB,aAAA,CAACb,gBAAgB;IACf,cAAW,MAAM;IACjBc,SAAS,EAAEF,aAAc;IACzBD,OAAO,EAAEA,OAAQ;IACjBI,IAAI,EAAC;EAAO,gBAEZtB,MAAA,YAAAoB,aAAA,CAAChB,MAAA,WAAK,MAAE,CACQ,CAAC;AAAA,CACpB;AAEDW,aAAa,CAACQ,SAAS,GAAG;EACxBL,OAAO,EAAEM,qBAAS,CAACC,IAAI;EACvBN,aAAa,EAAEK,qBAAS,CAACC;AAC3B,CAAC;AAEM,IAAMC,UAAU,GAAAV,OAAA,CAAAU,UAAA,GAAGX,aAAa","ignoreList":[]}