@react-spectrum/tree 3.0.0-alpha.0 → 3.0.0-alpha.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.
@@ -51,28 +51,28 @@ function $9b0dbe0a88ecfa3f$var$useTreeRendererContext() {
51
51
  // scroll into view due to how the ring is offset. Alternatively, have the tree render the top/bottom outline like it does in Listview
52
52
  const $9b0dbe0a88ecfa3f$var$tree = function anonymous(props) {
53
53
  let rules = "";
54
- rules += " wc";
55
- rules += " xc";
56
- rules += " ua";
57
- rules += " va";
58
- rules += " __ka";
59
- rules += " Aa";
60
- rules += " ca___y";
61
- rules += " ca";
62
- if (props.isEmpty) rules += " _Vd";
63
- if (props.isEmpty) rules += " _Uc";
64
- if (props.isEmpty) rules += " oY";
65
- if (props.isEmpty) rules += " nY";
66
- if (props.isEmpty) rules += " _Sd";
54
+ rules += ' wc';
55
+ rules += ' xc';
56
+ rules += ' ua';
57
+ rules += ' va';
58
+ rules += ' __ka';
59
+ rules += ' Aa';
60
+ rules += ' ca___y';
61
+ rules += ' ca';
62
+ if (props.isEmpty) rules += ' _Vd';
63
+ if (props.isEmpty) rules += ' _Uc';
64
+ if (props.isEmpty) rules += ' oY';
65
+ if (props.isEmpty) rules += ' nY';
66
+ if (props.isEmpty) rules += ' _Sd';
67
67
  return rules;
68
68
  };
69
69
  function $9b0dbe0a88ecfa3f$var$TreeView(props, ref) {
70
70
  let { children: children, selectionStyle: selectionStyle } = props;
71
71
  let renderer;
72
- if (typeof children === "function") renderer = children;
72
+ if (typeof children === 'function') renderer = children;
73
73
  let { styleProps: styleProps } = (0, $6Q8R1$reactspectrumutils.useStyleProps)(props);
74
74
  let domRef = (0, $6Q8R1$reactspectrumutils.useDOMRef)(ref);
75
- let selectionBehavior = selectionStyle === "highlight" ? "replace" : "toggle";
75
+ let selectionBehavior = selectionStyle === 'highlight' ? 'replace' : 'toggle';
76
76
  return /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement($9b0dbe0a88ecfa3f$var$TreeRendererContext.Provider, {
77
77
  value: {
78
78
  renderer: renderer
@@ -89,99 +89,99 @@ function $9b0dbe0a88ecfa3f$var$TreeView(props, ref) {
89
89
  }
90
90
  const $9b0dbe0a88ecfa3f$var$treeRow = function anonymous(props) {
91
91
  let rules = "";
92
- rules += " Xc";
93
- rules += " _Sd";
94
- rules += " nk";
95
- rules += " oY";
96
- rules += " __ka";
97
- rules += " _6c";
98
- rules += " _7d";
99
- rules += " _9b";
100
- rules += " a___K";
101
- rules += " _Ea";
102
- if (props.isLink) rules += " __Ec";
103
- else rules += " __Eb";
104
- if (props.isSelected) rules += " b-7vr0l1";
105
- else if (props.isPressed) rules += " b-1t6gvb8";
106
- else if (props.isFocusVisibleWithin) rules += " b-ml9cvk";
107
- else if (props.isHovered) rules += " b-ml9cvk";
92
+ rules += ' Xc';
93
+ rules += ' _Sd';
94
+ rules += ' nk';
95
+ rules += ' oY';
96
+ rules += ' __ka';
97
+ rules += ' _6c';
98
+ rules += ' _7d';
99
+ rules += ' _9b';
100
+ rules += ' a___K';
101
+ rules += ' _Ea';
102
+ if (props.isLink) rules += ' __Ec';
103
+ else rules += ' __Eb';
104
+ if (props.isSelected) rules += ' b-7vr0l1';
105
+ else if (props.isPressed) rules += ' b-1t6gvb8';
106
+ else if (props.isFocusVisibleWithin) rules += ' b-ml9cvk';
107
+ else if (props.isHovered) rules += ' b-ml9cvk';
108
108
  return rules;
109
109
  };
110
110
  const $9b0dbe0a88ecfa3f$var$treeCellGrid = function anonymous(props) {
111
111
  let rules = "";
112
- rules += " _Sf";
113
- rules += " oY";
114
- rules += " _Uc";
115
- rules += " __d-1nxidkl-1nxidkl-1nxidkl-zjkg1z-1nxidkl-375yi6-1nxidkl-ykdwf2";
116
- rules += " __e-375yi6";
117
- rules += " __f-1qk85yo";
112
+ rules += ' _Sf';
113
+ rules += ' oY';
114
+ rules += ' _Uc';
115
+ rules += ' __d-1nxidkl-1nxidkl-1nxidkl-zjkg1z-1nxidkl-375yi6-1nxidkl-ykdwf2';
116
+ rules += ' __e-375yi6';
117
+ rules += ' __f-1qk85yo';
118
118
  if (props.isDisabled) {
119
- rules += " aa___F";
120
- rules += " ai";
119
+ rules += ' aa___F';
120
+ rules += ' ai';
121
121
  }
122
122
  return rules;
123
123
  };
124
124
  // TODO: These styles lose against the spectrum class names, so I've did unsafe for the ones that get overridden
125
125
  const $9b0dbe0a88ecfa3f$var$treeCheckbox = function anonymous(props) {
126
126
  let rules = "";
127
- rules += " __g-4wahvw";
128
- rules += " _J-37nn5o";
129
- rules += " Cd";
130
- rules += " Da";
127
+ rules += ' __g-4wahvw';
128
+ rules += ' _J-37nn5o';
129
+ rules += ' Cd';
130
+ rules += ' Da';
131
131
  return rules;
132
132
  };
133
133
  const $9b0dbe0a88ecfa3f$var$treeIcon = function anonymous(props) {
134
134
  let rules = "";
135
- rules += " __g-ykjmzy";
136
- rules += " Dc";
135
+ rules += ' __g-ykjmzy';
136
+ rules += ' Dc';
137
137
  return rules;
138
138
  };
139
139
  const $9b0dbe0a88ecfa3f$var$treeContent = function anonymous(props) {
140
140
  let rules = "";
141
- rules += " __g-1mod4sg";
142
- rules += " _ga";
143
- rules += " _kb";
144
- rules += " __sb";
145
- rules += " __tb";
141
+ rules += ' __g-1mod4sg';
142
+ rules += ' _ga';
143
+ rules += ' _kb';
144
+ rules += ' __sb';
145
+ rules += ' __tb';
146
146
  return rules;
147
147
  };
148
148
  const $9b0dbe0a88ecfa3f$var$treeActions = function anonymous(props) {
149
149
  let rules = "";
150
- rules += " __g-8ayfo6";
151
- rules += " _3-3t1x";
152
- rules += " _2-3t1x";
153
- rules += " CF";
154
- rules += " Db";
150
+ rules += ' __g-8ayfo6';
151
+ rules += ' _3-3t1x';
152
+ rules += ' _2-3t1x';
153
+ rules += ' CF';
154
+ rules += ' Db';
155
155
  return rules;
156
156
  };
157
157
  const $9b0dbe0a88ecfa3f$var$treeActionMenu = function anonymous(props) {
158
158
  let rules = "";
159
- rules += " __g-wit6hk";
160
- rules += " oi";
159
+ rules += ' __g-wit6hk';
160
+ rules += ' oi';
161
161
  return rules;
162
162
  };
163
163
  const $9b0dbe0a88ecfa3f$var$treeRowOutline = function anonymous(props) {
164
164
  let rules = "";
165
- rules += " _Sa";
166
- rules += " Xa";
167
- rules += " Ya";
168
- rules += " Za";
165
+ rules += ' _Sa';
166
+ rules += ' Xa';
167
+ rules += ' Ya';
168
+ rules += ' Za';
169
169
  if (props.isSelected) {
170
- if (props.isFocusVisible) rules += " _0-yj8a3w";
171
- else rules += " _0-yj899n";
172
- } else if (props.isFocusVisible) rules += " _0-yj8a3w";
173
- else rules += " _0a";
174
- rules += " _2a";
175
- rules += " __ya";
176
- rules += " _tb";
170
+ if (props.isFocusVisible) rules += ' _0-yj8a3w';
171
+ else rules += ' _0-yj899n';
172
+ } else if (props.isFocusVisible) rules += ' _0-yj8a3w';
173
+ else rules += ' _0a';
174
+ rules += ' _2a';
175
+ rules += ' __ya';
176
+ rules += ' _tb';
177
177
  if (props.isSelected) {
178
- if (props.isFocusVisible) rules += " _oa-4bhpmf";
179
- else rules += " _oa-zlnqab";
180
- } else if (props.isFocusVisible) rules += " _oa-4bhpmf";
178
+ if (props.isFocusVisible) rules += ' _oa-4bhpmf';
179
+ else rules += ' _oa-zlnqab';
180
+ } else if (props.isFocusVisible) rules += ' _oa-4bhpmf';
181
181
  if (props.isSelected) {
182
- if (props.isFocusVisible) rules += " _o-ba5uxf";
183
- else rules += " _o-1ytnijz";
184
- } else if (props.isFocusVisible) rules += " _o-ba5uxf";
182
+ if (props.isFocusVisible) rules += ' _o-ba5uxf';
183
+ else rules += ' _o-1ytnijz';
184
+ } else if (props.isFocusVisible) rules += ' _o-ba5uxf';
185
185
  return rules;
186
186
  };
187
187
  const $9b0dbe0a88ecfa3f$export$6e77ea6719814e9c = (props)=>{
@@ -191,7 +191,7 @@ const $9b0dbe0a88ecfa3f$export$6e77ea6719814e9c = (props)=>{
191
191
  let { renderer: renderer } = $9b0dbe0a88ecfa3f$var$useTreeRendererContext();
192
192
  // TODO alternative api is that we have a separate prop for the TreeItems contents and expect the child to then be
193
193
  // a nested tree item
194
- if (typeof children === "string") content = /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement((0, $6Q8R1$reactspectrumtext.Text), null, children);
194
+ if (typeof children === 'string') content = /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement((0, $6Q8R1$reactspectrumtext.Text), null, children);
195
195
  else {
196
196
  content = [];
197
197
  nestedRows = [];
@@ -214,17 +214,17 @@ const $9b0dbe0a88ecfa3f$export$6e77ea6719814e9c = (props)=>{
214
214
  className: $9b0dbe0a88ecfa3f$var$treeCellGrid({
215
215
  isDisabled: isDisabled
216
216
  })
217
- }, selectionMode !== "none" && selectionBehavior === "toggle" && // TODO: add transition?
217
+ }, selectionMode !== 'none' && selectionBehavior === 'toggle' && // TODO: add transition?
218
218
  /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement((0, $6Q8R1$reactspectrumcheckbox.Checkbox), {
219
219
  isEmphasized: true,
220
220
  UNSAFE_className: $9b0dbe0a88ecfa3f$var$treeCheckbox(),
221
221
  UNSAFE_style: {
222
- paddingInlineEnd: "0px"
222
+ paddingInlineEnd: '0px'
223
223
  },
224
224
  slot: "selection"
225
225
  }), /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement("div", {
226
226
  style: {
227
- gridArea: "level-padding",
227
+ gridArea: 'level-padding',
228
228
  marginInlineEnd: `calc(${level - 1} * var(--spectrum-global-dimension-size-200))`
229
229
  }
230
230
  }), (hasChildRows || hasChildItems) && /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement($9b0dbe0a88ecfa3f$var$ExpandableRowChevron, {
@@ -241,7 +241,7 @@ const $9b0dbe0a88ecfa3f$export$6e77ea6719814e9c = (props)=>{
241
241
  // but could crop up later for other components
242
242
  icon: {
243
243
  UNSAFE_className: $9b0dbe0a88ecfa3f$var$treeIcon(),
244
- size: "S"
244
+ size: 'S'
245
245
  },
246
246
  actionButton: {
247
247
  UNSAFE_className: $9b0dbe0a88ecfa3f$var$treeActions(),
@@ -250,15 +250,15 @@ const $9b0dbe0a88ecfa3f$export$6e77ea6719814e9c = (props)=>{
250
250
  actionGroup: {
251
251
  UNSAFE_className: $9b0dbe0a88ecfa3f$var$treeActions(),
252
252
  isQuiet: true,
253
- density: "compact",
254
- buttonLabelBehavior: "hide",
253
+ density: 'compact',
254
+ buttonLabelBehavior: 'hide',
255
255
  isDisabled: isDisabled,
256
- overflowMode: "collapse"
256
+ overflowMode: 'collapse'
257
257
  },
258
258
  actionMenu: {
259
259
  UNSAFE_className: $9b0dbe0a88ecfa3f$var$treeActionMenu(),
260
260
  UNSAFE_style: {
261
- marginInlineEnd: ".5rem"
261
+ marginInlineEnd: '.5rem'
262
262
  },
263
263
  isQuiet: true
264
264
  }
@@ -272,33 +272,33 @@ const $9b0dbe0a88ecfa3f$export$6e77ea6719814e9c = (props)=>{
272
272
  };
273
273
  const $9b0dbe0a88ecfa3f$var$expandButton = function anonymous(props) {
274
274
  let rules = "";
275
- rules += " __g-pn4rxq";
276
- rules += " nY";
277
- rules += " _4b";
278
- rules += " _Sd";
279
- rules += " _0a";
280
- rules += " _Tb";
281
- rules += " _Vd";
282
- rules += " _Ea";
275
+ rules += ' __g-pn4rxq';
276
+ rules += ' nY';
277
+ rules += ' _4b';
278
+ rules += ' _Sd';
279
+ rules += ' _0a';
280
+ rules += ' _Tb';
281
+ rules += ' _Vd';
282
+ rules += ' _Ea';
283
283
  if (props.isExpanded) {
284
- if (props.isRTL) rules += " W-negfvv";
285
- else rules += " W-10b8jr2";
284
+ if (props.isRTL) rules += ' W-negfvv';
285
+ else rules += ' W-10b8jr2';
286
286
  }
287
- rules += " _H-1o2fh9e";
287
+ rules += ' _H-1o2fh9e';
288
288
  return rules;
289
289
  };
290
290
  function $9b0dbe0a88ecfa3f$var$ExpandableRowChevron(props) {
291
- let expandButtonRef = (0, $6Q8R1$react.useRef)();
291
+ let expandButtonRef = (0, $6Q8R1$react.useRef)(null);
292
292
  let [fullProps, ref] = (0, $6Q8R1$reactariacomponents.useContextProps)({
293
293
  ...props,
294
- slot: "chevron"
294
+ slot: 'chevron'
295
295
  }, expandButtonRef, (0, $6Q8R1$reactariacomponents.ButtonContext));
296
296
  let { isExpanded: isExpanded, isDisabled: isDisabled } = fullProps;
297
297
  let { direction: direction } = (0, $6Q8R1$reactariai18n.useLocale)();
298
298
  // Will need to keep the chevron as a button for iOS VO at all times since VO doesn't focus the cell. Also keep as button if cellAction is defined by the user in the future
299
299
  let { buttonProps: buttonProps } = (0, $6Q8R1$reactariabutton.useButton)({
300
300
  ...fullProps,
301
- elementType: "span"
301
+ elementType: 'span'
302
302
  }, ref);
303
303
  return /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement("span", {
304
304
  ...buttonProps,
@@ -308,9 +308,9 @@ function $9b0dbe0a88ecfa3f$var$ExpandableRowChevron(props) {
308
308
  className: $9b0dbe0a88ecfa3f$var$expandButton({
309
309
  isExpanded: isExpanded,
310
310
  isDisabled: isDisabled,
311
- isRTL: direction === "rtl"
311
+ isRTL: direction === 'rtl'
312
312
  })
313
- }, direction === "ltr" ? /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement((0, ($parcel$interopDefault($6Q8R1$spectrumiconsuiChevronRightMedium))), null) : /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement((0, ($parcel$interopDefault($6Q8R1$spectrumiconsuiChevronLeftMedium))), null));
313
+ }, direction === 'ltr' ? /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement((0, ($parcel$interopDefault($6Q8R1$spectrumiconsuiChevronRightMedium))), null) : /*#__PURE__*/ (0, ($parcel$interopDefault($6Q8R1$react))).createElement((0, ($parcel$interopDefault($6Q8R1$spectrumiconsuiChevronLeftMedium))), null));
314
314
  }
315
315
  /**
316
316
  * A tree view provides users with a way to navigate nested hierarchical information.
@@ -1 +1 @@
1
- {"mappings":"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","sources":["packages/@react-spectrum/tree/src/TreeView.tsx"],"sourcesContent":["/*\n * Copyright 2024 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaTreeGridListProps} from '@react-aria/tree';\nimport {ButtonContext, Collection, TreeItemContentRenderProps, TreeItemProps, TreeItemRenderProps, TreeRenderProps, UNSTABLE_Tree, UNSTABLE_TreeItem, UNSTABLE_TreeItemContent, useContextProps} from 'react-aria-components';\nimport {Checkbox} from '@react-spectrum/checkbox';\nimport ChevronLeftMedium from '@spectrum-icons/ui/ChevronLeftMedium';\nimport ChevronRightMedium from '@spectrum-icons/ui/ChevronRightMedium';\nimport {DOMRef, Expandable, Key, SelectionBehavior, SpectrumSelectionProps, StyleProps} from '@react-types/shared';\nimport {isAndroid} from '@react-aria/utils';\nimport React, {createContext, isValidElement, ReactElement, ReactNode, useContext, useRef} from 'react';\nimport {SlotProvider, useDOMRef, useStyleProps} from '@react-spectrum/utils';\nimport {style} from '@react-spectrum/style-macro-s1' with {type: 'macro'};\nimport {Text} from '@react-spectrum/text';\nimport {useButton} from '@react-aria/button';\nimport {useLocale} from '@react-aria/i18n';\n\nexport interface SpectrumTreeViewProps<T> extends Omit<AriaTreeGridListProps<T>, 'children'>, StyleProps, SpectrumSelectionProps, Expandable {\n /** Provides content to display when there are no items in the tree. */\n renderEmptyState?: () => JSX.Element,\n /**\n * Handler that is called when a user performs an action on an item. The exact user event depends on\n * the collection's `selectionStyle` prop and the interaction modality.\n */\n onAction?: (key: Key) => void,\n /**\n * The contents of the tree.\n */\n children?: ReactNode | ((item: T) => ReactNode)\n}\n\nexport interface SpectrumTreeViewItemProps extends Omit<TreeItemProps, 'className' | 'style' | 'value'> {\n /** Rendered contents of the tree item or child items. */\n children: ReactNode,\n /** Whether this item has children, even if not loaded yet. */\n hasChildItems?: boolean\n}\n\ninterface TreeRendererContextValue {\n renderer?: (item) => React.ReactElement<any, string | React.JSXElementConstructor<any>>\n}\nconst TreeRendererContext = createContext<TreeRendererContextValue>({});\n\nfunction useTreeRendererContext(): TreeRendererContextValue {\n return useContext(TreeRendererContext)!;\n}\n\n// TODO: add animations for rows appearing and disappearing\n\n// TODO: the below is needed so the borders of the top and bottom row isn't cut off if the TreeView is wrapped within a container by always reserving the 2px needed for the\n// keyboard focus ring. Perhaps find a different way of rendering the outlines since the top of the item doesn't\n// scroll into view due to how the ring is offset. Alternatively, have the tree render the top/bottom outline like it does in Listview\nconst tree = style<Pick<TreeRenderProps, 'isEmpty'>>({\n borderWidth: 2,\n boxSizing: 'border-box',\n borderXWidth: 0,\n borderStyle: 'solid',\n borderColor: {\n default: 'transparent',\n forcedColors: 'Background'\n },\n justifyContent: {\n isEmpty: 'center'\n },\n alignItems: {\n isEmpty: 'center'\n },\n width: {\n isEmpty: 'full'\n },\n height: {\n isEmpty: 'full'\n },\n display: {\n isEmpty: 'flex'\n }\n});\n\nfunction TreeView<T extends object>(props: SpectrumTreeViewProps<T>, ref: DOMRef<HTMLDivElement>) {\n let {children, selectionStyle} = props;\n\n let renderer;\n if (typeof children === 'function') {\n renderer = children;\n }\n\n let {styleProps} = useStyleProps(props);\n let domRef = useDOMRef(ref);\n let selectionBehavior = selectionStyle === 'highlight' ? 'replace' : 'toggle';\n\n return (\n <TreeRendererContext.Provider value={{renderer}}>\n <UNSTABLE_Tree {...props} {...styleProps} className={({isEmpty}) => tree({isEmpty})} selectionBehavior={selectionBehavior as SelectionBehavior} ref={domRef}>\n {props.children}\n </UNSTABLE_Tree>\n </TreeRendererContext.Provider>\n );\n}\n\ninterface TreeRowRenderProps extends TreeItemRenderProps {\n isLink?: boolean\n}\n\nconst treeRow = style<TreeRowRenderProps>({\n position: 'relative',\n display: 'flex',\n height: 10,\n width: 'full',\n boxSizing: 'border-box',\n fontSize: 'base',\n fontWeight: 'normal',\n lineHeight: 200,\n color: 'body',\n outlineStyle: 'none',\n cursor: {\n default: 'default',\n isLink: 'pointer'\n },\n // TODO: not sure where to get the equivalent colors here, for instance isHovered is spectrum 600 with 10% opacity but I don't think that exists in the theme\n backgroundColor: {\n isHovered: '[var(--spectrum-table-row-background-color-hover)]',\n isFocusVisibleWithin: '[var(--spectrum-table-row-background-color-hover)]',\n isPressed: '[var(--spectrum-table-row-background-color-down)]',\n isSelected: '[var(--spectrum-table-row-background-color-selected)]'\n }\n});\n\nconst treeCellGrid = style({\n display: 'grid',\n width: 'full',\n alignItems: 'center',\n // TODO: needed to use spectrum var since gridTemplateColumns uses baseSizing and not scaled sizing\n gridTemplateColumns: ['minmax(0, auto)', 'minmax(0, auto)', 'minmax(0, auto)', 'var(--spectrum-global-dimension-size-500)', 'minmax(0, auto)', '1fr', 'minmax(0, auto)', 'auto'],\n gridTemplateRows: '1fr',\n gridTemplateAreas: [\n 'drag-handle checkbox level-padding expand-button icon content actions actionmenu'\n ],\n color: {\n isDisabled: {\n default: 'gray-400',\n forcedColors: 'GrayText'\n }\n }\n});\n\n// TODO: These styles lose against the spectrum class names, so I've did unsafe for the ones that get overridden\nconst treeCheckbox = style({\n gridArea: 'checkbox',\n transitionDuration: '160ms',\n marginStart: 3,\n marginEnd: 0\n});\n\nconst treeIcon = style({\n gridArea: 'icon',\n marginEnd: 2\n});\n\nconst treeContent = style<Pick<TreeItemContentRenderProps, 'isDisabled'>>({\n gridArea: 'content',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n overflow: 'hidden'\n});\n\nconst treeActions = style({\n gridArea: 'actions',\n flexGrow: 0,\n flexShrink: 0,\n /* TODO: I made this one up, confirm desired behavior. These paddings are to make sure the action group has enough padding for the focus ring */\n marginStart: .5,\n marginEnd: 1\n});\n\nconst treeActionMenu = style({\n gridArea: 'actionmenu',\n width: 8\n});\n\nconst treeRowOutline = style({\n content: '',\n display: 'block',\n position: 'absolute',\n insetStart: 0,\n insetEnd: 0,\n top: {\n default: 0,\n isFocusVisible: '[-2px]',\n isSelected: {\n default: '[-1px]',\n isFocusVisible: '[-2px]'\n }\n },\n bottom: 0,\n pointerEvents: 'none',\n forcedColorAdjust: 'none',\n\n boxShadow: {\n isFocusVisible: '[inset 2px 0 0 0 var(--spectrum-alias-focus-color), inset -2px 0 0 0 var(--spectrum-alias-focus-color), inset 0 -2px 0 0 var(--spectrum-alias-focus-color), inset 0 2px 0 0 var(--spectrum-alias-focus-color)]',\n isSelected: {\n default: '[inset 1px 0 0 0 var(--spectrum-alias-focus-color), inset -1px 0 0 0 var(--spectrum-alias-focus-color), inset 0 -1px 0 0 var(--spectrum-alias-focus-color), inset 0 1px 0 0 var(--spectrum-alias-focus-color)]',\n isFocusVisible: '[inset 2px 0 0 0 var(--spectrum-alias-focus-color), inset -2px 0 0 0 var(--spectrum-alias-focus-color), inset 0 -2px 0 0 var(--spectrum-alias-focus-color), inset 0 2px 0 0 var(--spectrum-alias-focus-color)]'\n },\n forcedColors: {\n isFocusVisible: '[inset 2px 0 0 0 Highlight, inset -2px 0 0 0 Highlight, inset 0 -2px 0 0 Highlight, inset 0 2px 0 0 Highlight]',\n isSelected: {\n default: '[inset 1px 0 0 0 Highlight, inset -1px 0 0 0 Highlight, inset 0 -1px 0 0 Highlight, inset 0 1px 0 0 Highlight]',\n isFocusVisible: '[inset 2px 0 0 0 Highlight, inset -2px 0 0 0 Highlight, inset 0 -2px 0 0 Highlight, inset 0 2px 0 0 Highlight]'\n }\n }\n }\n});\n\nexport const TreeViewItem = (props: SpectrumTreeViewItemProps) => {\n let {\n children,\n childItems,\n hasChildItems,\n href\n } = props;\n\n let content;\n let nestedRows;\n let {renderer} = useTreeRendererContext();\n // TODO alternative api is that we have a separate prop for the TreeItems contents and expect the child to then be\n // a nested tree item\n\n if (typeof children === 'string') {\n content = <Text>{children}</Text>;\n } else {\n content = [];\n nestedRows = [];\n React.Children.forEach(children, node => {\n if (isValidElement(node) && node.type === TreeViewItem) {\n nestedRows.push(node);\n } else {\n content.push(node);\n }\n });\n }\n\n if (childItems != null && renderer) {\n nestedRows = (\n <Collection items={childItems}>\n {renderer}\n </Collection>\n );\n }\n\n return (\n // TODO right now all the tree rows have the various data attributes applied on their dom nodes, should they? Doesn't feel very useful\n <UNSTABLE_TreeItem\n {...props}\n className={renderProps => treeRow({\n ...renderProps,\n isLink: !!href\n })}>\n <UNSTABLE_TreeItemContent>\n {({isExpanded, hasChildRows, level, selectionMode, selectionBehavior, isDisabled, isSelected, isFocusVisible}) => (\n <div className={treeCellGrid({isDisabled})}>\n {selectionMode !== 'none' && selectionBehavior === 'toggle' && (\n // TODO: add transition?\n <Checkbox\n isEmphasized\n UNSAFE_className={treeCheckbox()}\n UNSAFE_style={{paddingInlineEnd: '0px'}}\n slot=\"selection\" />\n )}\n <div style={{gridArea: 'level-padding', marginInlineEnd: `calc(${level - 1} * var(--spectrum-global-dimension-size-200))`}} />\n {/* TODO: revisit when we do async loading, at the moment hasChildItems will only cause the chevron to be rendered, no aria/data attributes indicating the row's expandability are added */}\n {(hasChildRows || hasChildItems) && <ExpandableRowChevron isDisabled={isDisabled} isExpanded={isExpanded} />}\n <SlotProvider\n slots={{\n text: {UNSAFE_className: treeContent({isDisabled})},\n // Note there is also an issue here where these icon props are making into the action menu's icon. Resolved by 8ab0ffb276ff437a65b365c9a3be0323a1b24656\n // but could crop up later for other components\n icon: {UNSAFE_className: treeIcon(), size: 'S'},\n actionButton: {UNSAFE_className: treeActions(), isQuiet: true},\n actionGroup: {\n UNSAFE_className: treeActions(),\n isQuiet: true,\n density: 'compact',\n buttonLabelBehavior: 'hide',\n isDisabled,\n overflowMode: 'collapse'\n },\n actionMenu: {UNSAFE_className: treeActionMenu(), UNSAFE_style: {marginInlineEnd: '.5rem'}, isQuiet: true}\n }}>\n {content}\n </SlotProvider>\n <div className={treeRowOutline({isFocusVisible, isSelected})} />\n </div>\n )}\n </UNSTABLE_TreeItemContent>\n {nestedRows}\n </UNSTABLE_TreeItem>\n );\n};\n\ninterface ExpandableRowChevronProps {\n isExpanded?: boolean,\n isDisabled?: boolean,\n isRTL?: boolean\n}\n\nconst expandButton = style<ExpandableRowChevronProps>({\n gridArea: 'expand-button',\n height: 'full',\n aspectRatio: 'square',\n display: 'flex',\n flexWrap: 'wrap',\n alignContent: 'center',\n justifyContent: 'center',\n outlineStyle: 'none',\n transform: {\n isExpanded: {\n default: 'rotate(90deg)',\n isRTL: 'rotate(-90deg)'\n }\n },\n transition: '[transform ease var(--spectrum-global-animation-duration-100)]'\n});\n\nfunction ExpandableRowChevron(props: ExpandableRowChevronProps) {\n let expandButtonRef = useRef();\n let [fullProps, ref] = useContextProps({...props, slot: 'chevron'}, expandButtonRef, ButtonContext);\n let {isExpanded, isDisabled} = fullProps;\n let {direction} = useLocale();\n\n // Will need to keep the chevron as a button for iOS VO at all times since VO doesn't focus the cell. Also keep as button if cellAction is defined by the user in the future\n let {buttonProps} = useButton({\n ...fullProps,\n elementType: 'span'\n }, ref);\n\n return (\n <span\n {...buttonProps}\n ref={ref}\n // Override tabindex so that grid keyboard nav skips over it. Needs -1 so android talkback can actually \"focus\" it\n tabIndex={isAndroid() && !isDisabled ? -1 : undefined}\n className={expandButton({isExpanded, isDisabled, isRTL: direction === 'rtl'})}>\n {direction === 'ltr' ? <ChevronRightMedium /> : <ChevronLeftMedium />}\n </span>\n );\n}\n\n/**\n * A tree view provides users with a way to navigate nested hierarchical information.\n */\nconst _TreeView = React.forwardRef(TreeView) as <T>(props: SpectrumTreeViewProps<T> & {ref?: DOMRef<HTMLDivElement>}) => ReactElement;\nexport {_TreeView as TreeView};\n"],"names":[],"version":3,"file":"TreeView.main.js.map"}
1
+ {"mappings":"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","sources":["packages/@react-spectrum/tree/src/TreeView.tsx"],"sourcesContent":["/*\n * Copyright 2024 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaTreeGridListProps} from '@react-aria/tree';\nimport {ButtonContext, Collection, TreeItemContentRenderProps, TreeItemProps, TreeItemRenderProps, TreeRenderProps, UNSTABLE_Tree, UNSTABLE_TreeItem, UNSTABLE_TreeItemContent, useContextProps} from 'react-aria-components';\nimport {Checkbox} from '@react-spectrum/checkbox';\nimport ChevronLeftMedium from '@spectrum-icons/ui/ChevronLeftMedium';\nimport ChevronRightMedium from '@spectrum-icons/ui/ChevronRightMedium';\nimport {DOMRef, Expandable, Key, SelectionBehavior, SpectrumSelectionProps, StyleProps} from '@react-types/shared';\nimport {isAndroid} from '@react-aria/utils';\nimport React, {createContext, isValidElement, JSX, JSXElementConstructor, ReactElement, ReactNode, useContext, useRef} from 'react';\nimport {SlotProvider, useDOMRef, useStyleProps} from '@react-spectrum/utils';\nimport {style} from '@react-spectrum/style-macro-s1' with {type: 'macro'};\nimport {Text} from '@react-spectrum/text';\nimport {useButton} from '@react-aria/button';\nimport {useLocale} from '@react-aria/i18n';\n\nexport interface SpectrumTreeViewProps<T> extends Omit<AriaTreeGridListProps<T>, 'children'>, StyleProps, SpectrumSelectionProps, Expandable {\n /** Provides content to display when there are no items in the tree. */\n renderEmptyState?: () => JSX.Element,\n /**\n * Handler that is called when a user performs an action on an item. The exact user event depends on\n * the collection's `selectionStyle` prop and the interaction modality.\n */\n onAction?: (key: Key) => void,\n /**\n * The contents of the tree.\n */\n children?: ReactNode | ((item: T) => ReactNode)\n}\n\nexport interface SpectrumTreeViewItemProps<T extends object = object> extends Omit<TreeItemProps, 'className' | 'style' | 'value' | 'onHoverStart' | 'onHoverEnd' | 'onHoverChange'> {\n /** Rendered contents of the tree item or child items. */\n children: ReactNode,\n /** Whether this item has children, even if not loaded yet. */\n hasChildItems?: boolean,\n /** A list of child tree item objects used when dynamically rendering the tree item children. */\n childItems?: Iterable<T>\n}\n\ninterface TreeRendererContextValue {\n renderer?: (item) => ReactElement<any, string | JSXElementConstructor<any>>\n}\nconst TreeRendererContext = createContext<TreeRendererContextValue>({});\n\nfunction useTreeRendererContext(): TreeRendererContextValue {\n return useContext(TreeRendererContext)!;\n}\n\n// TODO: add animations for rows appearing and disappearing\n\n// TODO: the below is needed so the borders of the top and bottom row isn't cut off if the TreeView is wrapped within a container by always reserving the 2px needed for the\n// keyboard focus ring. Perhaps find a different way of rendering the outlines since the top of the item doesn't\n// scroll into view due to how the ring is offset. Alternatively, have the tree render the top/bottom outline like it does in Listview\nconst tree = style<Pick<TreeRenderProps, 'isEmpty'>>({\n borderWidth: 2,\n boxSizing: 'border-box',\n borderXWidth: 0,\n borderStyle: 'solid',\n borderColor: {\n default: 'transparent',\n forcedColors: 'Background'\n },\n justifyContent: {\n isEmpty: 'center'\n },\n alignItems: {\n isEmpty: 'center'\n },\n width: {\n isEmpty: 'full'\n },\n height: {\n isEmpty: 'full'\n },\n display: {\n isEmpty: 'flex'\n }\n});\n\nfunction TreeView<T extends object>(props: SpectrumTreeViewProps<T>, ref: DOMRef<HTMLDivElement>) {\n let {children, selectionStyle} = props;\n\n let renderer;\n if (typeof children === 'function') {\n renderer = children;\n }\n\n let {styleProps} = useStyleProps(props);\n let domRef = useDOMRef(ref);\n let selectionBehavior = selectionStyle === 'highlight' ? 'replace' : 'toggle';\n\n return (\n <TreeRendererContext.Provider value={{renderer}}>\n <UNSTABLE_Tree {...props} {...styleProps} className={({isEmpty}) => tree({isEmpty})} selectionBehavior={selectionBehavior as SelectionBehavior} ref={domRef}>\n {props.children}\n </UNSTABLE_Tree>\n </TreeRendererContext.Provider>\n );\n}\n\ninterface TreeRowRenderProps extends TreeItemRenderProps {\n isLink?: boolean\n}\n\nconst treeRow = style<TreeRowRenderProps>({\n position: 'relative',\n display: 'flex',\n height: 10,\n width: 'full',\n boxSizing: 'border-box',\n fontSize: 'base',\n fontWeight: 'normal',\n lineHeight: 200,\n color: 'body',\n outlineStyle: 'none',\n cursor: {\n default: 'default',\n isLink: 'pointer'\n },\n // TODO: not sure where to get the equivalent colors here, for instance isHovered is spectrum 600 with 10% opacity but I don't think that exists in the theme\n backgroundColor: {\n isHovered: '[var(--spectrum-table-row-background-color-hover)]',\n isFocusVisibleWithin: '[var(--spectrum-table-row-background-color-hover)]',\n isPressed: '[var(--spectrum-table-row-background-color-down)]',\n isSelected: '[var(--spectrum-table-row-background-color-selected)]'\n }\n});\n\nconst treeCellGrid = style({\n display: 'grid',\n width: 'full',\n alignItems: 'center',\n // TODO: needed to use spectrum var since gridTemplateColumns uses baseSizing and not scaled sizing\n gridTemplateColumns: ['minmax(0, auto)', 'minmax(0, auto)', 'minmax(0, auto)', 'var(--spectrum-global-dimension-size-500)', 'minmax(0, auto)', '1fr', 'minmax(0, auto)', 'auto'],\n gridTemplateRows: '1fr',\n gridTemplateAreas: [\n 'drag-handle checkbox level-padding expand-button icon content actions actionmenu'\n ],\n color: {\n isDisabled: {\n default: 'gray-400',\n forcedColors: 'GrayText'\n }\n }\n});\n\n// TODO: These styles lose against the spectrum class names, so I've did unsafe for the ones that get overridden\nconst treeCheckbox = style({\n gridArea: 'checkbox',\n transitionDuration: '160ms',\n marginStart: 3,\n marginEnd: 0\n});\n\nconst treeIcon = style({\n gridArea: 'icon',\n marginEnd: 2\n});\n\nconst treeContent = style<Pick<TreeItemContentRenderProps, 'isDisabled'>>({\n gridArea: 'content',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n overflow: 'hidden'\n});\n\nconst treeActions = style({\n gridArea: 'actions',\n flexGrow: 0,\n flexShrink: 0,\n /* TODO: I made this one up, confirm desired behavior. These paddings are to make sure the action group has enough padding for the focus ring */\n marginStart: .5,\n marginEnd: 1\n});\n\nconst treeActionMenu = style({\n gridArea: 'actionmenu',\n width: 8\n});\n\nconst treeRowOutline = style({\n content: '',\n display: 'block',\n position: 'absolute',\n insetStart: 0,\n insetEnd: 0,\n top: {\n default: 0,\n isFocusVisible: '[-2px]',\n isSelected: {\n default: '[-1px]',\n isFocusVisible: '[-2px]'\n }\n },\n bottom: 0,\n pointerEvents: 'none',\n forcedColorAdjust: 'none',\n\n boxShadow: {\n isFocusVisible: '[inset 2px 0 0 0 var(--spectrum-alias-focus-color), inset -2px 0 0 0 var(--spectrum-alias-focus-color), inset 0 -2px 0 0 var(--spectrum-alias-focus-color), inset 0 2px 0 0 var(--spectrum-alias-focus-color)]',\n isSelected: {\n default: '[inset 1px 0 0 0 var(--spectrum-alias-focus-color), inset -1px 0 0 0 var(--spectrum-alias-focus-color), inset 0 -1px 0 0 var(--spectrum-alias-focus-color), inset 0 1px 0 0 var(--spectrum-alias-focus-color)]',\n isFocusVisible: '[inset 2px 0 0 0 var(--spectrum-alias-focus-color), inset -2px 0 0 0 var(--spectrum-alias-focus-color), inset 0 -2px 0 0 var(--spectrum-alias-focus-color), inset 0 2px 0 0 var(--spectrum-alias-focus-color)]'\n },\n forcedColors: {\n isFocusVisible: '[inset 2px 0 0 0 Highlight, inset -2px 0 0 0 Highlight, inset 0 -2px 0 0 Highlight, inset 0 2px 0 0 Highlight]',\n isSelected: {\n default: '[inset 1px 0 0 0 Highlight, inset -1px 0 0 0 Highlight, inset 0 -1px 0 0 Highlight, inset 0 1px 0 0 Highlight]',\n isFocusVisible: '[inset 2px 0 0 0 Highlight, inset -2px 0 0 0 Highlight, inset 0 -2px 0 0 Highlight, inset 0 2px 0 0 Highlight]'\n }\n }\n }\n});\n\nexport const TreeViewItem = <T extends object>(props: SpectrumTreeViewItemProps<T>) => {\n let {\n children,\n childItems,\n hasChildItems,\n href\n } = props;\n\n let content;\n let nestedRows;\n let {renderer} = useTreeRendererContext();\n // TODO alternative api is that we have a separate prop for the TreeItems contents and expect the child to then be\n // a nested tree item\n\n if (typeof children === 'string') {\n content = <Text>{children}</Text>;\n } else {\n content = [];\n nestedRows = [];\n React.Children.forEach(children, node => {\n if (isValidElement(node) && node.type === TreeViewItem) {\n nestedRows.push(node);\n } else {\n content.push(node);\n }\n });\n }\n\n if (childItems != null && renderer) {\n nestedRows = (\n <Collection items={childItems}>\n {renderer}\n </Collection>\n );\n }\n\n return (\n // TODO right now all the tree rows have the various data attributes applied on their dom nodes, should they? Doesn't feel very useful\n <UNSTABLE_TreeItem\n {...props}\n className={renderProps => treeRow({\n ...renderProps,\n isLink: !!href\n })}>\n <UNSTABLE_TreeItemContent>\n {({isExpanded, hasChildRows, level, selectionMode, selectionBehavior, isDisabled, isSelected, isFocusVisible}) => (\n <div className={treeCellGrid({isDisabled})}>\n {selectionMode !== 'none' && selectionBehavior === 'toggle' && (\n // TODO: add transition?\n <Checkbox\n isEmphasized\n UNSAFE_className={treeCheckbox()}\n UNSAFE_style={{paddingInlineEnd: '0px'}}\n slot=\"selection\" />\n )}\n <div style={{gridArea: 'level-padding', marginInlineEnd: `calc(${level - 1} * var(--spectrum-global-dimension-size-200))`}} />\n {/* TODO: revisit when we do async loading, at the moment hasChildItems will only cause the chevron to be rendered, no aria/data attributes indicating the row's expandability are added */}\n {(hasChildRows || hasChildItems) && <ExpandableRowChevron isDisabled={isDisabled} isExpanded={isExpanded} />}\n <SlotProvider\n slots={{\n text: {UNSAFE_className: treeContent({isDisabled})},\n // Note there is also an issue here where these icon props are making into the action menu's icon. Resolved by 8ab0ffb276ff437a65b365c9a3be0323a1b24656\n // but could crop up later for other components\n icon: {UNSAFE_className: treeIcon(), size: 'S'},\n actionButton: {UNSAFE_className: treeActions(), isQuiet: true},\n actionGroup: {\n UNSAFE_className: treeActions(),\n isQuiet: true,\n density: 'compact',\n buttonLabelBehavior: 'hide',\n isDisabled,\n overflowMode: 'collapse'\n },\n actionMenu: {UNSAFE_className: treeActionMenu(), UNSAFE_style: {marginInlineEnd: '.5rem'}, isQuiet: true}\n }}>\n {content}\n </SlotProvider>\n <div className={treeRowOutline({isFocusVisible, isSelected})} />\n </div>\n )}\n </UNSTABLE_TreeItemContent>\n {nestedRows}\n </UNSTABLE_TreeItem>\n );\n};\n\ninterface ExpandableRowChevronProps {\n isExpanded?: boolean,\n isDisabled?: boolean,\n isRTL?: boolean\n}\n\nconst expandButton = style<ExpandableRowChevronProps>({\n gridArea: 'expand-button',\n height: 'full',\n aspectRatio: 'square',\n display: 'flex',\n flexWrap: 'wrap',\n alignContent: 'center',\n justifyContent: 'center',\n outlineStyle: 'none',\n transform: {\n isExpanded: {\n default: 'rotate(90deg)',\n isRTL: 'rotate(-90deg)'\n }\n },\n transition: '[transform ease var(--spectrum-global-animation-duration-100)]'\n});\n\nfunction ExpandableRowChevron(props: ExpandableRowChevronProps) {\n let expandButtonRef = useRef<HTMLSpanElement>(null);\n let [fullProps, ref] = useContextProps({...props, slot: 'chevron'}, expandButtonRef, ButtonContext);\n let {isExpanded, isDisabled} = fullProps;\n let {direction} = useLocale();\n\n // Will need to keep the chevron as a button for iOS VO at all times since VO doesn't focus the cell. Also keep as button if cellAction is defined by the user in the future\n let {buttonProps} = useButton({\n ...fullProps,\n elementType: 'span'\n }, ref);\n\n return (\n <span\n {...buttonProps}\n ref={ref}\n // Override tabindex so that grid keyboard nav skips over it. Needs -1 so android talkback can actually \"focus\" it\n tabIndex={isAndroid() && !isDisabled ? -1 : undefined}\n className={expandButton({isExpanded, isDisabled, isRTL: direction === 'rtl'})}>\n {direction === 'ltr' ? <ChevronRightMedium /> : <ChevronLeftMedium />}\n </span>\n );\n}\n\n/**\n * A tree view provides users with a way to navigate nested hierarchical information.\n */\nconst _TreeView = React.forwardRef(TreeView) as <T>(props: SpectrumTreeViewProps<T> & {ref?: DOMRef<HTMLDivElement>}) => ReactElement;\nexport {_TreeView as TreeView};\n"],"names":[],"version":3,"file":"TreeView.main.js.map"}