mirror of
https://github.com/twentyhq/twenty.git
synced 2024-12-18 09:02:11 +03:00
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:
parent
2d5ad60aeb
commit
7028a8098e
@ -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 {
|
||||||
|
@ -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>;
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
42
front/src/modules/ui/link/components/RoundedLink.tsx
Normal file
42
front/src/modules/ui/link/components/RoundedLink.tsx
Normal 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>
|
||||||
|
);
|
||||||
|
}
|
@ -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 = {};
|
Loading…
Reference in New Issue
Block a user