mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-14 15:57:42 +02:00
Change Weather to use OpenWeatherMap
This commit is contained in:
@@ -1,87 +0,0 @@
|
|||||||
const Command = require('../../structures/Command');
|
|
||||||
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',
|
|
||||||
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, args) {
|
|
||||||
const { query } = args;
|
|
||||||
try {
|
|
||||||
const { body } = await snekfetch
|
|
||||||
.get('https://query.yahooapis.com/v1/public/yql')
|
|
||||||
.query({
|
|
||||||
q: `select * from weather.forecast where u='f' AND woeid in (select woeid from geo.places(1) where text="${query}")`, // eslint-disable-line max-len
|
|
||||||
format: 'json'
|
|
||||||
});
|
|
||||||
if (!body.query.count) return msg.say('Could not find any results.');
|
|
||||||
const forecasts = body.query.results.channel.item.forecast;
|
|
||||||
const embed = new MessageEmbed()
|
|
||||||
.setColor(0x0000FF)
|
|
||||||
.setAuthor(body.query.results.channel.title, 'https://i.imgur.com/2MT0ViC.png')
|
|
||||||
.setURL(body.query.results.channel.link)
|
|
||||||
.setTimestamp()
|
|
||||||
.addField(`❯ ${forecasts[0].day} - ${forecasts[0].date}`,
|
|
||||||
stripIndents`
|
|
||||||
**High:** ${forecasts[0].high}°F
|
|
||||||
**Low:** ${forecasts[0].low}°F
|
|
||||||
**Condition:** ${forecasts[0].text}
|
|
||||||
`)
|
|
||||||
.addField(`❯ ${forecasts[1].day} - ${forecasts[1].date}`,
|
|
||||||
stripIndents`
|
|
||||||
**High:** ${forecasts[1].high}°F
|
|
||||||
**Low:** ${forecasts[1].low}°F
|
|
||||||
**Condition:** ${forecasts[1].text}
|
|
||||||
`)
|
|
||||||
.addField(`❯ ${forecasts[2].day} - ${forecasts[2].date}`,
|
|
||||||
stripIndents`
|
|
||||||
**High:** ${forecasts[2].high}°F
|
|
||||||
**Low:** ${forecasts[2].low}°F
|
|
||||||
**Condition:** ${forecasts[2].text}
|
|
||||||
`)
|
|
||||||
.addField(`❯ ${forecasts[3].day} - ${forecasts[3].date}`,
|
|
||||||
stripIndents`
|
|
||||||
**High:** ${forecasts[3].high}°F
|
|
||||||
**Low:** ${forecasts[3].low}°F
|
|
||||||
**Condition:** ${forecasts[3].text}
|
|
||||||
`)
|
|
||||||
.addField(`❯ ${forecasts[4].day} - ${forecasts[4].date}`,
|
|
||||||
stripIndents`
|
|
||||||
**High:** ${forecasts[4].high}°F
|
|
||||||
**Low:** ${forecasts[4].low}°F
|
|
||||||
**Condition:** ${forecasts[4].text}
|
|
||||||
`)
|
|
||||||
.addField(`❯ ${forecasts[5].day} - ${forecasts[5].date}`,
|
|
||||||
stripIndents`
|
|
||||||
**High:** ${forecasts[5].high}°F
|
|
||||||
**Low:** ${forecasts[5].low}°F
|
|
||||||
**Condition:** ${forecasts[5].text}
|
|
||||||
`)
|
|
||||||
.addField(`❯ ${forecasts[6].day} - ${forecasts[6].date}`,
|
|
||||||
stripIndents`
|
|
||||||
**High:** ${forecasts[6].high}°F
|
|
||||||
**Low:** ${forecasts[6].low}°F
|
|
||||||
**Condition:** ${forecasts[6].text}
|
|
||||||
`);
|
|
||||||
return msg.embed(embed);
|
|
||||||
} catch (err) {
|
|
||||||
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
+36
-23
@@ -1,6 +1,9 @@
|
|||||||
const Command = require('../../structures/Command');
|
const Command = require('../../structures/Command');
|
||||||
const { MessageEmbed } = require('discord.js');
|
const { MessageEmbed } = require('discord.js');
|
||||||
const snekfetch = require('snekfetch');
|
const snekfetch = require('snekfetch');
|
||||||
|
const { list } = require('../../structures/Util');
|
||||||
|
const { OWM_KEY } = process.env;
|
||||||
|
const types = ['zip', 'name', 'lat/lon'];
|
||||||
|
|
||||||
module.exports = class WeatherCommand extends Command {
|
module.exports = class WeatherCommand extends Command {
|
||||||
constructor(client) {
|
constructor(client) {
|
||||||
@@ -11,6 +14,16 @@ module.exports = class WeatherCommand extends Command {
|
|||||||
description: 'Responds with weather information for a specified location.',
|
description: 'Responds with weather information for a specified location.',
|
||||||
clientPermissions: ['EMBED_LINKS'],
|
clientPermissions: ['EMBED_LINKS'],
|
||||||
args: [
|
args: [
|
||||||
|
{
|
||||||
|
key: 'type',
|
||||||
|
prompt: `What type should the search be? Either ${list(types, 'or')}.`,
|
||||||
|
type: 'string',
|
||||||
|
validate: type => {
|
||||||
|
if (types.includes(type)) return true;
|
||||||
|
return `Invalid type, please enter either ${list(types, 'or')}.`;
|
||||||
|
},
|
||||||
|
parse: type => type.toLowerCase()
|
||||||
|
},
|
||||||
{
|
{
|
||||||
key: 'query',
|
key: 'query',
|
||||||
prompt: 'What location would you like to get the weather of?',
|
prompt: 'What location would you like to get the weather of?',
|
||||||
@@ -21,46 +34,46 @@ module.exports = class WeatherCommand extends Command {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async run(msg, args) {
|
async run(msg, args) {
|
||||||
const { query } = args;
|
const { type, query } = args;
|
||||||
try {
|
try {
|
||||||
const { body } = await snekfetch
|
const { body } = await snekfetch
|
||||||
.get('https://query.yahooapis.com/v1/public/yql')
|
.get('http://api.openweathermap.org/data/2.5/weather')
|
||||||
.query({
|
.query({
|
||||||
q: `select * from weather.forecast where u='f' AND woeid in (select woeid from geo.places(1) where text="${query}")`, // eslint-disable-line max-len
|
q: type === 'name' ? query : '',
|
||||||
format: 'json'
|
zip: type === 'zip' ? query : '',
|
||||||
|
lat: type === 'lat/lon' ? query.split('/')[0] : '',
|
||||||
|
lon: type === 'lat/lon' ? query.split('/')[1] : '',
|
||||||
|
units: 'metric',
|
||||||
|
appid: OWM_KEY
|
||||||
});
|
});
|
||||||
if (!body.query.count) return msg.say('Could not find any results.');
|
|
||||||
const embed = new MessageEmbed()
|
const embed = new MessageEmbed()
|
||||||
.setColor(0x0000FF)
|
.setColor(0xFF7A09)
|
||||||
.setAuthor(body.query.results.channel.title, 'https://i.imgur.com/2MT0ViC.png')
|
.setAuthor('OpenWeatherMap', 'https://i.imgur.com/S5MHmeY.png')
|
||||||
.setURL(body.query.results.channel.link)
|
.setThumbnail(body.weather[0].icon ? `http://openweathermap.org/img/w/${body.weather[0].icon}.png` : null)
|
||||||
.setTimestamp()
|
.setTimestamp()
|
||||||
.addField('❯ City',
|
.addField('❯ City',
|
||||||
body.query.results.channel.location.city, true)
|
body.name, true)
|
||||||
.addField('❯ Country',
|
.addField('❯ Country',
|
||||||
body.query.results.channel.location.country, true)
|
body.sys.country, true)
|
||||||
.addField('❯ Region',
|
|
||||||
body.query.results.channel.location.region, true)
|
|
||||||
.addField('❯ Condition',
|
.addField('❯ Condition',
|
||||||
body.query.results.channel.item.condition.text, true)
|
body.weather.map(cond => `${cond.main} (${cond.description})`).join('\n'), true)
|
||||||
.addField('❯ Temperature',
|
.addField('❯ Temperature',
|
||||||
`${body.query.results.channel.item.condition.temp}°F`, true)
|
`${body.main.temp}°C`, true)
|
||||||
.addField('❯ Humidity',
|
.addField('❯ Humidity',
|
||||||
body.query.results.channel.atmosphere.humidity, true)
|
`${body.main.humidity}%`, true)
|
||||||
.addField('❯ Pressure',
|
.addField('❯ Pressure',
|
||||||
body.query.results.channel.atmosphere.pressure, true)
|
`${body.main.pressure} hPa`, true)
|
||||||
.addField('❯ Rising',
|
|
||||||
body.query.results.channel.atmosphere.rising, true)
|
|
||||||
.addField('❯ Visibility',
|
.addField('❯ Visibility',
|
||||||
body.query.results.channel.atmosphere.visibility, true)
|
`${body.visibility}m`, true)
|
||||||
.addField('❯ Wind Chill',
|
.addField('❯ Cloudiness',
|
||||||
body.query.results.channel.wind.chill, true)
|
`${body.clouds.all}%`, true)
|
||||||
.addField('❯ Wind Direction',
|
.addField('❯ Wind Direction',
|
||||||
body.query.results.channel.wind.direction, true)
|
`${body.wind.deg}°`, true)
|
||||||
.addField('❯ Wind Speed',
|
.addField('❯ Wind Speed',
|
||||||
body.query.results.channel.wind.speed, true);
|
`${body.wind.speed}m/s`, 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.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
+1
-1
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "xiaobot",
|
"name": "xiaobot",
|
||||||
"version": "36.1.2",
|
"version": "37.0.0",
|
||||||
"description": "Your personal server companion.",
|
"description": "Your personal server companion.",
|
||||||
"main": "Shard.js",
|
"main": "Shard.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|||||||
Reference in New Issue
Block a user