style(urls): Updated link style to round chips (#1010)

* style(urls): Updated link style to round chips

* restored RawLink changes

* feat:(rounded): introduced newchip varient rounded

* feat(rounded-link): added rounded link component
This commit is contained in:
Shobhit Gupta 2023-08-06 00:20:59 +05:30 committed by GitHub
parent 2d5ad60aeb
commit 7028a8098e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 89 additions and 11 deletions

View File

@ -17,6 +17,7 @@ export enum ChipVariant {
Highlighted = 'highlighted', Highlighted = 'highlighted',
Regular = 'regular', Regular = 'regular',
Transparent = 'transparent', Transparent = 'transparent',
Rounded = 'rounded',
} }
type OwnProps = { type OwnProps = {
@ -38,8 +39,18 @@ const StyledContainer = styled.div<Partial<OwnProps>>`
background-color: ${({ theme, variant }) => background-color: ${({ theme, variant }) =>
variant === ChipVariant.Highlighted variant === ChipVariant.Highlighted
? theme.background.transparent.light ? theme.background.transparent.light
: variant === ChipVariant.Rounded
? theme.background.transparent.lighter
: 'transparent'}; : 'transparent'};
border-radius: ${({ theme }) => theme.border.radius.sm}; border-color: ${({ theme, variant }) =>
variant === ChipVariant.Rounded ? theme.border.color.medium : 'none'};
border-radius: ${({ theme, variant }) =>
variant === ChipVariant.Rounded ? '50px' : theme.border.radius.sm};
border-style: ${({ variant }) =>
variant === ChipVariant.Rounded ? 'solid' : 'none'};
border-width: ${({ variant }) =>
variant === ChipVariant.Rounded ? '1px' : '0px'};
color: ${({ theme, disabled, accent }) => color: ${({ theme, disabled, accent }) =>
disabled disabled
? theme.font.color.light ? theme.font.color.light
@ -59,7 +70,8 @@ const StyledContainer = styled.div<Partial<OwnProps>>`
max-width: ${({ maxWidth }) => (maxWidth ? maxWidth : '200px')}; max-width: ${({ maxWidth }) => (maxWidth ? maxWidth : '200px')};
overflow: hidden; overflow: hidden;
padding: ${({ theme }) => theme.spacing(1)}; padding: ${({ theme, variant }) =>
variant === ChipVariant.Rounded ? '3px 8px' : theme.spacing(1)};
user-select: none; user-select: none;
:hover { :hover {

View File

@ -1,5 +1,5 @@
import { RawLink } from '@/ui/link/components/RawLink'; import { RoundedLink } from '@/ui/link/components/RoundedLink';
export function FieldDisplayURL({ URL }: { URL: string | undefined }) { export function FieldDisplayURL({ URL }: { URL: string | undefined }) {
return <RawLink href={URL ? 'https://' + URL : ''}>{URL}</RawLink>; return <RoundedLink href={URL ? 'https://' + URL : ''}>{URL}</RoundedLink>;
} }

View File

@ -1,9 +1,9 @@
import { MouseEvent } from 'react'; import { MouseEvent } from 'react';
import styled from '@emotion/styled'; import styled from '@emotion/styled';
import { RawLink } from '@/ui/link/components/RawLink'; import { RoundedLink } from '@/ui/link/components/RoundedLink';
const StyledRawLink = styled(RawLink)` const StyledRawLink = styled(RoundedLink)`
overflow: hidden; overflow: hidden;
a { a {

View File

@ -20,11 +20,15 @@ const StyledClickable = styled.div`
`; `;
export function RawLink({ className, href, children, onClick }: OwnProps) { export function RawLink({ className, href, children, onClick }: OwnProps) {
console.log(children);
return ( return (
<StyledClickable className={className}> <div>
<ReactLink target="_blank" onClick={onClick} to={href}> <StyledClickable className={className}>
{children} <ReactLink target="_blank" onClick={onClick} to={href}>
</ReactLink> {children}
</StyledClickable> </ReactLink>
</StyledClickable>
</div>
); );
} }

View File

@ -0,0 +1,42 @@
import * as React from 'react';
import { Link as ReactLink } from 'react-router-dom';
import styled from '@emotion/styled';
import { Chip } from '@/ui/chip/components/Chip';
import { ChipSize, ChipVariant } from '@/ui/chip/components/Chip';
type OwnProps = {
href: string;
children?: React.ReactNode;
onClick?: (event: React.MouseEvent<HTMLElement>) => void;
};
const StyledClickable = styled.div`
overflow: hidden;
white-space: nowrap;
a {
color: inherit;
text-decoration: none;
}
`;
export function RoundedLink({ children, href, onClick }: OwnProps) {
return (
<div>
{children !== '' ? (
<StyledClickable>
<ReactLink target="_blank" to={href} onClick={onClick}>
<Chip
label={`${children}`}
variant={ChipVariant.Rounded}
size={ChipSize.Large}
/>
</ReactLink>
</StyledClickable>
) : (
<></>
)}
</div>
);
}

View File

@ -0,0 +1,20 @@
import type { Meta, StoryObj } from '@storybook/react';
import { ComponentWithRouterDecorator } from '~/testing/decorators/ComponentWithRouterDecorator';
import { RoundedLink } from '../RoundedLink';
const meta: Meta<typeof RoundedLink> = {
title: 'UI/Links/RoundedLink',
component: RoundedLink,
decorators: [ComponentWithRouterDecorator],
args: {
href: '/test',
children: 'Rounded chip',
},
};
export default meta;
type Story = StoryObj<typeof RoundedLink>;
export const Default: Story = {};