105 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Vue
		
	
	
| import classNames from '../_util/classNames';
 | |
| import { defineComponent, computed, ref } from 'vue';
 | |
| import Tooltip from '../tooltip';
 | |
| import Badge from '../badge';
 | |
| 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<HTMLAnchorElement | HTMLButtonElement>(null);
 | |
| 
 | |
|     const mergeShape = computed(() => {
 | |
|       return groupShape?.value || props.shape;
 | |
|     });
 | |
| 
 | |
|     return () => {
 | |
|       const {
 | |
|         prefixCls: customPrefixCls,
 | |
|         type = 'default',
 | |
|         shape = 'circle',
 | |
|         description = slots.description?.(),
 | |
|         tooltip,
 | |
|         badge = {},
 | |
|         ...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 = (
 | |
|         <Tooltip
 | |
|           placement="left"
 | |
|           v-slots={{
 | |
|             title:
 | |
|               slots.tooltip || tooltip
 | |
|                 ? () => (slots.tooltip && slots.tooltip()) || tooltip
 | |
|                 : undefined,
 | |
|             default: () => (
 | |
|               <Badge {...badge}>
 | |
|                 <div class={`${prefixCls.value}-body`}>
 | |
|                   <Content
 | |
|                     prefixCls={prefixCls.value}
 | |
|                     v-slots={{
 | |
|                       icon: slots.icon,
 | |
|                       description: () => description,
 | |
|                     }}
 | |
|                   ></Content>
 | |
|                 </div>
 | |
|               </Badge>
 | |
|             ),
 | |
|           }}
 | |
|         ></Tooltip>
 | |
|       );
 | |
| 
 | |
|       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 ? (
 | |
|           <a ref={floatButtonRef} {...attrs} {...(restProps as any)} class={classString}>
 | |
|             {buttonNode}
 | |
|           </a>
 | |
|         ) : (
 | |
|           <button ref={floatButtonRef} {...attrs} {...restProps} class={classString} type="button">
 | |
|             {buttonNode}
 | |
|           </button>
 | |
|         ),
 | |
|       );
 | |
|     };
 | |
|   },
 | |
| });
 | |
| 
 | |
| export default FloatButton;
 |