mirror of
https://gitlab.com/bignutty/labscore.git
synced 2025-06-08 22:23:03 -04:00
[cmd] wolfram-alpha
This commit is contained in:
parent
4eccafdbb6
commit
f4a22934c6
4 changed files with 78 additions and 1 deletions
65
commands/message/search/wolfram-alpha.js
Normal file
65
commands/message/search/wolfram-alpha.js
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
const { createEmbed, formatPaginationEmbeds } = require('../../../labscore/utils/embed')
|
||||||
|
const { link } = require('../../../labscore/utils/markdown')
|
||||||
|
const { editOrReply } = require('../../../labscore/utils/message')
|
||||||
|
const { STATICS } = require('../../../labscore/utils/statics')
|
||||||
|
|
||||||
|
const { paginator } = require('../../../labscore/client');
|
||||||
|
const { wolframAlpha } = require('../../../labscore/api');
|
||||||
|
|
||||||
|
function createWolframPage(context, pod){
|
||||||
|
let res = {
|
||||||
|
"embeds": [
|
||||||
|
createEmbed("default", context, {
|
||||||
|
description: `**${pod.title}**`,
|
||||||
|
footer: {
|
||||||
|
iconUrl: STATICS.wolframalpha,
|
||||||
|
text: `Wolfram|Alpha • ${context.application.name}`
|
||||||
|
}
|
||||||
|
})
|
||||||
|
]
|
||||||
|
}
|
||||||
|
if(pod.value) res.embeds[0].description = res.embeds[0].description + `\n${pod.value}`
|
||||||
|
if(pod.image) res.embeds[0].image = { url: pod.image };
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
const reactions = {
|
||||||
|
previousPage: "⬅️",
|
||||||
|
nextPage: "➡️"
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
name: 'wolframalpha',
|
||||||
|
label: 'query',
|
||||||
|
aliases: ['wa', 'wolfram-alpha'],
|
||||||
|
metadata: {
|
||||||
|
description: 'wolfram alpha search',
|
||||||
|
examples: ['wa Gray'],
|
||||||
|
category: 'search',
|
||||||
|
usage: 'wolframalpha <query>'
|
||||||
|
},
|
||||||
|
run: async (context, args) => {
|
||||||
|
context.triggerTyping();
|
||||||
|
if(!args.query) return editOrReply(context, {embeds:[createEmbed("warning", context, `Missing Parameter (query).`)]})
|
||||||
|
try{
|
||||||
|
let search = await wolframAlpha(context, args.query)
|
||||||
|
search = search.response
|
||||||
|
|
||||||
|
let pages = []
|
||||||
|
for(const res of search.body.data){
|
||||||
|
pages.push(createWolframPage(context, res))
|
||||||
|
}
|
||||||
|
|
||||||
|
pages = formatPaginationEmbeds(pages)
|
||||||
|
const message = context.message
|
||||||
|
const paging = await paginator.createReactionPaginator({
|
||||||
|
message,
|
||||||
|
pages,
|
||||||
|
reactions
|
||||||
|
});
|
||||||
|
}catch(e){
|
||||||
|
console.log(e)
|
||||||
|
return editOrReply(context, {embeds:[createEmbed("error", context, `Unable to perform Wolfram|Alpha search.`)]})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
|
@ -14,6 +14,7 @@ const Api = Object.freeze({
|
||||||
SEARCH_GOOGLE_IMAGES: '/search/google-images',
|
SEARCH_GOOGLE_IMAGES: '/search/google-images',
|
||||||
SEARCH_BING: '/search/bing',
|
SEARCH_BING: '/search/bing',
|
||||||
SEARCH_BING_IMAGES: '/search/bing-images',
|
SEARCH_BING_IMAGES: '/search/bing-images',
|
||||||
|
SEARCH_WOLFRAM_ALPHA: '/search/wolfram-alpha',
|
||||||
|
|
||||||
PHOTOFUNIA_YACHT: '/photofunia/yacht'
|
PHOTOFUNIA_YACHT: '/photofunia/yacht'
|
||||||
})
|
})
|
||||||
|
|
|
@ -70,6 +70,12 @@ module.exports.bingImages = async function(context, query){
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
module.exports.wolframAlpha = async function(context, query){
|
||||||
|
return await request(Api.SEARCH_WOLFRAM_ALPHA, "GET", {}, {
|
||||||
|
q: query
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
module.exports.yacht = async function(context, text){
|
module.exports.yacht = async function(context, text){
|
||||||
return await request(Api.PHOTOFUNIA_YACHT, "GET", {}, {
|
return await request(Api.PHOTOFUNIA_YACHT, "GET", {}, {
|
||||||
text: text
|
text: text
|
||||||
|
|
|
@ -17,6 +17,10 @@ const Statics = Object.freeze({
|
||||||
google: {
|
google: {
|
||||||
file: "brands/google.png",
|
file: "brands/google.png",
|
||||||
revision: 0
|
revision: 0
|
||||||
|
},
|
||||||
|
wolframalpha: {
|
||||||
|
file: "brands/wolframalpha.png",
|
||||||
|
revision: 0
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -29,5 +33,6 @@ module.exports.STATICS = Object.freeze({
|
||||||
photofunia: staticAsset(Statics.brands.photofunia),
|
photofunia: staticAsset(Statics.brands.photofunia),
|
||||||
genius: staticAsset(Statics.brands.genius),
|
genius: staticAsset(Statics.brands.genius),
|
||||||
bing: staticAsset(Statics.brands.bing),
|
bing: staticAsset(Statics.brands.bing),
|
||||||
google: staticAsset(Statics.brands.google)
|
google: staticAsset(Statics.brands.google),
|
||||||
|
wolframalpha: staticAsset(Statics.brands.wolframalpha)
|
||||||
})
|
})
|
Loading…
Add table
Add a link
Reference in a new issue