mirror of
https://github.com/Chatterino/chatterino2.git
synced 2024-11-21 22:24:07 +01:00
fix: the font switcher now remembers your previous font (#5224)
Fixes #2112
This commit is contained in:
parent
449c5397b7
commit
77cfd1393c
3 changed files with 29 additions and 17 deletions
|
@ -53,6 +53,7 @@
|
|||
- Bugfix: Fixed selection of tabs after closing a tab when using "Live Tabs Only". (#4770)
|
||||
- Bugfix: Fixed input in reply thread popup losing focus when dragging. (#4815)
|
||||
- Bugfix: Fixed the Quick Switcher (CTRL+K) from sometimes showing up on the wrong window. (#4819)
|
||||
- Bugfix: Fixed the font switcher not remembering what font you had previously selected. (#5224)
|
||||
- Bugfix: Fixed too much text being copied when copying chat messages. (#4812, #4830, #4839)
|
||||
- Bugfix: Fixed an issue where the setting `Only search for emote autocompletion at the start of emote names` wouldn't disable if it was enabled when the client started. (#4855)
|
||||
- Bugfix: Fixed empty page being added when showing out of bounds dialog. (#4849)
|
||||
|
|
|
@ -173,7 +173,8 @@ void GeneralPage::initLayout(GeneralPageView &layout)
|
|||
},
|
||||
[this](auto args) {
|
||||
return this->getFont(args);
|
||||
});
|
||||
},
|
||||
true, "", true);
|
||||
layout.addDropdown<int>(
|
||||
"Font size", {"9pt", "10pt", "12pt", "14pt", "16pt", "20pt"},
|
||||
getIApp()->getFonts()->chatFontSize,
|
||||
|
@ -1293,22 +1294,19 @@ QString GeneralPage::getFont(const DropdownArgs &args) const
|
|||
{
|
||||
if (args.combobox->currentIndex() == args.combobox->count() - 1)
|
||||
{
|
||||
args.combobox->setCurrentIndex(0);
|
||||
args.combobox->setEditText("Choosing...");
|
||||
QFontDialog dialog(
|
||||
getIApp()->getFonts()->getFont(FontStyle::ChatMedium, 1.));
|
||||
|
||||
auto ok = bool();
|
||||
auto font = dialog.getFont(&ok, this->window());
|
||||
auto previousFont =
|
||||
getIApp()->getFonts()->getFont(FontStyle::ChatMedium, 1.);
|
||||
auto font = QFontDialog::getFont(&ok, previousFont, this->window());
|
||||
|
||||
if (ok)
|
||||
{
|
||||
return font.family();
|
||||
}
|
||||
else
|
||||
{
|
||||
return args.combobox->itemText(0);
|
||||
}
|
||||
|
||||
return previousFont.family();
|
||||
}
|
||||
return args.value;
|
||||
}
|
||||
|
|
|
@ -147,7 +147,7 @@ public:
|
|||
pajlada::Settings::Setting<T> &setting,
|
||||
std::function<boost::variant<int, QString>(T)> getValue,
|
||||
std::function<T(DropdownArgs)> setValue, bool editable = true,
|
||||
QString toolTipText = {})
|
||||
QString toolTipText = {}, bool listenToActivated = false)
|
||||
{
|
||||
auto items2 = items;
|
||||
auto selected = getValue(setting.getValue());
|
||||
|
@ -197,14 +197,27 @@ public:
|
|||
},
|
||||
this->managedConnections_);
|
||||
|
||||
QObject::connect(
|
||||
combo, QOverload<const int>::of(&QComboBox::currentIndexChanged),
|
||||
[combo, &setting,
|
||||
setValue = std::move(setValue)](const int newIndex) {
|
||||
setting = setValue(DropdownArgs{combo->itemText(newIndex),
|
||||
combo->currentIndex(), combo});
|
||||
getIApp()->getWindows()->forceLayoutChannelViews();
|
||||
auto updateSetting = [combo, &setting, setValue = std::move(setValue)](
|
||||
const int newIndex) {
|
||||
setting = setValue(DropdownArgs{
|
||||
.value = combo->itemText(newIndex),
|
||||
.index = combo->currentIndex(),
|
||||
.combobox = combo,
|
||||
});
|
||||
getIApp()->getWindows()->forceLayoutChannelViews();
|
||||
};
|
||||
|
||||
if (listenToActivated)
|
||||
{
|
||||
QObject::connect(combo, &QComboBox::activated, updateSetting);
|
||||
}
|
||||
else
|
||||
{
|
||||
QObject::connect(
|
||||
combo,
|
||||
QOverload<const int>::of(&QComboBox::currentIndexChanged),
|
||||
updateSetting);
|
||||
}
|
||||
|
||||
return combo;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue