ant-design-vue/components/tour/index.tsx

93 lines
2.6 KiB
Vue

import { computed, defineComponent, toRefs } from 'vue';
import VCTour from '../vc-tour';
import classNames from '../_util/classNames';
import TourPanel from './panelRender';
import type { TourProps, TourStepProps } from './interface';
import { tourProps } from './interface';
import useConfigInject from '../config-provider/hooks/useConfigInject';
import type { VueNode } from '../_util/type';
import { withInstall } from '../_util/type';
import useMergedType from './useMergedType';
// CSSINJS
import useStyle from './style';
import getPlacements from '../_util/placements';
export { TourProps, TourStepProps };
const Tour = defineComponent({
name: 'ATour',
inheritAttrs: false,
props: tourProps(),
setup(props, { attrs, emit, slots }) {
const { current, type, steps, defaultCurrent } = toRefs(props);
const { prefixCls, direction } = useConfigInject('tour', props);
// style
const [wrapSSR, hashId] = useStyle(prefixCls);
const { currentMergedType, updateInnerCurrent } = useMergedType({
defaultType: type,
steps,
current,
defaultCurrent,
});
return () => {
const { steps, current, type, rootClassName, ...restProps } = props;
const customClassName = classNames(
{
[`${prefixCls.value}-primary`]: currentMergedType.value === 'primary',
[`${prefixCls.value}-rtl`]: direction.value === 'rtl',
},
hashId.value,
rootClassName,
);
const mergedRenderPanel = (stepProps: TourStepProps, stepCurrent: number): VueNode => {
return (
<TourPanel
{...stepProps}
type={type}
current={stepCurrent}
v-slots={{
indicatorsRender: slots.indicatorsRender,
}}
></TourPanel>
);
};
const onStepChange = (stepCurrent: number) => {
updateInnerCurrent(stepCurrent);
emit('update:current', stepCurrent);
emit('change', stepCurrent);
};
const builtinPlacements = computed(() =>
getPlacements({
arrowPointAtCenter: true,
autoAdjustOverflow: true,
}),
);
return wrapSSR(
<VCTour
{...attrs}
{...restProps}
rootClassName={customClassName}
prefixCls={prefixCls.value}
current={current}
defaultCurrent={props.defaultCurrent}
animated
renderPanel={mergedRenderPanel}
onChange={onStepChange}
steps={steps}
builtinPlacements={builtinPlacements.value as any}
/>,
);
};
},
});
export default withInstall(Tour);