Revert "broke everything (revert if needed)"

This reverts commit f9d50954d9.
This commit is contained in:
TranRed 2019-09-27 14:05:03 +02:00
parent f9d50954d9
commit 1d306c1dd9
11 changed files with 102 additions and 279 deletions

View file

@ -83,9 +83,6 @@ SOURCES += \
src/controllers/taggedusers/TaggedUser.cpp \ src/controllers/taggedusers/TaggedUser.cpp \
src/controllers/taggedusers/TaggedUsersController.cpp \ src/controllers/taggedusers/TaggedUsersController.cpp \
src/controllers/taggedusers/TaggedUsersModel.cpp \ src/controllers/taggedusers/TaggedUsersModel.cpp \
src/controllers/timeoutbuttons/TimeoutButton.cpp \
src/controllers/timeoutbuttons/TimeoutButtonController.cpp \
src/controllers/timeoutbuttons/TimeoutButtonModel.cpp \
src/main.cpp \ src/main.cpp \
src/messages/Emote.cpp \ src/messages/Emote.cpp \
src/messages/Image.cpp \ src/messages/Image.cpp \
@ -256,9 +253,6 @@ HEADERS += \
src/controllers/taggedusers/TaggedUser.hpp \ src/controllers/taggedusers/TaggedUser.hpp \
src/controllers/taggedusers/TaggedUsersController.hpp \ src/controllers/taggedusers/TaggedUsersController.hpp \
src/controllers/taggedusers/TaggedUsersModel.hpp \ src/controllers/taggedusers/TaggedUsersModel.hpp \
src/controllers/timeoutbuttons/TimeoutButton.hpp \
src/controllers/timeoutbuttons/TimeoutButtonController.hpp \
src/controllers/timeoutbuttons/TimeoutButtonModel.hpp \
src/messages/Emote.hpp \ src/messages/Emote.hpp \
src/messages/Image.hpp \ src/messages/Image.hpp \
src/messages/ImageSet.hpp \ src/messages/ImageSet.hpp \

View file

@ -19,7 +19,6 @@ class AccountController;
class ModerationActions; class ModerationActions;
class NotificationController; class NotificationController;
class PingController; class PingController;
class TimeoutButtonController;
class Theme; class Theme;
class WindowManager; class WindowManager;
@ -59,12 +58,12 @@ public:
Emotes *const emotes{}; Emotes *const emotes{};
WindowManager *const windows{}; WindowManager *const windows{};
Toasts *const toasts{}; Toasts *const toasts{};
AccountController *const accounts{}; AccountController *const accounts{};
CommandController *const commands{}; CommandController *const commands{};
HighlightController *const highlights{}; HighlightController *const highlights{};
NotificationController *const notifications{}; NotificationController *const notifications{};
PingController *const pings{}; PingController *const pings{};
TimeoutButtonController *const timeoutButtons{};
IgnoreController *const ignores{}; IgnoreController *const ignores{};
TaggedUsersController *const taggedUsers{}; TaggedUsersController *const taggedUsers{};
ModerationActions *const moderationActions{}; ModerationActions *const moderationActions{};

View file

@ -1,34 +0,0 @@
#include "TimeoutButton.hpp"
namespace chatterino {
TimeoutButton::TimeoutButton(const int &duration, const QString &unit)
: duration_(duration)
, unit_(unit)
{
}
int TimeoutButton::getDuration() const
{
return this->duration_;
}
QString TimeoutButton::getDurationString() const
{
return QString::number(this->getDuration());
}
QString TimeoutButton::getUnit() const
{
return this->unit_;
}
int TimeoutButton::getTimeoutDuration() const
{
static const QMap<QString, int> durations{
{"s", 1}, {"m", 60}, {"h", 3600}, {"d", 86400}, {"w", 604800},
};
return this->duration_ * durations[this->unit_];
}
} // namespace chatterino

View file

@ -1,63 +0,0 @@
#pragma once
#include "util/RapidJsonSerializeQString.hpp"
#include "util/RapidjsonHelpers.hpp"
#include <QString>
#include <pajlada/serialize.hpp>
namespace chatterino {
class TimeoutButton
{
public:
TimeoutButton(const int &duration, const QString &unit);
int getDuration() const;
QString getDurationString() const;
QString getUnit() const;
int getTimeoutDuration() const;
private:
int duration_;
QString unit_;
};
} // namespace chatterino
namespace pajlada {
template <>
struct Serialize<chatterino::TimeoutButton> {
static rapidjson::Value get(const chatterino::TimeoutButton &value,
rapidjson::Document::AllocatorType &a)
{
rapidjson::Value ret(rapidjson::kObjectType);
chatterino::rj::set(ret, "duration", value.getDuration(), a);
chatterino::rj::set(ret, "unit", value.getUnit(), a);
return ret;
}
};
template <>
struct Deserialize<chatterino::TimeoutButton> {
static chatterino::TimeoutButton get(const rapidjson::Value &value)
{
if (!value.IsObject())
{
return chatterino::TimeoutButton(int(), QString());
}
int _duration;
QString _unit;
chatterino::rj::getSafe(value, "duration", _duration);
chatterino::rj::getSafe(value, "unit", _unit);
return chatterino::TimeoutButton(_duration, _unit);
}
};
} // namespace pajlada

View file

@ -1,33 +0,0 @@
#include "TimeoutButtonController.hpp"
#include "controllers/timeoutbuttons/TimeoutButton.hpp"
#include "controllers/timeoutbuttons/TimeoutButtonModel.hpp"
#include "debug/Log.hpp"
#include "providers/twitch/TwitchAccount.hpp"
namespace chatterino {
TimeoutButtonController::TimeoutButtonController()
{
}
TimeoutButtonModel *TimeoutButtonController::createModel(QObject *parent)
{
TimeoutButtonModel *model = new TimeoutButtonModel(parent);
// this breaks NaM - idk why
model->init(&this->buttons);
return model;
}
void TimeoutButtonController::initialize(Settings &settings, Paths &paths)
{
this->initialized_ = true;
log("hallo");
for (const TimeoutButton &button : this->timeoutButtons_.getValue())
{
this->buttons.appendItem(button);
}
}
} // namespace chatterino

View file

@ -1,35 +0,0 @@
#pragma once
#include <QObject>
#include "common/ChatterinoSetting.hpp"
#include "common/SignalVector.hpp"
#include "common/Singleton.hpp"
namespace chatterino {
class TimeoutButton;
class TimeoutButtonModel;
class Settings;
class TimeoutButtonController final : public Singleton
{
public:
TimeoutButtonController();
TimeoutButtonModel *createModel(QObject *parent);
virtual void initialize(Settings &settings, Paths &paths) override;
UnsortedSignalVector<TimeoutButton> buttons;
private:
bool initialized_ = false;
ChatterinoSetting<std::vector<TimeoutButton>> timeoutButtons_ = {
"/timeouts/timeoutButtons"};
};
} // namespace chatterino

View file

@ -1,29 +0,0 @@
#include "TimeoutButtonModel.hpp"
#include "controllers/timeoutbuttons/TimeoutButton.hpp"
#include "util/StandardItemHelper.hpp"
namespace chatterino {
TimeoutButtonModel::TimeoutButtonModel(QObject *parent)
: SignalVectorModel<TimeoutButton>(2, parent)
{
}
// turn a vector item into a model row
TimeoutButton TimeoutButtonModel::getItemFromRow(
std::vector<QStandardItem *> &row, const TimeoutButton &original)
{
return TimeoutButton(row[0]->data(Qt::EditRole).toInt(),
row[1]->data(Qt::EditRole).toString());
}
// turns a row in the model into a vector item
void TimeoutButtonModel::getRowFromItem(const TimeoutButton &item,
std::vector<QStandardItem *> &row)
{
row[0]->setData(item.getDurationString(), Qt::DisplayRole);
row[1]->setData(item.getUnit(), Qt::DisplayRole);
}
} // namespace chatterino

View file

@ -1,31 +0,0 @@
#pragma once
#include "common/SignalVectorModel.hpp"
#include "controllers/timeoutbuttons/TimeoutButton.hpp"
#include "controllers/timeoutbuttons/TimeoutButtonController.hpp"
namespace chatterino {
class TimeoutButton;
class TimeoutButtonController;
class TimeoutButtonModel : public SignalVectorModel<TimeoutButton>
{
public:
TimeoutButtonModel(QObject *parent);
protected:
// turn a vector item into a model row
virtual TimeoutButton getItemFromRow(
std::vector<QStandardItem *> &row,
const TimeoutButton &original) override;
// turns a row in the model into a vector item
virtual void getRowFromItem(const TimeoutButton &item,
std::vector<QStandardItem *> &row) override;
friend class TimeoutButtonController;
private:
};
} // namespace chatterino

View file

@ -9,6 +9,8 @@
#include <pajlada/settings/setting.hpp> #include <pajlada/settings/setting.hpp>
#include <pajlada/settings/settinglistener.hpp> #include <pajlada/settings/settinglistener.hpp>
using TimeoutButton = std::pair<QString, int>;
namespace chatterino { namespace chatterino {
class Settings : public ABSettings class Settings : public ABSettings
@ -195,6 +197,13 @@ public:
QStringSetting cachePath = {"/cache/path", ""}; QStringSetting cachePath = {"/cache/path", ""};
/// Timeout buttons
ChatterinoSetting<std::vector<TimeoutButton>> timeoutButtons = {
"/timeouts/timeoutButtons",
{ { "s", 1 }, { "s", 30 }, { "m", 1 }, { "m", 5 },
{ "m", 30 }, { "h", 1 }, { "d", 1 }, { "w", 1 } } };
private: private:
void updateModerationActions(); void updateModerationActions();
}; };

View file

@ -34,6 +34,14 @@ namespace {
const auto borderColor = QColor(255, 255, 255, 80); const auto borderColor = QColor(255, 255, 255, 80);
int calculateTimeoutDuration(TimeoutButton timeout)
{
static const QMap<QString, int> durations{
{"s", 1}, {"m", 60}, {"h", 3600}, {"d", 86400}, {"w", 604800},
};
return timeout.second * durations[timeout.first];
}
ChannelPtr filterMessages(const QString &userName, ChannelPtr channel) ChannelPtr filterMessages(const QString &userName, ChannelPtr channel)
{ {
LimitedQueueSnapshot<MessagePtr> snapshot = LimitedQueueSnapshot<MessagePtr> snapshot =
@ -536,32 +544,28 @@ UserInfoPopup::TimeoutWidget::TimeoutWidget()
}); });
}; };
// const auto addTimeouts = [&](const QString &title) { const auto addTimeouts = [&](const QString &title) {
// auto hbox = addLayout(title); auto hbox = addLayout(title);
// for (const auto &item : for (const auto &item : getSettings()->timeoutButtons.getValue())
// getSettings()->timeoutButtons.getValue()) {
// { auto a = hbox.emplace<EffectLabel2>();
// auto a = hbox.emplace<EffectLabel2>(); a->getLabel().setText(QString::number(item.second) + item.first);
// a->getLabel().setText(QString::number(item.second) +
// item.first);
// a->setScaleIndependantSize(buttonWidth, buttonHeight); a->setScaleIndependantSize(buttonWidth, buttonHeight);
// a->setBorderColor(borderColor); a->setBorderColor(borderColor);
// const auto pair = const auto pair =
// std::make_pair(Action::Timeout, std::make_pair(Action::Timeout, calculateTimeoutDuration(item));
// calculateTimeoutDuration(item));
// QObject::connect( QObject::connect(
// a.getElement(), &EffectLabel2::leftClicked, a.getElement(), &EffectLabel2::leftClicked,
// [this, pair] { this->buttonClicked.invoke(pair); }); [this, pair] { this->buttonClicked.invoke(pair); });
// } }
};
// };
addButton(Unban, "Unban", getApp()->resources->buttons.unban); addButton(Unban, "Unban", getApp()->resources->buttons.unban);
// addTimeouts("Timeouts"); addTimeouts("Timeouts");
addButton(Ban, "Ban", getApp()->resources->buttons.ban); addButton(Ban, "Ban", getApp()->resources->buttons.ban);
} }

View file

@ -3,14 +3,11 @@
#include "Application.hpp" #include "Application.hpp"
#include "controllers/taggedusers/TaggedUsersController.hpp" #include "controllers/taggedusers/TaggedUsersController.hpp"
#include "controllers/taggedusers/TaggedUsersModel.hpp" #include "controllers/taggedusers/TaggedUsersModel.hpp"
#include "controllers/timeoutbuttons/TimeoutButtonController.hpp"
#include "controllers/timeoutbuttons/TimeoutButtonModel.hpp"
#include "singletons/Logging.hpp" #include "singletons/Logging.hpp"
#include "singletons/Paths.hpp" #include "singletons/Paths.hpp"
#include "singletons/Settings.hpp" #include "singletons/Settings.hpp"
#include "util/Helpers.hpp" #include "util/Helpers.hpp"
#include "util/LayoutCreator.hpp" #include "util/LayoutCreator.hpp"
#include "widgets/helper/EditableModelView.hpp"
#include <QFileDialog> #include <QFileDialog>
#include <QFormLayout> #include <QFormLayout>
@ -32,8 +29,6 @@ AdvancedPage::AdvancedPage()
{ {
LayoutCreator<AdvancedPage> layoutCreator(this); LayoutCreator<AdvancedPage> layoutCreator(this);
auto *app = getApp();
auto tabs = layoutCreator.emplace<QTabWidget>(); auto tabs = layoutCreator.emplace<QTabWidget>();
{ {
@ -77,9 +72,10 @@ AdvancedPage::AdvancedPage()
getSettings()->cachePath = ""; // getSettings()->cachePath = ""; //
}); });
} }
// Logs end // Logs end
// Timeoutbuttons
// Timeoutbuttons
{ {
auto timeoutLayout = tabs.appendTab(new QVBoxLayout, "Timeouts"); auto timeoutLayout = tabs.appendTab(new QVBoxLayout, "Timeouts");
auto texts = timeoutLayout.emplace<QVBoxLayout>().withoutMargin(); auto texts = timeoutLayout.emplace<QVBoxLayout>().withoutMargin();
@ -98,29 +94,75 @@ AdvancedPage::AdvancedPage()
texts->setContentsMargins(0, 0, 0, 15); texts->setContentsMargins(0, 0, 0, 15);
texts->setSizeConstraint(QLayout::SetMaximumSize); texts->setSizeConstraint(QLayout::SetMaximumSize);
EditableModelView *view = const auto valueChanged = [=] {
timeoutLayout const auto index = QObject::sender()->objectName().toInt();
.emplace<EditableModelView>(
app->timeoutButtons->createModel(nullptr))
.getElement();
view->setTitles({"Duration", "Unit"}); const auto line = this->durationInputs_[index];
view->getTableView()->horizontalHeader()->setSectionResizeMode( const auto duration = line->text().toInt();
QHeaderView::Fixed); const auto unit = this->unitInputs_[index]->currentText();
view->getTableView()->horizontalHeader()->setSectionResizeMode(
0, QHeaderView::Stretch);
// fourtf: make class extrend BaseWidget and add this to // safety mechanism for setting days and weeks
// dpiChanged if (unit == "d" && duration > 14)
QTimer::singleShot(1, [view] { {
view->getTableView()->resizeColumnsToContents(); line->setText("14");
view->getTableView()->setColumnWidth(0, 200); return;
}); }
else if (unit == "w" && duration > 2)
{
line->setText("2");
return;
}
view->addButtonPressed.connect([] { auto timeouts = getSettings()->timeoutButtons.getValue();
getApp()->timeoutButtons->buttons.appendItem(TimeoutButton{1, "s"}); timeouts[index] = TimeoutButton{ unit, duration };
}); getSettings()->timeoutButtons.setValue(timeouts);
};
// build one line for each customizable button
auto i = 0;
for (const auto tButton : getSettings()->timeoutButtons.getValue())
{
const auto buttonNumber = QString::number(i);
auto timeout = timeoutLayout.emplace<QHBoxLayout>().withoutMargin();
auto buttonLabel = timeout.emplace<QLabel>();
buttonLabel->setText(QString("Button %1: ").arg(++i));
auto *lineEditDurationInput = new QLineEdit();
lineEditDurationInput->setObjectName(buttonNumber);
lineEditDurationInput->setValidator(
new QIntValidator(1, 99, this));
lineEditDurationInput->setText(
QString::number(tButton.second));
lineEditDurationInput->setAlignment(Qt::AlignRight);
lineEditDurationInput->setMaximumWidth(30);
timeout.append(lineEditDurationInput);
auto *timeoutDurationUnit = new QComboBox();
timeoutDurationUnit->setObjectName(buttonNumber);
timeoutDurationUnit->addItems({ "s", "m", "h", "d", "w" });
timeoutDurationUnit->setCurrentText(tButton.first);
timeout.append(timeoutDurationUnit);
QObject::connect(lineEditDurationInput,
&QLineEdit::textChanged, this,
valueChanged);
QObject::connect(timeoutDurationUnit,
&QComboBox::currentTextChanged, this,
valueChanged);
timeout->addStretch();
this->durationInputs_.push_back(lineEditDurationInput);
this->unitInputs_.push_back(timeoutDurationUnit);
timeout->setContentsMargins(40, 0, 0, 0);
timeout->setSizeConstraint(QLayout::SetMaximumSize);
}
timeoutLayout->addStretch();
} }
// Timeoutbuttons end // Timeoutbuttons end
} }
} // namespace chatterino } // namespace chatterino