58 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Vue
		
	
	
| 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<ProgressSize>,
 | |
|   },
 | |
|   strokeColor: String,
 | |
|   trailColor: String,
 | |
| });
 | |
| 
 | |
| export type StepsProps = Partial<ExtractPropTypes<typeof stepsProps>>;
 | |
| 
 | |
| 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(
 | |
|           <div
 | |
|             key={i}
 | |
|             class={cls}
 | |
|             style={{
 | |
|               backgroundColor: i <= current.value - 1 ? strokeColor : trailColor,
 | |
|               width: `${stepWidth.value}px`,
 | |
|               height: `${strokeWidth}px`,
 | |
|             }}
 | |
|           />,
 | |
|         );
 | |
|       }
 | |
|       return temp;
 | |
|     });
 | |
| 
 | |
|     return () => (
 | |
|       <div class={`${props.prefixCls}-steps-outer`}>
 | |
|         {styledSteps.value}
 | |
|         {slots.default?.()}
 | |
|       </div>
 | |
|     );
 | |
|   },
 | |
| });
 |