/* * Copyright (c) 2010-2024 Belledonne Communications SARL. * * This file is part of linphone-desktop * (see https://www.linphone.org). * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "ChatList.hpp" #include "ChatCore.hpp" #include "ChatGui.hpp" #include "core/App.hpp" #include #include // ============================================================================= DEFINE_ABSTRACT_OBJECT(ChatList) QSharedPointer ChatList::create() { auto model = QSharedPointer(new ChatList(), &QObject::deleteLater); model->moveToThread(App::getInstance()->thread()); model->setSelf(model); return model; } QSharedPointer ChatList::createChatCore(const std::shared_ptr &chatroom) { auto chatCore = ChatCore::create(chatroom); return chatCore; } ChatList::ChatList(QObject *parent) : ListProxy(parent) { mustBeInMainThread(getClassName()); App::getInstance()->mEngine->setObjectOwnership(this, QQmlEngine::CppOwnership); } ChatList::~ChatList() { mustBeInMainThread("~" + getClassName()); mModelConnection = nullptr; } void ChatList::setSelf(QSharedPointer me) { mModelConnection = SafeConnection::create(me, CoreModel::getInstance()); mModelConnection->makeConnectToCore(&ChatList::lUpdate, [this]() { mModelConnection->invokeToModel([this]() { mustBeInLinphoneThread(getClassName()); // Avoid copy to lambdas QList> *chats = new QList>(); auto currentAccount = CoreModel::getInstance()->getCore()->getDefaultAccount(); auto linphoneChatRooms = currentAccount->filterChatRooms(Utils::appStringToCoreString(mFilter)); for (auto it : linphoneChatRooms) { auto model = createChatCore(it); chats->push_back(model); } mModelConnection->invokeToCore([this, chats]() { mustBeInMainThread(getClassName()); resetData(*chats); delete chats; }); }); }); mModelConnection->makeConnectToModel( &CoreModel::chatRoomStateChanged, [this](const std::shared_ptr &core, const std::shared_ptr &chatRoom, linphone::ChatRoom::State state) { // check account, filtre, puis ajout si c'est bon if (chatRoom->getAccount() == core->getDefaultAccount()) { if (state == linphone::ChatRoom::State::Created) { auto list = getSharedList(); auto found = std::find_if(list.begin(), list.end(), [chatRoom](const QSharedPointer &item) { return (item && item->getModel()->getMonitor() == chatRoom); }); if (found != list.end()) { qDebug() << "chat room created, add it to the list"; auto model = createChatCore(chatRoom); mModelConnection->invokeToCore([this, model]() { add(model); }); } } } }); mModelConnection->makeConnectToModel( &CoreModel::defaultAccountChanged, [this](std::shared_ptr core, std::shared_ptr account) { lUpdate(); }); connect(this, &ChatList::filterChanged, [this](QString filter) { mFilter = filter; lUpdate(); }); lUpdate(); } int ChatList::findChatIndex(ChatGui *chatGui) { if (!chatGui) return -1; auto core = chatGui->mCore; auto chatList = getSharedList(); auto it = std::find_if(chatList.begin(), chatList.end(), [core](const QSharedPointer item) { return item->getIdentifier() == core->getIdentifier(); }); return it == chatList.end() ? -1 : std::distance(chatList.begin(), it); } QVariant ChatList::data(const QModelIndex &index, int role) const { int row = index.row(); if (!index.isValid() || row < 0 || row >= mList.count()) return QVariant(); if (role == Qt::DisplayRole) return QVariant::fromValue(new ChatGui(mList[row].objectCast())); return QVariant(); }