/* This file is part of Telegram Desktop, the official desktop version of Telegram messaging app, see https://telegram.org Telegram Desktop 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. It 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. In addition, as a special exception, the copyright holders give permission to link the code of portions of this program with the OpenSSL library. Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org */ #pragma once #include #include "history/history_search_controller.h" namespace Ui { class SearchFieldController; } // namespace Ui namespace Window { class Controller; } // namespace Window namespace Info { enum class Wrap; class WrapWidget; class Memento; class ContentMemento; class Section final { public: enum class Type { Profile, Media, CommonGroups, }; using MediaType = Storage::SharedMediaType; Section(Type type) : _type(type) { Expects(type != Type::Media); } Section(MediaType mediaType) : _type(Type::Media) , _mediaType(mediaType) { } Type type() const { return _type; } MediaType mediaType() const { Expects(_type == Type::Media); return _mediaType; } private: Type _type; Storage::SharedMediaType _mediaType; }; class Controller { public: Controller( not_null widget, not_null window, not_null memento); not_null peer() const { return _peer; } PeerData *migrated() const { return _migrated; } PeerId peerId() const { return _peer->id; } PeerId migratedPeerId() const { return _migrated ? _migrated->id : PeerId(0); } const Section §ion() const { return _section; } bool validateMementoPeer( not_null memento) const; Wrap wrap() const; rpl::producer wrapValue() const; void setSection(not_null memento); bool hasStackHistory() const; not_null window() const { return _window; } Ui::SearchFieldController *searchFieldController() const { return _searchFieldController.get(); } rpl::producer mediaSource( SparseIdsMergedSlice::UniversalMsgId aroundId, int limitBefore, int limitAfter) const; rpl::producer<> mediaSourceChanged() const { return _searchController->sourceChanged(); } void saveSearchState(not_null memento); rpl::lifetime &lifetime() { return _lifetime; } ~Controller(); private: using SearchQuery = Api::DelayedSearchController::Query; void updateSearchControllers(not_null memento); SearchQuery produceSearchQuery(const QString &query) const; not_null _widget; not_null _peer; PeerData *_migrated = nullptr; not_null _window; rpl::variable _wrap; Section _section; std::unique_ptr _searchFieldController; std::unique_ptr _searchController; rpl::lifetime _lifetime; }; } // namespace Info