added global ffz and bttv emotes

This commit is contained in:
fourtf 2017-01-26 17:26:20 +01:00
parent e0abfb9a1f
commit fb14e86364
7 changed files with 215 additions and 9 deletions

View file

@ -24,6 +24,94 @@ Channel::Channel(const QString &channel)
// } // }
} }
void
Channel::reloadBttvEmotes()
{
QNetworkAccessManager *manager = new QNetworkAccessManager();
QUrl url("https://api.frankerfacez.com/v1/set/global");
QNetworkRequest request(url);
QNetworkReply *reply = manager->get(request);
QObject::connect(reply, &QNetworkReply::finished, [=] {
if (reply->error() == QNetworkReply::NetworkError::NoError) {
QByteArray data = reply->readAll();
QJsonDocument jsonDoc(QJsonDocument::fromJson(data));
QJsonObject root = jsonDoc.object();
auto sets = root.value("sets").toObject();
for (const QJsonValue &set : sets) {
auto emoticons = set.toObject().value("emoticons").toArray();
for (const QJsonValue &emote : emoticons) {
QJsonObject object = emote.toObject();
// margins
int id = object.value("id").toInt();
QString code = object.value("name").toString();
QJsonObject urls = object.value("urls").toObject();
QString url1 = "http:" + urls.value("1").toString();
Emotes::getBttvEmotes().insert(
code, new messages::LazyLoadedImage(
url1, 1, code, code + "\nGlobal Ffz Emote"));
}
}
}
reply->deleteLater();
manager->deleteLater();
});
}
void
Channel::reloadFfzEmotes()
{
QNetworkAccessManager *manager = new QNetworkAccessManager();
QUrl url("https://api.frankerfacez.com/v1/set/global");
QNetworkRequest request(url);
QNetworkReply *reply = manager->get(request);
QObject::connect(reply, &QNetworkReply::finished, [=] {
if (reply->error() == QNetworkReply::NetworkError::NoError) {
QByteArray data = reply->readAll();
QJsonDocument jsonDoc(QJsonDocument::fromJson(data));
QJsonObject root = jsonDoc.object();
auto sets = root.value("sets").toObject();
for (const QJsonValue &set : sets) {
auto emoticons = set.toObject().value("emoticons").toArray();
for (const QJsonValue &emote : emoticons) {
QJsonObject object = emote.toObject();
// margins
int id = object.value("id").toInt();
QString code = object.value("name").toString();
QJsonObject urls = object.value("urls").toObject();
QString url1 = "http:" + urls.value("1").toString();
Emotes::getBttvEmotes().insert(
code, new messages::LazyLoadedImage(
url1, 1, code, code + "\nGlobal Ffz Emote"));
}
}
}
reply->deleteLater();
manager->deleteLater();
});
}
QVector<std::shared_ptr<messages::Message>> QVector<std::shared_ptr<messages::Message>>
Channel::getMessagesClone() Channel::getMessagesClone()
{ {

View file

@ -99,6 +99,13 @@ public:
return messages; return messages;
} }
void
reloadChannelEmotes()
{
reloadBttvEmotes();
reloadFfzEmotes();
}
private: private:
QVector<std::shared_ptr<messages::Message>> messages; QVector<std::shared_ptr<messages::Message>> messages;
@ -117,6 +124,9 @@ private:
int streamViewerCount; int streamViewerCount;
QString streamStatus; QString streamStatus;
QString streamGame; QString streamGame;
void reloadBttvEmotes();
void reloadFfzEmotes();
}; };
} }

View file

@ -2,6 +2,14 @@
#include "resources.h" #include "resources.h"
#include <QDebug> #include <QDebug>
#include <QJsonArray>
#include <QJsonDocument>
#include <QJsonObject>
#include <QJsonValue>
#include <QNetworkAccessManager>
#include <QNetworkReply>
#include <QNetworkRequest>
#include <memory>
namespace chatterino { namespace chatterino {
@ -25,6 +33,100 @@ Emotes::Emotes()
{ {
} }
void
Emotes::loadGlobalEmotes()
{
loadBttvEmotes();
loadFfzEmotes();
}
void
Emotes::loadBttvEmotes()
{
// bttv
QNetworkAccessManager *manager = new QNetworkAccessManager();
QUrl url("https://api.betterttv.net/2/emotes");
QNetworkRequest request(url);
QNetworkReply *reply = manager->get(request);
QObject::connect(reply, &QNetworkReply::finished, [=] {
if (reply->error() == QNetworkReply::NetworkError::NoError) {
QByteArray data = reply->readAll();
QJsonDocument jsonDoc(QJsonDocument::fromJson(data));
QJsonObject root = jsonDoc.object();
auto emotes = root.value("emotes").toArray();
QString _template = "https:" + root.value("urlTemplate").toString();
for (const QJsonValue &emote : emotes) {
QString id = emote.toObject().value("id").toString();
QString code = emote.toObject().value("code").toString();
// emote.value("imageType").toString();
QString tmp = _template;
tmp.detach();
QString url =
tmp.replace("{{id}}", id).replace("{{image}}", "1x");
Emotes::getBttvEmotes().insert(
code, new messages::LazyLoadedImage(
url, 1, code, code + "\nGlobal Bttv Emote"));
}
}
reply->deleteLater();
manager->deleteLater();
});
}
void
Emotes::loadFfzEmotes()
{
// bttv
QNetworkAccessManager *manager = new QNetworkAccessManager();
QUrl url("https://api.frankerfacez.com/v1/set/global");
QNetworkRequest request(url);
QNetworkReply *reply = manager->get(request);
QObject::connect(reply, &QNetworkReply::finished, [=] {
if (reply->error() == QNetworkReply::NetworkError::NoError) {
QByteArray data = reply->readAll();
QJsonDocument jsonDoc(QJsonDocument::fromJson(data));
QJsonObject root = jsonDoc.object();
auto sets = root.value("sets").toObject();
for (const QJsonValue &set : sets) {
auto emoticons = set.toObject().value("emoticons").toArray();
for (const QJsonValue &emote : emoticons) {
QJsonObject object = emote.toObject();
// margins
int id = object.value("id").toInt();
QString code = object.value("name").toString();
QJsonObject urls = object.value("urls").toObject();
QString url1 = "http:" + urls.value("1").toString();
Emotes::getBttvEmotes().insert(
code, new messages::LazyLoadedImage(
url1, 1, code, code + "\nGlobal Ffz Emote"));
}
}
}
reply->deleteLater();
manager->deleteLater();
});
}
messages::LazyLoadedImage * messages::LazyLoadedImage *
Emotes::getTwitchEmoteById(const QString &name, long id) Emotes::getTwitchEmoteById(const QString &name, long id)
{ {

View file

@ -102,6 +102,9 @@ private:
static QString getTwitchEmoteLink(long id, qreal &scale); static QString getTwitchEmoteLink(long id, qreal &scale);
static void loadFfzEmotes();
static void loadBttvEmotes();
static int generation; static int generation;
}; };
} }

View file

@ -1,6 +1,7 @@
#include "channels.h" #include "channels.h"
#include "colorscheme.h" #include "colorscheme.h"
#include "emojis.h" #include "emojis.h"
#include "emotes.h"
#include "ircmanager.h" #include "ircmanager.h"
#include "resources.h" #include "resources.h"
#include "settings.h" #include "settings.h"
@ -21,6 +22,7 @@ main(int argc, char *argv[])
Settings::getInstance().load(); Settings::getInstance().load();
Resources::load(); Resources::load();
Emojis::loadEmojis(); Emojis::loadEmojis();
Emotes::loadGlobalEmotes();
ColorScheme::getInstance().setColors(0, -0.8); ColorScheme::getInstance().setColors(0, -0.8);

View file

@ -66,7 +66,8 @@ LazyLoadedImage::loadImage()
Emotes::incGeneration(); Emotes::incGeneration();
Windows::layoutVisibleChatWidgets(); Windows::layoutVisibleChatWidgets();
delete manager; reply->deleteLater();
manager->deleteLater();
}); });
// })); // }));
} }

View file

@ -11,15 +11,15 @@ class LazyLoadedImage
{ {
public: public:
explicit LazyLoadedImage(const QString &url, qreal scale = 1, explicit LazyLoadedImage(const QString &url, qreal scale = 1,
const QString &getName = "", const QString &name = "",
const QString &getTooltip = "", const QString &tooltip = "",
const QMargins &getMargin = QMargins(), const QMargins &margin = QMargins(),
bool getIsHat = false); bool isHat = false);
explicit LazyLoadedImage(QPixmap *pixmap, qreal scale = 1, explicit LazyLoadedImage(QPixmap *pixmap, qreal scale = 1,
const QString &getName = "", const QString &name = "",
const QString &getTooltip = "", const QString &tooltip = "",
const QMargins &getMargin = QMargins(), const QMargins &margin = QMargins(),
bool getIsHat = false); bool isHat = false);
const QPixmap * const QPixmap *
getPixmap() getPixmap()