Mercurial > minori
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}); }