fix: header dropdown item might not be linkable

This commit is contained in:
Sami Mazouz 2024-10-25 16:00:08 +01:00
parent 1ead69e9b6
commit 9f87bf18c2
No known key found for this signature in database
2 changed files with 14 additions and 3 deletions

View File

@ -13,7 +13,7 @@ export interface IHeaderListItemAttrs extends ComponentAttrs {
content: string;
excerpt: string;
datetime?: Date;
href: string;
href?: string | null;
onclick?: (e: Event) => void;
actions?: Mithril.Children;
}
@ -22,8 +22,18 @@ export default class HeaderListItem<CustomAttrs extends IHeaderListItemAttrs = I
view(vnode: Mithril.Vnode<CustomAttrs, this>) {
const { avatar, icon: iconName, content, excerpt, datetime, href, className, onclick, actions, ...attrs } = vnode.attrs;
const Tag = href ? Link : 'button';
return (
<Link className={classList('HeaderListItem', className)} href={href} external={href.includes('://')} onclick={onclick}>
<Tag
className={classList('HeaderListItem', className, {
'Button--ua-reset': Tag === 'button',
})}
href={href}
external={href?.includes('://')}
onclick={onclick}
{...attrs}
>
{avatar}
<Icon name={iconName} className="HeaderListItem-icon" />
<span className="HeaderListItem-title">
@ -33,7 +43,7 @@ export default class HeaderListItem<CustomAttrs extends IHeaderListItemAttrs = I
</span>
<div className="HeaderListItem-actions">{actions}</div>
<div className="HeaderListItem-excerpt">{excerpt}</div>
</Link>
</Tag>
);
}
}

View File

@ -168,6 +168,7 @@
align-items: baseline;
row-gap: 1px;
column-gap: 6px;
cursor: pointer;
// Prevent outline overflowing parent
.add-keyboard-focus-ring-offset(-1px);