2022-06-24 03:16:01 +00:00
|
|
|
import type {
|
|
|
|
AnchorHTMLAttributes,
|
|
|
|
ButtonHTMLAttributes,
|
|
|
|
ReactNode,
|
|
|
|
} from 'react';
|
2022-03-30 09:49:48 +00:00
|
|
|
import { forwardRef } from 'react';
|
|
|
|
import type { IconName } from '../icon';
|
|
|
|
import { Icon } from '../icon';
|
2022-06-24 03:16:01 +00:00
|
|
|
import classnames from 'classnames';
|
2022-03-07 12:27:56 +00:00
|
|
|
|
2022-08-31 04:35:46 +00:00
|
|
|
type ButtonVariant = 'default' | 'primary' | 'secondary';
|
2022-09-12 13:05:39 +00:00
|
|
|
type ButtonSize = 'lg' | 'md' | 'sm' | 'xs';
|
2022-08-31 04:35:46 +00:00
|
|
|
|
2022-09-12 13:05:39 +00:00
|
|
|
const base = 'inline-block uppercase border rounded-md disabled:opacity-60';
|
|
|
|
const xs = 'px-2 py-0 text-sm';
|
2022-08-31 04:35:46 +00:00
|
|
|
const sm = 'px-2 py-1 text-sm';
|
|
|
|
const md = 'px-10 py-2 text-base';
|
|
|
|
const lg = 'px-14 py-4';
|
|
|
|
const fillClasses = 'block w-full';
|
|
|
|
const defaultClasses = [
|
2022-10-28 15:13:14 +00:00
|
|
|
'border-neutral-500',
|
|
|
|
'bg-transparent',
|
|
|
|
'enabled:hover:bg-neutral-500/20 dark:enabled:hover:bg-neutral-500/40',
|
|
|
|
'enabled:active:bg-neutral-500/20 dark:enabled:active:bg-neutral-500/40',
|
2022-08-31 04:35:46 +00:00
|
|
|
];
|
|
|
|
const primary = [
|
|
|
|
'text-black',
|
|
|
|
'border-vega-yellow',
|
|
|
|
'bg-vega-yellow',
|
|
|
|
'enabled:hover:bg-vega-yellow-dark enabled:hover:border-vega-yellow-dark',
|
|
|
|
'enabled:active:bg-vega-yellow-dark enabled:active:border-vega-yellow-dark',
|
|
|
|
];
|
|
|
|
const secondary = [
|
|
|
|
'text-white',
|
|
|
|
'border-vega-pink',
|
|
|
|
'bg-vega-pink',
|
|
|
|
'enabled:hover:bg-vega-pink-dark enabled:hover:border-vega-pink-dark',
|
|
|
|
'enabled:active:bg-vega-pink-dark enabled:active:border-vega-pink-dark',
|
|
|
|
];
|
|
|
|
|
|
|
|
const getClassname = ({
|
|
|
|
variant,
|
|
|
|
size,
|
|
|
|
fill,
|
|
|
|
className,
|
|
|
|
}: {
|
|
|
|
variant: ButtonVariant;
|
|
|
|
size: ButtonSize;
|
|
|
|
fill: boolean;
|
|
|
|
className?: string;
|
|
|
|
}) => {
|
|
|
|
return classnames(base, className, {
|
|
|
|
[defaultClasses.join(' ')]: variant === 'default',
|
|
|
|
[primary.join(' ')]: variant === 'primary',
|
|
|
|
[secondary.join(' ')]: variant === 'secondary',
|
2022-09-12 13:05:39 +00:00
|
|
|
|
2022-08-31 04:35:46 +00:00
|
|
|
[lg]: size === 'lg',
|
|
|
|
[md]: size === 'md',
|
|
|
|
[sm]: size === 'sm',
|
2022-09-12 13:05:39 +00:00
|
|
|
[xs]: size === 'xs',
|
2022-08-31 04:35:46 +00:00
|
|
|
[fillClasses]: fill,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2022-03-07 12:27:56 +00:00
|
|
|
interface CommonProps {
|
2022-06-24 03:16:01 +00:00
|
|
|
children?: ReactNode;
|
2022-08-31 04:35:46 +00:00
|
|
|
variant?: ButtonVariant;
|
|
|
|
disabled?: boolean;
|
|
|
|
fill?: boolean;
|
|
|
|
size?: ButtonSize;
|
|
|
|
icon?: IconName;
|
|
|
|
rightIcon?: IconName;
|
2022-03-01 09:26:26 +00:00
|
|
|
}
|
2022-03-07 12:27:56 +00:00
|
|
|
export interface ButtonProps
|
|
|
|
extends ButtonHTMLAttributes<HTMLButtonElement>,
|
|
|
|
CommonProps {}
|
|
|
|
|
|
|
|
export const Button = forwardRef<HTMLButtonElement, ButtonProps>(
|
|
|
|
(
|
|
|
|
{
|
2022-08-31 04:35:46 +00:00
|
|
|
variant = 'default',
|
|
|
|
size = 'md',
|
|
|
|
fill = false,
|
Feat/63 Deal ticket (#82)
* scaffold dealticket package, remove trading views from react-helpers
* add deal ticket component, add intent utils, expand dialog and form group styles
* add splash component, show market not found message if market doesnt exist
* tidy up error handling
* add handleError method for vega tx hook
* add better testname for provider test, flesh out tests a bit more for deal ticket
* Add unit tests for useVegaTransaction and useOrderSubmit hooks
* add wrapper component for order dialog styles
* add vega styled loader to ui toolkit and use in order dialog
* add title prop to order dialog
* split limit and market tickets into own files
* add button radio component
* revert dialog styles
* move splash component to ui-toolkit, add story
* convert intent to enum
* Make button always type=button unless type prop is passed
* inline filter logic for tif selector
* add date-fns, add datetime to helpers
* add order types to wallet package, make price undefined if order type is market
* use enums in deal ticket logic
* tidy up order state by moving submit and transaction hooks out of deal ticket
* add comment for dialog styles
* remove decimal from price input
* add types package, delete old generated types from trading project
* rename types package to graphql
* update generate command to point to correct locations
* fix use order submit test
* use intent shadow helper
* remove date-fns and format manually, update submit button error to use input-error
* remove stray console.log
2022-03-17 19:35:46 +00:00
|
|
|
type = 'button',
|
2022-08-31 04:35:46 +00:00
|
|
|
icon,
|
|
|
|
rightIcon,
|
2022-03-07 12:27:56 +00:00
|
|
|
children,
|
|
|
|
className,
|
2022-03-07 20:45:39 +00:00
|
|
|
...props
|
2022-03-07 12:27:56 +00:00
|
|
|
},
|
|
|
|
ref
|
|
|
|
) => {
|
2022-08-31 04:35:46 +00:00
|
|
|
const buttonClasses = getClassname({ variant, size, fill, className });
|
2022-03-07 12:27:56 +00:00
|
|
|
return (
|
2022-08-31 04:35:46 +00:00
|
|
|
<button ref={ref} type={type} className={buttonClasses} {...props}>
|
|
|
|
<ButtonContent icon={icon} rightIcon={rightIcon}>
|
|
|
|
{children}
|
|
|
|
</ButtonContent>
|
2022-03-07 12:27:56 +00:00
|
|
|
</button>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2022-08-31 04:35:46 +00:00
|
|
|
export interface AnchorButtonProps
|
|
|
|
extends AnchorHTMLAttributes<HTMLAnchorElement>,
|
|
|
|
CommonProps {}
|
|
|
|
|
2022-03-07 12:27:56 +00:00
|
|
|
export const AnchorButton = forwardRef<HTMLAnchorElement, AnchorButtonProps>(
|
|
|
|
(
|
|
|
|
{
|
2022-08-31 04:35:46 +00:00
|
|
|
variant = 'default',
|
|
|
|
size = 'lg',
|
|
|
|
fill = false,
|
|
|
|
icon,
|
|
|
|
rightIcon,
|
2022-03-07 12:27:56 +00:00
|
|
|
children,
|
2022-06-06 16:19:56 +00:00
|
|
|
...props
|
2022-03-07 12:27:56 +00:00
|
|
|
},
|
|
|
|
ref
|
|
|
|
) => {
|
2022-08-31 04:35:46 +00:00
|
|
|
const className = getClassname({ variant, size, fill });
|
2022-03-07 12:27:56 +00:00
|
|
|
return (
|
2022-08-31 04:35:46 +00:00
|
|
|
<a ref={ref} className={className} {...props}>
|
|
|
|
<ButtonContent icon={icon} rightIcon={rightIcon}>
|
|
|
|
{children}
|
|
|
|
</ButtonContent>
|
2022-03-07 12:27:56 +00:00
|
|
|
</a>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
2022-08-31 04:35:46 +00:00
|
|
|
|
|
|
|
type ButtonLinkProps = Omit<
|
|
|
|
ButtonHTMLAttributes<HTMLButtonElement>,
|
|
|
|
'className' | 'style'
|
|
|
|
>;
|
|
|
|
|
|
|
|
export const ButtonLink = forwardRef<HTMLButtonElement, ButtonLinkProps>(
|
|
|
|
({ type = 'button', ...props }, ref) => {
|
|
|
|
const className = classnames('inline underline');
|
|
|
|
return <button ref={ref} className={className} type={type} {...props} />;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
interface ButtonContentProps {
|
|
|
|
children: ReactNode;
|
|
|
|
icon?: IconName;
|
|
|
|
rightIcon?: IconName;
|
|
|
|
}
|
|
|
|
|
|
|
|
const ButtonContent = ({ children, icon, rightIcon }: ButtonContentProps) => {
|
|
|
|
const iconEl = icon ? (
|
|
|
|
<Icon name={icon} className="fill-current mr-2 align-text-top" />
|
|
|
|
) : null;
|
|
|
|
const rightIconEl = rightIcon ? (
|
|
|
|
<Icon name={rightIcon} className="fill-current ml-2 align-text-top" />
|
|
|
|
) : null;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
{iconEl}
|
|
|
|
{children}
|
|
|
|
{rightIconEl}
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|