vant/packages/progress/index.vue
2017-08-22 17:52:16 +08:00

84 lines
2.0 KiB
Vue

<template>
<div class="van-progress">
<div class="van-progress__bar">
<span class="van-progress__bar__finished-portion" :style="{backgroundColor: componentColor, width: percentage + '%'}"></span>
<span class="van-progress__bar__pivot" :style="pivotStyle">{{ pivotText }}</span>
</div>
</div>
</template>
<script>
/**
* van-progress
* @module components/progress
* @desc 开关
* @param {boolean} [inactive=false] - 是否置灰
* @param {number} [percentage=0] - 进度百分比
* @param {string} [pivotText=percentage] - 进度条显示文字
* @param {string} [color='#38f'] - 进度条颜色
* @param {string} [textColor='#fff'] - 进度条文字颜色
*
* @example
* <van-switch checked="true" disabled="false"></van-switch>
*/
const DEFAULT_COLOR = '#38f';
const DEFAULT_TEXT_COLOR = '#fff';
const INACTIVE_COLOR = '#cacaca';
export default {
name: 'van-progress',
props: {
percentage: {
type: Number,
required: true,
validator(value) {
return value <= 100 && value >= 0;
}
},
inactive: Boolean,
pivotText: {
type: String,
default: function() {
return this.percentage + '%';
}
},
color: {
type: String,
default: DEFAULT_COLOR
},
textColor: {
type: String,
default: DEFAULT_TEXT_COLOR
}
},
computed: {
componentColor() {
return this.inactive ? INACTIVE_COLOR : this.color;
},
pivotStyle() {
const pivotStyle = {
backgroundColor: this.componentColor,
color: this.textColor,
left: this.percentage + '%',
marginLeft: '-14px'
};
if (this.percentage <= 5) {
pivotStyle.left = '0%';
pivotStyle.marginLeft = '0';
} else if (this.percentage >= 95) {
pivotStyle.left = '100%';
pivotStyle.marginLeft = '-28px';
} else {
pivotStyle.left = this.percentage + '%';
pivotStyle.marginLeft = '-14px';
}
return pivotStyle;
}
}
};
</script>