Skip to content

Commit

Permalink
Revert "fix(VDataTable): selection duplication (#18908)"
Browse files Browse the repository at this point in the history
This reverts commit 9745cd1.
  • Loading branch information
johnleider committed May 2, 2024
1 parent 6cb03d4 commit 0ad2992
Showing 1 changed file with 9 additions and 10 deletions.
19 changes: 9 additions & 10 deletions packages/vuetify/src/components/VDataTable/composables/select.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
import { useProxiedModel } from '@/composables/proxiedModel'

// Utilities
import { computed, inject, provide, toRaw, toRef } from 'vue'
import { computed, inject, provide } from 'vue'
import { deepEqual, propsFactory, wrapInArray } from '@/util'

// Types
Expand Down Expand Up @@ -45,7 +45,7 @@ const singleSelectStrategy: DataTableSelectStrategy = {
showSelectAll: false,
allSelected: () => [],
select: ({ items, value }) => {
return new Set(value ? [toRaw(items[0]?.value)] : [])
return new Set(value ? [items[0]?.value] : [])
},
selectAll: ({ selected }) => selected,
}
Expand All @@ -55,8 +55,8 @@ const pageSelectStrategy: DataTableSelectStrategy = {
allSelected: ({ currentPage }) => currentPage,
select: ({ items, value, selected }) => {
for (const item of items) {
if (value) selected.add(toRaw(item.value))
else selected.delete(toRaw(item.value))
if (value) selected.add(item.value)
else selected.delete(item.value)
}

return selected
Expand All @@ -69,8 +69,8 @@ const allSelectStrategy: DataTableSelectStrategy = {
allSelected: ({ allItems }) => allItems,
select: ({ items, value, selected }) => {
for (const item of items) {
if (value) selected.add(toRaw(item.value))
else selected.delete(toRaw(item.value))
if (value) selected.add(item.value)
else selected.delete(item.value)
}

return selected
Expand Down Expand Up @@ -123,11 +123,11 @@ export function provideSelection (
})

function isSelected (items: SelectableItem | SelectableItem[]) {
return wrapInArray(items).every(item => selected.value.has(toRaw(item.value)))
return wrapInArray(items).every(item => selected.value.has(item.value))
}

function isSomeSelected (items: SelectableItem | SelectableItem[]) {
return wrapInArray(items).some(item => selected.value.has(toRaw(item.value)))
return wrapInArray(items).some(item => selected.value.has(item.value))
}

function select (items: SelectableItem[], value: boolean) {
Expand All @@ -141,8 +141,7 @@ export function provideSelection (
}

function toggleSelect (item: SelectableItem) {
const newItem = toRef(item)
select([newItem.value], !isSelected([newItem.value]))
select([item], !isSelected([item]))
}

function selectAll (value: boolean) {
Expand Down

0 comments on commit 0ad2992

Please sign in to comment.