import classNames from '../_util/classNames'; import { defineComponent, computed, ref } from 'vue'; import Tooltip from '../tooltip'; import Content from './FloatButtonContent'; import useConfigInject from '../config-provider/hooks/useConfigInject'; import { useInjectFloatButtonGroupContext } from './context'; import warning from '../_util/warning'; import { initDefaultProps } from '../_util/props-util'; import { floatButtonProps } from './interface'; // import { useCompactItemContext } from '../space/Compact'; // CSSINJS import useStyle from './style'; export const floatButtonPrefixCls = 'float-btn'; const FloatButton = defineComponent({ compatConfig: { MODE: 3 }, name: 'AFloatButton', inheritAttrs: false, props: initDefaultProps(floatButtonProps(), { type: 'default', shape: 'circle' }), setup(props, { attrs, slots }) { const { prefixCls, direction } = useConfigInject(floatButtonPrefixCls, props); const [wrapSSR, hashId] = useStyle(prefixCls); const { shape: groupShape } = useInjectFloatButtonGroupContext(); const floatButtonRef = ref(null); const mergeShape = computed(() => { return groupShape?.value || props.shape; }); return () => { const { prefixCls: customPrefixCls, type = 'default', shape = 'circle', description = slots.description?.(), tooltip, ...restProps } = props; const classString = classNames( prefixCls.value, `${prefixCls.value}-${type}`, `${prefixCls.value}-${mergeShape.value}`, { [`${prefixCls.value}-rtl`]: direction.value === 'rtl', }, attrs.class, hashId.value, ); const buttonNode = ( (slots.tooltip && slots.tooltip()) || tooltip : undefined, default: () => (
description, }} >
), }} >
); if (process.env.NODE_ENV !== 'production') { warning( !(shape === 'circle' && description), 'FloatButton', 'supported only when `shape` is `square`. Due to narrow space for text, short sentence is recommended.', ); } return wrapSSR( props.href ? ( {buttonNode} ) : ( ), ); }; }, }); export default FloatButton;