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
		
			
				
	
	
		
			227 lines
		
	
	
	
		
			6.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			227 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);
 | 
						|
}
 |