You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ant-design-vue/components/slider/SliderTooltip.tsx

50 lines
1.1 KiB

import { onBeforeUnmount, watch, onActivated, defineComponent, ref } from 'vue';
import Tooltip, { tooltipProps } from '../tooltip';
import type { RafFrame } from '../_util/raf';
import raf from '../_util/raf';
export default defineComponent({
name: 'SliderTooltip',
inheritAttrs: false,
props: tooltipProps(),
setup(props, { attrs, slots }) {
const innerRef = ref<any>(null);
const rafRef = ref<RafFrame>(null);
function cancelKeepAlign() {
raf.cancel(rafRef.value!);
rafRef.value = null;
}
function keepAlign() {
rafRef.value = raf(() => {
innerRef.value?.forcePopupAlign();
rafRef.value = null;
});
}
const align = () => {
cancelKeepAlign();
if (props.visible) {
keepAlign();
}
};
watch(
[() => props.visible, () => props.title],
() => {
align();
},
{ flush: 'post', immediate: true },
);
onActivated(() => {
align();
});
onBeforeUnmount(() => {
cancelKeepAlign();
});
return () => {
return <Tooltip ref={innerRef} {...props} {...attrs} v-slots={slots} />;
};
},
});