From 7fa8a2a13d98d5a25df2cd9a11e40940c5c6d6c5 Mon Sep 17 00:00:00 2001
From: Minotriz02
Date: Thu, 14 Nov 2024 13:59:43 -0500
Subject: [PATCH] AC-234 Compare data feature added
---
.../components/weatherChart/WeatherChart.js | 24 +++++-
src/src/pages/dashboard/Dashboard.js | 73 +++++++++++++++++--
2 files changed, 87 insertions(+), 10 deletions(-)
diff --git a/src/src/components/weatherChart/WeatherChart.js b/src/src/components/weatherChart/WeatherChart.js
index 001c4aa..dbdea7d 100644
--- a/src/src/components/weatherChart/WeatherChart.js
+++ b/src/src/components/weatherChart/WeatherChart.js
@@ -27,6 +27,7 @@ Chart.register(
const WeatherChart = ({
title,
data,
+ dataSpatial,
unit,
color,
isChartLoading,
@@ -71,7 +72,7 @@ const WeatherChart = ({
document.body.removeChild(link);
};
- const chartConfig = (label, data, color) => ({
+ const chartConfig = (label, data, color, dataSpatial, spatialColor) => ({
labels: data.map((item) => item.label),
datasets: [
{
@@ -81,6 +82,17 @@ const WeatherChart = ({
borderColor: color,
tension: 0.1,
},
+ ...(dataSpatial
+ ? [
+ {
+ label: `Datos satelitales`,
+ data: dataSpatial.map((item) => item.value),
+ fill: false,
+ borderColor: spatialColor,
+ tension: 0.1,
+ },
+ ]
+ : []),
],
});
@@ -91,7 +103,7 @@ const WeatherChart = ({
y: { title: { display: true, text: unit }, beginAtZero: false },
},
}),
- []
+ [unit]
);
const ChartOptionsStartedAtZero = useMemo(
@@ -177,7 +189,13 @@ const WeatherChart = ({
identificar patrones climáticos recientes en la región.
{
precipitation: [],
solRad: [],
});
+ const [dataSpacial, setDataSpacial] = useState({
+ tempMax: [],
+ tempMin: [],
+ precipitation: [],
+ solRad: [],
+ });
const [stations, setStations] = useState([]);
const [currentStation, setCurrentStation] = useState(null);
const [currentStationSpacial, setCurrentStationSpacial] = useState(null);
@@ -27,6 +41,7 @@ const Dashboard = () => {
const [endDataDate, setEndDataDate] = useState();
const [endDataSpacialDate, setEndDataSpacialDate] = useState();
const [isFavorite, setIsFavorite] = useState(false);
+ const [showToast, setShowToast] = useState(false);
const { idWS } = useParams();
const navigate = useNavigate();
@@ -81,11 +96,11 @@ const Dashboard = () => {
const lastDataSpacialAvailable = await Services.getLastDailyWeather(
currentStationSpacial.id
);
- const formattedSpacialEndDate = new Date(
- lastDataSpacialAvailable[0].date
- )
- .toISOString()
- .split("T")[0];
+ const formattedSpacialEndDate = lastDataSpacialAvailable.length
+ ? new Date(lastDataSpacialAvailable[0].date)
+ .toISOString()
+ .split("T")[0]
+ : "N/A";
setEndDataSpacialDate(formattedSpacialEndDate);
const startDate = new Date(lastDataAvailable[0].date);
@@ -223,10 +238,50 @@ const Dashboard = () => {
setIsFavorite(true);
};
- const compareData = () => {};
+ const compareData = () => {
+ const fetchData = async () => {
+ if (!currentStationSpacial) return;
+ try {
+ const response = await Services.getDailyWeather(
+ startDate,
+ endDate,
+ currentStationSpacial.id
+ );
+ const parsedData = parseWeatherData(response.daily_data);
+ setDataSpacial(parsedData);
+ console.log(parsedData);
+ } catch (error) {
+ console.error("Error fetching daily weather data:", error);
+ } finally {
+ if (dataSpacial.tempMax.length === 0) {
+ setShowToast(true);
+ }
+ }
+ };
+ fetchData();
+ };
return (
+
+ setShowToast(false)}
+ show={showToast}
+ delay={3000}
+ autohide
+ bg="warning"
+ >
+
+
+ La estacion no tiene datos espaciales para este periodo de tiempo!
+
+
+
+
{
{
{
{