@bigbinary/neeto-molecules 3.5.2-beta → 3.5.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -9,6 +9,7 @@ var neetoCist = require('@bigbinary/neeto-cist');
9
9
  var reactUtils = require('@bigbinary/neeto-commons-frontend/react-utils');
10
10
  var Collapse = require('@bigbinary/neeto-icons/Collapse');
11
11
  var Button = require('@bigbinary/neetoui/Button');
12
+ var ramda = require('ramda');
12
13
  var _defineProperty = require('@babel/runtime/helpers/defineProperty');
13
14
  var general = require('@bigbinary/neeto-commons-frontend/utils/general');
14
15
  var Search = require('@bigbinary/neeto-icons/Search');
@@ -18,9 +19,8 @@ var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProp
18
19
  var injectCss = require('./inject-css-80a5faa3.js');
19
20
  var jsxRuntime = require('react/jsx-runtime');
20
21
  var Typography = require('@bigbinary/neetoui/Typography');
21
- var ramda = require('ramda');
22
- var dnd = require('@hello-pangea/dnd');
23
22
  var Tooltip = require('@bigbinary/neetoui/Tooltip');
23
+ var dnd = require('@hello-pangea/dnd');
24
24
  var MoreDropdown = require('./MoreDropdown.js');
25
25
  var constants = require('@bigbinary/neeto-commons-frontend/constants');
26
26
  var Flash = require('@bigbinary/neeto-icons/Flash');
@@ -48,9 +48,6 @@ var Close__default = /*#__PURE__*/_interopDefaultLegacy(Close);
48
48
  var withT__default = /*#__PURE__*/_interopDefaultLegacy(withT);
49
49
  var DownArrow__default = /*#__PURE__*/_interopDefaultLegacy(DownArrow);
50
50
 
51
- var SELECTED_ELEMENTS_LIST_DROPPABLE_ID = "droppable-selected-question-container";
52
- var PREVIEW_CONTAINER_DROPPABLE_ID = "droppable-form-preview-container";
53
-
54
51
  var css = ":root{--neeto-molecule-builder-left-sidebar-width:288px;--neeto-molecule-builder-left-sidebar-width-lg:360px;--neeto-molecule-builder-left-sidebar-header-height:70px;--neeto-molecule-builder-left-sidebar-search-height:40px;--neeto-molecule-builder-right-sidebar-width:420px}.neeto-molecules-builder-elements-list-panel__wrapper{height:100%;min-width:360px;min-width:var(--neeto-molecule-builder-left-sidebar-width-lg);position:relative;transition:all .15s;width:360px;width:var(--neeto-molecule-builder-left-sidebar-width-lg);z-index:101}@media screen and (min-width:768px) and (max-width:1279px){.neeto-molecules-builder-elements-list-panel__wrapper{min-width:288px;min-width:var(--neeto-molecule-builder-left-sidebar-width);width:288px;width:var(--neeto-molecule-builder-left-sidebar-width)}}@media screen and (max-width:767px){.neeto-molecules-builder-elements-list-panel__wrapper{left:0;position:fixed;top:0;transition:none}}@media screen and (max-width:576px){.neeto-molecules-builder-elements-list-panel__wrapper{height:100%;max-width:100%;min-width:0;width:100%}}.neeto-molecules-builder-elements-list-panel__wrapper--collapsed{max-width:0;min-width:0;width:0}.neeto-molecules-builder-elements-list-panel__wrapper--collapsed .neeto-molecules-builder-elements-list-panel__toggler{transform:scale(-1)}@media screen and (max-width:767px){.neeto-molecules-builder-elements-list-panel__wrapper--collapsed .neeto-molecules-builder-elements-list-panel__toggler{top:109px}}@media screen and (max-width:576px){.neeto-molecules-builder-elements-list-panel__wrapper--collapsed .neeto-molecules-builder-elements-list-panel__toggler{left:8px;right:auto}}.neeto-molecules-builder-elements-list-panel__container{height:100%;overflow:hidden;width:100%}.neeto-molecules-builder-elements-list-panel{border-right:1px solid rgb(var(--neeto-ui-gray-200));height:100%;min-width:360px;min-width:var(--neeto-molecule-builder-left-sidebar-width-lg);width:360px;width:var(--neeto-molecule-builder-left-sidebar-width-lg)}@media screen and (min-width:768px) and (max-width:1279px){.neeto-molecules-builder-elements-list-panel{min-width:288px;min-width:var(--neeto-molecule-builder-left-sidebar-width);width:288px;width:var(--neeto-molecule-builder-left-sidebar-width)}}@media screen and (max-width:576px){.neeto-molecules-builder-elements-list-panel{padding-top:24px;width:100%}}.neeto-molecules-builder-elements-list-panel__toggler{flex-shrink:0;left:calc(100% + 8px);position:absolute;top:8px;transition:color .3s ease-in-out}@media screen and (min-width:1024px){.neeto-molecules-builder-elements-list-panel__toggler{opacity:0;pointer-events:none}}@media screen and (max-width:576px){.neeto-molecules-builder-elements-list-panel__toggler{left:24px}}.neeto-molecules-builder-questions-list-panel__scroll{height:calc(100% - 70px);height:calc(100% - var(--neeto-molecule-builder-left-sidebar-header-height));overflow-y:auto;padding:8px 24px;width:100%}.neeto-molecules-builder-questions-list-panel__scroll.neeto-molecules-builder-questions-list-panel__scroll--small{height:calc(100% - 110px);height:calc(100% - var(--neeto-molecule-builder-left-sidebar-header-height) - var(--neeto-molecule-builder-left-sidebar-search-height))}.neeto-molecules-builder-element-properties-panel__wrapper{border-left:1px solid rgb(var(--neeto-ui-gray-200));height:100%;min-width:420px;min-width:var(--neeto-molecule-builder-right-sidebar-width);position:relative;transition:all .15s;width:420px;width:var(--neeto-molecule-builder-right-sidebar-width);z-index:101}.neeto-molecules-builder-element-properties-panel__wrapper .neeto-molecules-builder-properties-panel__close{opacity:0;pointer-events:none;position:absolute;right:8px;top:8px}@media screen and (max-width:1279px){.neeto-molecules-builder-element-properties-panel__wrapper .neeto-molecules-builder-properties-panel__close{opacity:1;pointer-events:all}.neeto-molecules-builder-element-properties-panel__wrapper{position:fixed;right:0;top:0;transition:none}}@media screen and (max-width:576px){.neeto-molecules-builder-element-properties-panel__wrapper{height:100%;max-width:100%;min-width:0;width:100%}}.neeto-molecules-builder-element-properties-panel__wrapper--collapsed{max-width:0;min-width:0;width:0}.neeto-molecules-builder-element-properties-panel{display:flex;flex-direction:column;height:100%;min-width:0;overflow-y:auto;padding-left:24px;padding-top:24px;width:100%}.neeto-molecules-builder-element-properties-panel--collapsed{max-width:0;min-width:0;padding:0;width:0}@media screen and (max-width:1279px){.neeto-molecules-builder-element-properties-panel{padding-top:48px}}.neeto-molecules-builder-element--active{border-color:rgb(var(--neeto-ui-primary-500))!important;box-shadow:0 0 0 1px rgb(var(--neeto-ui-primary-500))!important}.neeto-molecules-builder-panel__backdrop{background-color:rgba(var(--neeto-ui-black),.4);display:none;height:100%;left:0;position:fixed;top:0;visibility:hidden;width:100%;z-index:101}@media screen and (max-width:767px){.neeto-molecules-builder-panel__backdrop{display:block;visibility:visible}}@media screen and (max-width:1279px){.neeto-molecules-builder-panel__backdrop--extended{display:block;visibility:visible}}";
55
52
  injectCss.n(css,{});
56
53
 
@@ -67,55 +64,26 @@ var Body = function Body(_ref) {
67
64
  }));
68
65
  };
69
66
 
70
- var _excluded$1 = ["size"];
71
- function ownKeys$3(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; }
72
- function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$3(Object(t), !0).forEach(function (r) { _defineProperty__default["default"](e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$3(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
73
- var DragIcon = function DragIcon(_ref) {
74
- var _ref$size = _ref.size,
75
- size = _ref$size === void 0 ? 16 : _ref$size,
76
- otherProps = _objectWithoutProperties__default["default"](_ref, _excluded$1);
77
- return /*#__PURE__*/jsxRuntime.jsx("svg", _objectSpread$3(_objectSpread$3({
78
- fill: "currentColor",
79
- height: size,
80
- viewBox: "0 -960 960 960",
81
- width: size,
82
- xmlns: "http://www.w3.org/2000/svg"
83
- }, otherProps), {}, {
84
- children: /*#__PURE__*/jsxRuntime.jsx("path", {
85
- d: "M360-160q-33 0-56.5-23.5T280-240q0-33 23.5-56.5T360-320q33 0 56.5 23.5T440-240q0 33-23.5 56.5T360-160zm240 0q-33 0-56.5-23.5T520-240q0-33 23.5-56.5T600-320q33 0 56.5 23.5T680-240q0 33-23.5 56.5T600-160zM360-400q-33 0-56.5-23.5T280-480q0-33 23.5-56.5T360-560q33 0 56.5 23.5T440-480q0 33-23.5 56.5T360-400zm240 0q-33 0-56.5-23.5T520-480q0-33 23.5-56.5T600-560q33 0 56.5 23.5T680-480q0 33-23.5 56.5T600-400zM360-640q-33 0-56.5-23.5T280-720q0-33 23.5-56.5T360-800q33 0 56.5 23.5T440-720q0 33-23.5 56.5T360-640zm240 0q-33 0-56.5-23.5T520-720q0-33 23.5-56.5T600-800q33 0 56.5 23.5T680-720q0 33-23.5 56.5T600-640z"
86
- })
87
- }));
88
- };
89
-
90
67
  var Element = function Element(_ref) {
91
68
  var label = _ref.label,
92
69
  Icon = _ref.icon,
93
70
  _ref$isCreatable = _ref.isCreatable,
94
71
  isCreatable = _ref$isCreatable === void 0 ? true : _ref$isCreatable,
95
72
  onClick = _ref.onClick,
96
- _ref$isDragDisabled = _ref.isDragDisabled,
97
- isDragDisabled = _ref$isDragDisabled === void 0 ? false : _ref$isDragDisabled,
98
- disabledElementTooltip = _ref.disabledElementTooltip,
99
- isPlaceholder = _ref.isPlaceholder;
73
+ disabledElementTooltip = _ref.disabledElementTooltip;
100
74
  return /*#__PURE__*/jsxRuntime.jsx(Tooltip__default["default"], {
101
75
  content: disabledElementTooltip === null || disabledElementTooltip === void 0 ? void 0 : disabledElementTooltip(label),
102
76
  disabled: !disabledElementTooltip || isCreatable,
103
77
  position: "top",
104
78
  touch: ["hold", 500],
105
- children: /*#__PURE__*/jsxRuntime.jsxs("div", {
79
+ children: /*#__PURE__*/jsxRuntime.jsx("div", {
106
80
  "data-cy": "add-".concat(general.joinHyphenCase(label), "-element"),
107
- className: classnames__default["default"]("neeto-ui-border-gray-400 neeto-ui-bg-white hover:neeto-ui-bg-gray-200 neeto-ui-rounded-lg relative mb-2 flex h-10 items-center gap-2 border p-3 transition-all duration-300 ease-in-out", {
81
+ className: classnames__default["default"]("neeto-ui-border-gray-400 neeto-ui-bg-white hover:neeto-ui-bg-gray-200 neeto-ui-rounded-lg mb-2 flex h-10 items-center gap-2 border p-3 transition-all duration-300 ease-in-out", {
108
82
  "neeto-ui-bg-gray-300 cursor-not-allowed": !isCreatable,
109
- "cursor-pointer": isCreatable,
110
- "opacity-50": isPlaceholder
83
+ "cursor-pointer": isCreatable
111
84
  }),
112
85
  onClick: isCreatable ? onClick : neetoCist.noop,
113
- children: [!isDragDisabled && /*#__PURE__*/jsxRuntime.jsx("span", {
114
- className: "absolute right-full top-1/2 flex-shrink-0 -translate-y-1/2 cursor-grab",
115
- children: /*#__PURE__*/jsxRuntime.jsx(DragIcon, {
116
- size: 16
117
- })
118
- }), /*#__PURE__*/jsxRuntime.jsxs("div", {
86
+ children: /*#__PURE__*/jsxRuntime.jsxs("div", {
119
87
  className: "flex flex-grow items-center gap-2",
120
88
  children: [Icon && /*#__PURE__*/jsxRuntime.jsx(Icon, {
121
89
  "data-cy": "form-icon"
@@ -124,79 +92,19 @@ var Element = function Element(_ref) {
124
92
  style: "body2",
125
93
  children: label
126
94
  })]
127
- })]
95
+ })
128
96
  })
129
97
  });
130
98
  };
131
99
 
132
- function ownKeys$2(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; }
133
- function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$2(Object(t), !0).forEach(function (r) { _defineProperty__default["default"](e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$2(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
134
- var ElementContainer = function ElementContainer(_ref) {
135
- var index = _ref.index,
136
- isDragDisabled = _ref.isDragDisabled,
137
- element = _ref.element,
138
- disabledElementTooltip = _ref.disabledElementTooltip,
139
- isCreatable = _ref.isCreatable,
140
- onSelect = _ref.onSelect;
141
- if (isDragDisabled) {
142
- return /*#__PURE__*/jsxRuntime.jsx(Element, _objectSpread$2(_objectSpread$2({}, _objectSpread$2(_objectSpread$2({}, element), {}, {
143
- disabledElementTooltip: disabledElementTooltip,
144
- isDragDisabled: isDragDisabled
145
- })), {}, {
146
- isCreatable: isCreatable(element.value),
147
- onClick: function onClick() {
148
- return onSelect(element);
149
- }
150
- }));
151
- }
152
- return /*#__PURE__*/React.createElement(dnd.Draggable, {
153
- index: index,
154
- isDragDisabled: isDragDisabled,
155
- draggableId: "".concat(element.value, "-").concat(index),
156
- key: element.label
157
- }, function (_ref2, _ref3) {
158
- var innerRef = _ref2.innerRef,
159
- draggableProps = _ref2.draggableProps,
160
- dragHandleProps = _ref2.dragHandleProps;
161
- var isDragging = _ref3.isDragging,
162
- isDropAnimating = _ref3.isDropAnimating;
163
- return /*#__PURE__*/jsxRuntime.jsxs(jsxRuntime.Fragment, {
164
- children: [/*#__PURE__*/jsxRuntime.jsx("div", _objectSpread$2(_objectSpread$2(_objectSpread$2({
165
- ref: innerRef
166
- }, draggableProps), dragHandleProps), {}, {
167
- style: _objectSpread$2(_objectSpread$2({}, draggableProps.style), isDropAnimating && {
168
- opacity: 0,
169
- transition: null
170
- }),
171
- children: /*#__PURE__*/jsxRuntime.jsx(Element, _objectSpread$2(_objectSpread$2({}, _objectSpread$2(_objectSpread$2({}, element), {}, {
172
- disabledElementTooltip: disabledElementTooltip,
173
- isDragDisabled: isDragDisabled
174
- })), {}, {
175
- isCreatable: isCreatable(element.value),
176
- onClick: function onClick() {
177
- return onSelect(element);
178
- }
179
- }))
180
- })), isDragging && /*#__PURE__*/jsxRuntime.jsx(Element, _objectSpread$2(_objectSpread$2({
181
- isPlaceholder: !isDropAnimating
182
- }, _objectSpread$2(_objectSpread$2({}, element), {}, {
183
- disabledElementTooltip: disabledElementTooltip
184
- })), {}, {
185
- isCreatable: false,
186
- onClick: neetoCist.noop
187
- }))]
188
- });
189
- });
190
- };
191
-
100
+ function ownKeys$3(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; }
101
+ function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$3(Object(t), !0).forEach(function (r) { _defineProperty__default["default"](e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$3(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
192
102
  var Section = function Section(_ref) {
193
103
  var title = _ref.title,
194
104
  elements = _ref.elements,
195
105
  onSelect = _ref.onSelect,
196
106
  isCreatable = _ref.isCreatable,
197
- disabledElementTooltip = _ref.disabledElementTooltip,
198
- isDragElementsDisabled = _ref.isDragElementsDisabled,
199
- sectionIndex = _ref.sectionIndex;
107
+ disabledElementTooltip = _ref.disabledElementTooltip;
200
108
  if (ramda.isEmpty(elements)) {
201
109
  return null;
202
110
  }
@@ -206,25 +114,28 @@ var Section = function Section(_ref) {
206
114
  style: "h6",
207
115
  textTransform: "uppercase",
208
116
  children: title
209
- }), elements.map(function (element, elementIndex) {
210
- var index = elementIndex + sectionIndex;
211
- return /*#__PURE__*/React.createElement(ElementContainer, {
212
- disabledElementTooltip: disabledElementTooltip,
213
- element: element,
214
- index: index,
215
- isCreatable: isCreatable,
216
- onSelect: onSelect,
217
- isDragDisabled: isDragElementsDisabled,
218
- key: element.label
219
- });
117
+ }), elements.map(function (element) {
118
+ return /*#__PURE__*/React.createElement(Element, _objectSpread$3(_objectSpread$3({}, _objectSpread$3(_objectSpread$3({}, element), {}, {
119
+ disabledElementTooltip: disabledElementTooltip
120
+ })), {}, {
121
+ isCreatable: isCreatable(element.value),
122
+ key: element.label,
123
+ onClick: function onClick() {
124
+ return onSelect(element);
125
+ }
126
+ }));
220
127
  })]
221
128
  });
222
129
  };
223
130
 
224
- var TitleBar$1 = reactUtils.withT(function (_ref) {
225
- var t = _ref.t,
226
- setIsSummaryPanelVisible = _ref.setIsSummaryPanelVisible,
131
+ var TitleBar$1 = function TitleBar(_ref) {
132
+ var setIsElementsListVisible = _ref.setIsElementsListVisible,
227
133
  isSelectedElementsEmpty = _ref.isSelectedElementsEmpty;
134
+ var _useTranslation = reactI18next.useTranslation(),
135
+ t = _useTranslation.t;
136
+ var onCancel = function onCancel() {
137
+ return setIsElementsListVisible(false);
138
+ };
228
139
  return /*#__PURE__*/jsxRuntime.jsxs("div", {
229
140
  className: "flex items-center justify-between p-6 pb-4",
230
141
  "data-testid": "elements-panel-title",
@@ -236,25 +147,22 @@ var TitleBar$1 = reactUtils.withT(function (_ref) {
236
147
  children: t("neetoMolecules.builderSidebar.addNewElement")
237
148
  }), !isSelectedElementsEmpty && /*#__PURE__*/jsxRuntime.jsx(Button__default["default"], {
238
149
  "data-cy": "cancel-button",
239
- label: t("neetoMolecules.builderSidebar.summary"),
150
+ label: t("neetoMolecules.builderSidebar.cancel"),
240
151
  size: "small",
241
152
  style: "text",
242
- onClick: function onClick() {
243
- return setIsSummaryPanelVisible(true);
244
- }
153
+ onClick: onCancel
245
154
  })]
246
155
  });
247
- });
156
+ };
248
157
 
249
- function ownKeys$1(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; }
250
- function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$1(Object(t), !0).forEach(function (r) { _defineProperty__default["default"](e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$1(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
158
+ function ownKeys$2(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; }
159
+ function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$2(Object(t), !0).forEach(function (r) { _defineProperty__default["default"](e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$2(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
251
160
  var ElementList = function ElementList(_ref) {
252
- var setIsSummaryPanelVisible = _ref.setIsSummaryPanelVisible,
161
+ var setIsElementsListVisible = _ref.setIsElementsListVisible,
253
162
  _ref$elementSections = _ref.elementSections,
254
163
  elementSections = _ref$elementSections === void 0 ? [] : _ref$elementSections,
255
164
  onSelect = _ref.onSelect,
256
- isSelectedElementsEmpty = _ref.isSelectedElementsEmpty,
257
- isDragElementsDisabled = _ref.isDragElementsDisabled;
165
+ isSelectedElementsEmpty = _ref.isSelectedElementsEmpty;
258
166
  var _useTranslation = reactI18next.useTranslation(),
259
167
  t = _useTranslation.t;
260
168
  var _useState = React.useState(""),
@@ -263,7 +171,7 @@ var ElementList = function ElementList(_ref) {
263
171
  setSearchString = _useState2[1];
264
172
  var filteredSections = React.useMemo(function () {
265
173
  return elementSections.map(function (section) {
266
- return _objectSpread$1(_objectSpread$1({}, section), {}, {
174
+ return _objectSpread$2(_objectSpread$2({}, section), {}, {
267
175
  elements: section.elements.filter(function (element) {
268
176
  return element.label.toLowerCase().includes(searchString.toLowerCase());
269
177
  })
@@ -275,7 +183,7 @@ var ElementList = function ElementList(_ref) {
275
183
  return /*#__PURE__*/jsxRuntime.jsxs(jsxRuntime.Fragment, {
276
184
  children: [/*#__PURE__*/jsxRuntime.jsx(TitleBar$1, {
277
185
  isSelectedElementsEmpty: isSelectedElementsEmpty,
278
- setIsSummaryPanelVisible: setIsSummaryPanelVisible
186
+ setIsElementsListVisible: setIsElementsListVisible
279
187
  }), /*#__PURE__*/jsxRuntime.jsx("div", {
280
188
  className: "mb-2 px-6",
281
189
  children: /*#__PURE__*/jsxRuntime.jsx(Input__default["default"], {
@@ -289,11 +197,9 @@ var ElementList = function ElementList(_ref) {
289
197
  }), /*#__PURE__*/jsxRuntime.jsx(Body, {
290
198
  "data-testid": "elements-container",
291
199
  size: "small",
292
- children: filteredSections.map(function (section, sectionIndex) {
200
+ children: filteredSections.map(function (section) {
293
201
  return /*#__PURE__*/React.createElement(Section, {
294
- isDragElementsDisabled: isDragElementsDisabled,
295
202
  onSelect: onSelect,
296
- sectionIndex: sectionIndex,
297
203
  disabledElementTooltip: section.disabledElementTooltip,
298
204
  elements: section.elements,
299
205
  isCreatable: section.isCreatable,
@@ -305,6 +211,26 @@ var ElementList = function ElementList(_ref) {
305
211
  });
306
212
  };
307
213
 
214
+ var _excluded$1 = ["size"];
215
+ function ownKeys$1(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; }
216
+ function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$1(Object(t), !0).forEach(function (r) { _defineProperty__default["default"](e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$1(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
217
+ var DragIcon = function DragIcon(_ref) {
218
+ var _ref$size = _ref.size,
219
+ size = _ref$size === void 0 ? 16 : _ref$size,
220
+ otherProps = _objectWithoutProperties__default["default"](_ref, _excluded$1);
221
+ return /*#__PURE__*/jsxRuntime.jsx("svg", _objectSpread$1(_objectSpread$1({
222
+ fill: "currentColor",
223
+ height: size,
224
+ viewBox: "0 -960 960 960",
225
+ width: size,
226
+ xmlns: "http://www.w3.org/2000/svg"
227
+ }, otherProps), {}, {
228
+ children: /*#__PURE__*/jsxRuntime.jsx("path", {
229
+ d: "M360-160q-33 0-56.5-23.5T280-240q0-33 23.5-56.5T360-320q33 0 56.5 23.5T440-240q0 33-23.5 56.5T360-160zm240 0q-33 0-56.5-23.5T520-240q0-33 23.5-56.5T600-320q33 0 56.5 23.5T680-240q0 33-23.5 56.5T600-160zM360-400q-33 0-56.5-23.5T280-480q0-33 23.5-56.5T360-560q33 0 56.5 23.5T440-480q0 33-23.5 56.5T360-400zm240 0q-33 0-56.5-23.5T520-480q0-33 23.5-56.5T600-560q33 0 56.5 23.5T680-480q0 33-23.5 56.5T600-400zM360-640q-33 0-56.5-23.5T280-720q0-33 23.5-56.5T360-800q33 0 56.5 23.5T440-720q0 33-23.5 56.5T360-640zm240 0q-33 0-56.5-23.5T520-720q0-33 23.5-56.5T600-800q33 0 56.5 23.5T680-720q0 33-23.5 56.5T600-640z"
230
+ })
231
+ }));
232
+ };
233
+
308
234
  var _excluded = ["element", "isActive", "handleSelectElement", "isSelectable", "errors", "actions", "isDraggable"];
309
235
  var SelectedElement = function SelectedElement(_ref) {
310
236
  var element = _ref.element,
@@ -383,14 +309,18 @@ var SelectedElement = function SelectedElement(_ref) {
383
309
  };
384
310
  var SelectedElement$1 = /*#__PURE__*/React.memo(SelectedElement);
385
311
 
386
- var TitleBar = reactUtils.withT(function (_ref) {
387
- var t = _ref.t,
388
- setIsSummaryPanelVisible = _ref.setIsSummaryPanelVisible,
312
+ var TitleBar = function TitleBar(_ref) {
313
+ var setIsElementsListVisible = _ref.setIsElementsListVisible,
389
314
  isLoading = _ref.isLoading,
390
315
  showElementsFillButton = _ref.showElementsFillButton,
391
316
  isAddingAllElements = _ref.isAddingAllElements,
392
317
  addAllElements = _ref.addAllElements,
393
318
  isAddingNewElement = _ref.isAddingNewElement;
319
+ var _useTranslation = reactI18next.useTranslation(),
320
+ t = _useTranslation.t;
321
+ var handleAddElement = function handleAddElement() {
322
+ return setIsElementsListVisible(true);
323
+ };
394
324
  return /*#__PURE__*/jsxRuntime.jsxs("div", {
395
325
  className: "flex items-center justify-between p-6 pb-4",
396
326
  "data-testid": "selected-elements-title",
@@ -406,13 +336,11 @@ var TitleBar = reactUtils.withT(function (_ref) {
406
336
  "data-cy": "add-element-button",
407
337
  "data-testid": "add-element-button",
408
338
  disabled: isLoading,
409
- label: t("neetoMolecules.common.actions.close"),
339
+ label: t("neetoMolecules.builderSidebar.addNewElement"),
410
340
  loading: isAddingNewElement,
411
341
  size: "small",
412
342
  style: "secondary",
413
- onClick: function onClick() {
414
- return setIsSummaryPanelVisible(false);
415
- }
343
+ onClick: handleAddElement
416
344
  }), showElementsFillButton && /*#__PURE__*/jsxRuntime.jsx(Button__default["default"], {
417
345
  "data-cy": "add-all-elements-button",
418
346
  disabled: isAddingAllElements,
@@ -428,17 +356,18 @@ var TitleBar = reactUtils.withT(function (_ref) {
428
356
  })]
429
357
  })]
430
358
  });
431
- });
359
+ };
432
360
 
433
361
  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; }
434
362
  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__default["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; }
435
363
  var SelectedElementsList = function SelectedElementsList(_ref) {
436
- var handleSelectElement = _ref.handleSelectElement,
437
- isReorderDisabled = _ref.isReorderDisabled,
364
+ var handleDragEnd = _ref.handleDragEnd,
365
+ handleSelectElement = _ref.handleSelectElement,
366
+ isDragDisabled = _ref.isDragDisabled,
438
367
  isElementVisible = _ref.isElementVisible,
439
368
  selectedElementId = _ref.selectedElementId,
440
369
  selectedElements = _ref.selectedElements,
441
- setIsSummaryPanelVisible = _ref.setIsSummaryPanelVisible,
370
+ setIsElementsListVisible = _ref.setIsElementsListVisible,
442
371
  fixedLastElement = _ref.fixedLastElement,
443
372
  fixedFirstElement = _ref.fixedFirstElement,
444
373
  selectedElementActions = _ref.selectedElementActions,
@@ -465,52 +394,55 @@ var SelectedElementsList = function SelectedElementsList(_ref) {
465
394
  addAllElements: addAllElements,
466
395
  isAddingAllElements: isAddingAllElements,
467
396
  isAddingNewElement: isAddingNewElement,
468
- setIsSummaryPanelVisible: setIsSummaryPanelVisible,
397
+ setIsElementsListVisible: setIsElementsListVisible,
469
398
  showElementsFillButton: showElementsFillButton
470
399
  }), /*#__PURE__*/jsxRuntime.jsxs(Body, {
471
400
  "data-testid": "selected-elements-container",
472
- children: [Array.isArray(fixedFirstElement) ? neetoCist.isNotEmpty(fixedFirstElement) && fixedFirstElement.map(renderSelectedElement) : neetoCist.isPresent(fixedFirstElement) && renderSelectedElement(fixedFirstElement), /*#__PURE__*/jsxRuntime.jsx(dnd.Droppable, {
473
- droppableId: SELECTED_ELEMENTS_LIST_DROPPABLE_ID,
474
- children: function children(_ref2) {
475
- var innerRef = _ref2.innerRef,
476
- droppableProps = _ref2.droppableProps,
477
- placeholder = _ref2.placeholder;
478
- return /*#__PURE__*/jsxRuntime.jsxs("div", _objectSpread(_objectSpread({
479
- ref: innerRef
480
- }, droppableProps), {}, {
481
- "data-testid": "selected-elements-droppable-container",
482
- children: [selectedElements === null || selectedElements === void 0 ? void 0 : selectedElements.map(function (element, index) {
483
- var _isElementVisible, _element$id, _element$id2;
484
- var isVisible = (_isElementVisible = isElementVisible === null || isElementVisible === void 0 ? void 0 : isElementVisible(element)) !== null && _isElementVisible !== void 0 ? _isElementVisible : true;
485
- if (!isVisible) return null;
486
- var key = (_element$id = element.id) !== null && _element$id !== void 0 ? _element$id : "element-".concat(general.joinHyphenCase(element.label));
487
- return /*#__PURE__*/React.createElement(dnd.Draggable, {
488
- index: index,
489
- draggableId: (_element$id2 = element.id) !== null && _element$id2 !== void 0 ? _element$id2 : "element-".concat(index),
490
- isDragDisabled: isReorderDisabled,
491
- key: key
492
- }, function (_ref3) {
493
- var _element$id3;
494
- var innerRef = _ref3.innerRef,
495
- draggableProps = _ref3.draggableProps,
496
- dragHandleProps = _ref3.dragHandleProps;
497
- return /*#__PURE__*/jsxRuntime.jsx("div", _objectSpread(_objectSpread(_objectSpread({
498
- ref: innerRef
499
- }, draggableProps), dragHandleProps), {}, {
500
- children: /*#__PURE__*/React.createElement(SelectedElement$1, {
501
- element: element,
502
- handleSelectElement: handleSelectElement,
503
- isSelectable: true,
504
- actions: selectedElementActions,
505
- isActive: selectedElementId === element.id,
506
- isDraggable: !isReorderDisabled,
507
- key: (_element$id3 = element.id) !== null && _element$id3 !== void 0 ? _element$id3 : index
508
- })
509
- }));
510
- });
511
- }), placeholder]
512
- }));
513
- }
401
+ children: [Array.isArray(fixedFirstElement) ? neetoCist.isNotEmpty(fixedFirstElement) && fixedFirstElement.map(renderSelectedElement) : neetoCist.isPresent(fixedFirstElement) && renderSelectedElement(fixedFirstElement), /*#__PURE__*/jsxRuntime.jsx(dnd.DragDropContext, {
402
+ onDragEnd: handleDragEnd,
403
+ children: /*#__PURE__*/jsxRuntime.jsx(dnd.Droppable, {
404
+ droppableId: "droppable-question-list",
405
+ children: function children(_ref2) {
406
+ var innerRef = _ref2.innerRef,
407
+ droppableProps = _ref2.droppableProps,
408
+ placeholder = _ref2.placeholder;
409
+ return /*#__PURE__*/jsxRuntime.jsxs("div", _objectSpread(_objectSpread({
410
+ ref: innerRef
411
+ }, droppableProps), {}, {
412
+ "data-testid": "selected-elements-droppable-container",
413
+ children: [selectedElements === null || selectedElements === void 0 ? void 0 : selectedElements.map(function (element, index) {
414
+ var _isElementVisible, _element$id, _element$id2;
415
+ var isVisible = (_isElementVisible = isElementVisible === null || isElementVisible === void 0 ? void 0 : isElementVisible(element)) !== null && _isElementVisible !== void 0 ? _isElementVisible : true;
416
+ if (!isVisible) return null;
417
+ var key = (_element$id = element.id) !== null && _element$id !== void 0 ? _element$id : "element-".concat(general.joinHyphenCase(element.label));
418
+ return /*#__PURE__*/React.createElement(dnd.Draggable, {
419
+ index: index,
420
+ isDragDisabled: isDragDisabled,
421
+ draggableId: (_element$id2 = element.id) !== null && _element$id2 !== void 0 ? _element$id2 : "element-".concat(index),
422
+ key: key
423
+ }, function (_ref3) {
424
+ var _element$id3;
425
+ var innerRef = _ref3.innerRef,
426
+ draggableProps = _ref3.draggableProps,
427
+ dragHandleProps = _ref3.dragHandleProps;
428
+ return /*#__PURE__*/jsxRuntime.jsx("div", _objectSpread(_objectSpread(_objectSpread({
429
+ ref: innerRef
430
+ }, draggableProps), dragHandleProps), {}, {
431
+ children: /*#__PURE__*/React.createElement(SelectedElement$1, {
432
+ element: element,
433
+ handleSelectElement: handleSelectElement,
434
+ isSelectable: true,
435
+ actions: selectedElementActions,
436
+ isActive: selectedElementId === element.id,
437
+ isDraggable: !isDragDisabled,
438
+ key: (_element$id3 = element.id) !== null && _element$id3 !== void 0 ? _element$id3 : index
439
+ })
440
+ }));
441
+ });
442
+ }), placeholder]
443
+ }));
444
+ }
445
+ })
514
446
  }), neetoCist.isPresent(fixedLastElement) && /*#__PURE__*/jsxRuntime.jsx(SelectedElement$1, {
515
447
  handleSelectElement: handleSelectElement,
516
448
  isSelectable: true,
@@ -533,10 +465,10 @@ var ElementsPanel = function ElementsPanel(_ref) {
533
465
  _ref$fixedFirstElemen = _ref.fixedFirstElement,
534
466
  fixedFirstElement = _ref$fixedFirstElemen === void 0 ? [] : _ref$fixedFirstElemen,
535
467
  fixedLastElement = _ref.fixedLastElement,
536
- _ref$isReorderDisable = _ref.isReorderDisabled,
537
- isReorderDisabled = _ref$isReorderDisable === void 0 ? true : _ref$isReorderDisable,
538
- _ref$isDragElementsDi = _ref.isDragElementsDisabled,
539
- isDragElementsDisabled = _ref$isDragElementsDi === void 0 ? true : _ref$isDragElementsDi,
468
+ _ref$handleDragEnd = _ref.handleDragEnd,
469
+ handleDragEnd = _ref$handleDragEnd === void 0 ? neetoCist.noop : _ref$handleDragEnd,
470
+ _ref$isDragDisabled = _ref.isDragDisabled,
471
+ isDragDisabled = _ref$isDragDisabled === void 0 ? true : _ref$isDragDisabled,
540
472
  handleSelectElement = _ref.handleSelectElement,
541
473
  selectedElementId = _ref.selectedElementId,
542
474
  selectedElementActions = _ref.selectedElementActions,
@@ -550,8 +482,8 @@ var ElementsPanel = function ElementsPanel(_ref) {
550
482
  isAddingNewElement = _ref$isAddingNewEleme === void 0 ? false : _ref$isAddingNewEleme;
551
483
  var _useState = React.useState(false),
552
484
  _useState2 = _slicedToArray__default["default"](_useState, 2),
553
- isSummaryPanelVisible = _useState2[0],
554
- setIsSummaryPanelVisible = _useState2[1];
485
+ isElementsListVisible = _useState2[0],
486
+ setIsElementsListVisible = _useState2[1];
555
487
  var _useBreakpoints = reactUtils.useBreakpoints(),
556
488
  isSize = _useBreakpoints.isSize;
557
489
  var isLargerScreen = !isSize("mobile");
@@ -559,6 +491,12 @@ var ElementsPanel = function ElementsPanel(_ref) {
559
491
  _useState4 = _slicedToArray__default["default"](_useState3, 2),
560
492
  isElementsPanelCollapsed = _useState4[0],
561
493
  setIsElementsPanelCollapsed = _useState4[1];
494
+ var isSelectedElementsEmpty = ramda.isEmpty(selectedElements);
495
+ var shouldShowElementsList = isSelectedElementsEmpty || isElementsListVisible;
496
+ var handleElementSelect = function handleElementSelect(element) {
497
+ setIsElementsListVisible(false);
498
+ handleAddElement(element);
499
+ };
562
500
  React.useEffect(function () {
563
501
  setIsElementsPanelCollapsed(!isLargerScreen);
564
502
  }, [isLargerScreen]);
@@ -579,25 +517,26 @@ var ElementsPanel = function ElementsPanel(_ref) {
579
517
  onClick: function onClick(event) {
580
518
  return event.stopPropagation();
581
519
  },
582
- children: isSummaryPanelVisible ? /*#__PURE__*/jsxRuntime.jsx(SelectedElementsList, {
520
+ children: shouldShowElementsList ? /*#__PURE__*/jsxRuntime.jsx(ElementList, {
521
+ elementSections: elementSections,
522
+ isSelectedElementsEmpty: isSelectedElementsEmpty,
523
+ setIsElementsListVisible: setIsElementsListVisible,
524
+ onSelect: handleElementSelect
525
+ }) : /*#__PURE__*/jsxRuntime.jsx(SelectedElementsList, {
583
526
  addAllElements: addAllElements,
584
527
  fixedFirstElement: fixedFirstElement,
585
528
  fixedLastElement: fixedLastElement,
529
+ handleDragEnd: handleDragEnd,
586
530
  handleSelectElement: handleSelectElement,
587
531
  isAddingAllElements: isAddingAllElements,
588
532
  isAddingNewElement: isAddingNewElement,
533
+ isDragDisabled: isDragDisabled,
589
534
  isElementVisible: isElementVisible,
590
- isReorderDisabled: isReorderDisabled,
591
535
  selectedElementActions: selectedElementActions,
592
536
  selectedElementId: selectedElementId,
593
537
  selectedElements: selectedElements,
594
- setIsSummaryPanelVisible: setIsSummaryPanelVisible,
538
+ setIsElementsListVisible: setIsElementsListVisible,
595
539
  showElementsFillButton: showElementsFillButton
596
- }) : /*#__PURE__*/jsxRuntime.jsx(ElementList, {
597
- elementSections: elementSections,
598
- isDragElementsDisabled: isDragElementsDisabled,
599
- setIsSummaryPanelVisible: setIsSummaryPanelVisible,
600
- onSelect: handleAddElement
601
540
  })
602
541
  })
603
542
  }), /*#__PURE__*/jsxRuntime.jsx(Button__default["default"], {
@@ -706,7 +645,5 @@ var PropertiesPanel = function PropertiesPanel(_ref) {
706
645
  PropertiesPanel.EmptyProperty = EmptyProperty;
707
646
 
708
647
  exports.ElementsPanel = ElementsPanel;
709
- exports.PREVIEW_CONTAINER_DROPPABLE_ID = PREVIEW_CONTAINER_DROPPABLE_ID;
710
648
  exports.PropertiesPanel = PropertiesPanel;
711
- exports.SELECTED_ELEMENTS_LIST_DROPPABLE_ID = SELECTED_ELEMENTS_LIST_DROPPABLE_ID;
712
649
  //# sourceMappingURL=Builder.js.map