Skip to content

Commit

Permalink
Merge pull request #11 from LegallyNotBlonde/cleaned_firedata_20115_2019
Browse files Browse the repository at this point in the history
calculating stats and writing files for interactive link
  • Loading branch information
LegallyNotBlonde authored Aug 22, 2024
2 parents 87f6d20 + 170fdb8 commit 081536b
Show file tree
Hide file tree
Showing 4 changed files with 603 additions and 1 deletion.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -35,5 +35,5 @@ ___
* **[Charts](https://github.com/LegallyNotBlonde/Fire-Analysis/tree/main/Charts)** folder contains various visualization displays
* **Files with codes** have **self-explanatory names** and are available in the [main body of the repo](https://github.com/LegallyNotBlonde/Fire-Analysis)
* **[Presentation](https://docs.google.com/presentation/d/18218T6EQrjeQu0vUXJoN1WikxMXPLT6Y-v4c-PHHHL0/edit#slide=id.p)** with more information about the projects and all necessary charts.
* #### *[Link to the interactive visualization LINK TO BE ADDED]()*
* #### *[Link to the interactive visualization](http://127.0.0.1:5500/index.html)*

103 changes: 103 additions & 0 deletions app_java_visualization.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,103 @@
<script>
// Load the yearly statistics CSV file with D3.js
d3.csv('Outputs/yearly_stats.csv').then(function(data) {
// Populate dropdown with unique years
const yearSelect = d3.select("#year-select");
const uniqueYears = [...new Set(data.map(d => d.Year))];
uniqueYears.forEach(year => {
yearSelect.append("option").text(year).attr("value", year);
});

// Initial display
updateCharts(data, uniqueYears[0]);

// Update charts when the year is selected
yearSelect.on("change", function() {
const selectedYear = this.value;
updateCharts(data, selectedYear);
});

function updateCharts(data, selectedYear) {
// Filter data by the selected year
const filteredData = data.filter(d => d.Year == selectedYear)[0];

// Console log the filtered data to verify
console.log("Filtered Data:", filteredData);

// Update total stats for the selected year
const totalStatsDiv = d3.select("#total-stats");
totalStatsDiv.html(`
<p><strong>Total Fires:</strong> ${filteredData.total_fires}</p>
<p><strong>Total Acres:</strong> ${filteredData.total_acres}</p>
<p><strong>Average Duration:</strong> ${filteredData.avg_duration}</p>
<p><strong>Total Deaths:</strong> ${filteredData.total_deaths}</p>
`);

// Load the monthly statistics CSV file with D3.js
d3.csv('Outputs/monthly_stats.csv').then(function(monthlyData) {
// Filter monthly data by the selected year
const monthlyFilteredData = monthlyData.filter(d => d.Year == selectedYear);

// Update Total Fires chart by Month
const traceFires = {
x: monthlyFilteredData.map(d => d.Month),
y: monthlyFilteredData.map(d => d.total_fires),
type: 'bar',
name: 'Total Fires'
};
const layoutFires = {
title: `Total Fires by Month in ${selectedYear}`,
xaxis: { title: 'Month' },
yaxis: { title: 'Total Fires' }
};
Plotly.newPlot('chart-fires', [traceFires], layoutFires);

// Update Total Acres chart by Month
const traceAcres = {
x: monthlyFilteredData.map(d => d.Month),
y: monthlyFilteredData.map(d => d.total_acres),
type: 'bar',
name: 'Total Acres'
};
const layoutAcres = {
title: `Total Acres by Month in ${selectedYear}`,
xaxis: { title: 'Month' },
yaxis: { title: 'Total Acres' }
};
Plotly.newPlot('chart-acres', [traceAcres], layoutAcres);

// Update Average Duration chart by Month
const traceDuration = {
x: monthlyFilteredData.map(d => d.Month),
y: monthlyFilteredData.map(d => d.avg_duration),
type: 'bar',
name: 'Average Duration'
};
const layoutDuration = {
title: `Average Duration by Month in ${selectedYear}`,
xaxis: { title: 'Month' },
yaxis: { title: 'Average Duration' }
};
Plotly.newPlot('chart-duration', [traceDuration], layoutDuration);

// Update Total Deaths chart by Month
const traceDeaths = {
x: monthlyFilteredData.map(d => d.Month),
y: monthlyFilteredData.map(d => d.total_deaths),
type: 'bar',
name: 'Total Deaths'
};
const layoutDeaths = {
title: `Total Deaths by Month in ${selectedYear}`,
xaxis: { title: 'Month' },
yaxis: { title: 'Total Deaths' }
};
Plotly.newPlot('chart-deaths', [traceDeaths], layoutDeaths);
}).catch(function(error) {
console.error("Error loading monthly data:", error);
});
}
}).catch(function(error) {
console.error("Error loading yearly data:", error); // Error handling
});
</script>
Loading

0 comments on commit 081536b

Please sign in to comment.