Skip to content
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(Link): address problems with link color inheritance #1975

Merged
merged 1 commit into from
Jun 6, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 16 additions & 0 deletions src/components/AppNotification/AppNotification.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import React from 'react';
import { AppNotification } from './AppNotification';
import { ButtonV2 as Button } from '../Button';
import { ButtonGroupV2 as ButtonGroup } from '../ButtonGroup';
import { LinkV2 as Link } from '../Link';
import Text from '../Text';

export default {
title: 'Components/V2/AppNotification',
Expand Down Expand Up @@ -52,6 +54,20 @@ export const WithControls: StoryObj<Args> = {
},
};

export const WithLinkInSubtitle: StoryObj<Args> = {
args: {
subTitle: (
<Text as="span">
Some text with a{' '}
<Link href="https://example.com/" variant="inverse">
link
</Link>{' '}
in.
</Text>
),
},
};

export const LightColor: StoryObj<Args> = {
args: {
color: 'light',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -282,3 +282,43 @@ exports[`<AppNotification /> WithDismissAndControls story renders snapshot 1`] =
</div>
</div>
`;

exports[`<AppNotification /> WithLinkInSubtitle story renders snapshot 1`] = `
<div
class="app-notification app-notification--color-dark"
role="status"
>
<div
class="app-notification__content"
>
<section>
<div
class="text text--headline-sm-bold app-notification__title"
>
This is an AppNotification title
</div>
<p
class="text text--body-md app-notification__sub-title"
>
<span
class="text text--body-md"
>
Some text with a

<a
class="link link--emphasis-default link--size-md link--variant-inverse"
href="https://example.com/"
>
link
</a>

in.
</span>
</p>
<div
class="app-notification__actions"
/>
</section>
</div>
</div>
`;
32 changes: 17 additions & 15 deletions src/components/Link/Link-v2.module.css
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@
*/

.link {
color: var(--eds-theme-color-text-utility-default-primary);
display: inline;

/* TODO: verify the way to sync type tokens and one-off treatments */
Expand All @@ -17,7 +16,7 @@
}

/**
* Sub-components
* Sub-components (only should apply to standalone links
*/
.link__icon {
padding-left: 0.25rem;
Expand All @@ -37,6 +36,15 @@
.link--context-standalone {
display: block;

&.link--emphasis-default {
color: var(--eds-theme-color-text-utility-default-primary);
}

&.link--emphasis-low {
color: var(--eds-theme-color-text-utility-default-primary);
text-decoration: none;
}

/**
* Sizes - using the presets for type ramp matching body-*
*/
Expand Down Expand Up @@ -64,31 +72,25 @@
/**
* Emphasis
*/
.link--emphasis-high {
color: var(--eds-theme-color-text-utility-interactive-secondary);
.link--emphasis-default {
color: inherit;
}

.link--emphasis-low {
color: var(--eds-theme-color-text-utility-default-primary);
text-decoration: none;
.link--emphasis-high {
color: var(--eds-theme-color-text-utility-interactive-secondary);
}

/**
* Variants
* Inverse variant
*/
.link.link--variant-inverse {
color: var(--eds-theme-color-text-utility-inverse);

&:active,
&:visited {
.link.link--variant-inverse:hover,
.link.link--variant-inverse:active {
color: var(--eds-theme-color-text-utility-inverse);
}
}

/**
* States
*/

.link:hover {
color: var(--eds-theme-color-text-utility-interactive-secondary-hover);
}
Expand Down
76 changes: 64 additions & 12 deletions src/components/Link/Link-v2.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,22 @@ export default {
args: {
children: 'Link',
size: 'lg',
href: 'https://go.czi.team/eds',
href: 'http://example.org/',
// stop link from navigating to another page so we can click the link for testing
onClick: (event: any) => event.preventDefault(),
},
decorators: [
(Story) => <div className="text-utility-default-primary">{Story()}</div>,
],
} as Meta<Args>;

type Args = React.ComponentProps<typeof Link>;

export const Default: StoryObj<Args> = {};

/**
* When using context, you can specify a trailing icon for the link.
*/
export const LinkWithChevron: StoryObj<Args> = {
args: {
children: 'Default',
Expand All @@ -30,6 +36,9 @@ export const LinkWithChevron: StoryObj<Args> = {
},
};

/**
* When using context, you can specify a trailing icon for the link. When using the open icon, make sure that a new tab/window is opened.
*/
export const LinkWithOpenIcon: StoryObj<Args> = {
args: {
children: 'Default',
Expand All @@ -38,6 +47,9 @@ export const LinkWithOpenIcon: StoryObj<Args> = {
},
};

/**
* You can add formatting to the link if needed.
*/
export const LinkWithFormattedChildren: StoryObj<Args> = {
args: {
children: <em>emphasized link</em>,
Expand All @@ -46,6 +58,9 @@ export const LinkWithFormattedChildren: StoryObj<Args> = {
},
};

/**
* Standalone links can have additional emphasis or minimized emphasis applied.
*/
export const Emphasis: StoryObj<Args> = {
args: {
size: 'md',
Expand Down Expand Up @@ -78,43 +93,76 @@ export const Inverse: StoryObj<Args> = {
// TODO: find a cleaner way to decorate with unavailable tokens using parameters:backgounds:
decorators: [
(Story) => (
<div className="w-96 bg-[var(--eds-color-blue-850)] p-1 text-center">
<div className="w-96 bg-[var(--eds-color-blue-850)] p-1 text-center text-utility-inverse">
{Story()}
</div>
),
],
};

export const LinkInParagraphContext: StoryObj<ExtendArgs> = {
render: (
args: React.JSX.IntrinsicAttributes &
(LinkV2Props & React.RefAttributes<HTMLAnchorElement>),
) => (
render: (args) => (
<div>
Lorem ipsum dolor sit amet,{' '}
<Link {...args} href="https://example.com/">
consectetur adipiscing elit
</Link>
. Morbi porta at ante quis molestie. Nam scelerisque id diam at iaculis.
Nullam sit amet iaculis erat. Nulla id tellus ante.{' '}
<Link {...args} href="https://example.org">
Aliquam pellentesque ipsum sagittis, commodo neque at, ornare est.
Maecenas a malesuada sem, vitae euismod erat. Nullam molestie nunc non
dui dignissim fermentum.
</Link>{' '}
Aliquam id volutpat nulla, sed auctor orci. Fusce cursus leo nisi. Fusce
vehicula vitae nisl nec ultricies. Cras ut enim nec magna semper egestas.
Sed sed quam id nisl bibendum convallis. Proin suscipit, odio{' '}
<Link {...args} href="https://example.edu">
vel pulvinar
</Link>{' '}
euismod, risus eros ullamcorper lectus, non blandit nulla dui eget massa.
</div>
),
};

/**
* Links will inherit the color from the surrounding text color definition (default emphasis, inline links)
*/
export const InheritColor: StoryObj<Args> = {
args: {
children: 'Inheriting',
},
render: (args) => (
<div>
Lorem ipsum dolor sit amet,{' '}
<Link {...args} href="https://go.czi.team/eds">
<Link {...args} href="https://example.com/">
consectetur adipiscing elit
</Link>
. Morbi porta at ante quis molestie. Nam scelerisque id diam at iaculis.
Nullam sit amet iaculis erat. Nulla id tellus ante.{' '}
<Link {...args} href="https://go.czi.team/eds">
<Link {...args} href="https://example.org">
Aliquam pellentesque ipsum sagittis, commodo neque at, ornare est.
Maecenas a malesuada sem, vitae euismod erat. Nullam molestie nunc non
dui dignissim fermentum.
</Link>{' '}
Aliquam id volutpat nulla, sed auctor orci. Fusce cursus leo nisi. Fusce
vehicula vitae nisl nec ultricies. Cras ut enim nec magna semper egestas.
Sed sed quam id nisl bibendum convallis. Proin suscipit, odio{' '}
<Link {...args} href="https://go.czi.team/eds">
<Link {...args} href="https://example.edu">
vel pulvinar
</Link>{' '}
euismod, risus eros ullamcorper lectus, non blandit nulla dui eget massa.
</div>
),
decorators: [
(Story) => <div className="text-utility-critical">{Story()}</div>,
],
};

// Here, we introduce a special type extension to LinkProps, then use it in a
// composed component, to demonstrate the ability to offer custom props to a component
/**
* Here, we introduce a special type extension to LinkProps, then use it in a
* composed component, to demonstrate the ability to offer custom props to a component
*/
type ExtendArgs = LinkV2Props<{ to: string }>;
function ExtendedLink(args: ExtendArgs) {
return (
Expand Down Expand Up @@ -150,7 +198,11 @@ export const UsingExtendedLink: StoryObj<ExtendArgs> = {
render: (args) => (
<div>
Lorem ipsum dolor sit amet,{' '}
<ExtendedLink {...args} href="https://go.czi.team/eds" to="test">
<ExtendedLink
{...args}
href="https://example.org/extended-link/"
to="test"
>
consectetur adipiscing elit
</ExtendedLink>
. Morbi porta at ante quis molestie. Nam scelerisque id diam at iaculis.
Expand Down
2 changes: 2 additions & 0 deletions src/components/Link/Link-v2.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,8 @@ export const Link = forwardRef<HTMLAnchorElement, LinkV2Props>(

const iconSize = size && (['xl', 'lg'].includes(size) ? '1.5rem' : '1rem');

// TODO-AH: Inline links cannot be lowEmphasis (add runtime warning)
// TODO-AH: chevron-right only allowr when lowEmphasis is used (add runtime warning)
return (
<Component className={componentClassName} ref={ref} {...other}>
{children}
Expand Down
Loading
Loading