changeset 68:2417121d894e

*: normalize usage of layouts before, I used them two ways, once was by setting the layout later by using setLayout(QWidget), and the other was just using the constructor. I find the constructor to be easier to read, so I chose that one.
author Paper <mrpapersonic@gmail.com>
date Mon, 02 Oct 2023 21:33:25 -0400 (15 months ago)
parents 442065432549
children 27a19dd6cba1 893ad99b174d
files include/gui/dialog/settings.h src/gui/dialog/information.cpp src/gui/dialog/settings.cpp src/gui/dialog/settings/application.cpp src/gui/dialog/settings/services.cpp src/gui/pages/anime_list.cpp src/gui/pages/now_playing.cpp src/gui/widgets/poster.cpp src/gui/widgets/sidebar.cpp src/gui/window.cpp
diffstat 10 files changed, 95 insertions(+), 101 deletions(-) [+]
line wrap: on
line diff
--- a/include/gui/dialog/settings.h	Mon Oct 02 07:06:44 2023 -0400
+++ b/include/gui/dialog/settings.h	Mon Oct 02 21:33:25 2023 -0400
@@ -1,15 +1,13 @@
 #ifndef __gui__dialog__settings_h
 #define __gui__dialog__settings_h
 #include "core/anime.h"
-#include "gui/widgets/sidebar.h"
-#include <QComboBox>
 #include <QDialog>
-#include <QHBoxLayout>
-#include <QLabel>
-#include <QLineEdit>
-#include <QTabWidget>
 #include <QWidget>
 
+class QLabel;
+class QTabWidget;
+class SideBar;
+
 class SettingsPage : public QWidget {
 		Q_OBJECT
 
@@ -59,7 +57,6 @@
 		void OnOK();
 
 	private:
-		QHBoxLayout* layout;
 		SideBar* sidebar;
 };
 #endif // __gui__dialog__settings_h
--- a/src/gui/dialog/information.cpp	Mon Oct 02 07:06:44 2023 -0400
+++ b/src/gui/dialog/information.cpp	Mon Oct 02 21:33:25 2023 -0400
@@ -57,7 +57,6 @@
 	sidebar_layout->addWidget(poster);
 	sidebar_layout->setContentsMargins(0, 0, 0, 0);
 	sidebar_layout->addStretch();
-	sidebar->setFixedWidth(175);
 
 	/* main widget */
 	QWidget* main_widget = new QWidget(widget);
@@ -83,18 +82,17 @@
 	AnimeInfoWidget* main_information_widget = new AnimeInfoWidget(anime, tabbed_widget);
 
 	QWidget* settings_widget = new QWidget(tabbed_widget);
-	settings_widget->setLayout(new QVBoxLayout);
 	settings_widget->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Maximum);
 
-	settings_widget->layout()->addWidget(new TextWidgets::Header(tr("Anime list"), settings_widget));
+	QVBoxLayout* settings_layout = new QVBoxLayout(settings_widget);
+	settings_layout->addWidget(new TextWidgets::Header(tr("Anime list"), settings_widget));
 
 	QWidget* sg_anime_list_content = new QWidget(settings_widget);
-	settings_widget->layout()->addWidget(sg_anime_list_content);
-	sg_anime_list_content->setLayout(new QVBoxLayout);
-	sg_anime_list_content->layout()->setSpacing(5);
-	sg_anime_list_content->layout()->setContentsMargins(12, 0, 0, 0);
 
-/* these macros make this a lot easier to edit */
+	QVBoxLayout* al_layout = new QVBoxLayout(sg_anime_list_content);
+	al_layout->setSpacing(5);
+	al_layout->setContentsMargins(12, 0, 0, 0);
+
 #define LAYOUT_HORIZ_SPACING 25
 #define LAYOUT_VERT_SPACING  5
 #define LAYOUT_ITEM_WIDTH    175
@@ -102,17 +100,14 @@
 #define CREATE_FULL_WIDTH_SUBSECTION(x) \
 	{ \
 		QWidget* subsection = new QWidget(section); \
-		subsection->setLayout(new QVBoxLayout); \
 		subsection->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred); \
-		subsection->layout()->setSpacing(LAYOUT_VERT_SPACING); \
-		subsection->layout()->setContentsMargins(0, 0, 0, 0); \
+		QVBoxLayout* subsection_layout = new QVBoxLayout(subsection); \
+		subsection_layout->setSpacing(LAYOUT_VERT_SPACING); \
+		subsection_layout->setContentsMargins(0, 0, 0, 0); \
 		x; \
 		layout->addWidget(subsection); \
 	}
 
-/* Creates a subsection with a width of 175 */
-#define CREATE_SUBSECTION(x) CREATE_FULL_WIDTH_SUBSECTION(x subsection->setFixedWidth(LAYOUT_ITEM_WIDTH);)
-
 /* Creates a section in the parent `a` */
 #define CREATE_FULL_WIDTH_SECTION(a, x) \
 	{ \
@@ -124,35 +119,37 @@
 		a->layout()->addWidget(section); \
 	}
 
+/* Creates a subsection with a width of 175 */
+#define CREATE_SUBSECTION(x) CREATE_FULL_WIDTH_SUBSECTION(x subsection->setFixedWidth(LAYOUT_ITEM_WIDTH);)
 /* Creates a section in the parent `a` */
 #define CREATE_SECTION(a, x) CREATE_FULL_WIDTH_SECTION(a, x layout->addStretch();)
 
 	CREATE_SECTION(sg_anime_list_content, {
 		/* Episodes watched section */
 		CREATE_SUBSECTION({
-			subsection->layout()->addWidget(new QLabel(tr("Episodes watched:"), subsection));
+			subsection_layout->addWidget(new QLabel(tr("Episodes watched:"), subsection));
 
 			QSpinBox* spin_box = new QSpinBox(subsection);
 			connect(spin_box, QOverload<int>::of(&QSpinBox::valueChanged), this, [this](int i) { progress = i; });
 			spin_box->setRange(0, anime.GetEpisodes());
 			spin_box->setSingleStep(1);
 			spin_box->setValue(progress = anime.GetUserProgress());
-			subsection->layout()->addWidget(spin_box);
+			subsection_layout->addWidget(spin_box);
 		});
 		CREATE_SUBSECTION({
-			subsection->layout()->addWidget(new QLabel(tr(" "), subsection));
+			subsection_layout->addWidget(new QLabel(tr(" "), subsection));
 
 			QCheckBox* checkbox = new QCheckBox(tr("Rewatching"));
 			connect(checkbox, QOverload<int>::of(&QCheckBox::stateChanged), this,
 			        [this](int state) { rewatching = (state == Qt::Checked); });
 			checkbox->setCheckState(anime.GetUserIsRewatching() ? Qt::Checked : Qt::Unchecked);
-			subsection->layout()->addWidget(checkbox);
+			subsection_layout->addWidget(checkbox);
 		});
 	});
 	CREATE_SECTION(sg_anime_list_content, {
 		/* Status & score section */
 		CREATE_SUBSECTION({
-			subsection->layout()->addWidget(new QLabel(tr("Status:"), subsection));
+			subsection_layout->addWidget(new QLabel(tr("Status:"), subsection));
 
 			QStringList string_list;
 			for (unsigned int i = 0; i < ARRAYSIZE(Anime::ListStatuses); i++)
@@ -163,23 +160,23 @@
 			connect(combo_box, QOverload<int>::of(&QComboBox::currentIndexChanged), this,
 			        [this](int i) { status = Anime::ListStatuses[i]; });
 			combo_box->setCurrentIndex(static_cast<int>(status = anime.GetUserStatus()) - 1);
-			subsection->layout()->addWidget(combo_box);
+			subsection_layout->addWidget(combo_box);
 		});
 		CREATE_SUBSECTION({
-			subsection->layout()->addWidget(new QLabel(tr("Score:"), subsection));
+			subsection_layout->addWidget(new QLabel(tr("Score:"), subsection));
 
 			QSpinBox* spin_box = new QSpinBox(subsection);
 			connect(spin_box, QOverload<int>::of(&QSpinBox::valueChanged), this, [this](int i) { score = i; });
 			spin_box->setRange(0, 100);
 			spin_box->setSingleStep(5);
 			spin_box->setValue(score = anime.GetUserScore());
-			subsection->layout()->addWidget(spin_box);
+			subsection_layout->addWidget(spin_box);
 		});
 	});
 	CREATE_FULL_WIDTH_SECTION(sg_anime_list_content, {
 		/* Notes section */
 		CREATE_FULL_WIDTH_SUBSECTION({
-			subsection->layout()->addWidget(new QLabel(tr("Notes:"), subsection));
+			subsection_layout->addWidget(new QLabel(tr("Notes:"), subsection));
 
 			QLineEdit* line_edit = new QLineEdit(subsection);
 			connect(line_edit, &QLineEdit::textChanged, this, [this](const QString& text) {
@@ -188,13 +185,13 @@
 			});
 			line_edit->setText(Strings::ToQString(notes = anime.GetUserNotes()));
 			line_edit->setPlaceholderText(tr("Enter your notes about this anime"));
-			subsection->layout()->addWidget(line_edit);
+			subsection_layout->addWidget(line_edit);
 		});
 	});
 	CREATE_SECTION(sg_anime_list_content, {
 		/* Dates section */
 		CREATE_SUBSECTION({
-			subsection->layout()->addWidget(new QLabel(tr("Date started:"), subsection));
+			subsection_layout->addWidget(new QLabel(tr("Date started:"), subsection));
 
 			OptionalDate* date = new OptionalDate(true, subsection);
 			connect(date, &OptionalDate::DataChanged, this,
@@ -205,10 +202,10 @@
 				started = anime.GetAirDate();
 			}
 			date->SetDate(started);
-			subsection->layout()->addWidget(date);
+			subsection_layout->addWidget(date);
 		});
 		CREATE_SUBSECTION({
-			subsection->layout()->addWidget(new QLabel(tr("Date completed:"), subsection));
+			subsection_layout->addWidget(new QLabel(tr("Date completed:"), subsection));
 
 			OptionalDate* date = new OptionalDate(true, subsection);
 			connect(date, &OptionalDate::DataChanged, this,
@@ -219,30 +216,31 @@
 				completed = anime.GetAirDate();
 			}
 			date->SetDate(completed);
-			subsection->layout()->addWidget(date);
+			subsection_layout->addWidget(date);
 		});
 	});
 
-	settings_widget->layout()->addWidget(new TextWidgets::Header(tr("Local settings"), settings_widget));
+	settings_layout->addWidget(sg_anime_list_content);
+
+	settings_layout->addWidget(new TextWidgets::Header(tr("Local settings"), settings_widget));
 
 	QWidget* sg_local_content = new QWidget(settings_widget);
-	settings_widget->layout()->addWidget(sg_local_content);
-	sg_local_content->setLayout(new QVBoxLayout);
-	sg_local_content->layout()->setSpacing(5);
-	sg_local_content->layout()->setContentsMargins(12, 0, 0, 0);
+	QVBoxLayout* sg_local_layout = new QVBoxLayout(sg_local_content);
+	sg_local_layout->setSpacing(5);
+	sg_local_layout->setContentsMargins(12, 0, 0, 0);
 
 	CREATE_FULL_WIDTH_SECTION(sg_local_content, {
 		/* Alternative titles */
 		CREATE_FULL_WIDTH_SUBSECTION({
-			subsection->layout()->addWidget(new QLabel(tr("Alternative titles:"), subsection));
+			subsection_layout->addWidget(new QLabel(tr("Alternative titles:"), subsection));
 
 			QLineEdit* line_edit = new QLineEdit(Strings::ToQString(anime.GetUserNotes()), subsection);
 			line_edit->setPlaceholderText(
 			    tr("Enter alternative titles here, separated by a semicolon (i.e. Title 1; Title 2)"));
-			subsection->layout()->addWidget(line_edit);
+			subsection_layout->addWidget(line_edit);
 
 			QCheckBox* checkbox = new QCheckBox(tr("Use the first alternative title to search for torrents"));
-			subsection->layout()->addWidget(checkbox);
+			subsection_layout->addWidget(checkbox);
 		});
 	});
 #undef CREATE_SECTION
@@ -250,21 +248,21 @@
 #undef CREATE_FULL_WIDTH_SECTION
 #undef CREATE_FULL_WIDTH_SUBSECTION
 
-	reinterpret_cast<QBoxLayout*>(settings_widget->layout())->addStretch();
+	settings_layout->addWidget(sg_local_content);
+	settings_layout->addStretch();
 
 	tabbed_widget->addTab(main_information_widget, tr("Main information"));
 	tabbed_widget->addTab(settings_widget, tr("My list and settings"));
 
-	QVBoxLayout* main_layout = new QVBoxLayout;
+	QVBoxLayout* main_layout = new QVBoxLayout(main_widget);
 	main_layout->addWidget(anime_title);
 	main_layout->addWidget(tabbed_widget);
 	main_layout->setContentsMargins(0, 0, 0, 0);
-	main_widget->setLayout(main_layout);
 
-	QHBoxLayout* layout = new QHBoxLayout;
+	QHBoxLayout* layout = new QHBoxLayout(widget);
 	layout->addWidget(sidebar);
 	layout->addWidget(main_widget);
-	widget->setLayout(layout);
+	layout->setSpacing(12);
 
 	QDialogButtonBox* button_box = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel, this);
 	connect(button_box, &QDialogButtonBox::accepted, this, [this, accept] {
@@ -274,10 +272,9 @@
 	});
 	connect(button_box, &QDialogButtonBox::rejected, this, &QDialog::reject);
 
-	QVBoxLayout* buttons_layout = new QVBoxLayout;
+	QVBoxLayout* buttons_layout = new QVBoxLayout(this);
 	buttons_layout->addWidget(widget);
 	buttons_layout->addWidget(button_box, 0, Qt::AlignBottom);
-	setLayout(buttons_layout);
 }
 
 #include "gui/dialog/moc_information.cpp"
--- a/src/gui/dialog/settings.cpp	Mon Oct 02 07:06:44 2023 -0400
+++ b/src/gui/dialog/settings.cpp	Mon Oct 02 21:33:25 2023 -0400
@@ -1,14 +1,10 @@
 #include "gui/dialog/settings.h"
 #include "gui/widgets/sidebar.h"
 #include "gui/widgets/text.h"
-#include <QComboBox>
 #include <QDialogButtonBox>
-#include <QGroupBox>
-#include <QHBoxLayout>
-#include <QPlainTextDocumentLayout>
-#include <QPlainTextEdit>
 #include <QStackedWidget>
 #include <QVBoxLayout>
+#include <QHBoxLayout>
 #include <QWidget>
 
 SettingsPage::SettingsPage(QWidget* parent, QString title) : QWidget(parent) {
@@ -36,11 +32,10 @@
 	tab_widget = new QTabWidget(this);
 	tab_widget->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Expanding);
 
-	QVBoxLayout* layout = new QVBoxLayout;
+	QVBoxLayout* layout = new QVBoxLayout(this);
 	layout->setContentsMargins(0, 0, 0, 0);
 	layout->addWidget(page_title);
 	layout->addWidget(tab_widget);
-	setLayout(layout);
 }
 
 void SettingsPage::SetTitle(QString title) {
@@ -56,7 +51,7 @@
 }
 
 void SettingsDialog::OnOK() {
-	QStackedWidget* stacked = reinterpret_cast<QStackedWidget*>(layout->itemAt(1)->widget());
+	QStackedWidget* stacked = reinterpret_cast<QStackedWidget*>(layout()->itemAt(1)->widget());
 	for (int i = 0; i < stacked->count(); i++) {
 		reinterpret_cast<SettingsPage*>(stacked->widget(i))->SaveInfo();
 	}
@@ -84,25 +79,24 @@
 	font.setPointSize(9);
 	sidebar->setFont(font);
 
-	QPalette pal;
-	pal.setColor(QPalette::Window, Qt::white);
+	QPalette pal(sidebar->palette());
+	pal.setColor(QPalette::Base, pal.color(QPalette::Window));
 	sidebar->setPalette(pal);
 
 	sidebar->setFixedWidth(158);
 	sidebar->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Expanding);
 
-	QStackedWidget* stacked = new QStackedWidget;
+	QStackedWidget* stacked = new QStackedWidget(this);
 	stacked->addWidget(new SettingsPageServices(stacked));
 	stacked->addWidget(new SettingsPageApplication(stacked));
 	stacked->setCurrentIndex(0);
 
 	connect(sidebar, &QListWidget::currentRowChanged, stacked, &QStackedWidget::setCurrentIndex);
 
-	layout = new QHBoxLayout;
+	QHBoxLayout* layout = new QHBoxLayout(widget);
 	layout->addWidget(sidebar);
 	layout->addWidget(stacked);
 	layout->setContentsMargins(0, 0, 0, 0);
-	widget->setLayout(layout);
 
 	QDialogButtonBox* button_box = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel, this);
 	connect(button_box, &QDialogButtonBox::accepted, this, &SettingsDialog::OnOK);
@@ -111,7 +105,6 @@
 	QVBoxLayout* buttons_layout = new QVBoxLayout(this);
 	buttons_layout->addWidget(widget);
 	buttons_layout->addWidget(button_box);
-	setLayout(buttons_layout);
 }
 
 #include "gui/dialog/moc_settings.cpp"
--- a/src/gui/dialog/settings/application.cpp	Mon Oct 02 07:06:44 2023 -0400
+++ b/src/gui/dialog/settings/application.cpp	Mon Oct 02 21:33:25 2023 -0400
@@ -3,8 +3,11 @@
 #include <QCheckBox>
 #include <QComboBox>
 #include <QGroupBox>
+#include <QHBoxLayout>
+#include <QLabel>
 #include <QPushButton>
 #include <QSizePolicy>
+#include <QVBoxLayout>
 
 QWidget* SettingsPageApplication::CreateAnimeListWidget() {
 	QWidget* result = new QWidget(this);
@@ -19,11 +22,10 @@
 	QComboBox* dc_combo_box = new QComboBox(double_click_widget);
 	dc_combo_box->addItem(tr("View anime info"));
 
-	QVBoxLayout* double_click_layout = new QVBoxLayout;
+	QVBoxLayout* double_click_layout = new QVBoxLayout(double_click_widget);
 	double_click_layout->addWidget(dc_combo_box_label);
 	double_click_layout->addWidget(dc_combo_box);
 	double_click_layout->setContentsMargins(0, 0, 0, 0);
-	double_click_widget->setLayout(double_click_layout);
 
 	/* Actions/Middle click */
 	QWidget* middle_click_widget = new QWidget(actions_group_box);
@@ -31,17 +33,15 @@
 	QComboBox* mc_combo_box = new QComboBox(middle_click_widget);
 	mc_combo_box->addItem(tr("Play next episode"));
 
-	QVBoxLayout* middle_click_layout = new QVBoxLayout;
+	QVBoxLayout* middle_click_layout = new QVBoxLayout(middle_click_widget);
 	middle_click_layout->addWidget(mc_combo_box_label);
 	middle_click_layout->addWidget(mc_combo_box);
 	middle_click_layout->setContentsMargins(0, 0, 0, 0);
-	middle_click_widget->setLayout(middle_click_layout);
 
 	/* Actions */
-	QHBoxLayout* actions_layout = new QHBoxLayout;
+	QHBoxLayout* actions_layout = new QHBoxLayout(actions_group_box);
 	actions_layout->addWidget(double_click_widget);
 	actions_layout->addWidget(middle_click_widget);
-	actions_group_box->setLayout(actions_layout);
 
 	QGroupBox* appearance_group_box = new QGroupBox(tr("Appearance"), result);
 	appearance_group_box->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Maximum);
@@ -59,23 +59,22 @@
 	    new QCheckBox(tr("Highlight anime if next episode is available in library folders"), appearance_group_box);
 	QCheckBox* hl_above_anime_box = new QCheckBox(tr("Display highlighted anime above others"), appearance_group_box);
 	connect(hl_anime_box, &QCheckBox::stateChanged, this, [this, hl_above_anime_box](int state) {
-		highlight_anime_if_available = (state == Qt::Unchecked) ? false : true;
+		highlight_anime_if_available = !(state == Qt::Unchecked);
 		hl_above_anime_box->setEnabled(state);
 	});
 	connect(hl_above_anime_box, &QCheckBox::stateChanged, this,
-	        [this](int state) { highlight_anime_if_available = (state == Qt::Unchecked) ? false : true; });
+	        [this](int state) { highlight_anime_if_available = !(state == Qt::Unchecked); });
 	hl_anime_box->setCheckState(highlight_anime_if_available ? Qt::Checked : Qt::Unchecked);
 	hl_above_anime_box->setCheckState(highlighted_anime_above_others ? Qt::Checked : Qt::Unchecked);
 	hl_above_anime_box->setEnabled(hl_anime_box->checkState() != Qt::Unchecked);
 	hl_above_anime_box->setContentsMargins(10, 0, 0, 0);
 
 	/* Appearance */
-	QVBoxLayout* appearance_layout = new QVBoxLayout;
+	QVBoxLayout* appearance_layout = new QVBoxLayout(appearance_group_box);
 	appearance_layout->addWidget(lang_combo_box_label);
 	appearance_layout->addWidget(lang_combo_box);
 	appearance_layout->addWidget(hl_anime_box);
 	appearance_layout->addWidget(hl_above_anime_box);
-	appearance_group_box->setLayout(appearance_layout);
 
 	QGroupBox* progress_group_box = new QGroupBox(tr("Progress"), result);
 	progress_group_box->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Maximum);
@@ -83,27 +82,26 @@
 	QCheckBox* progress_display_aired_episodes =
 	    new QCheckBox(tr("Display aired episodes (estimated)"), progress_group_box);
 	connect(progress_display_aired_episodes, &QCheckBox::stateChanged, this,
-	        [this](int state) { display_aired_episodes = (state == Qt::Unchecked) ? false : true; });
+	        [this](int state) { display_aired_episodes = !(state == Qt::Unchecked); });
 	progress_display_aired_episodes->setCheckState(display_aired_episodes ? Qt::Checked : Qt::Unchecked);
 
 	QCheckBox* progress_display_available_episodes =
 	    new QCheckBox(tr("Display available episodes in library folders"), progress_group_box);
 	connect(progress_display_available_episodes, &QCheckBox::stateChanged, this,
-	        [this](int state) { display_available_episodes = (state == Qt::Unchecked) ? false : true; });
+	        [this](int state) { display_available_episodes = !(state == Qt::Unchecked); });
 	progress_display_available_episodes->setCheckState(display_available_episodes ? Qt::Checked : Qt::Unchecked);
 
-	QVBoxLayout* progress_layout = new QVBoxLayout;
+	QVBoxLayout* progress_layout = new QVBoxLayout(progress_group_box);
 	progress_layout->addWidget(progress_display_aired_episodes);
 	progress_layout->addWidget(progress_display_available_episodes);
-	progress_group_box->setLayout(progress_layout);
 
-	QVBoxLayout* full_layout = new QVBoxLayout;
+	QVBoxLayout* full_layout = new QVBoxLayout(result);
 	full_layout->addWidget(actions_group_box);
 	full_layout->addWidget(appearance_group_box);
 	full_layout->addWidget(progress_group_box);
 	full_layout->setSpacing(10);
 	full_layout->addStretch();
-	result->setLayout(full_layout);
+
 	return result;
 }
 
--- a/src/gui/dialog/settings/services.cpp	Mon Oct 02 07:06:44 2023 -0400
+++ b/src/gui/dialog/settings/services.cpp	Mon Oct 02 21:33:25 2023 -0400
@@ -7,6 +7,10 @@
 #include <QGroupBox>
 #include <QPushButton>
 #include <QSizePolicy>
+#include <QVBoxLayout>
+#include <QLabel>
+#include <QPushButton>
+#include <QLineEdit>
 
 QWidget* SettingsPageServices::CreateMainPage() {
 	QWidget* result = new QWidget(this);
@@ -26,17 +30,16 @@
 	QLabel* sync_note_label =
 	    new QLabel(tr("Note: Minori is unable to synchronize multiple services at the same time."), sync_group_box);
 
-	QVBoxLayout* sync_layout = new QVBoxLayout;
+	QVBoxLayout* sync_layout = new QVBoxLayout(sync_group_box);
 	sync_layout->addWidget(sync_combo_box_label);
 	sync_layout->addWidget(sync_combo_box);
 	sync_layout->addWidget(sync_note_label);
-	sync_group_box->setLayout(sync_layout);
 
-	QVBoxLayout* full_layout = new QVBoxLayout;
+	QVBoxLayout* full_layout = new QVBoxLayout(result);
 	full_layout->addWidget(sync_group_box);
 	full_layout->setSpacing(10);
 	full_layout->addStretch();
-	result->setLayout(full_layout);
+
 	return result;
 }
 
@@ -60,27 +63,24 @@
 	connect(auth_button, &QPushButton::clicked, this, [] { Services::AniList::AuthorizeUser(); });
 	auth_button->setText(session.config.anilist.auth_token.empty() ? tr("Authorize...") : tr("Re-authorize..."));
 
-	QHBoxLayout* auth_layout = new QHBoxLayout;
+	QHBoxLayout* auth_layout = new QHBoxLayout(auth_widget);
 	auth_layout->addWidget(username_entry);
 	auth_layout->addWidget(auth_button);
-	auth_widget->setLayout(auth_layout);
 
 	QLabel* note_label = new QLabel(tr("<a href=\"http://anilist.co/\">Create a new AniList account</a>"), group_box);
 	note_label->setTextFormat(Qt::RichText);
 	note_label->setTextInteractionFlags(Qt::TextBrowserInteraction);
 	note_label->setOpenExternalLinks(true);
 
-	QVBoxLayout* layout = new QVBoxLayout;
+	QVBoxLayout* layout = new QVBoxLayout(group_box);
 	layout->addWidget(username_entry_label);
 	layout->addWidget(auth_widget);
 	layout->addWidget(note_label);
-	group_box->setLayout(layout);
 
-	QVBoxLayout* full_layout = new QVBoxLayout;
+	QVBoxLayout* full_layout = new QVBoxLayout(result);
 	full_layout->addWidget(group_box);
 	full_layout->setSpacing(10);
 	full_layout->addStretch();
-	result->setLayout(full_layout);
 	return result;
 }
 
--- a/src/gui/pages/anime_list.cpp	Mon Oct 02 07:06:44 2023 -0400
+++ b/src/gui/pages/anime_list.cpp	Mon Oct 02 21:33:25 2023 -0400
@@ -451,10 +451,9 @@
 	}
 	tree_view->setModel(sort_models[0]);
 
-	QHBoxLayout* layout = new QHBoxLayout;
+	QHBoxLayout* layout = new QHBoxLayout(tree_widget);
 	layout->addWidget(tree_view);
 	layout->setContentsMargins(0, 0, 0, 0);
-	tree_widget->setLayout(layout);
 
 	/* Double click stuff */
 	connect(tree_view, &QAbstractItemView::doubleClicked, this, &AnimeListPage::ItemDoubleClicked);
--- a/src/gui/pages/now_playing.cpp	Mon Oct 02 07:06:44 2023 -0400
+++ b/src/gui/pages/now_playing.cpp	Mon Oct 02 21:33:25 2023 -0400
@@ -36,7 +36,7 @@
 
 Playing::Playing(QWidget* parent) : QWidget(parent) {
 	QHBoxLayout* layout = new QHBoxLayout(this);
-	
+
 	layout->setContentsMargins(0, 0, 0, 0);
 }
 
@@ -68,7 +68,6 @@
 	stack->addWidget(new NowPlayingPages::Playing(stack));
 	layout->addWidget(stack);
 
-	layout->addStretch();
 	SetDefault();
 }
 
--- a/src/gui/widgets/poster.cpp	Mon Oct 02 07:06:44 2023 -0400
+++ b/src/gui/widgets/poster.cpp	Mon Oct 02 21:33:25 2023 -0400
@@ -56,6 +56,7 @@
 	QPixmap pixmap = QPixmap::fromImage(img);
 
 	label = new ClickableLabel(this);
+	label->setAlignment(Qt::AlignCenter);
 	connect(label, &ClickableLabel::clicked, this, [anime]{
 		QDesktopServices::openUrl(Strings::ToQString(anime.GetServiceUrl()));
 	});
@@ -63,7 +64,7 @@
 }
 
 void Poster::resizeEvent(QResizeEvent*) {
-	QPixmap pixmap = QPixmap::fromImage(img).scaled(size(), Qt::KeepAspectRatioByExpanding, Qt::SmoothTransformation);
+	QPixmap pixmap = QPixmap::fromImage(img).scaled(label->size(), Qt::KeepAspectRatioByExpanding, Qt::SmoothTransformation);
 	label->setPixmap(pixmap);
 }
 
--- a/src/gui/widgets/sidebar.cpp	Mon Oct 02 07:06:44 2023 -0400
+++ b/src/gui/widgets/sidebar.cpp	Mon Oct 02 21:33:25 2023 -0400
@@ -53,14 +53,9 @@
 	line->setMouseTracking(true);
 	line->setEnabled(false);
 
-	/*
-	QPalette pal;
-	pal.setColor(QPalette::Window, Qt::transparent);
-	line->setPalette(pal);
-	*/
-
 	setItemWidget(item, line);
 	item->setFlags(Qt::NoItemFlags);
+	item->setBackground(QBrush(Qt::transparent));
 	return item;
 }
 
--- a/src/gui/window.cpp	Mon Oct 02 07:06:44 2023 -0400
+++ b/src/gui/window.cpp	Mon Oct 02 21:33:25 2023 -0400
@@ -22,11 +22,13 @@
 #include <QFile>
 #include <QMainWindow>
 #include <QMenuBar>
+#include <QToolBar>
 #include <QMessageBox>
 #include <QPlainTextEdit>
 #include <QStackedWidget>
 #include <QTextStream>
 #include <QTimer>
+#include <QHBoxLayout>
 #if MACOSX
 #	include "sys/osx/dark_theme.h"
 #elif defined(WIN32)
@@ -194,6 +196,19 @@
 
 	setMenuBar(menubar);
 
+	/* Toolbar */
+	QToolBar* toolbar = new QToolBar(this);
+	toolbar->addAction(QIcon(":/icons/24x24/arrow-circle-double-135.png"), tr("&Synchronize"), [stack] {
+		Services::Synchronize();
+		reinterpret_cast<AnimeListPage*>(stack->widget(static_cast<int>(Pages::ANIME_LIST)))->Refresh();
+	});
+	toolbar->addSeparator();
+	toolbar->addAction(QIcon(":/icons/24x24/gear.png"), tr("S&ettings"), [this]{
+		SettingsDialog dialog(this);
+		dialog.exec();
+	});
+	addToolBar(toolbar);
+
 	QHBoxLayout* layout = new QHBoxLayout(main_widget);
 	layout->addWidget(sidebar);
 	layout->addWidget(stack);