|
|
@ -21,7 +21,6 @@ |
|
|
|
#include "encryption/DeviceVerificationFlow.h" |
|
|
|
#include "encryption/DeviceVerificationFlow.h" |
|
|
|
#include "encryption/Olm.h" |
|
|
|
#include "encryption/Olm.h" |
|
|
|
#include "ui/RoomSummary.h" |
|
|
|
#include "ui/RoomSummary.h" |
|
|
|
#include "ui/Theme.h" |
|
|
|
|
|
|
|
#include "ui/UserProfile.h" |
|
|
|
#include "ui/UserProfile.h" |
|
|
|
#include "voip/CallManager.h" |
|
|
|
#include "voip/CallManager.h" |
|
|
|
|
|
|
|
|
|
|
@ -29,8 +28,6 @@ |
|
|
|
|
|
|
|
|
|
|
|
#include "timeline/TimelineViewManager.h" |
|
|
|
#include "timeline/TimelineViewManager.h" |
|
|
|
|
|
|
|
|
|
|
|
#include "blurhash.hpp" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ChatPage *ChatPage::instance_ = nullptr; |
|
|
|
ChatPage *ChatPage::instance_ = nullptr; |
|
|
|
static constexpr int CHECK_CONNECTIVITY_INTERVAL = 15'000; |
|
|
|
static constexpr int CHECK_CONNECTIVITY_INTERVAL = 15'000; |
|
|
|
static constexpr int RETRY_TIMEOUT = 5'000; |
|
|
|
static constexpr int RETRY_TIMEOUT = 5'000; |
|
|
@ -404,6 +401,19 @@ ChatPage::ChatPage(QSharedPointer<UserSettings> userSettings, QObject *parent) |
|
|
|
[](std::function<void()> f) { f(); }, |
|
|
|
[](std::function<void()> f) { f(); }, |
|
|
|
Qt::QueuedConnection); |
|
|
|
Qt::QueuedConnection); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
connect(qobject_cast<QGuiApplication *>(QGuiApplication::instance()), |
|
|
|
|
|
|
|
&QGuiApplication::focusWindowChanged, |
|
|
|
|
|
|
|
this, |
|
|
|
|
|
|
|
[this](QWindow *activeWindow) { |
|
|
|
|
|
|
|
if (activeWindow) { |
|
|
|
|
|
|
|
nhlog::ui()->debug("Stopping inactive timer."); |
|
|
|
|
|
|
|
lastWindowActive = QDateTime(); |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
nhlog::ui()->debug("Starting inactive timer."); |
|
|
|
|
|
|
|
lastWindowActive = QDateTime::currentDateTime(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
connectCallMessage<mtx::events::voip::CallInvite>(); |
|
|
|
connectCallMessage<mtx::events::voip::CallInvite>(); |
|
|
|
connectCallMessage<mtx::events::voip::CallCandidates>(); |
|
|
|
connectCallMessage<mtx::events::voip::CallCandidates>(); |
|
|
|
connectCallMessage<mtx::events::voip::CallAnswer>(); |
|
|
|
connectCallMessage<mtx::events::voip::CallAnswer>(); |
|
|
@ -1107,6 +1117,13 @@ ChatPage::currentPresence() const |
|
|
|
return mtx::presence::unavailable; |
|
|
|
return mtx::presence::unavailable; |
|
|
|
case UserSettings::Presence::Offline: |
|
|
|
case UserSettings::Presence::Offline: |
|
|
|
return mtx::presence::offline; |
|
|
|
return mtx::presence::offline; |
|
|
|
|
|
|
|
case UserSettings::Presence::AutomaticPresence: |
|
|
|
|
|
|
|
if (lastWindowActive.isValid() && |
|
|
|
|
|
|
|
lastWindowActive.addSecs(60 * 5) < QDateTime::currentDateTime()) |
|
|
|
|
|
|
|
return mtx::presence::unavailable; |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
return mtx::presence::online; |
|
|
|
|
|
|
|
|
|
|
|
default: |
|
|
|
default: |
|
|
|
return mtx::presence::online; |
|
|
|
return mtx::presence::online; |
|
|
|
} |
|
|
|
} |
|
|
|