import type { ExtractPropTypes, PropType } from 'vue'; import { computed, defineComponent } from 'vue'; import type { VueNode } from '../_util/type'; import type { ProgressSize } from './props'; import { progressProps } from './props'; export const stepsProps = () => ({ ...progressProps(), steps: Number, size: { type: String as PropType, }, strokeColor: String, trailColor: String, }); export type StepsProps = Partial>; export default defineComponent({ name: 'Steps', props: stepsProps(), setup(props, { slots }) { const current = computed(() => Math.round(props.steps * ((props.percent || 0) / 100))); const stepWidth = computed(() => (props.size === 'small' ? 2 : 14)); const styledSteps = computed(() => { const { steps, strokeWidth = 8, strokeColor, trailColor, prefixCls } = props; const temp: VueNode[] = []; for (let i = 0; i < steps; i += 1) { const cls = { [`${prefixCls}-steps-item`]: true, [`${prefixCls}-steps-item-active`]: i <= current.value - 1, }; temp.push(
, ); } return temp; }); return () => (
{styledSteps.value} {slots.default?.()}
); }, });