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
F19153222: D20359.id.diff
Thu, Dec 11, 8:23 AM
F19130222: D20359.diff
Wed, Dec 10, 4:47 AM
F18870231: D20359.id.diff
Nov 4 2025, 4:05 PM
F18869185: D20359.diff
Nov 4 2025, 10:18 AM
F18837145: D20359.diff
Oct 27 2025, 4:33 AM
F18809030: D20359.id.diff
Oct 19 2025, 10:40 AM
F18790736: D20359.id48579.diff
Oct 15 2025, 5:53 PM
F18780612: D20359.id48610.diff
Oct 12 2025, 5:52 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.