ecomlab-components-next 0.1.82 → 0.1.83

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.
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.AccordionItem = void 0;
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ require("./AccordionItem.scss");
10
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
11
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
12
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
13
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
14
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
15
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
16
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
17
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
18
+ // подключим стили отдельно
19
+
20
+ var AccordionItem = exports.AccordionItem = function AccordionItem(_ref) {
21
+ var title = _ref.title,
22
+ content = _ref.content;
23
+ var _useState = (0, _react.useState)(false),
24
+ _useState2 = _slicedToArray(_useState, 2),
25
+ isOpen = _useState2[0],
26
+ setIsOpen = _useState2[1];
27
+ return /*#__PURE__*/_react["default"].createElement("div", {
28
+ className: "accordion-item ".concat(isOpen ? "open" : "")
29
+ }, /*#__PURE__*/_react["default"].createElement("button", {
30
+ className: "accordion-item__button",
31
+ onClick: function onClick() {
32
+ return setIsOpen(!isOpen);
33
+ }
34
+ }, title), /*#__PURE__*/_react["default"].createElement("div", {
35
+ className: "accordion-item__content ".concat(isOpen ? "open" : "")
36
+ }, /*#__PURE__*/_react["default"].createElement("div", {
37
+ className: "accordion-item__text"
38
+ }, content)));
39
+ };
@@ -0,0 +1,64 @@
1
+ .accordion-item {
2
+ border-bottom: 1px solid #ccc;
3
+
4
+ &__button {
5
+ width: 100%;
6
+ padding: 16px;
7
+ font-size: 16px;
8
+ background: none;
9
+ border: none;
10
+ text-align: left;
11
+ cursor: pointer;
12
+ outline: none;
13
+ display: flex;
14
+ align-items: center;
15
+ transition: color 0.3s ease;
16
+ position: relative; // Для позиционирования псевдоэлемента
17
+
18
+ // Треугольник/стрелка
19
+ &::before {
20
+ content: '';
21
+ display: inline-block;
22
+ width: 0;
23
+ height: 0;
24
+ margin-right: 10px;
25
+ border-top: 5px solid transparent;
26
+ border-bottom: 5px solid transparent;
27
+ border-left: 5px solid #000;
28
+ transition: transform 0.3s ease, border-left-color 0.3s ease;
29
+ transform-origin: center 3px; // Центр вращения
30
+ }
31
+
32
+ &:hover {
33
+ color: #0077cc;
34
+
35
+ &::before {
36
+ border-left-color: #0077cc; // Меняем только цвет границы
37
+ }
38
+ }
39
+ }
40
+
41
+ &__content {
42
+ max-height: 0;
43
+ overflow: hidden;
44
+ transition: max-height 0.4s ease;
45
+ }
46
+
47
+ &__text {
48
+ padding: 0 16px 16px;
49
+ font-size: 14px;
50
+ color: #444;
51
+ line-height: 1.5;
52
+ }
53
+
54
+ // Состояние "открыто"
55
+ &.open {
56
+ .accordion-item__button::before {
57
+ transform: rotate(90deg); // Поворот стрелки
58
+ }
59
+
60
+ .accordion-item__content {
61
+ max-height: 1000px; // Достаточно большое значение для контента
62
+ }
63
+ }
64
+ }
@@ -0,0 +1,184 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.Accordion = void 0;
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ var _EditWrapper = require("../EditWrapper/EditWrapper");
10
+ var _TextareaDynamicPlaceholder = _interopRequireDefault(require("../../Inputs/TextareaDynamicPlaceholder/TextareaDynamicPlaceholder"));
11
+ var _ButtonBasic = _interopRequireDefault(require("../../Buttons/ButtonBasic/ButtonBasic"));
12
+ var _AccordionItem = require("../../AccordionItem/AccordionItem");
13
+ var _useDebounce = require("../../../common/hooks/useDebounce");
14
+ require("./Accordion.scss");
15
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
16
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
17
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
18
+ function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
19
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
20
+ function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
21
+ function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
22
+ 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; }
23
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
24
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
25
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
26
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
27
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
28
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
29
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
30
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
31
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
32
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
33
+ var Accordion = exports.Accordion = function Accordion(_ref) {
34
+ var _data$;
35
+ var id = _ref.id,
36
+ data = _ref.data,
37
+ changeContent = _ref.changeContent,
38
+ setIsModal = _ref.setIsModal,
39
+ ind = _ref.ind,
40
+ setCurrentIndex = _ref.setCurrentIndex,
41
+ before = _ref.before,
42
+ setBeforeBlock = _ref.setBeforeBlock,
43
+ setContentArr = _ref.setContentArr,
44
+ deleteBlock = _ref.deleteBlock,
45
+ _ref$readonly = _ref.readonly,
46
+ readonly = _ref$readonly === void 0 ? false : _ref$readonly,
47
+ draggableElement = _ref.draggableElement,
48
+ setDraggableElement = _ref.setDraggableElement,
49
+ articleId = _ref.articleId,
50
+ fetchDataById = _ref.fetchDataById,
51
+ changeBlock = _ref.changeBlock,
52
+ addNewBlock = _ref.addNewBlock,
53
+ currentIndex = _ref.currentIndex;
54
+ var _useState = (0, _react.useState)(''),
55
+ _useState2 = _slicedToArray(_useState, 2),
56
+ title = _useState2[0],
57
+ setTitle = _useState2[1];
58
+ var _useState3 = (0, _react.useState)(''),
59
+ _useState4 = _slicedToArray(_useState3, 2),
60
+ text = _useState4[0],
61
+ setText = _useState4[1];
62
+ var _useState5 = (0, _react.useState)(false),
63
+ _useState6 = _slicedToArray(_useState5, 2),
64
+ isEdit = _useState6[0],
65
+ setIsEdit = _useState6[1];
66
+ var _useState7 = (0, _react.useState)(((_data$ = data[0]) === null || _data$ === void 0 || (_data$ = _data$.properties) === null || _data$ === void 0 ? void 0 : _data$.value) || []),
67
+ _useState8 = _slicedToArray(_useState7, 2),
68
+ content = _useState8[0],
69
+ setContent = _useState8[1];
70
+ var debounceChange = (0, _useDebounce.useDebounce)(changeContent, 1000);
71
+ var handleDeleteBlock = function handleDeleteBlock(e) {
72
+ // setContent(e.currentTarget.textContent)
73
+ setContentArr(function (prev) {
74
+ return prev.filter(function (el) {
75
+ if ((el === null || el === void 0 ? void 0 : el.block_id) != id) {
76
+ return el;
77
+ }
78
+ });
79
+ });
80
+ deleteBlock(id);
81
+ };
82
+ var handleAddPoint = function handleAddPoint(content) {
83
+ debounceChange(id, [{
84
+ value: '',
85
+ properties: {
86
+ value: content
87
+ }
88
+ }]);
89
+ setContentArr(function (prev) {
90
+ return prev.map(function (el) {
91
+ if ((el === null || el === void 0 ? void 0 : el.block_id) == id) {
92
+ return _objectSpread(_objectSpread({}, el), {}, {
93
+ properties: {
94
+ value: content
95
+ }
96
+ });
97
+ } else {
98
+ return el;
99
+ }
100
+ });
101
+ });
102
+ };
103
+ return /*#__PURE__*/_react["default"].createElement(_EditWrapper.EditWrapper, {
104
+ id: id,
105
+ before: before,
106
+ articleId: articleId,
107
+ changeBlock: changeBlock,
108
+ readonly: readonly,
109
+ draggableElement: draggableElement,
110
+ setDraggableElement: setDraggableElement,
111
+ fetchDataById: fetchDataById,
112
+ deleteFunc: function deleteFunc(e) {
113
+ return handleDeleteBlock(id);
114
+ },
115
+ type: "accordion",
116
+ ind: ind,
117
+ currentIndex: currentIndex,
118
+ setCurrentIndex: setCurrentIndex,
119
+ addNewBlock: addNewBlock,
120
+ child: /*#__PURE__*/_react["default"].createElement("div", {
121
+ className: "accordion-type",
122
+ onContextMenu: function onContextMenu(e) {
123
+ if (!readonly) {
124
+ e.preventDefault();
125
+ setCurrentIndex(ind);
126
+ setIsModal(true);
127
+ }
128
+ }
129
+ }, !readonly && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, !isEdit ? /*#__PURE__*/_react["default"].createElement(_ButtonBasic["default"], {
130
+ grey: true,
131
+ text: "\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u043D\u043E\u0432\u044B\u0439 \u044D\u043B\u0435\u043C\u0435\u043D\u0442 +",
132
+ onClick: function onClick(e) {
133
+ setIsEdit(true);
134
+ }
135
+ }) : /*#__PURE__*/_react["default"].createElement("div", {
136
+ className: "accordion-type__fields"
137
+ }, /*#__PURE__*/_react["default"].createElement(_TextareaDynamicPlaceholder["default"], {
138
+ placeholder: "\u0412\u0438\u0434\u0438\u043C\u044B\u0439 \u043A\u043E\u043D\u0442\u0435\u043D\u0442",
139
+ changeValue: title,
140
+ onChange: function onChange(e) {
141
+ return setTitle(e);
142
+ },
143
+ size: "s"
144
+ }), /*#__PURE__*/_react["default"].createElement(_TextareaDynamicPlaceholder["default"], {
145
+ placeholder: "\u0421\u043A\u0440\u044B\u0432\u0430\u0435\u043C\u044B\u0439 \u043A\u043E\u043D\u0442\u0435\u043D\u0442",
146
+ changeValue: text,
147
+ onChange: function onChange(e) {
148
+ return setText(e);
149
+ },
150
+ size: "s"
151
+ }), /*#__PURE__*/_react["default"].createElement(_ButtonBasic["default"], {
152
+ disabled: !title || !text,
153
+ width: "180px",
154
+ text: "\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u044D\u043B\u0435\u043C\u0435\u043D\u0442 +",
155
+ onClick: function onClick(e) {
156
+ var current_array = [].concat(_toConsumableArray(content), [{
157
+ title: title,
158
+ content: text
159
+ }]);
160
+ setContent(current_array);
161
+ setTitle('');
162
+ setText('');
163
+ handleAddPoint(current_array);
164
+ }
165
+ }), /*#__PURE__*/_react["default"].createElement(_ButtonBasic["default"], {
166
+ grey: true,
167
+ width: "auto",
168
+ text: "\u0417\u0430\u043A\u0440\u044B\u0442\u044C",
169
+ onClick: function onClick(e) {
170
+ setIsEdit(false);
171
+ }
172
+ }))), /*#__PURE__*/_react["default"].createElement("div", {
173
+ className: "accordion-type__list"
174
+ }, content === null || content === void 0 ? void 0 : content.map(function (_ref2) {
175
+ var title = _ref2.title,
176
+ content = _ref2.content;
177
+ return /*#__PURE__*/_react["default"].createElement(_AccordionItem.AccordionItem, {
178
+ key: title + content,
179
+ title: title,
180
+ content: content
181
+ });
182
+ })))
183
+ });
184
+ };
@@ -0,0 +1,26 @@
1
+ .accordion-type {
2
+ display: flex;
3
+ width: 100%;
4
+ flex-direction: column;
5
+ gap: 24px;
6
+
7
+ &__fields {
8
+ display: flex;
9
+ flex-wrap: wrap;
10
+ width: 100%;
11
+ gap: 12px;
12
+ background-color: #EDEFFB;
13
+ padding: 12px;
14
+ border-radius: 8px;
15
+
16
+ .textarea-dynamic-placeholder {
17
+ max-width: calc(50% - 12px);
18
+ }
19
+ }
20
+
21
+ &__list {
22
+ display: flex;
23
+ flex-direction: column;
24
+ width: 100%;
25
+ }
26
+ }
@@ -17,6 +17,27 @@ var apiData = {
17
17
  "active": true,
18
18
  "author": ["Елена", "rgb(224, 173, 46)"],
19
19
  "blocks": [{
20
+ "content": [{
21
+ "value": "222222222222",
22
+ "properties": {}
23
+ }],
24
+ "block_id": 4256,
25
+ "block_type": "code",
26
+ "block_before": null
27
+ }, {
28
+ "content": [{
29
+ "value": "",
30
+ "properties": {
31
+ "value": [{
32
+ "title": "2222222",
33
+ "content": "11111111"
34
+ }]
35
+ }
36
+ }],
37
+ "block_id": 4257,
38
+ "block_type": "accordion",
39
+ "block_before": 4256
40
+ }, {
20
41
  "content": [{
21
42
  "value": "Заголовок",
22
43
  "properties": {
@@ -0,0 +1,115 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.Code = void 0;
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ var _EditWrapper = require("../EditWrapper/EditWrapper");
10
+ var _EditorCode = require("../../EditorCode/EditorCode");
11
+ var _useDebounce = require("../../../common/hooks/useDebounce");
12
+ require("./Code.scss");
13
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
14
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
15
+ 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; }
16
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
17
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
18
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
19
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
20
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
21
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
22
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
23
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
24
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
25
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
26
+ var Code = exports.Code = function Code(_ref) {
27
+ var _data$;
28
+ var id = _ref.id,
29
+ data = _ref.data,
30
+ changeContent = _ref.changeContent,
31
+ setIsModal = _ref.setIsModal,
32
+ ind = _ref.ind,
33
+ setCurrentIndex = _ref.setCurrentIndex,
34
+ before = _ref.before,
35
+ setBeforeBlock = _ref.setBeforeBlock,
36
+ setContentArr = _ref.setContentArr,
37
+ deleteBlock = _ref.deleteBlock,
38
+ _ref$readonly = _ref.readonly,
39
+ readonly = _ref$readonly === void 0 ? false : _ref$readonly,
40
+ draggableElement = _ref.draggableElement,
41
+ setDraggableElement = _ref.setDraggableElement,
42
+ articleId = _ref.articleId,
43
+ fetchDataById = _ref.fetchDataById,
44
+ changeBlock = _ref.changeBlock,
45
+ addNewBlock = _ref.addNewBlock,
46
+ currentIndex = _ref.currentIndex;
47
+ var _useState = (0, _react.useState)(((_data$ = data[0]) === null || _data$ === void 0 ? void 0 : _data$.value) || ''),
48
+ _useState2 = _slicedToArray(_useState, 2),
49
+ content = _useState2[0],
50
+ setContent = _useState2[1];
51
+ var debounceChange = (0, _useDebounce.useDebounce)(changeContent, 1000);
52
+ var handleDeleteBlock = function handleDeleteBlock(e) {
53
+ // setContent(e.currentTarget.textContent)
54
+ setContentArr(function (prev) {
55
+ return prev.filter(function (el) {
56
+ if ((el === null || el === void 0 ? void 0 : el.block_id) != id) {
57
+ return el;
58
+ }
59
+ });
60
+ });
61
+ deleteBlock(id);
62
+ };
63
+ var handleAddContent = function handleAddContent(content) {
64
+ debounceChange(id, [{
65
+ value: content,
66
+ properties: {}
67
+ }]);
68
+ setContentArr(function (prev) {
69
+ return prev.map(function (el) {
70
+ if ((el === null || el === void 0 ? void 0 : el.block_id) == id) {
71
+ return _objectSpread(_objectSpread({}, el), {}, {
72
+ value: content
73
+ });
74
+ } else {
75
+ return el;
76
+ }
77
+ });
78
+ });
79
+ };
80
+ return /*#__PURE__*/_react["default"].createElement(_EditWrapper.EditWrapper, {
81
+ id: id,
82
+ before: before,
83
+ articleId: articleId,
84
+ changeBlock: changeBlock,
85
+ readonly: readonly,
86
+ draggableElement: draggableElement,
87
+ setDraggableElement: setDraggableElement,
88
+ fetchDataById: fetchDataById,
89
+ deleteFunc: function deleteFunc(e) {
90
+ return handleDeleteBlock(id);
91
+ },
92
+ type: "code",
93
+ ind: ind,
94
+ currentIndex: currentIndex,
95
+ setCurrentIndex: setCurrentIndex,
96
+ addNewBlock: addNewBlock,
97
+ child: /*#__PURE__*/_react["default"].createElement("div", {
98
+ className: "editor-code-type",
99
+ onContextMenu: function onContextMenu(e) {
100
+ if (!readonly) {
101
+ e.preventDefault();
102
+ setCurrentIndex(ind);
103
+ setIsModal(true);
104
+ }
105
+ }
106
+ }, /*#__PURE__*/_react["default"].createElement(_EditorCode.EditorCode, {
107
+ value: content,
108
+ onChange: function onChange(e) {
109
+ if (!readonly) {
110
+ handleAddContent(e);
111
+ }
112
+ }
113
+ }))
114
+ });
115
+ };
@@ -0,0 +1,7 @@
1
+ .editor-code-type {
2
+ width: 100%;
3
+
4
+ .editor-code {
5
+ width: 80%;
6
+ }
7
+ }
@@ -23,7 +23,10 @@
23
23
  clip-path: polygon(20% 0%, 0% 20%, 30% 50%, 0% 80%, 20% 100%, 50% 70%, 80% 100%, 100% 80%, 70% 50%, 100% 20%, 80% 0%, 50% 30%);
24
24
  }
25
25
 
26
- &__text {
26
+ &__text,
27
+ &__question,
28
+ &__accordion,
29
+ &__code {
27
30
  padding-bottom: 24px;
28
31
  }
29
32
 
@@ -16,6 +16,8 @@ var _ImgArticle = require("../ImgArticle/ImgArticle");
16
16
  var _FormBtn = require("../FormBtn/FormBtn");
17
17
  var _VideoArticle = require("../VideoArticle/VideoArticle");
18
18
  var _QuestionAnswer = require("../QuestionAnswer/QuestionAnswer");
19
+ var _Code = require("../Code/Code");
20
+ var _Accordion = require("../Accordion/Accordion");
19
21
  var _headers = _interopRequireDefault(require("../../../common/headers"));
20
22
  require("./SelectedBlocks.scss");
21
23
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
@@ -286,6 +288,8 @@ var SelectedBlocks = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
286
288
  if (block_type == 'question') return /*#__PURE__*/_react["default"].createElement(_QuestionAnswer.QuestionAnswer, _extends({
287
289
  editMode: true
288
290
  }, commonProps));
291
+ if (block_type == 'accordion') return /*#__PURE__*/_react["default"].createElement(_Accordion.Accordion, commonProps);
292
+ if (block_type == 'code') return /*#__PURE__*/_react["default"].createElement(_Code.Code, commonProps);
289
293
  })));
290
294
  });
291
295
  var _default = exports["default"] = SelectedBlocks;
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.EditorCode = void 0;
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ var _react2 = _interopRequireDefault(require("@monaco-editor/react"));
10
+ var _monacoJsxHighlighter = _interopRequireDefault(require("monaco-jsx-highlighter"));
11
+ var _parser = require("@babel/parser");
12
+ var _traverse = _interopRequireDefault(require("@babel/traverse"));
13
+ require("./EditorCode.scss");
14
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
15
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
16
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
17
+ var EditorCode = exports.EditorCode = function EditorCode(_ref) {
18
+ var value = _ref.value,
19
+ children = _ref.children,
20
+ onReset = _ref.onReset,
21
+ _ref$onChange = _ref.onChange,
22
+ _onChange = _ref$onChange === void 0 ? function () {} : _ref$onChange;
23
+ var editorRef = (0, _react.useRef)(null);
24
+ var handleEditorDidMount = function handleEditorDidMount(editor, monaco) {
25
+ editorRef.current = editor;
26
+
27
+ // Настройка опций компилятора для поддержки JSX
28
+ monaco.languages.typescript.javascriptDefaults.setCompilerOptions({
29
+ jsx: monaco.languages.typescript.JsxEmit.Preserve,
30
+ target: monaco.languages.typescript.ScriptTarget.ESNext,
31
+ allowNonTsExtensions: true,
32
+ moduleResolution: monaco.languages.typescript.ModuleResolutionKind.NodeJs,
33
+ module: monaco.languages.typescript.ModuleKind.ESNext,
34
+ noEmit: true,
35
+ esModuleInterop: true,
36
+ allowJs: true
37
+ });
38
+
39
+ // Создание модели с расширением .jsx для поддержки JSX
40
+ var model = monaco.editor.createModel(value, 'javascript', monaco.Uri.parse('file:///main.jsx'));
41
+ editor.setModel(model);
42
+
43
+ // Подключение подсветки JSX с помощью monaco-jsx-highlighter
44
+ var babelParse = function babelParse(code) {
45
+ return (0, _parser.parse)(code, {
46
+ sourceType: 'module',
47
+ plugins: ['jsx']
48
+ });
49
+ };
50
+ var monacoJSXHighlighter = new _monacoJsxHighlighter["default"](monaco, babelParse, _traverse["default"], editor);
51
+ monacoJSXHighlighter.highlightOnDidChangeModelContent(100);
52
+ monacoJSXHighlighter.addJSXCommentCommand();
53
+ };
54
+ return /*#__PURE__*/_react["default"].createElement("div", {
55
+ className: "editor-code"
56
+ }, children, /*#__PURE__*/_react["default"].createElement(_react2["default"], {
57
+ height: "400px",
58
+ defaultLanguage: "javascript",
59
+ onMount: handleEditorDidMount,
60
+ theme: "vs-dark",
61
+ onChange: function onChange(e) {
62
+ return _onChange(e);
63
+ }
64
+ }));
65
+ };
@@ -0,0 +1,5 @@
1
+ .editor-code {
2
+ width: 100%;
3
+ border-radius: 8px;
4
+ overflow: hidden;
5
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ecomlab-components-next",
3
- "version": "0.1.82",
3
+ "version": "0.1.83",
4
4
  "description": "A set of common and reusable React components",
5
5
  "main": "dist/index.js",
6
6
  "files": [
@@ -19,6 +19,7 @@
19
19
  "build:lib": "babel src --out-dir dist --copy-files"
20
20
  },
21
21
  "dependencies": {
22
+ "@monaco-editor/react": "^4.7.0",
22
23
  "@types/styled-components": "^5.1.34",
23
24
  "chart.js": "^4.4.7",
24
25
  "deep-equal": "^2.2.3",
@@ -30,7 +31,9 @@
30
31
  "react-spinners": "^0.15.0",
31
32
  "sass": "^1.55.0",
32
33
  "styled-components": "^6.1.14",
33
- "universal-cookie": "^7.2.2"
34
+ "universal-cookie": "^7.2.2",
35
+ "monaco-editor": "^0.52.2",
36
+ "monaco-jsx-highlighter": "^2.77.77"
34
37
  },
35
38
  "devDependencies": {
36
39
  "@babel/cli": "^7.26.4",
@@ -64,4 +67,4 @@
64
67
  "plugin:storybook/recommended"
65
68
  ]
66
69
  }
67
- }
70
+ }