mirror-chatterino2/src/controllers/notifications/NotificationController.cpp

204 lines
5.8 KiB
C++
Raw Normal View History

#include "controllers/notifications/NotificationController.hpp"
#include "Application.hpp"
#include "common/NetworkRequest.hpp"
2018-08-29 19:25:37 +02:00
#include "common/Outcome.hpp"
#include "controllers/notifications/NotificationModel.hpp"
#include "providers/twitch/TwitchIrcServer.hpp"
#include "providers/twitch/api/Helix.hpp"
#include "singletons/Toasts.hpp"
#include "singletons/WindowManager.hpp"
2018-08-29 19:25:37 +02:00
#include "widgets/Window.hpp"
2018-09-01 13:01:54 +02:00
#ifdef Q_OS_WIN
# include <wintoastlib.h>
#endif
2018-08-11 12:47:03 +02:00
#include <QDesktopServices>
#include <QDir>
#include <QMediaPlayer>
2018-08-11 12:47:03 +02:00
#include <QUrl>
namespace chatterino {
void NotificationController::initialize(Settings &settings, Paths &paths)
{
this->initialized_ = true;
2018-10-21 13:43:02 +02:00
for (const QString &channelName : this->twitchSetting_.getValue())
{
this->channelMap[Platform::Twitch].append(channelName);
}
this->channelMap[Platform::Twitch].delayedItemsChanged.connect([this] { //
this->twitchSetting_.setValue(this->channelMap[Platform::Twitch].raw());
2018-08-12 15:29:40 +02:00
});
/*
2018-08-12 15:29:40 +02:00
for (const QString &channelName : this->mixerSetting_.getValue()) {
this->channelMap[Platform::Mixer].appendItem(channelName);
2018-08-12 15:29:40 +02:00
}
this->channelMap[Platform::Mixer].delayedItemsChanged.connect([this] { //
this->mixerSetting_.setValue(
this->channelMap[Platform::Mixer]);
2018-08-26 13:19:09 +02:00
});*/
liveStatusTimer_ = new QTimer();
2018-08-26 13:19:09 +02:00
this->fetchFakeChannels();
QObject::connect(this->liveStatusTimer_, &QTimer::timeout,
[=] { this->fetchFakeChannels(); });
2018-08-26 13:19:09 +02:00
this->liveStatusTimer_->start(60 * 1000);
}
void NotificationController::updateChannelNotification(
2018-08-12 18:54:32 +02:00
const QString &channelName, Platform p)
{
2018-10-21 13:43:02 +02:00
if (isChannelNotified(channelName, p))
{
removeChannelNotification(channelName, p);
2018-10-21 13:43:02 +02:00
}
else
{
addChannelNotification(channelName, p);
}
}
2018-08-12 15:29:40 +02:00
bool NotificationController::isChannelNotified(const QString &channelName,
2018-08-12 18:54:32 +02:00
Platform p)
{
for (const auto &channel : this->channelMap[p])
2018-10-21 13:43:02 +02:00
{
if (channelName.toLower() == channel.toLower())
{
return true;
}
}
return false;
}
2018-08-11 12:47:03 +02:00
void NotificationController::addChannelNotification(const QString &channelName,
Platform p)
{
channelMap[p].append(channelName);
}
void NotificationController::removeChannelNotification(
const QString &channelName, Platform p)
{
for (std::vector<int>::size_type i = 0; i != channelMap[p].raw().size();
i++)
2018-10-21 13:43:02 +02:00
{
2020-02-23 17:45:59 +01:00
if (channelMap[p].raw()[i].toLower() == channelName.toLower())
2018-10-21 13:43:02 +02:00
{
channelMap[p].removeAt(i);
i--;
}
}
}
void NotificationController::playSound()
{
static auto player = new QMediaPlayer;
static QUrl currentPlayerUrl;
QUrl highlightSoundUrl =
getSettings()->notificationCustomSound
? QUrl::fromLocalFile(
getSettings()->notificationPathSound.getValue())
: QUrl("qrc:/sounds/ping2.wav");
2018-10-21 13:43:02 +02:00
if (currentPlayerUrl != highlightSoundUrl)
{
player->setMedia(highlightSoundUrl);
currentPlayerUrl = highlightSoundUrl;
}
player->play();
}
2018-08-12 18:54:32 +02:00
NotificationModel *NotificationController::createModel(QObject *parent,
Platform p)
{
NotificationModel *model = new NotificationModel(parent);
2020-02-23 19:31:43 +01:00
model->initialize(&this->channelMap[p]);
return model;
}
void NotificationController::fetchFakeChannels()
{
for (std::vector<int>::size_type i = 0;
2020-02-23 17:45:59 +01:00
i != channelMap[Platform::Twitch].raw().size(); i++)
2018-10-21 13:43:02 +02:00
{
auto chan = getApp()->twitch.server->getChannelOrEmpty(
2020-02-23 17:45:59 +01:00
channelMap[Platform::Twitch].raw()[i]);
2018-10-21 13:43:02 +02:00
if (chan->isEmpty())
{
2018-08-26 13:19:09 +02:00
getFakeTwitchChannelLiveStatus(
2020-02-23 17:45:59 +01:00
channelMap[Platform::Twitch].raw()[i]);
}
}
}
void NotificationController::getFakeTwitchChannelLiveStatus(
const QString &channelName)
{
getHelix()->getStreamByName(
channelName,
[channelName, this](bool live, const auto &stream) {
qDebug() << "[TwitchChannel" << channelName
<< "] Refreshing live status";
if (!live)
{
// Stream is offline
this->removeFakeChannel(channelName);
return;
}
// Stream is online
auto i = std::find(fakeTwitchChannels.begin(),
fakeTwitchChannels.end(), channelName);
if (i != fakeTwitchChannels.end())
{
// We have already pushed the live state of this stream
// Could not find stream in fake twitch channels!
return;
}
if (Toasts::isEnabled())
{
getApp()->toasts->sendChannelNotification(channelName,
Platform::Twitch);
}
if (getSettings()->notificationPlaySound)
{
getApp()->notifications->playSound();
}
if (getSettings()->notificationFlashTaskbar)
{
getApp()->windows->sendAlert();
}
// Indicate that we have pushed notifications for this stream
fakeTwitchChannels.push_back(channelName);
},
[channelName, this] {
qDebug() << "[TwitchChannel" << channelName
<< "] Refreshing live status (Missing ID)";
this->removeFakeChannel(channelName);
});
}
void NotificationController::removeFakeChannel(const QString channelName)
{
auto i = std::find(fakeTwitchChannels.begin(), fakeTwitchChannels.end(),
channelName);
2018-10-21 13:43:02 +02:00
if (i != fakeTwitchChannels.end())
{
fakeTwitchChannels.erase(i);
}
}
} // namespace chatterino