const { darksky } = require('#api'); const { createEmbed } = require('#utils/embed') const { pill, iconPill, smallPill, weatherIcon, timestamp, icon, link} = require('#utils/markdown'); const { editOrReply } = require('#utils/message') const { STATICS } = require('#utils/statics'); // TODO: Turn this into a general purpose permissions constant const { Permissions } = require("detritus-client/lib/constants"); module.exports = { name: 'weather', aliases: ['forecast'], label: 'query', metadata: { description: 'Displays information about the weather.', description_short: 'Local weather information', examples: ['weather Otter, Germany'], category: 'utils', usage: 'weather ', slashCommand: "weather" }, permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY], run: async (context, args) => { context.triggerTyping(); if(!args.query) return editOrReply(context, createEmbed("warning", context, `Missing Parameter (location).`)) try{ let data = await darksky(context, args.query) data = data.response.body let description = `### ${weatherIcon(data.result.current.icon.id)} ​ ​ ​ ​ ${Math.floor(data.result.current.temperature.current)}°C • ${data.result.current.condition.label}\n\n${pill("Feels like")} ${smallPill(Math.floor(data.result.current.temperature.feels_like) + "°C")} ​ ​ ​ ​ ${pill("Wind")} ${smallPill(data.result.current.wind.speed + " km/h")}` let secondaryPills = []; if(data.result.current.humidity > 0) secondaryPills.push(`${pill("Humidity")} ${smallPill(Math.floor(data.result.current.humidity * 100) + "%")}`) if(data.result.current.uvindex > 0) secondaryPills.push(`${pill("UV Index")} ${smallPill(data.result.current.uvindex)}`) if(secondaryPills.length >= 1) description += '\n' + secondaryPills.join(` ​ ​ ​ ​ `) description += `\n\n${iconPill("sun", "Sunrise")} ${timestamp(data.result.current.sun.sunrise, "t")} ​ ​ ${iconPill("moon", "Sunset")} ${timestamp(data.result.current.sun.sunset, "t")}` // Render weather alerts if(data.result.warnings.length >= 1){ for(const w of data.result.warnings.splice(0, 2)){ if(description.includes(w.label)) continue; description += `\n\n${icon("warning")} **${w.label}**\n-# ${w.source} • ${link(w.url, "Learn More", "Learn more about this alert")}` } } // Render Forecasts description += `\n` for(const i of data.result.forecast){ description += `\n${pill(i.day)} ​ ​ ${weatherIcon(i.icon)}` if(Math.floor(i.temperature.max).toString().length === 1) description += `${pill(Math.floor(i.temperature.max) + "°C ")}` else description += `${pill(Math.floor(i.temperature.max) + "°C")}` description += `​**/**​` if(Math.floor(i.temperature.min).toString().length === 1) description += `${smallPill(Math.floor(i.temperature.min) + "°C ")}` else description += `${smallPill(Math.floor(i.temperature.min) + "°C")}` } let e = createEmbed("default", context, { description, timestamp: new Date(data.result.current.date) }) e.footer.iconUrl = STATICS.weather if(data.result.location) e.footer.text = data.result.location //+ " • " + context.client.user.username if(data.result.current.icon) e.thumbnail = { url: data.result.current.icon.url } if(data.result.current.image) e.image = { url: data.result.current.image } return editOrReply(context, e) }catch(e){ return editOrReply(context, createEmbed("warning", context, `No weather data available for given location.`)) } }, };