index.vue 5.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <template>
  2. <uni-shadow-root class="weapp-lib-steps-index"><view :class="'custom-class '+(utils.bem('steps', [direction]))">
  3. <view class="van-step__wrapper">
  4. <view v-for="(item,index) in (steps)" :key="item.index" @click="onClick" :data-index="index" :class="(utils.bem('step', [direction, status(index, active)]))+' van-hairline'" :style="status(index, active) === 'inactive' ? 'color: ' + inactiveColor: ''">
  5. <view class="van-step__title" :style="index === active ? 'color: ' + activeColor : ''">
  6. <view>{{ item.text }}</view>
  7. <view class="desc-class">{{ item.desc }}</view>
  8. </view>
  9. <view class="van-step__circle-container">
  10. <block v-if="index !== active">
  11. <van-icon v-if="item.inactiveIcon || inactiveIcon" :color="status(index, active) === 'inactive' ? inactiveColor: activeColor" :name="item.inactiveIcon || inactiveIcon" class="van-step__icon"></van-icon>
  12. <view v-else class="van-step__circle" :style="'background-color: ' + (index < active ? activeColor : inactiveColor)"></view>
  13. </block>
  14. <van-icon v-else :name="item.activeIcon || activeIcon" :color="activeColor" class="van-step__icon"></van-icon>
  15. </view>
  16. <view v-if="index !== steps.length - 1" class="van-step__line" :style="'background-color: ' + (index < active ? activeColor : inactiveColor)"></view>
  17. </view>
  18. </view>
  19. </view></uni-shadow-root>
  20. </template>
  21. <wxs src="../wxs/utils.wxs" module="utils"></wxs><wxs module="status" src="./index-status.wxs"></wxs>
  22. <script>
  23. import VanIcon from '../icon/index.vue'
  24. global['__wxVueOptions'] = {components:{'van-icon': VanIcon}}
  25. global['__wxRoute'] = 'weapp/lib/steps/index'
  26. "use strict";
  27. Object.defineProperty(exports, "__esModule", { value: true });
  28. var component_1 = require("../common/component");
  29. var color_1 = require("../common/color");
  30. (0, component_1.VantComponent)({
  31. classes: ['desc-class'],
  32. props: {
  33. icon: String,
  34. steps: Array,
  35. active: Number,
  36. direction: {
  37. type: String,
  38. value: 'horizontal',
  39. },
  40. activeColor: {
  41. type: String,
  42. value: color_1.GREEN,
  43. },
  44. inactiveColor: {
  45. type: String,
  46. value: color_1.GRAY_DARK,
  47. },
  48. activeIcon: {
  49. type: String,
  50. value: 'checked',
  51. },
  52. inactiveIcon: String,
  53. },
  54. methods: {
  55. onClick: function (event) {
  56. var index = event.currentTarget.dataset.index;
  57. this.$emit('click-step', index);
  58. },
  59. },
  60. });
  61. export default global['__wxComponents']['weapp/lib/steps/index']
  62. </script>
  63. <style platform="mp-weixin">
  64. @import '../common/index.css';.van-steps{background-color:var(--steps-background-color,#fff);overflow:hidden}.van-steps--horizontal{padding:10px}.van-steps--horizontal .van-step__wrapper{display:flex;overflow:hidden;position:relative}.van-steps--vertical{padding-left:10px}.van-steps--vertical .van-step__wrapper{padding:0 0 0 20px}.van-step{color:var(--step-text-color,#969799);flex:1;font-size:var(--step-font-size,14px);position:relative}.van-step--finish{color:var(--step-finish-text-color,#323233)}.van-step__circle{background-color:var(--step-circle-color,#969799);border-radius:50%;height:var(--step-circle-size,5px);width:var(--step-circle-size,5px)}.van-step--horizontal{padding-bottom:14px}.van-step--horizontal:first-child .van-step__title{transform:none}.van-step--horizontal:first-child .van-step__circle-container{padding:0 8px 0 0;transform:translate3d(0,50%,0)}.van-step--horizontal:last-child{position:absolute;right:0;width:auto}.van-step--horizontal:last-child .van-step__title{text-align:right;transform:none}.van-step--horizontal:last-child .van-step__circle-container{padding:0 0 0 8px;right:0;transform:translate3d(0,50%,0)}.van-step--horizontal .van-step__circle-container{background-color:#fff;bottom:6px;padding:0 var(--padding-xs,8px);position:absolute;transform:translate3d(-50%,50%,0);z-index:1}.van-step--horizontal .van-step__title{display:inline-block;font-size:var(--step-horizontal-title-font-size,12px);transform:translate3d(-50%,0,0)}.van-step--horizontal .van-step__line{background-color:var(--step-line-color,#ebedf0);bottom:6px;height:1px;left:0;position:absolute;right:0;transform:translate3d(0,50%,0)}.van-step--horizontal.van-step--process{color:var(--step-process-text-color,#323233)}.van-step--horizontal.van-step--process .van-step__icon{display:block;font-size:var(--step-icon-size,12px);line-height:1}.van-step--vertical{line-height:18px;padding:10px 10px 10px 0}.van-step--vertical:after{border-bottom-width:1px}.van-step--vertical:last-child:after{border-bottom-width:none}.van-step--vertical:first-child:before{background-color:#fff;content:"";height:20px;left:-15px;position:absolute;top:0;width:1px;z-index:1}.van-step--vertical .van-step__circle,.van-step--vertical .van-step__icon,.van-step--vertical .van-step__line{left:-14px;position:absolute;top:19px;transform:translate3d(-50%,-50%,0);z-index:2}.van-step--vertical .van-step__icon{background-color:var(--steps-background-color,#fff);font-size:var(--step-icon-size,12px);line-height:1}.van-step--vertical .van-step__line{background-color:var(--step-line-color,#ebedf0);height:100%;transform:translate3d(-50%,0,0);width:1px;z-index:1}
  65. </style>