make sure to use filtered selected keys
This commit is contained in:
parent
ecff6acf2d
commit
10ecc2c816
2 changed files with 11 additions and 5 deletions
|
@ -22,11 +22,17 @@ const SelectableList = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
|
allKeys () {
|
||||||
|
return this.items.map(this.getKey)
|
||||||
|
},
|
||||||
|
filteredSelected () {
|
||||||
|
return this.allKeys.filter(key => this.selected.indexOf(key) !== -1)
|
||||||
|
},
|
||||||
allSelected () {
|
allSelected () {
|
||||||
return !this.items.find(item => !this.isSelected(item))
|
return this.filteredSelected.length === this.items.length
|
||||||
},
|
},
|
||||||
noneSelected () {
|
noneSelected () {
|
||||||
return !this.items.find(item => this.isSelected(item))
|
return this.filteredSelected.length === 0
|
||||||
},
|
},
|
||||||
someSelected () {
|
someSelected () {
|
||||||
return !this.allSelected && !this.noneSelected
|
return !this.allSelected && !this.noneSelected
|
||||||
|
@ -34,7 +40,7 @@ const SelectableList = {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
isSelected (item) {
|
isSelected (item) {
|
||||||
return this.selected.indexOf(this.getKey(item)) !== -1
|
return this.filteredSelected.indexOf(this.getKey(item)) !== -1
|
||||||
},
|
},
|
||||||
toggle (checked, item) {
|
toggle (checked, item) {
|
||||||
const key = this.getKey(item)
|
const key = this.getKey(item)
|
||||||
|
@ -49,7 +55,7 @@ const SelectableList = {
|
||||||
},
|
},
|
||||||
toggleAll (value) {
|
toggleAll (value) {
|
||||||
if (value) {
|
if (value) {
|
||||||
this.selected = this.items.map(this.getKey)
|
this.selected = this.allKeys.slice(0)
|
||||||
} else {
|
} else {
|
||||||
this.selected = []
|
this.selected = []
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<Checkbox :checked="allSelected" @change="toggleAll" :indeterminate="someSelected">{{ $t('selectable_list.select_all') }}</Checkbox>
|
<Checkbox :checked="allSelected" @change="toggleAll" :indeterminate="someSelected">{{ $t('selectable_list.select_all') }}</Checkbox>
|
||||||
</div>
|
</div>
|
||||||
<div class="selectable-list-header-actions">
|
<div class="selectable-list-header-actions">
|
||||||
<slot name="header" :selected="selected" />
|
<slot name="header" :selected="filteredSelected" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<List :items="items" :getKey="getKey">
|
<List :items="items" :getKey="getKey">
|
||||||
|
|
Loading…
Reference in a new issue