/* 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 */ #include "info/profile/info_profile_widget.h" #include "dialogs/ui/dialogs_stories_content.h" #include "info/profile/info_profile_inner_widget.h" #include "info/profile/info_profile_members.h" #include "ui/widgets/scroll_area.h" #include "ui/ui_utility.h" #include "data/data_peer.h" #include "data/data_channel.h" #include "data/data_forum_topic.h" #include "data/data_user.h" #include "lang/lang_keys.h" #include "info/info_controller.h" namespace Info::Profile { Memento::Memento(not_null controller) : Memento( controller->peer(), controller->topic(), controller->migratedPeerId(), { v::null }) { } Memento::Memento( not_null peer, PeerId migratedPeerId, Origin origin) : Memento(peer, nullptr, migratedPeerId, origin) { } Memento::Memento( not_null peer, Data::ForumTopic *topic, PeerId migratedPeerId, Origin origin) : ContentMemento(peer, topic, migratedPeerId) , _origin(origin) { } Memento::Memento(not_null topic) : ContentMemento(topic->channel(), topic, 0) { } Section Memento::section() const { return Section(Section::Type::Profile); } object_ptr Memento::createWidget( QWidget *parent, not_null controller, const QRect &geometry) { auto result = object_ptr(parent, controller, _origin); result->setInternalState(geometry, this); return result; } void Memento::setMembersState(std::unique_ptr state) { _membersState = std::move(state); } std::unique_ptr Memento::membersState() { return std::move(_membersState); } Memento::~Memento() = default; Widget::Widget( QWidget *parent, not_null controller, Origin origin) : ContentWidget(parent, controller) { controller->setSearchEnabledByContent(false); _inner = setInnerWidget(object_ptr( this, controller, origin)); _inner->move(0, 0); _inner->scrollToRequests( ) | rpl::start_with_next([this](Ui::ScrollToRequest request) { if (request.ymin < 0) { scrollTopRestore( qMin(scrollTopSave(), request.ymax)); } else { scrollTo(request); } }, lifetime()); } void Widget::setInnerFocus() { _inner->setFocus(); } rpl::producer Widget::title() { if (const auto topic = controller()->key().topic()) { return tr::lng_info_topic_title(); } const auto peer = controller()->key().peer(); if (const auto user = peer->asUser()) { return (user->isBot() && !user->isSupport()) ? tr::lng_info_bot_title() : tr::lng_info_user_title(); } else if (const auto channel = peer->asChannel()) { return channel->isMegagroup() ? tr::lng_info_group_title() : tr::lng_info_channel_title(); } else if (peer->isChat()) { return tr::lng_info_group_title(); } Unexpected("Bad peer type in Info::TitleValue()"); } rpl::producer Widget::titleStories() { const auto peer = controller()->key().peer(); if (peer && !peer->isChat()) { return Dialogs::Stories::LastForPeer(peer); } return nullptr; } bool Widget::showInternal(not_null memento) { if (!controller()->validateMementoPeer(memento)) { return false; } if (auto profileMemento = dynamic_cast(memento.get())) { restoreState(profileMemento); return true; } return false; } void Widget::setInternalState( const QRect &geometry, not_null memento) { setGeometry(geometry); Ui::SendPendingMoveResizeEvents(this); restoreState(memento); } std::shared_ptr Widget::doCreateMemento() { auto result = std::make_shared(controller()); saveState(result.get()); return result; } void Widget::saveState(not_null memento) { memento->setScrollTop(scrollTopSave()); _inner->saveState(memento); } void Widget::restoreState(not_null memento) { _inner->restoreState(memento); scrollTopRestore(memento->scrollTop()); } } // namespace Info::Profile