mirror of
https://github.com/qTox/qTox.git
synced 2024-03-22 14:00:36 +08:00
Merge pull request #6388
bodwok (1): fix(ui): contact list optimization
This commit is contained in:
commit
26f021e8bd
|
@ -20,9 +20,9 @@
|
||||||
#include "friendlistmanager.h"
|
#include "friendlistmanager.h"
|
||||||
#include "src/widget/genericchatroomwidget.h"
|
#include "src/widget/genericchatroomwidget.h"
|
||||||
|
|
||||||
FriendListManager::FriendListManager(QObject *parent) : QObject(parent)
|
FriendListManager::FriendListManager(int countContacts, QObject *parent) : QObject(parent)
|
||||||
{
|
{
|
||||||
|
this->countContacts = countContacts;
|
||||||
}
|
}
|
||||||
|
|
||||||
QVector<FriendListManager::IFriendListItemPtr> FriendListManager::getItems() const
|
QVector<FriendListManager::IFriendListItemPtr> FriendListManager::getItems() const
|
||||||
|
@ -35,6 +35,11 @@ bool FriendListManager::needHideCircles() const
|
||||||
return hideCircles;
|
return hideCircles;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool FriendListManager::getPositionsChanged() const
|
||||||
|
{
|
||||||
|
return positionsChanged;
|
||||||
|
}
|
||||||
|
|
||||||
void FriendListManager::addFriendListItem(IFriendListItem *item)
|
void FriendListManager::addFriendListItem(IFriendListItem *item)
|
||||||
{
|
{
|
||||||
if (item->isGroup()) {
|
if (item->isGroup()) {
|
||||||
|
@ -44,15 +49,16 @@ void FriendListManager::addFriendListItem(IFriendListItem *item)
|
||||||
items.push_back(IFriendListItemPtr(item));
|
items.push_back(IFriendListItemPtr(item));
|
||||||
}
|
}
|
||||||
|
|
||||||
updatePositions();
|
if (countContacts <= items.size()) {
|
||||||
emit itemsChanged();
|
countContacts = 0;
|
||||||
|
setSortRequired();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendListManager::removeFriendListItem(IFriendListItem *item)
|
void FriendListManager::removeFriendListItem(IFriendListItem *item)
|
||||||
{
|
{
|
||||||
removeAll(item);
|
removeAll(item);
|
||||||
updatePositions();
|
setSortRequired();
|
||||||
emit itemsChanged();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendListManager::sortByName()
|
void FriendListManager::sortByName()
|
||||||
|
@ -87,7 +93,7 @@ void FriendListManager::setFilter(const QString &searchString, bool hideOnline,
|
||||||
filterParams.hideOffline = hideOffline;
|
filterParams.hideOffline = hideOffline;
|
||||||
filterParams.hideGroups = hideGroups;
|
filterParams.hideGroups = hideGroups;
|
||||||
|
|
||||||
emit itemsChanged();
|
setSortRequired();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendListManager::applyFilter()
|
void FriendListManager::applyFilter()
|
||||||
|
@ -126,19 +132,40 @@ void FriendListManager::applyFilter()
|
||||||
|
|
||||||
void FriendListManager::updatePositions()
|
void FriendListManager::updatePositions()
|
||||||
{
|
{
|
||||||
|
positionsChanged = true;
|
||||||
|
|
||||||
if (byName) {
|
if (byName) {
|
||||||
std::sort(items.begin(), items.end(),
|
auto sortName = [&](const IFriendListItemPtr &a, const IFriendListItemPtr &b) {
|
||||||
[&](const IFriendListItemPtr &a, const IFriendListItemPtr &b) {
|
|
||||||
return cmpByName(a, b, groupsOnTop);
|
return cmpByName(a, b, groupsOnTop);
|
||||||
|
};
|
||||||
|
if (!needSort) {
|
||||||
|
if (std::is_sorted(items.begin(), items.end(), sortName)) {
|
||||||
|
positionsChanged = false;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
);
|
}
|
||||||
|
std::sort(items.begin(), items.end(),sortName);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
std::sort(items.begin(), items.end(),
|
auto sortActivity = [&](const IFriendListItemPtr &a, const IFriendListItemPtr &b) {
|
||||||
[&](const IFriendListItemPtr &a, const IFriendListItemPtr &b) {
|
|
||||||
return cmpByActivity(a, b);
|
return cmpByActivity(a, b);
|
||||||
|
};
|
||||||
|
if (!needSort) {
|
||||||
|
if (std::is_sorted(items.begin(), items.end(), sortActivity)) {
|
||||||
|
positionsChanged = false;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
std::sort(items.begin(), items.end(), sortActivity);
|
||||||
|
}
|
||||||
|
|
||||||
|
needSort = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FriendListManager::setSortRequired()
|
||||||
|
{
|
||||||
|
needSort = true;
|
||||||
|
emit itemsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendListManager::setGroupsOnTop(bool v)
|
void FriendListManager::setGroupsOnTop(bool v)
|
||||||
|
|
|
@ -32,10 +32,12 @@ class FriendListManager : public QObject
|
||||||
public:
|
public:
|
||||||
using IFriendListItemPtr = std::shared_ptr<IFriendListItem>;
|
using IFriendListItemPtr = std::shared_ptr<IFriendListItem>;
|
||||||
|
|
||||||
explicit FriendListManager(QObject *parent = nullptr);
|
explicit FriendListManager(int countContacts, QObject *parent = nullptr);
|
||||||
|
|
||||||
QVector<IFriendListItemPtr> getItems() const;
|
QVector<IFriendListItemPtr> getItems() const;
|
||||||
bool needHideCircles() const;
|
bool needHideCircles() const;
|
||||||
|
// If the contact positions have changed, need to redraw view
|
||||||
|
bool getPositionsChanged() const;
|
||||||
|
|
||||||
void addFriendListItem(IFriendListItem* item);
|
void addFriendListItem(IFriendListItem* item);
|
||||||
void removeFriendListItem(IFriendListItem* item);
|
void removeFriendListItem(IFriendListItem* item);
|
||||||
|
@ -46,6 +48,7 @@ public:
|
||||||
bool hideOffline, bool hideGroups);
|
bool hideOffline, bool hideGroups);
|
||||||
void applyFilter();
|
void applyFilter();
|
||||||
void updatePositions();
|
void updatePositions();
|
||||||
|
void setSortRequired();
|
||||||
|
|
||||||
void setGroupsOnTop(bool v);
|
void setGroupsOnTop(bool v);
|
||||||
|
|
||||||
|
@ -67,6 +70,10 @@ private:
|
||||||
bool byName = true;
|
bool byName = true;
|
||||||
bool hideCircles = false;
|
bool hideCircles = false;
|
||||||
bool groupsOnTop;
|
bool groupsOnTop;
|
||||||
|
bool positionsChanged;
|
||||||
|
bool needSort;
|
||||||
QVector<IFriendListItemPtr> items;
|
QVector<IFriendListItemPtr> items;
|
||||||
|
// At startup, while the size of items is less than countContacts, the view will not be processed to improve performance
|
||||||
|
int countContacts;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -101,7 +101,8 @@ FriendListWidget::FriendListWidget(const Core &_core, Widget* parent, bool group
|
||||||
: QWidget(parent)
|
: QWidget(parent)
|
||||||
, core{_core}
|
, core{_core}
|
||||||
{
|
{
|
||||||
manager = new FriendListManager(this);
|
int countContacts = core.getFriendList().size();
|
||||||
|
manager = new FriendListManager(countContacts, this);
|
||||||
manager->setGroupsOnTop(groupsOnTop);
|
manager->setGroupsOnTop(groupsOnTop);
|
||||||
connect(manager, &FriendListManager::itemsChanged, this, &FriendListWidget::itemsChanged);
|
connect(manager, &FriendListManager::itemsChanged, this, &FriendListWidget::itemsChanged);
|
||||||
|
|
||||||
|
@ -137,15 +138,18 @@ void FriendListWidget::setMode(SortingMode mode)
|
||||||
this->mode = mode;
|
this->mode = mode;
|
||||||
Settings::getInstance().setFriendSortingMode(mode);
|
Settings::getInstance().setFriendSortingMode(mode);
|
||||||
|
|
||||||
sortByMode(mode);
|
manager->setSortRequired();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendListWidget::sortByMode(SortingMode mode)
|
void FriendListWidget::sortByMode(SortingMode mode)
|
||||||
{
|
{
|
||||||
cleanMainLayout();
|
|
||||||
|
|
||||||
if (mode == SortingMode::Name) {
|
if (mode == SortingMode::Name) {
|
||||||
manager->sortByName();
|
manager->sortByName();
|
||||||
|
if (!manager->getPositionsChanged()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
cleanMainLayout();
|
||||||
|
|
||||||
for (int i = 0; i < Settings::getInstance().getCircleCount(); ++i) {
|
for (int i = 0; i < Settings::getInstance().getCircleCount(); ++i) {
|
||||||
addCircleWidget(i);
|
addCircleWidget(i);
|
||||||
|
@ -202,6 +206,13 @@ void FriendListWidget::sortByMode(SortingMode mode)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (mode == SortingMode::Activity) {
|
} else if (mode == SortingMode::Activity) {
|
||||||
|
|
||||||
|
manager->sortByActivity();
|
||||||
|
if (!manager->getPositionsChanged()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
cleanMainLayout();
|
||||||
|
|
||||||
QLocale ql(Settings::getInstance().getTranslation());
|
QLocale ql(Settings::getInstance().getTranslation());
|
||||||
QDate today = QDate::currentDate();
|
QDate today = QDate::currentDate();
|
||||||
#define COMMENT "Category for sorting friends by activity"
|
#define COMMENT "Category for sorting friends by activity"
|
||||||
|
@ -222,7 +233,6 @@ void FriendListWidget::sortByMode(SortingMode mode)
|
||||||
// clang-format on
|
// clang-format on
|
||||||
#undef COMMENT
|
#undef COMMENT
|
||||||
|
|
||||||
manager->sortByActivity();
|
|
||||||
QVector<std::shared_ptr<IFriendListItem>> itemsTmp = manager->getItems();
|
QVector<std::shared_ptr<IFriendListItem>> itemsTmp = manager->getItems();
|
||||||
|
|
||||||
for (int i = 0; i < itemsTmp.size(); ++i) {
|
for (int i = 0; i < itemsTmp.size(); ++i) {
|
||||||
|
@ -386,9 +396,9 @@ void FriendListWidget::addCircleWidget(FriendWidget* friendWidget)
|
||||||
|
|
||||||
if (window()->isActiveWindow())
|
if (window()->isActiveWindow())
|
||||||
circleWidget->editName();
|
circleWidget->editName();
|
||||||
}
|
|
||||||
|
|
||||||
itemsChanged();
|
manager->setSortRequired();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendListWidget::removeCircleWidget(CircleWidget* widget)
|
void FriendListWidget::removeCircleWidget(CircleWidget* widget)
|
||||||
|
@ -412,7 +422,7 @@ void FriendListWidget::renameCircleWidget(CircleWidget* circleWidget, const QStr
|
||||||
circleWidget->setName(newName);
|
circleWidget->setName(newName);
|
||||||
|
|
||||||
if (mode == SortingMode::Name) {
|
if (mode == SortingMode::Name) {
|
||||||
itemsChanged();
|
manager->setSortRequired();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -423,7 +433,6 @@ void FriendListWidget::onGroupchatPositionChanged(bool top)
|
||||||
if (mode != SortingMode::Name)
|
if (mode != SortingMode::Name)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
manager->updatePositions();
|
|
||||||
itemsChanged();
|
itemsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -559,10 +568,12 @@ void FriendListWidget::moveWidget(FriendWidget* widget, Status::Status s, bool a
|
||||||
CircleWidget* circleWidget = CircleWidget::getFromID(circleId);
|
CircleWidget* circleWidget = CircleWidget::getFromID(circleId);
|
||||||
|
|
||||||
if (circleWidget == nullptr || add) {
|
if (circleWidget == nullptr || add) {
|
||||||
if (circleId != -1)
|
if (circleId != -1) {
|
||||||
Settings::getInstance().setFriendCircleID(f->getPublicKey(), -1);
|
Settings::getInstance().setFriendCircleID(f->getPublicKey(), -1);
|
||||||
|
manager->setSortRequired();
|
||||||
|
} else {
|
||||||
itemsChanged();
|
itemsChanged();
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user