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