Skip to content

Commit

Permalink
fix: the font switcher now remembers your previous font (Chatterino#5224
Browse files Browse the repository at this point in the history
  • Loading branch information
pajlada authored Mar 3, 2024
1 parent 449c539 commit 77cfd13
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 17 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -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)
Expand Down
16 changes: 7 additions & 9 deletions src/widgets/settingspages/GeneralPage.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down Expand Up @@ -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;
}
Expand Down
29 changes: 21 additions & 8 deletions src/widgets/settingspages/GeneralPageView.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ class GeneralPageView : public QWidget
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());
Expand Down Expand Up @@ -197,14 +197,27 @@ class GeneralPageView : public QWidget
},
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;
}
Expand Down

0 comments on commit 77cfd13

Please sign in to comment.