Added precipitation prediction

This commit is contained in:
Zakary Timson 2018-12-06 19:05:31 -05:00
parent d844aad122
commit e6201c62a7
3 changed files with 8 additions and 1 deletions

View File

@ -6,6 +6,7 @@
<excludeFolder url="file://$MODULE_DIR$/dist" /> <excludeFolder url="file://$MODULE_DIR$/dist" />
<excludeFolder url="file://$MODULE_DIR$/tmp" /> <excludeFolder url="file://$MODULE_DIR$/tmp" />
</content> </content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" /> <orderEntry type="sourceFolder" forTests="false" />
</component> </component>
</module> </module>

View File

@ -8,7 +8,7 @@
</div> </div>
<div class="my-4 d-flex mx-auto" style="max-width: 450px"> <div class="my-4 d-flex mx-auto" style="max-width: 450px">
<div class="text-center flex-grow-1"> <div class="text-center flex-grow-1">
<i class="wi wi-fw wi-humidity"></i> {{weatherService.humidity}} % <i class="wi wi-fw wi-umbrella"></i> {{weatherService.pop}} mm
</div> </div>
<div class="text-center flex-grow-1"> <div class="text-center flex-grow-1">
<i class="wi wi-fw wi-cloud"></i> {{weatherService.cloudCover}} % <i class="wi wi-fw wi-cloud"></i> {{weatherService.cloudCover}} %

View File

@ -18,6 +18,7 @@ export class WeatherService {
forecast = []; forecast = [];
humidity = 0; humidity = 0;
icon: string; icon: string;
pop = 0;
pressure = 0; pressure = 0;
sunrise: Date; sunrise: Date;
sunset: Date; sunset: Date;
@ -46,6 +47,11 @@ export class WeatherService {
// 5 day forecast // 5 day forecast
httpClient.get(`https://api.openweathermap.org/data/2.5/forecast?q=${this.city},${this.countryCode}&APPID=${this.apiKey}&units=metric`).toPromise().then((weather: any) => { httpClient.get(`https://api.openweathermap.org/data/2.5/forecast?q=${this.city},${this.countryCode}&APPID=${this.apiKey}&units=metric`).toPromise().then((weather: any) => {
this.pop = Math.round(weather.list.slice(0, 4).reduce((acc, weather) => {
if(weather['rain']) acc += weather['rain']['3h'] || 0;
if(weather['snow']) acc += weather['snow']['3h'] || 0;
return acc;
}, 0) * 10) / 10;
let temp = weather.list.filter(weather => weather.dt_txt.indexOf('12:00:00') != -1); let temp = weather.list.filter(weather => weather.dt_txt.indexOf('12:00:00') != -1);
temp.splice(0, temp.length - 5); temp.splice(0, temp.length - 5);
this.forecast = temp.map(weather => ({ this.forecast = temp.map(weather => ({