Page MenuHomePhabricator

When picking a default menu item to render, don't pick disabled items
ClosedPublic

Authored by epriestley on Mar 31 2019, 9:13 PM.
Tags
None
Referenced Files
F15540116: D20359.diff
Fri, Apr 25, 6:35 AM
F15489684: D20359.diff
Fri, Apr 11, 11:23 AM
F15462427: D20359.id48610.diff
Tue, Apr 1, 3:05 PM
F15442397: D20359.id.diff
Mar 26 2025, 11:11 PM
F15381001: D20359.id48610.diff
Mar 14 2025, 5:25 AM
F15334957: D20359.diff
Mar 8 2025, 1:15 PM
Unknown Object (File)
Feb 26 2025, 8:04 PM
Unknown Object (File)
Feb 26 2025, 8:03 PM
Subscribers
None

Details

Summary

Depends on D20358. Fixes T12871. After refactoring, we can now tell when a "storage" menu item generated only disabled "display" menu items, and not pick any of them as the default rendering.

This means that if you're looking at a portal/menu with several dashboards, but can't see some at the top, you'll get the first one you can see.

Also clean up a lot of minor issues with less-common states.

Test Plan
  • Created a portal with two private dashboards and a public dashboard.
  • Viewed it as another user, saw the default view show the dashboard I can actually see.
  • Minor fix: Disabled and enabled the hard-coded "Home" item, now worked cleanly with the right menu state.
  • Minor fix: added a motivator panel.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

src/applications/search/engine/PhabricatorProfileMenuItemViewList.php
96–101

This is the actual fix to T12871 after shuffling a thousand lines of code around.

This revision is now accepted and ready to land.Apr 2 2019, 9:01 PM
This revision was automatically updated to reflect the committed changes.