Go back to Yahoo Weather

This commit is contained in:
Daniel Odendahl Jr
2017-12-13 16:05:31 +00:00
parent 9230975852
commit 52deb3ed0a
3 changed files with 85 additions and 27 deletions
+55
View File
@@ -0,0 +1,55 @@
const { Command } = require('discord.js-commando');
const { stripIndents } = require('common-tags');
const { MessageEmbed } = require('discord.js');
const snekfetch = require('snekfetch');
module.exports = class ForecastCommand extends Command {
constructor(client) {
super(client, {
name: 'forecast',
aliases: ['yahoo-forecast', 'weather-forecast', 'yahoo-weather-forecast'],
group: 'search',
memberName: 'forecast',
description: 'Responds with the seven-day forecast for a specified location.',
clientPermissions: ['EMBED_LINKS'],
args: [
{
key: 'query',
prompt: 'What location would you like to get the forecast for?',
type: 'string'
}
]
});
}
async run(msg, { query }) {
try {
const { body } = await snekfetch
.get('https://query.yahooapis.com/v1/public/yql')
.query({
// eslint-disable-next-line max-len
q: `select * from weather.forecast where u='f' AND woeid in (select woeid from geo.places(1) where text="${query}")`,
format: 'json'
});
if (!body.query.count) return msg.say('Could not find any results.');
const data = body.query.results.channel;
const embed = new MessageEmbed()
.setColor(0x0000FF)
.setAuthor(data.title, 'https://i.imgur.com/B9MMbtB.png')
.setURL(data.link)
.setTimestamp();
for (let i = 0; i < 6; i++) {
const forecast = data.item.forecast[i];
embed.addField(` ${forecast.day} - ${forecast.data}`,
stripIndents`
**High**: ${forecast.high}°F
**Low**: ${forecast.low}°F
**Condition**: ${forecast.text}
`);
}
return msg.embed(embed);
} catch (err) {
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
}
}
};
+29 -26
View File
@@ -1,20 +1,19 @@
const { Command } = require('discord.js-commando'); const { Command } = require('discord.js-commando');
const { MessageEmbed } = require('discord.js'); const { MessageEmbed } = require('discord.js');
const snekfetch = require('snekfetch'); const snekfetch = require('snekfetch');
const { OWM_KEY } = process.env;
module.exports = class WeatherCommand extends Command { module.exports = class WeatherCommand extends Command {
constructor(client) { constructor(client) {
super(client, { super(client, {
name: 'weather', name: 'weather',
aliases: ['open-weather-map'], aliases: ['yahoo-weather'],
group: 'search', group: 'search',
memberName: 'weather', memberName: 'weather',
description: 'Responds with weather information for a specific location.', description: 'Responds with weather information for a specified location.',
clientPermissions: ['EMBED_LINKS'], clientPermissions: ['EMBED_LINKS'],
args: [ args: [
{ {
key: 'location', key: 'query',
prompt: 'What location would you like to get the weather of?', prompt: 'What location would you like to get the weather of?',
type: 'string' type: 'string'
} }
@@ -22,45 +21,49 @@ module.exports = class WeatherCommand extends Command {
}); });
} }
async run(msg, { location }) { async run(msg, { query }) {
try { try {
const { body } = await snekfetch const { body } = await snekfetch
.get('http://api.openweathermap.org/data/2.5/weather') .get('https://query.yahooapis.com/v1/public/yql')
.query({ .query({
q: location, // eslint-disable-next-line max-len
units: 'metric', q: `select * from weather.forecast where u='f' AND woeid in (select woeid from geo.places(1) where text="${query}")`,
appid: OWM_KEY format: 'json'
}); });
if (!body.query.count) return msg.say('Could not find any results.');
const data = body.query.results.channel;
const embed = new MessageEmbed() const embed = new MessageEmbed()
.setColor(0xFF7A09) .setColor(0x0000FF)
.setAuthor('OpenWeatherMap', 'https://i.imgur.com/tUd1MYB.png') .setAuthor(data.title, 'https://i.imgur.com/B9MMbtB.png')
.setURL(`https://openweathermap.org/city/${body.id}`) .setURL(data.link)
.setThumbnail(body.weather[0].icon ? `http://openweathermap.org/img/w/${body.weather[0].icon}.png` : null)
.setTimestamp() .setTimestamp()
.addField(' City', .addField(' City',
body.name, true) data.location.city, true)
.addField(' Country', .addField(' Country',
body.sys.country, true) data.location.country, true)
.addField(' Region',
data.location.region, true)
.addField(' Condition', .addField(' Condition',
body.weather.map(cond => `${cond.main} (${cond.description})`).join('\n'), true) data.item.condition.text, true)
.addField(' Temperature', .addField(' Temperature',
body.main.temp ? `${body.main.temp}°C` : '???', true) `${data.item.condition.temp}°F`, true)
.addField(' Humidity', .addField(' Humidity',
body.main.humidity ? `${body.main.humidity}%` : '???', true) data.atmosphere.humidity, true)
.addField(' Pressure', .addField(' Pressure',
body.main.pressure ? `${body.main.pressure} hPa` : '???', true) data.atmosphere.pressure, true)
.addField(' Rising',
data.atmosphere.rising, true)
.addField(' Visibility', .addField(' Visibility',
body.visibility ? `${body.visibility}m` : '???', true) data.atmosphere.visibility, true)
.addField(' Cloudiness', .addField(' Wind Chill',
body.clouds && body.clouds.all ? `${body.clouds.all}%` : '???', true) data.wind.chill, true)
.addField(' Wind Direction', .addField(' Wind Direction',
body.wind && body.wind.deg ? `${body.wind.deg}°` : '???', true) data.wind.direction, true)
.addField(' Wind Speed', .addField(' Wind Speed',
body.wind && body.wind.speed ? `${body.wind.speed}m/s` : '???', true); data.wind.speed, true);
return msg.embed(embed); return msg.embed(embed);
} catch (err) { } catch (err) {
if (err.status === 404) return msg.say('Could not find any results.'); return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
} }
} }
}; };
+1 -1
View File
@@ -1,6 +1,6 @@
{ {
"name": "xiao", "name": "xiao",
"version": "57.0.0", "version": "57.1.0",
"description": "Your personal server companion.", "description": "Your personal server companion.",
"main": "Xiao.js", "main": "Xiao.js",
"scripts": { "scripts": {