1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/dashboard/client/components/button/button.tsx
Sebastian Malton b1ff34879a cleanup Lens repo with tighter linting
Signed-off-by: Sebastian Malton <smalton@mirantis.com>
2020-07-09 17:00:23 -04:00

78 lines
1.6 KiB
TypeScript

import "./button.scss";
import React, { ButtonHTMLAttributes, ReactNode } from "react";
import { cssNames } from "../../utils";
import { TooltipDecoratorProps, withTooltip } from "../tooltip";
export interface ButtonProps extends ButtonHTMLAttributes<any>, TooltipDecoratorProps {
label?: React.ReactNode;
waiting?: boolean;
primary?: boolean;
accent?: boolean;
plain?: boolean;
hidden?: boolean;
active?: boolean;
big?: boolean;
round?: boolean;
href?: string; // render as hyperlink
target?: "_blank"; // in case of using @href
}
@withTooltip
export class Button extends React.PureComponent<ButtonProps, {}> {
private link: HTMLAnchorElement;
private button: HTMLButtonElement;
render(): JSX.Element {
const {
className,
waiting,
label,
primary,
accent,
plain,
hidden,
active,
big,
round,
tooltip: _tooltip,
children,
...props
} = this.props;
const btnProps = props as Partial<ButtonProps>;
if (hidden) {
return null;
}
btnProps.className = cssNames('Button', className, {
waiting, primary, accent, plain, active, big, round,
});
const btnContent: ReactNode = (
<>
{label}
{children}
</>
);
// render as link
if (this.props.href) {
return (
<a {...btnProps} ref={(e): void => {
this.link = e;
}}>
{btnContent}
</a>
);
}
// render as button
return (
<button type="button" {...btnProps} ref={(e): void => {
this.button = e;
}}>
{btnContent}
</button>
);
}
}