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"
|
||||
stroke-linecap="round" fill="transparent" cx="50%" cy="50%" r="5"></circle>
|
||||
</svg>
|
||||
<span>
|
||||
{{ $t(checklist.total === checklist.checked ? 'task.checklistAllDone' : 'task.checklistTotal', checklist) }}
|
||||
</span>
|
||||
<span>{{ label }}</span>
|
||||
</span>
|
||||
</template>
|
||||
|
||||
<script lang="ts">
|
||||
import {defineComponent} from 'vue'
|
||||
<script setup lang="ts">
|
||||
import {computed} from 'vue'
|
||||
import { useI18n } from 'vue-i18n'
|
||||
|
||||
import {getChecklistStatistics} from '@/helpers/checklistFromText'
|
||||
import TaskModel from '@/models/task'
|
||||
|
||||
export default defineComponent({
|
||||
name: 'checklist-summary',
|
||||
props: {
|
||||
task: {
|
||||
required: true,
|
||||
},
|
||||
const props = defineProps({
|
||||
task: {
|
||||
type: TaskModel,
|
||||
required: true,
|
||||
},
|
||||
computed: {
|
||||
checklist() {
|
||||
return getChecklistStatistics(this.task.description)
|
||||
},
|
||||
checklistCircleDone() {
|
||||
const r = 5
|
||||
const c = Math.PI * (r * 2)
|
||||
})
|
||||
|
||||
const progress = this.checklist.checked / this.checklist.total * 100
|
||||
const checklist = computed(() => getChecklistStatistics(props.task.description))
|
||||
|
||||
return ((100 - progress) / 100) * c
|
||||
},
|
||||
},
|
||||
const checklistCircleDone = computed(() => {
|
||||
const r = 5
|
||||
const c = Math.PI * (r * 2)
|
||||
|
||||
const progress = checklist.value.checked / checklist.value.total * 100
|
||||
|
||||
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>
|
||||
|
||||
|
@ -47,18 +50,20 @@ export default defineComponent({
|
|||
padding-left: .5rem;
|
||||
font-size: .9rem;
|
||||
|
||||
svg {
|
||||
transform: rotate(-90deg);
|
||||
transition: stroke-dashoffset 0.35s;
|
||||
margin-right: .25rem;
|
||||
}
|
||||
|
||||
circle {
|
||||
stroke: var(--grey-400);
|
||||
svg {
|
||||
transform: rotate(-90deg);
|
||||
transition: stroke-dashoffset 0.35s;
|
||||
margin-right: .25rem;
|
||||
|
||||
&:last-child {
|
||||
stroke: var(--primary);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
circle {
|
||||
stroke: var(--grey-400);
|
||||
|
||||
&:last-child {
|
||||
stroke: var(--primary);
|
||||
}
|
||||
}
|
||||
</style>
|
Loading…
Reference in a new issue