Implement new settings design with icons etc.
After Width: | Height: | Size: 248 B |
After Width: | Height: | Size: 393 B |
After Width: | Height: | Size: 318 B |
After Width: | Height: | Size: 647 B |
After Width: | Height: | Size: 715 B |
After Width: | Height: | Size: 1.7 KiB |
After Width: | Height: | Size: 290 B |
After Width: | Height: | Size: 566 B |
After Width: | Height: | Size: 589 B |
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 541 B |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 382 B |
After Width: | Height: | Size: 729 B |
After Width: | Height: | Size: 586 B |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 431 B |
After Width: | Height: | Size: 930 B |
After Width: | Height: | Size: 715 B |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 391 B |
After Width: | Height: | Size: 770 B |
After Width: | Height: | Size: 408 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 992 B |
After Width: | Height: | Size: 2.8 KiB |
|
@ -156,8 +156,13 @@ infoTopBarCall: IconButton(infoTopBarNotifications) {
|
||||||
iconOver: icon {{ "top_bar_call", boxTitleCloseFgOver }};
|
iconOver: icon {{ "top_bar_call", boxTitleCloseFgOver }};
|
||||||
}
|
}
|
||||||
infoTopBarSave: IconButton(infoTopBarNotifications) {
|
infoTopBarSave: IconButton(infoTopBarNotifications) {
|
||||||
|
width: 48px;
|
||||||
icon: icon {{ "passport_ready", windowActiveTextFg }};
|
icon: icon {{ "passport_ready", windowActiveTextFg }};
|
||||||
iconOver: icon {{ "passport_ready", windowActiveTextFg}};
|
iconOver: icon {{ "passport_ready", windowActiveTextFg }};
|
||||||
|
iconPosition: point(11px, 17px);
|
||||||
|
ripple: RippleAnimation(defaultRippleAnimation) {
|
||||||
|
color: lightButtonBgOver;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
infoTopBarForward: IconButton(infoTopBarBack) {
|
infoTopBarForward: IconButton(infoTopBarBack) {
|
||||||
width: 46px;
|
width: 46px;
|
||||||
|
@ -229,6 +234,10 @@ infoLayerTopBarCall: IconButton(infoLayerTopBarNotifications) {
|
||||||
infoLayerTopBarSave: IconButton(infoLayerTopBarNotifications) {
|
infoLayerTopBarSave: IconButton(infoLayerTopBarNotifications) {
|
||||||
icon: icon {{ "passport_ready", windowActiveTextFg }};
|
icon: icon {{ "passport_ready", windowActiveTextFg }};
|
||||||
iconOver: icon {{ "passport_ready", windowActiveTextFg }};
|
iconOver: icon {{ "passport_ready", windowActiveTextFg }};
|
||||||
|
iconPosition: point(13px, 18px);
|
||||||
|
ripple: RippleAnimation(defaultRippleAnimation) {
|
||||||
|
color: lightButtonBgOver;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
infoLayerTopBarForward: IconButton(infoLayerTopBarBack) {
|
infoLayerTopBarForward: IconButton(infoLayerTopBarBack) {
|
||||||
width: 45px;
|
width: 45px;
|
||||||
|
|
|
@ -19,7 +19,6 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "window/main_window.h"
|
#include "window/main_window.h"
|
||||||
#include "auth_session.h"
|
#include "auth_session.h"
|
||||||
#include "styles/style_info.h"
|
#include "styles/style_info.h"
|
||||||
#include "styles/style_old_settings.h"
|
|
||||||
#include "styles/style_window.h"
|
#include "styles/style_window.h"
|
||||||
#include "styles/style_boxes.h"
|
#include "styles/style_boxes.h"
|
||||||
|
|
||||||
|
|
|
@ -10,47 +10,67 @@ using "ui/widgets/widgets.style";
|
||||||
using "info/info.style";
|
using "info/info.style";
|
||||||
using "boxes/boxes.style";
|
using "boxes/boxes.style";
|
||||||
|
|
||||||
|
settingsFirstDividerSkip: 3px;
|
||||||
settingsSectionButton: InfoProfileButton(infoProfileButton) {
|
settingsSectionButton: InfoProfileButton(infoProfileButton) {
|
||||||
font: boxTextFont;
|
font: boxTextFont;
|
||||||
|
padding: margins(79px, 13px, 22px, 11px);
|
||||||
}
|
}
|
||||||
settingsGeneralButton: InfoProfileButton(settingsSectionButton) {
|
settingsGeneralButton: InfoProfileButton(settingsSectionButton) {
|
||||||
padding: margins(28px, 10px, 22px, 8px);
|
padding: margins(24px, 13px, 22px, 11px);
|
||||||
}
|
}
|
||||||
settingsButton: InfoProfileButton(settingsSectionButton) {
|
settingsButton: InfoProfileButton(settingsSectionButton) {
|
||||||
padding: margins(22px, 10px, 22px, 8px);
|
padding: margins(22px, 13px, 22px, 11px);
|
||||||
}
|
}
|
||||||
settingsSectionSkip: infoProfileSkip;
|
settingsSectionSkip: 9px;
|
||||||
|
settingsSectionIconPosition: point(22px, 9px);
|
||||||
settingsSeparatorPadding: margins(22px, infoProfileSkip, 0px, infoProfileSkip);
|
settingsSeparatorPadding: margins(22px, infoProfileSkip, 0px, infoProfileSkip);
|
||||||
settingsButtonRightPosition: point(28px, 10px);
|
settingsButtonRightPosition: point(28px, 13px);
|
||||||
settingsButtonRight: FlatLabel(defaultFlatLabel) {
|
settingsButtonRight: FlatLabel(defaultFlatLabel) {
|
||||||
textFg: windowActiveTextFg;
|
textFg: windowActiveTextFg;
|
||||||
style: boxTextStyle;
|
style: boxTextStyle;
|
||||||
}
|
}
|
||||||
settingsScalePadding: margins(79px, 10px, 28px, 8px);
|
settingsScalePadding: margins(79px, 10px, 28px, 8px);
|
||||||
settingsSlider: SettingsSlider(defaultSettingsSlider) {
|
settingsSlider: SettingsSlider(defaultSettingsSlider) {
|
||||||
|
barFg: windowBgOver;
|
||||||
labelFg: windowSubTextFg;
|
labelFg: windowSubTextFg;
|
||||||
labelFgActive: windowActiveTextFg;
|
labelFgActive: windowActiveTextFg;
|
||||||
}
|
}
|
||||||
settingsUpdateToggle: InfoProfileButton(settingsButton) {
|
settingsUpdateToggle: InfoProfileButton(settingsGeneralButton) {
|
||||||
height: 38px;
|
height: 40px;
|
||||||
|
padding: margins(24px, 8px, 22px, 8px);
|
||||||
}
|
}
|
||||||
settingsUpdateState: FlatLabel(defaultFlatLabel) {
|
settingsUpdateState: FlatLabel(defaultFlatLabel) {
|
||||||
textFg: windowSubTextFg;
|
textFg: windowSubTextFg;
|
||||||
}
|
}
|
||||||
settingsUpdate: InfoProfileButton(infoMainButton, settingsButton) {
|
settingsUpdate: InfoProfileButton(infoMainButton, settingsButton) {
|
||||||
}
|
}
|
||||||
settingsUpdateStatePosition: point(28px, 30px);
|
settingsUpdateStatePosition: point(24px, 29px);
|
||||||
settingsDividerLabelPadding: margins(22px, 7px, 22px, 14px);
|
settingsDividerLabelPadding: margins(22px, 10px, 22px, 19px);
|
||||||
|
|
||||||
settingsSendType: defaultBoxCheckbox;
|
settingsIconSetPhoto: icon {{ "settings_set_photo", menuIconFg }};
|
||||||
settingsSendTypePadding: margins(22px, 5px, 10px, 5px);
|
settingsIconInformation: icon {{ "settings_information", menuIconFg }};
|
||||||
settingsSendTypeSkip: 5px;
|
settingsIconNotifications: icon {{ "settings_notifications", menuIconFg }};
|
||||||
|
settingsIconChat: icon {{ "settings_chat", menuIconFg }};
|
||||||
|
settingsIconGeneral: icon {{ "settings_general", menuIconFg }};
|
||||||
|
settingsIconPrivacySecurity: icon {{ "settings_privacy_security", menuIconFg }};
|
||||||
|
settingsIconLanguage: icon {{ "settings_language", menuIconFg }};
|
||||||
|
settingsIconInterfaceScale: icon {{ "settings_interface_scale", menuIconFg }};
|
||||||
|
settingsIconFaq: icon {{ "settings_faq", menuIconFg }};
|
||||||
|
|
||||||
settingsCheckbox: defaultBoxCheckbox;
|
settingsSetPhotoSkip: 7px;
|
||||||
|
|
||||||
|
settingsCheckbox: Checkbox(defaultBoxCheckbox) {
|
||||||
|
textPosition: point(15px, 1px);
|
||||||
|
}
|
||||||
settingsCheckboxPadding: margins(22px, 10px, 10px, 10px);
|
settingsCheckboxPadding: margins(22px, 10px, 10px, 10px);
|
||||||
settingsLink: boxLinkButton;
|
settingsLink: boxLinkButton;
|
||||||
settingsAdvancedNotificationsPadding: margins(22px, 20px, 10px, 10px);
|
settingsAdvancedNotificationsPadding: margins(22px, 20px, 10px, 10px);
|
||||||
settingsLinkLabel: defaultFlatLabel;
|
settingsLinkLabel: defaultFlatLabel;
|
||||||
|
settingsCheckboxesSkip: 12px;
|
||||||
|
|
||||||
|
settingsSendType: settingsCheckbox;
|
||||||
|
settingsSendTypePadding: margins(22px, 5px, 10px, 5px);
|
||||||
|
settingsSendTypeSkip: 5px;
|
||||||
|
|
||||||
settingsAskPathPadding: margins(22px, 10px, 10px, 0px);
|
settingsAskPathPadding: margins(22px, 10px, 10px, 0px);
|
||||||
settingsDownloadPathPadding: margins(22px, 1px, 10px, 0px);
|
settingsDownloadPathPadding: margins(22px, 1px, 10px, 0px);
|
||||||
|
@ -65,10 +85,12 @@ settingsSubsectionTitle: FlatLabel(defaultFlatLabel) {
|
||||||
}
|
}
|
||||||
textFg: windowActiveTextFg;
|
textFg: windowActiveTextFg;
|
||||||
}
|
}
|
||||||
settingsSubsectionTitlePadding: margins(22px, 7px, 10px, 9px);
|
settingsSubsectionTitlePadding: margins(22px, 7px, 10px, 6px);
|
||||||
settingsBackgroundPadding: margins(22px, 8px, 10px, 8px);
|
settingsBackgroundPadding: margins(22px, 11px, 10px, 12px);
|
||||||
|
settingsTileSkip: 15px;
|
||||||
settingsFromGalleryTop: 2px;
|
settingsFromGalleryTop: 2px;
|
||||||
settingsFromFileTop: 14px;
|
settingsFromFileTop: 14px;
|
||||||
|
settingsPrivacySecurityPadding: 12px;
|
||||||
|
|
||||||
settingsCloudPasswordLabel: FlatLabel(defaultFlatLabel) {
|
settingsCloudPasswordLabel: FlatLabel(defaultFlatLabel) {
|
||||||
textFg: windowSubTextFg;
|
textFg: windowSubTextFg;
|
||||||
|
@ -78,7 +100,7 @@ settingsCloudPasswordLabel: FlatLabel(defaultFlatLabel) {
|
||||||
settingsCloudPasswordLabelPadding: margins(22px, 8px, 10px, 8px);
|
settingsCloudPasswordLabelPadding: margins(22px, 8px, 10px, 8px);
|
||||||
|
|
||||||
settingsInfoRowHeight: 62px;
|
settingsInfoRowHeight: 62px;
|
||||||
settingsInfoIconPosition: point(24px, 16px);
|
settingsInfoIconPosition: point(22px, 18px);
|
||||||
settingsInfoValue: FlatLabel(defaultFlatLabel) {
|
settingsInfoValue: FlatLabel(defaultFlatLabel) {
|
||||||
textFg: windowFg;
|
textFg: windowFg;
|
||||||
style: boxTextStyle;
|
style: boxTextStyle;
|
||||||
|
@ -89,13 +111,47 @@ settingsInfoAbout: FlatLabel(settingsInfoValue) {
|
||||||
textFg: windowSubTextFg;
|
textFg: windowSubTextFg;
|
||||||
style: defaultTextStyle;
|
style: defaultTextStyle;
|
||||||
}
|
}
|
||||||
settingsInfoAboutPosition: point(78px, 33px);
|
settingsInfoAboutPosition: point(78px, 34px);
|
||||||
settingsInfoRightSkip: 60px;
|
settingsInfoRightSkip: 60px;
|
||||||
settingsInfoEditPosition: point(12px, 12px);
|
settingsInfoEditPosition: point(0px, 6px);
|
||||||
settingsInfoEdit: IconButton(defaultIconButton) {
|
settingsInfoEdit: IconButton(defaultIconButton) {
|
||||||
}
|
width: 56px;
|
||||||
|
height: 56px;
|
||||||
|
|
||||||
settingsBioMargins: margins(20px, 2px, 20px, 2px);
|
icon: icon {{ "settings_edit", menuIconFg }};
|
||||||
|
iconOver: icon {{ "settings_edit", menuIconFgOver }};
|
||||||
|
iconPosition: point(14px, 14px);
|
||||||
|
|
||||||
|
rippleAreaPosition: point(8px, 8px);
|
||||||
|
rippleAreaSize: 40px;
|
||||||
|
ripple: RippleAnimation(defaultRippleAnimation) {
|
||||||
|
color: windowBgOver;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
settingsBio: InputField(defaultInputField) {
|
||||||
|
textBg: transparent;
|
||||||
|
textMargins: margins(2px, 7px, 2px, 0px);
|
||||||
|
|
||||||
|
placeholderFg: placeholderFg;
|
||||||
|
placeholderFgActive: placeholderFgActive;
|
||||||
|
placeholderFgError: placeholderFgActive;
|
||||||
|
placeholderMargins: margins(2px, 0px, 2px, 0px);
|
||||||
|
placeholderScale: 0.;
|
||||||
|
placeholderFont: normalFont;
|
||||||
|
|
||||||
|
border: 0px;
|
||||||
|
borderActive: 0px;
|
||||||
|
|
||||||
|
heightMin: 32px;
|
||||||
|
|
||||||
|
font: boxTextFont;
|
||||||
|
}
|
||||||
|
settingsInfoAfterSkip: 14px;
|
||||||
|
settingsInfoName: icon {{ "settings_name", menuIconFg }};
|
||||||
|
settingsInfoPhone: icon {{ "settings_phone_number", menuIconFg }};
|
||||||
|
settingsInfoUsername: icon {{ "settings_username", menuIconFg }};
|
||||||
|
|
||||||
|
settingsBioMargins: margins(20px, 6px, 20px, 6px);
|
||||||
settingsBioCountdown: FlatLabel(defaultFlatLabel) {
|
settingsBioCountdown: FlatLabel(defaultFlatLabel) {
|
||||||
style: boxTextStyle;
|
style: boxTextStyle;
|
||||||
textFg: windowSubTextFg;
|
textFg: windowSubTextFg;
|
||||||
|
|
|
@ -372,7 +372,7 @@ void DownloadPathRow::setupControls() {
|
||||||
|
|
||||||
void SetupChatOptions(not_null<Ui::VerticalLayout*> container) {
|
void SetupChatOptions(not_null<Ui::VerticalLayout*> container) {
|
||||||
AddDivider(container);
|
AddDivider(container);
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsCheckboxesSkip);
|
||||||
|
|
||||||
auto wrap = object_ptr<Ui::VerticalLayout>(container);
|
auto wrap = object_ptr<Ui::VerticalLayout>(container);
|
||||||
const auto inner = wrap.data();
|
const auto inner = wrap.data();
|
||||||
|
@ -468,13 +468,13 @@ void SetupChatOptions(not_null<Ui::VerticalLayout*> container) {
|
||||||
|
|
||||||
}, inner->lifetime());
|
}, inner->lifetime());
|
||||||
|
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsCheckboxesSkip);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetupSendKey(not_null<Ui::VerticalLayout*> container) {
|
void SetupSendKey(not_null<Ui::VerticalLayout*> container) {
|
||||||
AddDivider(container);
|
AddDivider(container);
|
||||||
const auto skip = st::settingsSendTypeSkip;
|
const auto skip = st::settingsSendTypeSkip;
|
||||||
const auto full = st::settingsSectionSkip + skip;
|
const auto full = st::settingsCheckboxesSkip + skip;
|
||||||
AddSkip(container, full);
|
AddSkip(container, full);
|
||||||
|
|
||||||
enum class SendByType {
|
enum class SendByType {
|
||||||
|
@ -553,7 +553,7 @@ void SetupMediaOptions(not_null<Ui::VerticalLayout*> container) {
|
||||||
|
|
||||||
void SetupChatBackground(not_null<Ui::VerticalLayout*> container) {
|
void SetupChatBackground(not_null<Ui::VerticalLayout*> container) {
|
||||||
AddDivider(container);
|
AddDivider(container);
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsCheckboxesSkip);
|
||||||
|
|
||||||
AddSubsectionTitle(container, lng_settings_section_background);
|
AddSubsectionTitle(container, lng_settings_section_background);
|
||||||
|
|
||||||
|
@ -571,7 +571,7 @@ void SetupChatBackground(not_null<Ui::VerticalLayout*> container) {
|
||||||
std::move(wrap),
|
std::move(wrap),
|
||||||
QMargins(0, skipTop, 0, skipBottom)));
|
QMargins(0, skipTop, 0, skipBottom)));
|
||||||
|
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsTileSkip);
|
||||||
|
|
||||||
const auto tile = inner->add(
|
const auto tile = inner->add(
|
||||||
object_ptr<Ui::Checkbox>(
|
object_ptr<Ui::Checkbox>(
|
||||||
|
@ -693,6 +693,7 @@ Chat::Chat(QWidget *parent, not_null<UserData*> self)
|
||||||
void Chat::setupContent() {
|
void Chat::setupContent() {
|
||||||
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
||||||
|
|
||||||
|
AddSkip(content, st::settingsFirstDividerSkip);
|
||||||
SetupChatOptions(content);
|
SetupChatOptions(content);
|
||||||
SetupSendKey(content);
|
SetupSendKey(content);
|
||||||
SetupMediaOptions(content);
|
SetupMediaOptions(content);
|
||||||
|
|
|
@ -76,11 +76,35 @@ void AddDividerText(
|
||||||
not_null<Button*> AddButton(
|
not_null<Button*> AddButton(
|
||||||
not_null<Ui::VerticalLayout*> container,
|
not_null<Ui::VerticalLayout*> container,
|
||||||
LangKey text,
|
LangKey text,
|
||||||
const style::InfoProfileButton &st) {
|
const style::InfoProfileButton &st,
|
||||||
return container->add(object_ptr<Button>(
|
const style::icon *leftIcon) {
|
||||||
|
const auto result = container->add(object_ptr<Button>(
|
||||||
container,
|
container,
|
||||||
Lang::Viewer(text),
|
Lang::Viewer(text),
|
||||||
st));
|
st));
|
||||||
|
if (leftIcon) {
|
||||||
|
const auto icon = Ui::CreateChild<Ui::RpWidget>(result);
|
||||||
|
icon->setAttribute(Qt::WA_TransparentForMouseEvents);
|
||||||
|
icon->resize(leftIcon->size());
|
||||||
|
result->widthValue(
|
||||||
|
) | rpl::start_with_next([=](int width) {
|
||||||
|
icon->moveToLeft(
|
||||||
|
st::settingsSectionIconPosition.x(),
|
||||||
|
st::settingsSectionIconPosition.y(),
|
||||||
|
width);
|
||||||
|
}, icon->lifetime());
|
||||||
|
icon->paintRequest(
|
||||||
|
) | rpl::start_with_next([=] {
|
||||||
|
Painter p(icon);
|
||||||
|
const auto width = icon->width();
|
||||||
|
if (result->isOver()) {
|
||||||
|
leftIcon->paint(p, QPoint(), width, st::menuIconFgOver->c);
|
||||||
|
} else {
|
||||||
|
leftIcon->paint(p, QPoint(), width);
|
||||||
|
}
|
||||||
|
}, icon->lifetime());
|
||||||
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CreateRightLabel(
|
void CreateRightLabel(
|
||||||
|
@ -105,8 +129,9 @@ not_null<Button*> AddButtonWithLabel(
|
||||||
not_null<Ui::VerticalLayout*> container,
|
not_null<Ui::VerticalLayout*> container,
|
||||||
LangKey text,
|
LangKey text,
|
||||||
rpl::producer<QString> label,
|
rpl::producer<QString> label,
|
||||||
const style::InfoProfileButton &st) {
|
const style::InfoProfileButton &st,
|
||||||
const auto button = AddButton(container, text, st);
|
const style::icon *leftIcon) {
|
||||||
|
const auto button = AddButton(container, text, st, leftIcon);
|
||||||
CreateRightLabel(button, std::move(label));
|
CreateRightLabel(button, std::move(label));
|
||||||
return button;
|
return button;
|
||||||
}
|
}
|
||||||
|
|
|
@ -73,12 +73,14 @@ void AddDividerText(
|
||||||
not_null<Button*> AddButton(
|
not_null<Button*> AddButton(
|
||||||
not_null<Ui::VerticalLayout*> container,
|
not_null<Ui::VerticalLayout*> container,
|
||||||
LangKey text,
|
LangKey text,
|
||||||
const style::InfoProfileButton &st);
|
const style::InfoProfileButton &st,
|
||||||
|
const style::icon *leftIcon = nullptr);
|
||||||
not_null<Button*> AddButtonWithLabel(
|
not_null<Button*> AddButtonWithLabel(
|
||||||
not_null<Ui::VerticalLayout*> container,
|
not_null<Ui::VerticalLayout*> container,
|
||||||
LangKey text,
|
LangKey text,
|
||||||
rpl::producer<QString> label,
|
rpl::producer<QString> label,
|
||||||
const style::InfoProfileButton &st);
|
const style::InfoProfileButton &st,
|
||||||
|
const style::icon *leftIcon = nullptr);
|
||||||
void CreateRightLabel(
|
void CreateRightLabel(
|
||||||
not_null<Button*> button,
|
not_null<Button*> button,
|
||||||
rpl::producer<QString> label);
|
rpl::producer<QString> label);
|
||||||
|
|
|
@ -384,6 +384,7 @@ General::General(QWidget *parent, UserData *self)
|
||||||
void General::setupContent() {
|
void General::setupContent() {
|
||||||
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
||||||
|
|
||||||
|
AddSkip(content, st::settingsFirstDividerSkip);
|
||||||
SetupUpdate(content);
|
SetupUpdate(content);
|
||||||
SetupTray(content);
|
SetupTray(content);
|
||||||
SetupStorageAndConnection(content);
|
SetupStorageAndConnection(content);
|
||||||
|
|
|
@ -21,7 +21,6 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "auth_session.h"
|
#include "auth_session.h"
|
||||||
#include "apiwrap.h"
|
#include "apiwrap.h"
|
||||||
#include "styles/style_settings.h"
|
#include "styles/style_settings.h"
|
||||||
#include "styles/style_old_settings.h"
|
|
||||||
|
|
||||||
namespace Settings {
|
namespace Settings {
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -110,18 +109,18 @@ void SetupRows(
|
||||||
Lang::Viewer(lng_settings_name_label),
|
Lang::Viewer(lng_settings_name_label),
|
||||||
Info::Profile::NameValue(self),
|
Info::Profile::NameValue(self),
|
||||||
lang(lng_profile_copy_fullname),
|
lang(lng_profile_copy_fullname),
|
||||||
st::settingsEditButton,
|
st::settingsInfoEdit,
|
||||||
[=] { Ui::show(Box<EditNameBox>(self)); },
|
[=] { Ui::show(Box<EditNameBox>(self)); },
|
||||||
st::settingsEditButton.icon);
|
st::settingsInfoName);
|
||||||
|
|
||||||
AddRow(
|
AddRow(
|
||||||
container,
|
container,
|
||||||
Lang::Viewer(lng_settings_phone_label),
|
Lang::Viewer(lng_settings_phone_label),
|
||||||
Info::Profile::PhoneValue(self),
|
Info::Profile::PhoneValue(self),
|
||||||
lang(lng_profile_copy_phone),
|
lang(lng_profile_copy_phone),
|
||||||
st::settingsEditButton,
|
st::settingsInfoEdit,
|
||||||
[] { Ui::show(Box<ChangePhoneBox>()); },
|
[] { Ui::show(Box<ChangePhoneBox>()); },
|
||||||
st::settingsEditButton.icon);
|
st::settingsInfoPhone);
|
||||||
|
|
||||||
auto username = Info::Profile::UsernameValue(self);
|
auto username = Info::Profile::UsernameValue(self);
|
||||||
auto empty = base::duplicate(
|
auto empty = base::duplicate(
|
||||||
|
@ -155,11 +154,11 @@ void SetupRows(
|
||||||
std::move(label),
|
std::move(label),
|
||||||
std::move(value),
|
std::move(value),
|
||||||
lang(lng_context_copy_mention),
|
lang(lng_context_copy_mention),
|
||||||
st::settingsEditButton,
|
st::settingsInfoEdit,
|
||||||
[=] { Ui::show(Box<UsernameBox>()); },
|
[=] { Ui::show(Box<UsernameBox>()); },
|
||||||
st::settingsEditButton.icon);
|
st::settingsInfoUsername);
|
||||||
|
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsInfoAfterSkip);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct BioManager {
|
struct BioManager {
|
||||||
|
@ -174,7 +173,10 @@ BioManager SetupBio(
|
||||||
AddSkip(container);
|
AddSkip(container);
|
||||||
|
|
||||||
const auto bioStyle = [] {
|
const auto bioStyle = [] {
|
||||||
auto result = CreateBioFieldStyle();
|
auto result = st::settingsBio;
|
||||||
|
result.textMargins.setRight(
|
||||||
|
st::boxTextFont->spacew
|
||||||
|
+ st::boxTextFont->width(QString::number(kMaxBioLength)));
|
||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
const auto style = Ui::AttachAsChild(container, bioStyle());
|
const auto style = Ui::AttachAsChild(container, bioStyle());
|
||||||
|
@ -273,6 +275,7 @@ void Information::sectionSaveChanges(FnMut<void()> done) {
|
||||||
void Information::setupContent() {
|
void Information::setupContent() {
|
||||||
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
||||||
|
|
||||||
|
AddSkip(content, st::settingsFirstDividerSkip);
|
||||||
SetupRows(content, _self);
|
SetupRows(content, _self);
|
||||||
auto manager = SetupBio(content, _self);
|
auto manager = SetupBio(content, _self);
|
||||||
_canSaveChanges = std::move(manager.canSave);
|
_canSaveChanges = std::move(manager.canSave);
|
||||||
|
|
|
@ -32,7 +32,7 @@ void SetupUploadPhotoButton(
|
||||||
not_null<Ui::VerticalLayout*> container,
|
not_null<Ui::VerticalLayout*> container,
|
||||||
not_null<UserData*> self) {
|
not_null<UserData*> self) {
|
||||||
AddDivider(container);
|
AddDivider(container);
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsSetPhotoSkip);
|
||||||
|
|
||||||
const auto upload = [=] {
|
const auto upload = [=] {
|
||||||
const auto imageExtensions = cImgExtensions();
|
const auto imageExtensions = cImgExtensions();
|
||||||
|
@ -70,13 +70,14 @@ void SetupUploadPhotoButton(
|
||||||
AddButton(
|
AddButton(
|
||||||
container,
|
container,
|
||||||
lng_settings_upload,
|
lng_settings_upload,
|
||||||
st::settingsSectionButton
|
st::settingsSectionButton,
|
||||||
|
&st::settingsIconSetPhoto
|
||||||
)->addClickHandler(App::LambdaDelayed(
|
)->addClickHandler(App::LambdaDelayed(
|
||||||
st::settingsSectionButton.ripple.hideDuration,
|
st::settingsSectionButton.ripple.hideDuration,
|
||||||
container,
|
container,
|
||||||
upload));
|
upload));
|
||||||
|
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsSetPhotoSkip);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetupLanguageButton(not_null<Ui::VerticalLayout*> container) {
|
void SetupLanguageButton(not_null<Ui::VerticalLayout*> container) {
|
||||||
|
@ -84,7 +85,8 @@ void SetupLanguageButton(not_null<Ui::VerticalLayout*> container) {
|
||||||
container,
|
container,
|
||||||
lng_settings_language,
|
lng_settings_language,
|
||||||
Lang::Viewer(lng_language_name),
|
Lang::Viewer(lng_language_name),
|
||||||
st::settingsSectionButton);
|
st::settingsSectionButton,
|
||||||
|
&st::settingsIconLanguage);
|
||||||
const auto guard = Ui::AttachAsChild(button, base::binary_guard());
|
const auto guard = Ui::AttachAsChild(button, base::binary_guard());
|
||||||
button->addClickHandler([=] {
|
button->addClickHandler([=] {
|
||||||
*guard = LanguageBox::Show();
|
*guard = LanguageBox::Show();
|
||||||
|
@ -97,18 +99,37 @@ void SetupSections(
|
||||||
AddDivider(container);
|
AddDivider(container);
|
||||||
AddSkip(container);
|
AddSkip(container);
|
||||||
|
|
||||||
const auto addSection = [&](LangKey label, Type type) {
|
const auto addSection = [&](
|
||||||
|
LangKey label,
|
||||||
|
Type type,
|
||||||
|
const style::icon *icon) {
|
||||||
AddButton(
|
AddButton(
|
||||||
container,
|
container,
|
||||||
label,
|
label,
|
||||||
st::settingsSectionButton
|
st::settingsSectionButton,
|
||||||
|
icon
|
||||||
)->addClickHandler([=] { showOther(type); });
|
)->addClickHandler([=] { showOther(type); });
|
||||||
};
|
};
|
||||||
addSection(lng_settings_section_info, Type::Information);
|
addSection(
|
||||||
addSection(lng_settings_section_notify, Type::Notifications);
|
lng_settings_section_info,
|
||||||
addSection(lng_settings_section_privacy, Type::PrivacySecurity);
|
Type::Information,
|
||||||
addSection(lng_settings_section_general, Type::General);
|
&st::settingsIconInformation);
|
||||||
addSection(lng_settings_section_chat_settings, Type::Chat);
|
addSection(
|
||||||
|
lng_settings_section_notify,
|
||||||
|
Type::Notifications,
|
||||||
|
&st::settingsIconNotifications);
|
||||||
|
addSection(
|
||||||
|
lng_settings_section_privacy,
|
||||||
|
Type::PrivacySecurity,
|
||||||
|
&st::settingsIconPrivacySecurity);
|
||||||
|
addSection(
|
||||||
|
lng_settings_section_general,
|
||||||
|
Type::General,
|
||||||
|
&st::settingsIconGeneral);
|
||||||
|
addSection(
|
||||||
|
lng_settings_section_chat_settings,
|
||||||
|
Type::Chat,
|
||||||
|
&st::settingsIconChat);
|
||||||
|
|
||||||
SetupLanguageButton(container);
|
SetupLanguageButton(container);
|
||||||
|
|
||||||
|
@ -131,7 +152,8 @@ void SetupInterfaceScale(not_null<Ui::VerticalLayout*> container) {
|
||||||
const auto button = AddButton(
|
const auto button = AddButton(
|
||||||
container,
|
container,
|
||||||
lng_settings_default_scale,
|
lng_settings_default_scale,
|
||||||
st::settingsSectionButton
|
st::settingsSectionButton,
|
||||||
|
&st::settingsIconInterfaceScale
|
||||||
)->toggleOn(toggled->events_starting_with_copy(switched));
|
)->toggleOn(toggled->events_starting_with_copy(switched));
|
||||||
|
|
||||||
const auto slider = container->add(
|
const auto slider = container->add(
|
||||||
|
@ -234,7 +256,8 @@ void SetupHelp(not_null<Ui::VerticalLayout*> container) {
|
||||||
AddButton(
|
AddButton(
|
||||||
container,
|
container,
|
||||||
lng_settings_faq,
|
lng_settings_faq,
|
||||||
st::settingsSectionButton
|
st::settingsSectionButton,
|
||||||
|
&st::settingsIconFaq
|
||||||
)->addClickHandler([] {
|
)->addClickHandler([] {
|
||||||
QDesktopServices::openUrl(telegramFaqLink());
|
QDesktopServices::openUrl(telegramFaqLink());
|
||||||
});
|
});
|
||||||
|
|
|
@ -203,7 +203,7 @@ void SetupNotificationsContent(not_null<Ui::VerticalLayout*> container) {
|
||||||
|
|
||||||
void SetupNotifications(not_null<Ui::VerticalLayout*> container) {
|
void SetupNotifications(not_null<Ui::VerticalLayout*> container) {
|
||||||
AddDivider(container);
|
AddDivider(container);
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsCheckboxesSkip);
|
||||||
|
|
||||||
auto wrap = object_ptr<Ui::VerticalLayout>(container);
|
auto wrap = object_ptr<Ui::VerticalLayout>(container);
|
||||||
SetupNotificationsContent(wrap.data());
|
SetupNotificationsContent(wrap.data());
|
||||||
|
@ -212,7 +212,7 @@ void SetupNotifications(not_null<Ui::VerticalLayout*> container) {
|
||||||
container,
|
container,
|
||||||
std::move(wrap)));
|
std::move(wrap)));
|
||||||
|
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsCheckboxesSkip);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
@ -226,6 +226,7 @@ Notifications::Notifications(QWidget *parent, not_null<UserData*> self)
|
||||||
void Notifications::setupContent() {
|
void Notifications::setupContent() {
|
||||||
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
||||||
|
|
||||||
|
AddSkip(content, st::settingsFirstDividerSkip);
|
||||||
SetupNotifications(content);
|
SetupNotifications(content);
|
||||||
|
|
||||||
Ui::ResizeFitChild(this, content);
|
Ui::ResizeFitChild(this, content);
|
||||||
|
|
|
@ -90,7 +90,7 @@ void SetupPrivacy(not_null<Ui::VerticalLayout*> container) {
|
||||||
std::make_unique<OldSettings::GroupsInvitePrivacyController>()));
|
std::make_unique<OldSettings::GroupsInvitePrivacyController>()));
|
||||||
});
|
});
|
||||||
|
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsPrivacySecurityPadding);
|
||||||
AddDividerText(
|
AddDividerText(
|
||||||
container,
|
container,
|
||||||
Lang::Viewer(lng_settings_group_privacy_about));
|
Lang::Viewer(lng_settings_group_privacy_about));
|
||||||
|
@ -378,7 +378,7 @@ void SetupSecurity(not_null<Ui::VerticalLayout*> container) {
|
||||||
SetupSelfDestruction(container);
|
SetupSelfDestruction(container);
|
||||||
SetupSessionsList(container);
|
SetupSessionsList(container);
|
||||||
|
|
||||||
AddSkip(container);
|
AddSkip(container, st::settingsPrivacySecurityPadding);
|
||||||
AddDividerText(
|
AddDividerText(
|
||||||
container,
|
container,
|
||||||
Lang::Viewer(lng_settings_sessions_about));
|
Lang::Viewer(lng_settings_sessions_about));
|
||||||
|
@ -413,6 +413,7 @@ PrivacySecurity::PrivacySecurity(QWidget *parent, not_null<UserData*> self)
|
||||||
void PrivacySecurity::setupContent() {
|
void PrivacySecurity::setupContent() {
|
||||||
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
const auto content = Ui::CreateChild<Ui::VerticalLayout>(this);
|
||||||
|
|
||||||
|
AddSkip(content, st::settingsFirstDividerSkip);
|
||||||
SetupPrivacy(content);
|
SetupPrivacy(content);
|
||||||
SetupSecurity(content);
|
SetupSecurity(content);
|
||||||
SetupExport(content);
|
SetupExport(content);
|
||||||
|
|