Skip to content

Conversation

@smhigley
Copy link
Contributor

@smhigley smhigley commented Feb 6, 2024

Previous Behavior

Related to #27002

GroupedList internally used List, because of the same bug in the linked issue, the internal FocusZone was not setting focus on the first row in the List.

Instead, focus went to the first tabbable item in the content of the List (usually the checkbox), which meant arrow key interaction and screen reader behavior was not correct.

Additionally, the focus outline was not showing up since GroupedList does not initiate FocusRects itself (this only repros if you create a sandbox with only GroupedList and no other Fluent controls, since other controls will initate FocusRects if included).

New Behavior

Sets the renderEarly flag on List, so FocusZone can set tabIndex on the first row in List. Also adds FocusRects to GroupedList.

Related Issue(s)

@smhigley smhigley requested review from a team, ThomasMichon and spmonahan as code owners February 6, 2024 01:28
@codesandbox-ci
Copy link

codesandbox-ci bot commented Feb 6, 2024

This pull request is automatically built and testable in CodeSandbox.

To see build info of the built libraries, click here or the icon next to each commit SHA.

Latest deployment of this branch, based on commit 14d8d72:

Sandbox Source
@fluentui/react 8 starter Configuration
@fluentui/react-components 9 starter Configuration

@fabricteam
Copy link
Collaborator

fabricteam commented Feb 6, 2024

🕵 fluentuiv8 No visual regressions between this PR and main

@fabricteam
Copy link
Collaborator

fabricteam commented Feb 6, 2024

📊 Bundle size report

Package & Exports Baseline (minified/GZIP) PR Change
react
DetailsList
225.886 kB
64.647 kB
225.926 kB
64.655 kB
40 B
8 B
react
GroupedList
131.636 kB
39.657 kB
131.722 kB
39.697 kB
86 B
40 B
react
ShimmeredDetailsList
236.654 kB
67.42 kB
236.694 kB
67.427 kB
40 B
7 B
Unchanged fixtures
Package & Exports Size (minified/GZIP)
react
ActivityItem
68.833 kB
22.613 kB
react
Announced
36.473 kB
12.628 kB
react
Autofill
15.365 kB
4.743 kB
react
Breadcrumb
196.083 kB
58.757 kB
react
Button
190.127 kB
55.019 kB
react
ButtonGrid
175.918 kB
53.25 kB
react
Calendar
118.756 kB
36.101 kB
react
Callout
80.866 kB
26.564 kB
react
Check
51.062 kB
17.152 kB
react
Checkbox
57.791 kB
19.17 kB
react
ChoiceGroup
63.339 kB
20.824 kB
react
ChoiceGroupOption
56.601 kB
18.695 kB
react
Coachmark
89.633 kB
28.377 kB
react
Color
7.737 kB
3.106 kB
react
ColorPicker
129.984 kB
40.589 kB
react
ComboBox
245.355 kB
70.51 kB
react
CommandBar
197.362 kB
58.46 kB
react
ContextualMenu
150.967 kB
46.982 kB
react
DatePicker
180.203 kB
54.911 kB
react
DateTimeUtilities
5.244 kB
1.849 kB
react
Dialog
205.294 kB
61.428 kB
react
Divider
17.63 kB
6.234 kB
react
DocumentCard
211.08 kB
62.793 kB
react
DragDrop
8.343 kB
2.724 kB
react
DraggableZone
33.345 kB
11.166 kB
react
Dropdown
227.732 kB
66.867 kB
react
ExtendedPicker
94.987 kB
27.297 kB
react
Fabric
39.75 kB
13.688 kB
react
Facepile
205.992 kB
61.67 kB
react
FloatingPicker
236.233 kB
67.368 kB
react
FocusTrapZone
15.831 kB
5.54 kB
react
FocusZone
53.259 kB
16.869 kB
react
Grid
175.918 kB
53.25 kB
react
GroupedListV2
119.324 kB
36.822 kB
react
HoverCard
93.735 kB
29.778 kB
react
Icon
49.74 kB
16.603 kB
react
Icons
65.829 kB
24.212 kB
react
Image
44.79 kB
15.024 kB
react
Keytip
78.588 kB
25.825 kB
react
KeytipData
13.585 kB
4.418 kB
react
KeytipLayer
100.422 kB
31.128 kB
react
Keytips
103.175 kB
32.07 kB
react
Label
36.347 kB
12.639 kB
react
Layer
45.683 kB
15.585 kB
react
Link
37.673 kB
12.993 kB
react
List
38.136 kB
12.004 kB
react
MarqueeSelection
72.119 kB
21.676 kB
react
MessageBar
184.707 kB
55.523 kB
react
Modal
90.409 kB
29.213 kB
react
Nav
183.442 kB
55.093 kB
react
OverflowSet
31.044 kB
10.593 kB
react
Overlay
38.784 kB
13.401 kB
react
Panel
194.946 kB
58.34 kB
react
Persona
111.705 kB
35.58 kB
react
PersonaCoin
111.705 kB
35.58 kB
react
PersonaPresence
55.928 kB
18.715 kB
react
Pickers
287.603 kB
80.607 kB
react
Pivot
184.252 kB
55.823 kB
react
Popup
12.032 kB
4.114 kB
react
Positioning
21.821 kB
7.334 kB
react
PositioningContainer
70.754 kB
22.84 kB
react
ProgressIndicator
37.498 kB
12.906 kB
react
Rating
78.989 kB
25.18 kB
react
ResizeGroup
13.286 kB
4.365 kB
react
ResponsiveMode
8.078 kB
2.95 kB
react
ScrollablePane
53.538 kB
17.113 kB
react
SearchBox
182.982 kB
55.1 kB
react
SelectableOption
724 B
413 B
react
SelectedItemsList
226.659 kB
66.321 kB
react
Selection
41.202 kB
11.839 kB
react
Separator
33.397 kB
11.529 kB
react
Shimmer
47.265 kB
15.632 kB
react
Slider
55.575 kB
18.574 kB
react
SpinButton
186.661 kB
56.205 kB
react
Spinner
39.691 kB
13.815 kB
react
Stack
40.761 kB
13.931 kB
react
Sticky
32.064 kB
10.324 kB
react
Styling
44.812 kB
14.688 kB
react
SwatchColorPicker
186.166 kB
56.724 kB
react
TeachingBubble
200.004 kB
59.345 kB
react
Text
35.931 kB
12.486 kB
react
TextField
78.587 kB
24.642 kB
react
Theme
42.456 kB
13.773 kB
react
ThemeGenerator
12.34 kB
4.106 kB
react
TimePicker
235.197 kB
68.29 kB
react
Toggle
44.17 kB
15.346 kB
react
Tooltip
84.225 kB
27.277 kB
react
Utilities
71.851 kB
21.843 kB
react
Viewport
22.945 kB
7.292 kB
react
WeeklyDayPicker
98.762 kB
30.828 kB
react
WindowProvider
1.059 kB
541 B
🤖 This report was generated against 7b89afa6ca231f610fcb26f5d816e0b86faec3d9

@fabricteam
Copy link
Collaborator

fabricteam commented Feb 6, 2024

Perf Analysis (@fluentui/react)

Scenario Render type Master Ticks PR Ticks Iterations Status
GroupedList mount 42349 26380 2 Possible regression
GroupedList virtual-rerender 20496 12827 2 Possible regression
GroupedList virtual-rerender-with-unmount 51645 43790 2 Possible regression
All results

Scenario Render type Master Ticks PR Ticks Iterations Status
BaseButton mount 625 630 5000
Breadcrumb mount 1699 1674 1000
Checkbox mount 1707 1718 5000
CheckboxBase mount 1462 1478 5000
ChoiceGroup mount 2948 2992 5000
ComboBox mount 645 669 1000
CommandBar mount 6329 6299 1000
ContextualMenu mount 12708 12775 1000
DefaultButton mount 764 762 5000
DetailsRow mount 2220 2181 5000
DetailsRowFast mount 2243 2225 5000
DetailsRowNoStyles mount 2015 2084 5000
Dialog mount 2686 2689 1000
DocumentCardTitle mount 228 233 1000
Dropdown mount 1998 1994 5000
FocusTrapZone mount 1157 1176 5000
FocusZone mount 1139 1115 5000
GroupedList mount 42349 26380 2 Possible regression
GroupedList virtual-rerender 20496 12827 2 Possible regression
GroupedList virtual-rerender-with-unmount 51645 43790 2 Possible regression
GroupedListV2 mount 226 222 2
GroupedListV2 virtual-rerender 206 214 2
GroupedListV2 virtual-rerender-with-unmount 232 231 2
IconButton mount 1136 1105 5000
Label mount 332 324 5000
Layer mount 2773 2751 5000
Link mount 385 385 5000
MenuButton mount 949 953 5000
MessageBar mount 21506 21535 5000
Nav mount 1958 1987 1000
OverflowSet mount 786 789 5000
Panel mount 1855 1814 1000
Persona mount 754 751 1000
Pivot mount 891 892 1000
PrimaryButton mount 839 855 5000
Rating mount 4622 4714 5000
SearchBox mount 943 909 5000
Shimmer mount 1901 1867 5000
Slider mount 1322 1332 5000
SpinButton mount 2906 2888 5000
Spinner mount 388 393 5000
SplitButton mount 1857 1848 5000
Stack mount 419 407 5000
StackWithIntrinsicChildren mount 859 836 5000
StackWithTextChildren mount 2674 2681 5000
SwatchColorPicker mount 6230 6215 5000
TagPicker mount 1498 1499 5000
Text mount 371 370 5000
TextField mount 919 948 5000
ThemeProvider mount 830 834 5000
ThemeProvider virtual-rerender 592 587 5000
ThemeProvider virtual-rerender-with-unmount 1255 1293 5000
Toggle mount 630 616 5000
buttonNative mount 187 176 5000

usePageCache={usePageCache}
onShouldVirtualize={onShouldVirtualize}
version={version}
renderEarly={true}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm a bit concerned about changing this default behavior as doing so broke TilesList (which is why it's not enabled by default now). This change will also affect DetailsList as GroupedList is used internally for rendering in that control in "grouped" mode. I know we strive to be accessible by default so I like this change in principle -- how confident are you that enabling this won't break GroupedList usage?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I suppose it's impossible to really be sure, since GroupedList seems to get some pretty custom usage.

The only other potential approach I can think of would be to manually apply tabIndex={0} to the first GroupHeader, though that's equally buggy since it wouldn't help folks using custom GroupHeaders. It also seems potentially a little less reliable than letting the FocusZone take care of applying tabIndex.

Thoughts on which is better?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe the answer here to allow people to opt out of early rendering?

renderEarly={typeof props.renderEarly === 'boolean' ? props.renderEarly : true}

(perhaps there is a less verbose way of writing that).

The early rendering is a better option as it addresses the underlying issue of the DOM just not being present but it is also much more likely to break something using GroupedList as it changes the rendering behavior. tabIndex is better in that it is highly unlikely to break rendering.

Allowing folks to opt out will at least give people an easy change should they need it. That said, there is an argument that this is a breaking change and we should rather require users to opt in.

Not a serious suggestion: GroupedListV3: now with early rendering?

... actually that last suggestion got me thinking: is this an issue with GroupedListV2? The rendering is quite different so it may not be (though it still ultimately uses List).

shouldEnterInnerZone={shouldEnterInnerZone}
className={css(this._classNames.root, focusZoneProps.className)}
>
<FocusRects />
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we need to make the same change for GroupedListV2?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants