feat: checklist-summary script setup (#1924)
Co-authored-by: Dominik Pschenitschni <mail@celement.de> Reviewed-on: https://kolaente.dev/vikunja/frontend/pulls/1924 Co-authored-by: Dominik Pschenitschni <dpschen@noreply.kolaente.de> Co-committed-by: Dominik Pschenitschni <dpschen@noreply.kolaente.de>
This commit is contained in:
parent
99d1c40cfd
commit
49a73a154b
1 changed files with 37 additions and 32 deletions
|
@ -5,37 +5,40 @@
|
||||||
<circle stroke-width="2" stroke-dasharray="31" :stroke-dashoffset="checklistCircleDone"
|
<circle stroke-width="2" stroke-dasharray="31" :stroke-dashoffset="checklistCircleDone"
|
||||||
stroke-linecap="round" fill="transparent" cx="50%" cy="50%" r="5"></circle>
|
stroke-linecap="round" fill="transparent" cx="50%" cy="50%" r="5"></circle>
|
||||||
</svg>
|
</svg>
|
||||||
<span>
|
<span>{{ label }}</span>
|
||||||
{{ $t(checklist.total === checklist.checked ? 'task.checklistAllDone' : 'task.checklistTotal', checklist) }}
|
|
||||||
</span>
|
|
||||||
</span>
|
</span>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script setup lang="ts">
|
||||||
import {defineComponent} from 'vue'
|
import {computed} from 'vue'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
import {getChecklistStatistics} from '@/helpers/checklistFromText'
|
import {getChecklistStatistics} from '@/helpers/checklistFromText'
|
||||||
|
import TaskModel from '@/models/task'
|
||||||
|
|
||||||
export default defineComponent({
|
const props = defineProps({
|
||||||
name: 'checklist-summary',
|
|
||||||
props: {
|
|
||||||
task: {
|
task: {
|
||||||
|
type: TaskModel,
|
||||||
required: true,
|
required: true,
|
||||||
},
|
},
|
||||||
},
|
})
|
||||||
computed: {
|
|
||||||
checklist() {
|
const checklist = computed(() => getChecklistStatistics(props.task.description))
|
||||||
return getChecklistStatistics(this.task.description)
|
|
||||||
},
|
const checklistCircleDone = computed(() => {
|
||||||
checklistCircleDone() {
|
|
||||||
const r = 5
|
const r = 5
|
||||||
const c = Math.PI * (r * 2)
|
const c = Math.PI * (r * 2)
|
||||||
|
|
||||||
const progress = this.checklist.checked / this.checklist.total * 100
|
const progress = checklist.value.checked / checklist.value.total * 100
|
||||||
|
|
||||||
return ((100 - progress) / 100) * c
|
return ((100 - progress) / 100) * c
|
||||||
},
|
})
|
||||||
},
|
|
||||||
|
const {t} = useI18n()
|
||||||
|
const label = computed(() => {
|
||||||
|
return checklist.value.total === checklist.value.checked
|
||||||
|
? t('task.checklistAllDone', checklist.value)
|
||||||
|
: t('task.checklistTotal', checklist.value)
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
@ -47,18 +50,20 @@ export default defineComponent({
|
||||||
padding-left: .5rem;
|
padding-left: .5rem;
|
||||||
font-size: .9rem;
|
font-size: .9rem;
|
||||||
|
|
||||||
svg {
|
}
|
||||||
|
|
||||||
|
svg {
|
||||||
transform: rotate(-90deg);
|
transform: rotate(-90deg);
|
||||||
transition: stroke-dashoffset 0.35s;
|
transition: stroke-dashoffset 0.35s;
|
||||||
margin-right: .25rem;
|
margin-right: .25rem;
|
||||||
|
|
||||||
circle {
|
}
|
||||||
|
|
||||||
|
circle {
|
||||||
stroke: var(--grey-400);
|
stroke: var(--grey-400);
|
||||||
|
|
||||||
&:last-child {
|
&:last-child {
|
||||||
stroke: var(--primary);
|
stroke: var(--primary);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
Loading…
Reference in a new issue