Replaced AboutBox with generic box.

This commit is contained in:
23rd 2025-06-29 23:37:43 +03:00
parent c93e948bb3
commit ac243136b9
5 changed files with 71 additions and 101 deletions

View file

@ -7,18 +7,16 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
*/ */
#include "boxes/about_box.h" #include "boxes/about_box.h"
#include "lang/lang_keys.h"
#include "mainwidget.h"
#include "mainwindow.h"
#include "ui/boxes/confirm_box.h"
#include "ui/widgets/buttons.h"
#include "ui/widgets/labels.h"
#include "ui/text/text_utilities.h"
#include "base/platform/base_platform_info.h" #include "base/platform/base_platform_info.h"
#include "core/file_utilities.h"
#include "core/click_handler_types.h"
#include "core/update_checker.h"
#include "core/application.h" #include "core/application.h"
#include "core/file_utilities.h"
#include "core/update_checker.h"
#include "lang/lang_keys.h"
#include "ui/boxes/confirm_box.h"
#include "ui/text/text_utilities.h"
#include "ui/vertical_list.h"
#include "ui/widgets/buttons.h"
#include "ui/wrap/vertical_layout.h"
#include "styles/style_layers.h" #include "styles/style_layers.h"
#include "styles/style_boxes.h" #include "styles/style_boxes.h"
@ -57,43 +55,25 @@ rpl::producer<TextWithEntities> Text3() {
} // namespace } // namespace
AboutBox::AboutBox(QWidget *parent) void AboutBox(not_null<Ui::GenericBox*> box) {
: _version(this, tr::lng_about_version(tr::now, lt_version, currentVersionText()), st::aboutVersionLink) box->setTitle(rpl::single(u"Telegram Desktop"_q));
, _text1(this, Text1(), st::aboutLabel)
, _text2(this, Text2(), st::aboutLabel)
, _text3(this, Text3(), st::aboutLabel) {
}
void AboutBox::prepare() { auto layout = box->verticalLayout();
setTitle(rpl::single(u"Telegram Desktop"_q));
addButton(tr::lng_close(), [this] { closeBox(); }); const auto version = layout->add(
object_ptr<Ui::LinkButton>(
_text1->setLinksTrusted(); box,
_text2->setLinksTrusted(); tr::lng_about_version(
_text3->setLinksTrusted(); tr::now,
lt_version,
_version->setClickedCallback([this] { showVersionHistory(); }); currentVersionText()),
st::aboutVersionLink),
setDimensions(st::aboutWidth, st::aboutTextTop + _text1->height() + st::aboutSkip + _text2->height() + st::aboutSkip + _text3->height()); QMargins(
} st::boxRowPadding.left(),
-st::lineWidth * 3,
void AboutBox::resizeEvent(QResizeEvent *e) { st::boxRowPadding.right(),
BoxContent::resizeEvent(e); st::boxRowPadding.bottom()));
version->setClickedCallback([=] {
const auto available = width()
- st::boxPadding.left()
- st::boxPadding.right();
_version->moveToLeft(st::boxPadding.left(), st::aboutVersionTop);
_text1->resizeToWidth(available);
_text1->moveToLeft(st::boxPadding.left(), st::aboutTextTop);
_text2->resizeToWidth(available);
_text2->moveToLeft(st::boxPadding.left(), _text1->y() + _text1->height() + st::aboutSkip);
_text3->resizeToWidth(available);
_text3->moveToLeft(st::boxPadding.left(), _text2->y() + _text2->height() + st::aboutSkip);
}
void AboutBox::showVersionHistory() {
if (cRealAlphaVersion()) { if (cRealAlphaVersion()) {
auto url = u"https://tdesktop.com/"_q; auto url = u"https://tdesktop.com/"_q;
if (Platform::IsWindows32Bit()) { if (Platform::IsWindows32Bit()) {
@ -109,26 +89,39 @@ void AboutBox::showVersionHistory() {
} else { } else {
Unexpected("Platform value."); Unexpected("Platform value.");
} }
url = url.arg(u"talpha%1_%2"_q.arg(cRealAlphaVersion()).arg(Core::countAlphaVersionSignature(cRealAlphaVersion()))); url = url.arg(u"talpha%1_%2"_q
.arg(cRealAlphaVersion())
.arg(Core::countAlphaVersionSignature(cRealAlphaVersion())));
QGuiApplication::clipboard()->setText(url); QGuiApplication::clipboard()->setText(url);
getDelegate()->show( box->getDelegate()->show(
Ui::MakeInformBox( Ui::MakeInformBox(
"The link to the current private alpha " "The link to the current private alpha "
"version of Telegram Desktop was copied to the clipboard."), "version of Telegram Desktop was copied "
Ui::LayerOption::CloseOther); "to the clipboard."));
} else { } else {
File::OpenUrl(Core::App().changelogLink()); File::OpenUrl(Core::App().changelogLink());
} }
} });
void AboutBox::keyPressEvent(QKeyEvent *e) { Ui::AddSkip(layout, st::aboutTopSkip);
if (e->key() == Qt::Key_Enter || e->key() == Qt::Key_Return) {
closeBox(); const auto addText = [&](rpl::producer<TextWithEntities> text) {
} else { const auto label = layout->add(
BoxContent::keyPressEvent(e); object_ptr<Ui::FlatLabel>(box, std::move(text), st::aboutLabel),
} st::boxRowPadding);
label->setLinksTrusted();
Ui::AddSkip(layout, st::aboutSkip);
};
addText(Text1());
addText(Text2());
addText(Text3());
box->addButton(tr::lng_close(), [=] { box->closeBox(); });
box->setWidth(st::aboutWidth);
} }
QString telegramFaqLink() { QString telegramFaqLink() {

View file

@ -7,32 +7,9 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
*/ */
#pragma once #pragma once
#include "ui/layers/box_content.h" #include "ui/layers/generic_box.h"
namespace Ui { void AboutBox(not_null<Ui::GenericBox*> box);
class LinkButton;
class FlatLabel;
} // namespace Ui
class AboutBox : public Ui::BoxContent {
public:
AboutBox(QWidget*);
protected:
void prepare() override;
void resizeEvent(QResizeEvent *e) override;
void keyPressEvent(QKeyEvent *e) override;
private:
void showVersionHistory();
object_ptr<Ui::LinkButton> _version;
object_ptr<Ui::FlatLabel> _text1;
object_ptr<Ui::FlatLabel> _text2;
object_ptr<Ui::FlatLabel> _text3;
};
QString telegramFaqLink(); QString telegramFaqLink();
QString currentVersionText(); QString currentVersionText();

View file

@ -349,7 +349,7 @@ aboutVersionLink: LinkButton(defaultLinkButton) {
color: windowSubTextFg; color: windowSubTextFg;
overColor: windowSubTextFg; overColor: windowSubTextFg;
} }
aboutTextTop: 34px; aboutTopSkip: 19px;
aboutSkip: 14px; aboutSkip: 14px;
aboutLabel: FlatLabel(defaultFlatLabel) { aboutLabel: FlatLabel(defaultFlatLabel) {
minWidth: 300px; minWidth: 300px;

View file

@ -369,7 +369,7 @@ void MainWindow::createGlobalMenu() {
{ {
auto callback = [=] { auto callback = [=] {
ensureWindowShown(); ensureWindowShown();
controller().show(Box<AboutBox>()); controller().show(Box(AboutBox));
}; };
main->addAction( main->addAction(
tr::lng_mac_menu_about_telegram( tr::lng_mac_menu_about_telegram(

View file

@ -403,7 +403,7 @@ MainMenu::MainMenu(
_version->setLink( _version->setLink(
2, 2,
std::make_shared<LambdaClickHandler>([=] { std::make_shared<LambdaClickHandler>([=] {
controller->show(Box<AboutBox>()); controller->show(Box(AboutBox));
})); }));
rpl::combine( rpl::combine(