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,78 +55,73 @@ 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>(
box,
tr::lng_about_version(
tr::now,
lt_version,
currentVersionText()),
st::aboutVersionLink),
QMargins(
st::boxRowPadding.left(),
-st::lineWidth * 3,
st::boxRowPadding.right(),
st::boxRowPadding.bottom()));
version->setClickedCallback([=] {
if (cRealAlphaVersion()) {
auto url = u"https://tdesktop.com/"_q;
if (Platform::IsWindows32Bit()) {
url += u"win/%1.zip"_q;
} else if (Platform::IsWindows64Bit()) {
url += u"win64/%1.zip"_q;
} else if (Platform::IsWindowsARM64()) {
url += u"winarm/%1.zip"_q;
} else if (Platform::IsMac()) {
url += u"mac/%1.zip"_q;
} else if (Platform::IsLinux()) {
url += u"linux/%1.tar.xz"_q;
} else {
Unexpected("Platform value.");
}
url = url.arg(u"talpha%1_%2"_q
.arg(cRealAlphaVersion())
.arg(Core::countAlphaVersionSignature(cRealAlphaVersion())));
_text1->setLinksTrusted(); QGuiApplication::clipboard()->setText(url);
_text2->setLinksTrusted();
_text3->setLinksTrusted();
_version->setClickedCallback([this] { showVersionHistory(); }); box->getDelegate()->show(
Ui::MakeInformBox(
setDimensions(st::aboutWidth, st::aboutTextTop + _text1->height() + st::aboutSkip + _text2->height() + st::aboutSkip + _text3->height()); "The link to the current private alpha "
} "version of Telegram Desktop was copied "
"to the clipboard."));
void AboutBox::resizeEvent(QResizeEvent *e) {
BoxContent::resizeEvent(e);
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()) {
auto url = u"https://tdesktop.com/"_q;
if (Platform::IsWindows32Bit()) {
url += u"win/%1.zip"_q;
} else if (Platform::IsWindows64Bit()) {
url += u"win64/%1.zip"_q;
} else if (Platform::IsWindowsARM64()) {
url += u"winarm/%1.zip"_q;
} else if (Platform::IsMac()) {
url += u"mac/%1.zip"_q;
} else if (Platform::IsLinux()) {
url += u"linux/%1.tar.xz"_q;
} else { } else {
Unexpected("Platform value."); File::OpenUrl(Core::App().changelogLink());
} }
url = url.arg(u"talpha%1_%2"_q.arg(cRealAlphaVersion()).arg(Core::countAlphaVersionSignature(cRealAlphaVersion()))); });
QGuiApplication::clipboard()->setText(url); Ui::AddSkip(layout, st::aboutTopSkip);
getDelegate()->show( const auto addText = [&](rpl::producer<TextWithEntities> text) {
Ui::MakeInformBox( const auto label = layout->add(
"The link to the current private alpha " object_ptr<Ui::FlatLabel>(box, std::move(text), st::aboutLabel),
"version of Telegram Desktop was copied to the clipboard."), st::boxRowPadding);
Ui::LayerOption::CloseOther); label->setLinksTrusted();
} else { Ui::AddSkip(layout, st::aboutSkip);
File::OpenUrl(Core::App().changelogLink()); };
}
}
void AboutBox::keyPressEvent(QKeyEvent *e) { addText(Text1());
if (e->key() == Qt::Key_Enter || e->key() == Qt::Key_Return) { addText(Text2());
closeBox(); addText(Text3());
} else {
BoxContent::keyPressEvent(e); 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(