Feat: month selector

This commit is contained in:
Bertrand Benjamin 2021-08-03 11:34:49 +02:00
parent 820bf435e8
commit 7f9cecf06d
1 changed files with 74 additions and 0 deletions

View File

@ -0,0 +1,74 @@
<template>
<ul>
<li>
Période
<input type="month" v-model="range.start">
<input type="month" v-model="range.end">
</li>
<li @click="setRange6months">6 mois</li>
<li @click="setRange1year">1 an</li>
<li @click="setRangeAll">Tout</li>
</ul>
</template>
<script>
import { mapGetters, mapActions } from 'vuex'
import { addMonths, format, parseISO } from 'date-fns'
const today = new Date();
export default {
name: 'MonthSelector',
components: {
},
data () {
return {}
},
computed: {
...mapGetters('travail', {
range: "Range",
monthsDate: "MonthsDate",
})
},
methods: {
...mapActions('travail', {
setRange: "setRange",
}),
setRange6months: function () {
const start = addMonths(new Date(), -6)
const range = {
start: format(start, 'yyyy-MM'),
end: format(today, 'yyyy-MM'),
}
this.setRange(range)
},
setRange1year: function () {
const start = addMonths(new Date(), -12)
const range = {
start: format(start, 'yyyy-MM'),
end: format(today, 'yyyy-MM'),
}
this.setRange(range)
},
setRangeAll: function () {
const dates = this.monthsDate.map(a => parseISO(a, "yyyy-MM", new Date()))
const start = dates.reduce((a, b) => (a.MeasureDate > b.MeasureDate ? a: b))
const end = dates.reduce((a, b) => (a.MeasureDate > b.MeasureDate ? b: a))
const range = {
start: format(start, 'yyyy-MM'),
end: format(end, 'yyyy-MM'),
}
this.setRange(range)
},
},
}
</script>
<style scoped>
ul {
}
</style>