-
Notifications
You must be signed in to change notification settings - Fork 1
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
Feat: Introduce NavigationItem
subcomponent and showcase Header with Navigation and Dropdown
#1840
base: feature/unstyled-button
Are you sure you want to change the base?
Feat: Introduce NavigationItem
subcomponent and showcase Header with Navigation and Dropdown
#1840
Conversation
✅ Deploy Preview for spirit-design-system-storybook ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
✅ Deploy Preview for spirit-design-system ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
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.
Nice!
align-items: center; | ||
} | ||
|
||
.NavigationItem--stretchChildren, |
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.
It's just the AlignmentYExtended dictionary alone, isn't it? 🙂 Now it looks a bit strange to me like this, but I think we will be able to get rid of this modifier once we abstract the alignment classes (and people will be able to use also other alignments here if needed).
$link-typography: tokens.$body-small-semibold; | ||
$link-gap: tokens.$space-600; | ||
$link-spacing: tokens.$space-600; | ||
$link-color-state-default: tokens.$component-header-item-state-default; | ||
$link-color-state-hover: tokens.$component-header-item-state-hover; |
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.
Shouldn't these all start with action
instead of link
?
It centers its children vertically if the children are not NavigationAction components or | ||
it does not have the `.NavigationItem--stretchChildren` class. |
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.
I would turn this around so it's more comprehensible (hopefully): If there is a NavigationAction inside or the XY modifier is present, it stretches its content vertically. In all other cases, the content is vertically centered.
display: flex; | ||
align-items: stretch; |
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.
Is it needed? It works without it for me.
@@ -29,7 +29,9 @@ export type NavigationActionProps<E extends ElementType> = { | |||
elementType?: E; | |||
} & NavigationActionBaseProps; | |||
|
|||
export interface SpiritNavigationItemProps extends ChildrenProps, StyleProps {} | |||
export interface SpiritNavigationItemProps extends ChildrenProps, StyleProps { | |||
isStretchingChildren?: boolean; |
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.
🕺 🙈
hasChildrenStretched
/ hasStretchedChildren
Also not great…
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.
hasStrechedContent
/ isContentExpanded
/ hasExpandedContent
...
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.
We have also AlignmentX.STRETCH
.
@@ -43,11 +43,27 @@ import { NavigationItem } from '@lmc-eu/spirit-web-react'; | |||
<NavigationItem>{/* Navigation actions go here */}</NavigationItem>; | |||
``` | |||
|
|||
If the children are not `NavigationAction` components or the `NavigationItem` does not have the | |||
`isStretchingChildren` class, it will centre its children vertically. |
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.
`isStretchingChildren` class, it will centre its children vertically. | |
`isStretchingChildren` prop, it will centre its children vertically. |
Otherwise better than in web
🙂.
<NavigationItem> | ||
<ButtonLink href="#" color="secondary"> | ||
Sign up | ||
Log out |
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.
🎉
I think we are missing a focused state. In both cases, the opened dropdown looks unrelated to the trigger. The only state change is the arrow. I think I was expecting also some color/background change when I clicked the trigger and the dropdown opened. And in the first example, it is maybe even worse. Because I do not know if the user icon is related to the account text and if the dropdown is related to the icon or the text. There is no clue that both are the same component. |
Description
Additional context
Issue reference