1
0
Fork 0
mirror of https://github.com/em-squared/5e-drs.git synced 2025-10-30 13:14:20 +00:00

ajout d'un range slider pour filter les monstres par ID

This commit is contained in:
Maxime Moraine 2020-05-10 10:43:34 +02:00
parent 3efc2aaaf5
commit eebf902641
6 changed files with 58 additions and 3 deletions

View file

@ -7,6 +7,7 @@
label="Filtrer"
single-line
hide-details
clearable
color="accent"
></v-text-field>

View file

@ -2,16 +2,33 @@
<div class="monster-filters pa-1">
<v-text-field
class="mb-1"
class="mb-1 mx-2"
v-model="search"
label="Filtrer"
single-line
hide-details
clearable
color="accent"
></v-text-field>
<v-expansion-panels multiple flat hover v-model="panels">
<v-expansion-panel>
<v-expansion-panel-header>Tranche d'ID</v-expansion-panel-header>
<v-expansion-panel-content class="pt-4">
<v-range-slider
class="mt-6"
v-model="challengeRange"
min="0"
max="30"
thumb-size="24"
thumb-label="always"
hide-details
@end="onEndChallengeRange"
></v-range-slider>
</v-expansion-panel-content>
</v-expansion-panel>
<v-expansion-panel>
<v-expansion-panel-header>Types</v-expansion-panel-header>
<v-expansion-panel-content>
@ -58,7 +75,7 @@ export default {
data () {
return {
panels: [],
panels: []
}
},
@ -72,6 +89,15 @@ export default {
}
},
challengeRange: {
get () {
return this.$store.state.monsterFilters.challengeRange
},
set (newValue) {
this.$store.commit('monsterFilters/setChallengeRange', newValue)
}
},
types: {
get () {
return this.$store.state.monsterFilters.types
@ -111,6 +137,10 @@ export default {
methods: {
onEndChallengeRange () {
setUrlParams('trancheID', this.challengeRange)
},
switchType () {
let list = []
for (var i = 0; i < this.types.length; i++) {
@ -182,11 +212,15 @@ export default {
mounted () {
this.$store.dispatch('monsterFilters/reset')
let challengeRange = getUrlParameter(window.location.href, "trancheID").split(",")
let selectedSizes = getUrlParameter(window.location.href, "tailles").split(",")
let selectedTypes = getUrlParameter(window.location.href, "types").split(",")
let selectedEnvironments = getUrlParameter(window.location.href, "environnements").split(",")
let selectedDungeonTypes = getUrlParameter(window.location.href, "donjons").split(",")
if (challengeRange && challengeRange[0] != '') {
this.$store.commit('monsterFilters/setChallengeRange', challengeRange)
}
setListMutation(selectedTypes, this.$store, 'monsterFilters/setTypesFromList')
setListMutation(selectedSizes, this.$store, 'monsterFilters/setSizesFromList')
setListMutation(selectedEnvironments, this.$store, 'monsterFilters/setEnvironmentsFromList')

View file

@ -7,6 +7,7 @@
label="Filtrer"
single-line
hide-details
clearable
color="accent"
></v-text-field>