/* 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 */ #include "info/info_memento.h" #include "info/profile/info_profile_widget.h" #include "info/media/info_media_widget.h" #include "info/info_common_groups_widget.h" #include "info/info_section_widget.h" #include "info/info_layer_widget.h" #include "info/info_controller.h" namespace Info { Memento::Memento(PeerId peerId) : Memento(peerId, Section::Type::Profile) { } Memento::Memento(PeerId peerId, Section section) : Memento(Default(peerId, section)) { } Memento::Memento(std::unique_ptr content) : _content(std::move(content)) { } std::unique_ptr Memento::Default( PeerId peerId, Section section) { Expects(peerId != 0); auto peer = App::peer(peerId); if (auto to = peer->migrateTo()) { peer = to; } auto migrated = peer->migrateFrom(); peerId = peer->id; auto migratedPeerId = migrated ? migrated->id : PeerId(0); switch (section.type()) { case Section::Type::Profile: return std::make_unique( peerId, migratedPeerId); case Section::Type::Media: return std::make_unique( peerId, migratedPeerId, section.mediaType()); case Section::Type::CommonGroups: Assert(peerIsUser(peerId)); return std::make_unique( peerToUser(peerId)); } Unexpected("Wrong section type in Info::Memento::Default()"); } object_ptr Memento::createWidget( QWidget *parent, not_null controller, Window::Column column, const QRect &geometry) { auto wrap = (column == Window::Column::Third) ? Wrap::Side : Wrap::Narrow; auto result = object_ptr( parent, controller, wrap, this); result->setGeometry(geometry); return std::move(result); } object_ptr Memento::createLayer( not_null controller, const QRect &geometry) { if (geometry.width() >= LayerWidget::MinimalSupportedWidth()) { return object_ptr(controller, this); } return nullptr; } void Memento::setInner(std::unique_ptr content) { _content = std::move(content); } Memento::~Memento() = default; MoveMemento::MoveMemento(object_ptr content) : _content(std::move(content)) { } object_ptr MoveMemento::createWidget( QWidget *parent, not_null controller, Window::Column column, const QRect &geometry) { auto wrap = (column == Window::Column::Third) ? Wrap::Side : Wrap::Narrow; auto result = object_ptr( parent, controller, wrap, this); result->setGeometry(geometry); return std::move(result); } object_ptr MoveMemento::createLayer( not_null controller, const QRect &geometry) { if (geometry.width() < LayerWidget::MinimalSupportedWidth()) { return nullptr; } return object_ptr(controller, this); } object_ptr MoveMemento::takeContent( QWidget *parent, Wrap wrap) { Ui::AttachParentChild(parent, _content); _content->setWrap(wrap); return std::move(_content); } } // namespace Info