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
@@ -11075,7 +11075,9 @@ var Search = /*#__PURE__*/React.forwardRef(function (props, ref) {
11075
11075
  }
11076
11076
  }
11077
11077
  function handleSearch() {
11078
- onSearch(value);
11078
+ if (!props.isLoading) {
11079
+ onSearch(value);
11080
+ }
11079
11081
  }
11080
11082
  function handleClear() {
11081
11083
  onClear && typeof onClear === 'function' && onClear();
@@ -11089,7 +11091,7 @@ var Search = /*#__PURE__*/React.forwardRef(function (props, ref) {
11089
11091
  isInverse: useIsInverse(props.isInverse),
11090
11092
  onChange: handleChange,
11091
11093
  onClear: handleClear,
11092
- onIconClick: props.isPredictive ? null : isLoading ? null : handleSearch,
11094
+ onIconClick: props.isPredictive ? null : handleSearch,
11093
11095
  onKeyDown: handleKeyPress,
11094
11096
  placeholder: placeholder ? placeholder : i18n.search.input.placeholder,
11095
11097
  type: exports.InputType.search,
@@ -14284,1380 +14286,1046 @@ var BlockQuoteItem = /*#__PURE__*/React.forwardRef(function (props, ref) {
14284
14286
  }, rest), hasAttribution ? React.createElement(React.Fragment, null, "\u2015\xA0", children) : React.createElement(React.Fragment, null, "\u201C", children, "\u201D"));
14285
14287
  });
14286
14288
 
14287
- (function (TreeNodeType) {
14288
- TreeNodeType["branch"] = "branch";
14289
- TreeNodeType["leaf"] = "leaf";
14290
- })(exports.TreeNodeType || (exports.TreeNodeType = {}));
14291
- /**
14292
- * Leaf node - 1st level has 40px of left padding.
14293
- * Each level after that adds 56px of left padding.
14294
- * 40, 64, 88, 112, 136, etc.
14295
- *
14296
- * Branch node - 1st level has 8px of left padding.
14297
- * Each level after that adds 24px of left padding.
14298
- * 8, 32, 56, 80, 104, etc.
14299
- *
14300
- * The label element (the div inside the li) gets additional spacing.
14301
- * In order to highlight the entire line, we need to negate the value for margin.
14302
- */
14303
- function calculateOffset(type, depth, labelElem, negative) {
14304
- if (depth === void 0) {
14305
- depth = 0;
14306
- }
14307
- if (labelElem === void 0) {
14308
- labelElem = false;
14309
- }
14310
- if (negative === void 0) {
14311
- negative = false;
14289
+ (function (TreeViewSelectable) {
14290
+ TreeViewSelectable["single"] = "single";
14291
+ TreeViewSelectable["multi"] = "multi";
14292
+ TreeViewSelectable["off"] = "off";
14293
+ })(exports.TreeViewSelectable || (exports.TreeViewSelectable = {}));
14294
+
14295
+ var TreeViewContext = /*#__PURE__*/React.createContext({
14296
+ hasIcons: false,
14297
+ initialExpandedItems: [],
14298
+ initialExpandedItemsNeedUpdate: false,
14299
+ registerTreeItem: function registerTreeItem(elements, element) {},
14300
+ selectable: exports.TreeViewSelectable.single,
14301
+ selectedItems: [],
14302
+ setInitialExpandedItemsNeedUpdate: function setInitialExpandedItemsNeedUpdate() {},
14303
+ checkParents: true,
14304
+ checkChildren: true,
14305
+ items: [],
14306
+ selectItem: function selectItem() {
14307
+ return undefined;
14312
14308
  }
14313
- var padding = 0;
14314
- if (type === exports.TreeNodeType.leaf) {
14315
- if (labelElem) {
14316
- padding = depth * 8 + 40;
14317
- if (depth !== 0) {
14318
- padding += depth * 16;
14319
- }
14320
- } else if (depth === 0) {
14321
- padding = 40;
14322
- } else {
14323
- padding = 56;
14309
+ });
14310
+
14311
+ var checkedStatusToBoolean = function checkedStatusToBoolean(status) {
14312
+ return status === exports.IndeterminateCheckboxStatus.checked;
14313
+ };
14314
+ function useTreeItem(props, forwardedRef) {
14315
+ var children = props.children,
14316
+ _props$isDisabled = props.isDisabled,
14317
+ isDisabled = _props$isDisabled === void 0 ? false : _props$isDisabled,
14318
+ itemDepth = props.itemDepth,
14319
+ itemId = props.itemId,
14320
+ onClick = props.onClick,
14321
+ parentDepth = props.parentDepth,
14322
+ topLevel = props.topLevel;
14323
+ var _React$useContext = React.useContext(TreeViewContext),
14324
+ initialExpandedItems = _React$useContext.initialExpandedItems,
14325
+ registerTreeItem = _React$useContext.registerTreeItem,
14326
+ selectable = _React$useContext.selectable,
14327
+ selectedItems = _React$useContext.selectedItems,
14328
+ treeItemRefArray = _React$useContext.treeItemRefArray,
14329
+ initialExpandedItemsNeedUpdate = _React$useContext.initialExpandedItemsNeedUpdate,
14330
+ items = _React$useContext.items,
14331
+ selectItem = _React$useContext.selectItem;
14332
+ var treeViewItemData = React.useMemo(function () {
14333
+ return items.find(function (item) {
14334
+ return item.itemId === itemId;
14335
+ });
14336
+ }, [itemId, items]);
14337
+ var checkedStatus = React.useMemo(function () {
14338
+ var _treeViewItemData$che;
14339
+ return (_treeViewItemData$che = treeViewItemData == null ? void 0 : treeViewItemData.checkedStatus) != null ? _treeViewItemData$che : exports.IndeterminateCheckboxStatus.unchecked;
14340
+ }, [treeViewItemData]);
14341
+ var hasOwnTreeItems = React.useMemo(function () {
14342
+ return treeViewItemData == null ? void 0 : treeViewItemData.hasOwnTreeItems;
14343
+ }, [treeViewItemData]);
14344
+ var _React$useState = React.useState(false),
14345
+ expanded = _React$useState[0],
14346
+ setExpanded = _React$useState[1];
14347
+ var treeItemChildren = React.Children.toArray(children).filter(function (child) {
14348
+ return child.type === TreeItem;
14349
+ });
14350
+ var ownRef = React.useRef();
14351
+ var ref = useForkedRef(forwardedRef, ownRef);
14352
+ var forceUpdate = useForceUpdate();
14353
+ var generatedId = useGenerateId();
14354
+ React.useEffect(function () {
14355
+ if (!isDisabled && ownRef.current !== null) {
14356
+ registerTreeItem(treeItemRefArray, ownRef);
14324
14357
  }
14325
- } else if (type === exports.TreeNodeType.branch) {
14326
- if (labelElem) {
14327
- padding = depth * 8 + 8;
14328
- if (depth !== 0) {
14329
- padding += depth * 16;
14358
+ forceUpdate();
14359
+ }, []);
14360
+ React.useEffect(function () {
14361
+ if (initialExpandedItemsNeedUpdate) {
14362
+ updateInitialExpanded();
14363
+ }
14364
+ }, [initialExpandedItemsNeedUpdate]);
14365
+ var updateInitialExpanded = function updateInitialExpanded() {
14366
+ if ((initialExpandedItems == null ? void 0 : initialExpandedItems.length) !== 0 && !isDisabled) {
14367
+ var childrenItemIds = getChildrenItemIdsFlat(treeItemChildren);
14368
+ var allExpanded = [].concat(initialExpandedItems, childrenItemIds);
14369
+ if (allExpanded != null && allExpanded.some(function (item) {
14370
+ return item === itemId;
14371
+ })) {
14372
+ setExpanded(true);
14373
+ } else {
14374
+ setExpanded(false);
14330
14375
  }
14331
- } else if (depth === 0) {
14332
- padding = 8;
14333
14376
  } else {
14334
- padding = 24;
14377
+ setExpanded(false);
14335
14378
  }
14336
- }
14337
- return "" + (negative ? '-' : '') + padding + "px";
14338
- }
14339
- function getTreeItemLabelColor(isInverse, disabled, theme) {
14340
- if (disabled) {
14341
- if (isInverse) {
14342
- return polished.transparentize(0.6, theme.colors.neutral100);
14379
+ };
14380
+ var checkboxChangeHandler = function checkboxChangeHandler(event) {
14381
+ handleClick(event, itemId);
14382
+ };
14383
+ var handleClick = function handleClick(event, itemId) {
14384
+ if (selectable !== exports.TreeViewSelectable.off) {
14385
+ selectItem({
14386
+ itemId: itemId,
14387
+ checkedStatus: checkedStatus === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.unchecked : exports.IndeterminateCheckboxStatus.checked
14388
+ });
14389
+ onClick && typeof onClick === 'function' && onClick();
14343
14390
  }
14344
- return polished.transparentize(0.6, theme.colors.neutral500);
14345
- }
14346
- if (isInverse) {
14347
- return theme.colors.neutral100;
14348
- }
14349
- return theme.colors.neutral700;
14350
- }
14351
- function getTreeItemWrapperCursor(disabled, selectable, nodeType) {
14352
- if (disabled) {
14353
- return 'not-allowed';
14354
- }
14355
- if (nodeType === exports.TreeNodeType.branch && selectable === exports.TreeViewSelectable.off || selectable === exports.TreeViewSelectable.single) {
14356
- return 'pointer';
14357
- }
14358
- return 'default';
14359
- }
14360
- // Returns boolean if itemsArray has itemId
14361
- function arrayIncludesId(itemsArray, itemId) {
14362
- return itemsArray == null ? void 0 : itemsArray.some(function (item) {
14363
- return item.itemId === itemId;
14364
- });
14365
- }
14366
- // Return an array of objects of all the enabled children ids recursively
14367
- function getChildrenItemIds(children, status) {
14368
- if (status === void 0) {
14369
- status = '';
14391
+ };
14392
+ function getFocusIndex(filteredArrayCurrent) {
14393
+ return itemId && (filteredArrayCurrent == null ? void 0 : filteredArrayCurrent.findIndex(function (_ref) {
14394
+ var item = _ref.current;
14395
+ if (!item || !ownRef.current) return false;
14396
+ return item === ownRef.current;
14397
+ }));
14370
14398
  }
14371
- var itemIds = [];
14372
- React__default.Children.forEach(children, function (child) {
14373
- var _child$props;
14374
- if (!((_child$props = child.props) != null && _child$props.isDisabled)) {
14375
- var _child$props2, _child$props3;
14376
- var childStatus = status === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.checked : exports.IndeterminateCheckboxStatus.unchecked;
14377
- if ((_child$props2 = child.props) != null && _child$props2.itemId && childStatus !== exports.IndeterminateCheckboxStatus.unchecked) {
14378
- itemIds.push({
14379
- itemId: child.props.itemId,
14380
- checkedStatus: childStatus
14399
+ var focusIndex = getFocusIndex(treeItemRefArray == null ? void 0 : treeItemRefArray.current);
14400
+ React.useEffect(function () {
14401
+ treeItemRefArray == null || treeItemRefArray.current.map(function (itemRef) {
14402
+ if (!itemRef.current) {
14403
+ treeItemRefArray.current = treeItemRefArray.current.filter(function (item) {
14404
+ return itemRef.current !== item.current;
14381
14405
  });
14382
14406
  }
14383
- if ((_child$props3 = child.props) != null && _child$props3.children) {
14384
- var nestedItemIds = getChildrenItemIds(child.props.children, childStatus);
14385
- itemIds = itemIds.concat(nestedItemIds);
14386
- }
14407
+ });
14408
+ }, [treeItemRefArray]);
14409
+ var focusFirst = function focusFirst() {
14410
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14411
+ var curr = filteredRefArray['current'];
14412
+ curr == null || curr[0].current.focus();
14413
+ };
14414
+ var focusNext = function focusNext() {
14415
+ var _curr$newIndex;
14416
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14417
+ var curr = filteredRefArray['current'];
14418
+ var arrLength = curr.length;
14419
+ focusIndex = getFocusIndex(curr);
14420
+ var newIndex = focusIndex + 1;
14421
+ var next = curr == null || (_curr$newIndex = curr[newIndex]) == null ? void 0 : _curr$newIndex.current;
14422
+ while (!next && newIndex < arrLength) {
14423
+ var _curr$newIndex2;
14424
+ newIndex++;
14425
+ next = curr == null || (_curr$newIndex2 = curr[newIndex]) == null ? void 0 : _curr$newIndex2.current;
14387
14426
  }
14388
- });
14389
- return itemIds;
14390
- }
14391
- // Return an array of strings of all enabled children ids recursively
14392
- function getChildrenItemIdsFlat(children) {
14393
- var itemIds = [];
14394
- React__default.Children.forEach(children, function (child) {
14395
- var _child$props4;
14396
- if (!((_child$props4 = child.props) != null && _child$props4.isDisabled)) {
14397
- var _child$props5, _child$props6;
14398
- if ((_child$props5 = child.props) != null && _child$props5.itemId) {
14399
- itemIds.push(child.props.itemId);
14400
- }
14401
- if ((_child$props6 = child.props) != null && _child$props6.children) {
14402
- var nestedItemIds = getChildrenItemIdsFlat(child.props.children);
14403
- itemIds = itemIds.concat(nestedItemIds);
14427
+ if (next) {
14428
+ next.focus();
14429
+ } else {
14430
+ var _curr;
14431
+ var nextNext = curr == null || (_curr = curr[focusIndex + 2]) == null ? void 0 : _curr.current;
14432
+ if (nextNext) {
14433
+ nextNext.focus();
14434
+ } else {
14435
+ focusFirst();
14404
14436
  }
14405
14437
  }
14406
- });
14407
- return itemIds;
14408
- }
14409
- // Return an array of objects where all children are items are nested in the parents
14410
- function getChildrenItemIdsInTree(children) {
14411
- var itemIds = [];
14412
- React__default.Children.forEach(children, function (child) {
14413
- var _child$props7, _child$props8;
14414
- if ((_child$props7 = child.props) != null && _child$props7.itemId && !((_child$props8 = child.props) != null && _child$props8.isDisabled)) {
14415
- var _child$props9, _child$props10;
14416
- itemIds.push({
14417
- itemId: (_child$props9 = child.props) == null ? void 0 : _child$props9.itemId,
14418
- children: getChildrenItemIdsInTree((_child$props10 = child.props) == null ? void 0 : _child$props10.children)
14419
- });
14420
- }
14421
- });
14422
- return itemIds;
14423
- }
14424
- function getAllParentIds(childrenArr, itemId, parentItemIds) {
14425
- if (parentItemIds === void 0) {
14426
- parentItemIds = [];
14427
- }
14428
- for (var _iterator = _createForOfIteratorHelperLoose(childrenArr), _step; !(_step = _iterator()).done;) {
14429
- var child = _step.value;
14430
- if (child.itemId === itemId) {
14431
- return parentItemIds; // Return the parentItemIds array if the itemId is found
14438
+ };
14439
+ var focusPrev = function focusPrev() {
14440
+ var _curr$newIndex3;
14441
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14442
+ var curr = filteredRefArray['current'];
14443
+ focusIndex = getFocusIndex(curr);
14444
+ var newIndex = focusIndex - 1;
14445
+ var itemToFocus = curr == null || (_curr$newIndex3 = curr[newIndex]) == null ? void 0 : _curr$newIndex3.current;
14446
+ while (!itemToFocus && newIndex >= 0) {
14447
+ var _curr$newIndex4;
14448
+ newIndex--;
14449
+ itemToFocus = curr == null || (_curr$newIndex4 = curr[newIndex]) == null ? void 0 : _curr$newIndex4.current;
14432
14450
  }
14433
- if (child.children && child.children.length > 0) {
14434
- var updatedParentItemIds = [].concat(parentItemIds, [child.itemId]);
14435
- var result = getAllParentIds(child.children, itemId, updatedParentItemIds);
14436
- if (result) {
14437
- return result; // Return the result if the itemId is found in the child's subtree
14438
- }
14451
+ if (itemToFocus) {
14452
+ itemToFocus.focus();
14439
14453
  }
14440
- }
14441
- return null; // Return null if the itemId is not found
14442
- }
14443
- // Return the node of an itemId by traversing through the children
14444
- function findChildByItemId(children, itemId) {
14445
- if (!children) {
14446
- return null;
14447
- }
14448
- for (var _iterator2 = _createForOfIteratorHelperLoose(children), _step2; !(_step2 = _iterator2()).done;) {
14449
- var _child$props11, _child$props12;
14450
- var child = _step2.value;
14451
- if ((child == null || (_child$props11 = child.props) == null ? void 0 : _child$props11.itemId) === itemId) {
14452
- return child;
14453
- }
14454
- if (child != null && (_child$props12 = child.props) != null && _child$props12.children) {
14455
- var _child$props13;
14456
- var nestedChild = findChildByItemId([child == null || (_child$props13 = child.props) == null ? void 0 : _child$props13.children], itemId);
14457
- if (nestedChild) {
14458
- return nestedChild;
14459
- }
14460
- }
14461
- }
14462
- return null;
14463
- }
14464
- // Return whether all the children are enabled
14465
- function getAllChildrenEnabled(children) {
14466
- return !children.some(function (child) {
14467
- return child.props.isDisabled;
14468
- });
14469
- }
14470
- // Return an array that filters out the childrenIds & itemId from selectedItems
14471
- // (used for deselecting indeterminate checkboxes)
14472
- function filterSelectedItems(selectedItems, childrenIds, itemId) {
14473
- var allItems = [].concat(childrenIds, [itemId]);
14474
- var ids = allItems.map(function (item) {
14475
- return item.itemId;
14476
- });
14477
- return selectedItems.filter(function (item) {
14478
- return !ids.includes(item.itemId);
14479
- });
14480
- }
14481
- // Return an array of childrenIds that are missing from selectedItems
14482
- function getMissingChildrenIds(selectedItems, childrenIds) {
14483
- var selectedIds = selectedItems.map(function (item) {
14484
- return item.itemId;
14485
- });
14486
- return childrenIds.filter(function (item) {
14487
- return !selectedIds.includes(item.itemId);
14488
- });
14489
- }
14490
- // Return an array of statuses for all enabled children
14491
- function getChildrenCheckedStatus(childrenIds, status) {
14492
- return childrenIds.map(function (child) {
14493
- return child.isDisabled ? exports.IndeterminateCheckboxStatus.unchecked : status;
14494
- });
14495
- }
14496
- // Return the length of enabled children
14497
- function getEnabledTreeItemChildrenLength(treeItemChildren) {
14498
- return treeItemChildren.reduce(function (count, child) {
14499
- if (!child.props.isDisabled) {
14500
- return count + 1;
14501
- }
14502
- return count;
14503
- }, 0);
14504
- }
14505
- // Updates the checkedStatus of the itemId in selectedItems and returns the selectedItems
14506
- function getUpdatedSelectedItems(selectedItems, itemId, checkedStatus) {
14507
- var updatedItems = selectedItems.map(function (item) {
14508
- if (item.itemId === itemId) {
14509
- return _extends({}, item, {
14510
- checkedStatus: checkedStatus
14511
- });
14512
- }
14513
- return item;
14514
- });
14515
- return updatedItems;
14516
- }
14517
- // Return an array of unique items from the previous state, initially selected items and the childrem item ids
14518
- function getUniqueSelectedItemsArray(itemArr0, itemArr1, itemArr2) {
14519
- var combinedArray = [].concat(itemArr0, itemArr2, itemArr1);
14520
- var uniqueItemsMap = new Map();
14521
- for (var _iterator3 = _createForOfIteratorHelperLoose(combinedArray), _step3; !(_step3 = _iterator3()).done;) {
14522
- var item = _step3.value;
14523
- uniqueItemsMap.set(item.itemId, item);
14524
- }
14525
- return Array.from(uniqueItemsMap.values());
14526
- }
14527
- // Return items in both arrays
14528
- function findCommonItems(initialItemsArr, childrenItemsArr) {
14529
- var commonItems = [];
14530
- for (var _iterator4 = _createForOfIteratorHelperLoose(initialItemsArr), _step4; !(_step4 = _iterator4()).done;) {
14531
- var initialItem = _step4.value;
14532
- for (var _iterator5 = _createForOfIteratorHelperLoose(childrenItemsArr), _step5; !(_step5 = _iterator5()).done;) {
14533
- var childItem = _step5.value;
14534
- if (initialItem.itemId === childItem.itemId) {
14535
- commonItems.push(initialItem);
14536
- break;
14537
- }
14538
- }
14539
- }
14540
- return commonItems;
14541
- }
14542
- // Compares two arrays
14543
- function areArraysEqual(array1, array2) {
14544
- if (array1.length !== array2.length) {
14545
- return false;
14546
- }
14547
- for (var i = 0; i < array1.length; i++) {
14548
- var obj1 = array1[i];
14549
- var obj2 = array2[i];
14550
- var keys1 = Object.keys(obj1);
14551
- var keys2 = Object.keys(obj2);
14552
- if (keys1.length !== keys2.length) {
14553
- return false;
14554
- }
14555
- for (var _i = 0, _keys = keys1; _i < _keys.length; _i++) {
14556
- var key = _keys[_i];
14557
- if (obj1[key] !== obj2[key]) {
14558
- return false;
14559
- }
14560
- }
14561
- }
14562
- return true;
14563
- }
14564
- // Return the checkedStatus of an itemId
14565
- function getCheckedStatus(itemId, selectedItems) {
14566
- for (var _iterator6 = _createForOfIteratorHelperLoose(selectedItems), _step6; !(_step6 = _iterator6()).done;) {
14567
- var item = _step6.value;
14568
- if (item.itemId === itemId) {
14569
- return item.checkedStatus;
14570
- }
14571
- }
14572
- return null;
14573
- }
14574
- // Return first child that is a branch
14575
- function findFirstBranchNode(children) {
14576
- for (var _iterator7 = _createForOfIteratorHelperLoose(children), _step7; !(_step7 = _iterator7()).done;) {
14577
- var _item$props, _item$props2, _item$props3, _item$props4;
14578
- var item = _step7.value;
14579
- if ((_item$props = item.props) != null && _item$props.children && (_item$props2 = item.props) != null && _item$props2.children) {
14580
- return item;
14581
- }
14582
- if ((_item$props3 = item.props) != null && _item$props3.children && ((_item$props4 = item.props) == null ? void 0 : _item$props4.children.length) === 0) {
14583
- var _item$props5;
14584
- var childResult = findFirstBranchNode((_item$props5 = item.props) == null ? void 0 : _item$props5.children);
14585
- if (childResult) {
14586
- return childResult;
14454
+ };
14455
+ var focusLast = function focusLast() {
14456
+ var _filteredRefArray$cur;
14457
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14458
+ var arrLength = filteredRefArray['current'].length;
14459
+ (_filteredRefArray$cur = filteredRefArray['current']) == null || _filteredRefArray$cur[arrLength - 1].current.focus();
14460
+ };
14461
+ var focusSelf = function focusSelf() {
14462
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14463
+ var curr = filteredRefArray['current'];
14464
+ focusIndex = getFocusIndex(curr);
14465
+ curr == null || curr[focusIndex].current.focus();
14466
+ };
14467
+ var expandFocusedNode = function expandFocusedNode() {
14468
+ if (hasOwnTreeItems) {
14469
+ if (expanded) {
14470
+ focusNext();
14471
+ } else {
14472
+ setExpanded(true);
14473
+ focusSelf();
14587
14474
  }
14588
14475
  }
14589
- }
14590
- return null;
14591
- }
14592
- // Returns the first item in the tree from the array of selected items
14593
- function getFirstItemInTree(arr, children) {
14594
- // If there's only 1 item, return that one first
14595
- if (arr.length === 1) {
14596
- var _arr$;
14597
- return (_arr$ = arr[0]) == null ? void 0 : _arr$.itemId;
14598
- }
14599
- var allFoundItems = [];
14600
- var _loop2 = function _loop2() {
14601
- var _children$props, _children$props2;
14602
- var item = _step8.value;
14603
- var foundItem = Array.isArray(children) ? children.find(function (child) {
14604
- var _child$props14;
14605
- return ((_child$props14 = child.props) == null ? void 0 : _child$props14.itemId) === item.itemId;
14606
- }) : ((_children$props = children.props) == null ? void 0 : _children$props.itemId) === item.itemId;
14607
- if (foundItem) {
14608
- var _foundItem$props;
14609
- allFoundItems.push((_foundItem$props = foundItem.props) == null ? void 0 : _foundItem$props.itemId);
14610
- } else if ((_children$props2 = children.props) != null && _children$props2.children) {
14611
- var result = getFirstItemInTree(arr, children.props.children);
14612
- if (result) {
14613
- allFoundItems.push(result);
14476
+ };
14477
+ var collapseFocusedNode = function collapseFocusedNode() {
14478
+ if (hasOwnTreeItems) {
14479
+ if (expanded) {
14480
+ setExpanded(false);
14481
+ focusSelf();
14482
+ } else {
14483
+ focusPrev();
14614
14484
  }
14485
+ } else {
14486
+ focusPrev();
14615
14487
  }
14616
14488
  };
14617
- for (var _iterator8 = _createForOfIteratorHelperLoose(arr), _step8; !(_step8 = _iterator8()).done;) {
14618
- _loop2();
14619
- }
14620
- // After finding all the items, return the one that comes first on the tree (top to bottom)
14621
- if (allFoundItems.length === 1) {
14622
- return allFoundItems[0];
14623
- } else if (allFoundItems.length > 1) {
14624
- var _loop = function _loop() {
14625
- var ch = _step9.value;
14626
- return {
14627
- v: allFoundItems.find(function (i) {
14628
- var _ch$props;
14629
- return i === ((_ch$props = ch.props) == null ? void 0 : _ch$props.itemId);
14630
- })
14631
- };
14632
- },
14633
- _ret;
14634
- for (var _iterator9 = _createForOfIteratorHelperLoose(children), _step9; !(_step9 = _iterator9()).done;) {
14635
- _ret = _loop();
14636
- if (_ret) return _ret.v;
14637
- }
14638
- }
14639
- return null;
14640
- }
14641
- // Return a treeItemRefArray object with no null children
14642
- function filterNullEntries(obj) {
14643
- if (Array.isArray(obj.current)) {
14644
- var filteredArray = obj.current.filter(function (item) {
14645
- return (item == null ? void 0 : item.current) !== null;
14646
- });
14647
- if (filteredArray.length > 0) {
14648
- return {
14649
- current: filteredArray
14650
- };
14651
- }
14652
- }
14653
- return {};
14654
- }
14655
-
14656
- (function (TreeViewSelectable) {
14657
- TreeViewSelectable["single"] = "single";
14658
- TreeViewSelectable["multi"] = "multi";
14659
- TreeViewSelectable["off"] = "off";
14660
- })(exports.TreeViewSelectable || (exports.TreeViewSelectable = {}));
14661
- function useTreeView(props) {
14662
- var _props$selectable = props.selectable,
14663
- selectable = _props$selectable === void 0 ? exports.TreeViewSelectable.single : _props$selectable,
14664
- onSelectedItemChange = props.onSelectedItemChange,
14665
- onExpandedChange = props.onExpandedChange,
14666
- initialExpandedItems = props.initialExpandedItems,
14667
- preselectedItems = props.preselectedItems,
14668
- _props$checkChildren = props.checkChildren,
14669
- checkChildren = _props$checkChildren === void 0 ? true : _props$checkChildren,
14670
- _props$checkParents = props.checkParents,
14671
- checkParents = _props$checkParents === void 0 ? true : _props$checkParents,
14672
- children = props.children;
14673
- var _React$useState = React.useState(false),
14674
- hasIcons = _React$useState[0],
14675
- setHasIcons = _React$useState[1];
14676
- var _React$useState2 = React.useState(preselectedItems || []),
14677
- selectedItems = _React$useState2[0],
14678
- setSelectedItems = _React$useState2[1];
14679
- var _React$useState3 = React.useState(false),
14680
- preselectedItemsNeedUpdate = _React$useState3[0],
14681
- setPreselectedItemsNeedUpdate = _React$useState3[1];
14682
- var _React$useState4 = React.useState(false),
14683
- initialExpandedItemsNeedUpdate = _React$useState4[0],
14684
- setInitialExpandedItemsNeedUpdate = _React$useState4[1];
14685
- var _React$useState5 = React.useState(false),
14686
- selectedItemsChanged = _React$useState5[0],
14687
- setSelectedItemsChanged = _React$useState5[1];
14688
- var _React$useState6 = React.useState(null),
14689
- itemToFocus = _React$useState6[0],
14690
- setItemToFocus = _React$useState6[1];
14691
- var _useDescendants = useDescendants(),
14692
- treeItemRefArray = _useDescendants[0],
14693
- registerTreeItem = _useDescendants[1];
14694
- React.useEffect(function () {
14695
- if (selectable !== exports.TreeViewSelectable.off && preselectedItems) {
14696
- setPreselectedItemsNeedUpdate(true);
14697
- }
14698
- if (initialExpandedItems) {
14699
- setInitialExpandedItemsNeedUpdate(true);
14489
+ var handleKeyDown = function handleKeyDown(event) {
14490
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14491
+ var curr = filteredRefArray['current'];
14492
+ var arrLength = curr.length;
14493
+ if (['ArrowDown', 'ArrowUp', 'Home', 'End', ' '].includes(event.key)) {
14494
+ event.preventDefault();
14700
14495
  }
14701
- getItemToFocusFirst();
14702
- }, []);
14703
- React.useEffect(function () {
14704
- if (selectable !== exports.TreeViewSelectable.off && selectedItemsChanged) {
14705
- onSelectedItemChange && typeof onSelectedItemChange === 'function' && onSelectedItemChange(selectedItems);
14706
- setSelectedItemsChanged(false);
14707
- getItemToFocusFirst();
14708
- }
14709
- }, [selectedItemsChanged]);
14710
- function getItemToFocusFirst() {
14711
- var item = null;
14712
- if ((children == null ? void 0 : children.length) > 0) {
14713
- var _findFirstBranchNode;
14714
- var allChildrenInTree = getChildrenItemIdsInTree(children);
14715
- var firstBranchNode = (_findFirstBranchNode = findFirstBranchNode(children)) == null ? void 0 : _findFirstBranchNode.props.itemId;
14716
- var firstItemSelected = getFirstItemInTree(selectedItems, children);
14717
- var firstNode = allChildrenInTree == null ? void 0 : allChildrenInTree[0].itemId;
14718
- if (selectable === exports.TreeViewSelectable.off) {
14719
- /*
14720
- If there is at least one node with a branch, focus is set on the first branch node.
14721
- If there are no nodes with branches, the first item is focused and the tree can be traversed
14722
- */
14723
- item = firstBranchNode || (allChildrenInTree == null ? void 0 : allChildrenInTree[0].itemId);
14724
- } else {
14725
- // Same behavior for Single and Multiple
14726
- if (selectedItems.length === 0) {
14727
- // If none of the nodes are selected before the tree receives focus, focus is set on the first node.
14728
- item = firstNode;
14729
- } else if (selectedItems.length > 0) {
14730
- // If one or more nodes are selected before the tree receives focus, focus is set on the first selected node.
14731
- item = firstItemSelected;
14496
+ switch (event.key) {
14497
+ case 'ArrowDown':
14498
+ {
14499
+ // Move to the next item, or wrap to first
14500
+ focusIndex === arrLength - 1 ? focusFirst() : focusNext();
14501
+ break;
14732
14502
  }
14733
- }
14503
+ case 'ArrowUp':
14504
+ {
14505
+ // Move to the previous item, or wrap to last
14506
+ focusIndex === 0 ? focusLast() : focusPrev();
14507
+ break;
14508
+ }
14509
+ case 'ArrowRight':
14510
+ {
14511
+ // Open parent nodes
14512
+ expandFocusedNode();
14513
+ break;
14514
+ }
14515
+ case 'ArrowLeft':
14516
+ {
14517
+ // Close open parent nodes
14518
+ collapseFocusedNode();
14519
+ break;
14520
+ }
14521
+ case 'Home':
14522
+ {
14523
+ // Moves focus to the first node in the tree without opening or closing a node.
14524
+ focusFirst();
14525
+ break;
14526
+ }
14527
+ case 'End':
14528
+ {
14529
+ // Moves focus to the last node in the tree that is focusable without opening a node.
14530
+ focusLast();
14531
+ break;
14532
+ }
14533
+ case 'Enter':
14534
+ {
14535
+ // Activates a node, i.e., performs its default action.
14536
+ if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
14537
+ setExpanded(!expanded);
14538
+ } else if (selectable === exports.TreeViewSelectable.single) {
14539
+ // In single-select it selects the focused node.
14540
+ selectItem({
14541
+ itemId: itemId,
14542
+ checkedStatus: exports.IndeterminateCheckboxStatus.checked
14543
+ });
14544
+ } else if (selectable === exports.TreeViewSelectable.multi) {
14545
+ // In multi-select, it toggles the selection state of the focused node.
14546
+ selectItem({
14547
+ itemId: itemId,
14548
+ checkedStatus: checkedStatus === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.unchecked : exports.IndeterminateCheckboxStatus.checked
14549
+ });
14550
+ }
14551
+ break;
14552
+ }
14553
+ case ' ':
14554
+ {
14555
+ // Toggles the selection state of the focused node.
14556
+ if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
14557
+ setExpanded(!expanded);
14558
+ } else if (selectable === exports.TreeViewSelectable.single) {
14559
+ if (hasOwnTreeItems) {
14560
+ setExpanded(!expanded);
14561
+ } else {
14562
+ selectItem({
14563
+ itemId: itemId,
14564
+ checkedStatus: exports.IndeterminateCheckboxStatus.checked
14565
+ });
14566
+ }
14567
+ } else if (selectable === exports.TreeViewSelectable.multi) {
14568
+ selectItem({
14569
+ itemId: itemId,
14570
+ checkedStatus: checkedStatus === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.unchecked : exports.IndeterminateCheckboxStatus.checked
14571
+ });
14572
+ }
14573
+ break;
14574
+ }
14575
+ default:
14576
+ return;
14734
14577
  }
14735
- setItemToFocus(item);
14736
- }
14578
+ };
14737
14579
  var contextValue = {
14738
- hasIcons: hasIcons,
14739
- itemToFocus: itemToFocus,
14740
- onSelectedItemChange: onSelectedItemChange,
14741
- onExpandedChange: onExpandedChange,
14742
- selectable: selectable,
14743
- setHasIcons: setHasIcons,
14580
+ checkboxChangeHandler: checkboxChangeHandler,
14581
+ checkedStatus: checkedStatus,
14582
+ expanded: expanded,
14583
+ hasOwnTreeItems: hasOwnTreeItems,
14584
+ itemDepth: parentDepth === 0 && topLevel ? 0 : itemDepth + 1,
14585
+ itemId: itemId || generatedId,
14586
+ parentDepth: parentDepth,
14587
+ ref: ref,
14744
14588
  selectedItems: selectedItems,
14745
- setSelectedItems: setSelectedItems,
14746
- initialExpandedItems: initialExpandedItems,
14747
- treeItemRefArray: treeItemRefArray,
14748
- registerTreeItem: registerTreeItem,
14749
- preselectedItemsNeedUpdate: preselectedItemsNeedUpdate,
14750
- setPreselectedItemsNeedUpdate: setPreselectedItemsNeedUpdate,
14751
- initialExpandedItemsNeedUpdate: initialExpandedItemsNeedUpdate,
14752
- setInitialExpandedItemsNeedUpdate: setInitialExpandedItemsNeedUpdate,
14753
- selectedItemsChanged: selectedItemsChanged,
14754
- setSelectedItemsChanged: setSelectedItemsChanged,
14755
- checkChildren: checkChildren,
14756
- checkParents: checkParents
14589
+ setExpanded: setExpanded,
14590
+ treeItemChildren: treeItemChildren
14757
14591
  };
14758
14592
  return {
14759
- contextValue: contextValue
14593
+ contextValue: contextValue,
14594
+ handleClick: handleClick,
14595
+ handleKeyDown: handleKeyDown
14760
14596
  };
14761
14597
  }
14762
14598
 
14763
- var TreeViewContext = /*#__PURE__*/React.createContext({
14764
- hasIcons: false,
14765
- initialExpandedItems: [],
14766
- initialExpandedItemsNeedUpdate: false,
14767
- preselectedItemsNeedUpdate: false,
14768
- registerTreeItem: function registerTreeItem(elements, element) {},
14769
- selectable: exports.TreeViewSelectable.single,
14770
- selectedItems: [],
14771
- selectedItemsChanged: false,
14772
- setHasIcons: function setHasIcons() {},
14773
- setInitialExpandedItemsNeedUpdate: function setInitialExpandedItemsNeedUpdate() {},
14774
- setPreselectedItemsNeedUpdate: function setPreselectedItemsNeedUpdate() {},
14775
- setSelectedItems: function setSelectedItems() {},
14776
- setSelectedItemsChanged: function setSelectedItemsChanged() {},
14777
- checkParents: true,
14778
- checkChildren: true
14599
+ var TreeItemContext = /*#__PURE__*/React.createContext({
14600
+ expanded: false,
14601
+ setExpanded: function setExpanded() {},
14602
+ checkedStatus: exports.IndeterminateCheckboxStatus.unchecked,
14603
+ checkboxChangeHandler: function checkboxChangeHandler() {},
14604
+ hasOwnTreeItems: false,
14605
+ parentDepth: 0
14779
14606
  });
14780
14607
 
14781
- var checkedStatusToBoolean = function checkedStatusToBoolean(status) {
14782
- return status === exports.IndeterminateCheckboxStatus.checked;
14783
- };
14784
- function useTreeItem(props, forwardedRef) {
14785
- var children = props.children,
14786
- icon = props.icon,
14787
- index = props.index,
14788
- _props$isDisabled = props.isDisabled,
14789
- isDisabled = _props$isDisabled === void 0 ? false : _props$isDisabled,
14790
- itemDepth = props.itemDepth,
14791
- itemId = props.itemId,
14792
- onClick = props.onClick,
14793
- parentCheckedStatus = props.parentCheckedStatus,
14794
- parentDepth = props.parentDepth,
14795
- topLevel = props.topLevel,
14796
- updateParentCheckStatus = props.updateParentCheckStatus;
14797
- var _React$useContext = React.useContext(TreeViewContext),
14798
- initialExpandedItems = _React$useContext.initialExpandedItems,
14799
- registerTreeItem = _React$useContext.registerTreeItem,
14608
+ var _excluded$1B = ["children", "icon", "index", "isDisabled", "label", "labelStyle", "style", "testId", "topLevel"];
14609
+ var StyledTreeItem = /*#__PURE__*/_styled("li", {
14610
+ target: "e1xiryew5",
14611
+ label: "StyledTreeItem"
14612
+ })("color:", function (props) {
14613
+ return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
14614
+ }, ";list-style-type:none;cursor:", function (props) {
14615
+ return getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType);
14616
+ }, ";position:relative;margin-bottom:0;padding-inline-start:", function (props) {
14617
+ return calculateOffset(props.nodeType, props.depth);
14618
+ }, ";>div:first-of-type{background:", function (props) {
14619
+ return props.selected && props.isInverse ? polished.transparentize(0.7, props.theme.colors.neutral900) : props.selected && polished.transparentize(0.92, props.theme.colors.neutral900);
14620
+ }, ";position:relative;padding-inline-start:", function (props) {
14621
+ return calculateOffset(props.nodeType, props.depth, true);
14622
+ }, ";margin-inline-start:", function (props) {
14623
+ return calculateOffset(props.nodeType, props.depth, true, true);
14624
+ }, ";padding-block-end:", function (props) {
14625
+ return props.theme.spaceScale.spacing02;
14626
+ }, ";padding-block-start:", function (props) {
14627
+ return props.theme.spaceScale.spacing02;
14628
+ }, ";padding-right:", function (props) {
14629
+ return props.theme.spaceScale.spacing02;
14630
+ }, ";", function (props) {
14631
+ return props.selected && /*#__PURE__*/react.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;" + ( "/*# 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"]} */"));
14632
+ }, " &:hover{background:", function (props) {
14633
+ return !props.isDisabled ? props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral900) : polished.transparentize(0.95, props.theme.colors.neutral900) : undefined;
14634
+ }, ";}}" + ( "/*# 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"]} */"));
14635
+ var IconWrapper$8 = /*#__PURE__*/_styled("span", {
14636
+ target: "e1xiryew4",
14637
+ label: "IconWrapper"
14638
+ })("color:", function (props) {
14639
+ return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
14640
+ }, ";margin-right:", function (props) {
14641
+ return props.theme.spaceScale.spacing03;
14642
+ }, ";margin-left:0px;svg{height:", function (props) {
14643
+ return props.theme.iconSizes.medium;
14644
+ }, "px;width:", function (props) {
14645
+ return props.theme.iconSizes.medium;
14646
+ }, "px;vertical-align:middle;}" + ( "/*# 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"]} */"));
14647
+ var StyledLabelWrapper = /*#__PURE__*/_styled("span", {
14648
+ target: "e1xiryew3",
14649
+ label: "StyledLabelWrapper"
14650
+ })("display:flex;align-items:flex-start;color:", function (props) {
14651
+ return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
14652
+ }, ";width:100%;" + ( "/*# 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"]} */"));
14653
+ var StyledExpandWrapper = /*#__PURE__*/_styled("div", {
14654
+ target: "e1xiryew2",
14655
+ label: "StyledExpandWrapper"
14656
+ })("display:inline-block;vertical-align:middle;margin-right:", function (props) {
14657
+ return props.theme.spaceScale.spacing03;
14658
+ }, ";color:", function (props) {
14659
+ return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
14660
+ }, ";border-radius:0;width:", function (props) {
14661
+ return props.theme.spaceScale.spacing06;
14662
+ }, ";height:", function (props) {
14663
+ return props.theme.spaceScale.spacing06;
14664
+ }, ";" + ( "/*# 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"]} */"));
14665
+ var StyledCheckboxWrapper = /*#__PURE__*/_styled("div", {
14666
+ target: "e1xiryew1",
14667
+ label: "StyledCheckboxWrapper"
14668
+ })("margin-right:", function (props) {
14669
+ return props.theme.spaceScale.spacing03;
14670
+ }, ";vertical-align:middle;display:inline-flex;" + ( "/*# 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"]} */"));
14671
+ var StyledItemWrapper = /*#__PURE__*/_styled("div", {
14672
+ target: "e1xiryew0",
14673
+ label: "StyledItemWrapper"
14674
+ })("display:flex;align-items:flex-start;cursor:", function (props) {
14675
+ return getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType);
14676
+ }, ";&:focus{outline-offset:-2px;outline:2px solid ", function (props) {
14677
+ return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
14678
+ }, ";}" + ( "/*# 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"]} */"));
14679
+ var TreeItem = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
14680
+ var _selectedItems$;
14681
+ var children = props.children,
14682
+ icon = props.icon,
14683
+ isDisabled = props.isDisabled,
14684
+ label = props.label,
14685
+ labelStyle = props.labelStyle,
14686
+ style = props.style,
14687
+ testId = props.testId,
14688
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1B);
14689
+ var theme = React.useContext(ThemeContext);
14690
+ var isInverse = useIsInverse();
14691
+ var _React$useContext = React.useContext(TreeViewContext),
14800
14692
  selectable = _React$useContext.selectable,
14801
- selectedItems = _React$useContext.selectedItems,
14802
- setHasIcons = _React$useContext.setHasIcons,
14803
- setSelectedItems = _React$useContext.setSelectedItems,
14804
- treeItemRefArray = _React$useContext.treeItemRefArray,
14805
- preselectedItemsNeedUpdate = _React$useContext.preselectedItemsNeedUpdate,
14806
- setPreselectedItemsNeedUpdate = _React$useContext.setPreselectedItemsNeedUpdate,
14807
- initialExpandedItemsNeedUpdate = _React$useContext.initialExpandedItemsNeedUpdate,
14808
- setSelectedItemsChanged = _React$useContext.setSelectedItemsChanged,
14809
- selectedItemsChanged = _React$useContext.selectedItemsChanged,
14810
- checkParents = _React$useContext.checkParents,
14811
- checkChildren = _React$useContext.checkChildren;
14812
- // Needs to skip sending an "onSelection" event during the initial render of items
14813
- var _React$useState = React.useState(false),
14814
- isSkipSelectedItemsUpdate = _React$useState[0],
14815
- setIsSkipSelectedItemsUpdate = _React$useState[1];
14816
- var _React$useState2 = React.useState(false),
14817
- expanded = _React$useState2[0],
14818
- setExpanded = _React$useState2[1];
14819
- var _React$useState3 = React.useState(exports.IndeterminateCheckboxStatus.unchecked),
14820
- checkedStatus = _React$useState3[0],
14821
- setCheckedStatus = _React$useState3[1];
14822
- var _React$useState4 = React.useState(undefined),
14823
- statusUpdatedBy = _React$useState4[0],
14824
- setStatusUpdatedBy = _React$useState4[1];
14825
- var treeItemChildren = React.Children.toArray(children).filter(function (child) {
14826
- return child.type === TreeItem;
14693
+ hasIcons = _React$useContext.hasIcons,
14694
+ onExpandedChange = _React$useContext.onExpandedChange,
14695
+ itemToFocus = _React$useContext.itemToFocus;
14696
+ var _useTreeItem = useTreeItem(props, forwardedRef),
14697
+ contextValue = _useTreeItem.contextValue,
14698
+ handleClick = _useTreeItem.handleClick,
14699
+ handleKeyDown = _useTreeItem.handleKeyDown;
14700
+ var checkboxChangeHandler = contextValue.checkboxChangeHandler,
14701
+ checkedStatus = contextValue.checkedStatus,
14702
+ expanded = contextValue.expanded,
14703
+ hasOwnTreeItems = contextValue.hasOwnTreeItems,
14704
+ itemDepth = contextValue.itemDepth,
14705
+ itemId = contextValue.itemId,
14706
+ parentDepth = contextValue.parentDepth,
14707
+ ref = contextValue.ref,
14708
+ selectedItems = contextValue.selectedItems,
14709
+ setExpanded = contextValue.setExpanded;
14710
+ var nodeType = hasOwnTreeItems ? exports.TreeNodeType.branch : exports.TreeNodeType.leaf;
14711
+ var selectedItem = selectable === exports.TreeViewSelectable.single ? (selectedItems == null || (_selectedItems$ = selectedItems[0]) == null ? void 0 : _selectedItems$.itemId) === itemId : null;
14712
+ var ariaCheckedValue = selectable === exports.TreeViewSelectable.multi ? checkedStatus === exports.IndeterminateCheckboxStatus.indeterminate ? 'mixed' : checkedStatus === exports.IndeterminateCheckboxStatus.checked : null;
14713
+ var defaultIcon = nodeType === exports.TreeNodeType.branch ? React.createElement(reactMagmaIcons.FolderIcon, {
14714
+ "aria-hidden": true
14715
+ }) : React.createElement(reactMagmaIcons.ArticleIcon, {
14716
+ "aria-hidden": true
14827
14717
  });
14828
- // TODO fix for disabled items (issue #1305)
14829
- // const numberOfTreeItemChildren = getEnabledTreeItemChildrenLength(treeItemChildren);
14830
- var numberOfTreeItemChildren = treeItemChildren.length;
14831
- var hasOwnTreeItems = numberOfTreeItemChildren > 0;
14832
- var _React$useState5 = React.useState(Array(numberOfTreeItemChildren).fill(exports.IndeterminateCheckboxStatus.unchecked)),
14833
- childrenCheckedStatus = _React$useState5[0],
14834
- setChildrenCheckedStatus = _React$useState5[1];
14835
- var ownRef = React.useRef();
14836
- var ref = useForkedRef(forwardedRef, ownRef);
14837
- var forceUpdate = useForceUpdate();
14838
- var generatedId = useGenerateId();
14839
- React.useEffect(function () {
14840
- setTreeViewIconVisibility();
14841
- selectedItems.map(function (item) {
14842
- if ((item == null ? void 0 : item.itemId) === itemId) {
14843
- var newStatus = item == null ? void 0 : item.checkedStatus;
14844
- if (checkedStatus !== newStatus) {
14845
- var childrenOfItemId = getChildrenItemIds(treeItemChildren, exports.IndeterminateCheckboxStatus.checked);
14846
- var itemIdChildrenInTree = getChildrenItemIdsInTree(treeItemChildren);
14847
- var parentIds = itemId && itemIdChildrenInTree.length > 0 ? getAllParentIds(itemIdChildrenInTree, itemId) : [];
14848
- var additionalItems = [];
14849
- if (newStatus === exports.IndeterminateCheckboxStatus.checked) {
14850
- if (parentIds && checkParents) additionalItems.push.apply(additionalItems, parentIds);
14851
- if (hasOwnTreeItems && checkChildren) additionalItems.push.apply(additionalItems, childrenOfItemId);
14852
- }
14853
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
14854
- setCheckedStatus(item == null ? void 0 : item.checkedStatus);
14855
- if (selectable === exports.TreeViewSelectable.multi) {
14856
- // Pass "true" as isInitialRender value to skip sending an "onSelection" event
14857
- // Required since this useEffect handles initial rendering of the item
14858
- updateParentCheckStatus(index, newStatus, true);
14859
- }
14860
- setSelectedItems(function (prev) {
14861
- return getUniqueSelectedItemsArray([{
14862
- itemId: itemId,
14863
- checkedStatus: newStatus
14864
- }], prev, additionalItems);
14865
- });
14866
- }
14867
- return;
14868
- }
14869
- });
14870
- if (!isDisabled && ownRef.current !== null) {
14871
- registerTreeItem(treeItemRefArray, ownRef);
14872
- }
14873
- forceUpdate();
14874
- }, []);
14875
- function setTreeViewIconVisibility() {
14876
- if (treeItemChildren.length === 0 && icon) {
14877
- setHasIcons(true);
14878
- return;
14879
- }
14880
- treeItemChildren.forEach(function (child) {
14881
- if (child != null && child.props.icon) {
14882
- setHasIcons(true);
14883
- return;
14718
+ var labelText = React.createElement(StyledLabelWrapper, {
14719
+ theme: theme,
14720
+ isDisabled: isDisabled,
14721
+ isInverse: isInverse,
14722
+ style: labelStyle,
14723
+ id: itemId + "-label",
14724
+ "data-testid": (testId || itemId) + "-label",
14725
+ onClick: function onClick(e) {
14726
+ if (selectable === exports.TreeViewSelectable.single && !isDisabled) {
14727
+ handleClick(e, itemId);
14884
14728
  }
14885
- });
14886
- }
14887
- function updateSelectedItemsChanged() {
14888
- if (topLevel && !selectedItemsChanged) {
14889
- setSelectedItemsChanged(true);
14890
- }
14891
- }
14892
- React.useEffect(function () {
14893
- if (preselectedItemsNeedUpdate) {
14894
- updateInitialSelected();
14895
- }
14896
- }, [preselectedItemsNeedUpdate]);
14897
- React.useEffect(function () {
14898
- if (initialExpandedItemsNeedUpdate) {
14899
- updateInitialExpanded();
14900
- }
14901
- }, [initialExpandedItemsNeedUpdate]);
14902
- var updateCheckedStatusFromChild = function updateCheckedStatusFromChild(index, status, isInitialRender) {
14903
- if (checkParents) {
14904
- // Set isSkipSelectedItemsUpdate as true if this update caused by the initial render of children during expanding
14905
- setIsSkipSelectedItemsUpdate(Boolean(isInitialRender));
14906
- setStatusUpdatedBy("children" /* children */);
14907
- setChildrenCheckedStatus(function (prev) {
14908
- var newChildrenCheckedStatus = [].concat(prev);
14909
- newChildrenCheckedStatus[index] = status;
14910
- return newChildrenCheckedStatus;
14911
- });
14912
14729
  }
14730
+ }, hasIcons && React.createElement(IconWrapper$8, {
14731
+ isInverse: isInverse,
14732
+ theme: theme,
14733
+ isDisabled: isDisabled,
14734
+ "data-testid": (testId || itemId) + "-icon"
14735
+ }, icon || defaultIcon), label);
14736
+ // Props shared by Checkbox and IndeterminateCheckbox
14737
+ var checkboxProps = {
14738
+ disabled: isDisabled,
14739
+ hideFocus: true,
14740
+ id: itemId + "-checkbox",
14741
+ inputStyle: {
14742
+ marginRight: theme.spaceScale.spacing03
14743
+ },
14744
+ labelStyle: {
14745
+ padding: 0
14746
+ },
14747
+ labelText: labelText,
14748
+ onChange: checkboxChangeHandler,
14749
+ tabIndex: -1,
14750
+ testId: itemId + "-checkbox"
14913
14751
  };
14914
- var updateStatusForItem = function updateStatusForItem(childrenItemIds, preselectedChildrenItems, itemId, itemIdChildren) {
14915
- var item = preselectedChildrenItems.find(function (child) {
14916
- return child.itemId === itemId;
14917
- });
14918
- var itemStatus = item != null && item.checkedStatus || areArraysEqual(preselectedChildrenItems, childrenItemIds) ? exports.IndeterminateCheckboxStatus.checked : exports.IndeterminateCheckboxStatus.indeterminate;
14919
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
14920
- setCheckedStatus(itemStatus);
14921
- updateParentCheckStatus(index, itemStatus);
14922
- if (!item) {
14923
- setSelectedItems(function (prev) {
14924
- return getUniqueSelectedItemsArray([{
14925
- itemId: itemId,
14926
- checkedStatus: itemStatus
14927
- }], preselectedChildrenItems, prev);
14928
- });
14929
- setSelectedItemsChanged(true);
14930
- return;
14931
- }
14932
- var thisItem = itemIdChildren.find(function (child) {
14933
- return child.itemId === itemId;
14752
+ var onExpandedClicked = function onExpandedClicked(event) {
14753
+ setExpanded(function (state) {
14754
+ return !state;
14934
14755
  });
14935
- if ((thisItem == null ? void 0 : thisItem.children.length) > 0 && (item == null ? void 0 : item.checkedStatus) === exports.IndeterminateCheckboxStatus.checked) {
14936
- var itemNode = findChildByItemId(treeItemChildren, thisItem == null ? void 0 : thisItem.itemId);
14937
- var newChildren = getChildrenItemIds(itemNode == null ? void 0 : itemNode.props.children, checkedStatus);
14938
- setSelectedItems(function (prev) {
14939
- return getUniqueSelectedItemsArray([{
14940
- itemId: itemId,
14941
- checkedStatus: itemStatus
14942
- }], newChildren, prev);
14943
- });
14944
- setSelectedItemsChanged(true);
14945
- }
14946
- };
14947
- var updateInitialExpanded = function updateInitialExpanded() {
14948
- if ((initialExpandedItems == null ? void 0 : initialExpandedItems.length) !== 0 && !isDisabled) {
14949
- var childrenItemIds = getChildrenItemIdsFlat(treeItemChildren);
14950
- var allExpanded = [].concat(initialExpandedItems, childrenItemIds);
14951
- if (allExpanded != null && allExpanded.some(function (item) {
14952
- return item === itemId;
14953
- })) {
14954
- setExpanded(true);
14955
- } else {
14956
- setExpanded(false);
14957
- }
14958
- } else {
14959
- setExpanded(false);
14960
- }
14756
+ event.preventDefault();
14757
+ onExpandedChange && typeof onExpandedChange === 'function' && onExpandedChange(event);
14961
14758
  };
14962
- var updateInitialSelected = function updateInitialSelected() {
14963
- if (selectable === exports.TreeViewSelectable.single && selectedItems) {
14964
- var _selectedItems$;
14965
- var firstItemId = selectedItems == null || (_selectedItems$ = selectedItems[0]) == null ? void 0 : _selectedItems$.itemId;
14966
- if (firstItemId && !isDisabled) {
14967
- setSelectedItems(function (prev) {
14968
- if (!arrayIncludesId(prev, firstItemId)) {
14969
- return [{
14970
- itemId: firstItemId,
14971
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
14972
- }];
14973
- }
14974
- });
14975
- setSelectedItemsChanged(true);
14976
- }
14977
- } else if (selectable === exports.TreeViewSelectable.multi && selectedItems) {
14978
- var item = selectedItems.find(function (obj) {
14979
- return obj.itemId === itemId;
14980
- });
14981
- var status = item == null ? void 0 : item.checkedStatus;
14982
- var childrenItemIds = getChildrenItemIds(treeItemChildren, status || exports.IndeterminateCheckboxStatus.checked);
14983
- // Items from selectedItems that are children
14984
- var preselectedChildrenItems = findCommonItems(childrenItemIds, selectedItems);
14985
- if (!isDisabled && (arrayIncludesId(selectedItems, itemId) || childrenItemIds != null && childrenItemIds.includes(itemId))) {
14986
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
14987
- setCheckedStatus(status);
14988
- updateParentCheckStatus(index, status);
14989
- if (childrenItemIds.length > 0 && status === exports.IndeterminateCheckboxStatus.checked) {
14990
- var newChildrenCheckedStatus = getChildrenCheckedStatus(childrenItemIds, checkChildren && status);
14991
- setChildrenCheckedStatus(newChildrenCheckedStatus);
14992
- }
14993
- setSelectedItems(function (prev) {
14994
- var allItems = getUniqueSelectedItemsArray(childrenItemIds, selectedItems, prev);
14995
- return allItems;
14996
- });
14997
- updateSelectedItemsChanged();
14998
- } else if (!isDisabled && preselectedChildrenItems.length > 0 && checkParents) {
14999
- // Case for selectedItems that are inside a collapsed item
15000
- var itemIdChildren = getChildrenItemIdsInTree(treeItemChildren);
15001
- for (var _iterator = _createForOfIteratorHelperLoose(preselectedChildrenItems), _step; !(_step = _iterator()).done;) {
15002
- var _itemIdNode$props;
15003
- var i = _step.value;
15004
- var itemIdNode = findChildByItemId(treeItemChildren, i.itemId);
15005
- var childrenOfItemId = getChildrenItemIds(itemIdNode == null || (_itemIdNode$props = itemIdNode.props) == null ? void 0 : _itemIdNode$props.children, exports.IndeterminateCheckboxStatus.checked);
15006
- var parentIds = getAllParentIds(itemIdChildren, i.itemId);
15007
- for (var _iterator2 = _createForOfIteratorHelperLoose(parentIds), _step2; !(_step2 = _iterator2()).done;) {
15008
- var p = _step2.value;
15009
- updateStatusForItem(childrenOfItemId, preselectedChildrenItems, p, itemIdChildren);
15010
- }
15011
- }
15012
- updateStatusForItem(childrenItemIds, preselectedChildrenItems, itemId, itemIdChildren);
14759
+ return React.createElement(TreeItemContext.Provider, {
14760
+ value: contextValue
14761
+ }, React.createElement(StyledTreeItem, Object.assign({}, rest, {
14762
+ "aria-expanded": hasOwnTreeItems ? expanded : null,
14763
+ "aria-selected": selectedItem,
14764
+ "aria-checked": ariaCheckedValue,
14765
+ "data-testid": testId,
14766
+ depth: itemDepth,
14767
+ hasOwnTreeItems: true,
14768
+ id: itemId,
14769
+ isDisabled: isDisabled,
14770
+ isInverse: isInverse,
14771
+ nodeType: nodeType,
14772
+ role: "treeitem",
14773
+ selectableType: selectable,
14774
+ selected: selectedItem,
14775
+ theme: theme
14776
+ }), React.createElement(StyledItemWrapper, {
14777
+ "data-testid": (testId || itemId) + "-itemwrapper",
14778
+ depth: itemDepth,
14779
+ id: itemId + "-itemwrapper",
14780
+ isDisabled: isDisabled,
14781
+ isInverse: isInverse,
14782
+ nodeType: nodeType,
14783
+ onClick: function onClick(event) {
14784
+ if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
14785
+ onExpandedClicked(event);
15013
14786
  }
15014
- }
15015
- setPreselectedItemsNeedUpdate(false);
15016
- };
15017
- React.useEffect(function () {
15018
- if (statusUpdatedBy && updateParentCheckStatus && !topLevel) {
15019
- updateParentCheckStatus(index, checkedStatus);
15020
- }
15021
- setStatusUpdatedBy(undefined);
15022
- }, [checkedStatus]);
15023
- React.useEffect(function () {
15024
- if (parentCheckedStatus && checkChildren && checkedStatus !== parentCheckedStatus && parentCheckedStatus !== exports.IndeterminateCheckboxStatus.indeterminate && !topLevel && !isDisabled) {
15025
- setStatusUpdatedBy("parent" /* parent */);
15026
- setCheckedStatus(parentCheckedStatus);
15027
- if (hasOwnTreeItems) {
15028
- if (getAllChildrenEnabled(treeItemChildren)) {
15029
- setChildrenCheckedStatus(Array(numberOfTreeItemChildren).fill(parentCheckedStatus));
15030
- } else {
15031
- var childrenIds = getChildrenItemIds(treeItemChildren);
15032
- var newChildrenCheckedStatus = getChildrenCheckedStatus(childrenIds, parentCheckedStatus);
15033
- setChildrenCheckedStatus(newChildrenCheckedStatus);
15034
- }
14787
+ },
14788
+ onKeyDown: function onKeyDown(e) {
14789
+ handleKeyDown(e);
14790
+ },
14791
+ ref: ref,
14792
+ selectable: selectable,
14793
+ style: style,
14794
+ tabIndex: itemToFocus === itemId ? 0 : -1,
14795
+ theme: theme
14796
+ }, hasOwnTreeItems && React.createElement(StyledExpandWrapper, {
14797
+ "aria-hidden": Boolean(!expanded),
14798
+ "data-testid": (testId || itemId) + "-expand",
14799
+ isDisabled: isDisabled,
14800
+ isInverse: isInverse,
14801
+ onClick: function onClick(event) {
14802
+ if (!isDisabled && selectable !== exports.TreeViewSelectable.off) {
14803
+ onExpandedClicked(event);
15035
14804
  }
15036
- }
15037
- }, [parentCheckedStatus]);
15038
- React.useEffect(function () {
15039
- if (statusUpdatedBy && (childrenCheckedStatus == null ? void 0 : childrenCheckedStatus[0]) !== undefined) {
15040
- var statusFromChildren = childrenCheckedStatus.every(function (status) {
15041
- return status === childrenCheckedStatus[0];
15042
- }) ? childrenCheckedStatus[0] : exports.IndeterminateCheckboxStatus.indeterminate;
15043
- var updateItemStatus = getUpdatedSelectedItems(selectedItems, itemId, statusFromChildren);
15044
- if (checkedStatus !== statusFromChildren && statusUpdatedBy !== "parent" /* parent */) {
15045
- setStatusUpdatedBy("children" /* children */);
15046
- setCheckedStatus(statusFromChildren);
15047
- if (statusFromChildren === exports.IndeterminateCheckboxStatus.checked || statusFromChildren === exports.IndeterminateCheckboxStatus.indeterminate) {
15048
- if (itemId && !arrayIncludesId(selectedItems, itemId)) {
15049
- setSelectedItems([].concat(selectedItems, [{
15050
- itemId: itemId,
15051
- checkedStatus: statusFromChildren
15052
- }]));
15053
- updateSelectedItemsChanged();
15054
- } else {
15055
- setSelectedItems(updateItemStatus);
15056
- updateSelectedItemsChanged();
15057
- }
15058
- } else if (statusFromChildren === exports.IndeterminateCheckboxStatus.unchecked) {
15059
- setSelectedItems(selectedItems.filter(function (obj) {
15060
- return obj.itemId !== itemId;
15061
- }));
15062
- updateSelectedItemsChanged();
15063
- }
15064
- } else if (checkedStatus === statusFromChildren && statusUpdatedBy !== "parent" /* parent */ && statusFromChildren === exports.IndeterminateCheckboxStatus.indeterminate && expanded) {
15065
- if (!arrayIncludesId(selectedItems, itemId)) {
15066
- setSelectedItems([].concat(selectedItems, [{
15067
- itemId: itemId,
15068
- checkedStatus: statusFromChildren
15069
- }]));
15070
- updateSelectedItemsChanged();
15071
- } else {
15072
- var itemStatus = getCheckedStatus(itemId, selectedItems);
15073
- if (itemStatus === parentCheckedStatus) {
15074
- // Skip updating items if instructed to do so
15075
- if (isSkipSelectedItemsUpdate) return;
15076
- if (!selectedItemsChanged) {
15077
- if (!topLevel && updateParentCheckStatus) {
15078
- setSelectedItemsChanged(true);
15079
- } else {
15080
- updateSelectedItemsChanged();
15081
- }
15082
- }
15083
- } else {
15084
- updateSelectedItemsChanged();
15085
- }
15086
- }
15087
- } else {
15088
- setSelectedItems(updateItemStatus);
15089
- if (!expanded) {
15090
- updateSelectedItemsChanged();
15091
- }
14805
+ },
14806
+ theme: theme
14807
+ }, expanded ? React.createElement(reactMagmaIcons.ExpandMoreIcon, {
14808
+ "aria-hidden": true
14809
+ }) : React.createElement(reactMagmaIcons.ChevronRightIcon, {
14810
+ "aria-hidden": true
14811
+ })), selectable === exports.TreeViewSelectable.multi ? React.createElement(StyledCheckboxWrapper, {
14812
+ theme: theme
14813
+ }, hasOwnTreeItems ? React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, {
14814
+ status: checkedStatus
14815
+ })) : React.createElement(Checkbox, Object.assign({}, checkboxProps, {
14816
+ checked: checkedStatusToBoolean(checkedStatus)
14817
+ }))) : React.createElement(React.Fragment, null, labelText)), React.Children.map(children, function (child, index) {
14818
+ var component = child.type === TreeItem ? React.createElement(Transition, {
14819
+ isOpen: expanded,
14820
+ collapse: true,
14821
+ unmountOnExit: true
14822
+ }, React.createElement("ul", {
14823
+ role: "group"
14824
+ }, React.cloneElement(child, {
14825
+ index: index,
14826
+ key: index,
14827
+ itemDepth: itemDepth,
14828
+ parentDepth: parentDepth
14829
+ }))) : child;
14830
+ // hide the disabled item + the children
14831
+ if (isDisabled) return React.createElement(React.Fragment, null);
14832
+ return component;
14833
+ })));
14834
+ });
14835
+
14836
+ (function (TreeNodeType) {
14837
+ TreeNodeType["branch"] = "branch";
14838
+ TreeNodeType["leaf"] = "leaf";
14839
+ })(exports.TreeNodeType || (exports.TreeNodeType = {}));
14840
+ /**
14841
+ * Leaf node - 1st level has 40px of left padding.
14842
+ * Each level after that adds 56px of left padding.
14843
+ * 40, 64, 88, 112, 136, etc.
14844
+ *
14845
+ * Branch node - 1st level has 8px of left padding.
14846
+ * Each level after that adds 24px of left padding.
14847
+ * 8, 32, 56, 80, 104, etc.
14848
+ *
14849
+ * The label element (the div inside the li) gets additional spacing.
14850
+ * In order to highlight the entire line, we need to negate the value for margin.
14851
+ */
14852
+ function calculateOffset(type, depth, labelElem, negative) {
14853
+ if (depth === void 0) {
14854
+ depth = 0;
14855
+ }
14856
+ if (labelElem === void 0) {
14857
+ labelElem = false;
14858
+ }
14859
+ if (negative === void 0) {
14860
+ negative = false;
14861
+ }
14862
+ var padding = 0;
14863
+ if (type === exports.TreeNodeType.leaf) {
14864
+ if (labelElem) {
14865
+ padding = depth * 8 + 40;
14866
+ if (depth !== 0) {
14867
+ padding += depth * 16;
15092
14868
  }
14869
+ } else if (depth === 0) {
14870
+ padding = 40;
14871
+ } else {
14872
+ padding = 56;
15093
14873
  }
15094
- }, [childrenCheckedStatus]);
15095
- var checkboxChangeHandler = function checkboxChangeHandler(event) {
15096
- var status = event.target.checked ? exports.IndeterminateCheckboxStatus.checked : exports.IndeterminateCheckboxStatus.unchecked;
15097
- if (checkedStatus !== status) {
15098
- setCheckedStatus(status);
15099
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
15100
- updateParentCheckStatus(index, status);
15101
- if (hasOwnTreeItems && checkChildren) {
15102
- if (getAllChildrenEnabled(treeItemChildren)) {
15103
- setChildrenCheckedStatus(Array(numberOfTreeItemChildren).fill(status));
15104
- } else {
15105
- var childrenIds = getChildrenItemIds(treeItemChildren);
15106
- var newChildrenCheckedStatus = getChildrenCheckedStatus(childrenIds, status);
15107
- setChildrenCheckedStatus(newChildrenCheckedStatus);
15108
- }
14874
+ } else if (type === exports.TreeNodeType.branch) {
14875
+ if (labelElem) {
14876
+ padding = depth * 8 + 8;
14877
+ if (depth !== 0) {
14878
+ padding += depth * 16;
15109
14879
  }
14880
+ } else if (depth === 0) {
14881
+ padding = 8;
14882
+ } else {
14883
+ padding = 24;
15110
14884
  }
15111
- handleClick(event, itemId);
15112
- };
15113
- var singleSelectChangeHandler = function singleSelectChangeHandler(event, itemId) {
15114
- if (!arrayIncludesId(selectedItems, itemId)) {
15115
- setSelectedItems([{
15116
- itemId: itemId,
15117
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15118
- }]);
15119
- setSelectedItemsChanged(true);
14885
+ }
14886
+ return "" + (negative ? '-' : '') + padding + "px";
14887
+ }
14888
+ function getTreeItemLabelColor(isInverse, disabled, theme) {
14889
+ if (disabled) {
14890
+ if (isInverse) {
14891
+ return polished.transparentize(0.6, theme.colors.neutral100);
15120
14892
  }
15121
- };
15122
- var multiSelectChangeHandler = function multiSelectChangeHandler(event) {
15123
- if (!checkParents) {
15124
- setSelectedItemsChanged(true);
15125
- }
15126
- if (hasOwnTreeItems && checkChildren) {
15127
- var childrenIds = getChildrenItemIds(treeItemChildren, exports.IndeterminateCheckboxStatus.checked);
15128
- if (event.target.checked) {
15129
- updateParentCheckStatus(index, exports.IndeterminateCheckboxStatus.checked);
15130
- if (!arrayIncludesId(selectedItems, itemId)) {
15131
- setSelectedItems([].concat(selectedItems, childrenIds, [{
15132
- itemId: itemId,
15133
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15134
- }]));
15135
- updateSelectedItemsChanged();
15136
- } else {
15137
- var missingChildren = getMissingChildrenIds(selectedItems, childrenIds);
15138
- setSelectedItems([].concat(selectedItems, missingChildren));
15139
- updateSelectedItemsChanged();
15140
- }
15141
- } else if (!event.target.checked) {
15142
- var newSelectedItems = filterSelectedItems(selectedItems, childrenIds, {
15143
- itemId: itemId,
15144
- checkedStatus: checkedStatus
14893
+ return polished.transparentize(0.6, theme.colors.neutral500);
14894
+ }
14895
+ if (isInverse) {
14896
+ return theme.colors.neutral100;
14897
+ }
14898
+ return theme.colors.neutral700;
14899
+ }
14900
+ function getTreeItemWrapperCursor(disabled, selectable, nodeType) {
14901
+ if (disabled) {
14902
+ return 'not-allowed';
14903
+ }
14904
+ if (nodeType === exports.TreeNodeType.branch && selectable === exports.TreeViewSelectable.off || selectable === exports.TreeViewSelectable.single) {
14905
+ return 'pointer';
14906
+ }
14907
+ return 'default';
14908
+ }
14909
+ // Return an array of objects of all the enabled children ids recursively
14910
+ function getChildrenItemIds(children, status) {
14911
+ if (status === void 0) {
14912
+ status = '';
14913
+ }
14914
+ var itemIds = [];
14915
+ React__default.Children.forEach(children, function (child) {
14916
+ var _child$props;
14917
+ if (!((_child$props = child.props) != null && _child$props.isDisabled)) {
14918
+ var _child$props2, _child$props3;
14919
+ var childStatus = status === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.checked : exports.IndeterminateCheckboxStatus.unchecked;
14920
+ if ((_child$props2 = child.props) != null && _child$props2.itemId && childStatus !== exports.IndeterminateCheckboxStatus.unchecked) {
14921
+ itemIds.push({
14922
+ itemId: child.props.itemId,
14923
+ checkedStatus: childStatus
15145
14924
  });
15146
- setSelectedItems(newSelectedItems);
15147
- updateSelectedItemsChanged();
15148
14925
  }
15149
- } else {
15150
- if (event.target.checked) {
15151
- if (!arrayIncludesId(selectedItems, itemId)) {
15152
- setSelectedItems([].concat(selectedItems, [{
15153
- itemId: itemId,
15154
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15155
- }]));
15156
- updateSelectedItemsChanged();
15157
- }
15158
- } else if (!event.target.checked) {
15159
- setSelectedItems(selectedItems.filter(function (obj) {
15160
- return obj.itemId !== itemId;
15161
- }));
15162
- updateSelectedItemsChanged();
14926
+ if ((_child$props3 = child.props) != null && _child$props3.children) {
14927
+ var nestedItemIds = getChildrenItemIds(child.props.children, childStatus);
14928
+ itemIds = itemIds.concat(nestedItemIds);
15163
14929
  }
15164
14930
  }
15165
- };
15166
- var handleClick = function handleClick(event, itemId) {
15167
- if (selectable !== exports.TreeViewSelectable.off) {
15168
- if (selectable === exports.TreeViewSelectable.single) {
15169
- singleSelectChangeHandler(event, itemId);
15170
- } else if (selectable === exports.TreeViewSelectable.multi) {
15171
- multiSelectChangeHandler(event);
14931
+ });
14932
+ return itemIds;
14933
+ }
14934
+ // Return an array of strings of all enabled children ids recursively
14935
+ function getChildrenItemIdsFlat(children) {
14936
+ var itemIds = [];
14937
+ React__default.Children.forEach(children, function (child) {
14938
+ var _child$props4;
14939
+ if (!((_child$props4 = child.props) != null && _child$props4.isDisabled)) {
14940
+ var _child$props5, _child$props6;
14941
+ if ((_child$props5 = child.props) != null && _child$props5.itemId) {
14942
+ itemIds.push(child.props.itemId);
15172
14943
  }
15173
- onClick && typeof onClick === 'function' && onClick();
14944
+ if ((_child$props6 = child.props) != null && _child$props6.children) {
14945
+ var nestedItemIds = getChildrenItemIdsFlat(child.props.children);
14946
+ itemIds = itemIds.concat(nestedItemIds);
14947
+ }
14948
+ }
14949
+ });
14950
+ return itemIds;
14951
+ }
14952
+ // Return an array of objects where all children are items are nested in the parents
14953
+ function getChildrenItemIdsInTree(children) {
14954
+ var itemIds = [];
14955
+ React__default.Children.forEach(children, function (child) {
14956
+ var _child$props7, _child$props8;
14957
+ if ((_child$props7 = child.props) != null && _child$props7.itemId && !((_child$props8 = child.props) != null && _child$props8.isDisabled)) {
14958
+ var _child$props9, _child$props10;
14959
+ itemIds.push({
14960
+ itemId: (_child$props9 = child.props) == null ? void 0 : _child$props9.itemId,
14961
+ children: getChildrenItemIdsInTree((_child$props10 = child.props) == null ? void 0 : _child$props10.children)
14962
+ });
14963
+ }
14964
+ });
14965
+ return itemIds;
14966
+ }
14967
+ // Return a treeItemRefArray object with no null children
14968
+ function filterNullEntries(obj) {
14969
+ if (Array.isArray(obj.current)) {
14970
+ var filteredArray = obj.current.filter(function (item) {
14971
+ return (item == null ? void 0 : item.current) !== null;
14972
+ });
14973
+ if (filteredArray.length > 0) {
14974
+ return {
14975
+ current: filteredArray
14976
+ };
15174
14977
  }
15175
- };
15176
- function getFocusIndex(filteredArrayCurrent) {
15177
- return itemId && (filteredArrayCurrent == null ? void 0 : filteredArrayCurrent.findIndex(function (_ref) {
15178
- var item = _ref.current;
15179
- if (!item || !ownRef.current) return false;
15180
- return item === ownRef.current;
15181
- }));
15182
14978
  }
15183
- var focusIndex = getFocusIndex(treeItemRefArray == null ? void 0 : treeItemRefArray.current);
15184
- React.useEffect(function () {
15185
- treeItemRefArray == null || treeItemRefArray.current.map(function (itemRef) {
15186
- if (!itemRef.current) {
15187
- treeItemRefArray.current = treeItemRefArray.current.filter(function (item) {
15188
- return itemRef.current !== item.current;
15189
- });
15190
- }
14979
+ return {};
14980
+ }
14981
+ var getTreeViewData = function getTreeViewData(children, parentId) {
14982
+ if (parentId === void 0) {
14983
+ parentId = null;
14984
+ }
14985
+ var treeItemChildren = React__default.Children.toArray(children).filter(function (child) {
14986
+ return child.type === TreeItem;
14987
+ });
14988
+ return treeItemChildren.map(function (_ref) {
14989
+ var props = _ref.props;
14990
+ return [{
14991
+ itemId: props.itemId,
14992
+ parentId: parentId,
14993
+ icon: props.icon,
14994
+ hasOwnTreeItems: Boolean(props.children)
14995
+ }].concat(props.children ? getTreeViewData(props.children, props.itemId) : []);
14996
+ }).flat();
14997
+ };
14998
+ var getChildrenIds = function getChildrenIds(_ref2) {
14999
+ var items = _ref2.items,
15000
+ itemId = _ref2.itemId;
15001
+ return items.reduce(function (result, item) {
15002
+ if (item.parentId !== itemId) {
15003
+ return result;
15004
+ }
15005
+ if (item.hasOwnTreeItems) {
15006
+ return [].concat(result, getChildrenIds({
15007
+ items: items,
15008
+ itemId: item.itemId
15009
+ }));
15010
+ }
15011
+ return [].concat(result, [item.itemId]);
15012
+ }, [itemId]);
15013
+ };
15014
+ var getChildrenUniqueStatuses = function getChildrenUniqueStatuses(_ref3) {
15015
+ var items = _ref3.items,
15016
+ itemId = _ref3.itemId;
15017
+ var childrenAndItemIds = getChildrenIds({
15018
+ items: items,
15019
+ itemId: itemId
15020
+ });
15021
+ var leaves = items.filter(function (item) {
15022
+ return !item.hasOwnTreeItems && childrenAndItemIds.includes(item.itemId);
15023
+ });
15024
+ var uniqueStatuses = Array.from(new Set(leaves.map(function (item) {
15025
+ var _item$checkedStatus;
15026
+ return (_item$checkedStatus = item.checkedStatus) != null ? _item$checkedStatus : exports.IndeterminateCheckboxStatus.unchecked;
15027
+ })));
15028
+ return uniqueStatuses.filter(function (checkedStatus) {
15029
+ return checkedStatus && checkedStatus !== exports.IndeterminateCheckboxStatus.indeterminate;
15030
+ });
15031
+ };
15032
+ var processInitialParentStatuses = function processInitialParentStatuses(_ref4) {
15033
+ var items = _ref4.items;
15034
+ var itemsWithSelectedChildren = items.reduce(function (result, item) {
15035
+ if (!item.hasOwnTreeItems || item.checkedStatus !== exports.IndeterminateCheckboxStatus.checked) {
15036
+ return result;
15037
+ }
15038
+ return processChildrenSelection({
15039
+ items: result,
15040
+ itemId: item.itemId,
15041
+ checkedStatus: exports.IndeterminateCheckboxStatus.checked
15191
15042
  });
15192
- }, [treeItemRefArray]);
15193
- var focusFirst = function focusFirst() {
15194
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15195
- var curr = filteredRefArray['current'];
15196
- curr == null || curr[0].current.focus();
15197
- };
15198
- var focusNext = function focusNext() {
15199
- var _curr$newIndex;
15200
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15201
- var curr = filteredRefArray['current'];
15202
- var arrLength = curr.length;
15203
- focusIndex = getFocusIndex(curr);
15204
- var newIndex = focusIndex + 1;
15205
- var next = curr == null || (_curr$newIndex = curr[newIndex]) == null ? void 0 : _curr$newIndex.current;
15206
- while (!next && newIndex < arrLength) {
15207
- var _curr$newIndex2;
15208
- newIndex++;
15209
- next = curr == null || (_curr$newIndex2 = curr[newIndex]) == null ? void 0 : _curr$newIndex2.current;
15043
+ }, items);
15044
+ return itemsWithSelectedChildren.map(function (item) {
15045
+ if (!item.hasOwnTreeItems) {
15046
+ return item;
15210
15047
  }
15211
- if (next) {
15212
- next.focus();
15213
- } else {
15214
- var _curr;
15215
- var nextNext = curr == null || (_curr = curr[focusIndex + 2]) == null ? void 0 : _curr.current;
15216
- if (nextNext) {
15217
- nextNext.focus();
15218
- } else {
15219
- focusFirst();
15220
- }
15048
+ var childrenUniqueStatuses = getChildrenUniqueStatuses({
15049
+ items: itemsWithSelectedChildren,
15050
+ itemId: item.itemId
15051
+ });
15052
+ var parentStatus = childrenUniqueStatuses.length > 1 ? exports.IndeterminateCheckboxStatus.indeterminate : childrenUniqueStatuses[0];
15053
+ return parentStatus ? _extends({}, item, {
15054
+ checkedStatus: parentStatus
15055
+ }) : item;
15056
+ });
15057
+ };
15058
+ var getInitialItems = function getInitialItems(_ref5) {
15059
+ var children = _ref5.children,
15060
+ rawPreselectedItems = _ref5.preselectedItems,
15061
+ checkParents = _ref5.checkParents,
15062
+ selectable = _ref5.selectable;
15063
+ var treeViewData = getTreeViewData(children);
15064
+ var preselectedItems = rawPreselectedItems != null && rawPreselectedItems.length && selectable === exports.TreeViewSelectable.single ? [rawPreselectedItems[0]] : rawPreselectedItems;
15065
+ var enhancedWithPreselectedItems = preselectedItems ? treeViewData.map(function (treeViewDataItem) {
15066
+ var preselectedItem = preselectedItems.find(function (_ref6) {
15067
+ var itemId = _ref6.itemId;
15068
+ return treeViewDataItem.itemId === itemId;
15069
+ });
15070
+ return preselectedItem ? _extends({}, treeViewDataItem, {
15071
+ checkedStatus: preselectedItem.checkedStatus
15072
+ }) : treeViewDataItem;
15073
+ }) : treeViewData;
15074
+ return selectable === exports.TreeViewSelectable.multi && checkParents && preselectedItems ? processInitialParentStatuses({
15075
+ items: enhancedWithPreselectedItems
15076
+ }) : enhancedWithPreselectedItems;
15077
+ };
15078
+ var selectSingle = function selectSingle(_ref7) {
15079
+ var items = _ref7.items,
15080
+ itemId = _ref7.itemId,
15081
+ checkedStatus = _ref7.checkedStatus;
15082
+ return items.map(function (item) {
15083
+ return _extends({}, item, {
15084
+ checkedStatus: item.itemId === itemId ? checkedStatus : exports.IndeterminateCheckboxStatus.unchecked
15085
+ });
15086
+ });
15087
+ };
15088
+ var processChildrenSelection = function processChildrenSelection(_ref8) {
15089
+ var items = _ref8.items,
15090
+ itemId = _ref8.itemId,
15091
+ checkedStatus = _ref8.checkedStatus;
15092
+ var childrenAndItemIds = getChildrenIds({
15093
+ items: items,
15094
+ itemId: itemId
15095
+ });
15096
+ return items.map(function (item) {
15097
+ return childrenAndItemIds.includes(item.itemId) ? _extends({}, item, {
15098
+ checkedStatus: checkedStatus
15099
+ }) : item;
15100
+ });
15101
+ };
15102
+ var processParentsSelection = function processParentsSelection(_ref9) {
15103
+ var items = _ref9.items,
15104
+ itemId = _ref9.itemId,
15105
+ checkedStatus = _ref9.checkedStatus;
15106
+ var item = items.find(function (item) {
15107
+ return item.itemId === itemId;
15108
+ });
15109
+ var parentId = item.parentId;
15110
+ if (parentId === null) {
15111
+ return items;
15112
+ }
15113
+ var siblings = items.filter(function (item) {
15114
+ return item.parentId === parentId;
15115
+ });
15116
+ var isAllSiblingsHasTheSameStatus = siblings.every(function (item) {
15117
+ return (item.checkedStatus || exports.IndeterminateCheckboxStatus.unchecked) === checkedStatus;
15118
+ });
15119
+ var parentStatus = isAllSiblingsHasTheSameStatus ? checkedStatus : exports.IndeterminateCheckboxStatus.indeterminate;
15120
+ var parent = items.find(function (item) {
15121
+ return item.itemId === parentId;
15122
+ });
15123
+ var nextItems = items.map(function (item) {
15124
+ return item.itemId === parent.itemId ? _extends({}, item, {
15125
+ checkedStatus: parentStatus
15126
+ }) : item;
15127
+ });
15128
+ return processParentsSelection({
15129
+ items: nextItems,
15130
+ itemId: parent.itemId,
15131
+ checkedStatus: parentStatus
15132
+ });
15133
+ };
15134
+ var selectMulti = function selectMulti(_ref10) {
15135
+ var items = _ref10.items,
15136
+ itemId = _ref10.itemId,
15137
+ checkedStatus = _ref10.checkedStatus,
15138
+ checkChildren = _ref10.checkChildren,
15139
+ checkParents = _ref10.checkParents;
15140
+ var itemsWithProcessedItemSelection = items.map(function (item) {
15141
+ return item.itemId === itemId ? _extends({}, item, {
15142
+ checkedStatus: checkedStatus
15143
+ }) : item;
15144
+ });
15145
+ var itemsWithProcessedChildrenSelection = checkChildren ? processChildrenSelection({
15146
+ items: itemsWithProcessedItemSelection,
15147
+ itemId: itemId,
15148
+ checkedStatus: checkedStatus
15149
+ }) : itemsWithProcessedItemSelection;
15150
+ return checkParents ? processParentsSelection({
15151
+ items: itemsWithProcessedChildrenSelection,
15152
+ itemId: itemId,
15153
+ checkedStatus: checkedStatus
15154
+ }) : itemsWithProcessedChildrenSelection;
15155
+ };
15156
+
15157
+ var _excluded$1C = ["checkedStatus"];
15158
+ function useTreeView(props) {
15159
+ var _props$selectable = props.selectable,
15160
+ selectable = _props$selectable === void 0 ? exports.TreeViewSelectable.single : _props$selectable,
15161
+ onSelectedItemChange = props.onSelectedItemChange,
15162
+ onExpandedChange = props.onExpandedChange,
15163
+ initialExpandedItems = props.initialExpandedItems,
15164
+ preselectedItems = props.preselectedItems,
15165
+ _props$checkChildren = props.checkChildren,
15166
+ checkChildren = _props$checkChildren === void 0 ? selectable !== exports.TreeViewSelectable.single : _props$checkChildren,
15167
+ _props$checkParents = props.checkParents,
15168
+ checkParents = _props$checkParents === void 0 ? selectable !== exports.TreeViewSelectable.single : _props$checkParents,
15169
+ children = props.children,
15170
+ apiRef = props.apiRef;
15171
+ var hasPreselectedItems = Boolean(preselectedItems);
15172
+ var _React$useState = React.useState(function () {
15173
+ return getInitialItems({
15174
+ children: children,
15175
+ preselectedItems: preselectedItems,
15176
+ checkParents: checkParents,
15177
+ selectable: selectable
15178
+ });
15179
+ }),
15180
+ items = _React$useState[0],
15181
+ setItems = _React$useState[1];
15182
+ var _React$useState2 = React.useState(function () {
15183
+ var initialItems = getInitialItems({
15184
+ children: children,
15185
+ preselectedItems: preselectedItems,
15186
+ checkParents: checkParents,
15187
+ selectable: selectable
15188
+ });
15189
+ return initialItems.some(function (item) {
15190
+ return item.icon;
15191
+ });
15192
+ }),
15193
+ hasIcons = _React$useState2[0];
15194
+ var selectedItems = React.useMemo(function () {
15195
+ return items.filter(function (item) {
15196
+ return item.checkedStatus === exports.IndeterminateCheckboxStatus.checked;
15197
+ });
15198
+ }, [items]);
15199
+ var itemToFocus = React.useMemo(function () {
15200
+ var firstItem = items[0];
15201
+ if (selectable === exports.TreeViewSelectable.off) {
15202
+ var firstExpandableItem = items.find(function (item) {
15203
+ return item.hasOwnTreeItems;
15204
+ });
15205
+ return firstExpandableItem ? firstExpandableItem.itemId : firstItem == null ? void 0 : firstItem.itemId;
15221
15206
  }
15222
- };
15223
- var focusPrev = function focusPrev() {
15224
- var _curr$newIndex3;
15225
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15226
- var curr = filteredRefArray['current'];
15227
- focusIndex = getFocusIndex(curr);
15228
- var newIndex = focusIndex - 1;
15229
- var itemToFocus = curr == null || (_curr$newIndex3 = curr[newIndex]) == null ? void 0 : _curr$newIndex3.current;
15230
- while (!itemToFocus && newIndex >= 0) {
15231
- var _curr$newIndex4;
15232
- newIndex--;
15233
- itemToFocus = curr == null || (_curr$newIndex4 = curr[newIndex]) == null ? void 0 : _curr$newIndex4.current;
15207
+ var firstNonUncheckedItem = items.find(function (item) {
15208
+ return item.checkedStatus && item.checkedStatus !== exports.IndeterminateCheckboxStatus.unchecked;
15209
+ });
15210
+ if (firstNonUncheckedItem) {
15211
+ return firstNonUncheckedItem.itemId;
15234
15212
  }
15235
- if (itemToFocus) {
15236
- itemToFocus.focus();
15213
+ return firstItem == null ? void 0 : firstItem.itemId;
15214
+ }, [items]);
15215
+ var initializationRef = React.useRef(true);
15216
+ React.useEffect(function () {
15217
+ if (initializationRef.current && !hasPreselectedItems) {
15218
+ initializationRef.current = false;
15219
+ return;
15237
15220
  }
15238
- };
15239
- var focusLast = function focusLast() {
15240
- var _filteredRefArray$cur;
15241
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15242
- var arrLength = filteredRefArray['current'].length;
15243
- (_filteredRefArray$cur = filteredRefArray['current']) == null || _filteredRefArray$cur[arrLength - 1].current.focus();
15244
- };
15245
- var focusSelf = function focusSelf() {
15246
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15247
- var curr = filteredRefArray['current'];
15248
- focusIndex = getFocusIndex(curr);
15249
- curr == null || curr[focusIndex].current.focus();
15250
- };
15251
- var expandFocusedNode = function expandFocusedNode() {
15252
- if (hasOwnTreeItems) {
15253
- if (expanded) {
15254
- focusNext();
15255
- } else {
15256
- setExpanded(true);
15257
- focusSelf();
15258
- }
15221
+ if (selectable === exports.TreeViewSelectable.off) {
15222
+ return;
15259
15223
  }
15260
- };
15261
- var collapseFocusedNode = function collapseFocusedNode() {
15262
- if (hasOwnTreeItems) {
15263
- if (expanded) {
15264
- setExpanded(false);
15265
- focusSelf();
15266
- } else {
15267
- focusPrev();
15268
- }
15269
- } else {
15270
- focusPrev();
15224
+ onSelectedItemChange && onSelectedItemChange(items.filter(function (_ref) {
15225
+ var checkedStatus = _ref.checkedStatus;
15226
+ return checkedStatus && checkedStatus !== exports.IndeterminateCheckboxStatus.unchecked;
15227
+ }).map(function (_ref2) {
15228
+ var itemId = _ref2.itemId,
15229
+ checkedStatus = _ref2.checkedStatus;
15230
+ return {
15231
+ itemId: itemId,
15232
+ checkedStatus: checkedStatus
15233
+ };
15234
+ }));
15235
+ }, [items, selectable, hasPreselectedItems]);
15236
+ var selectItem = React.useCallback(function (_ref3) {
15237
+ var itemId = _ref3.itemId,
15238
+ checkedStatus = _ref3.checkedStatus;
15239
+ if (selectable === exports.TreeViewSelectable.off) {
15240
+ return;
15271
15241
  }
15272
- };
15273
- var toggleMultiSelectItems = function toggleMultiSelectItems() {
15274
- var status = arrayIncludesId(selectedItems, itemId) ? exports.IndeterminateCheckboxStatus.unchecked : exports.IndeterminateCheckboxStatus.checked;
15275
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
15276
- setCheckedStatus(status);
15277
- updateParentCheckStatus(index, status);
15278
- if (hasOwnTreeItems && checkChildren) {
15279
- var childrenIds = getChildrenItemIds(treeItemChildren, exports.IndeterminateCheckboxStatus.checked);
15280
- if (!arrayIncludesId(selectedItems, itemId)) {
15281
- setSelectedItems([].concat(selectedItems, childrenIds, [{
15282
- itemId: itemId,
15283
- checkedStatus: status
15284
- }]));
15285
- } else {
15286
- var newSelectedItems = filterSelectedItems(selectedItems, childrenIds, {
15242
+ setItems(function (prevItems) {
15243
+ if (selectable === exports.TreeViewSelectable.single) {
15244
+ return selectSingle({
15245
+ items: prevItems,
15287
15246
  itemId: itemId,
15288
15247
  checkedStatus: checkedStatus
15289
15248
  });
15290
- setSelectedItems(newSelectedItems);
15291
15249
  }
15292
- } else {
15293
- if (!arrayIncludesId(selectedItems, itemId)) {
15294
- setSelectedItems([].concat(selectedItems, [{
15250
+ if (selectable === exports.TreeViewSelectable.multi) {
15251
+ return selectMulti({
15252
+ items: prevItems,
15295
15253
  itemId: itemId,
15296
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15297
- }]));
15298
- } else {
15299
- setSelectedItems(selectedItems.filter(function (obj) {
15300
- return obj.itemId !== itemId;
15301
- }));
15254
+ checkedStatus: checkedStatus,
15255
+ checkChildren: checkChildren,
15256
+ checkParents: checkParents
15257
+ });
15302
15258
  }
15303
- }
15304
- updateSelectedItemsChanged();
15305
- };
15306
- var handleKeyDown = function handleKeyDown(event) {
15307
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15308
- var curr = filteredRefArray['current'];
15309
- var arrLength = curr.length;
15310
- switch (event.key) {
15311
- case 'ArrowDown':
15312
- {
15313
- // Move to the next item, or wrap to first
15314
- focusIndex === arrLength - 1 ? focusFirst() : focusNext();
15315
- break;
15316
- }
15317
- case 'ArrowUp':
15318
- {
15319
- // Move to the previous item, or wrap to last
15320
- focusIndex === 0 ? focusLast() : focusPrev();
15321
- break;
15322
- }
15323
- case 'ArrowRight':
15324
- {
15325
- // Open parent nodes
15326
- expandFocusedNode();
15327
- break;
15328
- }
15329
- case 'ArrowLeft':
15330
- {
15331
- // Close open parent nodes
15332
- collapseFocusedNode();
15333
- break;
15334
- }
15335
- case 'Home':
15336
- {
15337
- // Moves focus to the first node in the tree without opening or closing a node.
15338
- focusFirst();
15339
- break;
15340
- }
15341
- case 'End':
15342
- {
15343
- // Moves focus to the last node in the tree that is focusable without opening a node.
15344
- focusLast();
15345
- break;
15346
- }
15347
- case 'Enter':
15348
- {
15349
- // Activates a node, i.e., performs its default action.
15350
- if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
15351
- setExpanded(!expanded);
15352
- } else if (selectable === exports.TreeViewSelectable.single) {
15353
- // In single-select it selects the focused node.
15354
- setSelectedItems([{
15355
- itemId: itemId,
15356
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15357
- }]);
15358
- setSelectedItemsChanged(true);
15359
- } else if (selectable === exports.TreeViewSelectable.multi) {
15360
- // In multi-select, it toggles the selection state of the focused node.
15361
- toggleMultiSelectItems();
15259
+ return prevItems;
15260
+ });
15261
+ }, [selectable, checkChildren, checkParents]);
15262
+ React.useEffect(function () {
15263
+ if (apiRef) {
15264
+ apiRef.current = {
15265
+ selectItem: selectItem,
15266
+ selectAll: function selectAll() {
15267
+ if ([exports.TreeViewSelectable.single, exports.TreeViewSelectable.single].includes(selectable)) {
15268
+ return;
15362
15269
  }
15363
- break;
15364
- }
15365
- case ' ':
15366
- {
15367
- // Toggles the selection state of the focused node.
15368
- if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
15369
- setExpanded(!expanded);
15370
- } else if (selectable === exports.TreeViewSelectable.single) {
15371
- if (hasOwnTreeItems) {
15372
- setExpanded(!expanded);
15373
- } else {
15374
- setSelectedItems([{
15375
- itemId: itemId,
15270
+ setItems(function (prevItems) {
15271
+ return prevItems.map(function (item) {
15272
+ return _extends({}, item, {
15376
15273
  checkedStatus: exports.IndeterminateCheckboxStatus.checked
15377
- }]);
15378
- setSelectedItemsChanged(true);
15379
- }
15380
- } else if (selectable === exports.TreeViewSelectable.multi) {
15381
- toggleMultiSelectItems();
15382
- }
15383
- break;
15274
+ });
15275
+ });
15276
+ });
15277
+ },
15278
+ clearAll: function clearAll() {
15279
+ setItems(function (prevItems) {
15280
+ return prevItems.map(function (_ref4) {
15281
+ var itemWithoutCheckedStatus = _objectWithoutPropertiesLoose(_ref4, _excluded$1C);
15282
+ return itemWithoutCheckedStatus;
15283
+ });
15284
+ });
15384
15285
  }
15385
- default:
15386
- return;
15286
+ };
15387
15287
  }
15388
- };
15288
+ }, [selectItem]);
15289
+ var _React$useState3 = React.useState(false),
15290
+ initialExpandedItemsNeedUpdate = _React$useState3[0],
15291
+ setInitialExpandedItemsNeedUpdate = _React$useState3[1];
15292
+ var _useDescendants = useDescendants(),
15293
+ treeItemRefArray = _useDescendants[0],
15294
+ registerTreeItem = _useDescendants[1];
15295
+ React.useEffect(function () {
15296
+ if (initialExpandedItems) {
15297
+ setInitialExpandedItemsNeedUpdate(true);
15298
+ }
15299
+ }, []);
15389
15300
  var contextValue = {
15390
- checkboxChangeHandler: checkboxChangeHandler,
15391
- checkedStatus: checkedStatus,
15392
- expanded: expanded,
15393
- hasOwnTreeItems: hasOwnTreeItems,
15394
- itemDepth: parentDepth === 0 && topLevel ? 0 : itemDepth + 1,
15395
- itemId: itemId || generatedId,
15396
- numberOfTreeItemChildren: numberOfTreeItemChildren,
15397
- parentCheckedStatus: parentCheckedStatus,
15398
- parentDepth: parentDepth,
15399
- ref: ref,
15301
+ hasIcons: hasIcons,
15302
+ itemToFocus: itemToFocus,
15303
+ onSelectedItemChange: onSelectedItemChange,
15304
+ onExpandedChange: onExpandedChange,
15305
+ selectable: selectable,
15400
15306
  selectedItems: selectedItems,
15401
- setExpanded: setExpanded,
15402
- updateCheckedStatusFromChild: updateCheckedStatusFromChild,
15403
- treeItemChildren: treeItemChildren
15307
+ initialExpandedItems: initialExpandedItems,
15308
+ treeItemRefArray: treeItemRefArray,
15309
+ registerTreeItem: registerTreeItem,
15310
+ initialExpandedItemsNeedUpdate: initialExpandedItemsNeedUpdate,
15311
+ setInitialExpandedItemsNeedUpdate: setInitialExpandedItemsNeedUpdate,
15312
+ checkChildren: checkChildren,
15313
+ checkParents: checkParents,
15314
+ items: items,
15315
+ selectItem: selectItem
15404
15316
  };
15405
15317
  return {
15406
- contextValue: contextValue,
15407
- handleClick: handleClick,
15408
- handleKeyDown: handleKeyDown
15318
+ contextValue: contextValue
15409
15319
  };
15410
15320
  }
15411
15321
 
15412
- var TreeItemContext = /*#__PURE__*/React.createContext({
15413
- expanded: false,
15414
- setExpanded: function setExpanded() {},
15415
- checkedStatus: exports.IndeterminateCheckboxStatus.unchecked,
15416
- checkboxChangeHandler: function checkboxChangeHandler() {},
15417
- hasOwnTreeItems: false,
15418
- updateCheckedStatusFromChild: function updateCheckedStatusFromChild() {},
15419
- numberOfTreeItemChildren: 0,
15420
- parentDepth: 0
15421
- });
15422
-
15423
- var _excluded$1B = ["children", "icon", "index", "isDisabled", "label", "labelStyle", "parentCheckedStatus", "style", "testId", "updateParentCheckStatus", "topLevel"];
15424
- var StyledTreeItem = /*#__PURE__*/_styled("li", {
15425
- target: "e1xiryew5",
15426
- label: "StyledTreeItem"
15427
- })("color:", function (props) {
15428
- return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
15429
- }, ";list-style-type:none;cursor:", function (props) {
15430
- return getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType);
15431
- }, ";position:relative;margin-bottom:0;padding-inline-start:", function (props) {
15432
- return calculateOffset(props.nodeType, props.depth);
15433
- }, ";>div:first-of-type{background:", function (props) {
15434
- return props.selected && props.isInverse ? polished.transparentize(0.7, props.theme.colors.neutral900) : props.selected && polished.transparentize(0.92, props.theme.colors.neutral900);
15435
- }, ";position:relative;padding-inline-start:", function (props) {
15436
- return calculateOffset(props.nodeType, props.depth, true);
15437
- }, ";margin-inline-start:", function (props) {
15438
- return calculateOffset(props.nodeType, props.depth, true, true);
15439
- }, ";padding-block-end:", function (props) {
15440
- return props.theme.spaceScale.spacing02;
15441
- }, ";padding-block-start:", function (props) {
15442
- return props.theme.spaceScale.spacing02;
15443
- }, ";padding-right:", function (props) {
15444
- return props.theme.spaceScale.spacing02;
15445
- }, ";", function (props) {
15446
- return props.selected && /*#__PURE__*/react.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;" + ( "/*# 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"]} */"));
15447
- }, " &:hover{background:", function (props) {
15448
- return !props.isDisabled ? props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral900) : polished.transparentize(0.95, props.theme.colors.neutral900) : undefined;
15449
- }, ";}}" + ( "/*# 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"]} */"));
15450
- var IconWrapper$8 = /*#__PURE__*/_styled("span", {
15451
- target: "e1xiryew4",
15452
- label: "IconWrapper"
15453
- })("color:", function (props) {
15454
- return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
15455
- }, ";margin-right:", function (props) {
15456
- return props.theme.spaceScale.spacing03;
15457
- }, ";margin-left:0px;svg{height:", function (props) {
15458
- return props.theme.iconSizes.medium;
15459
- }, "px;width:", function (props) {
15460
- return props.theme.iconSizes.medium;
15461
- }, "px;vertical-align:middle;}" + ( "/*# 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"]} */"));
15462
- var StyledLabelWrapper = /*#__PURE__*/_styled("span", {
15463
- target: "e1xiryew3",
15464
- label: "StyledLabelWrapper"
15465
- })("display:flex;align-items:flex-start;color:", function (props) {
15466
- return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
15467
- }, ";width:100%;" + ( "/*# 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"]} */"));
15468
- var StyledExpandWrapper = /*#__PURE__*/_styled("div", {
15469
- target: "e1xiryew2",
15470
- label: "StyledExpandWrapper"
15471
- })("display:inline-block;vertical-align:middle;margin-right:", function (props) {
15472
- return props.theme.spaceScale.spacing03;
15473
- }, ";color:", function (props) {
15474
- return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
15475
- }, ";border-radius:0;width:", function (props) {
15476
- return props.theme.spaceScale.spacing06;
15477
- }, ";height:", function (props) {
15478
- return props.theme.spaceScale.spacing06;
15479
- }, ";" + ( "/*# 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"]} */"));
15480
- var StyledCheckboxWrapper = /*#__PURE__*/_styled("div", {
15481
- target: "e1xiryew1",
15482
- label: "StyledCheckboxWrapper"
15483
- })("margin-right:", function (props) {
15484
- return props.theme.spaceScale.spacing03;
15485
- }, ";vertical-align:middle;display:inline-flex;" + ( "/*# 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"]} */"));
15486
- var StyledItemWrapper = /*#__PURE__*/_styled("div", {
15487
- target: "e1xiryew0",
15488
- label: "StyledItemWrapper"
15489
- })("display:flex;align-items:flex-start;cursor:", function (props) {
15490
- return getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType);
15491
- }, ";&:focus{outline-offset:-2px;outline:2px solid ", function (props) {
15492
- return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
15493
- }, ";}" + ( "/*# 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"]} */"));
15494
- var TreeItem = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
15495
- var _selectedItems$;
15496
- var children = props.children,
15497
- icon = props.icon,
15498
- isDisabled = props.isDisabled,
15499
- label = props.label,
15500
- labelStyle = props.labelStyle,
15501
- style = props.style,
15502
- testId = props.testId,
15503
- rest = _objectWithoutPropertiesLoose(props, _excluded$1B);
15504
- var theme = React.useContext(ThemeContext);
15505
- var isInverse = useIsInverse();
15506
- var _React$useContext = React.useContext(TreeViewContext),
15507
- selectable = _React$useContext.selectable,
15508
- hasIcons = _React$useContext.hasIcons,
15509
- onExpandedChange = _React$useContext.onExpandedChange,
15510
- itemToFocus = _React$useContext.itemToFocus;
15511
- var _useTreeItem = useTreeItem(props, forwardedRef),
15512
- contextValue = _useTreeItem.contextValue,
15513
- handleClick = _useTreeItem.handleClick,
15514
- handleKeyDown = _useTreeItem.handleKeyDown;
15515
- var checkboxChangeHandler = contextValue.checkboxChangeHandler,
15516
- checkedStatus = contextValue.checkedStatus,
15517
- expanded = contextValue.expanded,
15518
- hasOwnTreeItems = contextValue.hasOwnTreeItems,
15519
- itemDepth = contextValue.itemDepth,
15520
- itemId = contextValue.itemId,
15521
- parentDepth = contextValue.parentDepth,
15522
- ref = contextValue.ref,
15523
- selectedItems = contextValue.selectedItems,
15524
- setExpanded = contextValue.setExpanded,
15525
- updateCheckedStatusFromChild = contextValue.updateCheckedStatusFromChild;
15526
- var nodeType = hasOwnTreeItems ? exports.TreeNodeType.branch : exports.TreeNodeType.leaf;
15527
- var selectedItem = selectable === exports.TreeViewSelectable.single ? (selectedItems == null || (_selectedItems$ = selectedItems[0]) == null ? void 0 : _selectedItems$.itemId) === itemId : null;
15528
- var ariaCheckedValue = selectable === exports.TreeViewSelectable.multi ? checkedStatus === exports.IndeterminateCheckboxStatus.indeterminate ? 'mixed' : checkedStatus === exports.IndeterminateCheckboxStatus.checked : null;
15529
- var defaultIcon = nodeType === exports.TreeNodeType.branch ? React.createElement(reactMagmaIcons.FolderIcon, {
15530
- "aria-hidden": true
15531
- }) : React.createElement(reactMagmaIcons.ArticleIcon, {
15532
- "aria-hidden": true
15533
- });
15534
- var labelText = React.createElement(StyledLabelWrapper, {
15535
- theme: theme,
15536
- isDisabled: isDisabled,
15537
- isInverse: isInverse,
15538
- style: labelStyle,
15539
- id: itemId + "-label",
15540
- "data-testid": (testId || itemId) + "-label",
15541
- onClick: function onClick(e) {
15542
- if (selectable === exports.TreeViewSelectable.single && !isDisabled) {
15543
- handleClick(e, itemId);
15544
- }
15545
- }
15546
- }, hasIcons && React.createElement(IconWrapper$8, {
15547
- isInverse: isInverse,
15548
- theme: theme,
15549
- isDisabled: isDisabled,
15550
- "data-testid": (testId || itemId) + "-icon"
15551
- }, icon || defaultIcon), label);
15552
- // Props shared by Checkbox and IndeterminateCheckbox
15553
- var checkboxProps = {
15554
- disabled: isDisabled,
15555
- hideFocus: true,
15556
- id: itemId + "-checkbox",
15557
- inputStyle: {
15558
- marginRight: theme.spaceScale.spacing03
15559
- },
15560
- labelStyle: {
15561
- padding: 0
15562
- },
15563
- labelText: labelText,
15564
- onChange: checkboxChangeHandler,
15565
- tabIndex: -1,
15566
- testId: itemId + "-checkbox"
15567
- };
15568
- var onExpandedClicked = function onExpandedClicked(event) {
15569
- setExpanded(function (state) {
15570
- return !state;
15571
- });
15572
- event.preventDefault();
15573
- onExpandedChange && typeof onExpandedChange === 'function' && onExpandedChange(event);
15574
- };
15575
- return React.createElement(TreeItemContext.Provider, {
15576
- value: contextValue
15577
- }, React.createElement(StyledTreeItem, Object.assign({}, rest, {
15578
- "aria-expanded": hasOwnTreeItems ? expanded : null,
15579
- "aria-selected": selectedItem,
15580
- "aria-checked": ariaCheckedValue,
15581
- "data-testid": testId,
15582
- depth: itemDepth,
15583
- hasOwnTreeItems: true,
15584
- id: itemId,
15585
- isDisabled: isDisabled,
15586
- isInverse: isInverse,
15587
- nodeType: nodeType,
15588
- role: "treeitem",
15589
- selectableType: selectable,
15590
- selected: selectedItem,
15591
- theme: theme
15592
- }), React.createElement(StyledItemWrapper, {
15593
- "data-testid": (testId || itemId) + "-itemwrapper",
15594
- depth: itemDepth,
15595
- id: itemId + "-itemwrapper",
15596
- isDisabled: isDisabled,
15597
- isInverse: isInverse,
15598
- nodeType: nodeType,
15599
- onClick: function onClick(event) {
15600
- if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
15601
- onExpandedClicked(event);
15602
- }
15603
- },
15604
- onKeyDown: function onKeyDown(e) {
15605
- handleKeyDown(e);
15606
- },
15607
- ref: ref,
15608
- selectable: selectable,
15609
- style: style,
15610
- tabIndex: itemToFocus === itemId ? 0 : -1,
15611
- theme: theme
15612
- }, hasOwnTreeItems && React.createElement(StyledExpandWrapper, {
15613
- "aria-hidden": Boolean(!expanded),
15614
- "data-testid": (testId || itemId) + "-expand",
15615
- isDisabled: isDisabled,
15616
- isInverse: isInverse,
15617
- onClick: function onClick(event) {
15618
- if (!isDisabled && selectable !== exports.TreeViewSelectable.off) {
15619
- onExpandedClicked(event);
15620
- }
15621
- },
15622
- theme: theme
15623
- }, expanded ? React.createElement(reactMagmaIcons.ExpandMoreIcon, {
15624
- "aria-hidden": true
15625
- }) : React.createElement(reactMagmaIcons.ChevronRightIcon, {
15626
- "aria-hidden": true
15627
- })), selectable === exports.TreeViewSelectable.multi ? React.createElement(StyledCheckboxWrapper, {
15628
- theme: theme
15629
- }, hasOwnTreeItems ? React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, {
15630
- status: checkedStatus
15631
- })) : React.createElement(Checkbox, Object.assign({}, checkboxProps, {
15632
- checked: checkedStatusToBoolean(checkedStatus)
15633
- }))) : React.createElement(React.Fragment, null, labelText)), React.Children.map(children, function (child, index) {
15634
- var component = child.type === TreeItem ? React.createElement(Transition, {
15635
- isOpen: expanded,
15636
- collapse: true,
15637
- unmountOnExit: true
15638
- }, React.createElement("ul", {
15639
- role: "group"
15640
- }, React.cloneElement(child, {
15641
- index: index,
15642
- key: index,
15643
- itemDepth: itemDepth,
15644
- parentDepth: parentDepth,
15645
- parentCheckedStatus: checkedStatus,
15646
- updateParentCheckStatus: updateCheckedStatusFromChild
15647
- }))) : child;
15648
- // hide the disabled item + the children
15649
- if (isDisabled) return React.createElement(React.Fragment, null);
15650
- return component;
15651
- })));
15652
- });
15653
-
15654
- var _excluded$1C = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId"];
15322
+ var _excluded$1D = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId", "apiRef"];
15655
15323
  var StyledTreeView = /*#__PURE__*/_styled("ul", {
15656
15324
  target: "e1tyeayj0",
15657
15325
  label: "StyledTreeView"
15658
15326
  })("padding:0;margin:0;color:", function (props) {
15659
15327
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral;
15660
- }, ";ul{padding:0;margin:0;li{margin:0;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyZWVWaWV3LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRaUMiLCJmaWxlIjoiVHJlZVZpZXcudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VUcmVlVmlldywgVHJlZVZpZXdTZWxlY3RhYmxlLCB9IGZyb20gJy4vdXNlVHJlZVZpZXcnO1xyXG5pbXBvcnQgeyBUcmVlSXRlbSB9IGZyb20gJy4vVHJlZUl0ZW0nO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJbnZlcnNlQ29udGV4dCwgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IHVzZVRyZWVJdGVtIH0gZnJvbSAnLi91c2VUcmVlSXRlbSc7XHJcbmltcG9ydCB7IFRyZWVWaWV3Q29udGV4dCB9IGZyb20gJy4vVHJlZVZpZXdDb250ZXh0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5jb25zdCBTdHlsZWRUcmVlVmlldyA9IHN0eWxlZC51bCBgXG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsfTtcbiAgdWwge1xuICAgIHBhZGRpbmc6IDA7XG4gICAgbWFyZ2luOiAwO1xuICAgIGxpIHtcbiAgICAgIG1hcmdpbjogMDtcbiAgICB9XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBUcmVlVmlldyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYXJpYUxhYmVsLCBhcmlhTGFiZWxsZWRCeSwgY2hpbGRyZW4sIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgb25FeHBhbmRlZENoYW5nZSwgb25TZWxlY3RlZEl0ZW1DaGFuZ2UsIHNlbGVjdGFibGUsIHRlc3RJZCwgLi4ucmVzdCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIGNvbnN0IHsgY29udGV4dFZhbHVlIH0gPSB1c2VUcmVlVmlldyhwcm9wcyk7XHJcbiAgICBjb25zdCB7IGNvbnRleHRWYWx1ZTogdHJlZUl0ZW1Db250ZXh0VmFsdWUgfSA9IHVzZVRyZWVJdGVtKHsgbGFiZWw6IGFyaWFMYWJlbCwgaXRlbUlkOiAnJyB9LCByZWYpO1xyXG4gICAgbGV0IHRyZWVJdGVtSW5kZXggPSAwO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEludmVyc2VDb250ZXh0LlByb3ZpZGVyLCB7IHZhbHVlOiB7IGlzSW52ZXJzZSB9IH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUcmVlVmlld0NvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IGNvbnRleHRWYWx1ZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRyZWVWaWV3LCBPYmplY3QuYXNzaWduKHt9LCByZXN0LCB7IFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwsIFwiYXJpYS1sYWJlbGxlZGJ5XCI6IGFyaWFMYWJlbGxlZEJ5LCBcImFyaWEtbXVsdGlzZWxlY3RhYmxlXCI6IHNlbGVjdGFibGUgPT09IFRyZWVWaWV3U2VsZWN0YWJsZS5tdWx0aSwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCByZWY6IHJlZiwgcm9sZTogXCJ0cmVlXCIsIHRoZW1lOiB0aGVtZSB9KSwgUmVhY3QuQ2hpbGRyZW4ubWFwKGNoaWxkcmVuLCAoY2hpbGQpID0+IHtcclxuICAgICAgICAgICAgICAgIGlmIChjaGlsZC50eXBlID09PSBUcmVlSXRlbSkge1xyXG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IGl0ZW0gPSBSZWFjdC5jbG9uZUVsZW1lbnQoY2hpbGQsIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgaW5kZXg6IHRyZWVJdGVtSW5kZXgsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGtleTogdHJlZUl0ZW1JbmRleCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgcGFyZW50RGVwdGg6IDAsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGl0ZW1EZXB0aDogMCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgdG9wTGV2ZWw6IHRydWUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHBhcmVudENoZWNrZWRTdGF0dXM6IHRyZWVJdGVtQ29udGV4dFZhbHVlLmNoZWNrZWRTdGF0dXMgfHwgbnVsbCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgdXBkYXRlUGFyZW50Q2hlY2tTdGF0dXM6IHRyZWVJdGVtQ29udGV4dFZhbHVlLnVwZGF0ZUNoZWNrZWRTdGF0dXNGcm9tQ2hpbGQsXHJcbiAgICAgICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgICAgICAgICAgICAgdHJlZUl0ZW1JbmRleCsrO1xyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBpdGVtO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9KSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UcmVlVmlldy5qcy5tYXAiXX0= */"));
15328
+ }, ";ul{padding:0;margin:0;li{margin:0;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyZWVWaWV3LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTaUMiLCJmaWxlIjoiVHJlZVZpZXcudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VUcmVlVmlldywgfSBmcm9tICcuL3VzZVRyZWVWaWV3JztcclxuaW1wb3J0IHsgVHJlZVZpZXdTZWxlY3RhYmxlIH0gZnJvbSAnLi90eXBlcyc7XHJcbmltcG9ydCB7IFRyZWVJdGVtIH0gZnJvbSAnLi9UcmVlSXRlbSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEludmVyc2VDb250ZXh0LCB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgdXNlVHJlZUl0ZW0gfSBmcm9tICcuL3VzZVRyZWVJdGVtJztcclxuaW1wb3J0IHsgVHJlZVZpZXdDb250ZXh0IH0gZnJvbSAnLi9UcmVlVmlld0NvbnRleHQnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IFN0eWxlZFRyZWVWaWV3ID0gc3R5bGVkLnVsIGBcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICB1bCB7XG4gICAgcGFkZGluZzogMDtcbiAgICBtYXJnaW46IDA7XG4gICAgbGkge1xuICAgICAgbWFyZ2luOiAwO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IFRyZWVWaWV3ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBhcmlhTGFiZWwsIGFyaWFMYWJlbGxlZEJ5LCBjaGlsZHJlbiwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCBvbkV4cGFuZGVkQ2hhbmdlLCBvblNlbGVjdGVkSXRlbUNoYW5nZSwgc2VsZWN0YWJsZSwgdGVzdElkLCBhcGlSZWYsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCB7IGNvbnRleHRWYWx1ZSB9ID0gdXNlVHJlZVZpZXcocHJvcHMpO1xyXG4gICAgdXNlVHJlZUl0ZW0oeyBsYWJlbDogYXJpYUxhYmVsLCBpdGVtSWQ6ICcnIH0sIHJlZik7XHJcbiAgICBsZXQgdHJlZUl0ZW1JbmRleCA9IDA7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW52ZXJzZUNvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IHsgaXNJbnZlcnNlIH0gfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFRyZWVWaWV3Q29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZTogY29udGV4dFZhbHVlIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVHJlZVZpZXcsIE9iamVjdC5hc3NpZ24oe30sIHJlc3QsIHsgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCwgXCJhcmlhLWxhYmVsbGVkYnlcIjogYXJpYUxhYmVsbGVkQnksIFwiYXJpYS1tdWx0aXNlbGVjdGFibGVcIjogc2VsZWN0YWJsZSA9PT0gVHJlZVZpZXdTZWxlY3RhYmxlLm11bHRpLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCByb2xlOiBcInRyZWVcIiwgdGhlbWU6IHRoZW1lIH0pLCBSZWFjdC5DaGlsZHJlbi5tYXAoY2hpbGRyZW4sIChjaGlsZCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgaWYgKGNoaWxkLnR5cGUgPT09IFRyZWVJdGVtKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgaXRlbSA9IFJlYWN0LmNsb25lRWxlbWVudChjaGlsZCwge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBpbmRleDogdHJlZUl0ZW1JbmRleCxcclxuICAgICAgICAgICAgICAgICAgICAgICAga2V5OiB0cmVlSXRlbUluZGV4LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBwYXJlbnREZXB0aDogMCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgaXRlbURlcHRoOiAwLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICB0b3BMZXZlbDogdHJ1ZSxcclxuICAgICAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgICAgICB0cmVlSXRlbUluZGV4Kys7XHJcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGl0ZW07XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH0pKSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRyZWVWaWV3LmpzLm1hcCJdfQ== */"));
15661
15329
  var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
15662
15330
  var ariaLabel = props.ariaLabel,
15663
15331
  ariaLabelledBy = props.ariaLabelledBy,
@@ -15665,16 +15333,15 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
15665
15333
  isInverseProp = props.isInverse,
15666
15334
  selectable = props.selectable,
15667
15335
  testId = props.testId,
15668
- rest = _objectWithoutPropertiesLoose(props, _excluded$1C);
15336
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1D);
15669
15337
  var theme = React.useContext(ThemeContext);
15670
15338
  var isInverse = useIsInverse(isInverseProp);
15671
15339
  var _useTreeView = useTreeView(props),
15672
15340
  contextValue = _useTreeView.contextValue;
15673
- var _useTreeItem = useTreeItem({
15674
- label: ariaLabel,
15675
- itemId: ''
15676
- }, ref),
15677
- treeItemContextValue = _useTreeItem.contextValue;
15341
+ useTreeItem({
15342
+ label: ariaLabel,
15343
+ itemId: ''
15344
+ }, ref);
15678
15345
  var treeItemIndex = 0;
15679
15346
  return React.createElement(InverseContext.Provider, {
15680
15347
  value: {
@@ -15698,9 +15365,7 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
15698
15365
  key: treeItemIndex,
15699
15366
  parentDepth: 0,
15700
15367
  itemDepth: 0,
15701
- topLevel: true,
15702
- parentCheckedStatus: treeItemContextValue.checkedStatus || null,
15703
- updateParentCheckStatus: treeItemContextValue.updateCheckedStatusFromChild
15368
+ topLevel: true
15704
15369
  });
15705
15370
  treeItemIndex++;
15706
15371
  return item;
@@ -15708,7 +15373,7 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
15708
15373
  }))));
15709
15374
  });
15710
15375
 
15711
- var _excluded$1D = ["children", "enforced", "exclusive", "id", "isInverse", "noSpace", "onChange", "size", "value", "testId"];
15376
+ var _excluded$1E = ["children", "enforced", "exclusive", "id", "isInverse", "noSpace", "onChange", "size", "value", "testId"];
15712
15377
  var ToggleButtonGroupContext = /*#__PURE__*/React.createContext({});
15713
15378
  var ToggleButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
15714
15379
  var children = props.children,
@@ -15720,7 +15385,7 @@ var ToggleButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
15720
15385
  size = props.size,
15721
15386
  value = props.value,
15722
15387
  testId = props.testId,
15723
- rest = _objectWithoutPropertiesLoose(props, _excluded$1D);
15388
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1E);
15724
15389
  var theme = React.useContext(ThemeContext);
15725
15390
  var defaultSelectedValues = value ? [value] : [];
15726
15391
  // Array of currently selected items
@@ -16049,36 +15714,24 @@ exports.Transition = Transition;
16049
15714
  exports.TreeItem = TreeItem;
16050
15715
  exports.TreeView = TreeView;
16051
15716
  exports.VisuallyHidden = VisuallyHidden;
16052
- exports.areArraysEqual = areArraysEqual;
16053
- exports.arrayIncludesId = arrayIncludesId;
16054
15717
  exports.blockQuoteStyles = blockQuoteStyles;
16055
15718
  exports.calculateOffset = calculateOffset;
16056
15719
  exports.checkedStatusToBoolean = checkedStatusToBoolean;
16057
15720
  exports.defaultI18n = defaultI18n;
16058
15721
  exports.filterNullEntries = filterNullEntries;
16059
- exports.filterSelectedItems = filterSelectedItems;
16060
- exports.findChildByItemId = findChildByItemId;
16061
- exports.findCommonItems = findCommonItems;
16062
- exports.findFirstBranchNode = findFirstBranchNode;
16063
- exports.getAllChildrenEnabled = getAllChildrenEnabled;
16064
- exports.getAllParentIds = getAllParentIds;
16065
- exports.getCheckedStatus = getCheckedStatus;
16066
- exports.getChildrenCheckedStatus = getChildrenCheckedStatus;
16067
15722
  exports.getChildrenItemIds = getChildrenItemIds;
16068
15723
  exports.getChildrenItemIdsFlat = getChildrenItemIdsFlat;
16069
15724
  exports.getChildrenItemIdsInTree = getChildrenItemIdsInTree;
16070
15725
  exports.getDateFromString = getDateFromString;
16071
- exports.getEnabledTreeItemChildrenLength = getEnabledTreeItemChildrenLength;
16072
- exports.getFirstItemInTree = getFirstItemInTree;
16073
15726
  exports.getIconSizes = getIconSizes;
15727
+ exports.getInitialItems = getInitialItems;
16074
15728
  exports.getListAlignment = getListAlignment;
16075
- exports.getMissingChildrenIds = getMissingChildrenIds;
16076
15729
  exports.getTreeItemLabelColor = getTreeItemLabelColor;
16077
15730
  exports.getTreeItemWrapperCursor = getTreeItemWrapperCursor;
16078
- exports.getUniqueSelectedItemsArray = getUniqueSelectedItemsArray;
16079
- exports.getUpdatedSelectedItems = getUpdatedSelectedItems;
16080
15731
  exports.inDateRange = inDateRange;
16081
15732
  exports.magma = magma;
15733
+ exports.selectMulti = selectMulti;
15734
+ exports.selectSingle = selectSingle;
16082
15735
  exports.setBackgroundColor = setBackgroundColor;
16083
15736
  exports.setIconWidth = setIconWidth;
16084
15737
  exports.useAccordion = useAccordion;