-
Notifications
You must be signed in to change notification settings - Fork 6
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix sidenavs not redering for lovell facility pages #226
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -133,3 +133,34 @@ export function isLovellBifurcatedResource( | |
isLovellFederalResource(resource as LovellBifurcatedFormattedResource) | ||
) | ||
} | ||
|
||
export function getLovellVariantOfMenu(menu, variant: LovellVariant) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. SHOULD Also, noting here because it's semi-related, but not related to code from this PR (I noticed it when examining what a type definition for
The name of the Lovell menu should be the Federal name, likely. It's different than all the others in that it has three top-level items. This is just grabbing the first one, which is TRICARE. It might not ultimately matter, but it is technically not correct, and might make things confusing. Or, perhaps, this should not be setting a name at all at this point. I don't want to put a ton of specific business logic in at this layer, so I'd love to see this more generally handle menu data rather than assuming that there's only one top-level item. I think we (@jtmst, @ryguyk, @tjheffner) might want to sync up on this and chat about some of the architectural implications. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Going to leave this as is to be addressed in future issue per this discussion: https://dsva.slack.com/archives/C01SR56755H/p1698932592500079
tjheffner marked this conversation as resolved.
Show resolved
Hide resolved
|
||
if (!menu || typeof menu !== 'object') return menu | ||
|
||
// Check if the object has the fieldMenuSection and it doesn't match the variant or is 'both' | ||
if ( | ||
menu.fieldMenuSection && | ||
menu.fieldMenuSection !== variant && | ||
menu.fieldMenuSection !== 'both' | ||
) { | ||
return null | ||
} | ||
|
||
// Filter arrays | ||
if (Array.isArray(menu)) { | ||
return menu | ||
.map((item) => getLovellVariantOfMenu(item, variant)) | ||
.filter((item) => item !== null) | ||
} | ||
|
||
// Filter objects | ||
const newData = {} | ||
for (const key in menu) { | ||
const filteredData = getLovellVariantOfMenu(menu[key], variant) | ||
if (filteredData !== null) { | ||
newData[key] = filteredData | ||
} | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm not sure about this. Let's sync up and discuss some things. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I understand what's going on here, but it feels a bit weird to me. It took me a bit to wrap my head around why there's "Filter arrays" and "Filter objects". I think that kind of muddies the situation a bit. It doesn't seem like we'd ever need to worry about objects separately, as the recursion should always be on the The following code might not be perfect, as it depends on some of the other restructuring that we discussed, but it seems to me that this function should look something like this (general idea):
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Updated this logic for clarity, thanks for the feedback |
||
|
||
return newData | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
CONSIDER
I think I'd prefer this to not be
field...
. A big part of theformatter
step, I think, is to move away from the Drupal-specific naming. MaybemenuSection
or justsection
. Or, if this is only for Lovell and likely only ever will be, then maybelovellSection
?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
completely agree here.
lovellSection
feels appropriate, and clearer for future debuggersThere was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Makes sense to me, fixed