mirror of
https://github.com/telegramdesktop/tdesktop
synced 2025-02-25 10:01:00 +00:00
The following are commits related to removed variables. apiwrap.cppe050e27
: kSaveDraftBeforeQuitTimeout app.cpp113f665
: serviceImageCacheSize boxes/auto_download_box.cppa0c6104
: checked(Source source, Type type) boxes/background_preview_box.cppb6edf45
: resultBytesPerPixelfe21b5a
: ms boxes/calendar_box.cppae97704
: yearIndex, monthIndex99bb093
: ms boxes/connection_box.cppf794d8d
: ping boxes/dictionaries_manager.cpp8353867
: session boxes/peer_list_box.cpp2ce2a14
: grayedWidth boxes/peers/add_participants_box.cpp07e010d
: chat, channel boxes/self_destruction_box.cppfe9f02e
: count chat_helpers/emoji_suggestions_widget.cppa12bc60
: is(QLatin1String string) chat_helpers/field_autocomplete.cpp8c7a35c
: atwidth, hashwidth chat_helpers/gifs_list_widget.cppff65734
: inlineItems3d846fc
: newSelectedd1687ab
: kSaveDraftBeforeQuitTimeout chat_helpers/stickers_dice_pack.cppc83e297
: kZeroDiceDocumentId chat_helpers/stickers_emoji_pack.cppd298953
: length chat_helpers/stickers_list_widget.cppeb75859
: index, x core/crash_reports.cpp5940ae6
: LaunchedDateTimeStr, LaunchedBinaryName data/data_changes.cpp 3c4e959:clearRealtime data/data_cloud_file.cpp4b354b0
: fromCloud, cacheTag data/data_document_media.cpp7db5359
: kMaxVideoFrameArea data/data_messages.cpp794e315
: wasCount data/data_photo_media.cppe27d2bc
: index data/data_wall_paper.cppb6edf45
: resultBytesPerPixel data/data_types.cppaa8f62d
: kWebDocumentCacheTag, kStorageCacheMask history/admin_log/history_admin_log_inner.cpp794e315
: canDelete, canForward history/history_location_manager.cpp60f45ab
: kCoordPrecision9f90d3a
: kMaxHttpRedirects history/history_message.cppcedf8a6
: kPinnedMessageTextLimit history/history_widget.cppb305924
: serviceColorefa5fc4
: hasForward5e7aa4f
: kTabbedSelectorToggleTooltipTimeoutMs, kTabbedSelectorToggleTooltipCount history/view/history_view_context_menu.cppfe1a90b
: isVideoLink, isVoiceLink, isAudioLink settings.cppe2f54eb
: defaultRecent settings/settings_folders.cppe8bf5bb
: kRefreshSuggestedTimeout ui/filter_icon_panel.cppc4a0bc1
: kDelayedHideTimeoutMs window/themes/window_theme_preview.cppef927c8
: mutedCounter ----- Modified variables boxes/stickers_box.cpp554eb3a
: _rows[pressedIndex] -> set data/data_notify_settings.cpp734c410
: muteForSeconds -> muteUntil history/view/history_view_list_widget.cpp07528be
: _items[index] -> viewe5f3bed
: fromState, tillState history/history.cppcd3c1c6
: kStatusShowClientsideRecordVideo -> kStatusShowClientsideRecordVoice storage/download_manager_mtproto.cppae8fb14
: _queues[dcId] -> queue storage/localstorage.cpp357caf8
: MTP::Environment::Production -> production
228 lines
6.5 KiB
C++
228 lines
6.5 KiB
C++
/*
|
|
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 "boxes/auto_download_box.h"
|
|
|
|
#include "lang/lang_keys.h"
|
|
#include "main/main_session.h"
|
|
#include "main/main_session_settings.h"
|
|
#include "data/data_session.h"
|
|
#include "data/data_auto_download.h"
|
|
#include "ui/widgets/continuous_sliders.h"
|
|
#include "ui/widgets/buttons.h"
|
|
#include "ui/wrap/vertical_layout.h"
|
|
#include "ui/wrap/wrap.h"
|
|
#include "storage/localstorage.h"
|
|
#include "settings/settings_common.h"
|
|
#include "export/view/export_view_settings.h"
|
|
#include "styles/style_layers.h"
|
|
#include "styles/style_boxes.h"
|
|
#include "styles/style_settings.h"
|
|
|
|
namespace {
|
|
|
|
constexpr auto kMegabyte = 1024 * 1024;
|
|
constexpr auto kDefaultDownloadLimit = 10 * kMegabyte;
|
|
constexpr auto kDefaultAutoPlayLimit = 50 * kMegabyte;
|
|
|
|
using Type = Data::AutoDownload::Type;
|
|
|
|
not_null<int*> AddSizeLimitSlider(
|
|
not_null<Ui::VerticalLayout*> container,
|
|
const base::flat_map<Type, int> &values,
|
|
int defaultValue) {
|
|
using namespace Settings;
|
|
using Pair = base::flat_map<Type, int>::value_type;
|
|
|
|
const auto limits = Ui::CreateChild<rpl::event_stream<int>>(
|
|
container.get());
|
|
const auto currentLimit = ranges::max_element(
|
|
values,
|
|
std::less<>(),
|
|
[](Pair pair) { return pair.second; })->second;
|
|
const auto initialLimit = currentLimit ? currentLimit : defaultValue;
|
|
const auto result = Ui::CreateChild<int>(container.get(), initialLimit);
|
|
AddButtonWithLabel(
|
|
container,
|
|
tr::lng_media_size_limit(),
|
|
limits->events_starting_with_copy(
|
|
initialLimit
|
|
) | rpl::map([](int value) {
|
|
return tr::lng_media_size_up_to(
|
|
tr::now,
|
|
lt_size,
|
|
QString::number(value / kMegabyte) + " MB");
|
|
}),
|
|
st::autoDownloadLimitButton
|
|
)->setAttribute(Qt::WA_TransparentForMouseEvents);
|
|
const auto slider = container->add(
|
|
object_ptr<Ui::MediaSlider>(container, st::autoDownloadLimitSlider),
|
|
st::autoDownloadLimitPadding);
|
|
slider->resize(st::autoDownloadLimitSlider.seekSize);
|
|
slider->setPseudoDiscrete(
|
|
Export::View::kSizeValueCount,
|
|
Export::View::SizeLimitByIndex,
|
|
*result,
|
|
[=](int value) {
|
|
*result = value;
|
|
limits->fire_copy(value);
|
|
});
|
|
return result;
|
|
}
|
|
} // namespace
|
|
|
|
AutoDownloadBox::AutoDownloadBox(
|
|
QWidget*,
|
|
not_null<Main::Session*> session,
|
|
Data::AutoDownload::Source source)
|
|
: _session(session)
|
|
, _source(source) {
|
|
}
|
|
|
|
void AutoDownloadBox::prepare() {
|
|
setupContent();
|
|
}
|
|
|
|
void AutoDownloadBox::setupContent() {
|
|
using namespace rpl::mappers;
|
|
using namespace Settings;
|
|
using namespace Data::AutoDownload;
|
|
using Type = Data::AutoDownload::Type;
|
|
using Pair = base::flat_map<Type, int>::value_type;
|
|
|
|
setTitle(tr::lng_profile_settings_section());
|
|
|
|
const auto settings = &_session->settings().autoDownload();
|
|
|
|
auto wrap = object_ptr<Ui::VerticalLayout>(this);
|
|
const auto content = wrap.data();
|
|
setInnerWidget(object_ptr<Ui::OverrideMargins>(
|
|
this,
|
|
std::move(wrap)));
|
|
|
|
const auto add = [&](
|
|
not_null<base::flat_map<Type, int>*> values,
|
|
Type type,
|
|
rpl::producer<QString> label) {
|
|
const auto value = settings->bytesLimit(_source, type);
|
|
AddButton(
|
|
content,
|
|
std::move(label),
|
|
st::settingsButton
|
|
)->toggleOn(
|
|
rpl::single(value > 0)
|
|
)->toggledChanges(
|
|
) | rpl::start_with_next([=](bool enabled) {
|
|
(*values)[type] = enabled ? 1 : 0;
|
|
}, content->lifetime());
|
|
values->emplace(type, value);
|
|
};
|
|
|
|
AddSubsectionTitle(content, tr::lng_media_auto_title());
|
|
|
|
const auto downloadValues = Ui::CreateChild<base::flat_map<Type, int>>(
|
|
content);
|
|
add(downloadValues, Type::Photo, tr::lng_media_photo_title());
|
|
add(downloadValues, Type::File, tr::lng_media_file_title());
|
|
|
|
const auto downloadLimit = AddSizeLimitSlider(
|
|
content,
|
|
*downloadValues,
|
|
kDefaultDownloadLimit);
|
|
|
|
AddSkip(content);
|
|
AddSubsectionTitle(content, tr::lng_media_auto_play());
|
|
|
|
const auto autoPlayValues = Ui::CreateChild<base::flat_map<Type, int>>(
|
|
content);
|
|
add(
|
|
autoPlayValues,
|
|
Type::AutoPlayVideoMessage,
|
|
tr::lng_media_video_messages_title());
|
|
add(autoPlayValues, Type::AutoPlayVideo, tr::lng_media_video_title());
|
|
add(autoPlayValues, Type::AutoPlayGIF, tr::lng_media_animation_title());
|
|
|
|
const auto autoPlayLimit = AddSizeLimitSlider(
|
|
content,
|
|
*autoPlayValues,
|
|
kDefaultAutoPlayLimit);
|
|
|
|
const auto limitByType = [=](Type type) {
|
|
return (ranges::find(kAutoPlayTypes, type) != end(kAutoPlayTypes))
|
|
? *autoPlayLimit
|
|
: *downloadLimit;
|
|
};
|
|
|
|
addButton(tr::lng_connection_save(), [=] {
|
|
auto &&values = ranges::view::concat(
|
|
*downloadValues,
|
|
*autoPlayValues);
|
|
auto allowMore = values | ranges::view::filter([&](Pair pair) {
|
|
const auto [type, enabled] = pair;
|
|
const auto value = enabled ? limitByType(type) : 0;
|
|
const auto old = settings->bytesLimit(_source, type);
|
|
return (old < value);
|
|
}) | ranges::view::transform([](Pair pair) {
|
|
return pair.first;
|
|
});
|
|
const auto less = ranges::any_of(*autoPlayValues, [&](Pair pair) {
|
|
const auto [type, enabled] = pair;
|
|
const auto value = enabled ? limitByType(type) : 0;
|
|
return value < settings->bytesLimit(_source, type);
|
|
});
|
|
const auto allowMoreTypes = base::flat_set<Type>(
|
|
allowMore.begin(),
|
|
allowMore.end());
|
|
|
|
const auto changed = ranges::any_of(values, [&](Pair pair) {
|
|
const auto [type, enabled] = pair;
|
|
const auto value = enabled ? limitByType(type) : 0;
|
|
return value != settings->bytesLimit(_source, type);
|
|
});
|
|
|
|
const auto &kHidden = kStreamedTypes;
|
|
const auto hiddenChanged = ranges::any_of(kHidden, [&](Type type) {
|
|
const auto now = settings->bytesLimit(_source, type);
|
|
return (now > 0) && (now != limitByType(type));
|
|
});
|
|
|
|
if (changed) {
|
|
for (const auto [type, enabled] : values) {
|
|
const auto value = enabled ? limitByType(type) : 0;
|
|
settings->setBytesLimit(_source, type, value);
|
|
}
|
|
}
|
|
if (hiddenChanged) {
|
|
for (const auto type : kHidden) {
|
|
const auto now = settings->bytesLimit(_source, type);
|
|
if (now > 0) {
|
|
settings->setBytesLimit(
|
|
_source,
|
|
type,
|
|
limitByType(type));
|
|
}
|
|
}
|
|
}
|
|
if (changed || hiddenChanged) {
|
|
_session->saveSettingsDelayed();
|
|
}
|
|
if (allowMoreTypes.contains(Type::Photo)) {
|
|
_session->data().photoLoadSettingsChanged();
|
|
}
|
|
if (ranges::any_of(allowMoreTypes, _1 != Type::Photo)) {
|
|
_session->data().documentLoadSettingsChanged();
|
|
}
|
|
if (less) {
|
|
_session->data().checkPlayingAnimations();
|
|
}
|
|
closeBox();
|
|
});
|
|
addButton(tr::lng_cancel(), [=] { closeBox(); });
|
|
|
|
setDimensionsToContent(st::boxWidth, content);
|
|
}
|