ecomlab-components-next 0.1.82 → 0.1.84
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/dist/components/AccordionItem/AccordionItem.js +39 -0
- package/dist/components/AccordionItem/AccordionItem.scss +64 -0
- package/dist/components/Article/Accordion/Accordion.js +184 -0
- package/dist/components/Article/Accordion/Accordion.scss +26 -0
- package/dist/components/Article/ArticleViewV2/ArticleViewV2.stories.js +21 -0
- package/dist/components/Article/Code/Code.js +115 -0
- package/dist/components/Article/Code/Code.scss +7 -0
- package/dist/components/Article/EditWrapper/EditWrapper.scss +4 -1
- package/dist/components/Article/SelectedBlocks/SelectedBlocks.js +4 -0
- package/dist/components/ArticleElements/ShortTileArticleBox/ShortTileArticleBox.stories.js +1 -1
- package/dist/components/EditorCode/EditorCode.js +65 -0
- package/dist/components/EditorCode/EditorCode.scss +5 -0
- package/dist/components/Inputs/InputDinamycPlaceholder/InputDinamycPlaceholder.js +85 -32
- package/dist/components/Inputs/InputDinamycPlaceholder/InputDinamycPlaceholder.stories.js +3 -7
- package/package.json +6 -1
|
@@ -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
|
+
};
|
|
@@ -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;
|
|
@@ -18,7 +18,7 @@ var _default = exports["default"] = {
|
|
|
18
18
|
annotation: 'Когда селлер, торгующий на маркетплейсе, становится популярнее, ему приходится ежедневно обрабатывать… Когда селлер, торгующий на маркетплейсе, становится популярнее, ему приходится ежедневно обрабатывать…',
|
|
19
19
|
photoPreview: ['https://assets.cdn.personio.de/career-site/header/43501/28ed0d8a9de664d5fdcd5314facf8b51png', 'https://www.rollingstone.com/wp-content/uploads/2018/06/rs-186804-peripheryjeremysaffer.jpg'],
|
|
20
20
|
tags: ['какой-то тэг', 'какой-то тэг'],
|
|
21
|
-
date:
|
|
21
|
+
date: "14 апреля 2025",
|
|
22
22
|
timeToRead: 100500,
|
|
23
23
|
views: 15,
|
|
24
24
|
statusArray: ["https://dl.ecomru.ru/svg-storage/icon-waiting.svg", "Update"],
|
|
@@ -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
|
+
};
|
|
@@ -1,17 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
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
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports["default"] = void 0;
|
|
8
|
-
var _react =
|
|
7
|
+
var _react = require("react");
|
|
9
8
|
var _imask = _interopRequireDefault(require("imask"));
|
|
9
|
+
var _libphonenumberJs = require("libphonenumber-js");
|
|
10
10
|
require("./InputDinamycPlaceholder.scss");
|
|
11
|
-
var _excluded = ["tooltip", "tooltipStatic", "rows", "changeValue", "setChangeValue", "classname", "placeholder", "type", "onChange", "passwordTooltip", "err", "textErr", "infoHeader", "info", "autoComplete", "disabled", "showClearIndicator", "multiline", "maxLength", "autoFocus", "variant", "size", "maxlength", "required", "onBlur", "mask", "readOnly"];
|
|
11
|
+
var _excluded = ["tooltip", "tooltipStatic", "rows", "changeValue", "setChangeValue", "classname", "placeholder", "type", "onChange", "passwordTooltip", "err", "textErr", "infoHeader", "info", "autoComplete", "disabled", "showClearIndicator", "multiline", "maxLength", "autoFocus", "variant", "size", "maxlength", "required", "onBlur", "mask", "readOnly", "countrySelect"];
|
|
12
12
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
|
|
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
13
|
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
16
14
|
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."); }
|
|
17
15
|
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; } }
|
|
@@ -62,6 +60,8 @@ var InputDinamycPlaceholder = function InputDinamycPlaceholder(_ref) {
|
|
|
62
60
|
mask = _ref$mask === void 0 ? null : _ref$mask,
|
|
63
61
|
_ref$readOnly = _ref.readOnly,
|
|
64
62
|
readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
|
|
63
|
+
_ref$countrySelect = _ref.countrySelect,
|
|
64
|
+
countrySelect = _ref$countrySelect === void 0 ? false : _ref$countrySelect,
|
|
65
65
|
props = _objectWithoutProperties(_ref, _excluded);
|
|
66
66
|
var _useState = (0, _react.useState)(false),
|
|
67
67
|
_useState2 = _slicedToArray(_useState, 2),
|
|
@@ -79,8 +79,45 @@ var InputDinamycPlaceholder = function InputDinamycPlaceholder(_ref) {
|
|
|
79
79
|
_useState8 = _slicedToArray(_useState7, 2),
|
|
80
80
|
isFocus = _useState8[0],
|
|
81
81
|
setIsFocus = _useState8[1];
|
|
82
|
+
var _useState9 = (0, _react.useState)('RU'),
|
|
83
|
+
_useState10 = _slicedToArray(_useState9, 2),
|
|
84
|
+
country = _useState10[0],
|
|
85
|
+
setCountry = _useState10[1]; // По умолчанию Россия
|
|
82
86
|
var inputRef = (0, _react.useRef)(null);
|
|
83
87
|
var maskRef = (0, _react.useRef)(null);
|
|
88
|
+
|
|
89
|
+
// Список всех стран
|
|
90
|
+
var countries = (0, _libphonenumberJs.getCountries)();
|
|
91
|
+
|
|
92
|
+
// Обработчик изменения страны
|
|
93
|
+
var handleCountryChange = function handleCountryChange(e) {
|
|
94
|
+
var newCountry = e.target.value;
|
|
95
|
+
setCountry(newCountry);
|
|
96
|
+
|
|
97
|
+
// Обновляем маску для IMask
|
|
98
|
+
if (type === 'tel' && inputRef.current) {
|
|
99
|
+
var code = (0, _libphonenumberJs.getCountryCallingCode)(newCountry);
|
|
100
|
+
var newMask = {
|
|
101
|
+
mask: "+".concat(code, " (000) 000-00-00")
|
|
102
|
+
}; // Пример маски для России
|
|
103
|
+
|
|
104
|
+
if (maskRef.current) {
|
|
105
|
+
maskRef.current.destroy();
|
|
106
|
+
}
|
|
107
|
+
maskRef.current = (0, _imask["default"])(inputRef.current, newMask);
|
|
108
|
+
maskRef.current.on('accept', function () {
|
|
109
|
+
setValueInside(maskRef.current.value);
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
// Получаем полное название страны по коду
|
|
115
|
+
var getCountryName = function getCountryName(code) {
|
|
116
|
+
var country = countries[code];
|
|
117
|
+
return country ? country.name : code; // Если страны нет в списке, вернём код
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
// Обработчик размытия поля
|
|
84
121
|
var handleBlur = function handleBlur() {
|
|
85
122
|
if (onBlur) onBlur(valueInside);
|
|
86
123
|
};
|
|
@@ -94,33 +131,49 @@ var InputDinamycPlaceholder = function InputDinamycPlaceholder(_ref) {
|
|
|
94
131
|
}, [changeValue]);
|
|
95
132
|
(0, _react.useEffect)(function () {
|
|
96
133
|
if (type === 'tel' && inputRef.current) {
|
|
134
|
+
var code = (0, _libphonenumberJs.getCountryCallingCode)(country);
|
|
97
135
|
var maskOptions = {
|
|
98
|
-
mask:
|
|
136
|
+
mask: "+".concat(code, " (000) 000-00-00")
|
|
99
137
|
};
|
|
100
138
|
maskRef.current = (0, _imask["default"])(inputRef.current, maskOptions);
|
|
101
139
|
maskRef.current.on('accept', function () {
|
|
102
140
|
setValueInside(maskRef.current.value);
|
|
103
141
|
});
|
|
104
142
|
return function () {
|
|
105
|
-
|
|
143
|
+
var _maskRef$current;
|
|
144
|
+
return (_maskRef$current = maskRef.current) === null || _maskRef$current === void 0 ? void 0 : _maskRef$current.destroy();
|
|
106
145
|
};
|
|
107
146
|
}
|
|
108
|
-
}, [type]);
|
|
147
|
+
}, [type, country]);
|
|
148
|
+
|
|
149
|
+
// Обновление значения из props
|
|
109
150
|
(0, _react.useEffect)(function () {
|
|
110
|
-
|
|
111
|
-
maskRef.current.value = changeValue || '';
|
|
112
|
-
maskRef.current.updateValue();
|
|
113
|
-
}
|
|
151
|
+
setValueInside(changeValue || '');
|
|
114
152
|
}, [changeValue]);
|
|
115
|
-
return /*#__PURE__*/
|
|
153
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
116
154
|
className: "input-dinamyc-placeholder",
|
|
117
155
|
style: {
|
|
118
156
|
width: '100%',
|
|
119
157
|
marginBottom: tooltip ? '24px' : ''
|
|
120
158
|
}
|
|
121
|
-
}, /*#__PURE__*/
|
|
122
|
-
|
|
123
|
-
|
|
159
|
+
}, countrySelect && /*#__PURE__*/React.createElement("select", {
|
|
160
|
+
value: country,
|
|
161
|
+
onChange: handleCountryChange,
|
|
162
|
+
style: {
|
|
163
|
+
marginRight: '10px',
|
|
164
|
+
padding: '8px',
|
|
165
|
+
borderRadius: '4px',
|
|
166
|
+
border: '1px solid #ccc',
|
|
167
|
+
marginBottom: '12px'
|
|
168
|
+
}
|
|
169
|
+
}, countries.map(function (countryCode) {
|
|
170
|
+
return /*#__PURE__*/React.createElement("option", {
|
|
171
|
+
key: countryCode,
|
|
172
|
+
value: countryCode
|
|
173
|
+
}, getCountryName(countryCode), " (+", (0, _libphonenumberJs.getCountryCallingCode)(countryCode), ")");
|
|
174
|
+
})), /*#__PURE__*/React.createElement("div", {
|
|
175
|
+
className: "".concat(err ? 'input-box__err' : 'input-box', " ").concat(size === 's' ? 'size-s' : 'size-l', " ").concat(disabled ? 'input-box_disabled' : '')
|
|
176
|
+
}, /*#__PURE__*/React.createElement("input", {
|
|
124
177
|
ref: inputRef,
|
|
125
178
|
className: "input-dynamic",
|
|
126
179
|
maxLength: maxlength,
|
|
@@ -148,46 +201,46 @@ var InputDinamycPlaceholder = function InputDinamycPlaceholder(_ref) {
|
|
|
148
201
|
disabled: disabled,
|
|
149
202
|
required: required,
|
|
150
203
|
size: size
|
|
151
|
-
}), placeholder && /*#__PURE__*/
|
|
204
|
+
}), placeholder && /*#__PURE__*/React.createElement("div", {
|
|
152
205
|
className: valueInside.length > 0 || isFocus ? 'placeholder-dinamyc_min-blue' : 'placeholder-dinamyc'
|
|
153
|
-
}, /*#__PURE__*/
|
|
206
|
+
}, /*#__PURE__*/React.createElement("label", null, placeholder, required && /*#__PURE__*/React.createElement("span", {
|
|
154
207
|
style: {
|
|
155
208
|
color: 'red'
|
|
156
209
|
}
|
|
157
|
-
}, " *"))), /*#__PURE__*/
|
|
210
|
+
}, " *"))), /*#__PURE__*/React.createElement("div", {
|
|
158
211
|
className: "input-box__clean-value"
|
|
159
|
-
}, showClearIndicator && (valueInside === null || valueInside === void 0 ? void 0 : valueInside.length) > 0 && /*#__PURE__*/
|
|
212
|
+
}, showClearIndicator && (valueInside === null || valueInside === void 0 ? void 0 : valueInside.length) > 0 && /*#__PURE__*/React.createElement("button", {
|
|
160
213
|
className: "btn__clean",
|
|
161
214
|
onClick: function onClick() {
|
|
162
215
|
return setValueInside('');
|
|
163
216
|
}
|
|
164
|
-
}), type === 'password' && /*#__PURE__*/
|
|
217
|
+
}), type === 'password' && /*#__PURE__*/React.createElement("button", {
|
|
165
218
|
className: "btn__".concat(hidePassword ? 'show' : 'hide'),
|
|
166
219
|
onClick: function onClick() {
|
|
167
220
|
return setHidePassword(!hidePassword);
|
|
168
221
|
}
|
|
169
|
-
}), info && !err && showInfo && /*#__PURE__*/
|
|
222
|
+
}), info && !err && showInfo && /*#__PURE__*/React.createElement("div", {
|
|
170
223
|
className: "input-box__info"
|
|
171
|
-
}, /*#__PURE__*/
|
|
224
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
172
225
|
className: "tooltip-box"
|
|
173
|
-
}, /*#__PURE__*/
|
|
226
|
+
}, /*#__PURE__*/React.createElement("button", {
|
|
174
227
|
className: "btn__info",
|
|
175
228
|
disabled: true
|
|
176
|
-
}), /*#__PURE__*/
|
|
229
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
177
230
|
className: "tooltip"
|
|
178
|
-
}, /*#__PURE__*/
|
|
231
|
+
}, /*#__PURE__*/React.createElement("h6", {
|
|
179
232
|
className: "title"
|
|
180
|
-
}, infoHeader), /*#__PURE__*/
|
|
233
|
+
}, infoHeader), /*#__PURE__*/React.createElement("p", {
|
|
181
234
|
className: "text"
|
|
182
|
-
}, info))))), err ? /*#__PURE__*/
|
|
235
|
+
}, info))))), err ? /*#__PURE__*/React.createElement("div", {
|
|
183
236
|
className: "err"
|
|
184
|
-
}, /*#__PURE__*/
|
|
237
|
+
}, /*#__PURE__*/React.createElement("p", {
|
|
185
238
|
className: "text_red"
|
|
186
|
-
}, textErr)) : /*#__PURE__*/
|
|
239
|
+
}, textErr)) : /*#__PURE__*/React.createElement("div", {
|
|
187
240
|
className: "err"
|
|
188
|
-
}, /*#__PURE__*/
|
|
241
|
+
}, /*#__PURE__*/React.createElement("p", {
|
|
189
242
|
className: "text_tooltip"
|
|
190
|
-
}, tooltip))), tooltipStatic && /*#__PURE__*/
|
|
243
|
+
}, tooltip))), tooltipStatic && /*#__PURE__*/React.createElement("p", {
|
|
191
244
|
className: "text_tooltip-mui"
|
|
192
245
|
}, tooltipStatic));
|
|
193
246
|
};
|
|
@@ -7,10 +7,6 @@ exports["default"] = exports.Default = void 0;
|
|
|
7
7
|
var _InputDinamycPlaceholder = _interopRequireDefault(require("./InputDinamycPlaceholder.js"));
|
|
8
8
|
var _addonActions = require("@storybook/addon-actions");
|
|
9
9
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
|
|
10
|
-
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); }
|
|
11
|
-
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; }
|
|
12
|
-
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
13
|
-
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); }
|
|
14
10
|
var _default = exports["default"] = {
|
|
15
11
|
title: 'Input dinamyc placeholder',
|
|
16
12
|
component: _InputDinamycPlaceholder["default"],
|
|
@@ -19,7 +15,7 @@ var _default = exports["default"] = {
|
|
|
19
15
|
control: 'date'
|
|
20
16
|
}
|
|
21
17
|
},
|
|
22
|
-
args:
|
|
18
|
+
args: {
|
|
23
19
|
tooltip: 'Подсказка',
|
|
24
20
|
tooltipStatic: false,
|
|
25
21
|
rows: false,
|
|
@@ -29,7 +25,7 @@ var _default = exports["default"] = {
|
|
|
29
25
|
setValue: _addonActions.action,
|
|
30
26
|
classname: false,
|
|
31
27
|
placeholder: 'Value',
|
|
32
|
-
type: '
|
|
28
|
+
type: 'tel',
|
|
33
29
|
onChange: _addonActions.action,
|
|
34
30
|
passwordTooltip: true,
|
|
35
31
|
err: false,
|
|
@@ -45,6 +41,6 @@ var _default = exports["default"] = {
|
|
|
45
41
|
variant: 'filled',
|
|
46
42
|
size: 'l',
|
|
47
43
|
required: true
|
|
48
|
-
}
|
|
44
|
+
}
|
|
49
45
|
};
|
|
50
46
|
var Default = exports.Default = {};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ecomlab-components-next",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.84",
|
|
4
4
|
"description": "A set of common and reusable React components",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"files": [
|
|
@@ -19,9 +19,14 @@
|
|
|
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",
|
|
25
|
+
"country-data": "^0.0.31",
|
|
24
26
|
"deep-equal": "^2.2.3",
|
|
27
|
+
"libphonenumber-js": "^1.12.7",
|
|
28
|
+
"monaco-editor": "^0.52.2",
|
|
29
|
+
"monaco-jsx-highlighter": "^2.77.77",
|
|
25
30
|
"next": "15.1.5",
|
|
26
31
|
"react": "^19.0.0",
|
|
27
32
|
"react-chartjs-2": "^5.3.0",
|