tiny-vue/examples/sites/demos/pc/app/steps/slot-item-composition-api.vue

60 lines
1.1 KiB
Vue

<template>
<div class="demo-steps-slot-item">
<tiny-steps :data="stepsData">
<template #item="data">
<a class="label"
><span>{{ data.slotScope.name }}</span></a
>
<span>
<div :class="['dot', data.slotScope.status]">
<component :is="data.slotScope.status == 'done' ? IconYes : IconClose" class="tiny-svg-size" />
</div>
</span>
</template>
</tiny-steps>
</div>
</template>
<script setup>
import { ref } from 'vue'
import { Steps as TinySteps } from '@opentiny/vue'
import { iconYes, iconClose } from '@opentiny/vue-icon'
const IconYes = iconYes()
const IconClose = iconClose()
const stepsData = ref([
{
name: 'Basic Info',
count: 3,
status: 'done'
},
{
name: 'BOQ Info',
count: 0,
status: 'done'
},
{
name: 'Involved Parties',
count: 10,
status: 'doing'
},
{
name: 'Billing',
count: 0,
status: 'done'
}
])
</script>
<style scoped>
.demo-steps-slot-item {
padding: 20px;
max-width: 50%;
min-width: 700px;
}
.demo-steps-slot-item > div:not(:last-child) {
margin: 0 0 20px 0;
}
</style>