From bd6e45d2601879c8c29e8fcd05382b97dfa29af0 Mon Sep 17 00:00:00 2001 From: jorgep Date: Fri, 14 Jun 2024 14:52:39 +0200 Subject: [PATCH] refactor: refs #6238 get percentage from back --- src/pages/Travel/ExtraCommunity.vue | 31 ++++++++++++++++++++--------- 1 file changed, 22 insertions(+), 9 deletions(-) diff --git a/src/pages/Travel/ExtraCommunity.vue b/src/pages/Travel/ExtraCommunity.vue index d6669260f..6ea34fa2e 100644 --- a/src/pages/Travel/ExtraCommunity.vue +++ b/src/pages/Travel/ExtraCommunity.vue @@ -53,6 +53,7 @@ const draggedRowIndex = ref(null); const targetRowIndex = ref(null); const entryRowIndex = ref(null); const draggedEntry = ref(null); +const travelKgPercentages = ref([]); const tableColumnComponents = { id: { @@ -290,6 +291,8 @@ const saveFieldValue = async (val, field, index) => { await axios.patch(`Travels/${id}`, params); // Actualizar la copia de los datos originales con el nuevo valor originalRowDataCopy.value[index][field] = val; + + await arrayData.fetch({ append: false }); } catch (err) { console.error('Error updating travel'); } @@ -314,6 +317,11 @@ onMounted(async () => { landedTo.value.setDate(landedTo.value.getDate() + 7); landedTo.value.setHours(23, 59, 59, 59); + const { data } = await axios.get('TravelKgPercentages', { + params: { filter: JSON.stringify({ order: 'value DESC' }) }, + }); + + travelKgPercentages.value = data; await getData(); }); @@ -432,13 +440,9 @@ const handleDragScroll = (event) => { } }; -const getRate = ({ kg, loadedKg, volumeKg }) => { - return Math.round((Math.max(loadedKg || 0, volumeKg || 0) / kg) * 100); -}; - const getColor = (percentage) => { - if (percentage >= 100) return 'red-10'; - else if (percentage >= 80 && percentage < 100) return 'deep-orange-10'; + for (const { value, className } of travelKgPercentages.value) + if (percentage > value) return className; }; @@ -481,7 +485,7 @@ const getColor = (percentage) => {