react-magma-dom 4.6.1-next.0 → 4.7.0-next.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (26) hide show
  1. package/dist/components/ButtonGroup/ButtonGroup.stories.d.ts +6 -6
  2. package/dist/components/CharacterCounter/CharacterCounter.stories.d.ts +12 -12
  3. package/dist/components/Datagrid/Datagrid.stories.d.ts +8 -8
  4. package/dist/components/IconButton/IconButton.stories.d.ts +4 -4
  5. package/dist/components/Input/Input.stories.d.ts +30 -30
  6. package/dist/components/Table/Table.stories.d.ts +36 -36
  7. package/dist/components/Tag/Tag.stories.d.ts +68 -68
  8. package/dist/components/Textarea/Textarea.stories.d.ts +6 -6
  9. package/dist/components/ToggleButton/ToggleButton.stories.d.ts +24 -24
  10. package/dist/components/ToggleButtonGroup/ToggleButtonGroup.stories.d.ts +12 -12
  11. package/dist/components/TreeView/TreeItemContext.d.ts +0 -2
  12. package/dist/components/TreeView/TreeView.stories.d.ts +2 -0
  13. package/dist/components/TreeView/TreeViewContext.d.ts +10 -7
  14. package/dist/components/TreeView/index.d.ts +1 -0
  15. package/dist/components/TreeView/types.d.ts +5 -0
  16. package/dist/components/TreeView/useTreeItem.d.ts +0 -10
  17. package/dist/components/TreeView/useTreeView.d.ts +18 -13
  18. package/dist/components/TreeView/utils.d.ts +22 -16
  19. package/dist/esm/index.js +973 -1308
  20. package/dist/esm/index.js.map +1 -1
  21. package/dist/properties.json +80 -67
  22. package/dist/react-magma-dom.cjs.development.js +974 -1321
  23. package/dist/react-magma-dom.cjs.development.js.map +1 -1
  24. package/dist/react-magma-dom.cjs.production.min.js +1 -1
  25. package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
  26. package/package.json +1 -1
package/dist/esm/index.js CHANGED
@@ -21829,7 +21829,9 @@ var Search = /*#__PURE__*/forwardRef(function (props, ref) {
21829
21829
  }
21830
21830
  }
21831
21831
  function handleSearch() {
21832
- onSearch(value);
21832
+ if (!props.isLoading) {
21833
+ onSearch(value);
21834
+ }
21833
21835
  }
21834
21836
  function handleClear() {
21835
21837
  onClear && typeof onClear === 'function' && onClear();
@@ -21843,7 +21845,7 @@ var Search = /*#__PURE__*/forwardRef(function (props, ref) {
21843
21845
  isInverse: useIsInverse(props.isInverse),
21844
21846
  onChange: handleChange,
21845
21847
  onClear: handleClear,
21846
- onIconClick: props.isPredictive ? null : isLoading ? null : handleSearch,
21848
+ onIconClick: props.isPredictive ? null : handleSearch,
21847
21849
  onKeyDown: handleKeyPress,
21848
21850
  placeholder: placeholder ? placeholder : i18n.search.input.placeholder,
21849
21851
  type: InputType.search,
@@ -25094,1382 +25096,1048 @@ var BlockQuoteItem = /*#__PURE__*/forwardRef(function (props, ref) {
25094
25096
  }, rest), hasAttribution ? createElement(Fragment, null, "\u2015\xA0", children) : createElement(Fragment, null, "\u201C", children, "\u201D"));
25095
25097
  });
25096
25098
 
25097
- var TreeNodeType;
25098
- (function (TreeNodeType) {
25099
- TreeNodeType["branch"] = "branch";
25100
- TreeNodeType["leaf"] = "leaf";
25101
- })(TreeNodeType || (TreeNodeType = {}));
25102
- /**
25103
- * Leaf node - 1st level has 40px of left padding.
25104
- * Each level after that adds 56px of left padding.
25105
- * 40, 64, 88, 112, 136, etc.
25106
- *
25107
- * Branch node - 1st level has 8px of left padding.
25108
- * Each level after that adds 24px of left padding.
25109
- * 8, 32, 56, 80, 104, etc.
25110
- *
25111
- * The label element (the div inside the li) gets additional spacing.
25112
- * In order to highlight the entire line, we need to negate the value for margin.
25113
- */
25114
- function calculateOffset(type, depth, labelElem, negative) {
25115
- if (depth === void 0) {
25116
- depth = 0;
25117
- }
25118
- if (labelElem === void 0) {
25119
- labelElem = false;
25120
- }
25121
- if (negative === void 0) {
25122
- negative = false;
25099
+ var TreeViewSelectable;
25100
+ (function (TreeViewSelectable) {
25101
+ TreeViewSelectable["single"] = "single";
25102
+ TreeViewSelectable["multi"] = "multi";
25103
+ TreeViewSelectable["off"] = "off";
25104
+ })(TreeViewSelectable || (TreeViewSelectable = {}));
25105
+
25106
+ var TreeViewContext = /*#__PURE__*/createContext({
25107
+ hasIcons: false,
25108
+ initialExpandedItems: [],
25109
+ initialExpandedItemsNeedUpdate: false,
25110
+ registerTreeItem: function registerTreeItem(elements, element) {},
25111
+ selectable: TreeViewSelectable.single,
25112
+ selectedItems: [],
25113
+ setInitialExpandedItemsNeedUpdate: function setInitialExpandedItemsNeedUpdate() {},
25114
+ checkParents: true,
25115
+ checkChildren: true,
25116
+ items: [],
25117
+ selectItem: function selectItem() {
25118
+ return undefined;
25123
25119
  }
25124
- var padding = 0;
25125
- if (type === TreeNodeType.leaf) {
25126
- if (labelElem) {
25127
- padding = depth * 8 + 40;
25128
- if (depth !== 0) {
25129
- padding += depth * 16;
25130
- }
25131
- } else if (depth === 0) {
25132
- padding = 40;
25133
- } else {
25134
- padding = 56;
25120
+ });
25121
+
25122
+ var checkedStatusToBoolean = function checkedStatusToBoolean(status) {
25123
+ return status === IndeterminateCheckboxStatus.checked;
25124
+ };
25125
+ function useTreeItem(props, forwardedRef) {
25126
+ var children = props.children,
25127
+ _props$isDisabled = props.isDisabled,
25128
+ isDisabled = _props$isDisabled === void 0 ? false : _props$isDisabled,
25129
+ itemDepth = props.itemDepth,
25130
+ itemId = props.itemId,
25131
+ onClick = props.onClick,
25132
+ parentDepth = props.parentDepth,
25133
+ topLevel = props.topLevel;
25134
+ var _React$useContext = useContext(TreeViewContext),
25135
+ initialExpandedItems = _React$useContext.initialExpandedItems,
25136
+ registerTreeItem = _React$useContext.registerTreeItem,
25137
+ selectable = _React$useContext.selectable,
25138
+ selectedItems = _React$useContext.selectedItems,
25139
+ treeItemRefArray = _React$useContext.treeItemRefArray,
25140
+ initialExpandedItemsNeedUpdate = _React$useContext.initialExpandedItemsNeedUpdate,
25141
+ items = _React$useContext.items,
25142
+ selectItem = _React$useContext.selectItem;
25143
+ var treeViewItemData = useMemo(function () {
25144
+ return items.find(function (item) {
25145
+ return item.itemId === itemId;
25146
+ });
25147
+ }, [itemId, items]);
25148
+ var checkedStatus = useMemo(function () {
25149
+ var _treeViewItemData$che;
25150
+ return (_treeViewItemData$che = treeViewItemData == null ? void 0 : treeViewItemData.checkedStatus) != null ? _treeViewItemData$che : IndeterminateCheckboxStatus.unchecked;
25151
+ }, [treeViewItemData]);
25152
+ var hasOwnTreeItems = useMemo(function () {
25153
+ return treeViewItemData == null ? void 0 : treeViewItemData.hasOwnTreeItems;
25154
+ }, [treeViewItemData]);
25155
+ var _React$useState = useState(false),
25156
+ expanded = _React$useState[0],
25157
+ setExpanded = _React$useState[1];
25158
+ var treeItemChildren = Children.toArray(children).filter(function (child) {
25159
+ return child.type === TreeItem;
25160
+ });
25161
+ var ownRef = useRef();
25162
+ var ref = useForkedRef(forwardedRef, ownRef);
25163
+ var forceUpdate = useForceUpdate();
25164
+ var generatedId = useGenerateId();
25165
+ useEffect(function () {
25166
+ if (!isDisabled && ownRef.current !== null) {
25167
+ registerTreeItem(treeItemRefArray, ownRef);
25135
25168
  }
25136
- } else if (type === TreeNodeType.branch) {
25137
- if (labelElem) {
25138
- padding = depth * 8 + 8;
25139
- if (depth !== 0) {
25140
- padding += depth * 16;
25169
+ forceUpdate();
25170
+ }, []);
25171
+ useEffect(function () {
25172
+ if (initialExpandedItemsNeedUpdate) {
25173
+ updateInitialExpanded();
25174
+ }
25175
+ }, [initialExpandedItemsNeedUpdate]);
25176
+ var updateInitialExpanded = function updateInitialExpanded() {
25177
+ if ((initialExpandedItems == null ? void 0 : initialExpandedItems.length) !== 0 && !isDisabled) {
25178
+ var childrenItemIds = getChildrenItemIdsFlat(treeItemChildren);
25179
+ var allExpanded = [].concat(initialExpandedItems, childrenItemIds);
25180
+ if (allExpanded != null && allExpanded.some(function (item) {
25181
+ return item === itemId;
25182
+ })) {
25183
+ setExpanded(true);
25184
+ } else {
25185
+ setExpanded(false);
25141
25186
  }
25142
- } else if (depth === 0) {
25143
- padding = 8;
25144
25187
  } else {
25145
- padding = 24;
25188
+ setExpanded(false);
25146
25189
  }
25147
- }
25148
- return "" + (negative ? '-' : '') + padding + "px";
25149
- }
25150
- function getTreeItemLabelColor(isInverse, disabled, theme) {
25151
- if (disabled) {
25152
- if (isInverse) {
25153
- return curriedTransparentize(0.6, theme.colors.neutral100);
25190
+ };
25191
+ var checkboxChangeHandler = function checkboxChangeHandler(event) {
25192
+ handleClick(event, itemId);
25193
+ };
25194
+ var handleClick = function handleClick(event, itemId) {
25195
+ if (selectable !== TreeViewSelectable.off) {
25196
+ selectItem({
25197
+ itemId: itemId,
25198
+ checkedStatus: checkedStatus === IndeterminateCheckboxStatus.checked ? IndeterminateCheckboxStatus.unchecked : IndeterminateCheckboxStatus.checked
25199
+ });
25200
+ onClick && typeof onClick === 'function' && onClick();
25154
25201
  }
25155
- return curriedTransparentize(0.6, theme.colors.neutral500);
25156
- }
25157
- if (isInverse) {
25158
- return theme.colors.neutral100;
25159
- }
25160
- return theme.colors.neutral700;
25161
- }
25162
- function getTreeItemWrapperCursor(disabled, selectable, nodeType) {
25163
- if (disabled) {
25164
- return 'not-allowed';
25165
- }
25166
- if (nodeType === TreeNodeType.branch && selectable === TreeViewSelectable.off || selectable === TreeViewSelectable.single) {
25167
- return 'pointer';
25168
- }
25169
- return 'default';
25170
- }
25171
- // Returns boolean if itemsArray has itemId
25172
- function arrayIncludesId(itemsArray, itemId) {
25173
- return itemsArray == null ? void 0 : itemsArray.some(function (item) {
25174
- return item.itemId === itemId;
25175
- });
25176
- }
25177
- // Return an array of objects of all the enabled children ids recursively
25178
- function getChildrenItemIds(children, status) {
25179
- if (status === void 0) {
25180
- status = '';
25202
+ };
25203
+ function getFocusIndex(filteredArrayCurrent) {
25204
+ return itemId && (filteredArrayCurrent == null ? void 0 : filteredArrayCurrent.findIndex(function (_ref) {
25205
+ var item = _ref.current;
25206
+ if (!item || !ownRef.current) return false;
25207
+ return item === ownRef.current;
25208
+ }));
25181
25209
  }
25182
- var itemIds = [];
25183
- React__default.Children.forEach(children, function (child) {
25184
- var _child$props;
25185
- if (!((_child$props = child.props) != null && _child$props.isDisabled)) {
25186
- var _child$props2, _child$props3;
25187
- var childStatus = status === IndeterminateCheckboxStatus.checked ? IndeterminateCheckboxStatus.checked : IndeterminateCheckboxStatus.unchecked;
25188
- if ((_child$props2 = child.props) != null && _child$props2.itemId && childStatus !== IndeterminateCheckboxStatus.unchecked) {
25189
- itemIds.push({
25190
- itemId: child.props.itemId,
25191
- checkedStatus: childStatus
25210
+ var focusIndex = getFocusIndex(treeItemRefArray == null ? void 0 : treeItemRefArray.current);
25211
+ useEffect(function () {
25212
+ treeItemRefArray == null || treeItemRefArray.current.map(function (itemRef) {
25213
+ if (!itemRef.current) {
25214
+ treeItemRefArray.current = treeItemRefArray.current.filter(function (item) {
25215
+ return itemRef.current !== item.current;
25192
25216
  });
25193
25217
  }
25194
- if ((_child$props3 = child.props) != null && _child$props3.children) {
25195
- var nestedItemIds = getChildrenItemIds(child.props.children, childStatus);
25196
- itemIds = itemIds.concat(nestedItemIds);
25197
- }
25218
+ });
25219
+ }, [treeItemRefArray]);
25220
+ var focusFirst = function focusFirst() {
25221
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
25222
+ var curr = filteredRefArray['current'];
25223
+ curr == null || curr[0].current.focus();
25224
+ };
25225
+ var focusNext = function focusNext() {
25226
+ var _curr$newIndex;
25227
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
25228
+ var curr = filteredRefArray['current'];
25229
+ var arrLength = curr.length;
25230
+ focusIndex = getFocusIndex(curr);
25231
+ var newIndex = focusIndex + 1;
25232
+ var next = curr == null || (_curr$newIndex = curr[newIndex]) == null ? void 0 : _curr$newIndex.current;
25233
+ while (!next && newIndex < arrLength) {
25234
+ var _curr$newIndex2;
25235
+ newIndex++;
25236
+ next = curr == null || (_curr$newIndex2 = curr[newIndex]) == null ? void 0 : _curr$newIndex2.current;
25198
25237
  }
25199
- });
25200
- return itemIds;
25201
- }
25202
- // Return an array of strings of all enabled children ids recursively
25203
- function getChildrenItemIdsFlat(children) {
25204
- var itemIds = [];
25205
- React__default.Children.forEach(children, function (child) {
25206
- var _child$props4;
25207
- if (!((_child$props4 = child.props) != null && _child$props4.isDisabled)) {
25208
- var _child$props5, _child$props6;
25209
- if ((_child$props5 = child.props) != null && _child$props5.itemId) {
25210
- itemIds.push(child.props.itemId);
25211
- }
25212
- if ((_child$props6 = child.props) != null && _child$props6.children) {
25213
- var nestedItemIds = getChildrenItemIdsFlat(child.props.children);
25214
- itemIds = itemIds.concat(nestedItemIds);
25238
+ if (next) {
25239
+ next.focus();
25240
+ } else {
25241
+ var _curr;
25242
+ var nextNext = curr == null || (_curr = curr[focusIndex + 2]) == null ? void 0 : _curr.current;
25243
+ if (nextNext) {
25244
+ nextNext.focus();
25245
+ } else {
25246
+ focusFirst();
25215
25247
  }
25216
25248
  }
25217
- });
25218
- return itemIds;
25219
- }
25220
- // Return an array of objects where all children are items are nested in the parents
25221
- function getChildrenItemIdsInTree(children) {
25222
- var itemIds = [];
25223
- React__default.Children.forEach(children, function (child) {
25224
- var _child$props7, _child$props8;
25225
- if ((_child$props7 = child.props) != null && _child$props7.itemId && !((_child$props8 = child.props) != null && _child$props8.isDisabled)) {
25226
- var _child$props9, _child$props10;
25227
- itemIds.push({
25228
- itemId: (_child$props9 = child.props) == null ? void 0 : _child$props9.itemId,
25229
- children: getChildrenItemIdsInTree((_child$props10 = child.props) == null ? void 0 : _child$props10.children)
25230
- });
25231
- }
25232
- });
25233
- return itemIds;
25234
- }
25235
- function getAllParentIds(childrenArr, itemId, parentItemIds) {
25236
- if (parentItemIds === void 0) {
25237
- parentItemIds = [];
25238
- }
25239
- for (var _iterator = _createForOfIteratorHelperLoose(childrenArr), _step; !(_step = _iterator()).done;) {
25240
- var child = _step.value;
25241
- if (child.itemId === itemId) {
25242
- return parentItemIds; // Return the parentItemIds array if the itemId is found
25249
+ };
25250
+ var focusPrev = function focusPrev() {
25251
+ var _curr$newIndex3;
25252
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
25253
+ var curr = filteredRefArray['current'];
25254
+ focusIndex = getFocusIndex(curr);
25255
+ var newIndex = focusIndex - 1;
25256
+ var itemToFocus = curr == null || (_curr$newIndex3 = curr[newIndex]) == null ? void 0 : _curr$newIndex3.current;
25257
+ while (!itemToFocus && newIndex >= 0) {
25258
+ var _curr$newIndex4;
25259
+ newIndex--;
25260
+ itemToFocus = curr == null || (_curr$newIndex4 = curr[newIndex]) == null ? void 0 : _curr$newIndex4.current;
25243
25261
  }
25244
- if (child.children && child.children.length > 0) {
25245
- var updatedParentItemIds = [].concat(parentItemIds, [child.itemId]);
25246
- var result = getAllParentIds(child.children, itemId, updatedParentItemIds);
25247
- if (result) {
25248
- return result; // Return the result if the itemId is found in the child's subtree
25249
- }
25262
+ if (itemToFocus) {
25263
+ itemToFocus.focus();
25250
25264
  }
25251
- }
25252
- return null; // Return null if the itemId is not found
25253
- }
25254
- // Return the node of an itemId by traversing through the children
25255
- function findChildByItemId(children, itemId) {
25256
- if (!children) {
25257
- return null;
25258
- }
25259
- for (var _iterator2 = _createForOfIteratorHelperLoose(children), _step2; !(_step2 = _iterator2()).done;) {
25260
- var _child$props11, _child$props12;
25261
- var child = _step2.value;
25262
- if ((child == null || (_child$props11 = child.props) == null ? void 0 : _child$props11.itemId) === itemId) {
25263
- return child;
25264
- }
25265
- if (child != null && (_child$props12 = child.props) != null && _child$props12.children) {
25266
- var _child$props13;
25267
- var nestedChild = findChildByItemId([child == null || (_child$props13 = child.props) == null ? void 0 : _child$props13.children], itemId);
25268
- if (nestedChild) {
25269
- return nestedChild;
25270
- }
25271
- }
25272
- }
25273
- return null;
25274
- }
25275
- // Return whether all the children are enabled
25276
- function getAllChildrenEnabled(children) {
25277
- return !children.some(function (child) {
25278
- return child.props.isDisabled;
25279
- });
25280
- }
25281
- // Return an array that filters out the childrenIds & itemId from selectedItems
25282
- // (used for deselecting indeterminate checkboxes)
25283
- function filterSelectedItems(selectedItems, childrenIds, itemId) {
25284
- var allItems = [].concat(childrenIds, [itemId]);
25285
- var ids = allItems.map(function (item) {
25286
- return item.itemId;
25287
- });
25288
- return selectedItems.filter(function (item) {
25289
- return !ids.includes(item.itemId);
25290
- });
25291
- }
25292
- // Return an array of childrenIds that are missing from selectedItems
25293
- function getMissingChildrenIds(selectedItems, childrenIds) {
25294
- var selectedIds = selectedItems.map(function (item) {
25295
- return item.itemId;
25296
- });
25297
- return childrenIds.filter(function (item) {
25298
- return !selectedIds.includes(item.itemId);
25299
- });
25300
- }
25301
- // Return an array of statuses for all enabled children
25302
- function getChildrenCheckedStatus(childrenIds, status) {
25303
- return childrenIds.map(function (child) {
25304
- return child.isDisabled ? IndeterminateCheckboxStatus.unchecked : status;
25305
- });
25306
- }
25307
- // Return the length of enabled children
25308
- function getEnabledTreeItemChildrenLength(treeItemChildren) {
25309
- return treeItemChildren.reduce(function (count, child) {
25310
- if (!child.props.isDisabled) {
25311
- return count + 1;
25312
- }
25313
- return count;
25314
- }, 0);
25315
- }
25316
- // Updates the checkedStatus of the itemId in selectedItems and returns the selectedItems
25317
- function getUpdatedSelectedItems(selectedItems, itemId, checkedStatus) {
25318
- var updatedItems = selectedItems.map(function (item) {
25319
- if (item.itemId === itemId) {
25320
- return _extends({}, item, {
25321
- checkedStatus: checkedStatus
25322
- });
25323
- }
25324
- return item;
25325
- });
25326
- return updatedItems;
25327
- }
25328
- // Return an array of unique items from the previous state, initially selected items and the childrem item ids
25329
- function getUniqueSelectedItemsArray(itemArr0, itemArr1, itemArr2) {
25330
- var combinedArray = [].concat(itemArr0, itemArr2, itemArr1);
25331
- var uniqueItemsMap = new Map();
25332
- for (var _iterator3 = _createForOfIteratorHelperLoose(combinedArray), _step3; !(_step3 = _iterator3()).done;) {
25333
- var item = _step3.value;
25334
- uniqueItemsMap.set(item.itemId, item);
25335
- }
25336
- return Array.from(uniqueItemsMap.values());
25337
- }
25338
- // Return items in both arrays
25339
- function findCommonItems(initialItemsArr, childrenItemsArr) {
25340
- var commonItems = [];
25341
- for (var _iterator4 = _createForOfIteratorHelperLoose(initialItemsArr), _step4; !(_step4 = _iterator4()).done;) {
25342
- var initialItem = _step4.value;
25343
- for (var _iterator5 = _createForOfIteratorHelperLoose(childrenItemsArr), _step5; !(_step5 = _iterator5()).done;) {
25344
- var childItem = _step5.value;
25345
- if (initialItem.itemId === childItem.itemId) {
25346
- commonItems.push(initialItem);
25347
- break;
25348
- }
25349
- }
25350
- }
25351
- return commonItems;
25352
- }
25353
- // Compares two arrays
25354
- function areArraysEqual(array1, array2) {
25355
- if (array1.length !== array2.length) {
25356
- return false;
25357
- }
25358
- for (var i = 0; i < array1.length; i++) {
25359
- var obj1 = array1[i];
25360
- var obj2 = array2[i];
25361
- var keys1 = Object.keys(obj1);
25362
- var keys2 = Object.keys(obj2);
25363
- if (keys1.length !== keys2.length) {
25364
- return false;
25365
- }
25366
- for (var _i = 0, _keys = keys1; _i < _keys.length; _i++) {
25367
- var key = _keys[_i];
25368
- if (obj1[key] !== obj2[key]) {
25369
- return false;
25370
- }
25371
- }
25372
- }
25373
- return true;
25374
- }
25375
- // Return the checkedStatus of an itemId
25376
- function getCheckedStatus(itemId, selectedItems) {
25377
- for (var _iterator6 = _createForOfIteratorHelperLoose(selectedItems), _step6; !(_step6 = _iterator6()).done;) {
25378
- var item = _step6.value;
25379
- if (item.itemId === itemId) {
25380
- return item.checkedStatus;
25381
- }
25382
- }
25383
- return null;
25384
- }
25385
- // Return first child that is a branch
25386
- function findFirstBranchNode(children) {
25387
- for (var _iterator7 = _createForOfIteratorHelperLoose(children), _step7; !(_step7 = _iterator7()).done;) {
25388
- var _item$props, _item$props2, _item$props3, _item$props4;
25389
- var item = _step7.value;
25390
- if ((_item$props = item.props) != null && _item$props.children && (_item$props2 = item.props) != null && _item$props2.children) {
25391
- return item;
25392
- }
25393
- if ((_item$props3 = item.props) != null && _item$props3.children && ((_item$props4 = item.props) == null ? void 0 : _item$props4.children.length) === 0) {
25394
- var _item$props5;
25395
- var childResult = findFirstBranchNode((_item$props5 = item.props) == null ? void 0 : _item$props5.children);
25396
- if (childResult) {
25397
- return childResult;
25265
+ };
25266
+ var focusLast = function focusLast() {
25267
+ var _filteredRefArray$cur;
25268
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
25269
+ var arrLength = filteredRefArray['current'].length;
25270
+ (_filteredRefArray$cur = filteredRefArray['current']) == null || _filteredRefArray$cur[arrLength - 1].current.focus();
25271
+ };
25272
+ var focusSelf = function focusSelf() {
25273
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
25274
+ var curr = filteredRefArray['current'];
25275
+ focusIndex = getFocusIndex(curr);
25276
+ curr == null || curr[focusIndex].current.focus();
25277
+ };
25278
+ var expandFocusedNode = function expandFocusedNode() {
25279
+ if (hasOwnTreeItems) {
25280
+ if (expanded) {
25281
+ focusNext();
25282
+ } else {
25283
+ setExpanded(true);
25284
+ focusSelf();
25398
25285
  }
25399
25286
  }
25400
- }
25401
- return null;
25402
- }
25403
- // Returns the first item in the tree from the array of selected items
25404
- function getFirstItemInTree(arr, children) {
25405
- // If there's only 1 item, return that one first
25406
- if (arr.length === 1) {
25407
- var _arr$;
25408
- return (_arr$ = arr[0]) == null ? void 0 : _arr$.itemId;
25409
- }
25410
- var allFoundItems = [];
25411
- var _loop2 = function _loop2() {
25412
- var _children$props, _children$props2;
25413
- var item = _step8.value;
25414
- var foundItem = Array.isArray(children) ? children.find(function (child) {
25415
- var _child$props14;
25416
- return ((_child$props14 = child.props) == null ? void 0 : _child$props14.itemId) === item.itemId;
25417
- }) : ((_children$props = children.props) == null ? void 0 : _children$props.itemId) === item.itemId;
25418
- if (foundItem) {
25419
- var _foundItem$props;
25420
- allFoundItems.push((_foundItem$props = foundItem.props) == null ? void 0 : _foundItem$props.itemId);
25421
- } else if ((_children$props2 = children.props) != null && _children$props2.children) {
25422
- var result = getFirstItemInTree(arr, children.props.children);
25423
- if (result) {
25424
- allFoundItems.push(result);
25287
+ };
25288
+ var collapseFocusedNode = function collapseFocusedNode() {
25289
+ if (hasOwnTreeItems) {
25290
+ if (expanded) {
25291
+ setExpanded(false);
25292
+ focusSelf();
25293
+ } else {
25294
+ focusPrev();
25425
25295
  }
25296
+ } else {
25297
+ focusPrev();
25426
25298
  }
25427
25299
  };
25428
- for (var _iterator8 = _createForOfIteratorHelperLoose(arr), _step8; !(_step8 = _iterator8()).done;) {
25429
- _loop2();
25430
- }
25431
- // After finding all the items, return the one that comes first on the tree (top to bottom)
25432
- if (allFoundItems.length === 1) {
25433
- return allFoundItems[0];
25434
- } else if (allFoundItems.length > 1) {
25435
- var _loop = function _loop() {
25436
- var ch = _step9.value;
25437
- return {
25438
- v: allFoundItems.find(function (i) {
25439
- var _ch$props;
25440
- return i === ((_ch$props = ch.props) == null ? void 0 : _ch$props.itemId);
25441
- })
25442
- };
25443
- },
25444
- _ret;
25445
- for (var _iterator9 = _createForOfIteratorHelperLoose(children), _step9; !(_step9 = _iterator9()).done;) {
25446
- _ret = _loop();
25447
- if (_ret) return _ret.v;
25448
- }
25449
- }
25450
- return null;
25451
- }
25452
- // Return a treeItemRefArray object with no null children
25453
- function filterNullEntries(obj) {
25454
- if (Array.isArray(obj.current)) {
25455
- var filteredArray = obj.current.filter(function (item) {
25456
- return (item == null ? void 0 : item.current) !== null;
25457
- });
25458
- if (filteredArray.length > 0) {
25459
- return {
25460
- current: filteredArray
25461
- };
25462
- }
25463
- }
25464
- return {};
25465
- }
25466
-
25467
- var TreeViewSelectable;
25468
- (function (TreeViewSelectable) {
25469
- TreeViewSelectable["single"] = "single";
25470
- TreeViewSelectable["multi"] = "multi";
25471
- TreeViewSelectable["off"] = "off";
25472
- })(TreeViewSelectable || (TreeViewSelectable = {}));
25473
- function useTreeView(props) {
25474
- var _props$selectable = props.selectable,
25475
- selectable = _props$selectable === void 0 ? TreeViewSelectable.single : _props$selectable,
25476
- onSelectedItemChange = props.onSelectedItemChange,
25477
- onExpandedChange = props.onExpandedChange,
25478
- initialExpandedItems = props.initialExpandedItems,
25479
- preselectedItems = props.preselectedItems,
25480
- _props$checkChildren = props.checkChildren,
25481
- checkChildren = _props$checkChildren === void 0 ? true : _props$checkChildren,
25482
- _props$checkParents = props.checkParents,
25483
- checkParents = _props$checkParents === void 0 ? true : _props$checkParents,
25484
- children = props.children;
25485
- var _React$useState = useState(false),
25486
- hasIcons = _React$useState[0],
25487
- setHasIcons = _React$useState[1];
25488
- var _React$useState2 = useState(preselectedItems || []),
25489
- selectedItems = _React$useState2[0],
25490
- setSelectedItems = _React$useState2[1];
25491
- var _React$useState3 = useState(false),
25492
- preselectedItemsNeedUpdate = _React$useState3[0],
25493
- setPreselectedItemsNeedUpdate = _React$useState3[1];
25494
- var _React$useState4 = useState(false),
25495
- initialExpandedItemsNeedUpdate = _React$useState4[0],
25496
- setInitialExpandedItemsNeedUpdate = _React$useState4[1];
25497
- var _React$useState5 = useState(false),
25498
- selectedItemsChanged = _React$useState5[0],
25499
- setSelectedItemsChanged = _React$useState5[1];
25500
- var _React$useState6 = useState(null),
25501
- itemToFocus = _React$useState6[0],
25502
- setItemToFocus = _React$useState6[1];
25503
- var _useDescendants = useDescendants(),
25504
- treeItemRefArray = _useDescendants[0],
25505
- registerTreeItem = _useDescendants[1];
25506
- useEffect(function () {
25507
- if (selectable !== TreeViewSelectable.off && preselectedItems) {
25508
- setPreselectedItemsNeedUpdate(true);
25509
- }
25510
- if (initialExpandedItems) {
25511
- setInitialExpandedItemsNeedUpdate(true);
25300
+ var handleKeyDown = function handleKeyDown(event) {
25301
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
25302
+ var curr = filteredRefArray['current'];
25303
+ var arrLength = curr.length;
25304
+ if (['ArrowDown', 'ArrowUp', 'Home', 'End', ' '].includes(event.key)) {
25305
+ event.preventDefault();
25512
25306
  }
25513
- getItemToFocusFirst();
25514
- }, []);
25515
- useEffect(function () {
25516
- if (selectable !== TreeViewSelectable.off && selectedItemsChanged) {
25517
- onSelectedItemChange && typeof onSelectedItemChange === 'function' && onSelectedItemChange(selectedItems);
25518
- setSelectedItemsChanged(false);
25519
- getItemToFocusFirst();
25520
- }
25521
- }, [selectedItemsChanged]);
25522
- function getItemToFocusFirst() {
25523
- var item = null;
25524
- if ((children == null ? void 0 : children.length) > 0) {
25525
- var _findFirstBranchNode;
25526
- var allChildrenInTree = getChildrenItemIdsInTree(children);
25527
- var firstBranchNode = (_findFirstBranchNode = findFirstBranchNode(children)) == null ? void 0 : _findFirstBranchNode.props.itemId;
25528
- var firstItemSelected = getFirstItemInTree(selectedItems, children);
25529
- var firstNode = allChildrenInTree == null ? void 0 : allChildrenInTree[0].itemId;
25530
- if (selectable === TreeViewSelectable.off) {
25531
- /*
25532
- If there is at least one node with a branch, focus is set on the first branch node.
25533
- If there are no nodes with branches, the first item is focused and the tree can be traversed
25534
- */
25535
- item = firstBranchNode || (allChildrenInTree == null ? void 0 : allChildrenInTree[0].itemId);
25536
- } else {
25537
- // Same behavior for Single and Multiple
25538
- if (selectedItems.length === 0) {
25539
- // If none of the nodes are selected before the tree receives focus, focus is set on the first node.
25540
- item = firstNode;
25541
- } else if (selectedItems.length > 0) {
25542
- // If one or more nodes are selected before the tree receives focus, focus is set on the first selected node.
25543
- item = firstItemSelected;
25307
+ switch (event.key) {
25308
+ case 'ArrowDown':
25309
+ {
25310
+ // Move to the next item, or wrap to first
25311
+ focusIndex === arrLength - 1 ? focusFirst() : focusNext();
25312
+ break;
25544
25313
  }
25545
- }
25314
+ case 'ArrowUp':
25315
+ {
25316
+ // Move to the previous item, or wrap to last
25317
+ focusIndex === 0 ? focusLast() : focusPrev();
25318
+ break;
25319
+ }
25320
+ case 'ArrowRight':
25321
+ {
25322
+ // Open parent nodes
25323
+ expandFocusedNode();
25324
+ break;
25325
+ }
25326
+ case 'ArrowLeft':
25327
+ {
25328
+ // Close open parent nodes
25329
+ collapseFocusedNode();
25330
+ break;
25331
+ }
25332
+ case 'Home':
25333
+ {
25334
+ // Moves focus to the first node in the tree without opening or closing a node.
25335
+ focusFirst();
25336
+ break;
25337
+ }
25338
+ case 'End':
25339
+ {
25340
+ // Moves focus to the last node in the tree that is focusable without opening a node.
25341
+ focusLast();
25342
+ break;
25343
+ }
25344
+ case 'Enter':
25345
+ {
25346
+ // Activates a node, i.e., performs its default action.
25347
+ if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {
25348
+ setExpanded(!expanded);
25349
+ } else if (selectable === TreeViewSelectable.single) {
25350
+ // In single-select it selects the focused node.
25351
+ selectItem({
25352
+ itemId: itemId,
25353
+ checkedStatus: IndeterminateCheckboxStatus.checked
25354
+ });
25355
+ } else if (selectable === TreeViewSelectable.multi) {
25356
+ // In multi-select, it toggles the selection state of the focused node.
25357
+ selectItem({
25358
+ itemId: itemId,
25359
+ checkedStatus: checkedStatus === IndeterminateCheckboxStatus.checked ? IndeterminateCheckboxStatus.unchecked : IndeterminateCheckboxStatus.checked
25360
+ });
25361
+ }
25362
+ break;
25363
+ }
25364
+ case ' ':
25365
+ {
25366
+ // Toggles the selection state of the focused node.
25367
+ if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {
25368
+ setExpanded(!expanded);
25369
+ } else if (selectable === TreeViewSelectable.single) {
25370
+ if (hasOwnTreeItems) {
25371
+ setExpanded(!expanded);
25372
+ } else {
25373
+ selectItem({
25374
+ itemId: itemId,
25375
+ checkedStatus: IndeterminateCheckboxStatus.checked
25376
+ });
25377
+ }
25378
+ } else if (selectable === TreeViewSelectable.multi) {
25379
+ selectItem({
25380
+ itemId: itemId,
25381
+ checkedStatus: checkedStatus === IndeterminateCheckboxStatus.checked ? IndeterminateCheckboxStatus.unchecked : IndeterminateCheckboxStatus.checked
25382
+ });
25383
+ }
25384
+ break;
25385
+ }
25386
+ default:
25387
+ return;
25546
25388
  }
25547
- setItemToFocus(item);
25548
- }
25389
+ };
25549
25390
  var contextValue = {
25550
- hasIcons: hasIcons,
25551
- itemToFocus: itemToFocus,
25552
- onSelectedItemChange: onSelectedItemChange,
25553
- onExpandedChange: onExpandedChange,
25554
- selectable: selectable,
25555
- setHasIcons: setHasIcons,
25391
+ checkboxChangeHandler: checkboxChangeHandler,
25392
+ checkedStatus: checkedStatus,
25393
+ expanded: expanded,
25394
+ hasOwnTreeItems: hasOwnTreeItems,
25395
+ itemDepth: parentDepth === 0 && topLevel ? 0 : itemDepth + 1,
25396
+ itemId: itemId || generatedId,
25397
+ parentDepth: parentDepth,
25398
+ ref: ref,
25556
25399
  selectedItems: selectedItems,
25557
- setSelectedItems: setSelectedItems,
25558
- initialExpandedItems: initialExpandedItems,
25559
- treeItemRefArray: treeItemRefArray,
25560
- registerTreeItem: registerTreeItem,
25561
- preselectedItemsNeedUpdate: preselectedItemsNeedUpdate,
25562
- setPreselectedItemsNeedUpdate: setPreselectedItemsNeedUpdate,
25563
- initialExpandedItemsNeedUpdate: initialExpandedItemsNeedUpdate,
25564
- setInitialExpandedItemsNeedUpdate: setInitialExpandedItemsNeedUpdate,
25565
- selectedItemsChanged: selectedItemsChanged,
25566
- setSelectedItemsChanged: setSelectedItemsChanged,
25567
- checkChildren: checkChildren,
25568
- checkParents: checkParents
25400
+ setExpanded: setExpanded,
25401
+ treeItemChildren: treeItemChildren
25569
25402
  };
25570
25403
  return {
25571
- contextValue: contextValue
25404
+ contextValue: contextValue,
25405
+ handleClick: handleClick,
25406
+ handleKeyDown: handleKeyDown
25572
25407
  };
25573
25408
  }
25574
25409
 
25575
- var TreeViewContext = /*#__PURE__*/createContext({
25576
- hasIcons: false,
25577
- initialExpandedItems: [],
25578
- initialExpandedItemsNeedUpdate: false,
25579
- preselectedItemsNeedUpdate: false,
25580
- registerTreeItem: function registerTreeItem(elements, element) {},
25581
- selectable: TreeViewSelectable.single,
25582
- selectedItems: [],
25583
- selectedItemsChanged: false,
25584
- setHasIcons: function setHasIcons() {},
25585
- setInitialExpandedItemsNeedUpdate: function setInitialExpandedItemsNeedUpdate() {},
25586
- setPreselectedItemsNeedUpdate: function setPreselectedItemsNeedUpdate() {},
25587
- setSelectedItems: function setSelectedItems() {},
25588
- setSelectedItemsChanged: function setSelectedItemsChanged() {},
25589
- checkParents: true,
25590
- checkChildren: true
25410
+ var TreeItemContext = /*#__PURE__*/createContext({
25411
+ expanded: false,
25412
+ setExpanded: function setExpanded() {},
25413
+ checkedStatus: IndeterminateCheckboxStatus.unchecked,
25414
+ checkboxChangeHandler: function checkboxChangeHandler() {},
25415
+ hasOwnTreeItems: false,
25416
+ parentDepth: 0
25591
25417
  });
25592
25418
 
25593
- var checkedStatusToBoolean = function checkedStatusToBoolean(status) {
25594
- return status === IndeterminateCheckboxStatus.checked;
25595
- };
25596
- function useTreeItem(props, forwardedRef) {
25597
- var children = props.children,
25598
- icon = props.icon,
25599
- index = props.index,
25600
- _props$isDisabled = props.isDisabled,
25601
- isDisabled = _props$isDisabled === void 0 ? false : _props$isDisabled,
25602
- itemDepth = props.itemDepth,
25603
- itemId = props.itemId,
25604
- onClick = props.onClick,
25605
- parentCheckedStatus = props.parentCheckedStatus,
25606
- parentDepth = props.parentDepth,
25607
- topLevel = props.topLevel,
25608
- updateParentCheckStatus = props.updateParentCheckStatus;
25419
+ var _excluded$1B = ["children", "icon", "index", "isDisabled", "label", "labelStyle", "style", "testId", "topLevel"];
25420
+ var StyledTreeItem = /*#__PURE__*/_styled("li", {
25421
+ target: "e1xiryew5",
25422
+ label: "StyledTreeItem"
25423
+ })("color:", function (props) {
25424
+ return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
25425
+ }, ";list-style-type:none;cursor:", function (props) {
25426
+ return getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType);
25427
+ }, ";position:relative;margin-bottom:0;padding-inline-start:", function (props) {
25428
+ return calculateOffset(props.nodeType, props.depth);
25429
+ }, ";>div:first-of-type{background:", function (props) {
25430
+ return props.selected && props.isInverse ? curriedTransparentize(0.7, props.theme.colors.neutral900) : props.selected && curriedTransparentize(0.92, props.theme.colors.neutral900);
25431
+ }, ";position:relative;padding-inline-start:", function (props) {
25432
+ return calculateOffset(props.nodeType, props.depth, true);
25433
+ }, ";margin-inline-start:", function (props) {
25434
+ return calculateOffset(props.nodeType, props.depth, true, true);
25435
+ }, ";padding-block-end:", function (props) {
25436
+ return props.theme.spaceScale.spacing02;
25437
+ }, ";padding-block-start:", function (props) {
25438
+ return props.theme.spaceScale.spacing02;
25439
+ }, ";padding-right:", function (props) {
25440
+ return props.theme.spaceScale.spacing02;
25441
+ }, ";", function (props) {
25442
+ return props.selected && /*#__PURE__*/css("&:before{position:absolute;background-color:", props.isInverse ? props.theme.colors.tertiary500 : props.theme.colors.primary500, ";block-size:100%;content:'';inline-size:", props.theme.spaceScale.spacing02, ";inset-block-start:0;inset-inline-start:0;};label:StyledTreeItem;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAwCQ","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
25443
+ }, " &:hover{background:", function (props) {
25444
+ return !props.isDisabled ? props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral900) : curriedTransparentize(0.95, props.theme.colors.neutral900) : undefined;
25445
+ }, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAeiC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
25446
+ var IconWrapper$8 = /*#__PURE__*/_styled("span", {
25447
+ target: "e1xiryew4",
25448
+ label: "IconWrapper"
25449
+ })("color:", function (props) {
25450
+ return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
25451
+ }, ";margin-right:", function (props) {
25452
+ return props.theme.spaceScale.spacing03;
25453
+ }, ";margin-left:0px;svg{height:", function (props) {
25454
+ return props.theme.iconSizes.medium;
25455
+ }, "px;width:", function (props) {
25456
+ return props.theme.iconSizes.medium;
25457
+ }, "px;vertical-align:middle;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA8DgC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
25458
+ var StyledLabelWrapper = /*#__PURE__*/_styled("span", {
25459
+ target: "e1xiryew3",
25460
+ label: "StyledLabelWrapper"
25461
+ })("display:flex;align-items:flex-start;color:", function (props) {
25462
+ return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
25463
+ }, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAwEuC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
25464
+ var StyledExpandWrapper = /*#__PURE__*/_styled("div", {
25465
+ target: "e1xiryew2",
25466
+ label: "StyledExpandWrapper"
25467
+ })("display:inline-block;vertical-align:middle;margin-right:", function (props) {
25468
+ return props.theme.spaceScale.spacing03;
25469
+ }, ";color:", function (props) {
25470
+ return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
25471
+ }, ";border-radius:0;width:", function (props) {
25472
+ return props.theme.spaceScale.spacing06;
25473
+ }, ";height:", function (props) {
25474
+ return props.theme.spaceScale.spacing06;
25475
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA8EuC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
25476
+ var StyledCheckboxWrapper = /*#__PURE__*/_styled("div", {
25477
+ target: "e1xiryew1",
25478
+ label: "StyledCheckboxWrapper"
25479
+ })("margin-right:", function (props) {
25480
+ return props.theme.spaceScale.spacing03;
25481
+ }, ";vertical-align:middle;display:inline-flex;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAuFyC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
25482
+ var StyledItemWrapper = /*#__PURE__*/_styled("div", {
25483
+ target: "e1xiryew0",
25484
+ label: "StyledItemWrapper"
25485
+ })("display:flex;align-items:flex-start;cursor:", function (props) {
25486
+ return getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType);
25487
+ }, ";&:focus{outline-offset:-2px;outline:2px solid ", function (props) {
25488
+ return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
25489
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA4FqC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
25490
+ var TreeItem = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
25491
+ var _selectedItems$;
25492
+ var children = props.children,
25493
+ icon = props.icon,
25494
+ isDisabled = props.isDisabled,
25495
+ label = props.label,
25496
+ labelStyle = props.labelStyle,
25497
+ style = props.style,
25498
+ testId = props.testId,
25499
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1B);
25500
+ var theme = useContext(ThemeContext);
25501
+ var isInverse = useIsInverse();
25609
25502
  var _React$useContext = useContext(TreeViewContext),
25610
- initialExpandedItems = _React$useContext.initialExpandedItems,
25611
- registerTreeItem = _React$useContext.registerTreeItem,
25612
25503
  selectable = _React$useContext.selectable,
25613
- selectedItems = _React$useContext.selectedItems,
25614
- setHasIcons = _React$useContext.setHasIcons,
25615
- setSelectedItems = _React$useContext.setSelectedItems,
25616
- treeItemRefArray = _React$useContext.treeItemRefArray,
25617
- preselectedItemsNeedUpdate = _React$useContext.preselectedItemsNeedUpdate,
25618
- setPreselectedItemsNeedUpdate = _React$useContext.setPreselectedItemsNeedUpdate,
25619
- initialExpandedItemsNeedUpdate = _React$useContext.initialExpandedItemsNeedUpdate,
25620
- setSelectedItemsChanged = _React$useContext.setSelectedItemsChanged,
25621
- selectedItemsChanged = _React$useContext.selectedItemsChanged,
25622
- checkParents = _React$useContext.checkParents,
25623
- checkChildren = _React$useContext.checkChildren;
25624
- // Needs to skip sending an "onSelection" event during the initial render of items
25625
- var _React$useState = useState(false),
25626
- isSkipSelectedItemsUpdate = _React$useState[0],
25627
- setIsSkipSelectedItemsUpdate = _React$useState[1];
25628
- var _React$useState2 = useState(false),
25629
- expanded = _React$useState2[0],
25630
- setExpanded = _React$useState2[1];
25631
- var _React$useState3 = useState(IndeterminateCheckboxStatus.unchecked),
25632
- checkedStatus = _React$useState3[0],
25633
- setCheckedStatus = _React$useState3[1];
25634
- var _React$useState4 = useState(undefined),
25635
- statusUpdatedBy = _React$useState4[0],
25636
- setStatusUpdatedBy = _React$useState4[1];
25637
- var treeItemChildren = Children.toArray(children).filter(function (child) {
25638
- return child.type === TreeItem;
25504
+ hasIcons = _React$useContext.hasIcons,
25505
+ onExpandedChange = _React$useContext.onExpandedChange,
25506
+ itemToFocus = _React$useContext.itemToFocus;
25507
+ var _useTreeItem = useTreeItem(props, forwardedRef),
25508
+ contextValue = _useTreeItem.contextValue,
25509
+ handleClick = _useTreeItem.handleClick,
25510
+ handleKeyDown = _useTreeItem.handleKeyDown;
25511
+ var checkboxChangeHandler = contextValue.checkboxChangeHandler,
25512
+ checkedStatus = contextValue.checkedStatus,
25513
+ expanded = contextValue.expanded,
25514
+ hasOwnTreeItems = contextValue.hasOwnTreeItems,
25515
+ itemDepth = contextValue.itemDepth,
25516
+ itemId = contextValue.itemId,
25517
+ parentDepth = contextValue.parentDepth,
25518
+ ref = contextValue.ref,
25519
+ selectedItems = contextValue.selectedItems,
25520
+ setExpanded = contextValue.setExpanded;
25521
+ var nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;
25522
+ var selectedItem = selectable === TreeViewSelectable.single ? (selectedItems == null || (_selectedItems$ = selectedItems[0]) == null ? void 0 : _selectedItems$.itemId) === itemId : null;
25523
+ var ariaCheckedValue = selectable === TreeViewSelectable.multi ? checkedStatus === IndeterminateCheckboxStatus.indeterminate ? 'mixed' : checkedStatus === IndeterminateCheckboxStatus.checked : null;
25524
+ var defaultIcon = nodeType === TreeNodeType.branch ? createElement(FolderIcon, {
25525
+ "aria-hidden": true
25526
+ }) : createElement(ArticleIcon, {
25527
+ "aria-hidden": true
25639
25528
  });
25640
- // TODO fix for disabled items (issue #1305)
25641
- // const numberOfTreeItemChildren = getEnabledTreeItemChildrenLength(treeItemChildren);
25642
- var numberOfTreeItemChildren = treeItemChildren.length;
25643
- var hasOwnTreeItems = numberOfTreeItemChildren > 0;
25644
- var _React$useState5 = useState(Array(numberOfTreeItemChildren).fill(IndeterminateCheckboxStatus.unchecked)),
25645
- childrenCheckedStatus = _React$useState5[0],
25646
- setChildrenCheckedStatus = _React$useState5[1];
25647
- var ownRef = useRef();
25648
- var ref = useForkedRef(forwardedRef, ownRef);
25649
- var forceUpdate = useForceUpdate();
25650
- var generatedId = useGenerateId();
25651
- useEffect(function () {
25652
- setTreeViewIconVisibility();
25653
- selectedItems.map(function (item) {
25654
- if ((item == null ? void 0 : item.itemId) === itemId) {
25655
- var newStatus = item == null ? void 0 : item.checkedStatus;
25656
- if (checkedStatus !== newStatus) {
25657
- var childrenOfItemId = getChildrenItemIds(treeItemChildren, IndeterminateCheckboxStatus.checked);
25658
- var itemIdChildrenInTree = getChildrenItemIdsInTree(treeItemChildren);
25659
- var parentIds = itemId && itemIdChildrenInTree.length > 0 ? getAllParentIds(itemIdChildrenInTree, itemId) : [];
25660
- var additionalItems = [];
25661
- if (newStatus === IndeterminateCheckboxStatus.checked) {
25662
- if (parentIds && checkParents) additionalItems.push.apply(additionalItems, parentIds);
25663
- if (hasOwnTreeItems && checkChildren) additionalItems.push.apply(additionalItems, childrenOfItemId);
25664
- }
25665
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
25666
- setCheckedStatus(item == null ? void 0 : item.checkedStatus);
25667
- if (selectable === TreeViewSelectable.multi) {
25668
- // Pass "true" as isInitialRender value to skip sending an "onSelection" event
25669
- // Required since this useEffect handles initial rendering of the item
25670
- updateParentCheckStatus(index, newStatus, true);
25671
- }
25672
- setSelectedItems(function (prev) {
25673
- return getUniqueSelectedItemsArray([{
25674
- itemId: itemId,
25675
- checkedStatus: newStatus
25676
- }], prev, additionalItems);
25677
- });
25678
- }
25679
- return;
25529
+ var labelText = createElement(StyledLabelWrapper, {
25530
+ theme: theme,
25531
+ isDisabled: isDisabled,
25532
+ isInverse: isInverse,
25533
+ style: labelStyle,
25534
+ id: itemId + "-label",
25535
+ "data-testid": (testId || itemId) + "-label",
25536
+ onClick: function onClick(e) {
25537
+ if (selectable === TreeViewSelectable.single && !isDisabled) {
25538
+ handleClick(e, itemId);
25680
25539
  }
25681
- });
25682
- if (!isDisabled && ownRef.current !== null) {
25683
- registerTreeItem(treeItemRefArray, ownRef);
25684
- }
25685
- forceUpdate();
25686
- }, []);
25687
- function setTreeViewIconVisibility() {
25688
- if (treeItemChildren.length === 0 && icon) {
25689
- setHasIcons(true);
25690
- return;
25691
- }
25692
- treeItemChildren.forEach(function (child) {
25693
- if (child != null && child.props.icon) {
25694
- setHasIcons(true);
25695
- return;
25696
- }
25697
- });
25698
- }
25699
- function updateSelectedItemsChanged() {
25700
- if (topLevel && !selectedItemsChanged) {
25701
- setSelectedItemsChanged(true);
25702
- }
25703
- }
25704
- useEffect(function () {
25705
- if (preselectedItemsNeedUpdate) {
25706
- updateInitialSelected();
25707
- }
25708
- }, [preselectedItemsNeedUpdate]);
25709
- useEffect(function () {
25710
- if (initialExpandedItemsNeedUpdate) {
25711
- updateInitialExpanded();
25712
- }
25713
- }, [initialExpandedItemsNeedUpdate]);
25714
- var updateCheckedStatusFromChild = function updateCheckedStatusFromChild(index, status, isInitialRender) {
25715
- if (checkParents) {
25716
- // Set isSkipSelectedItemsUpdate as true if this update caused by the initial render of children during expanding
25717
- setIsSkipSelectedItemsUpdate(Boolean(isInitialRender));
25718
- setStatusUpdatedBy("children" /* children */);
25719
- setChildrenCheckedStatus(function (prev) {
25720
- var newChildrenCheckedStatus = [].concat(prev);
25721
- newChildrenCheckedStatus[index] = status;
25722
- return newChildrenCheckedStatus;
25723
- });
25724
25540
  }
25541
+ }, hasIcons && createElement(IconWrapper$8, {
25542
+ isInverse: isInverse,
25543
+ theme: theme,
25544
+ isDisabled: isDisabled,
25545
+ "data-testid": (testId || itemId) + "-icon"
25546
+ }, icon || defaultIcon), label);
25547
+ // Props shared by Checkbox and IndeterminateCheckbox
25548
+ var checkboxProps = {
25549
+ disabled: isDisabled,
25550
+ hideFocus: true,
25551
+ id: itemId + "-checkbox",
25552
+ inputStyle: {
25553
+ marginRight: theme.spaceScale.spacing03
25554
+ },
25555
+ labelStyle: {
25556
+ padding: 0
25557
+ },
25558
+ labelText: labelText,
25559
+ onChange: checkboxChangeHandler,
25560
+ tabIndex: -1,
25561
+ testId: itemId + "-checkbox"
25725
25562
  };
25726
- var updateStatusForItem = function updateStatusForItem(childrenItemIds, preselectedChildrenItems, itemId, itemIdChildren) {
25727
- var item = preselectedChildrenItems.find(function (child) {
25728
- return child.itemId === itemId;
25729
- });
25730
- var itemStatus = item != null && item.checkedStatus || areArraysEqual(preselectedChildrenItems, childrenItemIds) ? IndeterminateCheckboxStatus.checked : IndeterminateCheckboxStatus.indeterminate;
25731
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
25732
- setCheckedStatus(itemStatus);
25733
- updateParentCheckStatus(index, itemStatus);
25734
- if (!item) {
25735
- setSelectedItems(function (prev) {
25736
- return getUniqueSelectedItemsArray([{
25737
- itemId: itemId,
25738
- checkedStatus: itemStatus
25739
- }], preselectedChildrenItems, prev);
25740
- });
25741
- setSelectedItemsChanged(true);
25742
- return;
25743
- }
25744
- var thisItem = itemIdChildren.find(function (child) {
25745
- return child.itemId === itemId;
25563
+ var onExpandedClicked = function onExpandedClicked(event) {
25564
+ setExpanded(function (state) {
25565
+ return !state;
25746
25566
  });
25747
- if ((thisItem == null ? void 0 : thisItem.children.length) > 0 && (item == null ? void 0 : item.checkedStatus) === IndeterminateCheckboxStatus.checked) {
25748
- var itemNode = findChildByItemId(treeItemChildren, thisItem == null ? void 0 : thisItem.itemId);
25749
- var newChildren = getChildrenItemIds(itemNode == null ? void 0 : itemNode.props.children, checkedStatus);
25750
- setSelectedItems(function (prev) {
25751
- return getUniqueSelectedItemsArray([{
25752
- itemId: itemId,
25753
- checkedStatus: itemStatus
25754
- }], newChildren, prev);
25755
- });
25756
- setSelectedItemsChanged(true);
25757
- }
25758
- };
25759
- var updateInitialExpanded = function updateInitialExpanded() {
25760
- if ((initialExpandedItems == null ? void 0 : initialExpandedItems.length) !== 0 && !isDisabled) {
25761
- var childrenItemIds = getChildrenItemIdsFlat(treeItemChildren);
25762
- var allExpanded = [].concat(initialExpandedItems, childrenItemIds);
25763
- if (allExpanded != null && allExpanded.some(function (item) {
25764
- return item === itemId;
25765
- })) {
25766
- setExpanded(true);
25767
- } else {
25768
- setExpanded(false);
25769
- }
25770
- } else {
25771
- setExpanded(false);
25772
- }
25567
+ event.preventDefault();
25568
+ onExpandedChange && typeof onExpandedChange === 'function' && onExpandedChange(event);
25773
25569
  };
25774
- var updateInitialSelected = function updateInitialSelected() {
25775
- if (selectable === TreeViewSelectable.single && selectedItems) {
25776
- var _selectedItems$;
25777
- var firstItemId = selectedItems == null || (_selectedItems$ = selectedItems[0]) == null ? void 0 : _selectedItems$.itemId;
25778
- if (firstItemId && !isDisabled) {
25779
- setSelectedItems(function (prev) {
25780
- if (!arrayIncludesId(prev, firstItemId)) {
25781
- return [{
25782
- itemId: firstItemId,
25783
- checkedStatus: IndeterminateCheckboxStatus.checked
25784
- }];
25785
- }
25786
- });
25787
- setSelectedItemsChanged(true);
25788
- }
25789
- } else if (selectable === TreeViewSelectable.multi && selectedItems) {
25790
- var item = selectedItems.find(function (obj) {
25791
- return obj.itemId === itemId;
25792
- });
25793
- var status = item == null ? void 0 : item.checkedStatus;
25794
- var childrenItemIds = getChildrenItemIds(treeItemChildren, status || IndeterminateCheckboxStatus.checked);
25795
- // Items from selectedItems that are children
25796
- var preselectedChildrenItems = findCommonItems(childrenItemIds, selectedItems);
25797
- if (!isDisabled && (arrayIncludesId(selectedItems, itemId) || childrenItemIds != null && childrenItemIds.includes(itemId))) {
25798
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
25799
- setCheckedStatus(status);
25800
- updateParentCheckStatus(index, status);
25801
- if (childrenItemIds.length > 0 && status === IndeterminateCheckboxStatus.checked) {
25802
- var newChildrenCheckedStatus = getChildrenCheckedStatus(childrenItemIds, checkChildren && status);
25803
- setChildrenCheckedStatus(newChildrenCheckedStatus);
25804
- }
25805
- setSelectedItems(function (prev) {
25806
- var allItems = getUniqueSelectedItemsArray(childrenItemIds, selectedItems, prev);
25807
- return allItems;
25808
- });
25809
- updateSelectedItemsChanged();
25810
- } else if (!isDisabled && preselectedChildrenItems.length > 0 && checkParents) {
25811
- // Case for selectedItems that are inside a collapsed item
25812
- var itemIdChildren = getChildrenItemIdsInTree(treeItemChildren);
25813
- for (var _iterator = _createForOfIteratorHelperLoose(preselectedChildrenItems), _step; !(_step = _iterator()).done;) {
25814
- var _itemIdNode$props;
25815
- var i = _step.value;
25816
- var itemIdNode = findChildByItemId(treeItemChildren, i.itemId);
25817
- var childrenOfItemId = getChildrenItemIds(itemIdNode == null || (_itemIdNode$props = itemIdNode.props) == null ? void 0 : _itemIdNode$props.children, IndeterminateCheckboxStatus.checked);
25818
- var parentIds = getAllParentIds(itemIdChildren, i.itemId);
25819
- for (var _iterator2 = _createForOfIteratorHelperLoose(parentIds), _step2; !(_step2 = _iterator2()).done;) {
25820
- var p = _step2.value;
25821
- updateStatusForItem(childrenOfItemId, preselectedChildrenItems, p, itemIdChildren);
25822
- }
25823
- }
25824
- updateStatusForItem(childrenItemIds, preselectedChildrenItems, itemId, itemIdChildren);
25570
+ return createElement(TreeItemContext.Provider, {
25571
+ value: contextValue
25572
+ }, createElement(StyledTreeItem, Object.assign({}, rest, {
25573
+ "aria-expanded": hasOwnTreeItems ? expanded : null,
25574
+ "aria-selected": selectedItem,
25575
+ "aria-checked": ariaCheckedValue,
25576
+ "data-testid": testId,
25577
+ depth: itemDepth,
25578
+ hasOwnTreeItems: true,
25579
+ id: itemId,
25580
+ isDisabled: isDisabled,
25581
+ isInverse: isInverse,
25582
+ nodeType: nodeType,
25583
+ role: "treeitem",
25584
+ selectableType: selectable,
25585
+ selected: selectedItem,
25586
+ theme: theme
25587
+ }), createElement(StyledItemWrapper, {
25588
+ "data-testid": (testId || itemId) + "-itemwrapper",
25589
+ depth: itemDepth,
25590
+ id: itemId + "-itemwrapper",
25591
+ isDisabled: isDisabled,
25592
+ isInverse: isInverse,
25593
+ nodeType: nodeType,
25594
+ onClick: function onClick(event) {
25595
+ if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {
25596
+ onExpandedClicked(event);
25825
25597
  }
25826
- }
25827
- setPreselectedItemsNeedUpdate(false);
25828
- };
25829
- useEffect(function () {
25830
- if (statusUpdatedBy && updateParentCheckStatus && !topLevel) {
25831
- updateParentCheckStatus(index, checkedStatus);
25832
- }
25833
- setStatusUpdatedBy(undefined);
25834
- }, [checkedStatus]);
25835
- useEffect(function () {
25836
- if (parentCheckedStatus && checkChildren && checkedStatus !== parentCheckedStatus && parentCheckedStatus !== IndeterminateCheckboxStatus.indeterminate && !topLevel && !isDisabled) {
25837
- setStatusUpdatedBy("parent" /* parent */);
25838
- setCheckedStatus(parentCheckedStatus);
25839
- if (hasOwnTreeItems) {
25840
- if (getAllChildrenEnabled(treeItemChildren)) {
25841
- setChildrenCheckedStatus(Array(numberOfTreeItemChildren).fill(parentCheckedStatus));
25842
- } else {
25843
- var childrenIds = getChildrenItemIds(treeItemChildren);
25844
- var newChildrenCheckedStatus = getChildrenCheckedStatus(childrenIds, parentCheckedStatus);
25845
- setChildrenCheckedStatus(newChildrenCheckedStatus);
25846
- }
25598
+ },
25599
+ onKeyDown: function onKeyDown(e) {
25600
+ handleKeyDown(e);
25601
+ },
25602
+ ref: ref,
25603
+ selectable: selectable,
25604
+ style: style,
25605
+ tabIndex: itemToFocus === itemId ? 0 : -1,
25606
+ theme: theme
25607
+ }, hasOwnTreeItems && createElement(StyledExpandWrapper, {
25608
+ "aria-hidden": Boolean(!expanded),
25609
+ "data-testid": (testId || itemId) + "-expand",
25610
+ isDisabled: isDisabled,
25611
+ isInverse: isInverse,
25612
+ onClick: function onClick(event) {
25613
+ if (!isDisabled && selectable !== TreeViewSelectable.off) {
25614
+ onExpandedClicked(event);
25847
25615
  }
25848
- }
25849
- }, [parentCheckedStatus]);
25850
- useEffect(function () {
25851
- if (statusUpdatedBy && (childrenCheckedStatus == null ? void 0 : childrenCheckedStatus[0]) !== undefined) {
25852
- var statusFromChildren = childrenCheckedStatus.every(function (status) {
25853
- return status === childrenCheckedStatus[0];
25854
- }) ? childrenCheckedStatus[0] : IndeterminateCheckboxStatus.indeterminate;
25855
- var updateItemStatus = getUpdatedSelectedItems(selectedItems, itemId, statusFromChildren);
25856
- if (checkedStatus !== statusFromChildren && statusUpdatedBy !== "parent" /* parent */) {
25857
- setStatusUpdatedBy("children" /* children */);
25858
- setCheckedStatus(statusFromChildren);
25859
- if (statusFromChildren === IndeterminateCheckboxStatus.checked || statusFromChildren === IndeterminateCheckboxStatus.indeterminate) {
25860
- if (itemId && !arrayIncludesId(selectedItems, itemId)) {
25861
- setSelectedItems([].concat(selectedItems, [{
25862
- itemId: itemId,
25863
- checkedStatus: statusFromChildren
25864
- }]));
25865
- updateSelectedItemsChanged();
25866
- } else {
25867
- setSelectedItems(updateItemStatus);
25868
- updateSelectedItemsChanged();
25869
- }
25870
- } else if (statusFromChildren === IndeterminateCheckboxStatus.unchecked) {
25871
- setSelectedItems(selectedItems.filter(function (obj) {
25872
- return obj.itemId !== itemId;
25873
- }));
25874
- updateSelectedItemsChanged();
25875
- }
25876
- } else if (checkedStatus === statusFromChildren && statusUpdatedBy !== "parent" /* parent */ && statusFromChildren === IndeterminateCheckboxStatus.indeterminate && expanded) {
25877
- if (!arrayIncludesId(selectedItems, itemId)) {
25878
- setSelectedItems([].concat(selectedItems, [{
25879
- itemId: itemId,
25880
- checkedStatus: statusFromChildren
25881
- }]));
25882
- updateSelectedItemsChanged();
25883
- } else {
25884
- var itemStatus = getCheckedStatus(itemId, selectedItems);
25885
- if (itemStatus === parentCheckedStatus) {
25886
- // Skip updating items if instructed to do so
25887
- if (isSkipSelectedItemsUpdate) return;
25888
- if (!selectedItemsChanged) {
25889
- if (!topLevel && updateParentCheckStatus) {
25890
- setSelectedItemsChanged(true);
25891
- } else {
25892
- updateSelectedItemsChanged();
25893
- }
25894
- }
25895
- } else {
25896
- updateSelectedItemsChanged();
25897
- }
25898
- }
25899
- } else {
25900
- setSelectedItems(updateItemStatus);
25901
- if (!expanded) {
25902
- updateSelectedItemsChanged();
25903
- }
25616
+ },
25617
+ theme: theme
25618
+ }, expanded ? createElement(ExpandMoreIcon, {
25619
+ "aria-hidden": true
25620
+ }) : createElement(ChevronRightIcon, {
25621
+ "aria-hidden": true
25622
+ })), selectable === TreeViewSelectable.multi ? createElement(StyledCheckboxWrapper, {
25623
+ theme: theme
25624
+ }, hasOwnTreeItems ? createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, {
25625
+ status: checkedStatus
25626
+ })) : createElement(Checkbox, Object.assign({}, checkboxProps, {
25627
+ checked: checkedStatusToBoolean(checkedStatus)
25628
+ }))) : createElement(Fragment, null, labelText)), Children.map(children, function (child, index) {
25629
+ var component = child.type === TreeItem ? createElement(Transition, {
25630
+ isOpen: expanded,
25631
+ collapse: true,
25632
+ unmountOnExit: true
25633
+ }, createElement("ul", {
25634
+ role: "group"
25635
+ }, cloneElement(child, {
25636
+ index: index,
25637
+ key: index,
25638
+ itemDepth: itemDepth,
25639
+ parentDepth: parentDepth
25640
+ }))) : child;
25641
+ // hide the disabled item + the children
25642
+ if (isDisabled) return createElement(Fragment, null);
25643
+ return component;
25644
+ })));
25645
+ });
25646
+
25647
+ var TreeNodeType;
25648
+ (function (TreeNodeType) {
25649
+ TreeNodeType["branch"] = "branch";
25650
+ TreeNodeType["leaf"] = "leaf";
25651
+ })(TreeNodeType || (TreeNodeType = {}));
25652
+ /**
25653
+ * Leaf node - 1st level has 40px of left padding.
25654
+ * Each level after that adds 56px of left padding.
25655
+ * 40, 64, 88, 112, 136, etc.
25656
+ *
25657
+ * Branch node - 1st level has 8px of left padding.
25658
+ * Each level after that adds 24px of left padding.
25659
+ * 8, 32, 56, 80, 104, etc.
25660
+ *
25661
+ * The label element (the div inside the li) gets additional spacing.
25662
+ * In order to highlight the entire line, we need to negate the value for margin.
25663
+ */
25664
+ function calculateOffset(type, depth, labelElem, negative) {
25665
+ if (depth === void 0) {
25666
+ depth = 0;
25667
+ }
25668
+ if (labelElem === void 0) {
25669
+ labelElem = false;
25670
+ }
25671
+ if (negative === void 0) {
25672
+ negative = false;
25673
+ }
25674
+ var padding = 0;
25675
+ if (type === TreeNodeType.leaf) {
25676
+ if (labelElem) {
25677
+ padding = depth * 8 + 40;
25678
+ if (depth !== 0) {
25679
+ padding += depth * 16;
25904
25680
  }
25681
+ } else if (depth === 0) {
25682
+ padding = 40;
25683
+ } else {
25684
+ padding = 56;
25905
25685
  }
25906
- }, [childrenCheckedStatus]);
25907
- var checkboxChangeHandler = function checkboxChangeHandler(event) {
25908
- var status = event.target.checked ? IndeterminateCheckboxStatus.checked : IndeterminateCheckboxStatus.unchecked;
25909
- if (checkedStatus !== status) {
25910
- setCheckedStatus(status);
25911
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
25912
- updateParentCheckStatus(index, status);
25913
- if (hasOwnTreeItems && checkChildren) {
25914
- if (getAllChildrenEnabled(treeItemChildren)) {
25915
- setChildrenCheckedStatus(Array(numberOfTreeItemChildren).fill(status));
25916
- } else {
25917
- var childrenIds = getChildrenItemIds(treeItemChildren);
25918
- var newChildrenCheckedStatus = getChildrenCheckedStatus(childrenIds, status);
25919
- setChildrenCheckedStatus(newChildrenCheckedStatus);
25920
- }
25686
+ } else if (type === TreeNodeType.branch) {
25687
+ if (labelElem) {
25688
+ padding = depth * 8 + 8;
25689
+ if (depth !== 0) {
25690
+ padding += depth * 16;
25921
25691
  }
25692
+ } else if (depth === 0) {
25693
+ padding = 8;
25694
+ } else {
25695
+ padding = 24;
25922
25696
  }
25923
- handleClick(event, itemId);
25924
- };
25925
- var singleSelectChangeHandler = function singleSelectChangeHandler(event, itemId) {
25926
- if (!arrayIncludesId(selectedItems, itemId)) {
25927
- setSelectedItems([{
25928
- itemId: itemId,
25929
- checkedStatus: IndeterminateCheckboxStatus.checked
25930
- }]);
25931
- setSelectedItemsChanged(true);
25697
+ }
25698
+ return "" + (negative ? '-' : '') + padding + "px";
25699
+ }
25700
+ function getTreeItemLabelColor(isInverse, disabled, theme) {
25701
+ if (disabled) {
25702
+ if (isInverse) {
25703
+ return curriedTransparentize(0.6, theme.colors.neutral100);
25932
25704
  }
25933
- };
25934
- var multiSelectChangeHandler = function multiSelectChangeHandler(event) {
25935
- if (!checkParents) {
25936
- setSelectedItemsChanged(true);
25937
- }
25938
- if (hasOwnTreeItems && checkChildren) {
25939
- var childrenIds = getChildrenItemIds(treeItemChildren, IndeterminateCheckboxStatus.checked);
25940
- if (event.target.checked) {
25941
- updateParentCheckStatus(index, IndeterminateCheckboxStatus.checked);
25942
- if (!arrayIncludesId(selectedItems, itemId)) {
25943
- setSelectedItems([].concat(selectedItems, childrenIds, [{
25944
- itemId: itemId,
25945
- checkedStatus: IndeterminateCheckboxStatus.checked
25946
- }]));
25947
- updateSelectedItemsChanged();
25948
- } else {
25949
- var missingChildren = getMissingChildrenIds(selectedItems, childrenIds);
25950
- setSelectedItems([].concat(selectedItems, missingChildren));
25951
- updateSelectedItemsChanged();
25952
- }
25953
- } else if (!event.target.checked) {
25954
- var newSelectedItems = filterSelectedItems(selectedItems, childrenIds, {
25955
- itemId: itemId,
25956
- checkedStatus: checkedStatus
25705
+ return curriedTransparentize(0.6, theme.colors.neutral500);
25706
+ }
25707
+ if (isInverse) {
25708
+ return theme.colors.neutral100;
25709
+ }
25710
+ return theme.colors.neutral700;
25711
+ }
25712
+ function getTreeItemWrapperCursor(disabled, selectable, nodeType) {
25713
+ if (disabled) {
25714
+ return 'not-allowed';
25715
+ }
25716
+ if (nodeType === TreeNodeType.branch && selectable === TreeViewSelectable.off || selectable === TreeViewSelectable.single) {
25717
+ return 'pointer';
25718
+ }
25719
+ return 'default';
25720
+ }
25721
+ // Return an array of objects of all the enabled children ids recursively
25722
+ function getChildrenItemIds(children, status) {
25723
+ if (status === void 0) {
25724
+ status = '';
25725
+ }
25726
+ var itemIds = [];
25727
+ React__default.Children.forEach(children, function (child) {
25728
+ var _child$props;
25729
+ if (!((_child$props = child.props) != null && _child$props.isDisabled)) {
25730
+ var _child$props2, _child$props3;
25731
+ var childStatus = status === IndeterminateCheckboxStatus.checked ? IndeterminateCheckboxStatus.checked : IndeterminateCheckboxStatus.unchecked;
25732
+ if ((_child$props2 = child.props) != null && _child$props2.itemId && childStatus !== IndeterminateCheckboxStatus.unchecked) {
25733
+ itemIds.push({
25734
+ itemId: child.props.itemId,
25735
+ checkedStatus: childStatus
25957
25736
  });
25958
- setSelectedItems(newSelectedItems);
25959
- updateSelectedItemsChanged();
25960
25737
  }
25961
- } else {
25962
- if (event.target.checked) {
25963
- if (!arrayIncludesId(selectedItems, itemId)) {
25964
- setSelectedItems([].concat(selectedItems, [{
25965
- itemId: itemId,
25966
- checkedStatus: IndeterminateCheckboxStatus.checked
25967
- }]));
25968
- updateSelectedItemsChanged();
25969
- }
25970
- } else if (!event.target.checked) {
25971
- setSelectedItems(selectedItems.filter(function (obj) {
25972
- return obj.itemId !== itemId;
25973
- }));
25974
- updateSelectedItemsChanged();
25738
+ if ((_child$props3 = child.props) != null && _child$props3.children) {
25739
+ var nestedItemIds = getChildrenItemIds(child.props.children, childStatus);
25740
+ itemIds = itemIds.concat(nestedItemIds);
25975
25741
  }
25976
25742
  }
25977
- };
25978
- var handleClick = function handleClick(event, itemId) {
25979
- if (selectable !== TreeViewSelectable.off) {
25980
- if (selectable === TreeViewSelectable.single) {
25981
- singleSelectChangeHandler(event, itemId);
25982
- } else if (selectable === TreeViewSelectable.multi) {
25983
- multiSelectChangeHandler(event);
25743
+ });
25744
+ return itemIds;
25745
+ }
25746
+ // Return an array of strings of all enabled children ids recursively
25747
+ function getChildrenItemIdsFlat(children) {
25748
+ var itemIds = [];
25749
+ React__default.Children.forEach(children, function (child) {
25750
+ var _child$props4;
25751
+ if (!((_child$props4 = child.props) != null && _child$props4.isDisabled)) {
25752
+ var _child$props5, _child$props6;
25753
+ if ((_child$props5 = child.props) != null && _child$props5.itemId) {
25754
+ itemIds.push(child.props.itemId);
25984
25755
  }
25985
- onClick && typeof onClick === 'function' && onClick();
25756
+ if ((_child$props6 = child.props) != null && _child$props6.children) {
25757
+ var nestedItemIds = getChildrenItemIdsFlat(child.props.children);
25758
+ itemIds = itemIds.concat(nestedItemIds);
25759
+ }
25760
+ }
25761
+ });
25762
+ return itemIds;
25763
+ }
25764
+ // Return an array of objects where all children are items are nested in the parents
25765
+ function getChildrenItemIdsInTree(children) {
25766
+ var itemIds = [];
25767
+ React__default.Children.forEach(children, function (child) {
25768
+ var _child$props7, _child$props8;
25769
+ if ((_child$props7 = child.props) != null && _child$props7.itemId && !((_child$props8 = child.props) != null && _child$props8.isDisabled)) {
25770
+ var _child$props9, _child$props10;
25771
+ itemIds.push({
25772
+ itemId: (_child$props9 = child.props) == null ? void 0 : _child$props9.itemId,
25773
+ children: getChildrenItemIdsInTree((_child$props10 = child.props) == null ? void 0 : _child$props10.children)
25774
+ });
25775
+ }
25776
+ });
25777
+ return itemIds;
25778
+ }
25779
+ // Return a treeItemRefArray object with no null children
25780
+ function filterNullEntries(obj) {
25781
+ if (Array.isArray(obj.current)) {
25782
+ var filteredArray = obj.current.filter(function (item) {
25783
+ return (item == null ? void 0 : item.current) !== null;
25784
+ });
25785
+ if (filteredArray.length > 0) {
25786
+ return {
25787
+ current: filteredArray
25788
+ };
25986
25789
  }
25987
- };
25988
- function getFocusIndex(filteredArrayCurrent) {
25989
- return itemId && (filteredArrayCurrent == null ? void 0 : filteredArrayCurrent.findIndex(function (_ref) {
25990
- var item = _ref.current;
25991
- if (!item || !ownRef.current) return false;
25992
- return item === ownRef.current;
25993
- }));
25994
25790
  }
25995
- var focusIndex = getFocusIndex(treeItemRefArray == null ? void 0 : treeItemRefArray.current);
25996
- useEffect(function () {
25997
- treeItemRefArray == null || treeItemRefArray.current.map(function (itemRef) {
25998
- if (!itemRef.current) {
25999
- treeItemRefArray.current = treeItemRefArray.current.filter(function (item) {
26000
- return itemRef.current !== item.current;
26001
- });
26002
- }
25791
+ return {};
25792
+ }
25793
+ var getTreeViewData = function getTreeViewData(children, parentId) {
25794
+ if (parentId === void 0) {
25795
+ parentId = null;
25796
+ }
25797
+ var treeItemChildren = React__default.Children.toArray(children).filter(function (child) {
25798
+ return child.type === TreeItem;
25799
+ });
25800
+ return treeItemChildren.map(function (_ref) {
25801
+ var props = _ref.props;
25802
+ return [{
25803
+ itemId: props.itemId,
25804
+ parentId: parentId,
25805
+ icon: props.icon,
25806
+ hasOwnTreeItems: Boolean(props.children)
25807
+ }].concat(props.children ? getTreeViewData(props.children, props.itemId) : []);
25808
+ }).flat();
25809
+ };
25810
+ var getChildrenIds = function getChildrenIds(_ref2) {
25811
+ var items = _ref2.items,
25812
+ itemId = _ref2.itemId;
25813
+ return items.reduce(function (result, item) {
25814
+ if (item.parentId !== itemId) {
25815
+ return result;
25816
+ }
25817
+ if (item.hasOwnTreeItems) {
25818
+ return [].concat(result, getChildrenIds({
25819
+ items: items,
25820
+ itemId: item.itemId
25821
+ }));
25822
+ }
25823
+ return [].concat(result, [item.itemId]);
25824
+ }, [itemId]);
25825
+ };
25826
+ var getChildrenUniqueStatuses = function getChildrenUniqueStatuses(_ref3) {
25827
+ var items = _ref3.items,
25828
+ itemId = _ref3.itemId;
25829
+ var childrenAndItemIds = getChildrenIds({
25830
+ items: items,
25831
+ itemId: itemId
25832
+ });
25833
+ var leaves = items.filter(function (item) {
25834
+ return !item.hasOwnTreeItems && childrenAndItemIds.includes(item.itemId);
25835
+ });
25836
+ var uniqueStatuses = Array.from(new Set(leaves.map(function (item) {
25837
+ var _item$checkedStatus;
25838
+ return (_item$checkedStatus = item.checkedStatus) != null ? _item$checkedStatus : IndeterminateCheckboxStatus.unchecked;
25839
+ })));
25840
+ return uniqueStatuses.filter(function (checkedStatus) {
25841
+ return checkedStatus && checkedStatus !== IndeterminateCheckboxStatus.indeterminate;
25842
+ });
25843
+ };
25844
+ var processInitialParentStatuses = function processInitialParentStatuses(_ref4) {
25845
+ var items = _ref4.items;
25846
+ var itemsWithSelectedChildren = items.reduce(function (result, item) {
25847
+ if (!item.hasOwnTreeItems || item.checkedStatus !== IndeterminateCheckboxStatus.checked) {
25848
+ return result;
25849
+ }
25850
+ return processChildrenSelection({
25851
+ items: result,
25852
+ itemId: item.itemId,
25853
+ checkedStatus: IndeterminateCheckboxStatus.checked
26003
25854
  });
26004
- }, [treeItemRefArray]);
26005
- var focusFirst = function focusFirst() {
26006
- var filteredRefArray = filterNullEntries(treeItemRefArray);
26007
- var curr = filteredRefArray['current'];
26008
- curr == null || curr[0].current.focus();
26009
- };
26010
- var focusNext = function focusNext() {
26011
- var _curr$newIndex;
26012
- var filteredRefArray = filterNullEntries(treeItemRefArray);
26013
- var curr = filteredRefArray['current'];
26014
- var arrLength = curr.length;
26015
- focusIndex = getFocusIndex(curr);
26016
- var newIndex = focusIndex + 1;
26017
- var next = curr == null || (_curr$newIndex = curr[newIndex]) == null ? void 0 : _curr$newIndex.current;
26018
- while (!next && newIndex < arrLength) {
26019
- var _curr$newIndex2;
26020
- newIndex++;
26021
- next = curr == null || (_curr$newIndex2 = curr[newIndex]) == null ? void 0 : _curr$newIndex2.current;
25855
+ }, items);
25856
+ return itemsWithSelectedChildren.map(function (item) {
25857
+ if (!item.hasOwnTreeItems) {
25858
+ return item;
26022
25859
  }
26023
- if (next) {
26024
- next.focus();
26025
- } else {
26026
- var _curr;
26027
- var nextNext = curr == null || (_curr = curr[focusIndex + 2]) == null ? void 0 : _curr.current;
26028
- if (nextNext) {
26029
- nextNext.focus();
26030
- } else {
26031
- focusFirst();
26032
- }
25860
+ var childrenUniqueStatuses = getChildrenUniqueStatuses({
25861
+ items: itemsWithSelectedChildren,
25862
+ itemId: item.itemId
25863
+ });
25864
+ var parentStatus = childrenUniqueStatuses.length > 1 ? IndeterminateCheckboxStatus.indeterminate : childrenUniqueStatuses[0];
25865
+ return parentStatus ? _extends({}, item, {
25866
+ checkedStatus: parentStatus
25867
+ }) : item;
25868
+ });
25869
+ };
25870
+ var getInitialItems = function getInitialItems(_ref5) {
25871
+ var children = _ref5.children,
25872
+ rawPreselectedItems = _ref5.preselectedItems,
25873
+ checkParents = _ref5.checkParents,
25874
+ selectable = _ref5.selectable;
25875
+ var treeViewData = getTreeViewData(children);
25876
+ var preselectedItems = rawPreselectedItems != null && rawPreselectedItems.length && selectable === TreeViewSelectable.single ? [rawPreselectedItems[0]] : rawPreselectedItems;
25877
+ var enhancedWithPreselectedItems = preselectedItems ? treeViewData.map(function (treeViewDataItem) {
25878
+ var preselectedItem = preselectedItems.find(function (_ref6) {
25879
+ var itemId = _ref6.itemId;
25880
+ return treeViewDataItem.itemId === itemId;
25881
+ });
25882
+ return preselectedItem ? _extends({}, treeViewDataItem, {
25883
+ checkedStatus: preselectedItem.checkedStatus
25884
+ }) : treeViewDataItem;
25885
+ }) : treeViewData;
25886
+ return selectable === TreeViewSelectable.multi && checkParents && preselectedItems ? processInitialParentStatuses({
25887
+ items: enhancedWithPreselectedItems
25888
+ }) : enhancedWithPreselectedItems;
25889
+ };
25890
+ var selectSingle = function selectSingle(_ref7) {
25891
+ var items = _ref7.items,
25892
+ itemId = _ref7.itemId,
25893
+ checkedStatus = _ref7.checkedStatus;
25894
+ return items.map(function (item) {
25895
+ return _extends({}, item, {
25896
+ checkedStatus: item.itemId === itemId ? checkedStatus : IndeterminateCheckboxStatus.unchecked
25897
+ });
25898
+ });
25899
+ };
25900
+ var processChildrenSelection = function processChildrenSelection(_ref8) {
25901
+ var items = _ref8.items,
25902
+ itemId = _ref8.itemId,
25903
+ checkedStatus = _ref8.checkedStatus;
25904
+ var childrenAndItemIds = getChildrenIds({
25905
+ items: items,
25906
+ itemId: itemId
25907
+ });
25908
+ return items.map(function (item) {
25909
+ return childrenAndItemIds.includes(item.itemId) ? _extends({}, item, {
25910
+ checkedStatus: checkedStatus
25911
+ }) : item;
25912
+ });
25913
+ };
25914
+ var processParentsSelection = function processParentsSelection(_ref9) {
25915
+ var items = _ref9.items,
25916
+ itemId = _ref9.itemId,
25917
+ checkedStatus = _ref9.checkedStatus;
25918
+ var item = items.find(function (item) {
25919
+ return item.itemId === itemId;
25920
+ });
25921
+ var parentId = item.parentId;
25922
+ if (parentId === null) {
25923
+ return items;
25924
+ }
25925
+ var siblings = items.filter(function (item) {
25926
+ return item.parentId === parentId;
25927
+ });
25928
+ var isAllSiblingsHasTheSameStatus = siblings.every(function (item) {
25929
+ return (item.checkedStatus || IndeterminateCheckboxStatus.unchecked) === checkedStatus;
25930
+ });
25931
+ var parentStatus = isAllSiblingsHasTheSameStatus ? checkedStatus : IndeterminateCheckboxStatus.indeterminate;
25932
+ var parent = items.find(function (item) {
25933
+ return item.itemId === parentId;
25934
+ });
25935
+ var nextItems = items.map(function (item) {
25936
+ return item.itemId === parent.itemId ? _extends({}, item, {
25937
+ checkedStatus: parentStatus
25938
+ }) : item;
25939
+ });
25940
+ return processParentsSelection({
25941
+ items: nextItems,
25942
+ itemId: parent.itemId,
25943
+ checkedStatus: parentStatus
25944
+ });
25945
+ };
25946
+ var selectMulti = function selectMulti(_ref10) {
25947
+ var items = _ref10.items,
25948
+ itemId = _ref10.itemId,
25949
+ checkedStatus = _ref10.checkedStatus,
25950
+ checkChildren = _ref10.checkChildren,
25951
+ checkParents = _ref10.checkParents;
25952
+ var itemsWithProcessedItemSelection = items.map(function (item) {
25953
+ return item.itemId === itemId ? _extends({}, item, {
25954
+ checkedStatus: checkedStatus
25955
+ }) : item;
25956
+ });
25957
+ var itemsWithProcessedChildrenSelection = checkChildren ? processChildrenSelection({
25958
+ items: itemsWithProcessedItemSelection,
25959
+ itemId: itemId,
25960
+ checkedStatus: checkedStatus
25961
+ }) : itemsWithProcessedItemSelection;
25962
+ return checkParents ? processParentsSelection({
25963
+ items: itemsWithProcessedChildrenSelection,
25964
+ itemId: itemId,
25965
+ checkedStatus: checkedStatus
25966
+ }) : itemsWithProcessedChildrenSelection;
25967
+ };
25968
+
25969
+ var _excluded$1C = ["checkedStatus"];
25970
+ function useTreeView(props) {
25971
+ var _props$selectable = props.selectable,
25972
+ selectable = _props$selectable === void 0 ? TreeViewSelectable.single : _props$selectable,
25973
+ onSelectedItemChange = props.onSelectedItemChange,
25974
+ onExpandedChange = props.onExpandedChange,
25975
+ initialExpandedItems = props.initialExpandedItems,
25976
+ preselectedItems = props.preselectedItems,
25977
+ _props$checkChildren = props.checkChildren,
25978
+ checkChildren = _props$checkChildren === void 0 ? selectable !== TreeViewSelectable.single : _props$checkChildren,
25979
+ _props$checkParents = props.checkParents,
25980
+ checkParents = _props$checkParents === void 0 ? selectable !== TreeViewSelectable.single : _props$checkParents,
25981
+ children = props.children,
25982
+ apiRef = props.apiRef;
25983
+ var hasPreselectedItems = Boolean(preselectedItems);
25984
+ var _React$useState = useState(function () {
25985
+ return getInitialItems({
25986
+ children: children,
25987
+ preselectedItems: preselectedItems,
25988
+ checkParents: checkParents,
25989
+ selectable: selectable
25990
+ });
25991
+ }),
25992
+ items = _React$useState[0],
25993
+ setItems = _React$useState[1];
25994
+ var _React$useState2 = useState(function () {
25995
+ var initialItems = getInitialItems({
25996
+ children: children,
25997
+ preselectedItems: preselectedItems,
25998
+ checkParents: checkParents,
25999
+ selectable: selectable
26000
+ });
26001
+ return initialItems.some(function (item) {
26002
+ return item.icon;
26003
+ });
26004
+ }),
26005
+ hasIcons = _React$useState2[0];
26006
+ var selectedItems = useMemo(function () {
26007
+ return items.filter(function (item) {
26008
+ return item.checkedStatus === IndeterminateCheckboxStatus.checked;
26009
+ });
26010
+ }, [items]);
26011
+ var itemToFocus = useMemo(function () {
26012
+ var firstItem = items[0];
26013
+ if (selectable === TreeViewSelectable.off) {
26014
+ var firstExpandableItem = items.find(function (item) {
26015
+ return item.hasOwnTreeItems;
26016
+ });
26017
+ return firstExpandableItem ? firstExpandableItem.itemId : firstItem == null ? void 0 : firstItem.itemId;
26033
26018
  }
26034
- };
26035
- var focusPrev = function focusPrev() {
26036
- var _curr$newIndex3;
26037
- var filteredRefArray = filterNullEntries(treeItemRefArray);
26038
- var curr = filteredRefArray['current'];
26039
- focusIndex = getFocusIndex(curr);
26040
- var newIndex = focusIndex - 1;
26041
- var itemToFocus = curr == null || (_curr$newIndex3 = curr[newIndex]) == null ? void 0 : _curr$newIndex3.current;
26042
- while (!itemToFocus && newIndex >= 0) {
26043
- var _curr$newIndex4;
26044
- newIndex--;
26045
- itemToFocus = curr == null || (_curr$newIndex4 = curr[newIndex]) == null ? void 0 : _curr$newIndex4.current;
26019
+ var firstNonUncheckedItem = items.find(function (item) {
26020
+ return item.checkedStatus && item.checkedStatus !== IndeterminateCheckboxStatus.unchecked;
26021
+ });
26022
+ if (firstNonUncheckedItem) {
26023
+ return firstNonUncheckedItem.itemId;
26046
26024
  }
26047
- if (itemToFocus) {
26048
- itemToFocus.focus();
26025
+ return firstItem == null ? void 0 : firstItem.itemId;
26026
+ }, [items]);
26027
+ var initializationRef = useRef(true);
26028
+ useEffect(function () {
26029
+ if (initializationRef.current && !hasPreselectedItems) {
26030
+ initializationRef.current = false;
26031
+ return;
26049
26032
  }
26050
- };
26051
- var focusLast = function focusLast() {
26052
- var _filteredRefArray$cur;
26053
- var filteredRefArray = filterNullEntries(treeItemRefArray);
26054
- var arrLength = filteredRefArray['current'].length;
26055
- (_filteredRefArray$cur = filteredRefArray['current']) == null || _filteredRefArray$cur[arrLength - 1].current.focus();
26056
- };
26057
- var focusSelf = function focusSelf() {
26058
- var filteredRefArray = filterNullEntries(treeItemRefArray);
26059
- var curr = filteredRefArray['current'];
26060
- focusIndex = getFocusIndex(curr);
26061
- curr == null || curr[focusIndex].current.focus();
26062
- };
26063
- var expandFocusedNode = function expandFocusedNode() {
26064
- if (hasOwnTreeItems) {
26065
- if (expanded) {
26066
- focusNext();
26067
- } else {
26068
- setExpanded(true);
26069
- focusSelf();
26070
- }
26033
+ if (selectable === TreeViewSelectable.off) {
26034
+ return;
26071
26035
  }
26072
- };
26073
- var collapseFocusedNode = function collapseFocusedNode() {
26074
- if (hasOwnTreeItems) {
26075
- if (expanded) {
26076
- setExpanded(false);
26077
- focusSelf();
26078
- } else {
26079
- focusPrev();
26080
- }
26081
- } else {
26082
- focusPrev();
26036
+ onSelectedItemChange && onSelectedItemChange(items.filter(function (_ref) {
26037
+ var checkedStatus = _ref.checkedStatus;
26038
+ return checkedStatus && checkedStatus !== IndeterminateCheckboxStatus.unchecked;
26039
+ }).map(function (_ref2) {
26040
+ var itemId = _ref2.itemId,
26041
+ checkedStatus = _ref2.checkedStatus;
26042
+ return {
26043
+ itemId: itemId,
26044
+ checkedStatus: checkedStatus
26045
+ };
26046
+ }));
26047
+ }, [items, selectable, hasPreselectedItems]);
26048
+ var selectItem = useCallback(function (_ref3) {
26049
+ var itemId = _ref3.itemId,
26050
+ checkedStatus = _ref3.checkedStatus;
26051
+ if (selectable === TreeViewSelectable.off) {
26052
+ return;
26083
26053
  }
26084
- };
26085
- var toggleMultiSelectItems = function toggleMultiSelectItems() {
26086
- var status = arrayIncludesId(selectedItems, itemId) ? IndeterminateCheckboxStatus.unchecked : IndeterminateCheckboxStatus.checked;
26087
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
26088
- setCheckedStatus(status);
26089
- updateParentCheckStatus(index, status);
26090
- if (hasOwnTreeItems && checkChildren) {
26091
- var childrenIds = getChildrenItemIds(treeItemChildren, IndeterminateCheckboxStatus.checked);
26092
- if (!arrayIncludesId(selectedItems, itemId)) {
26093
- setSelectedItems([].concat(selectedItems, childrenIds, [{
26094
- itemId: itemId,
26095
- checkedStatus: status
26096
- }]));
26097
- } else {
26098
- var newSelectedItems = filterSelectedItems(selectedItems, childrenIds, {
26054
+ setItems(function (prevItems) {
26055
+ if (selectable === TreeViewSelectable.single) {
26056
+ return selectSingle({
26057
+ items: prevItems,
26099
26058
  itemId: itemId,
26100
26059
  checkedStatus: checkedStatus
26101
26060
  });
26102
- setSelectedItems(newSelectedItems);
26103
26061
  }
26104
- } else {
26105
- if (!arrayIncludesId(selectedItems, itemId)) {
26106
- setSelectedItems([].concat(selectedItems, [{
26062
+ if (selectable === TreeViewSelectable.multi) {
26063
+ return selectMulti({
26064
+ items: prevItems,
26107
26065
  itemId: itemId,
26108
- checkedStatus: IndeterminateCheckboxStatus.checked
26109
- }]));
26110
- } else {
26111
- setSelectedItems(selectedItems.filter(function (obj) {
26112
- return obj.itemId !== itemId;
26113
- }));
26066
+ checkedStatus: checkedStatus,
26067
+ checkChildren: checkChildren,
26068
+ checkParents: checkParents
26069
+ });
26114
26070
  }
26115
- }
26116
- updateSelectedItemsChanged();
26117
- };
26118
- var handleKeyDown = function handleKeyDown(event) {
26119
- var filteredRefArray = filterNullEntries(treeItemRefArray);
26120
- var curr = filteredRefArray['current'];
26121
- var arrLength = curr.length;
26122
- switch (event.key) {
26123
- case 'ArrowDown':
26124
- {
26125
- // Move to the next item, or wrap to first
26126
- focusIndex === arrLength - 1 ? focusFirst() : focusNext();
26127
- break;
26128
- }
26129
- case 'ArrowUp':
26130
- {
26131
- // Move to the previous item, or wrap to last
26132
- focusIndex === 0 ? focusLast() : focusPrev();
26133
- break;
26134
- }
26135
- case 'ArrowRight':
26136
- {
26137
- // Open parent nodes
26138
- expandFocusedNode();
26139
- break;
26140
- }
26141
- case 'ArrowLeft':
26142
- {
26143
- // Close open parent nodes
26144
- collapseFocusedNode();
26145
- break;
26146
- }
26147
- case 'Home':
26148
- {
26149
- // Moves focus to the first node in the tree without opening or closing a node.
26150
- focusFirst();
26151
- break;
26152
- }
26153
- case 'End':
26154
- {
26155
- // Moves focus to the last node in the tree that is focusable without opening a node.
26156
- focusLast();
26157
- break;
26158
- }
26159
- case 'Enter':
26160
- {
26161
- // Activates a node, i.e., performs its default action.
26162
- if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {
26163
- setExpanded(!expanded);
26164
- } else if (selectable === TreeViewSelectable.single) {
26165
- // In single-select it selects the focused node.
26166
- setSelectedItems([{
26167
- itemId: itemId,
26168
- checkedStatus: IndeterminateCheckboxStatus.checked
26169
- }]);
26170
- setSelectedItemsChanged(true);
26171
- } else if (selectable === TreeViewSelectable.multi) {
26172
- // In multi-select, it toggles the selection state of the focused node.
26173
- toggleMultiSelectItems();
26071
+ return prevItems;
26072
+ });
26073
+ }, [selectable, checkChildren, checkParents]);
26074
+ useEffect(function () {
26075
+ if (apiRef) {
26076
+ apiRef.current = {
26077
+ selectItem: selectItem,
26078
+ selectAll: function selectAll() {
26079
+ if ([TreeViewSelectable.single, TreeViewSelectable.single].includes(selectable)) {
26080
+ return;
26174
26081
  }
26175
- break;
26176
- }
26177
- case ' ':
26178
- {
26179
- // Toggles the selection state of the focused node.
26180
- if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {
26181
- setExpanded(!expanded);
26182
- } else if (selectable === TreeViewSelectable.single) {
26183
- if (hasOwnTreeItems) {
26184
- setExpanded(!expanded);
26185
- } else {
26186
- setSelectedItems([{
26187
- itemId: itemId,
26082
+ setItems(function (prevItems) {
26083
+ return prevItems.map(function (item) {
26084
+ return _extends({}, item, {
26188
26085
  checkedStatus: IndeterminateCheckboxStatus.checked
26189
- }]);
26190
- setSelectedItemsChanged(true);
26191
- }
26192
- } else if (selectable === TreeViewSelectable.multi) {
26193
- toggleMultiSelectItems();
26194
- }
26195
- break;
26086
+ });
26087
+ });
26088
+ });
26089
+ },
26090
+ clearAll: function clearAll() {
26091
+ setItems(function (prevItems) {
26092
+ return prevItems.map(function (_ref4) {
26093
+ var itemWithoutCheckedStatus = _objectWithoutPropertiesLoose(_ref4, _excluded$1C);
26094
+ return itemWithoutCheckedStatus;
26095
+ });
26096
+ });
26196
26097
  }
26197
- default:
26198
- return;
26098
+ };
26199
26099
  }
26200
- };
26100
+ }, [selectItem]);
26101
+ var _React$useState3 = useState(false),
26102
+ initialExpandedItemsNeedUpdate = _React$useState3[0],
26103
+ setInitialExpandedItemsNeedUpdate = _React$useState3[1];
26104
+ var _useDescendants = useDescendants(),
26105
+ treeItemRefArray = _useDescendants[0],
26106
+ registerTreeItem = _useDescendants[1];
26107
+ useEffect(function () {
26108
+ if (initialExpandedItems) {
26109
+ setInitialExpandedItemsNeedUpdate(true);
26110
+ }
26111
+ }, []);
26201
26112
  var contextValue = {
26202
- checkboxChangeHandler: checkboxChangeHandler,
26203
- checkedStatus: checkedStatus,
26204
- expanded: expanded,
26205
- hasOwnTreeItems: hasOwnTreeItems,
26206
- itemDepth: parentDepth === 0 && topLevel ? 0 : itemDepth + 1,
26207
- itemId: itemId || generatedId,
26208
- numberOfTreeItemChildren: numberOfTreeItemChildren,
26209
- parentCheckedStatus: parentCheckedStatus,
26210
- parentDepth: parentDepth,
26211
- ref: ref,
26113
+ hasIcons: hasIcons,
26114
+ itemToFocus: itemToFocus,
26115
+ onSelectedItemChange: onSelectedItemChange,
26116
+ onExpandedChange: onExpandedChange,
26117
+ selectable: selectable,
26212
26118
  selectedItems: selectedItems,
26213
- setExpanded: setExpanded,
26214
- updateCheckedStatusFromChild: updateCheckedStatusFromChild,
26215
- treeItemChildren: treeItemChildren
26119
+ initialExpandedItems: initialExpandedItems,
26120
+ treeItemRefArray: treeItemRefArray,
26121
+ registerTreeItem: registerTreeItem,
26122
+ initialExpandedItemsNeedUpdate: initialExpandedItemsNeedUpdate,
26123
+ setInitialExpandedItemsNeedUpdate: setInitialExpandedItemsNeedUpdate,
26124
+ checkChildren: checkChildren,
26125
+ checkParents: checkParents,
26126
+ items: items,
26127
+ selectItem: selectItem
26216
26128
  };
26217
26129
  return {
26218
- contextValue: contextValue,
26219
- handleClick: handleClick,
26220
- handleKeyDown: handleKeyDown
26130
+ contextValue: contextValue
26221
26131
  };
26222
26132
  }
26223
26133
 
26224
- var TreeItemContext = /*#__PURE__*/createContext({
26225
- expanded: false,
26226
- setExpanded: function setExpanded() {},
26227
- checkedStatus: IndeterminateCheckboxStatus.unchecked,
26228
- checkboxChangeHandler: function checkboxChangeHandler() {},
26229
- hasOwnTreeItems: false,
26230
- updateCheckedStatusFromChild: function updateCheckedStatusFromChild() {},
26231
- numberOfTreeItemChildren: 0,
26232
- parentDepth: 0
26233
- });
26234
-
26235
- var _excluded$1B = ["children", "icon", "index", "isDisabled", "label", "labelStyle", "parentCheckedStatus", "style", "testId", "updateParentCheckStatus", "topLevel"];
26236
- var StyledTreeItem = /*#__PURE__*/_styled("li", {
26237
- target: "e1xiryew5",
26238
- label: "StyledTreeItem"
26239
- })("color:", function (props) {
26240
- return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
26241
- }, ";list-style-type:none;cursor:", function (props) {
26242
- return getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType);
26243
- }, ";position:relative;margin-bottom:0;padding-inline-start:", function (props) {
26244
- return calculateOffset(props.nodeType, props.depth);
26245
- }, ";>div:first-of-type{background:", function (props) {
26246
- return props.selected && props.isInverse ? curriedTransparentize(0.7, props.theme.colors.neutral900) : props.selected && curriedTransparentize(0.92, props.theme.colors.neutral900);
26247
- }, ";position:relative;padding-inline-start:", function (props) {
26248
- return calculateOffset(props.nodeType, props.depth, true);
26249
- }, ";margin-inline-start:", function (props) {
26250
- return calculateOffset(props.nodeType, props.depth, true, true);
26251
- }, ";padding-block-end:", function (props) {
26252
- return props.theme.spaceScale.spacing02;
26253
- }, ";padding-block-start:", function (props) {
26254
- return props.theme.spaceScale.spacing02;
26255
- }, ";padding-right:", function (props) {
26256
- return props.theme.spaceScale.spacing02;
26257
- }, ";", function (props) {
26258
- return props.selected && /*#__PURE__*/css("&:before{position:absolute;background-color:", props.isInverse ? props.theme.colors.tertiary500 : props.theme.colors.primary500, ";block-size:100%;content:'';inline-size:", props.theme.spaceScale.spacing02, ";inset-block-start:0;inset-inline-start:0;};label:StyledTreeItem;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAwCQ","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
26259
- }, " &:hover{background:", function (props) {
26260
- return !props.isDisabled ? props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral900) : curriedTransparentize(0.95, props.theme.colors.neutral900) : undefined;
26261
- }, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAeiC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
26262
- var IconWrapper$8 = /*#__PURE__*/_styled("span", {
26263
- target: "e1xiryew4",
26264
- label: "IconWrapper"
26265
- })("color:", function (props) {
26266
- return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
26267
- }, ";margin-right:", function (props) {
26268
- return props.theme.spaceScale.spacing03;
26269
- }, ";margin-left:0px;svg{height:", function (props) {
26270
- return props.theme.iconSizes.medium;
26271
- }, "px;width:", function (props) {
26272
- return props.theme.iconSizes.medium;
26273
- }, "px;vertical-align:middle;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA8DgC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
26274
- var StyledLabelWrapper = /*#__PURE__*/_styled("span", {
26275
- target: "e1xiryew3",
26276
- label: "StyledLabelWrapper"
26277
- })("display:flex;align-items:flex-start;color:", function (props) {
26278
- return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
26279
- }, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAwEuC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
26280
- var StyledExpandWrapper = /*#__PURE__*/_styled("div", {
26281
- target: "e1xiryew2",
26282
- label: "StyledExpandWrapper"
26283
- })("display:inline-block;vertical-align:middle;margin-right:", function (props) {
26284
- return props.theme.spaceScale.spacing03;
26285
- }, ";color:", function (props) {
26286
- return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
26287
- }, ";border-radius:0;width:", function (props) {
26288
- return props.theme.spaceScale.spacing06;
26289
- }, ";height:", function (props) {
26290
- return props.theme.spaceScale.spacing06;
26291
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA8EuC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
26292
- var StyledCheckboxWrapper = /*#__PURE__*/_styled("div", {
26293
- target: "e1xiryew1",
26294
- label: "StyledCheckboxWrapper"
26295
- })("margin-right:", function (props) {
26296
- return props.theme.spaceScale.spacing03;
26297
- }, ";vertical-align:middle;display:inline-flex;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAuFyC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
26298
- var StyledItemWrapper = /*#__PURE__*/_styled("div", {
26299
- target: "e1xiryew0",
26300
- label: "StyledItemWrapper"
26301
- })("display:flex;align-items:flex-start;cursor:", function (props) {
26302
- return getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType);
26303
- }, ";&:focus{outline-offset:-2px;outline:2px solid ", function (props) {
26304
- return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
26305
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA4FqC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
26306
- var TreeItem = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
26307
- var _selectedItems$;
26308
- var children = props.children,
26309
- icon = props.icon,
26310
- isDisabled = props.isDisabled,
26311
- label = props.label,
26312
- labelStyle = props.labelStyle,
26313
- style = props.style,
26314
- testId = props.testId,
26315
- rest = _objectWithoutPropertiesLoose(props, _excluded$1B);
26316
- var theme = useContext(ThemeContext);
26317
- var isInverse = useIsInverse();
26318
- var _React$useContext = useContext(TreeViewContext),
26319
- selectable = _React$useContext.selectable,
26320
- hasIcons = _React$useContext.hasIcons,
26321
- onExpandedChange = _React$useContext.onExpandedChange,
26322
- itemToFocus = _React$useContext.itemToFocus;
26323
- var _useTreeItem = useTreeItem(props, forwardedRef),
26324
- contextValue = _useTreeItem.contextValue,
26325
- handleClick = _useTreeItem.handleClick,
26326
- handleKeyDown = _useTreeItem.handleKeyDown;
26327
- var checkboxChangeHandler = contextValue.checkboxChangeHandler,
26328
- checkedStatus = contextValue.checkedStatus,
26329
- expanded = contextValue.expanded,
26330
- hasOwnTreeItems = contextValue.hasOwnTreeItems,
26331
- itemDepth = contextValue.itemDepth,
26332
- itemId = contextValue.itemId,
26333
- parentDepth = contextValue.parentDepth,
26334
- ref = contextValue.ref,
26335
- selectedItems = contextValue.selectedItems,
26336
- setExpanded = contextValue.setExpanded,
26337
- updateCheckedStatusFromChild = contextValue.updateCheckedStatusFromChild;
26338
- var nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;
26339
- var selectedItem = selectable === TreeViewSelectable.single ? (selectedItems == null || (_selectedItems$ = selectedItems[0]) == null ? void 0 : _selectedItems$.itemId) === itemId : null;
26340
- var ariaCheckedValue = selectable === TreeViewSelectable.multi ? checkedStatus === IndeterminateCheckboxStatus.indeterminate ? 'mixed' : checkedStatus === IndeterminateCheckboxStatus.checked : null;
26341
- var defaultIcon = nodeType === TreeNodeType.branch ? createElement(FolderIcon, {
26342
- "aria-hidden": true
26343
- }) : createElement(ArticleIcon, {
26344
- "aria-hidden": true
26345
- });
26346
- var labelText = createElement(StyledLabelWrapper, {
26347
- theme: theme,
26348
- isDisabled: isDisabled,
26349
- isInverse: isInverse,
26350
- style: labelStyle,
26351
- id: itemId + "-label",
26352
- "data-testid": (testId || itemId) + "-label",
26353
- onClick: function onClick(e) {
26354
- if (selectable === TreeViewSelectable.single && !isDisabled) {
26355
- handleClick(e, itemId);
26356
- }
26357
- }
26358
- }, hasIcons && createElement(IconWrapper$8, {
26359
- isInverse: isInverse,
26360
- theme: theme,
26361
- isDisabled: isDisabled,
26362
- "data-testid": (testId || itemId) + "-icon"
26363
- }, icon || defaultIcon), label);
26364
- // Props shared by Checkbox and IndeterminateCheckbox
26365
- var checkboxProps = {
26366
- disabled: isDisabled,
26367
- hideFocus: true,
26368
- id: itemId + "-checkbox",
26369
- inputStyle: {
26370
- marginRight: theme.spaceScale.spacing03
26371
- },
26372
- labelStyle: {
26373
- padding: 0
26374
- },
26375
- labelText: labelText,
26376
- onChange: checkboxChangeHandler,
26377
- tabIndex: -1,
26378
- testId: itemId + "-checkbox"
26379
- };
26380
- var onExpandedClicked = function onExpandedClicked(event) {
26381
- setExpanded(function (state) {
26382
- return !state;
26383
- });
26384
- event.preventDefault();
26385
- onExpandedChange && typeof onExpandedChange === 'function' && onExpandedChange(event);
26386
- };
26387
- return createElement(TreeItemContext.Provider, {
26388
- value: contextValue
26389
- }, createElement(StyledTreeItem, Object.assign({}, rest, {
26390
- "aria-expanded": hasOwnTreeItems ? expanded : null,
26391
- "aria-selected": selectedItem,
26392
- "aria-checked": ariaCheckedValue,
26393
- "data-testid": testId,
26394
- depth: itemDepth,
26395
- hasOwnTreeItems: true,
26396
- id: itemId,
26397
- isDisabled: isDisabled,
26398
- isInverse: isInverse,
26399
- nodeType: nodeType,
26400
- role: "treeitem",
26401
- selectableType: selectable,
26402
- selected: selectedItem,
26403
- theme: theme
26404
- }), createElement(StyledItemWrapper, {
26405
- "data-testid": (testId || itemId) + "-itemwrapper",
26406
- depth: itemDepth,
26407
- id: itemId + "-itemwrapper",
26408
- isDisabled: isDisabled,
26409
- isInverse: isInverse,
26410
- nodeType: nodeType,
26411
- onClick: function onClick(event) {
26412
- if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {
26413
- onExpandedClicked(event);
26414
- }
26415
- },
26416
- onKeyDown: function onKeyDown(e) {
26417
- handleKeyDown(e);
26418
- },
26419
- ref: ref,
26420
- selectable: selectable,
26421
- style: style,
26422
- tabIndex: itemToFocus === itemId ? 0 : -1,
26423
- theme: theme
26424
- }, hasOwnTreeItems && createElement(StyledExpandWrapper, {
26425
- "aria-hidden": Boolean(!expanded),
26426
- "data-testid": (testId || itemId) + "-expand",
26427
- isDisabled: isDisabled,
26428
- isInverse: isInverse,
26429
- onClick: function onClick(event) {
26430
- if (!isDisabled && selectable !== TreeViewSelectable.off) {
26431
- onExpandedClicked(event);
26432
- }
26433
- },
26434
- theme: theme
26435
- }, expanded ? createElement(ExpandMoreIcon, {
26436
- "aria-hidden": true
26437
- }) : createElement(ChevronRightIcon, {
26438
- "aria-hidden": true
26439
- })), selectable === TreeViewSelectable.multi ? createElement(StyledCheckboxWrapper, {
26440
- theme: theme
26441
- }, hasOwnTreeItems ? createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, {
26442
- status: checkedStatus
26443
- })) : createElement(Checkbox, Object.assign({}, checkboxProps, {
26444
- checked: checkedStatusToBoolean(checkedStatus)
26445
- }))) : createElement(Fragment, null, labelText)), Children.map(children, function (child, index) {
26446
- var component = child.type === TreeItem ? createElement(Transition, {
26447
- isOpen: expanded,
26448
- collapse: true,
26449
- unmountOnExit: true
26450
- }, createElement("ul", {
26451
- role: "group"
26452
- }, cloneElement(child, {
26453
- index: index,
26454
- key: index,
26455
- itemDepth: itemDepth,
26456
- parentDepth: parentDepth,
26457
- parentCheckedStatus: checkedStatus,
26458
- updateParentCheckStatus: updateCheckedStatusFromChild
26459
- }))) : child;
26460
- // hide the disabled item + the children
26461
- if (isDisabled) return createElement(Fragment, null);
26462
- return component;
26463
- })));
26464
- });
26465
-
26466
- var _excluded$1C = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId"];
26134
+ var _excluded$1D = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId", "apiRef"];
26467
26135
  var StyledTreeView = /*#__PURE__*/_styled("ul", {
26468
26136
  target: "e1tyeayj0",
26469
26137
  label: "StyledTreeView"
26470
26138
  })("padding:0;margin:0;color:", function (props) {
26471
26139
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral;
26472
- }, ";ul{padding:0;margin:0;li{margin:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyZWVWaWV3LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRaUMiLCJmaWxlIjoiVHJlZVZpZXcudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VUcmVlVmlldywgVHJlZVZpZXdTZWxlY3RhYmxlLCB9IGZyb20gJy4vdXNlVHJlZVZpZXcnO1xyXG5pbXBvcnQgeyBUcmVlSXRlbSB9IGZyb20gJy4vVHJlZUl0ZW0nO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJbnZlcnNlQ29udGV4dCwgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IHVzZVRyZWVJdGVtIH0gZnJvbSAnLi91c2VUcmVlSXRlbSc7XHJcbmltcG9ydCB7IFRyZWVWaWV3Q29udGV4dCB9IGZyb20gJy4vVHJlZVZpZXdDb250ZXh0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5jb25zdCBTdHlsZWRUcmVlVmlldyA9IHN0eWxlZC51bCBgXG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsfTtcbiAgdWwge1xuICAgIHBhZGRpbmc6IDA7XG4gICAgbWFyZ2luOiAwO1xuICAgIGxpIHtcbiAgICAgIG1hcmdpbjogMDtcbiAgICB9XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBUcmVlVmlldyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYXJpYUxhYmVsLCBhcmlhTGFiZWxsZWRCeSwgY2hpbGRyZW4sIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgb25FeHBhbmRlZENoYW5nZSwgb25TZWxlY3RlZEl0ZW1DaGFuZ2UsIHNlbGVjdGFibGUsIHRlc3RJZCwgLi4ucmVzdCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIGNvbnN0IHsgY29udGV4dFZhbHVlIH0gPSB1c2VUcmVlVmlldyhwcm9wcyk7XHJcbiAgICBjb25zdCB7IGNvbnRleHRWYWx1ZTogdHJlZUl0ZW1Db250ZXh0VmFsdWUgfSA9IHVzZVRyZWVJdGVtKHsgbGFiZWw6IGFyaWFMYWJlbCwgaXRlbUlkOiAnJyB9LCByZWYpO1xyXG4gICAgbGV0IHRyZWVJdGVtSW5kZXggPSAwO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEludmVyc2VDb250ZXh0LlByb3ZpZGVyLCB7IHZhbHVlOiB7IGlzSW52ZXJzZSB9IH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUcmVlVmlld0NvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IGNvbnRleHRWYWx1ZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRyZWVWaWV3LCBPYmplY3QuYXNzaWduKHt9LCByZXN0LCB7IFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwsIFwiYXJpYS1sYWJlbGxlZGJ5XCI6IGFyaWFMYWJlbGxlZEJ5LCBcImFyaWEtbXVsdGlzZWxlY3RhYmxlXCI6IHNlbGVjdGFibGUgPT09IFRyZWVWaWV3U2VsZWN0YWJsZS5tdWx0aSwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCByZWY6IHJlZiwgcm9sZTogXCJ0cmVlXCIsIHRoZW1lOiB0aGVtZSB9KSwgUmVhY3QuQ2hpbGRyZW4ubWFwKGNoaWxkcmVuLCAoY2hpbGQpID0+IHtcclxuICAgICAgICAgICAgICAgIGlmIChjaGlsZC50eXBlID09PSBUcmVlSXRlbSkge1xyXG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IGl0ZW0gPSBSZWFjdC5jbG9uZUVsZW1lbnQoY2hpbGQsIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgaW5kZXg6IHRyZWVJdGVtSW5kZXgsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGtleTogdHJlZUl0ZW1JbmRleCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgcGFyZW50RGVwdGg6IDAsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGl0ZW1EZXB0aDogMCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgdG9wTGV2ZWw6IHRydWUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHBhcmVudENoZWNrZWRTdGF0dXM6IHRyZWVJdGVtQ29udGV4dFZhbHVlLmNoZWNrZWRTdGF0dXMgfHwgbnVsbCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgdXBkYXRlUGFyZW50Q2hlY2tTdGF0dXM6IHRyZWVJdGVtQ29udGV4dFZhbHVlLnVwZGF0ZUNoZWNrZWRTdGF0dXNGcm9tQ2hpbGQsXHJcbiAgICAgICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgICAgICAgICAgICAgdHJlZUl0ZW1JbmRleCsrO1xyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBpdGVtO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9KSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UcmVlVmlldy5qcy5tYXAiXX0= */"));
26140
+ }, ";ul{padding:0;margin:0;li{margin:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyZWVWaWV3LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTaUMiLCJmaWxlIjoiVHJlZVZpZXcudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VUcmVlVmlldywgfSBmcm9tICcuL3VzZVRyZWVWaWV3JztcclxuaW1wb3J0IHsgVHJlZVZpZXdTZWxlY3RhYmxlIH0gZnJvbSAnLi90eXBlcyc7XHJcbmltcG9ydCB7IFRyZWVJdGVtIH0gZnJvbSAnLi9UcmVlSXRlbSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEludmVyc2VDb250ZXh0LCB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgdXNlVHJlZUl0ZW0gfSBmcm9tICcuL3VzZVRyZWVJdGVtJztcclxuaW1wb3J0IHsgVHJlZVZpZXdDb250ZXh0IH0gZnJvbSAnLi9UcmVlVmlld0NvbnRleHQnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IFN0eWxlZFRyZWVWaWV3ID0gc3R5bGVkLnVsIGBcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICB1bCB7XG4gICAgcGFkZGluZzogMDtcbiAgICBtYXJnaW46IDA7XG4gICAgbGkge1xuICAgICAgbWFyZ2luOiAwO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IFRyZWVWaWV3ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBhcmlhTGFiZWwsIGFyaWFMYWJlbGxlZEJ5LCBjaGlsZHJlbiwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCBvbkV4cGFuZGVkQ2hhbmdlLCBvblNlbGVjdGVkSXRlbUNoYW5nZSwgc2VsZWN0YWJsZSwgdGVzdElkLCBhcGlSZWYsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCB7IGNvbnRleHRWYWx1ZSB9ID0gdXNlVHJlZVZpZXcocHJvcHMpO1xyXG4gICAgdXNlVHJlZUl0ZW0oeyBsYWJlbDogYXJpYUxhYmVsLCBpdGVtSWQ6ICcnIH0sIHJlZik7XHJcbiAgICBsZXQgdHJlZUl0ZW1JbmRleCA9IDA7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW52ZXJzZUNvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IHsgaXNJbnZlcnNlIH0gfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFRyZWVWaWV3Q29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZTogY29udGV4dFZhbHVlIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVHJlZVZpZXcsIE9iamVjdC5hc3NpZ24oe30sIHJlc3QsIHsgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCwgXCJhcmlhLWxhYmVsbGVkYnlcIjogYXJpYUxhYmVsbGVkQnksIFwiYXJpYS1tdWx0aXNlbGVjdGFibGVcIjogc2VsZWN0YWJsZSA9PT0gVHJlZVZpZXdTZWxlY3RhYmxlLm11bHRpLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCByb2xlOiBcInRyZWVcIiwgdGhlbWU6IHRoZW1lIH0pLCBSZWFjdC5DaGlsZHJlbi5tYXAoY2hpbGRyZW4sIChjaGlsZCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgaWYgKGNoaWxkLnR5cGUgPT09IFRyZWVJdGVtKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgaXRlbSA9IFJlYWN0LmNsb25lRWxlbWVudChjaGlsZCwge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBpbmRleDogdHJlZUl0ZW1JbmRleCxcclxuICAgICAgICAgICAgICAgICAgICAgICAga2V5OiB0cmVlSXRlbUluZGV4LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBwYXJlbnREZXB0aDogMCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgaXRlbURlcHRoOiAwLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICB0b3BMZXZlbDogdHJ1ZSxcclxuICAgICAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgICAgICB0cmVlSXRlbUluZGV4Kys7XHJcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGl0ZW07XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH0pKSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRyZWVWaWV3LmpzLm1hcCJdfQ== */"));
26473
26141
  var TreeView = /*#__PURE__*/forwardRef(function (props, ref) {
26474
26142
  var ariaLabel = props.ariaLabel,
26475
26143
  ariaLabelledBy = props.ariaLabelledBy,
@@ -26477,16 +26145,15 @@ var TreeView = /*#__PURE__*/forwardRef(function (props, ref) {
26477
26145
  isInverseProp = props.isInverse,
26478
26146
  selectable = props.selectable,
26479
26147
  testId = props.testId,
26480
- rest = _objectWithoutPropertiesLoose(props, _excluded$1C);
26148
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1D);
26481
26149
  var theme = useContext(ThemeContext);
26482
26150
  var isInverse = useIsInverse(isInverseProp);
26483
26151
  var _useTreeView = useTreeView(props),
26484
26152
  contextValue = _useTreeView.contextValue;
26485
- var _useTreeItem = useTreeItem({
26486
- label: ariaLabel,
26487
- itemId: ''
26488
- }, ref),
26489
- treeItemContextValue = _useTreeItem.contextValue;
26153
+ useTreeItem({
26154
+ label: ariaLabel,
26155
+ itemId: ''
26156
+ }, ref);
26490
26157
  var treeItemIndex = 0;
26491
26158
  return createElement(InverseContext.Provider, {
26492
26159
  value: {
@@ -26510,9 +26177,7 @@ var TreeView = /*#__PURE__*/forwardRef(function (props, ref) {
26510
26177
  key: treeItemIndex,
26511
26178
  parentDepth: 0,
26512
26179
  itemDepth: 0,
26513
- topLevel: true,
26514
- parentCheckedStatus: treeItemContextValue.checkedStatus || null,
26515
- updateParentCheckStatus: treeItemContextValue.updateCheckedStatusFromChild
26180
+ topLevel: true
26516
26181
  });
26517
26182
  treeItemIndex++;
26518
26183
  return item;
@@ -26520,7 +26185,7 @@ var TreeView = /*#__PURE__*/forwardRef(function (props, ref) {
26520
26185
  }))));
26521
26186
  });
26522
26187
 
26523
- var _excluded$1D = ["children", "enforced", "exclusive", "id", "isInverse", "noSpace", "onChange", "size", "value", "testId"];
26188
+ var _excluded$1E = ["children", "enforced", "exclusive", "id", "isInverse", "noSpace", "onChange", "size", "value", "testId"];
26524
26189
  var ToggleButtonGroupContext = /*#__PURE__*/createContext({});
26525
26190
  var ToggleButtonGroup = /*#__PURE__*/forwardRef(function (props, ref) {
26526
26191
  var children = props.children,
@@ -26532,7 +26197,7 @@ var ToggleButtonGroup = /*#__PURE__*/forwardRef(function (props, ref) {
26532
26197
  size = props.size,
26533
26198
  value = props.value,
26534
26199
  testId = props.testId,
26535
- rest = _objectWithoutPropertiesLoose(props, _excluded$1D);
26200
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1E);
26536
26201
  var theme = useContext(ThemeContext);
26537
26202
  var defaultSelectedValues = value ? [value] : [];
26538
26203
  // Array of currently selected items
@@ -26739,5 +26404,5 @@ var ToggleButton = /*#__PURE__*/forwardRef(function (props, ref) {
26739
26404
  }, children));
26740
26405
  });
26741
26406
 
26742
- export { Accordion, AccordionButton, AccordionContext, AccordionIconPosition, AccordionItem, AccordionItemContext, AccordionPanel, Alert, AlertVariant, Announce, AppBar, AppBarPosition, Badge, BadgeColor, BadgeVariant, Banner, BlockQuote, BlockQuoteItem, Breadcrumb, BreadcrumbItem, Breakpoint, BreakpointScreenSize, BreakpointsContainer, Button, ButtonColor, ButtonGroup, ButtonGroupAlignment, ButtonGroupContext, ButtonGroupOrientation, ButtonIconPosition, ButtonShape, ButtonSize, ButtonTextTransform, ButtonType, ButtonVariant, Card, CardAlignment, CardBody, CardCalloutType, CardHeading, CharacterCounter, Checkbox, CheckboxTextPosition, Combobox, ComboboxStateChangeTypes, Container$1 as Container, Datagrid, DatePicker, Drawer, DrawerPosition, Dropdown, DropdownAlignment, DropdownButton, DropdownContent, DropdownDivider, DropdownDropDirection, DropdownExpandableMenuButton, DropdownExpandableMenuGroup, DropdownExpandableMenuItem, DropdownExpandableMenuListItem, DropdownExpandableMenuPanel, DropdownHeader, DropdownMenuGroup, DropdownMenuItem, DropdownMenuNavItem, DropdownSplitButton, EnumTooltipPosition, Flex, FlexAlignContent, FlexAlignItems, FlexBehavior, FlexDirection, FlexJustify, FlexWrap, Form, FormFieldContainer, FormGroup, GlobalStyles, Grid, GridAlignContent, GridAlignItems, GridAutoFlow, GridDisplay, GridItem, GridItemAlignSelf, GridItemJustifySelf, GridJustifyContent, GridJustifyItems, Heading, HideAtBreakpoint, HideAtBreakpointDisplayType, Hyperlink, HyperlinkIconPosition, I18nContext, IconAlignment, IconButton, IconSizes, IndeterminateCheckbox, IndeterminateCheckboxStatus, Input, InputBase, InputIconPosition, InputMessage, InputSize, InputType, InverseContext, Label, LabelPosition, List$1 as List, ListItem, LoadingIndicator, Modal, ModalSize, MultipleSelectionStateChangeTypes, NativeSelect, NavTab, NavTabs, PageButtonSize, Pagination, PaginationType, Paragraph, PasswordInput, ProgressBar, ProgressBarColor, ProgressRing, Radio, RadioGroup, RadioTextPosition, Search, Select$1 as Select, SelectStateChangeTypes, SkipLink, SkipLinkContent, Spacer, SpacerAxis, Spinner, Step, Stepper, StepperLayout, StyledTooltip, Tab, TabPanel, TabPanelsContainer, TabScrollSpyPanel, Table, TableBody, TableCell, TableCellAlign, TableContext, TableDensity, TableHead, TableHeaderCell, TableHeaderCellScope, TablePagination, TableRow, TableRowColor, TableSortDirection, Tabs, TabsAlignment, TabsBorderPosition, TabsContainer, TabsIconPosition, TabsOrientation$1 as TabsOrientation, TabsScrollSpyContainer, Tag, TagColor, TagSize, Textarea, ThemeContext, TimePicker, Toast, ToastsContainer, Toggle, ToggleButton, ToggleButtonGroup, ToggleButtonGroupContext, ToggleButtonStyles, ToggleTextPosition, Tooltip, TooltipArrow, TooltipPosition, Transition, TreeItem, TreeNodeType, TreeView, TreeViewSelectable, TypographyColor, TypographyContextVariant, TypographyVisualStyle, VisuallyHidden, areArraysEqual, arrayIncludesId, blockQuoteStyles, calculateOffset, checkedStatusToBoolean, defaultI18n, filterNullEntries, filterSelectedItems, findChildByItemId, findCommonItems, findFirstBranchNode, getAllChildrenEnabled, getAllParentIds, getCheckedStatus, getChildrenCheckedStatus, getChildrenItemIds, getChildrenItemIdsFlat, getChildrenItemIdsInTree, getDateFromString, getEnabledTreeItemChildrenLength, getFirstItemInTree, getIconSizes, getListAlignment, getMissingChildrenIds, getTreeItemLabelColor, getTreeItemWrapperCursor, getUniqueSelectedItemsArray, getUpdatedSelectedItems, inDateRange, magma, olListType, setBackgroundColor, setIconWidth, ulListType, useAccordion, useAccordionButton, useAccordionItem, useDataPagination, useDescendants, useFocusLock, useForceUpdate, useGenerateId, useIsInverse, useMediaQuery, usePagination, useTreeItem, useTreeView };
26407
+ export { Accordion, AccordionButton, AccordionContext, AccordionIconPosition, AccordionItem, AccordionItemContext, AccordionPanel, Alert, AlertVariant, Announce, AppBar, AppBarPosition, Badge, BadgeColor, BadgeVariant, Banner, BlockQuote, BlockQuoteItem, Breadcrumb, BreadcrumbItem, Breakpoint, BreakpointScreenSize, BreakpointsContainer, Button, ButtonColor, ButtonGroup, ButtonGroupAlignment, ButtonGroupContext, ButtonGroupOrientation, ButtonIconPosition, ButtonShape, ButtonSize, ButtonTextTransform, ButtonType, ButtonVariant, Card, CardAlignment, CardBody, CardCalloutType, CardHeading, CharacterCounter, Checkbox, CheckboxTextPosition, Combobox, ComboboxStateChangeTypes, Container$1 as Container, Datagrid, DatePicker, Drawer, DrawerPosition, Dropdown, DropdownAlignment, DropdownButton, DropdownContent, DropdownDivider, DropdownDropDirection, DropdownExpandableMenuButton, DropdownExpandableMenuGroup, DropdownExpandableMenuItem, DropdownExpandableMenuListItem, DropdownExpandableMenuPanel, DropdownHeader, DropdownMenuGroup, DropdownMenuItem, DropdownMenuNavItem, DropdownSplitButton, EnumTooltipPosition, Flex, FlexAlignContent, FlexAlignItems, FlexBehavior, FlexDirection, FlexJustify, FlexWrap, Form, FormFieldContainer, FormGroup, GlobalStyles, Grid, GridAlignContent, GridAlignItems, GridAutoFlow, GridDisplay, GridItem, GridItemAlignSelf, GridItemJustifySelf, GridJustifyContent, GridJustifyItems, Heading, HideAtBreakpoint, HideAtBreakpointDisplayType, Hyperlink, HyperlinkIconPosition, I18nContext, IconAlignment, IconButton, IconSizes, IndeterminateCheckbox, IndeterminateCheckboxStatus, Input, InputBase, InputIconPosition, InputMessage, InputSize, InputType, InverseContext, Label, LabelPosition, List$1 as List, ListItem, LoadingIndicator, Modal, ModalSize, MultipleSelectionStateChangeTypes, NativeSelect, NavTab, NavTabs, PageButtonSize, Pagination, PaginationType, Paragraph, PasswordInput, ProgressBar, ProgressBarColor, ProgressRing, Radio, RadioGroup, RadioTextPosition, Search, Select$1 as Select, SelectStateChangeTypes, SkipLink, SkipLinkContent, Spacer, SpacerAxis, Spinner, Step, Stepper, StepperLayout, StyledTooltip, Tab, TabPanel, TabPanelsContainer, TabScrollSpyPanel, Table, TableBody, TableCell, TableCellAlign, TableContext, TableDensity, TableHead, TableHeaderCell, TableHeaderCellScope, TablePagination, TableRow, TableRowColor, TableSortDirection, Tabs, TabsAlignment, TabsBorderPosition, TabsContainer, TabsIconPosition, TabsOrientation$1 as TabsOrientation, TabsScrollSpyContainer, Tag, TagColor, TagSize, Textarea, ThemeContext, TimePicker, Toast, ToastsContainer, Toggle, ToggleButton, ToggleButtonGroup, ToggleButtonGroupContext, ToggleButtonStyles, ToggleTextPosition, Tooltip, TooltipArrow, TooltipPosition, Transition, TreeItem, TreeNodeType, TreeView, TreeViewSelectable, TypographyColor, TypographyContextVariant, TypographyVisualStyle, VisuallyHidden, blockQuoteStyles, calculateOffset, checkedStatusToBoolean, defaultI18n, filterNullEntries, getChildrenItemIds, getChildrenItemIdsFlat, getChildrenItemIdsInTree, getDateFromString, getIconSizes, getInitialItems, getListAlignment, getTreeItemLabelColor, getTreeItemWrapperCursor, inDateRange, magma, olListType, selectMulti, selectSingle, setBackgroundColor, setIconWidth, ulListType, useAccordion, useAccordionButton, useAccordionItem, useDataPagination, useDescendants, useFocusLock, useForceUpdate, useGenerateId, useIsInverse, useMediaQuery, usePagination, useTreeItem, useTreeView };
26743
26408
  //# sourceMappingURL=index.js.map