# HG changeset patch # User Paper # Date 1695922341 14400 # Node ID b7a1c0010ffd0af803f83e537b27d9fc477f2df1 # Parent 3c802806b74abb774e4a5252c4e057b1829afd31 sidebar: link view menu and sidebar together diff -r 3c802806b74a -r b7a1c0010ffd include/gui/widgets/sidebar.h --- a/include/gui/widgets/sidebar.h Thu Sep 28 13:09:11 2023 -0400 +++ b/include/gui/widgets/sidebar.h Thu Sep 28 13:32:21 2023 -0400 @@ -16,10 +16,14 @@ signals: void CurrentItemChanged(int index); + public slots: + void SetCurrentItem(int index); + protected: virtual void mouseMoveEvent(QMouseEvent* event) override; QItemSelectionModel::SelectionFlags selectionCommand(const QModelIndex& index, const QEvent* event) const override; int RemoveSeparatorsFromIndex(int index); + int AddSeparatorsToIndex(int index); }; #endif // __gui__sidebar_h diff -r 3c802806b74a -r b7a1c0010ffd src/gui/widgets/sidebar.cpp --- a/src/gui/widgets/sidebar.cpp Thu Sep 28 13:09:11 2023 -0400 +++ b/src/gui/widgets/sidebar.cpp Thu Sep 28 13:32:21 2023 -0400 @@ -4,6 +4,7 @@ #include #include #include +#include SideBar::SideBar(QWidget* parent) : QListWidget(parent) { setFrameShape(QFrame::NoFrame); @@ -24,6 +25,11 @@ [this](int index) { emit CurrentItemChanged(RemoveSeparatorsFromIndex(index)); }); } +void SideBar::SetCurrentItem(int index) { + qDebug() << AddSeparatorsToIndex(index) << "\n"; + setCurrentRow(AddSeparatorsToIndex(index)); +} + QListWidgetItem* SideBar::AddItem(QString name, QIcon icon) { QListWidgetItem* item = new QListWidgetItem(this); item->setText(name); @@ -59,6 +65,16 @@ return item; } +int SideBar::AddSeparatorsToIndex(int index) { + int i, j; + for (i = 0, j = 0; i < index; ) { + i++; + if (IndexIsSeparator(indexFromItem(item(i)))) + j++; + } + return i+j; +} + int SideBar::RemoveSeparatorsFromIndex(int index) { int i, j; for (i = 0, j = 0; i < index; i++) { diff -r 3c802806b74a -r b7a1c0010ffd src/gui/window.cpp --- a/src/gui/window.cpp Thu Sep 28 13:09:11 2023 -0400 +++ b/src/gui/window.cpp Thu Sep 28 13:32:21 2023 -0400 @@ -64,7 +64,7 @@ stack->addWidget(new TorrentsWidget(main_widget)); connect(sidebar, &SideBar::CurrentItemChanged, stack, &QStackedWidget::setCurrentIndex); - sidebar->setCurrentRow(2); + sidebar->SetCurrentItem((int)Pages::ANIME_LIST); /* Menu Bar */ QAction* action; @@ -145,9 +145,9 @@ action = pages_group->addAction(menu->addAction(tr("&Anime List"))); page_to_index_map[action] = 1; - action->setCheckable(true); action->setChecked(true); + action = pages_group->addAction(menu->addAction(tr("&History"))); action->setCheckable(true); page_to_index_map[action] = 2; @@ -168,12 +168,12 @@ action->setCheckable(true); page_to_index_map[action] = 6; - connect(stack, &QStackedWidget::currentChanged, this, [pages_group, sidebar](int index){ + connect(sidebar, &SideBar::CurrentItemChanged, this, [pages_group](int index){ pages_group->actions()[index]->setChecked(true); }); - connect(pages_group, &QActionGroup::triggered, this, [page_to_index_map, stack](QAction* action) { - stack->setCurrentIndex(page_to_index_map.at(action)); + connect(pages_group, &QActionGroup::triggered, this, [page_to_index_map, sidebar](QAction* action) { + sidebar->SetCurrentItem(page_to_index_map.at(action)); }); menu->addSeparator();