diff src/gui/pages/seasons.cc @ 327:b5d6c27c308f

anime: refactor Anime::SeriesSeason to Season class ToLocalString has also been altered to take in both season and year because lots of locales actually treat formatting seasons differently! most notably is Russian which adds a suffix at the end to notate seasons(??)
author Paper <paper@paper.us.eu.org>
date Thu, 13 Jun 2024 01:49:18 -0400
parents 10096c5489e3
children 6b0768158dcd
line wrap: on
line diff
--- a/src/gui/pages/seasons.cc	Thu Jun 13 00:42:00 2024 -0400
+++ b/src/gui/pages/seasons.cc	Thu Jun 13 01:49:18 2024 -0400
@@ -18,9 +18,9 @@
 SeasonsPageSearchThread::SeasonsPageSearchThread(QObject* parent) : QThread(parent) {
 }
 
-void SeasonsPageSearchThread::AddToQueue(Anime::SeriesSeason season, Date::Year year) {
+void SeasonsPageSearchThread::AddToQueue(Anime::Season season) {
 	queue_mutex_.lock();
-	queue_.push({season, year});
+	queue_.push(season);
 	queue_mutex_.unlock();
 }
 
@@ -28,14 +28,14 @@
 	queue_mutex_.lock();
 
 	while (!queue_.empty() && !isInterruptionRequested()) {
-		Season season = queue_.front();
+		Anime::Season season = queue_.front();
 
 		/* unlock the mutex for a long blocking operation, so items
 		 * can be added without worry */
 		queue_mutex_.unlock();
 
-		if (Services::GetSeason(season.season, season.year))
-			emit ReceivedSeason(season.season, season.year);
+		if (Services::GetSeason(season))
+			emit ReceivedSeason(season);
 
 		queue_mutex_.lock();
 
@@ -61,7 +61,7 @@
 
 	buttons->clear();
 
-	for (const auto& id : Anime::db.GetAllAnimeForSeason(season_, year_)) {
+	for (const auto& id : Anime::db.GetAllAnimeForSeason(season_)) {
 		QListWidgetItem* item = new QListWidgetItem;
 		AnimeButton* button = new AnimeButton(this);
 		button->SetAnime(Anime::db.items[id]);
@@ -70,14 +70,13 @@
 		buttons->setItemWidget(item, button);
 	}
 
-	season_button->setText(Strings::ToQString(Translate::ToLocalString(season_)) + " " + QString::number(year_));
+	season_button->setText(Strings::ToQString(Translate::ToLocalString(season_)));
 
 	setUpdatesEnabled(true);
 }
 
-void SeasonsPage::SetSeason(Anime::SeriesSeason season, Date::Year year) {
+void SeasonsPage::SetSeason(Anime::Season season) {
 	season_ = season;
-	year_ = year;
 
 	Refresh();
 }
@@ -97,16 +96,17 @@
 		toolbar->setMovable(false);
 
 		{
+			/* currently this is VERY hardcoded to en_US */
 			static constexpr Date::Year last_year = 1960;
 
 			auto create_year_menu = [this](QWidget* parent, QMenu* parent_menu, Date::Year year){
 				const QString year_s = QString::number(year);
 
 				QMenu* menu = new QMenu(year_s, parent);
-				for (const auto& season : Anime::SeriesSeasons) {
-					QAction* action = menu->addAction(Strings::ToQString(Translate::ToLocalString(season)) + " " + year_s);
+				for (const auto& season : Anime::Season::Names) {
+					QAction* action = menu->addAction(Strings::ToQString(Translate::ToLocalString(Anime::Season(season, year))));
 					connect(action, &QAction::triggered, this, [this, season, year] {
-						SetSeason(season, year);
+						SetSeason({season, year});
 					});
 				}
 				parent_menu->addMenu(menu);
@@ -143,7 +143,7 @@
 
 		{
 			toolbar->addAction(QIcon(":/icons/16x16/arrow-circle-315.png"), tr("Refresh data"), [this]{
-				search_thread_.AddToQueue(season_, year_);
+				search_thread_.AddToQueue(season_);
 				if (!search_thread_.isRunning())
 					search_thread_.start();
 			});
@@ -234,11 +234,11 @@
 	full_layout->setContentsMargins(0, 0, 0, 0);
 	full_layout->setSpacing(0);
 
-	connect(&search_thread_, &SeasonsPageSearchThread::ReceivedSeason, this, [this](Anime::SeriesSeason season, Date::Year year) {
-		if (season == season_ && year == year_)
+	connect(&search_thread_, &SeasonsPageSearchThread::ReceivedSeason, this, [this](Anime::Season season) {
+		if (season == season_)
 			Refresh();
 	});
 
 	/* Do NOT move this up in this function, buttons HAS to be initialized */
-	SetSeason(Anime::SeriesSeason::Summer, 2011U);
+	SetSeason({Anime::Season::Name::Summer, 2011U});
 }