mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-04 21:18:01 +08:00
59ad48476b
* chore: add boime lint * fix lint * use files ignore * revert change * ignore clarity.js * fix some errors * fix some errors * fix some errors * fix some errors * add yml file * Update clarity.js Signed-off-by: afc163 <afc163@gmail.com> * add npm run lint:biome * add npm run lint:biome * fix test case * fix ts errors * fix ts errors * fix lint and add .lintstagedrc * shorten prop name * chore: update package.json * update biome.json * chore: remove stylelint * chore: useOptionalChain * fix lint * biome format * prettier all code * prettier all code * fix site test --------- Signed-off-by: afc163 <afc163@gmail.com>
67 lines
2.0 KiB
TypeScript
67 lines
2.0 KiB
TypeScript
import type React from 'react';
|
|
|
|
import type { BadgeProps } from '../badge';
|
|
import type { TooltipProps } from '../tooltip';
|
|
|
|
export type FloatButtonElement = HTMLAnchorElement & HTMLButtonElement;
|
|
|
|
export interface FloatButtonRef {
|
|
nativeElement: FloatButtonElement | null;
|
|
}
|
|
|
|
export type FloatButtonType = 'default' | 'primary';
|
|
|
|
export type FloatButtonShape = 'circle' | 'square';
|
|
|
|
export type FloatButtonGroupTrigger = 'click' | 'hover';
|
|
|
|
export type FloatButtonBadgeProps = Omit<BadgeProps, 'status' | 'text' | 'title' | 'children'>;
|
|
|
|
export interface FloatButtonProps extends React.DOMAttributes<FloatButtonElement> {
|
|
prefixCls?: string;
|
|
className?: string;
|
|
rootClassName?: string;
|
|
style?: React.CSSProperties;
|
|
icon?: React.ReactNode;
|
|
description?: React.ReactNode;
|
|
type?: FloatButtonType;
|
|
shape?: FloatButtonShape;
|
|
tooltip?: TooltipProps['title'];
|
|
href?: string;
|
|
target?: React.HTMLAttributeAnchorTarget;
|
|
badge?: FloatButtonBadgeProps;
|
|
'aria-label'?: React.HtmlHTMLAttributes<HTMLElement>['aria-label'];
|
|
}
|
|
|
|
export interface FloatButtonContentProps extends React.DOMAttributes<HTMLDivElement> {
|
|
className?: string;
|
|
icon?: FloatButtonProps['icon'];
|
|
description?: FloatButtonProps['description'];
|
|
prefixCls: FloatButtonProps['prefixCls'];
|
|
}
|
|
|
|
export interface FloatButtonGroupProps extends FloatButtonProps {
|
|
// 包含的 Float Button
|
|
children: React.ReactNode;
|
|
// 触发方式 (有触发方式为菜单模式)
|
|
trigger?: FloatButtonGroupTrigger;
|
|
// 受控展开
|
|
open?: boolean;
|
|
// 关闭按钮自定义图标
|
|
closeIcon?: React.ReactNode;
|
|
// 展开收起的回调
|
|
onOpenChange?: (open: boolean) => void;
|
|
}
|
|
|
|
export interface BackTopProps extends Omit<FloatButtonProps, 'target'> {
|
|
visibilityHeight?: number;
|
|
onClick?: React.MouseEventHandler<FloatButtonElement>;
|
|
target?: () => HTMLElement | Window | Document;
|
|
prefixCls?: string;
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
rootClassName?: string;
|
|
style?: React.CSSProperties;
|
|
duration?: number;
|
|
}
|