tdesktop/Telegram/SourceFiles/window/window_controller.h

146 lines
3.5 KiB
C
Raw Normal View History

/*
This file is part of Telegram Desktop,
the official desktop application for the Telegram messaging service.
For license and copyright information please follow this link:
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
*/
#pragma once
#include "mainwindow.h"
#include "window/window_adaptive.h"
2019-09-18 11:19:05 +00:00
#include "ui/layers/layer_widget.h"
namespace Main {
class Account;
} // namespace Main
namespace Media::View {
struct OpenRequest;
} // namespace Media::View
namespace Window {
class Controller final : public base::has_weak_ptr {
public:
2020-06-15 16:25:02 +00:00
Controller();
2022-01-04 16:36:33 +00:00
Controller(
not_null<PeerData*> singlePeer,
MsgId showAtMsgId);
~Controller();
Controller(const Controller &other) = delete;
Controller &operator=(const Controller &other) = delete;
2020-06-15 16:25:02 +00:00
void showAccount(not_null<Main::Account*> account);
[[nodiscard]] PeerData *singlePeer() const;
[[nodiscard]] bool isPrimary() const {
return (singlePeer() == nullptr);
}
2020-06-15 16:25:02 +00:00
[[nodiscard]] not_null<::MainWindow*> widget() {
return &_widget;
}
[[nodiscard]] Main::Account &account() const {
2020-06-15 16:25:02 +00:00
Expects(_account != nullptr);
return *_account;
}
[[nodiscard]] SessionController *sessionController() const {
return _sessionController.get();
}
[[nodiscard]] bool locked() const;
[[nodiscard]] Adaptive &adaptive() const;
void finishFirstShow();
void setupPasscodeLock();
void clearPasscodeLock();
void setupIntro();
2022-01-04 16:36:33 +00:00
void setupMain(MsgId singlePeerShowAtMsgId);
void showLogoutConfirmation();
void showSettings();
[[nodiscard]] int verticalShadowTop() const;
template <typename BoxType>
QPointer<BoxType> show(
object_ptr<BoxType> content,
2019-09-18 11:19:05 +00:00
Ui::LayerOptions options = Ui::LayerOption::KeepOther,
anim::type animated = anim::type::normal) {
const auto result = QPointer<BoxType>(content.data());
showBox(std::move(content), options, animated);
return result;
}
void showToast(const QString &text);
void showLayer(
std::unique_ptr<Ui::LayerWidget> &&layer,
Ui::LayerOptions options,
anim::type animated = anim::type::normal);
2019-09-03 08:25:19 +00:00
void showRightColumn(object_ptr<TWidget> widget);
void activate();
void reActivate();
void updateIsActiveFocus();
void updateIsActiveBlur();
void updateIsActive();
void minimize();
void close();
void preventOrInvoke(Fn<void()> &&callback);
void invokeForSessionController(
not_null<Main::Account*> account,
Fn<void(not_null<SessionController*>)> &&callback);
void openInMediaView(Media::View::OpenRequest &&request);
[[nodiscard]] auto openInMediaViewRequests() const
-> rpl::producer<Media::View::OpenRequest>;
QPoint getPointForCallPanelCenter() const;
rpl::lifetime &lifetime();
private:
struct CreateArgs {
PeerData *singlePeer = nullptr;
};
explicit Controller(CreateArgs &&args);
2022-01-04 16:36:33 +00:00
void showAccount(
not_null<Main::Account*> account,
MsgId singlePeerShowAtMsgId);
void setupSideBar();
void sideBarChanged();
void logoutWithChecks(Main::Account *account);
2022-01-04 16:36:33 +00:00
void showBox(
2019-09-18 11:19:05 +00:00
object_ptr<Ui::BoxContent> content,
Ui::LayerOptions options,
anim::type animated);
2019-09-02 16:10:18 +00:00
void checkThemeEditor();
void checkLockByTerms();
void showTermsDecline();
void showTermsDelete();
PeerData *_singlePeer = nullptr;
2020-06-15 16:25:02 +00:00
Main::Account *_account = nullptr;
2019-06-22 09:52:18 +00:00
::MainWindow _widget;
const std::unique_ptr<Adaptive> _adaptive;
std::unique_ptr<SessionController> _sessionController;
base::Timer _isActiveTimer;
QPointer<Ui::BoxContent> _termsBox;
rpl::event_stream<Media::View::OpenRequest> _openInMediaViewRequests;
2020-06-15 16:25:02 +00:00
rpl::lifetime _accountLifetime;
rpl::lifetime _lifetime;
};
} // namespace Window