1
2
3
4
5
6
7
8
9
10
11
12
import { fetchText } from "https://esm.town/v/stevekrouse/fetchText?v=6";
import { load } from "npm:cheerio";
export async function latLngOfCity(args: { cityName: string }) {
const { cityName } = args;
const html = await fetchText(
`https://en.wikipedia.org/wiki/${cityName}`,
);
const $ = load(html);
const lat_lng = $("span.geo-default > span").first().text();
return lat_lng;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
import { weather as weather2 } from "https://esm.town/v/marcel/weather?v=4";
export const weather = async (city: string) => {
weather2(city)
.then(({ weather }) => ({
w: weather,
}))
.then(({ w }) =>
w.map((d) => ({
maxTempF: `${d.maxtempF}`,
minTempF: `${d.mintempF}`,
description: d.hourly.map((h) => h.weatherDesc[0].value),
}))
);
};
// Forked from @marcel.weather
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
import { weather as weather2 } from "https://esm.town/v/marcel/weather?v=4";
export let simpleWeather = async (city: string) =>
weather2(city)
.then(({ current_condition, weather }) => ({
c: current_condition[0],
w: weather,
}))
.then(({ c, w }) => ({
temp: `${c.temp_F}`,
feelsLike: `${c.FeelsLikeF}`,
currentHumidity: `${c.humidity}%`,
description: c.weatherDesc?.[0]?.value,
windSpeed: `${c.windspeedMiles}mph`,
forecast: w.map((f) => ({
date: new Date(f.date),
avgTemp: `${f.avgtempF}`,
hourly: f.hourly.map((h) => ({
rainChance: `${h.chanceofrain}`,
time: h.time,
description: h.weatherDesc?.[0]?.value,
windSpeed: `${h.windspeedMiles}mph`,
temp: `${h.tempF}`,
feelsLike: `${h.FeelsLikeF}`,
})),
})),
}));
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
import { weather as weather2 } from "https://esm.town/v/marcel/weather?v=4";
export let simpleWeather = async (city: string) =>
weather2(city)
.then(({ current_condition, weather }) => ({
c: current_condition[0],
w: weather,
}))
.then(({ c, w }) => ({
temp: `${c.temp_F}`,
feelsLike: `${c.FeelsLikeF}`,
description: c.weatherDesc?.[0]?.value,
windSpeed: `${c.windspeedMiles}mph`,
forecast: w.map((f) => ({
date: new Date(f.date),
minTemp: `${f.mintempF}`,
maxTemp: `${f.maxtempF}`,
hourly: f.hourly.map((h) => ({
description: h.weatherDesc?.[0]?.value,
windSpeed: `${h.windspeedMiles}mph`,
})),
})),
}));
// Forked from @patrickjm.simpleWeather
1
Next