@pingux/astro 1.10.1-alpha.1 → 1.11.0
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/CHANGELOG.md +18 -0
- package/lib/cjs/components/{MultiselectFilter/MultiselectFilter.js → CollapsiblePanel/CollapsiblePanel.js} +13 -13
- package/lib/cjs/components/{MultiselectFilter/MultiselectFilter.stories.js → CollapsiblePanel/CollapsiblePanel.stories.js} +9 -9
- package/lib/cjs/components/{MultiselectFilter/MultiselectFilter.test.js → CollapsiblePanel/CollapsiblePanel.test.js} +8 -8
- package/lib/cjs/components/{MultiselectFilter → CollapsiblePanel}/index.js +2 -2
- package/lib/cjs/components/{MultiselectListContainer/MultiselectBadge.js → CollapsiblePanelContainer/CollapsiblePanelBadge.js} +6 -6
- package/lib/cjs/components/{MultiselectListContainer/MultiselectBadge.test.js → CollapsiblePanelContainer/CollapsiblePanelBadge.test.js} +8 -8
- package/lib/cjs/components/{MultiselectListContainer/MultiselectListContainer.js → CollapsiblePanelContainer/CollapsiblePanelContainer.js} +12 -12
- package/lib/cjs/components/{MultiselectListContainer/MultiselectListContainer.test.js → CollapsiblePanelContainer/CollapsiblePanelContainer.test.js} +23 -23
- package/lib/cjs/components/{MultiselectListContainer → CollapsiblePanelContainer}/index.js +2 -2
- package/lib/cjs/components/{MultiselectFilterItem/MultiselectFilterItem.js → CollapsiblePanelItem/CollapsiblePanelItem.js} +7 -7
- package/lib/cjs/components/{MultiselectFilterItem/MultiselectFilterItem.test.js → CollapsiblePanelItem/CollapsiblePanelItem.test.js} +7 -7
- package/lib/cjs/components/{MultiselectFilterItem → CollapsiblePanelItem}/index.js +2 -2
- package/lib/cjs/components/MultivaluesField/MultivaluesField.js +36 -20
- package/lib/cjs/components/MultivaluesField/MultivaluesField.stories.js +16 -2
- package/lib/cjs/components/MultivaluesField/MultivaluesField.test.js +22 -1
- package/lib/cjs/index.js +36 -36
- package/lib/cjs/recipes/{MultiselectListContainer.stories.js → CollapsiblePanel.stories.js} +3 -3
- package/lib/cjs/styles/variants/boxes.js +23 -0
- package/lib/cjs/styles/variants/buttons.js +2 -2
- package/lib/cjs/styles/variants/{multiselectListContainer.js → collapsiblePanel.js} +10 -10
- package/lib/cjs/styles/variants/text.js +4 -4
- package/lib/cjs/styles/variants/variants.js +2 -2
- package/lib/components/{MultiselectFilter/MultiselectFilter.js → CollapsiblePanel/CollapsiblePanel.js} +14 -14
- package/lib/components/{MultiselectFilter/MultiselectFilter.stories.js → CollapsiblePanel/CollapsiblePanel.stories.js} +8 -8
- package/lib/components/{MultiselectFilter/MultiselectFilter.test.js → CollapsiblePanel/CollapsiblePanel.test.js} +8 -8
- package/lib/components/CollapsiblePanel/index.js +1 -0
- package/lib/components/{MultiselectListContainer/MultiselectBadge.js → CollapsiblePanelContainer/CollapsiblePanelBadge.js} +6 -6
- package/lib/components/{MultiselectListContainer/MultiselectBadge.test.js → CollapsiblePanelContainer/CollapsiblePanelBadge.test.js} +8 -8
- package/lib/components/{MultiselectListContainer/MultiselectListContainer.js → CollapsiblePanelContainer/CollapsiblePanelContainer.js} +12 -12
- package/lib/components/{MultiselectListContainer/MultiselectListContainer.test.js → CollapsiblePanelContainer/CollapsiblePanelContainer.test.js} +23 -23
- package/lib/components/CollapsiblePanelContainer/index.js +1 -0
- package/lib/components/{MultiselectFilterItem/MultiselectFilterItem.js → CollapsiblePanelItem/CollapsiblePanelItem.js} +7 -7
- package/lib/components/{MultiselectFilterItem/MultiselectFilterItem.test.js → CollapsiblePanelItem/CollapsiblePanelItem.test.js} +7 -7
- package/lib/components/CollapsiblePanelItem/index.js +1 -0
- package/lib/components/MultivaluesField/MultivaluesField.js +37 -20
- package/lib/components/MultivaluesField/MultivaluesField.stories.js +11 -0
- package/lib/components/MultivaluesField/MultivaluesField.test.js +16 -1
- package/lib/index.js +6 -6
- package/lib/recipes/{MultiselectListContainer.stories.js → CollapsiblePanel.stories.js} +4 -4
- package/lib/styles/variants/boxes.js +23 -0
- package/lib/styles/variants/buttons.js +2 -2
- package/lib/styles/variants/{multiselectListContainer.js → collapsiblePanel.js} +10 -10
- package/lib/styles/variants/text.js +4 -4
- package/lib/styles/variants/variants.js +2 -2
- package/package.json +1 -1
- package/lib/components/MultiselectFilter/index.js +0 -1
- package/lib/components/MultiselectFilterItem/index.js +0 -1
- package/lib/components/MultiselectListContainer/index.js +0 -1
@@ -114,6 +114,8 @@ var MultivaluesField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref)
|
|
114
114
|
onOpenChange = props.onOpenChange,
|
115
115
|
onSelectionChange = props.onSelectionChange,
|
116
116
|
placeholder = props.placeholder,
|
117
|
+
_props$readOnlyKeys = props.readOnlyKeys,
|
118
|
+
readOnlyKeys = _props$readOnlyKeys === void 0 ? [] : _props$readOnlyKeys,
|
117
119
|
selectedKeys = props.selectedKeys,
|
118
120
|
scrollBoxProps = props.scrollBoxProps;
|
119
121
|
var hasCustomValue = mode === 'non-restrictive';
|
@@ -162,7 +164,10 @@ var MultivaluesField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref)
|
|
162
164
|
return contains(item.textValue, filterString);
|
163
165
|
});
|
164
166
|
},
|
165
|
-
items: items,
|
167
|
+
items: (0, _filter["default"])(items).call(items, function (_ref) {
|
168
|
+
var key = _ref.key;
|
169
|
+
return !(0, _includes["default"])(readOnlyKeys).call(readOnlyKeys, key);
|
170
|
+
}),
|
166
171
|
onSelectionChange: toggleItems,
|
167
172
|
selectionMode: 'multiple'
|
168
173
|
}));
|
@@ -309,10 +314,8 @@ var MultivaluesField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref)
|
|
309
314
|
selectionManager.toggleSelection(key);
|
310
315
|
};
|
311
316
|
|
312
|
-
var
|
313
|
-
var
|
314
|
-
|
315
|
-
var item = (0, _find["default"])(_context5 = (0, _concat["default"])(_context6 = []).call(_context6, initialItems, customItems)).call(_context5, function (el) {
|
317
|
+
var readOnlyItems = (0, _react2.jsx)(_react["default"].Fragment, null, (0, _map["default"])(readOnlyKeys).call(readOnlyKeys, function (key) {
|
318
|
+
var item = (0, _find["default"])(initialItems).call(initialItems, function (el) {
|
316
319
|
return el.key === key;
|
317
320
|
});
|
318
321
|
|
@@ -320,25 +323,33 @@ var MultivaluesField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref)
|
|
320
323
|
return (0, _react2.jsx)(_.Chip, {
|
321
324
|
key: item.key,
|
322
325
|
role: "presentation",
|
323
|
-
bg: "active",
|
324
|
-
color: "white",
|
325
326
|
label: item.name,
|
326
|
-
|
327
|
-
|
328
|
-
cursor: 'default',
|
329
|
-
height: '100%',
|
330
|
-
m: 5,
|
331
|
-
mr: 10,
|
332
|
-
ml: 0,
|
333
|
-
py: 3,
|
334
|
-
pr: 0
|
335
|
-
},
|
327
|
+
variant: "boxes.readOnlyChip",
|
328
|
+
bg: "white",
|
336
329
|
textProps: {
|
337
330
|
sx: {
|
338
|
-
|
339
|
-
textTransform: 'none'
|
331
|
+
color: 'text.primary'
|
340
332
|
}
|
341
333
|
}
|
334
|
+
});
|
335
|
+
}
|
336
|
+
|
337
|
+
return null;
|
338
|
+
}));
|
339
|
+
var selectedItems = (0, _react2.jsx)(_react["default"].Fragment, null, (0, _map["default"])(_context4 = (0, _from["default"])(selectionManager.selectedKeys)).call(_context4, function (key) {
|
340
|
+
var _context5, _context6;
|
341
|
+
|
342
|
+
var item = (0, _find["default"])(_context5 = (0, _concat["default"])(_context6 = []).call(_context6, initialItems, customItems)).call(_context5, function (el) {
|
343
|
+
return el.key === key;
|
344
|
+
});
|
345
|
+
|
346
|
+
if (item) {
|
347
|
+
return (0, _react2.jsx)(_.Chip, {
|
348
|
+
key: item.key,
|
349
|
+
role: "presentation",
|
350
|
+
variant: "boxes.selectedItemChip",
|
351
|
+
bg: "active",
|
352
|
+
label: item.name
|
342
353
|
}, (0, _react2.jsx)(_.IconButton, {
|
343
354
|
"aria-label": "delete",
|
344
355
|
onPress: function onPress() {
|
@@ -406,7 +417,7 @@ var MultivaluesField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref)
|
|
406
417
|
return _onKeyUp && _onKeyUp(e.nativeEvent);
|
407
418
|
},
|
408
419
|
slots: {
|
409
|
-
beforeInput: selectedItems
|
420
|
+
beforeInput: (0, _react2.jsx)(_react["default"].Fragment, null, readOnlyItems, " ", selectedItems)
|
410
421
|
},
|
411
422
|
value: filterString
|
412
423
|
}, inputProps)), (0, _react2.jsx)(_.PopoverContainer, {
|
@@ -517,6 +528,11 @@ MultivaluesField.propTypes = {
|
|
517
528
|
/** Temporary text that occupies the text input when it is empty. */
|
518
529
|
placeholder: _propTypes["default"].string,
|
519
530
|
|
531
|
+
/**
|
532
|
+
* The item keys that are readonly. These items cannot be changed or selected.
|
533
|
+
*/
|
534
|
+
readOnlyKeys: _propTypes["default"].arrayOf(_propTypes["default"].string),
|
535
|
+
|
520
536
|
/** The currently selected keys in the collection (controlled). */
|
521
537
|
selectedKeys: _isIterable.isIterableProp,
|
522
538
|
// /** Props object that is spread directly into the ScrollBox element. */
|
@@ -14,7 +14,7 @@ _Object$defineProperty(exports, "__esModule", {
|
|
14
14
|
value: true
|
15
15
|
});
|
16
16
|
|
17
|
-
exports["default"] = exports.WithDisabledKeys = exports.WithCustomValues = exports.WithCustomSize = exports.Uncontrolled = exports.Default = exports.Controlled = void 0;
|
17
|
+
exports["default"] = exports.WithReadOnlyValues = exports.WithDisabledKeys = exports.WithCustomValues = exports.WithCustomSize = exports.Uncontrolled = exports.Default = exports.Controlled = void 0;
|
18
18
|
|
19
19
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
|
20
20
|
|
@@ -217,4 +217,18 @@ var WithCustomSize = function WithCustomSize(args) {
|
|
217
217
|
}))));
|
218
218
|
};
|
219
219
|
|
220
|
-
exports.WithCustomSize = WithCustomSize;
|
220
|
+
exports.WithCustomSize = WithCustomSize;
|
221
|
+
|
222
|
+
var WithReadOnlyValues = function WithReadOnlyValues(args) {
|
223
|
+
return (0, _react2.jsx)(_.OverlayProvider, null, (0, _react2.jsx)(_.MultivaluesField, (0, _extends2["default"])({
|
224
|
+
readOnlyKeys: ['Aardvark', 'Snake'],
|
225
|
+
items: items
|
226
|
+
}, args), function (item) {
|
227
|
+
return (0, _react2.jsx)(_.Item, {
|
228
|
+
key: item.key,
|
229
|
+
"data-id": item.name
|
230
|
+
}, item.name);
|
231
|
+
}));
|
232
|
+
};
|
233
|
+
|
234
|
+
exports.WithReadOnlyValues = WithReadOnlyValues;
|
@@ -458,4 +458,25 @@ test('should have no accessibility violations', /*#__PURE__*/(0, _asyncToGenerat
|
|
458
458
|
}
|
459
459
|
}
|
460
460
|
}, _callee);
|
461
|
-
})));
|
461
|
+
})));
|
462
|
+
test('read only keys', function () {
|
463
|
+
getComponent({
|
464
|
+
readOnlyKeys: [items[1].key, items[2].key]
|
465
|
+
});
|
466
|
+
|
467
|
+
var listbox = _testWrapper.screen.queryByRole('listbox');
|
468
|
+
|
469
|
+
expect(listbox).not.toBeInTheDocument();
|
470
|
+
|
471
|
+
var firstChip = _testWrapper.screen.getByText(items[1].name);
|
472
|
+
|
473
|
+
var deleteButton1 = firstChip.nextSibling;
|
474
|
+
expect(firstChip).toBeInTheDocument();
|
475
|
+
expect(deleteButton1).toBeNull();
|
476
|
+
|
477
|
+
var secondChip = _testWrapper.screen.getByText(items[2].name);
|
478
|
+
|
479
|
+
expect(secondChip).toBeInTheDocument();
|
480
|
+
var deleteButton2 = firstChip.nextSibling;
|
481
|
+
expect(deleteButton2).toBeNull();
|
482
|
+
});
|
package/lib/cjs/index.js
CHANGED
@@ -60,9 +60,9 @@ var _exportNames = {
|
|
60
60
|
Menu: true,
|
61
61
|
Messages: true,
|
62
62
|
Modal: true,
|
63
|
-
|
64
|
-
|
65
|
-
|
63
|
+
CollapsiblePanel: true,
|
64
|
+
CollapsiblePanelItem: true,
|
65
|
+
CollapsiblePanelContainer: true,
|
66
66
|
NavBar: true,
|
67
67
|
NavBarSection: true,
|
68
68
|
MultivaluesField: true,
|
@@ -210,6 +210,27 @@ _Object$defineProperty(exports, "CodeView", {
|
|
210
210
|
}
|
211
211
|
});
|
212
212
|
|
213
|
+
_Object$defineProperty(exports, "CollapsiblePanel", {
|
214
|
+
enumerable: true,
|
215
|
+
get: function get() {
|
216
|
+
return _CollapsiblePanel["default"];
|
217
|
+
}
|
218
|
+
});
|
219
|
+
|
220
|
+
_Object$defineProperty(exports, "CollapsiblePanelContainer", {
|
221
|
+
enumerable: true,
|
222
|
+
get: function get() {
|
223
|
+
return _CollapsiblePanelContainer["default"];
|
224
|
+
}
|
225
|
+
});
|
226
|
+
|
227
|
+
_Object$defineProperty(exports, "CollapsiblePanelItem", {
|
228
|
+
enumerable: true,
|
229
|
+
get: function get() {
|
230
|
+
return _CollapsiblePanelItem["default"];
|
231
|
+
}
|
232
|
+
});
|
233
|
+
|
213
234
|
_Object$defineProperty(exports, "ColorField", {
|
214
235
|
enumerable: true,
|
215
236
|
get: function get() {
|
@@ -378,27 +399,6 @@ _Object$defineProperty(exports, "Modal", {
|
|
378
399
|
}
|
379
400
|
});
|
380
401
|
|
381
|
-
_Object$defineProperty(exports, "MultiselectFilter", {
|
382
|
-
enumerable: true,
|
383
|
-
get: function get() {
|
384
|
-
return _MultiselectFilter["default"];
|
385
|
-
}
|
386
|
-
});
|
387
|
-
|
388
|
-
_Object$defineProperty(exports, "MultiselectFilterItem", {
|
389
|
-
enumerable: true,
|
390
|
-
get: function get() {
|
391
|
-
return _MultiselectFilterItem["default"];
|
392
|
-
}
|
393
|
-
});
|
394
|
-
|
395
|
-
_Object$defineProperty(exports, "MultiselectListContainer", {
|
396
|
-
enumerable: true,
|
397
|
-
get: function get() {
|
398
|
-
return _MultiselectListContainer["default"];
|
399
|
-
}
|
400
|
-
});
|
401
|
-
|
402
402
|
_Object$defineProperty(exports, "MultivaluesField", {
|
403
403
|
enumerable: true,
|
404
404
|
get: function get() {
|
@@ -1173,47 +1173,47 @@ _forEachInstanceProperty(_context32 = _Object$keys(_Modal)).call(_context32, fun
|
|
1173
1173
|
});
|
1174
1174
|
});
|
1175
1175
|
|
1176
|
-
var
|
1176
|
+
var _CollapsiblePanel = _interopRequireWildcard(require("./components/CollapsiblePanel"));
|
1177
1177
|
|
1178
|
-
_forEachInstanceProperty(_context33 = _Object$keys(
|
1178
|
+
_forEachInstanceProperty(_context33 = _Object$keys(_CollapsiblePanel)).call(_context33, function (key) {
|
1179
1179
|
if (key === "default" || key === "__esModule") return;
|
1180
1180
|
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
1181
|
-
if (key in exports && exports[key] ===
|
1181
|
+
if (key in exports && exports[key] === _CollapsiblePanel[key]) return;
|
1182
1182
|
|
1183
1183
|
_Object$defineProperty(exports, key, {
|
1184
1184
|
enumerable: true,
|
1185
1185
|
get: function get() {
|
1186
|
-
return
|
1186
|
+
return _CollapsiblePanel[key];
|
1187
1187
|
}
|
1188
1188
|
});
|
1189
1189
|
});
|
1190
1190
|
|
1191
|
-
var
|
1191
|
+
var _CollapsiblePanelItem = _interopRequireWildcard(require("./components/CollapsiblePanelItem"));
|
1192
1192
|
|
1193
|
-
_forEachInstanceProperty(_context34 = _Object$keys(
|
1193
|
+
_forEachInstanceProperty(_context34 = _Object$keys(_CollapsiblePanelItem)).call(_context34, function (key) {
|
1194
1194
|
if (key === "default" || key === "__esModule") return;
|
1195
1195
|
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
1196
|
-
if (key in exports && exports[key] ===
|
1196
|
+
if (key in exports && exports[key] === _CollapsiblePanelItem[key]) return;
|
1197
1197
|
|
1198
1198
|
_Object$defineProperty(exports, key, {
|
1199
1199
|
enumerable: true,
|
1200
1200
|
get: function get() {
|
1201
|
-
return
|
1201
|
+
return _CollapsiblePanelItem[key];
|
1202
1202
|
}
|
1203
1203
|
});
|
1204
1204
|
});
|
1205
1205
|
|
1206
|
-
var
|
1206
|
+
var _CollapsiblePanelContainer = _interopRequireWildcard(require("./components/CollapsiblePanelContainer"));
|
1207
1207
|
|
1208
|
-
_forEachInstanceProperty(_context35 = _Object$keys(
|
1208
|
+
_forEachInstanceProperty(_context35 = _Object$keys(_CollapsiblePanelContainer)).call(_context35, function (key) {
|
1209
1209
|
if (key === "default" || key === "__esModule") return;
|
1210
1210
|
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
1211
|
-
if (key in exports && exports[key] ===
|
1211
|
+
if (key in exports && exports[key] === _CollapsiblePanelContainer[key]) return;
|
1212
1212
|
|
1213
1213
|
_Object$defineProperty(exports, key, {
|
1214
1214
|
enumerable: true,
|
1215
1215
|
get: function get() {
|
1216
|
-
return
|
1216
|
+
return _CollapsiblePanelContainer[key];
|
1217
1217
|
}
|
1218
1218
|
});
|
1219
1219
|
});
|
@@ -69,7 +69,7 @@ function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (
|
|
69
69
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context2 = ownKeys(Object(source), !0)).call(_context2, function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
70
70
|
|
71
71
|
var _default = {
|
72
|
-
title: 'Recipes/
|
72
|
+
title: 'Recipes/CollapsiblePanel with List'
|
73
73
|
};
|
74
74
|
exports["default"] = _default;
|
75
75
|
var data = [{
|
@@ -327,7 +327,7 @@ var Default = function Default() {
|
|
327
327
|
return el.key === item.key;
|
328
328
|
})
|
329
329
|
}));
|
330
|
-
})), (0, _react2.jsx)(_.
|
330
|
+
})), (0, _react2.jsx)(_.CollapsiblePanel, {
|
331
331
|
items: selectedItems,
|
332
332
|
selectedFilterCount: selectedItems.length.toString(),
|
333
333
|
listTitle: "Selected Groups",
|
@@ -338,7 +338,7 @@ var Default = function Default() {
|
|
338
338
|
key: item.key,
|
339
339
|
textValue: item.name,
|
340
340
|
"data-id": item.key
|
341
|
-
}, (0, _react2.jsx)(_.
|
341
|
+
}, (0, _react2.jsx)(_.CollapsiblePanelItem, {
|
342
342
|
text: item.name,
|
343
343
|
icon: item.isDefaultSelected ? _CheckIcon["default"] : _CloseIcon["default"],
|
344
344
|
isDefaultSelected: item.isDefaultSelected,
|
@@ -133,6 +133,27 @@ var chip = {
|
|
133
133
|
}
|
134
134
|
};
|
135
135
|
exports.chip = chip;
|
136
|
+
|
137
|
+
var multivaluesChip = _objectSpread(_objectSpread({}, chip), {}, {
|
138
|
+
alignSelf: 'center',
|
139
|
+
cursor: 'default',
|
140
|
+
height: '100%',
|
141
|
+
m: 5,
|
142
|
+
mr: 10,
|
143
|
+
ml: 0
|
144
|
+
});
|
145
|
+
|
146
|
+
var selectedItemChip = _objectSpread(_objectSpread({}, multivaluesChip), {}, {
|
147
|
+
py: 3,
|
148
|
+
pr: 0
|
149
|
+
});
|
150
|
+
|
151
|
+
var readOnlyChip = _objectSpread(_objectSpread({}, multivaluesChip), {}, {
|
152
|
+
p: 3,
|
153
|
+
border: '1px solid',
|
154
|
+
borderColor: 'neutral.80'
|
155
|
+
});
|
156
|
+
|
136
157
|
var inputInContainerSlot = {
|
137
158
|
position: 'absolute',
|
138
159
|
bg: 'transparent',
|
@@ -309,6 +330,8 @@ var _default = {
|
|
309
330
|
base: base,
|
310
331
|
card: card,
|
311
332
|
chip: chip,
|
333
|
+
selectedItemChip: selectedItemChip,
|
334
|
+
readOnlyChip: readOnlyChip,
|
312
335
|
copy: copy,
|
313
336
|
datePicker: datePicker,
|
314
337
|
environmentChip: environmentChip,
|
@@ -146,7 +146,7 @@ var modalCloseButton = _objectSpread(_objectSpread({}, iconButton), {}, {
|
|
146
146
|
right: 10
|
147
147
|
});
|
148
148
|
|
149
|
-
var
|
149
|
+
var collapsiblePanelToggle = _objectSpread(_objectSpread({}, square), {}, {
|
150
150
|
bg: 'accent.99',
|
151
151
|
height: '40px',
|
152
152
|
minWidth: 'max-content',
|
@@ -720,7 +720,7 @@ var _default = {
|
|
720
720
|
tooltipInline: tooltipInline,
|
721
721
|
colorBlock: colorBlock,
|
722
722
|
menuTab: menuTab,
|
723
|
-
|
723
|
+
collapsiblePanelToggle: collapsiblePanelToggle,
|
724
724
|
neutralText: neutralText
|
725
725
|
};
|
726
726
|
exports["default"] = _default;
|
@@ -7,13 +7,13 @@ _Object$defineProperty(exports, "__esModule", {
|
|
7
7
|
});
|
8
8
|
|
9
9
|
exports["default"] = void 0;
|
10
|
-
var
|
10
|
+
var collapsiblePanelContainer = {
|
11
11
|
overflowX: 'hidden',
|
12
12
|
pr: 'sm',
|
13
13
|
transition: 'right 500ms',
|
14
14
|
minHeight: '80vh'
|
15
15
|
};
|
16
|
-
var
|
16
|
+
var collapsiblePanelContent = {
|
17
17
|
bg: 'accent.99',
|
18
18
|
fontSize: 'sm',
|
19
19
|
height: '100%',
|
@@ -32,7 +32,7 @@ var multiselectListContent = {
|
|
32
32
|
justifyContent: 'space-between'
|
33
33
|
}
|
34
34
|
};
|
35
|
-
var
|
35
|
+
var collapsiblePanelContainerTitle = {
|
36
36
|
alignContent: 'center',
|
37
37
|
bg: 'accent.99',
|
38
38
|
display: 'flex',
|
@@ -44,7 +44,7 @@ var multiselectListTitle = {
|
|
44
44
|
maxWidth: 'max-content !important',
|
45
45
|
margin: '0'
|
46
46
|
};
|
47
|
-
var
|
47
|
+
var collapsiblePanelBadge = {
|
48
48
|
borderRadius: '5px',
|
49
49
|
display: 'flex',
|
50
50
|
height: '17px',
|
@@ -57,15 +57,15 @@ var multiselectListBadge = {
|
|
57
57
|
alignItems: 'center',
|
58
58
|
fontWeight: 500
|
59
59
|
};
|
60
|
-
var
|
60
|
+
var collapsiblePanellItem = {
|
61
61
|
minHeight: '45px',
|
62
62
|
margin: 'auto'
|
63
63
|
};
|
64
64
|
var _default = {
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
65
|
+
collapsiblePanelContainer: collapsiblePanelContainer,
|
66
|
+
collapsiblePanelContent: collapsiblePanelContent,
|
67
|
+
collapsiblePanelContainerTitle: collapsiblePanelContainerTitle,
|
68
|
+
collapsiblePanelBadge: collapsiblePanelBadge,
|
69
|
+
collapsiblePanellItem: collapsiblePanellItem
|
70
70
|
};
|
71
71
|
exports["default"] = _default;
|
@@ -187,7 +187,7 @@ var navBarHeaderText = _objectSpread(_objectSpread({}, wordWrap), {}, {
|
|
187
187
|
maxWidth: '150px'
|
188
188
|
});
|
189
189
|
|
190
|
-
var
|
190
|
+
var collapsiblePanellItem = _objectSpread(_objectSpread({}, wordWrap), {}, {
|
191
191
|
color: 'neutral.30',
|
192
192
|
fontSize: 'sm',
|
193
193
|
fontWeight: 500,
|
@@ -197,7 +197,7 @@ var multiselectFilterItem = _objectSpread(_objectSpread({}, wordWrap), {}, {
|
|
197
197
|
whiteSpace: 'nowrap'
|
198
198
|
});
|
199
199
|
|
200
|
-
var
|
200
|
+
var collapsiblePanelTitle = _objectSpread(_objectSpread({}, wordWrap), {}, {
|
201
201
|
fontSize: 'sm',
|
202
202
|
fontWeight: 500,
|
203
203
|
color: 'text.secondary',
|
@@ -324,8 +324,8 @@ var text = {
|
|
324
324
|
}),
|
325
325
|
maskedValue: maskedValue,
|
326
326
|
expandableRow: expandableRow,
|
327
|
-
|
328
|
-
|
327
|
+
collapsiblePanellItem: collapsiblePanellItem,
|
328
|
+
collapsiblePanelTitle: collapsiblePanelTitle,
|
329
329
|
navBarHeaderText: navBarHeaderText,
|
330
330
|
navBarSubtitle: navBarSubtitle,
|
331
331
|
placeholder: {
|
@@ -74,7 +74,7 @@ var tabs = _interopRequireWildcard(require("./tabs"));
|
|
74
74
|
|
75
75
|
var _tooltip = _interopRequireDefault(require("./tooltip"));
|
76
76
|
|
77
|
-
var
|
77
|
+
var _collapsiblePanel = _interopRequireDefault(require("./collapsiblePanel"));
|
78
78
|
|
79
79
|
function _getRequireWildcardCache(nodeInterop) { if (typeof _WeakMap !== "function") return null; var cacheBabelInterop = new _WeakMap(); var cacheNodeInterop = new _WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
80
80
|
|
@@ -97,7 +97,7 @@ var _default = _objectSpread(_objectSpread({
|
|
97
97
|
menuItem: _menuItem["default"],
|
98
98
|
messages: _messages["default"],
|
99
99
|
modal: _modal["default"],
|
100
|
-
|
100
|
+
collapsiblePanel: _collapsiblePanel["default"],
|
101
101
|
navBar: _navBar["default"],
|
102
102
|
numberField: _numberField["default"],
|
103
103
|
overlayPanel: _overlayPanel["default"],
|
@@ -7,15 +7,15 @@ import { useFocusRing } from '@react-aria/focus';
|
|
7
7
|
import { mergeProps } from '@react-aria/utils';
|
8
8
|
import { isIterableProp } from '../../utils/devUtils/props/isIterable';
|
9
9
|
import { useStatusClasses } from '../../hooks';
|
10
|
-
import
|
11
|
-
import { Box, ListView,
|
10
|
+
import CollapsiblePanelBadge from '../CollapsiblePanelContainer/CollapsiblePanelBadge';
|
11
|
+
import { Box, ListView, CollapsiblePanelContainer, Text } from '../../index';
|
12
12
|
/**
|
13
|
-
* The
|
13
|
+
* The CollapsiblePanel serves as a filter menu with a menu title
|
14
14
|
* and selected count displayed in a badge.
|
15
15
|
*/
|
16
16
|
|
17
17
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
18
|
-
var
|
18
|
+
var CollapsiblePanel = /*#__PURE__*/forwardRef(function (props, ref) {
|
19
19
|
var selectedFilterCount = props.selectedFilterCount,
|
20
20
|
className = props.className,
|
21
21
|
closeAriaLabel = props.closeAriaLabel,
|
@@ -45,7 +45,7 @@ var MultiselectFilter = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
45
45
|
}),
|
46
46
|
classNames = _useStatusClasses.classNames;
|
47
47
|
|
48
|
-
return ___EmotionJSX(
|
48
|
+
return ___EmotionJSX(CollapsiblePanelContainer, {
|
49
49
|
closeAriaLabel: closeAriaLabel,
|
50
50
|
isDefaultOpen: isDefaultOpen,
|
51
51
|
isOpen: isOpen,
|
@@ -54,16 +54,16 @@ var MultiselectFilter = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
54
54
|
selectedFilterCount: selectedFilterCount
|
55
55
|
}, ___EmotionJSX(Box, _extends({
|
56
56
|
className: classNames,
|
57
|
-
"data-testid": "
|
57
|
+
"data-testid": "collapsible-panel",
|
58
58
|
ref: ref,
|
59
59
|
tabIndex: 0,
|
60
|
-
variant: "
|
60
|
+
variant: "collapsiblePanel.collapsiblePanelContent"
|
61
61
|
}, mergedProps, others), ___EmotionJSX(Box, {
|
62
62
|
isRow: true,
|
63
|
-
variant: "
|
63
|
+
variant: "collapsiblePanel.collapsiblePanelContainerTitle"
|
64
64
|
}, ___EmotionJSX(Text, {
|
65
|
-
variant: "
|
66
|
-
}, listTitle), selectedFilterCount && ___EmotionJSX(
|
65
|
+
variant: "collapsiblePanelTitle"
|
66
|
+
}, listTitle), selectedFilterCount && ___EmotionJSX(CollapsiblePanelBadge, {
|
67
67
|
margin: "0",
|
68
68
|
selectedFilterCount: selectedFilterCount
|
69
69
|
})), ___EmotionJSX(Box, {
|
@@ -79,7 +79,7 @@ var MultiselectFilter = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
79
79
|
pl: "md"
|
80
80
|
}, children))));
|
81
81
|
});
|
82
|
-
|
82
|
+
CollapsiblePanel.propTypes = {
|
83
83
|
/** Amount of selected items indicator. */
|
84
84
|
selectedFilterCount: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
85
85
|
|
@@ -112,8 +112,8 @@ MultiselectFilter.propTypes = {
|
|
112
112
|
/** Defines a string value that labels the trigger icon when menu is closed. */
|
113
113
|
openAriaLabel: PropTypes.string
|
114
114
|
};
|
115
|
-
|
115
|
+
CollapsiblePanel.defaultProps = {
|
116
116
|
isDefaultOpen: true
|
117
117
|
};
|
118
|
-
|
119
|
-
export default
|
118
|
+
CollapsiblePanel.displayName = 'CollapsiblePanel';
|
119
|
+
export default CollapsiblePanel;
|
@@ -6,13 +6,13 @@ import ChevronRightIcon from 'mdi-react/ChevronRightIcon';
|
|
6
6
|
import FilterIcon from 'mdi-react/FilterIcon';
|
7
7
|
import SearchIcon from 'mdi-react/SearchIcon';
|
8
8
|
import AccountIcon from 'mdi-react/AccountIcon';
|
9
|
-
import
|
9
|
+
import CollapsiblePanel from './CollapsiblePanel';
|
10
10
|
import { useOverlayPanelState } from '../../hooks';
|
11
|
-
import { Breadcrumbs, Box, Button, Chip, ListView, Item, Icon, IconButton,
|
11
|
+
import { Breadcrumbs, Box, Button, Chip, ListView, Item, Icon, IconButton, CollapsiblePanelItem, OverlayPanel, OverlayProvider, SearchField, Text } from '../../index';
|
12
12
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
13
13
|
export default {
|
14
|
-
title: '
|
15
|
-
component:
|
14
|
+
title: 'CollapsiblePanel',
|
15
|
+
component: CollapsiblePanel,
|
16
16
|
argTypes: {
|
17
17
|
listTitle: {
|
18
18
|
defaultValue: 'Selected Groups'
|
@@ -117,9 +117,9 @@ var changeSelection = function changeSelection(selected) {
|
|
117
117
|
};
|
118
118
|
|
119
119
|
export var Default = function Default(args) {
|
120
|
-
return ___EmotionJSX(
|
120
|
+
return ___EmotionJSX(CollapsiblePanel, args);
|
121
121
|
};
|
122
|
-
export var
|
122
|
+
export var CollapsiblePanelWithBadge = function CollapsiblePanelWithBadge(args) {
|
123
123
|
var _useOverlayPanelState = useOverlayPanelState(),
|
124
124
|
state = _useOverlayPanelState.state,
|
125
125
|
onClose = _useOverlayPanelState.onClose;
|
@@ -234,7 +234,7 @@ export var MultiselectWithBadge = function MultiselectWithBadge(args) {
|
|
234
234
|
})), ___EmotionJSX(Text, {
|
235
235
|
variant: "listSubtitle"
|
236
236
|
}, item.subtitle))));
|
237
|
-
})), ___EmotionJSX(
|
237
|
+
})), ___EmotionJSX(CollapsiblePanel, _extends({
|
238
238
|
items: mockData,
|
239
239
|
onSelectionChange: changeSelection,
|
240
240
|
selectedFilterCount: "1000+"
|
@@ -243,7 +243,7 @@ export var MultiselectWithBadge = function MultiselectWithBadge(args) {
|
|
243
243
|
key: item.key,
|
244
244
|
textValue: item.name,
|
245
245
|
"data-id": item.key
|
246
|
-
}, ___EmotionJSX(
|
246
|
+
}, ___EmotionJSX(CollapsiblePanelItem, {
|
247
247
|
text: item.name,
|
248
248
|
icon: FilterIcon
|
249
249
|
}));
|
@@ -2,9 +2,9 @@ import _extends from "@babel/runtime-corejs3/helpers/esm/extends";
|
|
2
2
|
import React from 'react';
|
3
3
|
import axeTest from '../../utils/testUtils/testAxe';
|
4
4
|
import { render, screen } from '../../utils/testUtils/testWrapper';
|
5
|
-
import
|
5
|
+
import CollapsiblePanel from './CollapsiblePanel';
|
6
6
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
7
|
-
var testId = '
|
7
|
+
var testId = 'collapsible-panel-item';
|
8
8
|
var onSelectionChange = jest.fn();
|
9
9
|
var defaultProps = {
|
10
10
|
'data-testid': testId,
|
@@ -19,7 +19,7 @@ var defaultProps = {
|
|
19
19
|
|
20
20
|
var getComponent = function getComponent() {
|
21
21
|
var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
22
|
-
return render(___EmotionJSX(
|
22
|
+
return render(___EmotionJSX(CollapsiblePanel, _extends({}, defaultProps, props)));
|
23
23
|
};
|
24
24
|
|
25
25
|
beforeAll(function () {
|
@@ -55,15 +55,15 @@ axeTest(getComponent, {
|
|
55
55
|
}
|
56
56
|
}
|
57
57
|
});
|
58
|
-
test('default
|
58
|
+
test('default CollapsiblePanel', function () {
|
59
59
|
getComponent();
|
60
|
-
var
|
61
|
-
expect(
|
60
|
+
var collapsiblePanel = screen.getByTestId(testId);
|
61
|
+
expect(collapsiblePanel).toBeInTheDocument();
|
62
62
|
});
|
63
63
|
test('custom classname can be passed', function () {
|
64
64
|
getComponent({
|
65
65
|
className: 'testing-class'
|
66
66
|
});
|
67
|
-
var
|
68
|
-
expect(
|
67
|
+
var collapsiblePanel = screen.getByTestId(testId);
|
68
|
+
expect(collapsiblePanel).toHaveClass('testing-class');
|
69
69
|
});
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './CollapsiblePanel';
|