element-plus
Version:
A Component Library for Vue 3
33 lines (30 loc) • 897 B
JavaScript
import { computed } from 'vue';
const useComputedData = (props) => {
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
};
};
export { useComputedData };
//# sourceMappingURL=useComputedData.mjs.map