mirror of
https://github.com/portainer/portainer.git
synced 2025-07-24 15:59:41 +02:00
refactor(docker/images): convert table to react [EE-4668] (#8910)
This commit is contained in:
parent
0e9902fee9
commit
ecd54ab929
26 changed files with 496 additions and 441 deletions
|
@ -1,6 +1,7 @@
|
|||
import {
|
||||
AriaAttributes,
|
||||
ComponentType,
|
||||
forwardRef,
|
||||
MouseEventHandler,
|
||||
PropsWithChildren,
|
||||
ReactNode,
|
||||
|
@ -39,9 +40,17 @@ export interface Props<TasProps = unknown>
|
|||
type?: Type;
|
||||
as?: ComponentType<TasProps> | string;
|
||||
onClick?: MouseEventHandler<HTMLButtonElement>;
|
||||
mRef?: React.ForwardedRef<HTMLButtonElement>;
|
||||
props?: TasProps;
|
||||
}
|
||||
|
||||
export const ButtonWithRef = forwardRef<HTMLButtonElement, Omit<Props, 'mRef'>>(
|
||||
(props, ref) => (
|
||||
// eslint-disable-next-line react/jsx-props-no-spreading
|
||||
<Button {...props} mRef={ref} />
|
||||
)
|
||||
);
|
||||
|
||||
export function Button<TasProps = unknown>({
|
||||
type = 'button',
|
||||
color = 'primary',
|
||||
|
@ -54,15 +63,19 @@ export function Button<TasProps = unknown>({
|
|||
children,
|
||||
as = 'button',
|
||||
props,
|
||||
mRef,
|
||||
...ariaProps
|
||||
}: PropsWithChildren<Props<TasProps>>) {
|
||||
const Component = as as 'button';
|
||||
return (
|
||||
<Component
|
||||
ref={mRef}
|
||||
/* eslint-disable-next-line react/button-has-type */
|
||||
type={type}
|
||||
disabled={disabled}
|
||||
className={clsx(`btn btn-${color}`, sizeClass(size), className)}
|
||||
className={clsx(`btn btn-${color}`, sizeClass(size), className, {
|
||||
disabled,
|
||||
})}
|
||||
onClick={(e) => {
|
||||
if (!disabled) {
|
||||
onClick?.(e);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue