8315-devToTest #1094
|
@ -20,21 +20,15 @@ const props = defineProps({
|
||||||
});
|
});
|
||||||
const state = useState();
|
const state = useState();
|
||||||
|
|
||||||
const total = computed(() => state.get('orderTotal'));
|
const orderData = computed(() => state.get('orderData'));
|
||||||
|
|
||||||
const prices = ref((props.item.prices || []).map((item) => ({ ...item, quantity: 0 })));
|
const prices = ref((props.item.prices || []).map((item) => ({ ...item, quantity: 0 })));
|
||||||
const isLoading = ref(false);
|
const isLoading = ref(false);
|
||||||
const calculateTotals = (items) => {
|
|
||||||
return items.reduce(
|
|
||||||
(acc, item) => {
|
|
||||||
acc.totalQuantity += item.quantity;
|
|
||||||
acc.totalSum += item.quantity * item.price;
|
|
||||||
return acc;
|
|
||||||
},
|
|
||||||
{ totalQuantity: 0, totalSum: 0 }
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
const totalQuantity = (items) =>
|
||||||
|
items.reduce((acc, item) => {
|
||||||
|
return acc + item.quantity;
|
||||||
|
}, 0);
|
||||||
const addToOrder = async () => {
|
const addToOrder = async () => {
|
||||||
if (isLoading.value) return;
|
if (isLoading.value) return;
|
||||||
isLoading.value = true;
|
isLoading.value = true;
|
||||||
|
@ -44,11 +38,18 @@ const addToOrder = async () => {
|
||||||
orderFk: Number(route.params.id),
|
orderFk: Number(route.params.id),
|
||||||
});
|
});
|
||||||
|
|
||||||
const { totalQuantity, totalSum } = calculateTotals(items);
|
const { data: orderTotal } = await axios.get(
|
||||||
|
`Orders/${Number(route.params.id)}/getTotal`
|
||||||
|
);
|
||||||
|
|
||||||
state.set('orderTotal', total.value + totalSum);
|
state.set('orderTotal', orderTotal);
|
||||||
|
const rows = orderData.value.rows.push(...items) || [];
|
||||||
|
state.set('orderData', {
|
||||||
|
...orderData.value,
|
||||||
|
rows,
|
||||||
|
});
|
||||||
notify(t('globals.dataSaved'), 'positive');
|
notify(t('globals.dataSaved'), 'positive');
|
||||||
emit('added', -totalQuantity);
|
emit('added', -totalQuantity(items));
|
||||||
isLoading.value = false;
|
isLoading.value = false;
|
||||||
};
|
};
|
||||||
const canAddToOrder = () => {
|
const canAddToOrder = () => {
|
||||||
|
|
Loading…
Reference in New Issue