element-plus
Version:
A Component Library for Vue3.0
35 lines (29 loc) • 875 B
text/typescript
import { computed } from 'vue'
import { TransferProps } from './transfer'
export const useComputedData = (props: TransferProps) => {
const propsKey = computed(() => props.props.key)
const dataObj = computed(() => {
return props.data.reduce((o, cur) => (o[cur[propsKey.value]] = cur) && o, {})
})
const sourceData = computed(() => {
return props.data.filter(item => !props.modelValue.includes(item[propsKey.value]))
})
const targetData = computed(() => {
if (props.targetOrder === 'original') {
return props.data.filter(item => props.modelValue.includes(item[propsKey.value]))
} else {
return props.modelValue.reduce((arr, cur) => {
const val = dataObj.value[cur]
if (val) {
arr.push(val)
}
return arr
}, [])
}
})
return {
propsKey,
sourceData,
targetData,
}
}