Skip to content

Commit

Permalink
feat(IconButton): loading state
Browse files Browse the repository at this point in the history
  • Loading branch information
SergeyRoyt committed Mar 20, 2024
1 parent 8309626 commit 8a00891
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 4 deletions.
7 changes: 5 additions & 2 deletions packages/core/src/components/Button/Button.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ export interface ButtonProps extends VibeComponentProps {
successText?: string;
/** loading boolean which switches the text to a loader */
loading?: boolean;
loaderClassName?: string;
style?: React.CSSProperties;
/** displays the active state */
active?: boolean;
Expand Down Expand Up @@ -120,6 +121,7 @@ const Button: VibeComponent<ButtonProps, unknown> & {
successIcon,
style,
loading: isLoading,
loaderClassName,
active,
activeButtonClassName,
id,
Expand Down Expand Up @@ -345,8 +347,8 @@ const Button: VibeComponent<ButtonProps, unknown> & {
if (loading) {
return (
<button {...buttonProps} key={`${id}-loading`}>
<span className={styles.loader}>
<Loader className={styles.loaderSvg} />
<span className={cx(styles.loader, loaderClassName)}>
<Loader className={cx(styles.loaderSvg)} />
<span aria-hidden className={styles.textPlaceholder}>
{buttonContent}
</span>
Expand Down Expand Up @@ -405,6 +407,7 @@ Button.defaultProps = {
successText: "",
successIcon: null,
loading: false,
loaderClassName: undefined,
active: false,
marginRight: false,
marginLeft: false,
Expand Down
14 changes: 13 additions & 1 deletion packages/core/src/components/IconButton/IconButton.module.scss
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,16 @@

.referenceWrapper {
display: inline-flex;
}
}

.loader.loader {
width: 16px;
height: 16px;
&.xxs {
width: 10px;
height: 10px;
svg {
display: block;
}
}
}
7 changes: 6 additions & 1 deletion packages/core/src/components/IconButton/IconButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import { backwardCompatibilityForProperties } from "../../helpers/backwardCompat
import Button from "../Button/Button";
import { BUTTON_ICON_SIZE, ButtonColor, ButtonType } from "../Button/ButtonConstants";
import styles from "./IconButton.module.scss";
import { getStyle } from "../../helpers/typesciptCssModulesHelper";

export interface IconButtonProps extends VibeComponentProps {
/**
Expand Down Expand Up @@ -86,6 +87,7 @@ export interface IconButtonProps extends VibeComponentProps {
insetFocus?: boolean;
/** Specifies the tab order of an element */
tabIndex?: number;
loading?: boolean;
}

const IconButton: VibeComponent<IconButtonProps> & {
Expand Down Expand Up @@ -116,7 +118,8 @@ const IconButton: VibeComponent<IconButtonProps> & {
dataTestId: backwardCompatabilityDataTestId,
"data-testid": dataTestId,
insetFocus = false,
tabIndex
tabIndex,
loading = false
},
ref
) => {
Expand Down Expand Up @@ -198,6 +201,8 @@ const IconButton: VibeComponent<IconButtonProps> & {
style={overrideStyle}
insetFocus={insetFocus}
tabIndex={tabIndex}
loading={loading}
loaderClassName={cx(styles.loader, getStyle(styles, size))}
>
<Icon
icon={icon}
Expand Down

0 comments on commit 8a00891

Please sign in to comment.