Files
element-plus/packages/components/progress/src/progress.ts
btea 1807c9d643 docs(components): [progress] (#12604)
* docs(components): [progress]
2023-04-29 01:25:30 +08:00

112 lines
2.5 KiB
TypeScript

import { buildProps, definePropType } from '@element-plus/utils'
import type { ExtractPropTypes, SVGAttributes } from 'vue'
import type Progress from './progress.vue'
export type ProgressColor = { color: string; percentage: number }
export type ProgressFn = (percentage: number) => string
export const progressProps = buildProps({
/**
* @description type of progress bar
*/
type: {
type: String,
default: 'line',
values: ['line', 'circle', 'dashboard'],
},
/**
* @description percentage, required
*/
percentage: {
type: Number,
default: 0,
validator: (val: number): boolean => val >= 0 && val <= 100,
},
/**
* @description the current status of progress bar
*/
status: {
type: String,
default: '',
values: ['', 'success', 'exception', 'warning'],
},
/**
* @description set indeterminate progress
*/
indeterminate: {
type: Boolean,
default: false,
},
/**
* @description control the animation duration of indeterminate progress or striped flow progress
*/
duration: {
type: Number,
default: 3,
},
/**
* @description the width of progress bar
*/
strokeWidth: {
type: Number,
default: 6,
},
/**
* @description butt/circle/dashboard type shape at the end path
*/
strokeLinecap: {
type: definePropType<NonNullable<SVGAttributes['stroke-linecap']>>(String),
default: 'round',
},
/**
* @description whether to place the percentage inside progress bar, only works when `type` is 'line'
*/
textInside: {
type: Boolean,
default: false,
},
/**
* @description the canvas width of circle progress bar
*/
width: {
type: Number,
default: 126,
},
/**
* @description whether to show percentage
*/
showText: {
type: Boolean,
default: true,
},
/**
* @description background color of progress bar. Overrides `status` prop
*/
color: {
type: definePropType<string | ProgressColor[] | ProgressFn>([
String,
Array,
Function,
]),
default: '',
},
/**
* @description stripe over the progress bar's color
*/
striped: Boolean,
/**
* @description get the stripes to flow
*/
stripedFlow: Boolean,
/**
* @description custom text format
*/
format: {
type: definePropType<ProgressFn>(Function),
default: (percentage: number): string => `${percentage}%`,
},
} as const)
export type ProgressProps = ExtractPropTypes<typeof progressProps>
export type ProgressInstance = InstanceType<typeof Progress>