Skip to content

Commit

Permalink
Merge pull request #50 from Giveth/add-loading-to-button
Browse files Browse the repository at this point in the history
add loading to buttons
  • Loading branch information
alireza-sharifpour authored Jun 7, 2022
2 parents 2e49221 + b20518f commit 59ede1f
Show file tree
Hide file tree
Showing 5 changed files with 65 additions and 13 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@giveth/ui-design-system",
"version": "1.8.5",
"version": "1.8.6",
"files": [
"/lib"
],
Expand Down
61 changes: 49 additions & 12 deletions src/components/buttons/Button.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import React from 'react';
import { FC } from 'react';
import styled from 'styled-components';
import { brandColors, neutralColors } from '../../common/colors';
import { rotate } from '../../styled-components/animations';
import { ButtonText } from '../typography/ButtonText';
import { IButtonContainerProps, IButtonProps } from './type';

Expand All @@ -16,23 +17,21 @@ const ButtonContainer = styled.button<IButtonContainerProps>`
gap: 4px;
white-space: nowrap;
${props => {
if (props.disabled) {
if (props.buttonType === 'texty') {
return `color: ${brandColors.giv[500]};background: unset};padding: 8px 24px;opacity: 0.5;`;
}
return `color: ${brandColors.giv[400]};background: ${brandColors.giv[500]};opacity: 0.5;`;
}
switch (props.buttonType) {
case 'primary':
return props.disabled
? `color: ${brandColors.giv[400]};background: ${brandColors.giv[500]};opacity: 0.5;`
: `color: ${neutralColors.gray[100]};background: ${brandColors.pinky[500]};`;
return `color: ${neutralColors.gray[100]};background: ${brandColors.pinky[500]};`;
case 'secondary':
return props.disabled
? `color: ${brandColors.giv[400]};background: ${brandColors.giv[500]};opacity: 0.5;`
: `color: ${neutralColors.gray[100]};background: ${brandColors.giv[500]};`;
return `color: ${neutralColors.gray[100]};background: ${brandColors.giv[500]};`;
case 'texty':
return props.disabled
? `color: ${brandColors.giv[500]};background: unset};padding: 8px 24px;opacity: 0.5;`
: `color: ${brandColors.deep[100]};background: unset};padding: 8px 24px;`;
return `color: ${brandColors.deep[100]};background: unset};padding: 8px 24px;`;
default:
return props.disabled
? `color: ${brandColors.giv[400]};background: ${brandColors.giv[500]};opacity: 0.5;`
: `color: ${neutralColors.gray[100]};background: ${brandColors.pinky[500]};`;
return `color: ${neutralColors.gray[100]};background: ${brandColors.pinky[500]};`;
}
}}
${props => (props.disabled ? '' : 'cursor: pointer;')}
Expand All @@ -53,11 +52,44 @@ const ButtonContainer = styled.button<IButtonContainerProps>`
}
`;

const LoadingContainer = styled.div<{ loading: boolean }>`
position: relative;
transition: width 0.3s ease;
width: ${props => (props.loading ? '16px' : 0)};
`;

const Loader = styled.div<IButtonContainerProps>`
border: 3px solid
${props => {
if (props.disabled) return brandColors.giv[600];
switch (props.buttonType) {
case 'primary':
return brandColors.pinky[600];
case 'secondary':
return brandColors.giv[600];
case 'texty':
return brandColors.giv[500];
default:
return brandColors.giv[500];
}
}};
border-radius: 50%;
border-top: 3px solid white;
width: 12px;
height: 12px;
animation: ${rotate} 1s ease infinite;
position: absolute;
top: -8px;
left: -8px;
`;

export const Button: FC<IButtonProps> = ({
label,
size = 'medium',
buttonType = 'secondary',
disabled = false,
loading = false,
onClick,
icon,
className,
Expand All @@ -70,6 +102,11 @@ export const Button: FC<IButtonProps> = ({
onClick={onClick}
className={className}
>
<LoadingContainer loading={loading}>
{loading && (
<Loader buttonType={buttonType} disabled={disabled} />
)}
</LoadingContainer>
<ButtonText size={size}>{label}</ButtonText>
{icon && icon}
</ButtonContainer>
Expand Down
1 change: 1 addition & 0 deletions src/components/buttons/type.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ export interface IButtonContainerProps {
buttonType?: 'primary' | 'secondary' | 'texty';
size?: 'small' | 'medium' | 'large';
disabled?: boolean;
loading?: boolean;
onClick?: MouseEventHandler<HTMLButtonElement>;
icon?: ReactNode;
className?: string;
Expand Down
3 changes: 3 additions & 0 deletions src/stories/Button.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ Primary.args = {
label: 'Primary',
size: 'medium',
disabled: false,
loading: false,
};

export const Secondary = Template.bind({});
Expand All @@ -26,6 +27,7 @@ Secondary.args = {
label: 'Secondary',
size: 'medium',
disabled: false,
loading: false,
};

export const Texty = Template.bind({});
Expand All @@ -34,4 +36,5 @@ Texty.args = {
label: 'Texty',
size: 'medium',
disabled: false,
loading: false,
};
11 changes: 11 additions & 0 deletions src/styled-components/animations.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { keyframes } from 'styled-components';

export const rotate = keyframes`
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
`;

0 comments on commit 59ede1f

Please sign in to comment.