diff --git a/Config/buck_rule_macros.bzl b/Config/buck_rule_macros.bzl index e597aa6ecd..0c101f023a 100644 --- a/Config/buck_rule_macros.bzl +++ b/Config/buck_rule_macros.bzl @@ -309,9 +309,9 @@ def glob_map(glob_results): result[file_name] = path return result -def glob_sub_map(prefix, glob_specs): +def glob_sub_map(prefix, glob_specs, exclude = []): result = dict() - for path in native.glob(glob_specs): + for path in native.glob(glob_specs, exclude = exclude): if not path.startswith(prefix): fail('\"%s\" does not start with \"%s\"' % (path, prefix)) file_key = path[len(prefix):] diff --git a/Makefile b/Makefile index 8a8b71c926..7f78364826 100644 --- a/Makefile +++ b/Makefile @@ -341,16 +341,6 @@ build_buckdebug: check_env //Telegram:IntentsExtension#dwarf-and-dsym,iphoneos-arm64 \ --verbose 7 ${BUCK_OPTIONS} ${BUCK_DEBUG_OPTIONS} -build_buckdebug_one: check_env - BUCK_DEBUG_MODE=1 $(BUCK) build \ - //submodules/Postbox:Postbox#shared,iphoneos-arm64 \ - --verbose 7 ${BUCK_OPTIONS} ${BUCK_DEBUG_OPTIONS} - -build_verbose_one: check_env - $(BUCK) build \ - //submodules/Postbox:Postbox#shared,iphoneos-arm64 \ - --verbose 7 ${BUCK_OPTIONS} ${BUCK_DEBUG_OPTIONS} - build_verbose: check_env $(BUCK) build \ //Telegram:AppPackage#iphoneos-arm64 \ @@ -385,39 +375,12 @@ deps: check_env $(BUCK) query "deps(//Telegram:AppPackage)" --dot \ ${BUCK_OPTIONS} ${BUCK_DEBUG_OPTIONS} -build_openssl: check_env - $(BUCK) build \ - //submodules/openssl:openssl#iphoneos-arm64 \ - --verbose 7 ${BUCK_OPTIONS} ${BUCK_THREADS_OPTIONS} ${BUCK_DEBUG_OPTIONS} - -build_libphonenumber: check_env - $(BUCK) build \ - //submodules/libphonenumber:libphonenumber#iphoneos-arm64 \ - ${BUCK_OPTIONS} ${BUCK_THREADS_OPTIONS} ${BUCK_DEBUG_OPTIONS} - -build_ton: check_env - $(BUCK) build \ - //submodules/ton:ton#iphoneos-arm64 \ - --verbose 7 ${BUCK_OPTIONS} ${BUCK_THREADS_OPTIONS} ${BUCK_DEBUG_OPTIONS} - clean: kill_xcode sh clean.sh project: check_env kill_xcode $(BUCK) project //Telegram:workspace --config custom.mode=project ${BUCK_OPTIONS} ${BUCK_DEBUG_OPTIONS} - open Telegram_Buck.xcworkspace - -project_opt: check_env kill_xcode - $(BUCK) project //Telegram:workspace --config custom.mode=project ${BUCK_OPTIONS} ${BUCK_RELEASE_OPTIONS} - open Telegram_Buck.xcworkspace - -project_buckdebug: check_env kill_xcode - BUCK_DEBUG_MODE=1 $(BUCK) project //Telegram:workspace --config custom.mode=project ${BUCK_OPTIONS} ${BUCK_DEBUG_OPTIONS} - open Telegram_Buck.xcworkspace - -temp_project: check_env kill_xcode - $(BUCK) project //Temp:workspace --config custom.mode=project ${BUCK_OPTIONS} ${BUCK_DEBUG_OPTIONS} - open Temp/Telegram_Buck.xcworkspace + open Telegram/Telegram_Buck.xcworkspace bazel_app_debug_arm64: APP_VERSION="${APP_VERSION}" \ diff --git a/Telegram/BUCK b/Telegram/BUCK index 57888d341a..ff2f315899 100644 --- a/Telegram/BUCK +++ b/Telegram/BUCK @@ -400,6 +400,7 @@ apple_binary( "//submodules/TelegramCore:TelegramCore#shared", "//submodules/BuildConfig:BuildConfig", "//submodules/OpenSSLEncryptionProvider:OpenSSLEncryptionProvider", + "//submodules/AppLockState:AppLockState", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/Telegram/Share/Info.plist b/Telegram/Share/Info.plist index f78fdec72f..ed09b1e9fd 100644 --- a/Telegram/Share/Info.plist +++ b/Telegram/Share/Info.plist @@ -4,6 +4,8 @@ CFBundleDevelopmentRegion en + CFBundleDisplayName + ${APP_NAME} CFBundleExecutable $(EXECUTABLE_NAME) CFBundleIdentifier @@ -14,6 +16,10 @@ $(PRODUCT_NAME) CFBundlePackageType XPC! + CFBundleShortVersionString + $(PRODUCT_BUNDLE_SHORT_VERSION) + CFBundleVersion + ${BUILD_NUMBER} NSExtension NSExtensionAttributes diff --git a/Telegram/Share/InfoBazel.plist b/Telegram/Share/InfoBazel.plist new file mode 100644 index 0000000000..f78fdec72f --- /dev/null +++ b/Telegram/Share/InfoBazel.plist @@ -0,0 +1,50 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + XPC! + NSExtension + + NSExtensionAttributes + + IntentsSupported + + INSendMessageIntent + + NSExtensionActivationRule + SUBQUERY ( + extensionItems, + $extensionItem, + SUBQUERY ( + $extensionItem.attachments, + $attachment, + ANY $attachment.registeredTypeIdentifiers UTI-CONFORMS-TO "public.file-url" || + ANY $attachment.registeredTypeIdentifiers UTI-CONFORMS-TO "public.movie" || + ANY $attachment.registeredTypeIdentifiers UTI-CONFORMS-TO "public.image" || + ANY $attachment.registeredTypeIdentifiers UTI-CONFORMS-TO "public.url" || + ANY $attachment.registeredTypeIdentifiers UTI-CONFORMS-TO "public.text" || + ANY $attachment.registeredTypeIdentifiers UTI-CONFORMS-TO "public.audio" || + ANY $attachment.registeredTypeIdentifiers UTI-CONFORMS-TO "public.data" || + ANY $attachment.registeredTypeIdentifiers UTI-CONFORMS-TO "public.vcard" || + ANY $attachment.registeredTypeIdentifiers UTI-CONFORMS-TO "com.apple.pkpass" + ).@count == $extensionItem.attachments.@count +).@count > 0 + + NSExtensionPointIdentifier + com.apple.share-services + NSExtensionPrincipalClass + ShareRootController + + + diff --git a/Telegram/SiriIntents/IntentHandler.swift b/Telegram/SiriIntents/IntentHandler.swift index 9083112cb9..46253f0897 100644 --- a/Telegram/SiriIntents/IntentHandler.swift +++ b/Telegram/SiriIntents/IntentHandler.swift @@ -106,7 +106,7 @@ public class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchFo let deviceSpecificEncryptionParameters = BuildConfig.deviceSpecificEncryptionParameters(rootPath, baseAppBundleId: baseAppBundleId) let encryptionParameters = ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: deviceSpecificEncryptionParameters.key)!, salt: ValueBoxEncryptionParameters.Salt(data: deviceSpecificEncryptionParameters.salt)!) - account = currentAccount(allocateIfNotExists: false, networkArguments: NetworkInitializationArguments(apiId: apiId, apiHash: apiHash, languagesCategory: languagesCategory, appVersion: appVersion, voipMaxLayer: 0, appData: .single(buildConfig.bundleData(withAppToken: nil, signatureDict: nil)), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), supplementary: true, manager: accountManager, rootPath: rootPath, auxiliaryMethods: accountAuxiliaryMethods, encryptionParameters: encryptionParameters) + account = currentAccount(allocateIfNotExists: false, networkArguments: NetworkInitializationArguments(apiId: apiId, apiHash: apiHash, languagesCategory: languagesCategory, appVersion: appVersion, voipMaxLayer: 0, voipVersions: [], appData: .single(buildConfig.bundleData(withAppToken: nil, signatureDict: nil)), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), supplementary: true, manager: accountManager, rootPath: rootPath, auxiliaryMethods: accountAuxiliaryMethods, encryptionParameters: encryptionParameters) |> mapToSignal { account -> Signal in if let account = account { switch account { diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/Contents.json b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000000..b1dd0aaddc --- /dev/null +++ b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,104 @@ +{ + "images" : [ + { + "idiom" : "iphone", + "size" : "20x20", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "20x20", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "3x" + }, + { + "size" : "60x60", + "idiom" : "iphone", + "filename" : "icon@120px.png", + "scale" : "2x" + }, + { + "size" : "60x60", + "idiom" : "iphone", + "filename" : "icon@180px.png", + "scale" : "3x" + }, + { + "idiom" : "ipad", + "size" : "20x20", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "20x20", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "29x29", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "29x29", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "40x40", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "40x40", + "scale" : "2x" + }, + { + "size" : "76x76", + "idiom" : "ipad", + "filename" : "icon@76px.png", + "scale" : "1x" + }, + { + "size" : "76x76", + "idiom" : "ipad", + "filename" : "icon@152px.png", + "scale" : "2x" + }, + { + "size" : "83.5x83.5", + "idiom" : "ipad", + "filename" : "icon@167px.png", + "scale" : "2x" + }, + { + "size" : "1024x1024", + "idiom" : "ios-marketing", + "filename" : "icon@1024px.png", + "scale" : "1x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@1024px.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@1024px.png new file mode 100644 index 0000000000..92875c6983 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@1024px.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@120px.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@120px.png new file mode 100644 index 0000000000..5e863192c3 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@120px.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@152px.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@152px.png new file mode 100644 index 0000000000..733e14018b Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@152px.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@167px.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@167px.png new file mode 100644 index 0000000000..6ae90ed3cd Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@167px.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@180px.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@180px.png new file mode 100644 index 0000000000..715eb5d04a Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@180px.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@76px.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@76px.png new file mode 100644 index 0000000000..6473725462 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIcon.appiconset/icon@76px.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIcon@2x-1.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIcon@2x-1.png new file mode 100644 index 0000000000..dd360d8f50 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIcon@2x-1.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIcon@2x.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIcon@2x.png new file mode 100644 index 0000000000..2e502e7dab Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIcon@2x.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIcon@3x.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIcon@3x.png new file mode 100644 index 0000000000..c47aeed4b1 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIcon@3x.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIconIpad.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIconIpad.png new file mode 100644 index 0000000000..5eaf0bab23 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIconIpad.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIconIpad@2x.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIconIpad@2x.png new file mode 100644 index 0000000000..6d9e7ab98c Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIconIpad@2x.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIconLargeIpad@2x.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIconLargeIpad@2x.png new file mode 100644 index 0000000000..9bf363744d Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueIconLargeIpad@2x.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon.png new file mode 100644 index 0000000000..dc5916282e Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon@2x-1.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon@2x-1.png new file mode 100644 index 0000000000..0898af42d9 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon@2x-1.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon@2x.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon@2x.png new file mode 100644 index 0000000000..0898af42d9 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon@2x.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon@3x.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon@3x.png new file mode 100644 index 0000000000..f7725e9914 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/BlueNotificationIcon@3x.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Contents.json b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Contents.json new file mode 100644 index 0000000000..00dd28927f --- /dev/null +++ b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Contents.json @@ -0,0 +1,119 @@ +{ + "images" : [ + { + "size" : "20x20", + "idiom" : "iphone", + "filename" : "BlueNotificationIcon@2x.png", + "scale" : "2x" + }, + { + "size" : "20x20", + "idiom" : "iphone", + "filename" : "BlueNotificationIcon@3x.png", + "scale" : "3x" + }, + { + "size" : "29x29", + "idiom" : "iphone", + "filename" : "Simple@58x58.png", + "scale" : "2x" + }, + { + "size" : "29x29", + "idiom" : "iphone", + "filename" : "Simple@87x87.png", + "scale" : "3x" + }, + { + "size" : "40x40", + "idiom" : "iphone", + "filename" : "Simple@80x80.png", + "scale" : "2x" + }, + { + "size" : "40x40", + "idiom" : "iphone", + "filename" : "BlueIcon@2x-1.png", + "scale" : "3x" + }, + { + "size" : "60x60", + "idiom" : "iphone", + "filename" : "BlueIcon@2x.png", + "scale" : "2x" + }, + { + "size" : "60x60", + "idiom" : "iphone", + "filename" : "BlueIcon@3x.png", + "scale" : "3x" + }, + { + "size" : "20x20", + "idiom" : "ipad", + "filename" : "BlueNotificationIcon.png", + "scale" : "1x" + }, + { + "size" : "20x20", + "idiom" : "ipad", + "filename" : "BlueNotificationIcon@2x-1.png", + "scale" : "2x" + }, + { + "size" : "29x29", + "idiom" : "ipad", + "filename" : "Simple@29x29.png", + "scale" : "1x" + }, + { + "size" : "29x29", + "idiom" : "ipad", + "filename" : "Simple@58x58-1.png", + "scale" : "2x" + }, + { + "size" : "40x40", + "idiom" : "ipad", + "filename" : "Simple@40x40-1.png", + "scale" : "1x" + }, + { + "size" : "40x40", + "idiom" : "ipad", + "filename" : "Simple@80x80-1.png", + "scale" : "2x" + }, + { + "size" : "76x76", + "idiom" : "ipad", + "filename" : "BlueIconIpad.png", + "scale" : "1x" + }, + { + "size" : "76x76", + "idiom" : "ipad", + "filename" : "BlueIconIpad@2x.png", + "scale" : "2x" + }, + { + "size" : "83.5x83.5", + "idiom" : "ipad", + "filename" : "BlueIconLargeIpad@2x.png", + "scale" : "2x" + }, + { + "size" : "1024x1024", + "idiom" : "ios-marketing", + "filename" : "Simple-iTunesArtwork.png", + "scale" : "1x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + }, + "properties" : { + "pre-rendered" : true + } +} \ No newline at end of file diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple-iTunesArtwork.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple-iTunesArtwork.png new file mode 100644 index 0000000000..f00a2857f0 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple-iTunesArtwork.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@29x29.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@29x29.png new file mode 100644 index 0000000000..90d7b67bc0 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@29x29.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@40x40-1.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@40x40-1.png new file mode 100644 index 0000000000..a79cb5dcdc Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@40x40-1.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@58x58-1.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@58x58-1.png new file mode 100644 index 0000000000..aa6a4a442e Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@58x58-1.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@58x58.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@58x58.png new file mode 100644 index 0000000000..aa6a4a442e Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@58x58.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@80x80-1.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@80x80-1.png new file mode 100644 index 0000000000..385bc474b2 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@80x80-1.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@80x80.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@80x80.png new file mode 100644 index 0000000000..385bc474b2 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@80x80.png differ diff --git a/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@87x87.png b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@87x87.png new file mode 100644 index 0000000000..c0a9ce9319 Binary files /dev/null and b/Telegram/Telegram-iOS/Icons.xcassets/AppIconLLC.appiconset/Simple@87x87.png differ diff --git a/Telegram/Telegram-iOS/Info.plist b/Telegram/Telegram-iOS/Info.plist index e7ca119cd8..f66daefe49 100644 --- a/Telegram/Telegram-iOS/Info.plist +++ b/Telegram/Telegram-iOS/Info.plist @@ -14,6 +14,172 @@ ${APP_NAME} CFBundleExecutable $(EXECUTABLE_NAME) + CFBundleIcons + + CFBundleAlternateIcons + + Black + + CFBundleIconFiles + + BlackIcon + BlackNotificationIcon + + UIPrerenderedIcon + + + BlackClassic + + CFBundleIconFiles + + BlackClassicIcon + BlackClassicNotificationIcon + + UIPrerenderedIcon + + + BlackFilled + + CFBundleIconFiles + + BlackFilledIcon + + UIPrerenderedIcon + + + Blue + + CFBundleIconFiles + + BlueIcon + BlueNotificationIcon + + UIPrerenderedIcon + + + BlueClassic + + CFBundleIconFiles + + BlueClassicIcon + BlueClassicNotificationIcon + + UIPrerenderedIcon + + + BlueFilled + + CFBundleIconFiles + + BlueFilledIcon + + UIPrerenderedIcon + + + WhiteFilled + + CFBundleIconFiles + + WhiteFilledIcon + + UIPrerenderedIcon + + + + CFBundlePrimaryIcon + + CFBundleIconName + AppIconLLC + UIPrerenderedIcon + + + + CFBundleIcons~ipad + + CFBundleAlternateIcons + + Black + + CFBundleIconFiles + + BlackIconIpad + BlackIconLargeIpad + BlackNotificationIcon + + UIPrerenderedIcon + + + BlackClassic + + CFBundleIconFiles + + BlackClassicIconIpad + BlackClassicIconLargeIpad + BlackClassicNotificationIcon + + UIPrerenderedIcon + + + BlackFilled + + CFBundleIconFiles + + BlackFilledIconIpad + BlackFilledIconLargeIpad + + UIPrerenderedIcon + + + Blue + + CFBundleIconFiles + + BlueIconIpad + BlueIconLargeIpad + BlueNotificationIcon + + UIPrerenderedIcon + + + BlueClassic + + CFBundleIconFiles + + BlueClassicIconIpad + BlueClassicIconLargeIpad + BlueClassicNotificationIcon + + UIPrerenderedIcon + + + BlueFilled + + CFBundleIconFiles + + BlueFilledIconIpad + BlueFilledIconLargeIpad + + UIPrerenderedIcon + + + WhiteFilled + + CFBundleIconFiles + + WhiteFilledIcon + + UIPrerenderedIcon + + + + CFBundlePrimaryIcon + + CFBundleIconName + AppIconLLC + UIPrerenderedIcon + + + CFBundleIdentifier $(PRODUCT_BUNDLE_IDENTIFIER) CFBundleInfoDictionaryVersion diff --git a/Telegram/Info.plist b/Telegram/Telegram-iOS/InfoBazel.plist similarity index 84% rename from Telegram/Info.plist rename to Telegram/Telegram-iOS/InfoBazel.plist index d157492d3a..e7ca119cd8 100644 --- a/Telegram/Info.plist +++ b/Telegram/Telegram-iOS/InfoBazel.plist @@ -11,7 +11,7 @@ CFBundleDevelopmentRegion en CFBundleDisplayName - ${PRODUCT_NAME} + ${APP_NAME} CFBundleExecutable $(EXECUTABLE_NAME) CFBundleIdentifier @@ -22,8 +22,46 @@ $(PRODUCT_NAME) CFBundlePackageType APPL + CFBundleShortVersionString + $(PRODUCT_BUNDLE_SHORT_VERSION) CFBundleSignature ???? + CFBundleURLTypes + + + CFBundleTypeRole + Viewer + CFBundleURLName + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleURLSchemes + + telegram + + + + CFBundleTypeRole + Viewer + CFBundleURLName + $(PRODUCT_BUNDLE_IDENTIFIER).compatibility + CFBundleURLSchemes + + tg + $(APP_SPECIFIC_URL_SCHEME) + + + + CFBundleTypeRole + Viewer + CFBundleURLName + $(PRODUCT_BUNDLE_IDENTIFIER).ton + CFBundleURLSchemes + + ton + + + + CFBundleVersion + ${BUILD_NUMBER} ITSAppUsesNonExemptEncryption LSApplicationQueriesSchemes diff --git a/Telegram/Telegram-iOS/en.lproj/Localizable.strings b/Telegram/Telegram-iOS/en.lproj/Localizable.strings index a0af4e214f..17dbcd68bf 100644 --- a/Telegram/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram/Telegram-iOS/en.lproj/Localizable.strings @@ -5366,3 +5366,5 @@ Any member of this group will be able to see messages in the channel."; "Stats.ViewsBySourceTitle" = "VIEWS BY SOURCE"; "Stats.FollowersBySourceTitle" = "FOLLOWERS BY SOURCE"; "Stats.LanguagesTitle" = "LANGUAGES"; + +"ChatListFilter.AddChatsTitle" = "Add Chats"; diff --git a/Telegram/Watch/App/Info.plist b/Telegram/Watch/App/Info.plist index d965321748..883fc23d8c 100644 --- a/Telegram/Watch/App/Info.plist +++ b/Telegram/Watch/App/Info.plist @@ -4,6 +4,8 @@ CFBundleDevelopmentRegion $(DEVELOPMENT_LANGUAGE) + CFBundleDisplayName + $(APP_NAME) CFBundleExecutable $(EXECUTABLE_NAME) CFBundleIdentifier @@ -14,6 +16,10 @@ $(PRODUCT_NAME) CFBundlePackageType APPL + CFBundleShortVersionString + $(PRODUCT_BUNDLE_SHORT_VERSION) + CFBundleVersion + ${BUILD_NUMBER} UIDeviceFamily 4 @@ -23,6 +29,8 @@ UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown + WKCompanionAppBundleIdentifier + $(APP_BUNDLE_ID) WKWatchKitApp diff --git a/Telegram/Watch/App/InfoBazel.plist b/Telegram/Watch/App/InfoBazel.plist new file mode 100644 index 0000000000..d965321748 --- /dev/null +++ b/Telegram/Watch/App/InfoBazel.plist @@ -0,0 +1,29 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + APPL + UIDeviceFamily + + 4 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + + WKWatchKitApp + + + diff --git a/Telegram/Watch/Extension/Info.plist b/Telegram/Watch/Extension/Info.plist index 483b83db68..4eb1d3e62e 100644 --- a/Telegram/Watch/Extension/Info.plist +++ b/Telegram/Watch/Extension/Info.plist @@ -4,6 +4,8 @@ CFBundleDevelopmentRegion $(DEVELOPMENT_LANGUAGE) + CFBundleDisplayName + $(APP_NAME) CFBundleExecutable $(EXECUTABLE_NAME) CFBundleIdentifier @@ -14,6 +16,20 @@ $(PRODUCT_NAME) CFBundlePackageType XPC! + CFBundleShortVersionString + $(PRODUCT_BUNDLE_SHORT_VERSION) + CFBundleVersion + ${BUILD_NUMBER} + NSExtension + + NSExtensionAttributes + + WKAppBundleIdentifier + $(APP_BUNDLE_ID).watchkitapp + + NSExtensionPointIdentifier + com.apple.watchkit + WKExtensionDelegateClassName TGExtensionDelegate diff --git a/Telegram/Watch/Extension/InfoBazel.plist b/Telegram/Watch/Extension/InfoBazel.plist new file mode 100644 index 0000000000..483b83db68 --- /dev/null +++ b/Telegram/Watch/Extension/InfoBazel.plist @@ -0,0 +1,20 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + XPC! + WKExtensionDelegateClassName + TGExtensionDelegate + + diff --git a/package_app.sh b/package_app.sh index 3ebc12800c..bd0c12db93 100644 --- a/package_app.sh +++ b/package_app.sh @@ -1,6 +1,5 @@ #!/bin/sh -#set -x set -e if [ -z "$1" ] || [ -z "$2" ] || [ -z "$3" ]; then @@ -55,7 +54,7 @@ mkdir -p "$TEMP_ENTITLEMENTS_PATH" if [ "$APP_TYPE" == "wallet" ]; then cp "buck-out/gen/Wallet/AppPackage#$PLATFORM_FLAVORS.ipa" "$IPA_PATH.original" else - cp "buck-out/gen/AppPackage#$PLATFORM_FLAVORS.ipa" "$IPA_PATH.original" + cp "buck-out/gen/Telegram/AppPackage#$PLATFORM_FLAVORS.ipa" "$IPA_PATH.original" fi rm -rf "$IPA_PATH.original.unpacked" rm -f "$BUILD_PATH/${APP_NAME}_signed.ipa" @@ -312,7 +311,7 @@ done if [ "$APP_TYPE" == "wallet" ]; then APP_BINARY_DSYM_PATH="buck-out/gen/Wallet/Wallet#dwarf-and-dsym,$PLATFORM_FLAVORS,no-include-frameworks/Wallet.app.dSYM" else - APP_BINARY_DSYM_PATH="buck-out/gen/Telegram#dwarf-and-dsym,$PLATFORM_FLAVORS,no-include-frameworks/Telegram.app.dSYM" + APP_BINARY_DSYM_PATH="buck-out/gen/Telegram/Telegram#dwarf-and-dsym,$PLATFORM_FLAVORS,no-include-frameworks/Telegram.app.dSYM" fi cp -r "$APP_BINARY_DSYM_PATH" "$DSYMS_DIR/" @@ -323,12 +322,12 @@ else fi for EXTENSION in $EXTENSIONS; do - EXTENSION_DSYM_PATH="buck-out/gen/${EXTENSION}Extension#dwarf-and-dsym,$PLATFORM_FLAVORS,no-include-frameworks/${EXTENSION}Extension.appex.dSYM" + EXTENSION_DSYM_PATH="buck-out/gen/Telegram/${EXTENSION}Extension#dwarf-and-dsym,$PLATFORM_FLAVORS,no-include-frameworks/${EXTENSION}Extension.appex.dSYM" cp -r "$EXTENSION_DSYM_PATH" "$DSYMS_DIR/" done if [ "$APP_TYPE" != "wallet" ]; then - WATCH_EXTENSION_DSYM_PATH="buck-out/gen/WatchAppExtension#dwarf-and-dsym,no-include-frameworks,watchos-arm64_32,watchos-armv7k/WatchAppExtension.appex.dSYM" + WATCH_EXTENSION_DSYM_PATH="buck-out/gen/Telegram/WatchAppExtension#dwarf-and-dsym,no-include-frameworks,watchos-arm64_32,watchos-armv7k/WatchAppExtension.appex.dSYM" cp -r "$WATCH_EXTENSION_DSYM_PATH" "$DSYMS_DIR/" fi diff --git a/submodules/AccountContext/Sources/ContactMultiselectionController.swift b/submodules/AccountContext/Sources/ContactMultiselectionController.swift index 0d69cfc183..cfbe13f9f2 100644 --- a/submodules/AccountContext/Sources/ContactMultiselectionController.swift +++ b/submodules/AccountContext/Sources/ContactMultiselectionController.swift @@ -7,6 +7,7 @@ public enum ContactMultiselectionControllerMode { case groupCreation case peerSelection(searchChatList: Bool, searchGroups: Bool, searchChannels: Bool) case channelCreation + case chatSelection } public enum ContactListFilter { diff --git a/submodules/AppBundle/BUCK b/submodules/AppBundle/BUCK index bb64ebe4e4..34e2293199 100644 --- a/submodules/AppBundle/BUCK +++ b/submodules/AppBundle/BUCK @@ -3,10 +3,13 @@ load("//Config:buck_rule_macros.bzl", "static_library") static_library( name = "AppBundle", srcs = glob([ - "Source/AppBundle/*.m", + "Sources/**/*.m", + ]), + headers = glob([ + "Sources/**/*.h", ]), exported_headers = glob([ - "Source/AppBundle/*.h", + "PublicHeaders/**/*.h", ]), deps = [ ], diff --git a/submodules/BuildConfigExtra/BUCK b/submodules/BuildConfigExtra/BUCK index 5d87460156..7c4e20f519 100644 --- a/submodules/BuildConfigExtra/BUCK +++ b/submodules/BuildConfigExtra/BUCK @@ -9,7 +9,7 @@ static_library( "Sources/*.h", ]), exported_headers = glob([ - "Sources/*.h", + "PublicHeaders/**/*.h", ]), deps = [ "//submodules/PKCS:PKCS", diff --git a/submodules/ChatListUI/Sources/ChatListController.swift b/submodules/ChatListUI/Sources/ChatListController.swift index 3b74034e53..4a176b5974 100644 --- a/submodules/ChatListUI/Sources/ChatListController.swift +++ b/submodules/ChatListUI/Sources/ChatListController.swift @@ -24,19 +24,26 @@ import LocalizedPeerData import TelegramIntents private func fixListNodeScrolling(_ listNode: ListView, searchNode: NavigationBarSearchContentNode) -> Bool { + if listNode.scroller.isDragging { + return false + } if searchNode.expansionProgress > 0.0 && searchNode.expansionProgress < 1.0 { let scrollToItem: ListViewScrollToItem let targetProgress: CGFloat + let offset: CGFloat if searchNode.expansionProgress < 0.6 { scrollToItem = ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: true, curve: .Default(duration: nil), directionHint: .Up) targetProgress = 0.0 + offset = navigationBarSearchContentHeight } else { scrollToItem = ListViewScrollToItem(index: 0, position: .top(0.0), animated: true, curve: .Default(duration: nil), directionHint: .Up) targetProgress = 1.0 + offset = 0.0 } - searchNode.updateExpansionProgress(targetProgress, animated: true) + //searchNode.updateExpansionProgress(targetProgress, animated: true) - listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: ListViewDeleteAndInsertOptions(), scrollToItem: scrollToItem, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + //listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: ListViewDeleteAndInsertOptions(), scrollToItem: scrollToItem, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + listNode.scrollToOffsetFromTop(offset) return true } else if searchNode.expansionProgress == 1.0 { var sortItemNode: ListViewItemNode? @@ -139,13 +146,11 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, private var searchContentNode: NavigationBarSearchContentNode? private let tabContainerNode: ChatListFilterTabContainerNode - private var tabContainerData: ([ChatListFilterTabEntry], ChatListFilterTabEntryId)? - - private let chatListFilterValue = Promise() + private var tabContainerData: [ChatListFilterTabEntry]? public override func updateNavigationCustomData(_ data: Any?, progress: CGFloat, transition: ContainedViewLayoutTransition) { if self.isNodeLoaded { - self.chatListDisplayNode.chatListNode.updateSelectedChatLocation(data as? ChatLocation, progress: progress, transition: transition) + self.chatListDisplayNode.containerNode.updateSelectedChatLocation(data: data as? ChatLocation, progress: progress, transition: transition) } } @@ -233,12 +238,12 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, if strongSelf.chatListDisplayNode.searchDisplayController != nil { strongSelf.deactivateSearch(animated: true) } else { - switch strongSelf.chatListDisplayNode.chatListNode.visibleContentOffset() { + switch strongSelf.chatListDisplayNode.containerNode.currentItemNode.visibleContentOffset() { case .none, .unknown: if let searchContentNode = strongSelf.searchContentNode { searchContentNode.updateExpansionProgress(1.0, animated: true) } - strongSelf.chatListDisplayNode.chatListNode.scrollToPosition(.top) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.scrollToPosition(.top) case let .known(offset): if offset <= navigationBarSearchContentHeight + 1.0 { strongSelf.tabContainerNode.tabSelected?(.all) @@ -246,24 +251,11 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, if let searchContentNode = strongSelf.searchContentNode { searchContentNode.updateExpansionProgress(1.0, animated: true) } - strongSelf.chatListDisplayNode.chatListNode.scrollToPosition(.top) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.scrollToPosition(.top) } } } } - self.longTapWithTabBar = { [weak self] in - guard let strongSelf = self else { - return - } - if strongSelf.chatListDisplayNode.searchDisplayController != nil { - strongSelf.deactivateSearch(animated: true) - } else { - if let searchContentNode = strongSelf.searchContentNode { - searchContentNode.updateExpansionProgress(1.0, animated: true) - } - strongSelf.chatListDisplayNode.chatListNode.scrollToPosition(.auto) - } - } let hasProxy = context.sharedContext.accountManager.sharedData(keys: [SharedDataKeys.proxySettings]) |> map { sharedData -> (Bool, Bool) in @@ -288,22 +280,17 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, context.account.networkState, hasProxy, passcode, - self.chatListDisplayNode.chatListNode.state + self.chatListDisplayNode.containerNode.currentItemState ).start(next: { [weak self] networkState, proxy, passcode, state in if let strongSelf = self { let defaultTitle: String if strongSelf.groupId == .root { - if let chatListFilter = strongSelf.filter { - let title: String = chatListFilter.title ?? strongSelf.presentationData.strings.DialogList_Title - defaultTitle = title - } else { - defaultTitle = strongSelf.presentationData.strings.DialogList_Title - } + defaultTitle = strongSelf.presentationData.strings.DialogList_Title } else { defaultTitle = strongSelf.presentationData.strings.ChatList_ArchivedChatsTitle } if state.editing { - if strongSelf.groupId == .root && strongSelf.filter == nil { + if strongSelf.groupId == .root { strongSelf.navigationItem.rightBarButtonItem = nil } @@ -313,11 +300,9 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, var isRoot = false if case .root = strongSelf.groupId { isRoot = true - if strongSelf.filter == nil { - let rightBarButtonItem = UIBarButtonItem(image: PresentationResourcesRootController.navigationComposeIcon(strongSelf.presentationData.theme), style: .plain, target: strongSelf, action: #selector(strongSelf.composePressed)) - rightBarButtonItem.accessibilityLabel = strongSelf.presentationData.strings.VoiceOver_Navigation_Compose - strongSelf.navigationItem.rightBarButtonItem = rightBarButtonItem - } + let rightBarButtonItem = UIBarButtonItem(image: PresentationResourcesRootController.navigationComposeIcon(strongSelf.presentationData.theme), style: .plain, target: strongSelf, action: #selector(strongSelf.composePressed)) + rightBarButtonItem.accessibilityLabel = strongSelf.presentationData.strings.VoiceOver_Navigation_Compose + strongSelf.navigationItem.rightBarButtonItem = rightBarButtonItem } let (hasProxy, connectsViaProxy) = proxy @@ -421,30 +406,39 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } if self.filter == nil { + self.chatListDisplayNode.containerNode.currentItemFilterUpdated = { [weak self] filter, fraction, transition in + guard let strongSelf = self else { + return + } + guard let layout = strongSelf.validLayout else { + return + } + guard let tabContainerData = strongSelf.tabContainerData else { + return + } + strongSelf.tabContainerNode.update(size: CGSize(width: layout.size.width, height: 46.0), sideInset: layout.safeInsets.left, filters: tabContainerData, selectedFilter: filter, transitionFraction: fraction, presentationData: strongSelf.presentationData, transition: transition) + } let preferencesKey: PostboxViewKey = .preferences(keys: Set([ ApplicationSpecificPreferencesKeys.chatListFilterSettings ])) let filterItems = chatListFilterItems(context: context) - |> map { totalCount, items -> [ChatListFilterTabEntry] in - var result: [ChatListFilterTabEntry] = [] - result.append(.all(unreadCount: totalCount)) - for (filter, unreadCount) in items { - result.append(.filter(id: filter.id, text: filter.title ?? "", unreadCount: unreadCount)) - } - return result - } - |> distinctUntilChanged self.filterDisposable = (combineLatest(queue: .mainQueue(), context.account.postbox.combinedView(keys: [ preferencesKey ]), - filterItems, - self.chatListFilterValue.get() |> map { $0?.id } |> distinctUntilChanged + filterItems ) - |> deliverOnMainQueue).start(next: { [weak self] combinedView, filterItems, selectedFilter in + |> deliverOnMainQueue).start(next: { [weak self] combinedView, countAndFilterItems in guard let strongSelf = self else { return } + let (totalCount, items) = countAndFilterItems + var filterItems: [ChatListFilterTabEntry] = [] + filterItems.append(.all(unreadCount: 0)) + for (filter, unreadCount) in items { + filterItems.append(.filter(id: filter.id, text: filter.title, unreadCount: unreadCount)) + } + var filterSettings: ChatListFilterSettings = .default if let preferencesView = combinedView.views[preferencesKey] as? PreferencesView { if let value = preferencesView.values[ApplicationSpecificPreferencesKeys.chatListFilterSettings] as? ChatListFilterSettings { @@ -459,12 +453,18 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, var wasEmpty = false if let tabContainerData = strongSelf.tabContainerData { - wasEmpty = tabContainerData.0.count <= 1 + wasEmpty = tabContainerData.count <= 1 } else { wasEmpty = true } - let selectedEntryId: ChatListFilterTabEntryId = selectedFilter.flatMap { .filter($0) } ?? .all - strongSelf.tabContainerData = (resolvedItems, selectedEntryId) + let selectedEntryId = strongSelf.chatListDisplayNode.containerNode.currentItemFilter + strongSelf.tabContainerData = resolvedItems + var availableFilters: [ChatListContainerNodeFilter] = [] + availableFilters.append(.all) + for item in items { + availableFilters.append(.filter(item.0)) + } + strongSelf.chatListDisplayNode.containerNode.updateAvailableFilters(availableFilters) let isEmpty = resolvedItems.count <= 1 @@ -480,7 +480,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.containerLayoutUpdated(layout, transition: .immediate) (strongSelf.parent as? TabBarController)?.updateLayout() } else { - strongSelf.tabContainerNode.update(size: CGSize(width: layout.size.width, height: NavigationBar.defaultSecondaryContentHeight), sideInset: layout.safeInsets.left, filters: resolvedItems, selectedFilter: selectedEntryId, presentationData: strongSelf.presentationData, transition: .animated(duration: 0.4, curve: .spring)) + strongSelf.tabContainerNode.update(size: CGSize(width: layout.size.width, height: 46.0), sideInset: layout.safeInsets.left, filters: resolvedItems, selectedFilter: selectedEntryId, transitionFraction: strongSelf.chatListDisplayNode.containerNode.transitionFraction, presentationData: strongSelf.presentationData, transition: .animated(duration: 0.4, curve: .spring)) } } }) @@ -498,7 +498,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - let previousFilter = strongSelf.chatListDisplayNode.chatListNode.chatListFilter + let previousFilter = strongSelf.chatListDisplayNode.containerNode.currentItemNode.chatListFilter let updatedFilter: ChatListFilter? switch id { case .all: @@ -519,26 +519,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, updatedFilter = nil } } - if previousFilter?.id != updatedFilter?.id { - var paneSwitchAnimationDirection: ChatListNodePaneSwitchAnimationDirection? - if let previousId = previousFilter?.id, let updatedId = updatedFilter?.id, let previousIndex = filters.index(where: { $0.id == previousId }), let updatedIndex = filters.index(where: { $0.id == updatedId }) { - if previousIndex > updatedIndex { - paneSwitchAnimationDirection = .right - } else { - paneSwitchAnimationDirection = .left - } - } else if (previousFilter != nil) != (updatedFilter != nil) { - if previousFilter != nil { - paneSwitchAnimationDirection = .right - } else { - paneSwitchAnimationDirection = .left - } - } - if let direction = paneSwitchAnimationDirection { - strongSelf.chatListDisplayNode.chatListNode.paneSwitchAnimation = (direction, .animated(duration: 0.4, curve: .spring)) - } - } - strongSelf.chatListDisplayNode.chatListNode.updateFilter(updatedFilter) + strongSelf.chatListDisplayNode.containerNode.switchToFilter(id: updatedFilter.flatMap { .filter($0.id) } ?? .all) }) } @@ -550,38 +531,17 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - var items: [ContextMenuItem] = [] - items.append(.action(ContextMenuActionItem(text: strongSelf.presentationData.strings.Common_Edit, icon: { _ in - return nil - }, action: { c, f in - c.dismiss(completion: { - guard let strongSelf = self else { - return - } - let _ = (strongSelf.context.account.postbox.transaction { transaction -> [ChatListFilter] in - let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default - return settings.filters - } - |> deliverOnMainQueue).start(next: { presetList in - guard let strongSelf = self else { - return - } - var found = false - for filter in presetList { - if filter.id == id { - strongSelf.push(chatListFilterPresetController(context: strongSelf.context, currentPreset: filter, updated: { _ in })) - f(.dismissWithoutContent) - found = true - break - } - } - }) - }) - }))) - if let chatListFilter = strongSelf.chatListDisplayNode.chatListNode.chatListFilter, chatListFilter.includePeers.count < 100 { - //TODO:localization - items.append(.action(ContextMenuActionItem(text: "Add Chats", icon: { _ in - return nil + let _ = (strongSelf.context.account.postbox.transaction { transaction -> [ChatListFilter] in + let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default + return settings.filters + } + |> deliverOnMainQueue).start(next: { [weak self] filters in + guard let strongSelf = self else { + return + } + var items: [ContextMenuItem] = [] + items.append(.action(ContextMenuActionItem(text: strongSelf.presentationData.strings.Common_Edit, icon: { theme in + return generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Edit"), color: theme.contextMenu.primaryColor) }, action: { c, f in c.dismiss(completion: { guard let strongSelf = self else { @@ -598,7 +558,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, var found = false for filter in presetList { if filter.id == id { - strongSelf.push(chatListFilterAddChatsController(context: strongSelf.context, filter: filter)) + strongSelf.push(chatListFilterPresetController(context: strongSelf.context, currentPreset: filter, updated: { _ in })) f(.dismissWithoutContent) found = true break @@ -607,10 +567,74 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, }) }) }))) - } - - let controller = ContextController(account: strongSelf.context.account, presentationData: strongSelf.presentationData, source: .extracted(ChatListHeaderBarContextExtractedContentSource(controller: strongSelf, sourceNode: sourceNode)), items: .single(items), reactionItems: [], recognizer: nil, gesture: gesture) - strongSelf.context.sharedContext.mainWindow?.presentInGlobalOverlay(controller) + if let filter = filters.first(where: { $0.id == id }), filter.data.includePeers.count < 100 { + //TODO:localization + items.append(.action(ContextMenuActionItem(text: "Add Chats", icon: { theme in + return generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Add"), color: theme.contextMenu.primaryColor) + }, action: { c, f in + c.dismiss(completion: { + guard let strongSelf = self else { + return + } + let _ = (strongSelf.context.account.postbox.transaction { transaction -> [ChatListFilter] in + let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default + return settings.filters + } + |> deliverOnMainQueue).start(next: { presetList in + guard let strongSelf = self else { + return + } + var found = false + for filter in presetList { + if filter.id == id { + strongSelf.push(chatListFilterAddChatsController(context: strongSelf.context, filter: filter)) + f(.dismissWithoutContent) + found = true + break + } + } + }) + }) + }))) + items.append(.action(ContextMenuActionItem(text: "Delete", textColor: .destructive, icon: { theme in + return generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Delete"), color: theme.contextMenu.destructiveColor) + }, action: { c, f in + c.dismiss(completion: { + guard let strongSelf = self else { + return + } + let actionSheet = ActionSheetController(presentationData: strongSelf.presentationData) + + actionSheet.setItemGroups([ + ActionSheetItemGroup(items: [ + ActionSheetButtonItem(title: strongSelf.presentationData.strings.Common_Delete, color: .destructive, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + + guard let strongSelf = self else { + return + } + let _ = updateChatListFilterSettingsInteractively(postbox: strongSelf.context.account.postbox, { settings in + var settings = settings + settings.filters = settings.filters.filter({ $0.id != id }) + return settings + }).start() + let _ = replaceRemoteChatListFilters(account: strongSelf.context.account).start() + }) + ]), + ActionSheetItemGroup(items: [ + ActionSheetButtonItem(title: strongSelf.presentationData.strings.Common_Cancel, color: .accent, font: .bold, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + }) + ]) + ]) + strongSelf.present(actionSheet, in: .window(.root)) + }) + }))) + } + + let controller = ContextController(account: strongSelf.context.account, presentationData: strongSelf.presentationData, source: .extracted(ChatListHeaderBarContextExtractedContentSource(controller: strongSelf, sourceNode: sourceNode)), items: .single(items), reactionItems: [], recognizer: nil, gesture: gesture) + strongSelf.context.sharedContext.mainWindow?.presentInGlobalOverlay(controller) + }) } } @@ -643,11 +667,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } self.searchContentNode?.updateThemeAndPlaceholder(theme: self.presentationData.theme, placeholder: self.presentationData.strings.DialogList_SearchLabel) - var editing = false - self.chatListDisplayNode.chatListNode.updateState { state in - editing = state.editing - return state - } + let editing = self.chatListDisplayNode.containerNode.currentItemNode.currentState.editing let editItem: UIBarButtonItem if editing { editItem = UIBarButtonItem(title: self.presentationData.strings.Common_Done, style: .done, target: self, action: #selector(self.donePressed)) @@ -677,7 +697,6 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, override public func loadDisplayNode() { self.displayNode = ChatListControllerNode(context: self.context, groupId: self.groupId, filter: self.filter, previewing: self.previewing, controlsHistoryPreload: self.controlsHistoryPreload, presentationData: self.presentationData, controller: self) - self.chatListFilterValue.set(self.chatListDisplayNode.chatListNode.appliedChatListFilterSignal) self.chatListDisplayNode.navigationBar = self.navigationBar @@ -685,37 +704,37 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, self?.deactivateSearch(animated: true) } - self.chatListDisplayNode.chatListNode.activateSearch = { [weak self] in + self.chatListDisplayNode.containerNode.activateSearch = { [weak self] in self?.activateSearch() } - self.chatListDisplayNode.chatListNode.presentAlert = { [weak self] text in + self.chatListDisplayNode.containerNode.presentAlert = { [weak self] text in if let strongSelf = self { self?.present(textAlertController(context: strongSelf.context, title: nil, text: text, actions: [TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Common_OK, action: {})]), in: .window(.root)) } } - self.chatListDisplayNode.chatListNode.present = { [weak self] c in + self.chatListDisplayNode.containerNode.present = { [weak self] c in if let strongSelf = self { self?.present(c, in: .window(.root)) } } - self.chatListDisplayNode.chatListNode.toggleArchivedFolderHiddenByDefault = { [weak self] in + self.chatListDisplayNode.containerNode.toggleArchivedFolderHiddenByDefault = { [weak self] in guard let strongSelf = self else { return } strongSelf.toggleArchivedFolderHiddenByDefault() } - self.chatListDisplayNode.chatListNode.deletePeerChat = { [weak self] peerId in + self.chatListDisplayNode.containerNode.deletePeerChat = { [weak self] peerId in guard let strongSelf = self else { return } strongSelf.deletePeerChat(peerId: peerId) } - self.chatListDisplayNode.chatListNode.peerSelected = { [weak self] peerId, animated, isAd in + self.chatListDisplayNode.containerNode.peerSelected = { [weak self] peer, animated, isAd in if let strongSelf = self { if let navigationController = strongSelf.navigationController as? NavigationController { if isAd { @@ -739,37 +758,37 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, scrollToEndIfExists = true } - strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), scrollToEndIfExists: scrollToEndIfExists, options: strongSelf.groupId == PeerGroupId.root ? [.removeOnMasterDetails] : [], parentGroupId: strongSelf.groupId, completion: { [weak self] in - self?.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peer.id), scrollToEndIfExists: scrollToEndIfExists, options: strongSelf.groupId == PeerGroupId.root ? [.removeOnMasterDetails] : [], parentGroupId: strongSelf.groupId, completion: { [weak self] in + self?.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) })) } } } - self.chatListDisplayNode.chatListNode.groupSelected = { [weak self] groupId in + self.chatListDisplayNode.containerNode.groupSelected = { [weak self] groupId in if let strongSelf = self { if let navigationController = strongSelf.navigationController as? NavigationController { let chatListController = ChatListControllerImpl(context: strongSelf.context, groupId: groupId, controlsHistoryPreload: false, enableDebugActions: false) chatListController.navigationPresentation = .master navigationController.pushViewController(chatListController) - strongSelf.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } } - self.chatListDisplayNode.chatListNode.updatePeerGrouping = { [weak self] peerId, group in + self.chatListDisplayNode.containerNode.updatePeerGrouping = { [weak self] peerId, group in guard let strongSelf = self else { return } if group { strongSelf.archiveChats(peerIds: [peerId]) } else { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerId) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerId) let _ = updatePeerGroupIdInteractively(postbox: strongSelf.context.account.postbox, peerId: peerId, groupId: group ? Namespaces.PeerGroup.archive : .root).start(completed: { guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) }) } } @@ -787,7 +806,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(actualPeerId), subject: .message(messageId), purposefulAction: { self?.deactivateSearch(animated: false) }, scrollToEndIfExists: scrollToEndIfExists, options: strongSelf.groupId == PeerGroupId.root ? [.removeOnMasterDetails] : [])) - strongSelf.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } })) @@ -816,7 +835,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peer.id), purposefulAction: { [weak self] in self?.deactivateSearch(animated: false) }, scrollToEndIfExists: scrollToEndIfExists, options: strongSelf.groupId == PeerGroupId.root ? [.removeOnMasterDetails] : [])) - strongSelf.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } })) @@ -868,7 +887,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, navigationController.filterController(strongSelf, animated: true) } - self.chatListDisplayNode.chatListNode.contentOffsetChanged = { [weak self] offset in + self.chatListDisplayNode.containerNode.contentOffsetChanged = { [weak self] offset in if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode, let validLayout = strongSelf.validLayout { var offset = offset if validLayout.inVoiceOver { @@ -878,7 +897,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } } - self.chatListDisplayNode.chatListNode.contentScrollingEnded = { [weak self] listView in + self.chatListDisplayNode.containerNode.contentScrollingEnded = { [weak self] listView in if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { return fixListNodeScrolling(listView, searchNode: searchContentNode) } else { @@ -898,7 +917,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - if let filter = strongSelf.chatListDisplayNode.chatListNode.chatListFilter { + if let filter = strongSelf.chatListDisplayNode.containerNode.currentItemNode.chatListFilter { strongSelf.push(chatListFilterPresetController(context: strongSelf.context, currentPreset: filter, updated: { _ in })) } else { strongSelf.composePressed() @@ -909,7 +928,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, self?.toolbarActionSelected(action: action) } - self.chatListDisplayNode.chatListNode.activateChatPreview = { [weak self] item, node, gesture in + self.chatListDisplayNode.containerNode.activateChatPreview = { [weak self] item, node, gesture in guard let strongSelf = self else { gesture?.cancel() return @@ -941,7 +960,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } let context = self.context - let peerIdsAndOptions: Signal<(ChatListSelectionOptions, Set)?, NoError> = self.chatListDisplayNode.chatListNode.state + let peerIdsAndOptions: Signal<(ChatListSelectionOptions, Set)?, NoError> = self.chatListDisplayNode.containerNode.currentItemState |> map { state -> Set? in if !state.editing { return nil @@ -989,7 +1008,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } } } - toolbar = Toolbar(leftAction: leftAction, rightAction: ToolbarAction(title: presentationData.strings.Common_Delete, isEnabled: options.delete), middleAction: strongSelf.chatListDisplayNode.chatListNode.chatListFilter != nil ? nil : ToolbarAction(title: presentationData.strings.ChatList_ArchiveAction, isEnabled: archiveEnabled)) + toolbar = Toolbar(leftAction: leftAction, rightAction: ToolbarAction(title: presentationData.strings.Common_Delete, isEnabled: options.delete), middleAction: strongSelf.chatListDisplayNode.containerNode.currentItemNode.chatListFilter != nil ? nil : ToolbarAction(title: presentationData.strings.ChatList_ArchiveAction, isEnabled: archiveEnabled)) } } else { if let (options, peerIds) = peerIdsAndOptions { @@ -1007,7 +1026,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.setToolbar(toolbar, transition: .animated(duration: 0.3, curve: .easeInOut)) })) - self.ready.set(self.chatListDisplayNode.chatListNode.ready) + self.ready.set(self.chatListDisplayNode.containerNode.ready) self.displayNodeDidLoad() } @@ -1106,7 +1125,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, })) } - self.chatListDisplayNode.chatListNode.addedVisibleChatsWithPeerIds = { [weak self] peerIds in + self.chatListDisplayNode.containerNode.addedVisibleChatsWithPeerIds = { [weak self] peerIds in guard let strongSelf = self else { return } @@ -1146,7 +1165,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, self.deactivateSearch(animated: false) } - self.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + self.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { @@ -1162,12 +1181,12 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, tabContainerOffset += 44.0 + 44.0 + 44.0 } - transition.updateFrame(node: self.tabContainerNode, frame: CGRect(origin: CGPoint(x: 0.0, y: self.visualNavigationInsetHeight - self.additionalHeight - NavigationBar.defaultSecondaryContentHeight + tabContainerOffset), size: CGSize(width: layout.size.width, height: NavigationBar.defaultSecondaryContentHeight))) - self.tabContainerNode.update(size: CGSize(width: layout.size.width, height: NavigationBar.defaultSecondaryContentHeight), sideInset: layout.safeInsets.left, filters: self.tabContainerData?.0 ?? [], selectedFilter: self.tabContainerData?.1, presentationData: self.presentationData, transition: .animated(duration: 0.4, curve: .spring)) + transition.updateFrame(node: self.tabContainerNode, frame: CGRect(origin: CGPoint(x: 0.0, y: self.visualNavigationInsetHeight - self.additionalHeight - 46.0 + tabContainerOffset), size: CGSize(width: layout.size.width, height: 46.0))) + self.tabContainerNode.update(size: CGSize(width: layout.size.width, height: 46.0), sideInset: layout.safeInsets.left, filters: self.tabContainerData ?? [], selectedFilter: self.chatListDisplayNode.containerNode.currentItemFilter, transitionFraction: self.chatListDisplayNode.containerNode.transitionFraction, presentationData: self.presentationData, transition: .animated(duration: 0.4, curve: .spring)) if let searchContentNode = self.searchContentNode, layout.inVoiceOver != wasInVoiceOver { searchContentNode.updateListVisibleContentOffset(.known(0.0)) - self.chatListDisplayNode.chatListNode.scrollToPosition(.top) + self.chatListDisplayNode.scrollToTop() } self.chatListDisplayNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, visualNavigationHeight: self.visualNavigationInsetHeight, cleanNavigationBarHeight: self.cleanNavigationHeight, transition: transition) @@ -1189,7 +1208,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } self.searchContentNode?.setIsEnabled(false, animated: true) - self.chatListDisplayNode.chatListNode.updateState { state in + self.chatListDisplayNode.containerNode.updateState { state in var state = state state.editing = true state.peerIdWithRevealedOptions = nil @@ -1207,7 +1226,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } (self.navigationController as? NavigationController)?.updateMasterDetailsBlackout(nil, transition: .animated(duration: 0.4, curve: .spring)) self.searchContentNode?.setIsEnabled(true, animated: true) - self.chatListDisplayNode.chatListNode.updateState { state in + self.chatListDisplayNode.containerNode.updateState { state in var state = state state.editing = false state.peerIdWithRevealedOptions = nil @@ -1218,7 +1237,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, public func activateSearch() { if self.displayNavigationBar { - let _ = (self.chatListDisplayNode.chatListNode.contentsReady + let _ = (self.chatListDisplayNode.containerNode.currentItemNode.contentsReady |> take(1) |> deliverOnMainQueue).start(completed: { [weak self] in guard let strongSelf = self else { @@ -1304,10 +1323,10 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return nil } - let listLocation = self.view.convert(location, to: self.chatListDisplayNode.chatListNode.view) + let listLocation = self.view.convert(location, to: self.chatListDisplayNode.containerNode.currentItemNode.view) var selectedNode: ChatListItemNode? - self.chatListDisplayNode.chatListNode.forEachItemNode { itemNode in + self.chatListDisplayNode.containerNode.currentItemNode.forEachItemNode { itemNode in if let itemNode = itemNode as? ChatListItemNode, itemNode.frame.contains(listLocation), !itemNode.isDisplayingRevealedOptions { selectedNode = itemNode } @@ -1347,12 +1366,12 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, chatController.updatePresentationMode(.standard(previewing: false)) if let navigationController = self.navigationController as? NavigationController { self.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, chatController: chatController, context: self.context, chatLocation: chatController.chatLocation, animated: false)) - self.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + self.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } else if let chatListController = viewControllerToCommit as? ChatListController { if let navigationController = self.navigationController as? NavigationController { navigationController.pushViewController(chatListController, animated: false, completion: {}) - self.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + self.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } } @@ -1374,22 +1393,22 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, let inputShortcuts: [KeyShortcut] = [ KeyShortcut(title: strings.KeyCommand_JumpToPreviousChat, input: UIKeyCommand.inputUpArrow, modifiers: [.alternate], action: { [weak self] in if let strongSelf = self { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.previous(unread: false)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.previous(unread: false)) } }), KeyShortcut(title: strings.KeyCommand_JumpToNextChat, input: UIKeyCommand.inputDownArrow, modifiers: [.alternate], action: { [weak self] in if let strongSelf = self { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.next(unread: false)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.next(unread: false)) } }), KeyShortcut(title: strings.KeyCommand_JumpToPreviousUnreadChat, input: UIKeyCommand.inputUpArrow, modifiers: [.alternate, .shift], action: { [weak self] in if let strongSelf = self { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.previous(unread: true)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.previous(unread: true)) } }), KeyShortcut(title: strings.KeyCommand_JumpToNextUnreadChat, input: UIKeyCommand.inputDownArrow, modifiers: [.alternate, .shift], action: { [weak self] in if let strongSelf = self { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.next(unread: true)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.next(unread: true)) } }), KeyShortcut(title: strings.KeyCommand_NewMessage, input: "N", modifiers: [.command], action: { [weak self] in @@ -1404,9 +1423,9 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, let openChat: (Int) -> Void = { [weak self] index in if let strongSelf = self { if index == 0 { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.peerId(strongSelf.context.account.peerId)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.peerId(strongSelf.context.account.peerId)) } else { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.index(index - 1)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.index(index - 1)) } } } @@ -1421,7 +1440,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } override public func toolbarActionSelected(action: ToolbarActionOption) { - let peerIds = self.chatListDisplayNode.chatListNode.currentState.selectedPeerIds + let peerIds = self.chatListDisplayNode.containerNode.currentItemNode.currentState.selectedPeerIds if case .left = action { let signal: Signal let context = self.context @@ -1434,7 +1453,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } else { let groupId = self.groupId signal = self.context.account.postbox.transaction { transaction -> Void in - markAllChatsAsReadInteractively(transaction: transaction, viewTracker: context.account.viewTracker, groupId: groupId, filterPredicate: self.chatListDisplayNode.chatListNode.chatListFilter.flatMap(chatListFilterPredicate)) + markAllChatsAsReadInteractively(transaction: transaction, viewTracker: context.account.viewTracker, groupId: groupId, filterPredicate: (self.chatListDisplayNode.containerNode.currentItemNode.chatListFilter?.data).flatMap(chatListFilterPredicate)) } } let _ = (signal @@ -1451,7 +1470,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return } - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state for peerId in peerIds { state.pendingRemovalPeerIds.insert(peerId) @@ -1495,15 +1514,15 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, |> deliverOnMainQueue).start() return true } else if value == .undo { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds.first!) - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds.first!) + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state for peerId in peerIds { state.pendingRemovalPeerIds.remove(peerId) } return state }) - self?.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds.first!) + self?.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds.first!) return true } return false @@ -1527,7 +1546,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, self.archiveChats(peerIds: Array(peerIds)) } else { if !peerIds.isEmpty { - self.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds.first!) + self.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds.first!) let _ = (self.context.account.postbox.transaction { transaction -> Void in for peerId in peerIds { updatePeerGroupIdInteractively(transaction: transaction, peerId: peerId, groupId: .root) @@ -1537,7 +1556,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) strongSelf.donePressed() }) } @@ -1560,7 +1579,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.updateState { state in + strongSelf.chatListDisplayNode.containerNode.updateState { state in var state = state if value { state.archiveShouldBeTemporaryRevealed = false @@ -1678,7 +1697,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingClearHistoryPeerIds.insert(peer.peerId) return state @@ -1699,7 +1718,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingClearHistoryPeerIds.remove(peer.peerId) return state @@ -1707,7 +1726,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, }) return true } else if value == .undo { - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingClearHistoryPeerIds.remove(peer.peerId) return state @@ -1871,7 +1890,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return } let postbox = self.context.account.postbox - self.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds[0]) + self.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds[0]) let _ = (ApplicationSpecificNotice.incrementArchiveChatTips(accountManager: self.context.sharedContext.accountManager, count: 1) |> deliverOnMainQueue).start(next: { [weak self] previousHintCount in let _ = (postbox.transaction { transaction -> Void in @@ -1883,7 +1902,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) for peerId in peerIds { deleteSendMessageIntents(peerId: peerId) @@ -1894,7 +1913,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return false } if value == .undo { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds[0]) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds[0]) let _ = (postbox.transaction { transaction -> Void in for peerId in peerIds { updatePeerGroupIdInteractively(transaction: transaction, peerId: peerId, groupId: .root) @@ -1904,7 +1923,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) }) return true } else { @@ -1950,13 +1969,13 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } let peerId = peer.peerId - self.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerId) - self.chatListDisplayNode.chatListNode.updateState({ state in + self.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerId) + self.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingRemovalPeerIds.insert(peer.peerId) return state }) - self.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + self.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) let statusText: String if let channel = chatPeer as? TelegramChannel { if deleteGloballyIfPossible { @@ -2000,7 +2019,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return false } if value == .commit { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerId) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerId) if let channel = chatPeer as? TelegramChannel { strongSelf.context.peerChannelMemberCategoriesContextsManager.externallyRemoved(peerId: channel.id, memberId: strongSelf.context.account.peerId) } @@ -2008,25 +2027,25 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingRemovalPeerIds.remove(peer.peerId) return state }) - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) deleteSendMessageIntents(peerId: peerId) }) completion() return true } else if value == .undo { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerId) - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerId) + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingRemovalPeerIds.remove(peer.peerId) return state }) - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) return true } return false @@ -2055,35 +2074,6 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, })) } - public func presentTabBarPreviewingController(sourceNodes: [ASDisplayNode]) { - if self.isNodeLoaded { - let _ = (self.context.account.postbox.transaction { transaction -> [ChatListFilter] in - let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default - return settings.filters - } - |> deliverOnMainQueue).start(next: { [weak self] presetList in - guard let strongSelf = self else { - return - } - let controller = TabBarChatListFilterController(context: strongSelf.context, sourceNodes: sourceNodes, presetList: presetList, currentPreset: strongSelf.chatListDisplayNode.chatListNode.chatListFilter, setup: { - guard let strongSelf = self else { - return - } - strongSelf.push(chatListFilterPresetListController(context: strongSelf.context, updated: { _ in - })) - }, updatePreset: { value in - guard let strongSelf = self else { - return - } - if let value = value { - strongSelf.tabContainerNode.tabSelected?(.filter(value.id)) - } - }) - strongSelf.context.sharedContext.mainWindow?.present(controller, on: .root) - }) - } - } - override public func tabBarItemContextAction(sourceNode: ContextExtractedContentContainingNode, gesture: ContextGesture) { let _ = (combineLatest(queue: .mainQueue(), self.context.account.postbox.transaction { transaction -> [ChatListFilter] in @@ -2121,6 +2111,18 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, }) }))) + if strongSelf.chatListDisplayNode.containerNode.currentItemNode.chatListFilter != nil { + items.append(.action(ContextMenuActionItem(text: "All Chats", icon: { theme in + return nil + }, action: { c, f in + f(.dismissWithoutContent) + guard let strongSelf = self else { + return + } + strongSelf.tabContainerNode.tabSelected?(.all) + }))) + } + if !presetList.isEmpty { items.append(.separator) @@ -2136,25 +2138,25 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, case privateChats } let filterType: ChatListFilterType - if preset.includePeers.isEmpty { - if preset.categories == .all { - if preset.excludeRead { + if preset.data.includePeers.isEmpty { + if preset.data.categories == .all { + if preset.data.excludeRead { filterType = .unread - } else if preset.excludeMuted { + } else if preset.data.excludeMuted { filterType = .unmuted } else { filterType = .generic } } else { - if preset.categories == .channels { + if preset.data.categories == .channels { filterType = .channels - } else if preset.categories.isSubset(of: [.publicGroups, .privateGroups]) { + } else if preset.data.categories.isSubset(of: [.publicGroups, .privateGroups]) { filterType = .groups - } else if preset.categories == .bots { + } else if preset.data.categories == .bots { filterType = .bots - } else if preset.categories == .secretChats { + } else if preset.data.categories == .secretChats { filterType = .secretChats - } else if preset.categories == .privateChats { + } else if preset.data.categories == .privateChats { filterType = .privateChats } else { filterType = .generic @@ -2204,6 +2206,27 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.context.sharedContext.mainWindow?.presentInGlobalOverlay(controller) }) } + + override public func tabBarItemSwipeAction(direction: TabBarItemSwipeDirection) { + guard let entries = self.tabContainerData, var index = entries.index(where: { $0.id == self.chatListDisplayNode.containerNode.currentItemFilter }) else { + return + } + switch direction { + case .right: + if index == 0 { + index = entries.count - 1 + } else { + index -= 1 + } + case .left: + if index == entries.count - 1 { + index = 0 + } else { + index += 1 + } + } + self.tabContainerNode.tabSelected?(entries[index].id) + } } private final class ChatListTabBarContextExtractedContentSource: ContextExtractedContentSource { diff --git a/submodules/ChatListUI/Sources/ChatListControllerNode.swift b/submodules/ChatListUI/Sources/ChatListControllerNode.swift index 4464bf8cfc..6a5ed75585 100644 --- a/submodules/ChatListUI/Sources/ChatListControllerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListControllerNode.swift @@ -26,19 +26,585 @@ private final class ChatListControllerNodeView: UITracingLayerView, PreviewingHo weak var controller: ChatListControllerImpl? } -private struct TestItem: Comparable, Identifiable { - var value: Int - var version: Int +enum ChatListContainerNodeFilter: Equatable { + case all + case filter(ChatListFilter) - var stableId: Int { - return self.value + var id: ChatListFilterTabEntryId { + switch self { + case .all: + return .all + case let .filter(filter): + return .filter(filter.id) + } } - static func <(lhs: TestItem, rhs: TestItem) -> Bool { - if lhs.version != rhs.version { - return lhs.version < rhs.version + var filter: ChatListFilter? { + switch self { + case .all: + return nil + case let .filter(filter): + return filter + } + } +} + +private final class ChatListContainerItemNode: ASDisplayNode { + private var presentationData: PresentationData + private let becameEmpty: (ChatListFilter?) -> Void + private let emptyAction: (ChatListFilter?) -> Void + + private var emptyNode: ChatListEmptyNode? + let listNode: ChatListNode + + private var validLayout: (CGSize, UIEdgeInsets, CGFloat)? + + init(context: AccountContext, groupId: PeerGroupId, filter: ChatListFilter?, previewing: Bool, presentationData: PresentationData, becameEmpty: @escaping (ChatListFilter?) -> Void, emptyAction: @escaping (ChatListFilter?) -> Void) { + self.presentationData = presentationData + self.becameEmpty = becameEmpty + self.emptyAction = emptyAction + + self.listNode = ChatListNode(context: context, groupId: groupId, chatListFilter: filter, previewing: previewing, controlsHistoryPreload: false, mode: .chatList, theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) + + super.init() + + self.addSubnode(self.listNode) + + self.listNode.isEmptyUpdated = { [weak self] isEmptyState, _, _, transition in + guard let strongSelf = self else { + return + } + switch isEmptyState { + case let .empty(isLoading): + if let currentNode = strongSelf.emptyNode { + currentNode.updateIsLoading(isLoading) + } else { + let emptyNode = ChatListEmptyNode(isFilter: filter != nil, isLoading: isLoading, theme: strongSelf.presentationData.theme, strings: strongSelf.presentationData.strings, action: { + self?.emptyAction(filter) + }) + strongSelf.emptyNode = emptyNode + strongSelf.addSubnode(emptyNode) + if let (size, insets, _) = strongSelf.validLayout { + let emptyNodeFrame = CGRect(origin: CGPoint(x: 0.0, y: insets.top), size: CGSize(width: size.width, height: size.height - insets.top - insets.bottom)) + emptyNode.frame = emptyNodeFrame + emptyNode.updateLayout(size: emptyNodeFrame.size, transition: .immediate) + } + } + strongSelf.becameEmpty(filter) + case .notEmpty: + if let emptyNode = strongSelf.emptyNode { + strongSelf.emptyNode = nil + transition.updateAlpha(node: emptyNode, alpha: 0.0, completion: { [weak emptyNode] _ in + emptyNode?.removeFromSupernode() + }) + } + } + } + } + + func updatePresentationData(_ presentationData: PresentationData) { + self.presentationData = presentationData + + self.listNode.updateThemeAndStrings(theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) + + self.emptyNode?.updateThemeAndStrings(theme: presentationData.theme, strings: presentationData.strings) + } + + func updateLayout(size: CGSize, insets: UIEdgeInsets, visualNavigationHeight: CGFloat, transition: ContainedViewLayoutTransition) { + self.validLayout = (size, insets, visualNavigationHeight) + + let updateSizeAndInsets = ListViewUpdateSizeAndInsets(size: size, insets: insets, duration: 0.0, curve: .Default(duration: 0.0)) + + transition.updateFrame(node: self.listNode, frame: CGRect(origin: CGPoint(), size: size)) + self.listNode.visualInsets = UIEdgeInsets(top: visualNavigationHeight, left: 0.0, bottom: 0.0, right: 0.0) + self.listNode.updateLayout(transition: .immediate, updateSizeAndInsets: updateSizeAndInsets) + + if let emptyNode = self.emptyNode { + let emptyNodeFrame = CGRect(origin: CGPoint(x: 0.0, y: insets.top), size: CGSize(width: size.width, height: size.height - insets.top - insets.bottom)) + transition.updateFrame(node: emptyNode, frame: emptyNodeFrame) + emptyNode.updateLayout(size: emptyNodeFrame.size, transition: transition) + } + } +} + +final class ChatListContainerNode: ASDisplayNode, UIGestureRecognizerDelegate { + private let context: AccountContext + private let groupId: PeerGroupId + private let previewing: Bool + private let filterBecameEmpty: (ChatListFilter?) -> Void + private let filterEmptyAction: (ChatListFilter?) -> Void + + private var presentationData: PresentationData + + private var itemNodes: [ChatListFilterTabEntryId: ChatListContainerItemNode] = [:] + private var pendingItemNode: (ChatListFilterTabEntryId, ChatListContainerItemNode, Disposable)? + private var availableFilters: [ChatListContainerNodeFilter] = [.all] + private var selectedId: ChatListFilterTabEntryId + + private(set) var transitionFraction: CGFloat = 0.0 + private var disableItemNodeOperationsWhileAnimating: Bool = false + private var validLayout: (layout: ContainerViewLayout, navigationBarHeight: CGFloat, visualNavigationHeight: CGFloat, cleanNavigationBarHeight: CGFloat)? + + private let _ready = Promise() + var ready: Signal { + return _ready.get() + } + + private var currentItemNodeValue: ChatListContainerItemNode? + var currentItemNode: ChatListNode { + return self.currentItemNodeValue!.listNode + } + + private let currentItemStateValue = Promise() + var currentItemState: Signal { + return self.currentItemStateValue.get() + } + + var currentItemFilterUpdated: ((ChatListFilterTabEntryId, CGFloat, ContainedViewLayoutTransition) -> Void)? + var currentItemFilter: ChatListFilterTabEntryId { + return self.currentItemNode.chatListFilter.flatMap { .filter($0.id) } ?? .all + } + + private func applyItemNodeAsCurrent(id: ChatListFilterTabEntryId, itemNode: ChatListContainerItemNode) { + if let previousItemNode = self.currentItemNodeValue { + previousItemNode.listNode.activateSearch = nil + previousItemNode.listNode.presentAlert = nil + previousItemNode.listNode.present = nil + previousItemNode.listNode.toggleArchivedFolderHiddenByDefault = nil + previousItemNode.listNode.deletePeerChat = nil + previousItemNode.listNode.peerSelected = nil + previousItemNode.listNode.groupSelected = nil + previousItemNode.listNode.updatePeerGrouping = nil + previousItemNode.listNode.contentOffsetChanged = nil + previousItemNode.listNode.contentScrollingEnded = nil + previousItemNode.listNode.activateChatPreview = nil + previousItemNode.listNode.addedVisibleChatsWithPeerIds = nil + + previousItemNode.accessibilityElementsHidden = true + } + self.currentItemNodeValue = itemNode + itemNode.accessibilityElementsHidden = false + + itemNode.listNode.activateSearch = { [weak self] in + self?.activateSearch?() + } + itemNode.listNode.presentAlert = { [weak self] text in + self?.presentAlert?(text) + } + itemNode.listNode.present = { [weak self] c in + self?.present?(c) + } + itemNode.listNode.toggleArchivedFolderHiddenByDefault = { [weak self] in + self?.toggleArchivedFolderHiddenByDefault?() + } + itemNode.listNode.deletePeerChat = { [weak self] peerId in + self?.deletePeerChat?(peerId) + } + itemNode.listNode.peerSelected = { [weak self] peerId, a, b in + self?.peerSelected?(peerId, a, b) + } + itemNode.listNode.groupSelected = { [weak self] groupId in + self?.groupSelected?(groupId) + } + itemNode.listNode.updatePeerGrouping = { [weak self] peerId, group in + self?.updatePeerGrouping?(peerId, group) + } + itemNode.listNode.contentOffsetChanged = { [weak self] offset in + self?.contentOffsetChanged?(offset) + } + itemNode.listNode.contentScrollingEnded = { [weak self] listView in + return self?.contentScrollingEnded?(listView) ?? false + } + itemNode.listNode.activateChatPreview = { [weak self] item, sourceNode, gesture in + self?.activateChatPreview?(item, sourceNode, gesture) + } + itemNode.listNode.addedVisibleChatsWithPeerIds = { [weak self] ids in + self?.addedVisibleChatsWithPeerIds?(ids) + } + + self.currentItemStateValue.set(itemNode.listNode.state) + } + + var activateSearch: (() -> Void)? + var presentAlert: ((String) -> Void)? + var present: ((ViewController) -> Void)? + var toggleArchivedFolderHiddenByDefault: (() -> Void)? + var deletePeerChat: ((PeerId) -> Void)? + var peerSelected: ((Peer, Bool, Bool) -> Void)? + var groupSelected: ((PeerGroupId) -> Void)? + var updatePeerGrouping: ((PeerId, Bool) -> Void)? + var contentOffsetChanged: ((ListViewVisibleContentOffset) -> Void)? + var contentScrollingEnded: ((ListView) -> Bool)? + var activateChatPreview: ((ChatListItem, ASDisplayNode, ContextGesture?) -> Void)? + var addedVisibleChatsWithPeerIds: (([PeerId]) -> Void)? + + init(context: AccountContext, groupId: PeerGroupId, previewing: Bool, presentationData: PresentationData, filterBecameEmpty: @escaping (ChatListFilter?) -> Void, filterEmptyAction: @escaping (ChatListFilter?) -> Void) { + self.context = context + self.groupId = groupId + self.previewing = previewing + self.filterBecameEmpty = filterBecameEmpty + self.filterEmptyAction = filterEmptyAction + + self.presentationData = presentationData + + self.selectedId = .all + + super.init() + + let itemNode = ChatListContainerItemNode(context: self.context, groupId: self.groupId, filter: nil, previewing: self.previewing, presentationData: presentationData, becameEmpty: { [weak self] filter in + self?.filterBecameEmpty(filter) + }, emptyAction: { [weak self] filter in + self?.filterEmptyAction(filter) + }) + self.itemNodes[.all] = itemNode + self.addSubnode(itemNode) + + self._ready.set(itemNode.listNode.ready) + + self.applyItemNodeAsCurrent(id: .all, itemNode: itemNode) + + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] _ in + guard let strongSelf = self, let index = strongSelf.availableFilters.index(where: { $0.id == strongSelf.selectedId }) else { + return [] + } + var directions: InteractiveTransitionGestureRecognizerDirections = [.leftCenter, .rightCenter] + if strongSelf.availableFilters.count > 1 { + if index == 0 { + directions.remove(.rightCenter) + } + if index == strongSelf.availableFilters.count - 1 { + directions.remove(.leftCenter) + } + } else { + directions = [] + } + return directions + }) + panRecognizer.delegate = self + panRecognizer.delaysTouchesBegan = false + panRecognizer.cancelsTouchesInView = true + self.view.addGestureRecognizer(panRecognizer) + } + + deinit { + self.pendingItemNode?.2.dispose() + } + + func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldRecognizeSimultaneouslyWith otherGestureRecognizer: UIGestureRecognizer) -> Bool { + return false + } + + func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldBeRequiredToFailBy otherGestureRecognizer: UIGestureRecognizer) -> Bool { + if let _ = otherGestureRecognizer as? InteractiveTransitionGestureRecognizer { + return false + } + if let _ = otherGestureRecognizer as? UIPanGestureRecognizer { + return true + } + return false + } + + @objc private func panGesture(_ recognizer: UIPanGestureRecognizer) { + switch recognizer.state { + case .changed: + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout, let selectedIndex = self.availableFilters.index(where: { $0.id == self.selectedId }) { + let translation = recognizer.translation(in: self.view) + var transitionFraction = translation.x / layout.size.width + if selectedIndex <= 0 { + transitionFraction = min(0.0, transitionFraction) + } + if selectedIndex >= self.availableFilters.count - 1 { + transitionFraction = max(0.0, transitionFraction) + } + self.transitionFraction = transitionFraction + if let currentItemNode = self.currentItemNodeValue { + let isNavigationHidden = currentItemNode.listNode.isNavigationHidden + for (_, itemNode) in self.itemNodes { + if itemNode !== currentItemNode { + itemNode.listNode.adjustScrollOffsetForNavigation(isNavigationHidden: isNavigationHidden) + } + } + } + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + self.currentItemFilterUpdated?(self.currentItemFilter, self.transitionFraction, .immediate) + } + case .cancelled, .ended: + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout, let selectedIndex = self.availableFilters.index(where: { $0.id == self.selectedId }) { + let translation = recognizer.translation(in: self.view) + let velocity = recognizer.velocity(in: self.view) + var directionIsToRight: Bool? + if abs(velocity.x) > 10.0 { + directionIsToRight = velocity.x < 0.0 + } else { + if abs(translation.x) > layout.size.width / 2.0 { + directionIsToRight = translation.x > layout.size.width / 2.0 + } + } + if let directionIsToRight = directionIsToRight { + var updatedIndex = selectedIndex + if directionIsToRight { + updatedIndex = min(updatedIndex + 1, self.availableFilters.count - 1) + } else { + updatedIndex = max(updatedIndex - 1, 0) + } + let switchToId = self.availableFilters[updatedIndex].id + if switchToId != self.selectedId, let itemNode = self.itemNodes[switchToId] { + self.selectedId = switchToId + self.applyItemNodeAsCurrent(id: switchToId, itemNode: itemNode) + } + } + self.transitionFraction = 0.0 + let transition: ContainedViewLayoutTransition = .animated(duration: 0.45, curve: .spring) + self.disableItemNodeOperationsWhileAnimating = true + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: transition) + self.currentItemFilterUpdated?(self.currentItemFilter, self.transitionFraction, transition) + /*transition.updateBounds(node: self, bounds: self.bounds, force: true, completion: { [weak self] _ in + guard let strongSelf = self else { + return + } + strongSelf.disableItemNodeOperationsWhileAnimating = false + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = strongSelf.validLayout { + strongSelf.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + } + })*/ + DispatchQueue.main.async { + self.disableItemNodeOperationsWhileAnimating = false + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout { + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + } + } + } + default: + break + } + } + + func updatePresentationData(_ presentationData: PresentationData) { + self.presentationData = presentationData + + for (_, itemNode) in self.itemNodes { + itemNode.updatePresentationData(presentationData) + } + } + + func playArchiveAnimation() { + if let itemNode = self.itemNodes[self.selectedId] { + itemNode.listNode.forEachVisibleItemNode { node in + if let node = node as? ChatListItemNode { + node.playArchiveAnimation() + } + } + } + } + + func scrollToTop() { + if let itemNode = self.itemNodes[self.selectedId] { + itemNode.listNode.scrollToPosition(.top) + } + } + + func updateSelectedChatLocation(data: ChatLocation?, progress: CGFloat, transition: ContainedViewLayoutTransition) { + for (_, itemNode) in self.itemNodes { + itemNode.listNode.updateSelectedChatLocation(data, progress: progress, transition: transition) + } + } + + func updateState(_ f: (ChatListNodeState) -> ChatListNodeState) { + self.currentItemNode.updateState(f) + let updatedState = self.currentItemNode.currentState + for (id, itemNode) in self.itemNodes { + if id != self.selectedId { + itemNode.listNode.updateState { state in + var state = state + state.editing = updatedState.editing + state.selectedPeerIds = updatedState.selectedPeerIds + return state + } + } + } + } + + func updateAvailableFilters(_ availableFilters: [ChatListContainerNodeFilter]) { + if self.availableFilters != availableFilters { + self.availableFilters = availableFilters + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout { + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + } + } + } + + func switchToFilter(id: ChatListFilterTabEntryId) { + guard let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout else { + return + } + if id != self.selectedId, let index = self.availableFilters.index(where: { $0.id == id }) { + if let itemNode = self.itemNodes[id] { + self.selectedId = id + if let currentItemNode = self.currentItemNodeValue { + itemNode.listNode.adjustScrollOffsetForNavigation(isNavigationHidden: currentItemNode.listNode.isNavigationHidden) + } + self.applyItemNodeAsCurrent(id: id, itemNode: itemNode) + let transition: ContainedViewLayoutTransition = .animated(duration: 0.35, curve: .spring) + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: transition) + self.currentItemFilterUpdated?(self.currentItemFilter, self.transitionFraction, transition) + } else if self.pendingItemNode == nil { + let itemNode = ChatListContainerItemNode(context: self.context, groupId: self.groupId, filter: self.availableFilters[index].filter, previewing: self.previewing, presentationData: self.presentationData, becameEmpty: { [weak self] filter in + self?.filterBecameEmpty(filter) + }, emptyAction: { [weak self] filter in + self?.filterEmptyAction(filter) + }) + let disposable = MetaDisposable() + self.pendingItemNode = (id, itemNode, disposable) + + disposable.set((itemNode.listNode.ready + |> filter { $0 } + |> take(1) + |> deliverOnMainQueue).start(next: { [weak self, weak itemNode] _ in + guard let strongSelf = self, let itemNode = itemNode, itemNode === strongSelf.pendingItemNode?.1 else { + return + } + guard let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = strongSelf.validLayout else { + return + } + strongSelf.pendingItemNode = nil + + let transition: ContainedViewLayoutTransition = .animated(duration: 0.35, curve: .spring) + + if let previousIndex = strongSelf.availableFilters.index(where: { $0.id == strongSelf.selectedId }), let index = strongSelf.availableFilters.index(where: { $0.id == id }) { + let previousId = strongSelf.selectedId + let offsetDirection: CGFloat = index < previousIndex ? 1.0 : -1.0 + let offset = offsetDirection * layout.size.width + + var validNodeIds: [ChatListFilterTabEntryId] = [] + for i in max(0, index - 1) ... min(strongSelf.availableFilters.count - 1, index + 1) { + validNodeIds.append(strongSelf.availableFilters[i].id) + } + + var removeIds: [ChatListFilterTabEntryId] = [] + for (id, _) in strongSelf.itemNodes { + if !validNodeIds.contains(id) { + removeIds.append(id) + } + } + for id in removeIds { + if let itemNode = strongSelf.itemNodes.removeValue(forKey: id) { + if id == previousId { + transition.updateFrame(node: itemNode, frame: itemNode.frame.offsetBy(dx: offset, dy: 0.0), completion: { [weak itemNode] _ in + itemNode?.removeFromSupernode() + }) + } else { + itemNode.removeFromSupernode() + } + } + } + + strongSelf.itemNodes[id] = itemNode + strongSelf.addSubnode(itemNode) + + let itemFrame = CGRect(origin: CGPoint(x: 0.0, y: 0.0), size: layout.size) + itemNode.frame = itemFrame + + transition.animatePositionAdditive(node: itemNode, offset: CGPoint(x: -offset, y: 0.0)) + + var insets = layout.insets(options: [.input]) + insets.top += navigationBarHeight + + insets.left += layout.safeInsets.left + insets.right += layout.safeInsets.right + + itemNode.updateLayout(size: layout.size, insets: insets, visualNavigationHeight: visualNavigationHeight, transition: .immediate) + + strongSelf.selectedId = id + if let currentItemNode = strongSelf.currentItemNodeValue { + itemNode.listNode.adjustScrollOffsetForNavigation(isNavigationHidden: currentItemNode.listNode.isNavigationHidden) + } + strongSelf.applyItemNodeAsCurrent(id: id, itemNode: itemNode) + + strongSelf.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + + strongSelf.currentItemFilterUpdated?(strongSelf.currentItemFilter, strongSelf.transitionFraction, transition) + } + })) + } + } + } + + func update(layout: ContainerViewLayout, navigationBarHeight: CGFloat, visualNavigationHeight: CGFloat, cleanNavigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { + self.validLayout = (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) + + var insets = layout.insets(options: [.input]) + insets.top += navigationBarHeight + + insets.left += layout.safeInsets.left + insets.right += layout.safeInsets.right + + if let selectedIndex = self.availableFilters.index(where: { $0.id == self.selectedId }) { + var validNodeIds: [ChatListFilterTabEntryId] = [] + for i in max(0, selectedIndex - 1) ... min(self.availableFilters.count - 1, selectedIndex + 1) { + let id = self.availableFilters[i].id + validNodeIds.append(id) + + if self.itemNodes[id] == nil && !self.disableItemNodeOperationsWhileAnimating { + let itemNode = ChatListContainerItemNode(context: self.context, groupId: self.groupId, filter: self.availableFilters[i].filter, previewing: self.previewing, presentationData: self.presentationData, becameEmpty: { [weak self] filter in + self?.filterBecameEmpty(filter) + }, emptyAction: { [weak self] filter in + self?.filterEmptyAction(filter) + }) + self.itemNodes[id] = itemNode + } + } + + var removeIds: [ChatListFilterTabEntryId] = [] + var animateSlidingIds: [ChatListFilterTabEntryId] = [] + var slidingOffset: CGFloat? + for (id, itemNode) in self.itemNodes { + if !validNodeIds.contains(id) { + removeIds.append(id) + } + guard let index = self.availableFilters.index(where: { $0.id == id }) else { + continue + } + let indexDistance = CGFloat(index - selectedIndex) + self.transitionFraction + + let wasAdded = itemNode.supernode == nil + var nodeTransition = transition + if wasAdded { + self.addSubnode(itemNode) + nodeTransition = .immediate + } + + let itemFrame = CGRect(origin: CGPoint(x: indexDistance * layout.size.width, y: 0.0), size: layout.size) + if !wasAdded && slidingOffset == nil { + slidingOffset = itemNode.frame.minX - itemFrame.minX + } + nodeTransition.updateFrame(node: itemNode, frame: itemFrame, completion: { [weak self] _ in + guard let strongSelf = self else { + return + } + }) + + itemNode.updateLayout(size: layout.size, insets: insets, visualNavigationHeight: visualNavigationHeight, transition: nodeTransition) + + if wasAdded, case .animated = transition { + animateSlidingIds.append(id) + } + } + if let slidingOffset = slidingOffset { + for id in animateSlidingIds { + if let itemNode = self.itemNodes[id] { + transition.animatePositionAdditive(node: itemNode, offset: CGPoint(x: slidingOffset, y: 0.0), completion: { + }) + } + } + } + if !self.disableItemNodeOperationsWhileAnimating { + for id in removeIds { + if let itemNode = self.itemNodes.removeValue(forKey: id) { + itemNode.removeFromSupernode() + } + } + } } - return lhs.value < rhs.value } } @@ -47,9 +613,7 @@ final class ChatListControllerNode: ASDisplayNode { private let groupId: PeerGroupId private var presentationData: PresentationData - private var chatListEmptyNodeContainer: ChatListEmptyNodeContainer - private var chatListEmptyIndicator: ActivityIndicator? - let chatListNode: ChatListNode + let containerNode: ChatListContainerNode var navigationBar: NavigationBar? weak var controller: ChatListControllerImpl? @@ -78,8 +642,13 @@ final class ChatListControllerNode: ASDisplayNode { self.groupId = groupId self.presentationData = presentationData - self.chatListEmptyNodeContainer = ChatListEmptyNodeContainer(theme: presentationData.theme, strings: presentationData.strings) - self.chatListNode = ChatListNode(context: context, groupId: groupId, chatListFilter: filter, previewing: previewing, controlsHistoryPreload: controlsHistoryPreload, mode: .chatList, theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) + var filterBecameEmpty: ((ChatListFilter?) -> Void)? + var filterEmptyAction: ((ChatListFilter?) -> Void)? + self.containerNode = ChatListContainerNode(context: context, groupId: groupId, previewing: previewing, presentationData: presentationData, filterBecameEmpty: { filter in + filterBecameEmpty?(filter) + }, filterEmptyAction: { filter in + filterEmptyAction?(filter) + }) self.controller = controller @@ -91,35 +660,24 @@ final class ChatListControllerNode: ASDisplayNode { self.backgroundColor = presentationData.theme.chatList.backgroundColor - self.addSubnode(self.chatListNode) - self.addSubnode(self.chatListEmptyNodeContainer) - self.chatListNode.isEmptyUpdated = { [weak self] isEmptyState, isFilter, transitionDirection, transition in + self.addSubnode(self.containerNode) + + self.addSubnode(self.debugListView) + + filterBecameEmpty = { [weak self] _ in guard let strongSelf = self else { return } - switch isEmptyState { - case .empty(false): - if case .group = strongSelf.groupId { - strongSelf.dismissSelf?() - } else { - strongSelf.chatListEmptyNodeContainer.update(state: isEmptyState, isFilter: isFilter, direction: transitionDirection, transition: transition) - } - case .notEmpty(false): - if case .group = strongSelf.groupId { - strongSelf.dismissSelf?() - } else { - strongSelf.chatListEmptyNodeContainer.update(state: isEmptyState, isFilter: isFilter, direction: transitionDirection, transition: transition) - } - default: - strongSelf.chatListEmptyNodeContainer.update(state: isEmptyState, isFilter: isFilter, direction: transitionDirection, transition: transition) + if case .group = strongSelf.groupId { + strongSelf.dismissSelf?() } } - - self.chatListEmptyNodeContainer.action = { [weak self] in - self?.emptyListAction?() + filterEmptyAction = { [weak self] filter in + guard let strongSelf = self else { + return + } + strongSelf.emptyListAction?() } - - self.addSubnode(self.debugListView) } override func didLoad() { @@ -133,9 +691,8 @@ final class ChatListControllerNode: ASDisplayNode { self.backgroundColor = self.presentationData.theme.chatList.backgroundColor - self.chatListNode.updateThemeAndStrings(theme: self.presentationData.theme, fontSize: self.presentationData.listsFontSize, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameSortOrder: self.presentationData.nameSortOrder, nameDisplayOrder: self.presentationData.nameDisplayOrder, disableAnimations: self.presentationData.disableAnimations) + self.containerNode.updatePresentationData(presentationData) self.searchDisplayController?.updatePresentationData(presentationData) - self.chatListEmptyNodeContainer.updateThemeAndStrings(theme: self.presentationData.theme, strings: self.presentationData.strings) if let toolbarNode = self.toolbarNode { toolbarNode.updateTheme(TabBarControllerTheme(rootControllerTheme: self.presentationData.theme)) @@ -194,23 +751,8 @@ final class ChatListControllerNode: ASDisplayNode { }) } - self.chatListNode.bounds = CGRect(x: 0.0, y: 0.0, width: layout.size.width, height: layout.size.height) - self.chatListNode.position = CGPoint(x: layout.size.width / 2.0, y: layout.size.height / 2.0) - - let (duration, curve) = listViewAnimationDurationAndCurve(transition: transition) - let updateSizeAndInsets = ListViewUpdateSizeAndInsets(size: layout.size, insets: insets, duration: duration, curve: curve) - - self.chatListNode.visualInsets = UIEdgeInsets(top: visualNavigationHeight, left: 0.0, bottom: 0.0, right: 0.0) - self.chatListNode.updateLayout(transition: transition, updateSizeAndInsets: updateSizeAndInsets) - - let emptySize = CGSize(width: updateSizeAndInsets.size.width, height: updateSizeAndInsets.size.height - updateSizeAndInsets.insets.top - updateSizeAndInsets.insets.bottom) - transition.updateFrame(node: self.chatListEmptyNodeContainer, frame: CGRect(origin: CGPoint(x: 0.0, y: updateSizeAndInsets.insets.top), size: emptySize)) - self.chatListEmptyNodeContainer.updateLayout(size: emptySize, transition: transition) - - if let chatListEmptyIndicator = self.chatListEmptyIndicator { - let indicatorSize = chatListEmptyIndicator.measure(CGSize(width: 100.0, height: 100.0)) - transition.updateFrame(node: chatListEmptyIndicator, frame: CGRect(origin: CGPoint(x: floor((layout.size.width - indicatorSize.width) / 2.0), y: updateSizeAndInsets.insets.top + floor((layout.size.height - updateSizeAndInsets.insets.top - updateSizeAndInsets.insets.bottom - indicatorSize.height) / 2.0)), size: indicatorSize)) - } + transition.updateFrame(node: self.containerNode, frame: CGRect(origin: CGPoint(), size: layout.size)) + self.containerNode.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: transition) if let searchDisplayController = self.searchDisplayController { searchDisplayController.containerLayoutUpdated(layout, navigationBarHeight: cleanNavigationBarHeight, transition: transition) @@ -242,7 +784,7 @@ final class ChatListControllerNode: ASDisplayNode { requestDeactivateSearch() } }) - self.chatListNode.accessibilityElementsHidden = true + self.containerNode.accessibilityElementsHidden = true self.searchDisplayController?.containerLayoutUpdated(containerLayout, navigationBarHeight: cleanNavigationBarHeight, transition: .immediate) self.searchDisplayController?.activate(insertSubnode: { [weak self, weak placeholderNode] subnode, isSearchBar in @@ -260,23 +802,19 @@ final class ChatListControllerNode: ASDisplayNode { if let searchDisplayController = self.searchDisplayController { searchDisplayController.deactivate(placeholder: placeholderNode, animated: animated) self.searchDisplayController = nil - self.chatListNode.accessibilityElementsHidden = false + self.containerNode.accessibilityElementsHidden = false } } func playArchiveAnimation() { - self.chatListNode.forEachVisibleItemNode { node in - if let node = node as? ChatListItemNode { - node.playArchiveAnimation() - } - } + self.containerNode.playArchiveAnimation() } func scrollToTop() { if let searchDisplayController = self.searchDisplayController { searchDisplayController.contentNode.scrollToTop() } else { - self.chatListNode.scrollToPosition(.top) + self.containerNode.scrollToTop() } } } diff --git a/submodules/ChatListUI/Sources/ChatListFilterPresetController.swift b/submodules/ChatListUI/Sources/ChatListFilterPresetController.swift index c9bdcc3c23..ddf591eb45 100644 --- a/submodules/ChatListUI/Sources/ChatListFilterPresetController.swift +++ b/submodules/ChatListUI/Sources/ChatListFilterPresetController.swift @@ -18,13 +18,15 @@ private final class ChatListFilterPresetControllerArguments { let openAddPeer: () -> Void let deleteAdditionalPeer: (PeerId) -> Void let setPeerIdWithRevealedOptions: (PeerId?, PeerId?) -> Void + let focusOnName: () -> Void - init(context: AccountContext, updateState: @escaping ((ChatListFilterPresetControllerState) -> ChatListFilterPresetControllerState) -> Void, openAddPeer: @escaping () -> Void, deleteAdditionalPeer: @escaping (PeerId) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void) { + init(context: AccountContext, updateState: @escaping ((ChatListFilterPresetControllerState) -> ChatListFilterPresetControllerState) -> Void, openAddPeer: @escaping () -> Void, deleteAdditionalPeer: @escaping (PeerId) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, focusOnName: @escaping () -> Void) { self.context = context self.updateState = updateState self.openAddPeer = openAddPeer self.deleteAdditionalPeer = deleteAdditionalPeer self.setPeerIdWithRevealedOptions = setPeerIdWithRevealedOptions + self.focusOnName = focusOnName } } @@ -168,13 +170,15 @@ private enum ChatListFilterPresetEntry: ItemListNodeEntry { case let .nameHeader(title): return ItemListSectionHeaderItem(presentationData: presentationData, text: title, sectionId: self.section) case let .name(placeholder, value): - return ItemListSingleLineInputItem(presentationData: presentationData, title: NSAttributedString(), text: value, placeholder: placeholder, type: .regular(capitalization: true, autocorrection: false), sectionId: self.section, textUpdated: { value in + return ItemListSingleLineInputItem(presentationData: presentationData, title: NSAttributedString(), text: value, placeholder: placeholder, type: .regular(capitalization: true, autocorrection: false), clearType: .always, sectionId: self.section, textUpdated: { value in arguments.updateState { current in var state = current state.name = value return state } - }, action: {}) + }, action: {}, cleared: { + arguments.focusOnName() + }) case let .typesHeader(text): return ItemListSectionHeaderItem(presentationData: presentationData, text: text, sectionId: self.section) case let .filterPrivateChats(title, value): @@ -276,7 +280,7 @@ private func chatListFilterPresetControllerEntries(presentationData: Presentatio } func chatListFilterAddChatsController(context: AccountContext, filter: ChatListFilter) -> ViewController { - let controller = context.sharedContext.makeContactMultiselectionController(ContactMultiselectionControllerParams(context: context, mode: .peerSelection(searchChatList: true, searchGroups: true, searchChannels: true), options: [])) + let controller = context.sharedContext.makeContactMultiselectionController(ContactMultiselectionControllerParams(context: context, mode: .chatSelection, options: [])) controller.navigationPresentation = .modal let _ = (controller.result |> take(1) @@ -285,7 +289,7 @@ func chatListFilterAddChatsController(context: AccountContext, filter: ChatListF var settings = settings for i in 0 ..< settings.filters.count { if settings.filters[i].id == filter.id { - let previousIncludePeers = settings.filters[i].includePeers + let previousIncludePeers = settings.filters[i].data.includePeers var chatPeerIds: [PeerId] = [] for peerId in peerIds { @@ -296,7 +300,7 @@ func chatListFilterAddChatsController(context: AccountContext, filter: ChatListF break } } - settings.filters[i].includePeers = chatPeerIds + previousIncludePeers.filter { peerId in + settings.filters[i].data.includePeers = chatPeerIds + previousIncludePeers.filter { peerId in return !chatPeerIds.contains(peerId) } } @@ -305,6 +309,8 @@ func chatListFilterAddChatsController(context: AccountContext, filter: ChatListF }) |> deliverOnMainQueue).start(next: { settings in controller?.dismiss() + + let _ = replaceRemoteChatListFilters(account: context.account).start() }) }) return controller @@ -317,7 +323,7 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat } else { initialName = "New Filter" } - let initialState = ChatListFilterPresetControllerState(name: initialName, includeCategories: currentPreset?.categories ?? .all, excludeMuted: currentPreset?.excludeMuted ?? false, excludeRead: currentPreset?.excludeRead ?? false, additionallyIncludePeers: currentPreset?.includePeers ?? []) + let initialState = ChatListFilterPresetControllerState(name: initialName, includeCategories: currentPreset?.data.categories ?? .all, excludeMuted: currentPreset?.data.excludeMuted ?? false, excludeRead: currentPreset?.data.excludeRead ?? false, additionallyIncludePeers: currentPreset?.data.includePeers ?? []) let stateValue = Atomic(value: initialState) let statePromise = ValuePromise(initialState, ignoreRepeated: true) let updateState: ((ChatListFilterPresetControllerState) -> ChatListFilterPresetControllerState) -> Void = { f in @@ -331,6 +337,7 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat var presentControllerImpl: ((ViewController, Any?) -> Void)? var dismissImpl: (() -> Void)? + var focusOnNameImpl: (() -> Void)? let arguments = ChatListFilterPresetControllerArguments( context: context, @@ -338,7 +345,7 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat updateState(f) }, openAddPeer: { - let controller = context.sharedContext.makeContactMultiselectionController(ContactMultiselectionControllerParams(context: context, mode: .peerSelection(searchChatList: true, searchGroups: true, searchChannels: true), options: [])) + let controller = context.sharedContext.makeContactMultiselectionController(ContactMultiselectionControllerParams(context: context, mode: .chatSelection, options: [])) addPeerDisposable.set((controller.result |> take(1) |> deliverOnMainQueue).start(next: { [weak controller] peerIds in @@ -377,6 +384,9 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat } return state } + }, + focusOnName: { + focusOnNameImpl?() } ) @@ -409,7 +419,7 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat }) let rightNavigationButton = ItemListNavigationButton(content: .text(currentPreset == nil ? presentationData.strings.Common_Create : presentationData.strings.Common_Done), style: .bold, enabled: state.isComplete, action: { let state = stateValue.with { $0 } - let preset = ChatListFilter(id: currentPreset?.id ?? -1, title: state.name, categories: state.includeCategories, excludeMuted: state.excludeMuted, excludeRead: state.excludeRead, includePeers: state.additionallyIncludePeers) + let preset = ChatListFilter(id: currentPreset?.id ?? -1, title: state.name, data: ChatListFilterData(categories: state.includeCategories, excludeMuted: state.excludeMuted, excludeRead: state.excludeRead, includePeers: state.additionallyIncludePeers)) let _ = (updateChatListFilterSettingsInteractively(postbox: context.account.postbox, { settings in var preset = preset if currentPreset == nil { @@ -435,6 +445,8 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat |> deliverOnMainQueue).start(next: { settings in updated(settings.filters) dismissImpl?() + + let _ = replaceRemoteChatListFilters(account: context.account).start() }) }) @@ -455,6 +467,16 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat dismissImpl = { [weak controller] in let _ = controller?.dismiss() } + focusOnNameImpl = { [weak controller] in + guard let controller = controller else { + return + } + controller.forEachItemNode { itemNode in + if let itemNode = itemNode as? ItemListSingleLineInputItemNode { + itemNode.focus() + } + } + } return controller } diff --git a/submodules/ChatListUI/Sources/ChatListFilterPresetListController.swift b/submodules/ChatListUI/Sources/ChatListFilterPresetListController.swift index 53b5d67994..b00da48d68 100644 --- a/submodules/ChatListUI/Sources/ChatListFilterPresetListController.swift +++ b/submodules/ChatListUI/Sources/ChatListFilterPresetListController.swift @@ -53,7 +53,7 @@ private enum ChatListFilterPresetListEntryStableId: Hashable { private enum ChatListFilterPresetListEntry: ItemListNodeEntry { case listHeader(String) - case preset(index: Int, title: String?, preset: ChatListFilter, canBeReordered: Bool, canBeDeleted: Bool, isEditing: Bool) + case preset(index: Int, title: String, label: String, preset: ChatListFilter, canBeReordered: Bool, canBeDeleted: Bool, isEditing: Bool) case addItem(text: String, isEditing: Bool) case listFooter(String) @@ -99,8 +99,8 @@ private enum ChatListFilterPresetListEntry: ItemListNodeEntry { switch self { case let .listHeader(text): return ItemListSectionHeaderItem(presentationData: presentationData, text: text, multiline: true, sectionId: self.section) - case let .preset(index, title, preset, canBeReordered, canBeDeleted, isEditing): - return ChatListFilterPresetListItem(presentationData: presentationData, preset: preset, title: title ?? "", editing: ChatListFilterPresetListItemEditing(editable: true, editing: isEditing, revealed: false), canBeReordered: canBeReordered, canBeDeleted: canBeDeleted, sectionId: self.section, action: { + case let .preset(index, title, label, preset, canBeReordered, canBeDeleted, isEditing): + return ChatListFilterPresetListItem(presentationData: presentationData, preset: preset, title: title ?? "", label: label, editing: ChatListFilterPresetListItemEditing(editable: true, editing: isEditing, revealed: false), canBeReordered: canBeReordered, canBeDeleted: canBeDeleted, sectionId: self.section, action: { arguments.openPreset(preset) }, setItemWithRevealedOptions: { lhs, rhs in arguments.setItemWithRevealedOptions(lhs, rhs) @@ -122,14 +122,14 @@ private struct ChatListFilterPresetListControllerState: Equatable { var revealedPreset: Int32? = nil } -private func chatListFilterPresetListControllerEntries(presentationData: PresentationData, state: ChatListFilterPresetListControllerState, filtersState: ChatListFiltersState, settings: ChatListFilterSettings) -> [ChatListFilterPresetListEntry] { +private func chatListFilterPresetListControllerEntries(presentationData: PresentationData, state: ChatListFilterPresetListControllerState, filters: [(ChatListFilter, Int)], settings: ChatListFilterSettings) -> [ChatListFilterPresetListEntry] { var entries: [ChatListFilterPresetListEntry] = [] entries.append(.listHeader("FILTERS")) - for preset in filtersState.filters { - entries.append(.preset(index: entries.count, title: preset.title, preset: preset, canBeReordered: filtersState.filters.count > 1, canBeDeleted: true, isEditing: state.isEditing)) + for (filter, chatCount) in filters { + entries.append(.preset(index: entries.count, title: filter.title, label: chatCount == 0 ? "" : "\(chatCount)", preset: filter, canBeReordered: filters.count > 1, canBeDeleted: true, isEditing: state.isEditing)) } - if filtersState.filters.count < 10 { + if filters.count < 10 { entries.append(.addItem(text: "Create New Filter", isEditing: state.isEditing)) } entries.append(.listFooter("Tap \"Edit\" to change the order or delete filters.")) @@ -137,7 +137,7 @@ private func chatListFilterPresetListControllerEntries(presentationData: Present return entries } -func chatListFilterPresetListController(context: AccountContext, updated: @escaping ([ChatListFilter]) -> Void) -> ViewController { +public func chatListFilterPresetListController(context: AccountContext, updated: @escaping ([ChatListFilter]) -> Void) -> ViewController { let initialState = ChatListFilterPresetListControllerState() let statePromise = ValuePromise(initialState, ignoreRepeated: true) let stateValue = Atomic(value: initialState) @@ -171,21 +171,51 @@ func chatListFilterPresetListController(context: AccountContext, updated: @escap }) |> deliverOnMainQueue).start(next: { settings in updated(settings.filters) + + let _ = replaceRemoteChatListFilters(account: context.account).start() }) }) - let preferences = context.account.postbox.preferencesView(keys: [PreferencesKeys.chatListFilters, ApplicationSpecificPreferencesKeys.chatListFilterSettings]) + let chatCountCache = Atomic<[ChatListFilterData: Int]>(value: [:]) + + let filtersWithCounts = context.account.postbox.preferencesView(keys: [PreferencesKeys.chatListFilters]) + |> map { preferences -> [ChatListFilter] in + let filtersState = preferences.values[PreferencesKeys.chatListFilters] as? ChatListFiltersState ?? ChatListFiltersState.default + return filtersState.filters + } + |> distinctUntilChanged + |> mapToSignal { filters -> Signal<[(ChatListFilter, Int)], NoError> in + return context.account.postbox.transaction { transaction -> [(ChatListFilter, Int)] in + return filters.map { filter -> (ChatListFilter, Int) in + let count: Int + if let cachedValue = chatCountCache.with({ dict -> Int? in + return dict[filter.data] + }) { + count = cachedValue + } else { + count = transaction.getChatCountMatchingPredicate(chatListFilterPredicate(filter: filter.data)) + let _ = chatCountCache.modify { dict in + var dict = dict + dict[filter.data] = count + return dict + } + } + return (filter, count) + } + } + } + + let preferences = context.account.postbox.preferencesView(keys: [ApplicationSpecificPreferencesKeys.chatListFilterSettings]) let signal = combineLatest(queue: .mainQueue(), context.sharedContext.presentationData, statePromise.get(), + filtersWithCounts, preferences ) - |> map { presentationData, state, preferences -> (ItemListControllerState, (ItemListNodeState, Any)) in - let filtersState = preferences.values[PreferencesKeys.chatListFilters] as? ChatListFiltersState ?? ChatListFiltersState.default + |> map { presentationData, state, filtersWithCounts, preferences -> (ItemListControllerState, (ItemListNodeState, Any)) in let filterSettings = preferences.values[ApplicationSpecificPreferencesKeys.chatListFilterSettings] as? ChatListFilterSettings ?? ChatListFilterSettings.default let leftNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Close), style: .regular, enabled: true, action: { - let _ = replaceRemoteChatListFilters(account: context.account).start() dismissImpl?() }) let rightNavigationButton: ItemListNavigationButton @@ -208,7 +238,7 @@ func chatListFilterPresetListController(context: AccountContext, updated: @escap } let controllerState = ItemListControllerState(presentationData: ItemListPresentationData(presentationData), title: .text("Filters"), leftNavigationButton: leftNavigationButton, rightNavigationButton: rightNavigationButton, backNavigationButton: ItemListBackButton(title: presentationData.strings.Common_Back), animateChanges: false) - let listState = ItemListNodeState(presentationData: ItemListPresentationData(presentationData), entries: chatListFilterPresetListControllerEntries(presentationData: presentationData, state: state, filtersState: filtersState, settings: filterSettings), style: .blocks, animateChanges: true) + let listState = ItemListNodeState(presentationData: ItemListPresentationData(presentationData), entries: chatListFilterPresetListControllerEntries(presentationData: presentationData, state: state, filters: filtersWithCounts, settings: filterSettings), style: .blocks, animateChanges: true) return (controllerState, (listState, arguments)) } @@ -217,6 +247,9 @@ func chatListFilterPresetListController(context: AccountContext, updated: @escap let controller = ItemListController(context: context, state: signal) controller.navigationPresentation = .modal + controller.willDisappear = { _ in + let _ = replaceRemoteChatListFilters(account: context.account).start() + } pushControllerImpl = { [weak controller] c in controller?.push(c) } diff --git a/submodules/ChatListUI/Sources/ChatListFilterPresetListItem.swift b/submodules/ChatListUI/Sources/ChatListFilterPresetListItem.swift index be38d24b1d..d839e97504 100644 --- a/submodules/ChatListUI/Sources/ChatListFilterPresetListItem.swift +++ b/submodules/ChatListUI/Sources/ChatListFilterPresetListItem.swift @@ -20,6 +20,7 @@ final class ChatListFilterPresetListItem: ListViewItem, ItemListItem { let presentationData: ItemListPresentationData let preset: ChatListFilter let title: String + let label: String let editing: ChatListFilterPresetListItemEditing let canBeReordered: Bool let canBeDeleted: Bool @@ -32,6 +33,7 @@ final class ChatListFilterPresetListItem: ListViewItem, ItemListItem { presentationData: ItemListPresentationData, preset: ChatListFilter, title: String, + label: String, editing: ChatListFilterPresetListItemEditing, canBeReordered: Bool, canBeDeleted: Bool, @@ -43,6 +45,7 @@ final class ChatListFilterPresetListItem: ListViewItem, ItemListItem { self.presentationData = presentationData self.preset = preset self.title = title + self.label = label self.editing = editing self.canBeReordered = canBeReordered self.canBeDeleted = canBeDeleted @@ -108,6 +111,8 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN private let maskNode: ASImageNode private let titleNode: TextNode + private let labelNode: TextNode + private let arrowNode: ASImageNode private let activateArea: AccessibilityAreaNode @@ -141,6 +146,14 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN self.titleNode.contentMode = .left self.titleNode.contentsScale = UIScreen.main.scale + self.labelNode = TextNode() + self.labelNode.isUserInteractionEnabled = false + + self.arrowNode = ASImageNode() + self.arrowNode.displayWithoutProcessing = true + self.arrowNode.displaysAsynchronously = false + self.arrowNode.isLayerBacked = true + self.activateArea = AccessibilityAreaNode() self.highlightedBackgroundNode = ASDisplayNode() @@ -149,6 +162,8 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN super.init(layerBacked: false, dynamicBounce: false, rotated: false, seeThrough: false) self.addSubnode(self.titleNode) + self.addSubnode(self.labelNode) + self.addSubnode(self.arrowNode) self.addSubnode(self.activateArea) self.activateArea.activate = { [weak self] in @@ -159,6 +174,7 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN func asyncLayout() -> (_ item: ChatListFilterPresetListItem, _ params: ListViewItemLayoutParams, _ neighbors: ItemListNeighbors) -> (ListViewItemNodeLayout, (Bool) -> Void) { let makeTitleLayout = TextNode.asyncLayout(self.titleNode) + let makeLabelLayout = TextNode.asyncLayout(self.labelNode) let editableControlLayout = ItemListEditableControlNode.asyncLayout(self.editableControlNode) let reorderControlLayout = ItemListEditableReorderControlNode.asyncLayout(self.reorderControlNode) @@ -166,9 +182,11 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN return { item, params, neighbors in var updatedTheme: PresentationTheme? + var updateArrowImage: UIImage? if currentItem?.presentationData.theme !== item.presentationData.theme { updatedTheme = item.presentationData.theme + updateArrowImage = PresentationResourcesItemList.disclosureArrowImage(item.presentationData.theme) } let peerRevealOptions: [ItemListRevealOption] @@ -187,21 +205,27 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN var editingOffset: CGFloat = 0.0 var reorderInset: CGFloat = 0.0 - if item.editing.editing && item.canBeReordered { + if item.editing.editing { let sizeAndApply = editableControlLayout(item.presentationData.theme, false) editableControlSizeAndApply = sizeAndApply editingOffset = sizeAndApply.0 - let reorderSizeAndApply = reorderControlLayout(item.presentationData.theme) - reorderControlSizeAndApply = reorderSizeAndApply - reorderInset = reorderSizeAndApply.0 + if item.canBeReordered { + let reorderSizeAndApply = reorderControlLayout(item.presentationData.theme) + reorderControlSizeAndApply = reorderSizeAndApply + reorderInset = reorderSizeAndApply.0 + } } let leftInset: CGFloat = 16.0 + params.leftInset let rightInset: CGFloat = params.rightInset + max(reorderInset, 55.0) + let rightArrowInset: CGFloat = 34.0 + params.rightInset let (titleLayout, titleApply) = makeTitleLayout(TextNodeLayoutArguments(attributedString: titleAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .middle, constrainedSize: CGSize(width: params.width - leftInset - 12.0 - editingOffset - rightInset, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let labelConstrain: CGFloat = params.width - params.rightInset - leftInset - 40.0 - titleLayout.size.width - 10.0 + let (labelLayout, labelApply) = makeLabelLayout(TextNodeLayoutArguments(attributedString: NSAttributedString(string: item.label, font: titleFont, textColor: item.presentationData.theme.list.itemSecondaryTextColor), backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: labelConstrain, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let insets = itemListNeighborsGroupedInsets(neighbors) let contentSize = CGSize(width: params.width, height: titleLayout.size.height + 11.0 * 2.0) let separatorHeight = UIScreenPixel @@ -280,6 +304,7 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN } let _ = titleApply() + let _ = labelApply() if strongSelf.backgroundNode.supernode == nil { strongSelf.insertSubnode(strongSelf.backgroundNode, at: 0) @@ -326,6 +351,20 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN transition.updateFrame(node: strongSelf.titleNode, frame: CGRect(origin: CGPoint(x: leftInset + revealOffset + editingOffset, y: 11.0), size: titleLayout.size)) + let labelFrame = CGRect(origin: CGPoint(x: params.width - rightArrowInset - labelLayout.size.width, y: 11.0), size: labelLayout.size) + strongSelf.labelNode.frame = labelFrame + + transition.updateAlpha(node: strongSelf.labelNode, alpha: reorderControlSizeAndApply != nil ? 0.0 : 1.0) + transition.updateAlpha(node: strongSelf.arrowNode, alpha: reorderControlSizeAndApply != nil ? 0.0 : 1.0) + + if let updateArrowImage = updateArrowImage { + strongSelf.arrowNode.image = updateArrowImage + } + + if let arrowImage = strongSelf.arrowNode.image { + strongSelf.arrowNode.frame = CGRect(origin: CGPoint(x: params.width - params.rightInset - 7.0 - arrowImage.size.width, y: floorToScreenPixels((layout.contentSize.height - arrowImage.size.height) / 2.0)), size: arrowImage.size) + } + strongSelf.activateArea.frame = CGRect(origin: CGPoint(x: leftInset + revealOffset + editingOffset, y: 0.0), size: CGSize(width: params.width - params.rightInset - 56.0 - (leftInset + revealOffset + editingOffset), height: layout.contentSize.height)) strongSelf.highlightedBackgroundNode.frame = CGRect(origin: CGPoint(x: 0.0, y: -UIScreenPixel), size: CGSize(width: params.width, height: layout.contentSize.height + UIScreenPixel + UIScreenPixel)) diff --git a/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift b/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift index 4d8a690927..1f41a8604c 100644 --- a/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift @@ -257,13 +257,12 @@ final class ChatListFilterTabContainerNode: ASDisplayNode { } } - func update(size: CGSize, sideInset: CGFloat, filters: [ChatListFilterTabEntry], selectedFilter: ChatListFilterTabEntryId?, presentationData: PresentationData, transition: ContainedViewLayoutTransition) { - let focusOnSelectedFilter = self.currentParams?.selectedFilter != selectedFilter - var previousSelectedAbsFrame: CGRect? + private var previousSelectedAbsFrame: CGRect? + private var previousSelectedFrame: CGRect? + + func update(size: CGSize, sideInset: CGFloat, filters: [ChatListFilterTabEntry], selectedFilter: ChatListFilterTabEntryId?, transitionFraction: CGFloat, presentationData: PresentationData, transition: ContainedViewLayoutTransition) { + var focusOnSelectedFilter = self.currentParams?.selectedFilter != selectedFilter let previousScrollBounds = self.scrollNode.bounds - if let currentSelectedFilter = self.currentParams?.selectedFilter, let itemNode = self.itemNodes[currentSelectedFilter] { - previousSelectedAbsFrame = itemNode.frame.offsetBy(dx: -self.scrollNode.bounds.minX, dy: 0.0) - } if self.currentParams?.presentationData.theme !== presentationData.theme { self.selectedLineNode.image = generateImage(CGSize(width: 7.0, height: 4.0), rotatedContext: { size, context in @@ -362,7 +361,7 @@ final class ChatListFilterTabContainerNode: ASDisplayNode { } } - let minSpacing: CGFloat = 30.0 + let minSpacing: CGFloat = 26.0 let sideInset: CGFloat = 16.0 var leftOffset: CGFloat = sideInset @@ -391,7 +390,8 @@ final class ChatListFilterTabContainerNode: ASDisplayNode { self.scrollNode.view.contentSize = CGSize(width: leftOffset - minSpacing + sideInset - 5.0, height: size.height) - let transitionFraction: CGFloat = 0.0 + var previousFrame: CGRect? + var nextFrame: CGRect? var selectedFrame: CGRect? if let selectedFilter = selectedFilter, let currentIndex = filters.index(where: { $0.id == selectedFilter }) { func interpolateFrame(from fromValue: CGRect, to toValue: CGRect, t: CGFloat) -> CGRect { @@ -422,28 +422,41 @@ final class ChatListFilterTabContainerNode: ASDisplayNode { } else { transition.updateFrame(node: self.selectedLineNode, frame: lineFrame) } + if !transitionFraction.isZero { + if previousScrollBounds.minX.isZero { + focusOnSelectedFilter = true + } else if previousScrollBounds.maxX == previousScrollBounds.width { + focusOnSelectedFilter = true + } else if let previousSelectedFrame = self.previousSelectedFrame, abs(previousSelectedFrame.offsetBy(dx: -previousScrollBounds.minX, dy: 0.0).midX - previousScrollBounds.width / 2.0) < 1.0 { + focusOnSelectedFilter = true + } + } if focusOnSelectedFilter { - if selectedFilter == filters.first?.id { + if transitionFraction.isZero && selectedFilter == filters.first?.id { transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(), size: self.scrollNode.bounds.size)) - } else if selectedFilter == filters.last?.id { + } else if transitionFraction.isZero && selectedFilter == filters.last?.id { transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(x: max(0.0, self.scrollNode.view.contentSize.width - self.scrollNode.bounds.width), y: 0.0), size: self.scrollNode.bounds.size)) } else { let contentOffsetX = max(0.0, min(self.scrollNode.view.contentSize.width - self.scrollNode.bounds.width, floor(selectedFrame.midX - self.scrollNode.bounds.width / 2.0))) transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(x: contentOffsetX, y: 0.0), size: self.scrollNode.bounds.size)) } - } else if !wasAdded, let previousSelectedAbsFrame = previousSelectedAbsFrame { + } else if !wasAdded, transitionFraction.isZero, let previousSelectedAbsFrame = self.previousSelectedAbsFrame { let contentOffsetX: CGFloat if previousScrollBounds.minX.isZero { contentOffsetX = 0.0 } else if previousScrollBounds.maxX == previousScrollBounds.width { contentOffsetX = self.scrollNode.view.contentSize.width - self.scrollNode.bounds.width } else { - contentOffsetX = selectedFrame.midX - previousSelectedAbsFrame.midX + contentOffsetX = max(0.0, min(self.scrollNode.view.contentSize.width - self.scrollNode.bounds.width, selectedFrame.midX - previousSelectedAbsFrame.midX)) } transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(x: contentOffsetX, y: 0.0), size: self.scrollNode.bounds.size)) } + self.previousSelectedAbsFrame = selectedFrame.offsetBy(dx: -self.scrollNode.bounds.minX, dy: 0.0) + self.previousSelectedFrame = selectedFrame } else { self.selectedLineNode.isHidden = true + self.previousSelectedAbsFrame = nil + self.previousSelectedFrame = nil } } } diff --git a/submodules/ChatListUI/Sources/Node/ChatListNode.swift b/submodules/ChatListUI/Sources/Node/ChatListNode.swift index 6d2f4b5903..407bfe1421 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListNode.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListNode.swift @@ -17,7 +17,7 @@ import SearchUI public enum ChatListNodeMode { case chatList - case peers(filter: ChatListNodePeersFilter) + case peers(filter: ChatListNodePeersFilter, isSelecting: Bool) } struct ChatListNodeListViewTransition { @@ -153,7 +153,7 @@ private func mappedInsertEntries(context: AccountContext, nodeInteraction: ChatL switch mode { case .chatList: return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, isInFilter: isInFilter, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) - case let .peers(filter): + case let .peers(filter, _): let itemPeer = peer.chatMainPeer var chatPeer: Peer? if let peer = peer.peers[peer.peerId] { @@ -218,7 +218,7 @@ private func mappedInsertEntries(context: AccountContext, nodeInteraction: ChatL } } - return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ContactsPeerItem(presentationData: ItemListPresentationData(theme: presentationData.theme, fontSize: presentationData.fontSize, strings: presentationData.strings), sortOrder: presentationData.nameSortOrder, displayOrder: presentationData.nameDisplayOrder, context: context, peerMode: .generalSearch, peer: .peer(peer: itemPeer, chatPeer: chatPeer), status: .none, enabled: enabled, selection: .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: false), index: nil, header: nil, action: { _ in + return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ContactsPeerItem(presentationData: ItemListPresentationData(theme: presentationData.theme, fontSize: presentationData.fontSize, strings: presentationData.strings), sortOrder: presentationData.nameSortOrder, displayOrder: presentationData.nameDisplayOrder, context: context, peerMode: .generalSearch, peer: .peer(peer: itemPeer, chatPeer: chatPeer), status: .none, enabled: enabled, selection: editing ? .selectable(selected: selected) : .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: false), index: nil, header: nil, action: { _ in if let chatPeer = chatPeer { nodeInteraction.peerSelected(chatPeer) } @@ -245,7 +245,7 @@ private func mappedUpdateEntries(context: AccountContext, nodeInteraction: ChatL switch mode { case .chatList: return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, isInFilter: isInFilter, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) - case let .peers(filter): + case let .peers(filter, _): let itemPeer = peer.chatMainPeer var chatPeer: Peer? if let peer = peer.peers[peer.peerId] { @@ -266,7 +266,7 @@ private func mappedUpdateEntries(context: AccountContext, nodeInteraction: ChatL enabled = false } } - return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ContactsPeerItem(presentationData: ItemListPresentationData(theme: presentationData.theme, fontSize: presentationData.fontSize, strings: presentationData.strings), sortOrder: presentationData.nameSortOrder, displayOrder: presentationData.nameDisplayOrder, context: context, peerMode: .generalSearch, peer: .peer(peer: itemPeer, chatPeer: chatPeer), status: .none, enabled: enabled, selection: .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: false), index: nil, header: nil, action: { _ in + return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ContactsPeerItem(presentationData: ItemListPresentationData(theme: presentationData.theme, fontSize: presentationData.fontSize, strings: presentationData.strings), sortOrder: presentationData.nameSortOrder, displayOrder: presentationData.nameDisplayOrder, context: context, peerMode: .generalSearch, peer: .peer(peer: itemPeer, chatPeer: chatPeer), status: .none, enabled: enabled, selection: editing ? .selectable(selected: selected) : .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: false), index: nil, header: nil, action: { _ in if let chatPeer = chatPeer { nodeInteraction.peerSelected(chatPeer) } @@ -352,7 +352,7 @@ public final class ChatListNode: ListView { return _contentsReady.get() } - public var peerSelected: ((PeerId, Bool, Bool) -> Void)? + public var peerSelected: ((Peer, Bool, Bool) -> Void)? public var disabledPeerSelected: ((Peer) -> Void)? public var groupSelected: ((PeerGroupId) -> Void)? public var addContact: ((String) -> Void)? @@ -373,7 +373,7 @@ public final class ChatListNode: ListView { private var dequeuedInitialTransitionOnLayout = false private var enqueuedTransition: (ChatListNodeListViewTransition, () -> Void)? - private(set) var currentState: ChatListNodeState + public private(set) var currentState: ChatListNodeState private let statePromise: ValuePromise public var state: Signal { return self.statePromise.get() @@ -453,7 +453,12 @@ public final class ChatListNode: ListView { self.controlsHistoryPreload = controlsHistoryPreload self.mode = mode - self.currentState = ChatListNodeState(presentationData: ChatListPresentationData(theme: theme, fontSize: fontSize, strings: strings, dateTimeFormat: dateTimeFormat, nameSortOrder: nameSortOrder, nameDisplayOrder: nameDisplayOrder, disableAnimations: disableAnimations), editing: false, peerIdWithRevealedOptions: nil, selectedPeerIds: Set(), peerInputActivities: nil, pendingRemovalPeerIds: Set(), pendingClearHistoryPeerIds: Set(), archiveShouldBeTemporaryRevealed: false) + var isSelecting = false + if case .peers(_, true) = mode { + isSelecting = true + } + + self.currentState = ChatListNodeState(presentationData: ChatListPresentationData(theme: theme, fontSize: fontSize, strings: strings, dateTimeFormat: dateTimeFormat, nameSortOrder: nameSortOrder, nameDisplayOrder: nameDisplayOrder, disableAnimations: disableAnimations), editing: isSelecting, peerIdWithRevealedOptions: nil, selectedPeerIds: Set(), peerInputActivities: nil, pendingRemovalPeerIds: Set(), pendingClearHistoryPeerIds: Set(), archiveShouldBeTemporaryRevealed: false) self.statePromise = ValuePromise(self.currentState, ignoreRepeated: true) self.theme = theme @@ -471,7 +476,7 @@ public final class ChatListNode: ListView { } }, peerSelected: { [weak self] peer in if let strongSelf = self, let peerSelected = strongSelf.peerSelected { - peerSelected(peer.id, true, false) + peerSelected(peer, true, false) } }, disabledPeerSelected: { [weak self] peer in if let strongSelf = self, let disabledPeerSelected = strongSelf.disabledPeerSelected { @@ -491,7 +496,7 @@ public final class ChatListNode: ListView { } }, messageSelected: { [weak self] peer, message, isAd in if let strongSelf = self, let peerSelected = strongSelf.peerSelected { - peerSelected(peer.id, true, isAd) + peerSelected(peer, true, isAd) } }, groupSelected: { [weak self] groupId in if let strongSelf = self, let groupSelected = strongSelf.groupSelected { @@ -586,7 +591,7 @@ public final class ChatListNode: ListView { let currentRemovingPeerId = self.currentRemovingPeerId let savedMessagesPeer: Signal - if case let .peers(filter) = mode, filter.contains(.onlyWriteable) { + if case let .peers(filter, _) = mode, filter.contains(.onlyWriteable) { savedMessagesPeer = context.account.postbox.loadedPeerWithId(context.account.peerId) |> map(Optional.init) } else { @@ -639,7 +644,7 @@ public final class ChatListNode: ListView { switch mode { case .chatList: return true - case let .peers(filter): + case let .peers(filter, _): guard !filter.contains(.excludeSavedMessages) || peer.peerId != currentPeerId else { return false } guard !filter.contains(.excludeSecretChats) || peer.peerId.namespace != Namespaces.Peer.SecretChat else { return false } guard !filter.contains(.onlyPrivateChats) || peer.peerId.namespace == Namespaces.Peer.CloudUser else { return false } @@ -1422,6 +1427,35 @@ public final class ChatListNode: ListView { } } + var isNavigationHidden: Bool { + switch self.visibleContentOffset() { + case let .known(value) where abs(value) < navigationBarSearchContentHeight: + return false + default: + return true + } + } + + func adjustScrollOffsetForNavigation(isNavigationHidden: Bool) { + if self.isNavigationHidden == isNavigationHidden { + return + } + var scrollToItem: ListViewScrollToItem? + switch self.visibleContentOffset() { + case let .known(value) where abs(value) < navigationBarSearchContentHeight: + if isNavigationHidden { + scrollToItem = ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: false, curve: .Default(duration: 0.0), directionHint: .Up) + } + default: + if !isNavigationHidden { + scrollToItem = ListViewScrollToItem(index: 0, position: .top(0.0), animated: false, curve: .Default(duration: 0.0), directionHint: .Up) + } + } + if let scrollToItem = scrollToItem { + self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous], scrollToItem: scrollToItem, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + } + } + public func updateLayout(transition: ContainedViewLayoutTransition, updateSizeAndInsets: ListViewUpdateSizeAndInsets) { self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous, .LowLatency], scrollToItem: nil, updateSizeAndInsets: updateSizeAndInsets, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) @@ -1524,9 +1558,9 @@ public final class ChatListNode: ListView { } let entryCount = chatListView.filteredEntries.count - var current: (ChatListIndex, PeerId, Int)? = nil - var previous: (ChatListIndex, PeerId)? = nil - var next: (ChatListIndex, PeerId)? = nil + var current: (ChatListIndex, Peer, Int)? = nil + var previous: (ChatListIndex, Peer)? = nil + var next: (ChatListIndex, Peer)? = nil outer: for i in range.firstIndex ..< range.lastIndex { if i < 0 || i >= entryCount { @@ -1536,7 +1570,7 @@ public final class ChatListNode: ListView { switch chatListView.filteredEntries[entryCount - i - 1] { case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _): if interaction.highlightedChatLocation?.location == ChatLocation.peer(peer.peerId) { - current = (index, peer.peerId, entryCount - i - 1) + current = (index, peer.peer!, entryCount - i - 1) break outer } default: @@ -1556,22 +1590,35 @@ public final class ChatListNode: ListView { } else { position = .later(than: nil) } - let _ = (relativeUnreadChatListIndex(position: position) |> deliverOnMainQueue).start(next: { [weak self] index in - guard let strongSelf = self, let index = index else { + let postbox = self.context.account.postbox + let _ = (relativeUnreadChatListIndex(position: position) + |> mapToSignal { index -> Signal<(ChatListIndex, Peer)?, NoError> in + if let index = index { + return postbox.transaction { transaction -> (ChatListIndex, Peer)? in + return transaction.getPeer(index.messageIndex.id.peerId).flatMap { peer -> (ChatListIndex, Peer)? in + (index, peer) + } + } + } else { + return .single(nil) + } + } + |> deliverOnMainQueue).start(next: { [weak self] indexAndPeer in + guard let strongSelf = self, let (index, peer) = indexAndPeer else { return } let location: ChatListNodeLocation = .scroll(index: index, sourceIndex: strongSelf.currentlyVisibleLatestChatListIndex() ?? .absoluteUpperBound, scrollPosition: .center(.top), animated: true, filter: strongSelf.chatListFilter) strongSelf.setChatListLocation(location) - strongSelf.peerSelected?(index.messageIndex.id.peerId, false, false) + strongSelf.peerSelected?(peer, false, false) }) case .previous(unread: false), .next(unread: false): - var target: (ChatListIndex, PeerId)? = nil + var target: (ChatListIndex, Peer)? = nil if let current = current, entryCount > 1 { if current.2 > 0, case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 - 1] { - next = (index, peer.peerId) + next = (index, peer.peer!) } if current.2 <= entryCount - 2, case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 + 1] { - previous = (index, peer.peerId) + previous = (index, peer.peer!) } if case .previous = option { target = previous @@ -1580,7 +1627,7 @@ public final class ChatListNode: ListView { } } else if entryCount > 0 { if case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _) = chatListView.filteredEntries[entryCount - 1] { - target = (index, peer.peerId) + target = (index, peer.peer!) } } if let target = target { @@ -1589,7 +1636,15 @@ public final class ChatListNode: ListView { self.peerSelected?(target.1, false, false) } case let .peerId(peerId): - self.peerSelected?(peerId, false, false) + let _ = (self.context.account.postbox.transaction { transaction -> Peer? in + return transaction.getPeer(peerId) + } + |> deliverOnMainQueue).start(next: { [weak self] peer in + guard let strongSelf = self, let peer = peer else { + return + } + strongSelf.peerSelected?(peer, false, false) + }) case let .index(index): guard index < 10 else { return @@ -1607,7 +1662,7 @@ public final class ChatListNode: ListView { if entries.count > index, case let .MessageEntry(index, _, _, _, _, renderedPeer, _, _, _) = entries[10 - index - 1] { let location: ChatListNodeLocation = .scroll(index: index, sourceIndex: .absoluteLowerBound, scrollPosition: .center(.top), animated: true, filter: filter) self.setChatListLocation(location) - self.peerSelected?(renderedPeer.peerId, false, false) + self.peerSelected?(renderedPeer.peer!, false, false) } }) }) diff --git a/submodules/ChatListUI/Sources/Node/ChatListNodeLocation.swift b/submodules/ChatListUI/Sources/Node/ChatListNodeLocation.swift index 802010adb0..351f9ad159 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListNodeLocation.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListNodeLocation.swift @@ -29,7 +29,7 @@ struct ChatListNodeViewUpdate { let scrollPosition: ChatListNodeViewScrollPosition? } -func chatListFilterPredicate(filter: ChatListFilter) -> ChatListFilterPredicate { +func chatListFilterPredicate(filter: ChatListFilterData) -> ChatListFilterPredicate { let includePeers = Set(filter.includePeers) return ChatListFilterPredicate(includePeerIds: includePeers, include: { peer, notificationSettings, isUnread in if filter.excludeRead { @@ -97,7 +97,7 @@ func chatListFilterPredicate(filter: ChatListFilter) -> ChatListFilterPredicate } func chatListViewForLocation(groupId: PeerGroupId, location: ChatListNodeLocation, account: Account) -> Signal { - let filterPredicate: ChatListFilterPredicate? = location.filter.flatMap(chatListFilterPredicate) + let filterPredicate: ChatListFilterPredicate? = (location.filter?.data).flatMap(chatListFilterPredicate) switch location { case let .initial(count, _): diff --git a/submodules/ChatListUI/Sources/TabBarChatListFilterController.swift b/submodules/ChatListUI/Sources/TabBarChatListFilterController.swift index c02d9656b6..cce754115f 100644 --- a/submodules/ChatListUI/Sources/TabBarChatListFilterController.swift +++ b/submodules/ChatListUI/Sources/TabBarChatListFilterController.swift @@ -320,7 +320,7 @@ func chatListFilterItems(context: AccountContext) -> Signal<(Int, [(ChatListFilt unreadCountItems.append(.total(nil)) var additionalPeerIds = Set() for filter in filters { - additionalPeerIds.formUnion(filter.includePeers) + additionalPeerIds.formUnion(filter.data.includePeers) } if !additionalPeerIds.isEmpty { for peerId in additionalPeerIds { @@ -390,22 +390,22 @@ func chatListFilterItems(context: AccountContext) -> Signal<(Int, [(ChatListFilt var shouldUpdateLayout = false for filter in filters { var tags: [PeerSummaryCounterTags] = [] - if filter.categories.contains(.privateChats) { + if filter.data.categories.contains(.privateChats) { tags.append(.privateChat) } - if filter.categories.contains(.secretChats) { + if filter.data.categories.contains(.secretChats) { tags.append(.secretChat) } - if filter.categories.contains(.privateGroups) { + if filter.data.categories.contains(.privateGroups) { tags.append(.privateGroup) } - if filter.categories.contains(.bots) { + if filter.data.categories.contains(.bots) { tags.append(.bot) } - if filter.categories.contains(.publicGroups) { + if filter.data.categories.contains(.publicGroups) { tags.append(.publicGroup) } - if filter.categories.contains(.channels) { + if filter.data.categories.contains(.channels) { tags.append(.channel) } @@ -417,7 +417,7 @@ func chatListFilterItems(context: AccountContext) -> Signal<(Int, [(ChatListFilt } } } - for peerId in filter.includePeers { + for peerId in filter.data.includePeers { if let (tag, peerCount) = peerTagAndCount[peerId] { if !tags.contains(tag) { if peerCount != 0 { @@ -513,7 +513,7 @@ private final class TabBarChatListFilterControllerNode: ViewControllerTracingNod unreadCountItems.append(.total(nil)) var additionalPeerIds = Set() for preset in presetList { - additionalPeerIds.formUnion(preset.includePeers) + additionalPeerIds.formUnion(preset.data.includePeers) } if !additionalPeerIds.isEmpty { for peerId in additionalPeerIds { @@ -567,22 +567,22 @@ private final class TabBarChatListFilterControllerNode: ViewControllerTracingNod let badgeString: String if let preset = contentNode.preset { var tags: [PeerSummaryCounterTags] = [] - if preset.categories.contains(.privateChats) { + if preset.data.categories.contains(.privateChats) { tags.append(.privateChat) } - if preset.categories.contains(.secretChats) { + if preset.data.categories.contains(.secretChats) { tags.append(.secretChat) } - if preset.categories.contains(.privateGroups) { + if preset.data.categories.contains(.privateGroups) { tags.append(.privateGroup) } - if preset.categories.contains(.bots) { + if preset.data.categories.contains(.bots) { tags.append(.bot) } - if preset.categories.contains(.publicGroups) { + if preset.data.categories.contains(.publicGroups) { tags.append(.publicGroup) } - if preset.categories.contains(.channels) { + if preset.data.categories.contains(.channels) { tags.append(.channel) } @@ -594,7 +594,7 @@ private final class TabBarChatListFilterControllerNode: ViewControllerTracingNod } } } - for peerId in preset.includePeers { + for peerId in preset.data.includePeers { if let (tag, peerCount) = peerTagAndCount[peerId] { if !tags.contains(tag) { count += peerCount diff --git a/submodules/ContextUI/Sources/ContextController.swift b/submodules/ContextUI/Sources/ContextController.swift index f63658522d..e8f603e52c 100644 --- a/submodules/ContextUI/Sources/ContextController.swift +++ b/submodules/ContextUI/Sources/ContextController.swift @@ -747,7 +747,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi self.withoutBlurDimNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: transitionDuration * animationDurationFactor, removeOnCompletion: false) } - self.actionsContainerNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.2 * animationDurationFactor, removeOnCompletion: false, completion: { _ in + self.actionsContainerNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.15 * animationDurationFactor, removeOnCompletion: false, completion: { _ in completedActionsNode = true intermediateCompletion() }) diff --git a/submodules/Display/Source/InteractiveTransitionGestureRecognizer.swift b/submodules/Display/Source/InteractiveTransitionGestureRecognizer.swift index 6462a0d325..ae8af03902 100644 --- a/submodules/Display/Source/InteractiveTransitionGestureRecognizer.swift +++ b/submodules/Display/Source/InteractiveTransitionGestureRecognizer.swift @@ -1,16 +1,23 @@ import Foundation import UIKit -private func hasHorizontalGestures(_ view: UIView, point: CGPoint?) -> Bool { - if view.disablesInteractiveTransitionGestureRecognizer { - return true - } +private enum HorizontalGestures { + case none + case some + case strict +} + +private func hasHorizontalGestures(_ view: UIView, point: CGPoint?) -> HorizontalGestures { if let disablesInteractiveTransitionGestureRecognizerNow = view.disablesInteractiveTransitionGestureRecognizerNow, disablesInteractiveTransitionGestureRecognizerNow() { - return true + return .strict + } + + if view.disablesInteractiveTransitionGestureRecognizer { + return .some } if let point = point, let test = view.interactiveTransitionGestureRecognizerTest, test(point) { - return true + return .some } if let view = view as? ListViewBackingView { @@ -20,14 +27,14 @@ private func hasHorizontalGestures(_ view: UIView, point: CGPoint?) -> Bool { let term2: Double = abs(angle + Double.pi / 2.0) let term3: Double = abs(angle - Double.pi * 3.0 / 2.0) if term1 < 0.001 || term2 < 0.001 || term3 < 0.001 { - return true + return .some } } if let superview = view.superview { return hasHorizontalGestures(superview, point: point != nil ? view.convert(point!, to: superview) : nil) } else { - return false + return .none } } @@ -38,18 +45,23 @@ public struct InteractiveTransitionGestureRecognizerDirections: OptionSet { self.rawValue = rawValue } - public static let left = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 0) - public static let right = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 1) + public static let leftEdge = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 2) + public static let rightEdge = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 3) + public static let leftCenter = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 0) + public static let rightCenter = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 1) + + public static let left: InteractiveTransitionGestureRecognizerDirections = [.leftEdge, .leftCenter] + public static let right: InteractiveTransitionGestureRecognizerDirections = [.rightEdge, .rightCenter] } public class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { - private let allowedDirections: () -> InteractiveTransitionGestureRecognizerDirections + private let allowedDirections: (CGPoint) -> InteractiveTransitionGestureRecognizerDirections private var validatedGesture = false private var firstLocation: CGPoint = CGPoint() private var currentAllowedDirections: InteractiveTransitionGestureRecognizerDirections = [] - public init(target: Any?, action: Selector?, allowedDirections: @escaping () -> InteractiveTransitionGestureRecognizerDirections) { + public init(target: Any?, action: Selector?, allowedDirections: @escaping (CGPoint) -> InteractiveTransitionGestureRecognizerDirections) { self.allowedDirections = allowedDirections super.init(target: target, action: action) @@ -65,37 +77,68 @@ public class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { } override public func touchesBegan(_ touches: Set, with event: UIEvent) { - self.currentAllowedDirections = self.allowedDirections() - if self.currentAllowedDirections.isEmpty { + let touch = touches.first! + let point = touch.location(in: self.view) + + var allowedDirections = self.allowedDirections(point) + if allowedDirections.isEmpty { self.state = .failed return } super.touchesBegan(touches, with: event) - let touch = touches.first! - self.firstLocation = touch.location(in: self.view) + self.firstLocation = point if let target = self.view?.hitTest(self.firstLocation, with: event) { - if hasHorizontalGestures(target, point: self.view?.convert(self.firstLocation, to: target)) { - self.state = .cancelled + let horizontalGestures = hasHorizontalGestures(target, point: self.view?.convert(self.firstLocation, to: target)) + switch horizontalGestures { + case .some, .strict: + if case .strict = horizontalGestures { + allowedDirections = [] + } else if allowedDirections.contains(.leftEdge) || allowedDirections.contains(.rightEdge) { + allowedDirections.remove(.leftCenter) + allowedDirections.remove(.rightCenter) + } + case .none: + break } } + + if allowedDirections.isEmpty { + self.state = .failed + } else { + self.currentAllowedDirections = allowedDirections + } } override public func touchesMoved(_ touches: Set, with event: UIEvent) { let location = touches.first!.location(in: self.view) - let translation = CGPoint(x: location.x - firstLocation.x, y: location.y - firstLocation.y) + let translation = CGPoint(x: location.x - self.firstLocation.x, y: location.y - self.firstLocation.y) let absTranslationX: CGFloat = abs(translation.x) let absTranslationY: CGFloat = abs(translation.y) + let size = self.view?.bounds.size ?? CGSize() + let edgeWidth: CGFloat = 20.0 + if !self.validatedGesture { - if self.currentAllowedDirections.contains(.right) && self.firstLocation.x < 16.0 { - self.validatedGesture = true - } else if !self.currentAllowedDirections.contains(.left) && translation.x < 0.0 { + if self.firstLocation.x < edgeWidth && !self.currentAllowedDirections.contains(.rightEdge) { self.state = .failed - } else if !self.currentAllowedDirections.contains(.right) && translation.x > 0.0 { + return + } + if self.firstLocation.x > size.width - edgeWidth && !self.currentAllowedDirections.contains(.leftEdge) { + self.state = .failed + return + } + + if self.currentAllowedDirections.contains(.rightEdge) && self.firstLocation.x < edgeWidth { + self.validatedGesture = true + } else if self.currentAllowedDirections.contains(.leftEdge) && self.firstLocation.x > size.width - edgeWidth { + self.validatedGesture = true + } else if !self.currentAllowedDirections.contains(.leftCenter) && translation.x < 0.0 { + self.state = .failed + } else if !self.currentAllowedDirections.contains(.rightCenter) && translation.x > 0.0 { self.state = .failed } else if absTranslationY > 2.0 && absTranslationY > absTranslationX * 2.0 { self.state = .failed @@ -104,7 +147,7 @@ public class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { } } - if validatedGesture { + if self.validatedGesture { super.touchesMoved(touches, with: event) } } diff --git a/submodules/Display/Source/Navigation/NavigationContainer.swift b/submodules/Display/Source/Navigation/NavigationContainer.swift index c45e446656..b5be8762d8 100644 --- a/submodules/Display/Source/Navigation/NavigationContainer.swift +++ b/submodules/Display/Source/Navigation/NavigationContainer.swift @@ -111,7 +111,7 @@ final class NavigationContainer: ASDisplayNode, UIGestureRecognizerDelegate { override func didLoad() { super.didLoad() - let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] in + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] _ in guard let strongSelf = self, strongSelf.controllers.count > 1 else { return [] } diff --git a/submodules/Display/Source/Navigation/NavigationModalContainer.swift b/submodules/Display/Source/Navigation/NavigationModalContainer.swift index f837e4157a..0447d6eb5b 100644 --- a/submodules/Display/Source/Navigation/NavigationModalContainer.swift +++ b/submodules/Display/Source/Navigation/NavigationModalContainer.swift @@ -91,7 +91,7 @@ final class NavigationModalContainer: ASDisplayNode, UIScrollViewDelegate, UIGes self.scrollNode.view.clipsToBounds = false self.scrollNode.view.delegate = self - let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] in + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] _ in guard let strongSelf = self, !strongSelf.isDismissed else { return [] } diff --git a/submodules/Display/Source/TabBarContollerNode.swift b/submodules/Display/Source/TabBarContollerNode.swift index dee3c1f46a..c84927e88a 100644 --- a/submodules/Display/Source/TabBarContollerNode.swift +++ b/submodules/Display/Source/TabBarContollerNode.swift @@ -25,10 +25,10 @@ final class TabBarControllerNode: ASDisplayNode { } } - init(theme: TabBarControllerTheme, navigationBar: NavigationBar?, itemSelected: @escaping (Int, Bool, [ASDisplayNode]) -> Void, contextAction: @escaping (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void, toolbarActionSelected: @escaping (ToolbarActionOption) -> Void) { + init(theme: TabBarControllerTheme, navigationBar: NavigationBar?, itemSelected: @escaping (Int, Bool, [ASDisplayNode]) -> Void, contextAction: @escaping (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void, swipeAction: @escaping (Int, TabBarItemSwipeDirection) -> Void, toolbarActionSelected: @escaping (ToolbarActionOption) -> Void) { self.theme = theme self.navigationBar = navigationBar - self.tabBarNode = TabBarNode(theme: theme, itemSelected: itemSelected, contextAction: contextAction) + self.tabBarNode = TabBarNode(theme: theme, itemSelected: itemSelected, contextAction: contextAction, swipeAction: swipeAction) self.toolbarActionSelected = toolbarActionSelected super.init() diff --git a/submodules/Display/Source/TabBarController.swift b/submodules/Display/Source/TabBarController.swift index bf48fe944b..73c6c68d34 100644 --- a/submodules/Display/Source/TabBarController.swift +++ b/submodules/Display/Source/TabBarController.swift @@ -240,6 +240,13 @@ open class TabBarController: ViewController { if index >= 0 && index < strongSelf.controllers.count { strongSelf.controllers[index].tabBarItemContextAction(sourceNode: node, gesture: gesture) } + }, swipeAction: { [weak self] index, direction in + guard let strongSelf = self else { + return + } + if index >= 0 && index < strongSelf.controllers.count { + strongSelf.controllers[index].tabBarItemSwipeAction(direction: direction) + } }, toolbarActionSelected: { [weak self] action in self?.currentController?.toolbarActionSelected(action: action) }) diff --git a/submodules/Display/Source/TabBarNode.swift b/submodules/Display/Source/TabBarNode.swift index 4e964e2d9b..76658fb1b6 100644 --- a/submodules/Display/Source/TabBarNode.swift +++ b/submodules/Display/Source/TabBarNode.swift @@ -89,6 +89,11 @@ private func tabBarItemImage(_ image: UIImage?, title: String, backgroundColor: private let badgeFont = Font.regular(13.0) +public enum TabBarItemSwipeDirection { + case left + case right +} + private final class TabBarItemNode: ASDisplayNode { let extractedContainerNode: ContextExtractedContentContainingNode let containerNode: ContextControllerSourceNode @@ -98,6 +103,8 @@ private final class TabBarItemNode: ASDisplayNode { let contextTextImageNode: ASImageNode var contentWidth: CGFloat? + var swiped: ((TabBarItemSwipeDirection) -> Void)? + override init() { self.extractedContainerNode = ContextExtractedContentContainingNode() self.containerNode = ContextControllerSourceNode() @@ -147,6 +154,26 @@ private final class TabBarItemNode: ASDisplayNode { transition.updateAlpha(node: strongSelf.contextImageNode, alpha: isExtracted ? 1.0 : 0.0) transition.updateAlpha(node: strongSelf.contextTextImageNode, alpha: isExtracted ? 1.0 : 0.0) } + + let leftSwipe = UISwipeGestureRecognizer(target: self, action: #selector(self.swipeGesture(_:))) + leftSwipe.direction = .left + self.containerNode.view.addGestureRecognizer(leftSwipe) + let rightSwipe = UISwipeGestureRecognizer(target: self, action: #selector(self.swipeGesture(_:))) + rightSwipe.direction = .right + self.containerNode.view.addGestureRecognizer(rightSwipe) + } + + @objc private func swipeGesture(_ gesture: UISwipeGestureRecognizer) { + if case .ended = gesture.state { + self.containerNode.cancelGesture() + + switch gesture.direction { + case .left: + self.swiped?(.left) + default: + self.swiped?(.right) + } + } } } @@ -174,7 +201,7 @@ private final class TabBarNodeContainer { var selectedImageValue: UIImage? var appliedSelectedImageValue: UIImage? - init(item: TabBarNodeItem, imageNode: TabBarItemNode, updateBadge: @escaping (String) -> Void, updateTitle: @escaping (String, Bool) -> Void, updateImage: @escaping (UIImage?) -> Void, updateSelectedImage: @escaping (UIImage?) -> Void, contextAction: @escaping (ContextExtractedContentContainingNode, ContextGesture) -> Void) { + init(item: TabBarNodeItem, imageNode: TabBarItemNode, updateBadge: @escaping (String) -> Void, updateTitle: @escaping (String, Bool) -> Void, updateImage: @escaping (UIImage?) -> Void, updateSelectedImage: @escaping (UIImage?) -> Void, contextAction: @escaping (ContextExtractedContentContainingNode, ContextGesture) -> Void, swipeAction: @escaping (TabBarItemSwipeDirection) -> Void) { self.item = item.item self.imageNode = imageNode @@ -226,6 +253,9 @@ private final class TabBarNodeContainer { } contextAction(strongSelf.imageNode.extractedContainerNode, gesture) } + imageNode.swiped = { [weak self] direction in + swipeAction(direction) + } imageNode.containerNode.isGestureEnabled = item.hasContext } @@ -270,6 +300,7 @@ class TabBarNode: ASDisplayNode { private let itemSelected: (Int, Bool, [ASDisplayNode]) -> Void private let contextAction: (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void + private let swipeAction: (Int, TabBarItemSwipeDirection) -> Void private var theme: TabBarControllerTheme private var validLayout: (CGSize, CGFloat, CGFloat, CGFloat)? @@ -283,9 +314,10 @@ class TabBarNode: ASDisplayNode { private var tapRecognizer: TapLongTapOrDoubleTapGestureRecognizer? - init(theme: TabBarControllerTheme, itemSelected: @escaping (Int, Bool, [ASDisplayNode]) -> Void, contextAction: @escaping (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void) { + init(theme: TabBarControllerTheme, itemSelected: @escaping (Int, Bool, [ASDisplayNode]) -> Void, contextAction: @escaping (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void, swipeAction: @escaping (Int, TabBarItemSwipeDirection) -> Void) { self.itemSelected = itemSelected self.contextAction = contextAction + self.swipeAction = swipeAction self.theme = theme self.separatorNode = ASDisplayNode() @@ -382,6 +414,8 @@ class TabBarNode: ASDisplayNode { }, contextAction: { [weak self] node, gesture in self?.tapRecognizer?.cancel() self?.contextAction(i, node, gesture) + }, swipeAction: { [weak self] direction in + self?.swipeAction(i, direction) }) if let selectedIndex = self.selectedIndex, selectedIndex == i { let (textImage, contentWidth) = tabBarItemImage(item.item.selectedImage, title: item.item.title ?? "", backgroundColor: .clear, tintColor: self.theme.tabBarSelectedTextColor, horizontal: self.horizontal, imageMode: false, centered: self.centered) diff --git a/submodules/Display/Source/ViewController.swift b/submodules/Display/Source/ViewController.swift index 180bbf22af..1200e0ba38 100644 --- a/submodules/Display/Source/ViewController.swift +++ b/submodules/Display/Source/ViewController.swift @@ -629,6 +629,9 @@ public enum ViewControllerNavigationPresentation { open func tabBarItemContextAction(sourceNode: ContextExtractedContentContainingNode, gesture: ContextGesture) { } + + open func tabBarItemSwipeAction(direction: TabBarItemSwipeDirection) { + } } func traceIsOpaque(layer: CALayer, rect: CGRect) -> Bool { diff --git a/submodules/EncryptionKeyVisualization/BUCK b/submodules/EncryptionKeyVisualization/BUCK index 8fa948603e..72ecc6e1db 100644 --- a/submodules/EncryptionKeyVisualization/BUCK +++ b/submodules/EncryptionKeyVisualization/BUCK @@ -4,17 +4,11 @@ static_library( name = "EncryptionKeyVisualization", srcs = glob([ "Sources/*.swift", - "Sources/*.m", ]), - headers = glob([ - "Sources/*.h", - ], exclude = ["Sources/EncryptionKeyVisualization.h"]), - exported_headers = glob([ - "Sources/*.h", - ], exclude = ["Sources/EncryptionKeyVisualization.h"]), deps = [ "//submodules/TelegramCore:TelegramCore#shared", "//submodules/SyncCore:SyncCore#shared", + "//submodules/EncryptionKeyVisualization/Impl:EncryptionKeyVisualizationImpl", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/EncryptionKeyVisualization/Impl/BUCK b/submodules/EncryptionKeyVisualization/Impl/BUCK new file mode 100644 index 0000000000..19d1462ea0 --- /dev/null +++ b/submodules/EncryptionKeyVisualization/Impl/BUCK @@ -0,0 +1,18 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "EncryptionKeyVisualizationImpl", + srcs = glob([ + "Sources/*.m", + ]), + headers = glob([ + "Sources/*.h", + ]), + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/UIKit.framework", + ], +) diff --git a/submodules/FFMpegBinding/BUCK b/submodules/FFMpegBinding/BUCK new file mode 100644 index 0000000000..b011e6c299 --- /dev/null +++ b/submodules/FFMpegBinding/BUCK @@ -0,0 +1,20 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "FFMpegBinding", + srcs = glob([ + "Sources/*.m", + ]), + headers = glob([ + "Sources/*.h", + ]), + exported_headers = glob([ + "Public/**/*.h", + ]), + deps = [ + "//submodules/ffmpeg:ffmpeg", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + ], +) diff --git a/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift b/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift index dc6f9a1a6f..b95d244833 100644 --- a/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift +++ b/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift @@ -91,6 +91,7 @@ open class ItemListRevealOptionsItemNode: ListViewItemNode, UIGestureRecognizerD let recognizer = ItemListRevealOptionsGestureRecognizer(target: self, action: #selector(self.revealGesture(_:))) self.recognizer = recognizer + recognizer.delegate = self recognizer.allowAnyDirection = self.allowAnyDirection self.view.addGestureRecognizer(recognizer) @@ -100,6 +101,16 @@ open class ItemListRevealOptionsItemNode: ListViewItemNode, UIGestureRecognizerD self.view.addGestureRecognizer(tapRecognizer) self.view.disablesInteractiveTransitionGestureRecognizer = self.allowAnyDirection + + self.view.disablesInteractiveTransitionGestureRecognizerNow = { [weak self] in + guard let strongSelf = self else { + return false + } + if !strongSelf.revealOffset.isZero { + return true + } + return false + } } open func setRevealOptions(_ options: (left: [ItemListRevealOption], right: [ItemListRevealOption])) { diff --git a/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift b/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift index 5b8028f7a9..6173e2adb4 100644 --- a/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift +++ b/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift @@ -45,9 +45,10 @@ public class ItemListSingleLineInputItem: ListViewItem, ItemListItem { let shouldUpdateText: (String) -> Bool let processPaste: ((String) -> String)? let updatedFocus: ((Bool) -> Void)? + let cleared: (() -> Void)? public let tag: ItemListItemTag? - public init(presentationData: ItemListPresentationData, title: NSAttributedString, text: String, placeholder: String, type: ItemListSingleLineInputItemType = .regular(capitalization: true, autocorrection: true), returnKeyType: UIReturnKeyType = .`default`, spacing: CGFloat = 0.0, clearType: ItemListSingleLineInputClearType = .none, enabled: Bool = true, tag: ItemListItemTag? = nil, sectionId: ItemListSectionId, textUpdated: @escaping (String) -> Void, shouldUpdateText: @escaping (String) -> Bool = { _ in return true }, processPaste: ((String) -> String)? = nil, updatedFocus: ((Bool) -> Void)? = nil, action: @escaping () -> Void) { + public init(presentationData: ItemListPresentationData, title: NSAttributedString, text: String, placeholder: String, type: ItemListSingleLineInputItemType = .regular(capitalization: true, autocorrection: true), returnKeyType: UIReturnKeyType = .`default`, spacing: CGFloat = 0.0, clearType: ItemListSingleLineInputClearType = .none, enabled: Bool = true, tag: ItemListItemTag? = nil, sectionId: ItemListSectionId, textUpdated: @escaping (String) -> Void, shouldUpdateText: @escaping (String) -> Bool = { _ in return true }, processPaste: ((String) -> String)? = nil, updatedFocus: ((Bool) -> Void)? = nil, action: @escaping () -> Void, cleared: (() -> Void)? = nil) { self.presentationData = presentationData self.title = title self.text = text @@ -64,6 +65,7 @@ public class ItemListSingleLineInputItem: ListViewItem, ItemListItem { self.processPaste = processPaste self.updatedFocus = updatedFocus self.action = action + self.cleared = cleared } public func nodeConfiguredForParams(async: @escaping (@escaping () -> Void) -> Void, params: ListViewItemLayoutParams, synchronousLoads: Bool, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> (Signal?, (ListViewItemApply) -> Void)) -> Void) { @@ -420,6 +422,7 @@ public class ItemListSingleLineInputItemNode: ListViewItemNode, UITextFieldDeleg @objc private func clearButtonPressed() { self.textNode.textField.text = "" self.textUpdated("") + self.item?.cleared?() } private func textUpdated(_ text: String) { diff --git a/submodules/LegacyComponents/BUCK b/submodules/LegacyComponents/BUCK index d3a3ad444d..732e23594b 100644 --- a/submodules/LegacyComponents/BUCK +++ b/submodules/LegacyComponents/BUCK @@ -3,7 +3,7 @@ load("//Config:buck_rule_macros.bzl", "static_library") apple_resource( name = "LegacyComponentsResources", dirs = [ - "LegacyComponents/Resources/LegacyComponentsResources.bundle", + "Resources/LegacyComponentsResources.bundle", ], visibility = ["PUBLIC"], ) @@ -11,351 +11,17 @@ apple_resource( static_library( name = "LegacyComponents", srcs = glob([ - "LegacyComponents/*.m", - "LegacyComponents/*.mm", - "LegacyComponents/*.c", - "LegacyComponents/*.cpp", + "Sources/*.m", + "Sources/*.mm", + "Sources/*.c", + "Sources/*.cpp", ]), headers = glob([ - "LegacyComponents/*.h", + "Sources/*.h", + ]), + exported_headers = glob([ + "PublicHeaders/**/*.h", ]), - exported_headers = [ - "LegacyComponents/LegacyComponentsGlobals.h", - "LegacyComponents/LegacyComponentsContext.h", - "LegacyComponents/TGLocalization.h", - "LegacyComponents/TGPluralization.h", - "LegacyComponents/TGStringUtils.h", - "LegacyComponents/TGPhoneUtils.h", - "LegacyComponents/NSObject+TGLock.h", - "LegacyComponents/RMPhoneFormat.h", - "LegacyComponents/NSInputStream+TL.h", - "LegacyComponents/TGFont.h", - "LegacyComponents/TGImageUtils.h", - "LegacyComponents/TGDateUtils.h", - "LegacyComponents/Freedom.h", - "LegacyComponents/FreedomUIKit.h", - "LegacyComponents/TGHacks.h", - "LegacyComponents/TGImageBlur.h", - "LegacyComponents/UIDevice+PlatformInfo.h", - "LegacyComponents/TGObserverProxy.h", - "LegacyComponents/TGModernCache.h", - "LegacyComponents/TGMemoryImageCache.h", - "LegacyComponents/LegacyComponentsAccessChecker.h", - "LegacyComponents/TGTimerTarget.h", - "LegacyComponents/TGKeyCommand.h", - "LegacyComponents/TGKeyCommandController.h", - "LegacyComponents/TGWeakDelegate.h", - "LegacyComponents/TGCache.h", - "LegacyComponents/TGLiveUploadInterface.h", - - "LegacyComponents/JNWSpringAnimation.h", - "LegacyComponents/POPAnimationEvent.h", - "LegacyComponents/POPAnimationTracer.h", - "LegacyComponents/POPAnimation.h", - "LegacyComponents/POPBasicAnimation.h", - "LegacyComponents/POPCustomAnimation.h", - "LegacyComponents/POPDecayAnimation.h", - "LegacyComponents/POPPropertyAnimation.h", - "LegacyComponents/POPSpringAnimation.h", - "LegacyComponents/POPGeometry.h", - "LegacyComponents/POPAnimatableProperty.h", - - "LegacyComponents/lmdb.h", - "LegacyComponents/PSLMDBTable.h", - "LegacyComponents/PSLMDBKeyValueStore.h", - "LegacyComponents/PSLMDBKeyValueReaderWriter.h", - "LegacyComponents/PSLMDBKeyValueCursor.h", - - "LegacyComponents/PSCoding.h", - "LegacyComponents/PSData.h", - "LegacyComponents/PSKeyValueCoder.h", - "LegacyComponents/PSKeyValueDecoder.h", - "LegacyComponents/PSKeyValueEncoder.h", - "LegacyComponents/PSKeyValueReader.h", - "LegacyComponents/PSKeyValueStore.h", - "LegacyComponents/PSKeyValueWriter.h", - - "LegacyComponents/TGPeerIdAdapter.h", - "LegacyComponents/TGUser.h", - "LegacyComponents/TGBotInfo.h", - "LegacyComponents/TGBotComandInfo.h", - "LegacyComponents/TGConversation.h", - - "LegacyComponents/TGModernConversationAssociatedInputPanel.h", - "LegacyComponents/TGModernConversationHashtagsAssociatedPanel.h", - "LegacyComponents/TGModernConversationMentionsAssociatedPanel.h", - "LegacyComponents/TGModernConversationAlphacodeAssociatedPanel.h", - "LegacyComponents/TGSuggestionContext.h", - "LegacyComponents/TGAlphacode.h", - - "LegacyComponents/TGTextCheckingResult.h", - "LegacyComponents/TGChannelBannedRights.h", - "LegacyComponents/TGChannelAdminRights.h", - "LegacyComponents/TGDatabaseMessageDraft.h", - "LegacyComponents/TGMessageGroup.h", - "LegacyComponents/TGMessageHole.h", - "LegacyComponents/TGMessageViewCountContentProperty.h", - "LegacyComponents/TGAuthorSignatureMediaAttachment.h", - "LegacyComponents/TGWebDocument.h", - "LegacyComponents/TGInvoiceMediaAttachment.h", - "LegacyComponents/TGGameMediaAttachment.h", - "LegacyComponents/TGViaUserAttachment.h", - "LegacyComponents/TGBotContextResultAttachment.h", - "LegacyComponents/TGMessageEntity.h", - "LegacyComponents/TGMessageEntityBold.h", - "LegacyComponents/TGMessageEntityBotCommand.h", - "LegacyComponents/TGMessageEntityCode.h", - "LegacyComponents/TGMessageEntityEmail.h", - "LegacyComponents/TGMessageEntityHashtag.h", - "LegacyComponents/TGMessageEntityItalic.h", - "LegacyComponents/TGMessageEntityMention.h", - "LegacyComponents/TGMessageEntityMentionName.h", - "LegacyComponents/TGMessageEntityPre.h", - "LegacyComponents/TGMessageEntityTextUrl.h", - "LegacyComponents/TGMessageEntityUrl.h", - "LegacyComponents/TGMessageEntitiesAttachment.h", - "LegacyComponents/TGBotReplyMarkup.h", - "LegacyComponents/TGBotReplyMarkupButton.h", - "LegacyComponents/TGBotReplyMarkupRow.h", - "LegacyComponents/TGReplyMarkupAttachment.h", - "LegacyComponents/TGInstantPage.h", - "LegacyComponents/TGWebPageMediaAttachment.h", - "LegacyComponents/TGAudioMediaAttachment.h", - "LegacyComponents/TGAudioWaveform.h", - "LegacyComponents/TGStickerPackReference.h", - "LegacyComponents/TGDocumentAttributeFilename.h", - "LegacyComponents/TGDocumentAttributeImageSize.h", - "LegacyComponents/TGDocumentAttributeSticker.h", - "LegacyComponents/TGDocumentAttributeVideo.h", - "LegacyComponents/TGDocumentAttributeAnimated.h", - "LegacyComponents/TGDocumentAttributeAudio.h", - "LegacyComponents/TGDocumentMediaAttachment.h", - "LegacyComponents/TGUnsupportedMediaAttachment.h", - "LegacyComponents/TGForwardedMessageMediaAttachment.h", - "LegacyComponents/TGContactMediaAttachment.h", - "LegacyComponents/TGVideoInfo.h", - "LegacyComponents/TGVideoMediaAttachment.h", - "LegacyComponents/TGLocalMessageMetaMediaAttachment.h", - "LegacyComponents/TGLocationMediaAttachment.h", - "LegacyComponents/TGImageMediaAttachment.h", - "LegacyComponents/TGMediaAttachment.h", - "LegacyComponents/TGImageInfo.h", - "LegacyComponents/TGMediaOriginInfo.h", - "LegacyComponents/TGMessage.h", - "LegacyComponents/TGStickerPack.h", - "LegacyComponents/TGStickerAssociation.h", - "LegacyComponents/TGPhotoMaskPosition.h", - - "LegacyComponents/ActionStage.h", - "LegacyComponents/ASActor.h", - "LegacyComponents/ASHandle.h", - "LegacyComponents/ASQueue.h", - "LegacyComponents/ASWatcher.h", - "LegacyComponents/SGraphListNode.h", - "LegacyComponents/SGraphNode.h", - "LegacyComponents/SGraphObjectNode.h", - - "LegacyComponents/TGLabel.h", - "LegacyComponents/TGToolbarButton.h", - "LegacyComponents/UIScrollView+TGHacks.h", - "LegacyComponents/TGAnimationBlockDelegate.h", - "LegacyComponents/TGBackdropView.h", - "LegacyComponents/UIImage+TG.h", - "LegacyComponents/TGStaticBackdropAreaData.h", - "LegacyComponents/TGStaticBackdropImageData.h", - "LegacyComponents/TGImageLuminanceMap.h", - "LegacyComponents/TGFullscreenContainerView.h", - "LegacyComponents/TGDoubleTapGestureRecognizer.h", - "LegacyComponents/TGModernButton.h", - "LegacyComponents/TGModernToolbarButton.h", - "LegacyComponents/TGModernBackToolbarButton.h", - "LegacyComponents/UIControl+HitTestEdgeInsets.h", - "LegacyComponents/TGMenuView.h", - "LegacyComponents/TGImageView.h", - "LegacyComponents/UICollectionView+Utils.h", - "LegacyComponents/TGMessageImageViewOverlayView.h", - "LegacyComponents/TGLetteredAvatarView.h", - "LegacyComponents/TGGradientLabel.h", - "LegacyComponents/TGRemoteImageView.h", - - "LegacyComponents/TGProgressSpinnerView.h", - "LegacyComponents/TGProgressWindow.h", - - "LegacyComponents/TGMenuSheetController.h", - "LegacyComponents/TGMenuSheetButtonItemView.h", - "LegacyComponents/TGMenuSheetCollectionView.h", - "LegacyComponents/TGMenuSheetItemView.h", - "LegacyComponents/TGMenuSheetTitleItemView.h", - "LegacyComponents/TGMenuSheetView.h", - - "LegacyComponents/HPGrowingTextView.h", - "LegacyComponents/HPTextViewInternal.h", - "LegacyComponents/TGInputTextTag.h", - - "LegacyComponents/TGStickerKeyboardTabPanel.h", - - "LegacyComponents/TGItemPreviewController.h", - "LegacyComponents/TGItemPreviewView.h", - "LegacyComponents/TGItemMenuSheetPreviewView.h", - - "LegacyComponents/TGImageManager.h", - "LegacyComponents/TGDataResource.h", - "LegacyComponents/TGImageDataSource.h", - "LegacyComponents/TGImageManagerTask.h", - - "LegacyComponents/TGRTLScreenEdgePanGestureRecognizer.h", - "LegacyComponents/TGNavigationController.h", - "LegacyComponents/TGNavigationBar.h", - "LegacyComponents/TGViewController.h", - "LegacyComponents/TGViewController+TGRecursiveEnumeration.h", - "LegacyComponents/TGOverlayController.h", - "LegacyComponents/TGOverlayControllerWindow.h", - - "LegacyComponents/TGMediaAssetsLibrary.h", - "LegacyComponents/TGMediaAssetsModernLibrary.h", - "LegacyComponents/TGMediaAsset.h", - "LegacyComponents/TGMediaAssetFetchResult.h", - "LegacyComponents/TGMediaAssetFetchResultChange.h", - "LegacyComponents/TGMediaAssetGroup.h", - "LegacyComponents/TGMediaAssetMoment.h", - "LegacyComponents/TGMediaAssetMomentList.h", - "LegacyComponents/TGMediaAssetImageSignals.h", - "LegacyComponents/TGMediaSelectionContext.h", - "LegacyComponents/TGMediaEditingContext.h", - - "LegacyComponents/TGModernGalleryZoomableItemViewContent.h", - "LegacyComponents/TGModernGalleryZoomableScrollView.h", - "LegacyComponents/TGModernGalleryZoomableScrollViewSwipeGestureRecognizer.h", - "LegacyComponents/TGModernGalleryVideoView.h", - "LegacyComponents/TGModernGalleryScrollView.h", - "LegacyComponents/TGModernGalleryItem.h", - "LegacyComponents/TGModernGalleryItemView.h", - "LegacyComponents/TGModernGalleryImageItem.h", - "LegacyComponents/TGModernGalleryImageItemView.h", - "LegacyComponents/TGModernGalleryImageItemImageView.h", - "LegacyComponents/TGModernGalleryEditableItemView.h", - "LegacyComponents/TGModernGallerySelectableItem.h", - "LegacyComponents/TGModernGalleryDefaultFooterAccessoryView.h", - "LegacyComponents/TGModernGalleryDefaultFooterView.h", - "LegacyComponents/TGModernGalleryDefaultHeaderView.h", - "LegacyComponents/TGModernGalleryDefaultInterfaceView.h", - "LegacyComponents/TGModernGalleryInterfaceView.h", - "LegacyComponents/TGModernGalleryImageItemContainerView.h", - "LegacyComponents/TGModernGalleryZoomableItemView.h", - "LegacyComponents/TGModernGalleryModel.h", - "LegacyComponents/TGModernGalleryTransitionView.h", - "LegacyComponents/TGModernGalleryView.h", - "LegacyComponents/TGModernGalleryContainerView.h", - "LegacyComponents/TGModernGalleryEmbeddedStickersHeaderView.h", - "LegacyComponents/TGModernGalleryController.h", - - "LegacyComponents/TGPhotoToolbarView.h", - "LegacyComponents/TGMediaPickerGalleryModel.h", - "LegacyComponents/TGMediaPickerGalleryInterfaceView.h", - "LegacyComponents/TGPhotoEditorController.h", - "LegacyComponents/TGMediaAvatarEditorTransition.h", - - "LegacyComponents/TGPhotoEditorUtils.h", - "LegacyComponents/PGPhotoEditorValues.h", - "LegacyComponents/TGVideoEditAdjustments.h", - "LegacyComponents/AVURLAsset+TGMediaItem.h", - "LegacyComponents/UIImage+TGMediaEditableItem.h", - "LegacyComponents/TGMediaVideoConverter.h", - "LegacyComponents/TGGifConverter.h", - - "LegacyComponents/TGPhotoEditorAnimation.h", - - "LegacyComponents/TGPaintingData.h", - "LegacyComponents/TGPaintUtils.h", - "LegacyComponents/TGPhotoPaintEntity.h", - "LegacyComponents/TGPhotoPaintStickerEntity.h", - "LegacyComponents/TGPaintUndoManager.h", - - "LegacyComponents/PGCamera.h", - "LegacyComponents/PGCameraCaptureSession.h", - "LegacyComponents/PGCameraDeviceAngleSampler.h", - "LegacyComponents/PGCameraMomentSegment.h", - "LegacyComponents/PGCameraMomentSession.h", - "LegacyComponents/PGCameraMovieWriter.h", - "LegacyComponents/PGCameraShotMetadata.h", - "LegacyComponents/PGCameraVolumeButtonHandler.h", - "LegacyComponents/TGCameraPreviewView.h", - "LegacyComponents/TGCameraMainPhoneView.h", - "LegacyComponents/TGCameraMainTabletView.h", - "LegacyComponents/TGCameraMainView.h", - "LegacyComponents/TGCameraFlashActiveView.h", - "LegacyComponents/TGCameraFlashControl.h", - "LegacyComponents/TGCameraFlipButton.h", - "LegacyComponents/TGCameraInterfaceAssets.h", - "LegacyComponents/TGCameraModeControl.h", - "LegacyComponents/TGCameraSegmentsView.h", - "LegacyComponents/TGCameraShutterButton.h", - "LegacyComponents/TGCameraTimeCodeView.h", - "LegacyComponents/TGCameraZoomView.h", - "LegacyComponents/TGCameraPhotoPreviewController.h", - "LegacyComponents/TGCameraController.h", - "LegacyComponents/TGCameraCapturedPhoto.h", - "LegacyComponents/TGCameraCapturedVideo.h", - "LegacyComponents/TGPhotoVideoEditor.h", - - "LegacyComponents/TGModernConversationTitleActivityIndicator.h", - "LegacyComponents/TGEmbedPIPButton.h", - "LegacyComponents/TGEmbedPIPPullArrowView.h", - "LegacyComponents/TGEmbedPlayerState.h", - "LegacyComponents/TGAttachmentCameraView.h", - "LegacyComponents/TGMediaAvatarMenuMixin.h", - "LegacyComponents/TGPassportAttachMenu.h", - "LegacyComponents/TGPassportScanController.h", - "LegacyComponents/TGPassportOCR.h", - "LegacyComponents/TGPassportMRZ.h", - "LegacyComponents/TGPassportICloud.h", - "LegacyComponents/TGEmbedPlayerView.h", - "LegacyComponents/LegacyHTTPRequestOperation.h", - - "LegacyComponents/TGAttachmentCarouselItemView.h", - "LegacyComponents/TGMediaAssetsController.h", - - "LegacyComponents/TGLocationVenue.h", - "LegacyComponents/TGLocationMapViewController.h", - "LegacyComponents/TGLocationPickerController.h", - "LegacyComponents/TGLocationViewController.h", - "LegacyComponents/TGListsTableView.h", - "LegacyComponents/TGSearchBar.h", - "LegacyComponents/TGSearchDisplayMixin.h", - - "LegacyComponents/TGPhotoEditorSliderView.h", - - "LegacyComponents/TGClipboardGalleryMixin.h", - "LegacyComponents/TGClipboardGalleryPhotoItem.h", - "LegacyComponents/TGVideoMessageCaptureController.h", - "LegacyComponents/TGModernConversationInputMicButton.h", - - "LegacyComponents/TGLocationPulseView.h", - "LegacyComponents/TGLocationWavesView.h", - "LegacyComponents/TGLocationLiveElapsedView.h", - "LegacyComponents/TGLocationLiveSessionItemView.h", - - "LegacyComponents/TGTooltipView.h", - - "LegacyComponents/TGCheckButtonView.h", - "LegacyComponents/TGClipboardMenu.h", - "LegacyComponents/TGImagePickerController.h", - "LegacyComponents/TGLegacyCameraController.h", - "LegacyComponents/TGProxyWindow.h", - "LegacyComponents/TGIconSwitchView.h", - - "LegacyComponents/TGModernGalleryEditableItem.h", - "LegacyComponents/TGPhotoEditorButton.h", - - "LegacyComponents/TGActionMediaAttachment.h", - "LegacyComponents/TGReplyMessageMediaAttachment.h", - "LegacyComponents/TGMessageEntityPhone.h", - "LegacyComponents/TGMessageEntityCashtag.h", - "LegacyComponents/TGPIPAblePlayerView.h", - "LegacyComponents/TGEmbedPlayerControls.h", - - "LegacyComponents/TGMediaAssetsUtils.h", - ], deps = [ "//submodules/SSignalKit/SSignalKit:SSignalKit", "//submodules/AppBundle:AppBundle", diff --git a/submodules/LegacyComponents/BUILD b/submodules/LegacyComponents/BUILD index f460ed401b..c58a789540 100644 --- a/submodules/LegacyComponents/BUILD +++ b/submodules/LegacyComponents/BUILD @@ -16,6 +16,7 @@ objc_library( "Sources/*.mm", "Sources/*.c", "Sources/*.cpp", + "Sources/*.h", ]), hdrs = glob([ "PublicHeaders/**/*.h", diff --git a/submodules/LegacyDataImport/BUCK b/submodules/LegacyDataImport/BUCK index 91a8201c15..3ca8359f67 100644 --- a/submodules/LegacyDataImport/BUCK +++ b/submodules/LegacyDataImport/BUCK @@ -4,14 +4,7 @@ static_library( name = "LegacyDataImport", srcs = glob([ "Sources/**/*.swift", - "Sources/*.m", ]), - headers = glob([ - "Sources/*.h", - ], exclude = ["Sources/LegacyDataImport.h"]), - exported_headers = glob([ - "Sources/*.h", - ], exclude = ["Sources/LegacyDataImport.h"]), deps = [ "//submodules/TelegramCore:TelegramCore#shared", "//submodules/SyncCore:SyncCore#shared", @@ -21,6 +14,7 @@ static_library( "//submodules/TelegramUIPreferences:TelegramUIPreferences", "//submodules/RadialStatusNode:RadialStatusNode", "//submodules/LegacyComponents:LegacyComponents", + "//submodules/LegacyDataImport/Impl:LegacyDataImportImpl", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/LegacyDataImport/Impl/BUCK b/submodules/LegacyDataImport/Impl/BUCK new file mode 100644 index 0000000000..4ec9c8c66a --- /dev/null +++ b/submodules/LegacyDataImport/Impl/BUCK @@ -0,0 +1,28 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "LegacyDataImportImpl", + srcs = glob([ + "Sources/*.m", + ]), + headers = glob([ + "Sources/*.h", + ]), + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), + deps = [ + "//submodules/TelegramCore:TelegramCore#shared", + "//submodules/SyncCore:SyncCore#shared", + "//submodules/Postbox:Postbox#shared", + "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit#shared", + "//submodules/TelegramNotices:TelegramNotices", + "//submodules/TelegramUIPreferences:TelegramUIPreferences", + "//submodules/RadialStatusNode:RadialStatusNode", + "//submodules/LegacyComponents:LegacyComponents", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/UIKit.framework", + ], +) diff --git a/submodules/MediaPlayer/BUCK b/submodules/MediaPlayer/BUCK index 9cd33dfe42..e041921605 100644 --- a/submodules/MediaPlayer/BUCK +++ b/submodules/MediaPlayer/BUCK @@ -13,7 +13,7 @@ static_library( "//submodules/AsyncDisplayKit:AsyncDisplayKit#shared", "//submodules/Display:Display#shared", "//submodules/TelegramAudio:TelegramAudio", - "//submodules/FFMpeg:FFMpeg", + "//submodules/FFMpegBinding:FFMpegBinding", "//submodules/RingBuffer:RingBuffer", ], frameworks = [ diff --git a/submodules/OpenSSLEncryptionProvider/BUCK b/submodules/OpenSSLEncryptionProvider/BUCK index b8582ad887..6c38b32dc0 100644 --- a/submodules/OpenSSLEncryptionProvider/BUCK +++ b/submodules/OpenSSLEncryptionProvider/BUCK @@ -9,7 +9,7 @@ static_library( "Sources/**/*.h", ]), exported_headers = glob([ - "Sources/**/*.h", + "PublicHeaders/**/*.h", ]), deps = [ "//submodules/EncryptionProvider:EncryptionProvider", diff --git a/submodules/Opus/BUCK b/submodules/Opus/BUCK index 13c082a367..5d0591fb7f 100644 --- a/submodules/Opus/BUCK +++ b/submodules/Opus/BUCK @@ -33,7 +33,7 @@ static_library( "Sources/**/*.swift", ]), exported_headers = glob([ - "Sources/**/*.h", + "Public/**/*.h", ]), deps = [ ":opus_lib", diff --git a/submodules/OpusBinding/BUCK b/submodules/OpusBinding/BUCK index acebbafd3c..165c852e46 100644 --- a/submodules/OpusBinding/BUCK +++ b/submodules/OpusBinding/BUCK @@ -9,9 +9,9 @@ static_library( headers = { "ogg/ogg.h": "Sources/ogg/ogg.h", "ogg/os_types.h": "Sources/ogg/os_types.h", - "OggOpusReader.h": "Sources/OggOpusReader.h", - "TGDataItem.h": "Sources/TGDataItem.h", - "TGOggOpusWriter.h": "Sources/TGOggOpusWriter.h", + "OggOpusReader.h": "PublicHeaders/OpusBinding/OggOpusReader.h", + "TGDataItem.h": "PublicHeaders/OpusBinding/TGDataItem.h", + "TGOggOpusWriter.h": "PublicHeaders/OpusBinding/TGOggOpusWriter.h", "opusenc/diag_range.h": "Sources/opusenc/diag_range.h", "opusenc/opus_header.h": "Sources/opusenc/opus_header.h", "opusenc/picture.h": "Sources/opusenc/picture.h", @@ -19,11 +19,9 @@ static_library( "opusfile/internal.h": "Sources/opusfile/internal.h", "OpusBinding/opusfile.h": "Sources/opusfile/opusfile.h", }, - exported_headers = [ - "Sources/TGDataItem.h", - "Sources/TGOggOpusWriter.h", - "Sources/OggOpusReader.h", - ], + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), deps = [ "//submodules/Opus:opus", ], diff --git a/submodules/PKCS/BUCK b/submodules/PKCS/BUCK index b699dbded7..e30546631f 100644 --- a/submodules/PKCS/BUCK +++ b/submodules/PKCS/BUCK @@ -9,7 +9,7 @@ static_library( "Sources/**/*.h", ]), exported_headers = glob([ - "Sources/**/*.h", + "PublicHeaders/**/*.h", ]), deps = [ "//submodules/openssl:openssl", diff --git a/submodules/PhotoResources/BUCK b/submodules/PhotoResources/BUCK index 488bc20353..5cf1d06502 100644 --- a/submodules/PhotoResources/BUCK +++ b/submodules/PhotoResources/BUCK @@ -18,7 +18,7 @@ static_library( "//submodules/AccountContext:AccountContext", "//submodules/MediaResources:MediaResources", "//submodules/TelegramUIPreferences:TelegramUIPreferences", - "//submodules/WebP:WebPImage", + "//submodules/WebPBinding:WebPBinding", "//submodules/AppBundle:AppBundle", ], frameworks = [ diff --git a/submodules/Postbox/Sources/ChatListTable.swift b/submodules/Postbox/Sources/ChatListTable.swift index 9252022dce..2e4a9794a9 100644 --- a/submodules/Postbox/Sources/ChatListTable.swift +++ b/submodules/Postbox/Sources/ChatListTable.swift @@ -421,8 +421,8 @@ final class ChatListTable: Table { lowerEntries.append(entry) return .accept } - }, limit: count / 2 + 1) - if lowerEntries.count >= count / 2 + 1 { + }, limit: count + 1) + if lowerEntries.count >= count + 1 { lower = lowerEntries.last lowerEntries.removeLast() } @@ -440,42 +440,12 @@ final class ChatListTable: Table { upperEntries.append(entry) return .accept } - }, limit: count - lowerEntries.count + 1) - if upperEntries.count >= count - lowerEntries.count + 1 { + }, limit: count + 1) + if upperEntries.count >= count + 1 { upper = upperEntries.last upperEntries.removeLast() } - if lowerEntries.count != 0 && lowerEntries.count + upperEntries.count < count { - var additionalLowerEntries: [ChatListIntermediateEntry] = [] - let startEntryType: ChatListEntryType - switch lowerEntries.last! { - case .message: - startEntryType = .message - case .hole: - startEntryType = .hole - } - self.valueBox.filteredRange(self.table, start: self.key(groupId: groupId, index: lowerEntries.last!.index, type: startEntryType), end: self.lowerBound(groupId: groupId), values: { key, value in - let entry = readEntry(groupId: groupId, messageHistoryTable: messageHistoryTable, peerChatInterfaceStateTable: peerChatInterfaceStateTable, key: key, value: value) - if let predicate = predicate { - if predicate(entry) { - additionalLowerEntries.append(entry) - return .accept - } else { - return .skip - } - } else { - additionalLowerEntries.append(entry) - return .accept - } - }, limit: count - lowerEntries.count - upperEntries.count + 1) - if additionalLowerEntries.count >= count - lowerEntries.count + upperEntries.count + 1 { - lower = additionalLowerEntries.last - additionalLowerEntries.removeLast() - } - lowerEntries.append(contentsOf: additionalLowerEntries) - } - var entries: [ChatListIntermediateEntry] = [] entries.append(contentsOf: lowerEntries.reversed()) entries.append(contentsOf: upperEntries) @@ -641,6 +611,25 @@ final class ChatListTable: Table { return entries } + func countWithPredicate(groupId: PeerGroupId, predicate: (PeerId) -> Bool) -> Int { + var result = 0 + self.valueBox.filteredRange(self.table, start: self.lowerBound(groupId: groupId), end: self.upperBound(groupId: groupId), keys: { key in + let (_, _, messageIndex, type) = extractKey(key) + + if type == ChatListEntryType.message.rawValue { + if predicate(messageIndex.id.peerId) { + result += 1 + return .accept + } else { + return .skip + } + } else { + return .skip + } + }, limit: 10000) + return result + } + func getStandalone(peerId: PeerId, messageHistoryTable: MessageHistoryTable) -> ChatListIntermediateEntry? { let index = self.indexTable.get(peerId: peerId) switch index.inclusion { diff --git a/submodules/Postbox/Sources/ChatListView.swift b/submodules/Postbox/Sources/ChatListView.swift index aa70142924..d0a4ea0845 100644 --- a/submodules/Postbox/Sources/ChatListView.swift +++ b/submodules/Postbox/Sources/ChatListView.swift @@ -320,6 +320,7 @@ final class MutableChatListView { fileprivate var additionalItemIds: Set fileprivate var additionalItemEntries: [MutableChatListEntry] fileprivate var additionalMixedItemIds: Set + fileprivate var additionalMixedPinnedItemIds: Set fileprivate var additionalMixedItemEntries: [MutableChatListEntry] fileprivate var earlier: MutableChatListEntry? fileprivate var later: MutableChatListEntry? @@ -340,10 +341,17 @@ final class MutableChatListView { self.additionalItemEntries = [] self.additionalMixedItemEntries = [] self.additionalMixedItemIds = Set() + self.additionalMixedPinnedItemIds = Set() if let filterPredicate = self.filterPredicate { self.additionalMixedItemIds.formUnion(filterPredicate.includePeerIds) + for (itemId, _) in postbox.chatListTable.getPinnedItemIds(groupId: self.groupId, messageHistoryTable: postbox.messageHistoryTable, peerChatInterfaceStateTable: postbox.peerChatInterfaceStateTable) { + switch itemId { + case let .peer(peerId): + self.additionalMixedPinnedItemIds.insert(peerId) + } + } } - for peerId in self.additionalMixedItemIds { + for peerId in self.additionalMixedItemIds.union(self.additionalMixedPinnedItemIds) { if let entry = postbox.chatListTable.getEntry(peerId: peerId, messageHistoryTable: postbox.messageHistoryTable, peerChatInterfaceStateTable: postbox.peerChatInterfaceStateTable) { self.additionalMixedItemEntries.append(MutableChatListEntry(entry, cachedDataTable: postbox.cachedPeerDataTable, readStateTable: postbox.readStateTable, messageHistoryTable: postbox.messageHistoryTable)) } @@ -554,7 +562,7 @@ final class MutableChatListView { if !updatedPeerNotificationSettings.isEmpty { if let filterPredicate = self.filterPredicate { for (peerId, settingsChange) in updatedPeerNotificationSettings { - if let peer = postbox.peerTable.get(peerId) { + if let peer = postbox.peerTable.get(peerId), !self.additionalMixedItemIds.contains(peerId), !self.additionalMixedPinnedItemIds.contains(peerId) { let isUnread = postbox.readStateTable.getCombinedState(peerId)?.isUnread ?? false let wasIncluded = filterPredicate.includes(peer: peer, notificationSettings: settingsChange.0, isUnread: isUnread) let isIncluded = filterPredicate.includes(peer: peer, notificationSettings: settingsChange.1, isUnread: isUnread) @@ -611,6 +619,22 @@ final class MutableChatListView { continue } } + + for i in 0 ..< self.additionalMixedItemEntries.count { + switch self.additionalMixedItemEntries[i] { + case let .MessageEntry(index, message, readState, _, embeddedState, peer, peerPresence, summaryInfo, hasFailed): + var notificationSettingsPeerId = peer.peerId + if let peer = peer.peers[peer.peerId], let associatedPeerId = peer.associatedPeerId { + notificationSettingsPeerId = associatedPeerId + } + if let (_, settings) = updatedPeerNotificationSettings[notificationSettingsPeerId] { + self.additionalMixedItemEntries[i] = .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo, hasFailed) + hasChanges = true + } + default: + continue + } + } } if !transaction.updatedFailedMessagePeerIds.isEmpty { @@ -723,7 +747,7 @@ final class MutableChatListView { hasChanges = true } var updateAdditionalMixedItems = false - for peerId in self.additionalMixedItemIds { + for peerId in self.additionalMixedItemIds.union(self.additionalMixedPinnedItemIds) { if transaction.currentOperationsByPeerId[peerId] != nil { updateAdditionalMixedItems = true } @@ -736,7 +760,7 @@ final class MutableChatListView { } if updateAdditionalMixedItems { self.additionalMixedItemEntries.removeAll() - for peerId in self.additionalMixedItemIds { + for peerId in self.additionalMixedItemIds.union(self.additionalMixedPinnedItemIds) { if let entry = postbox.chatListTable.getEntry(peerId: peerId, messageHistoryTable: postbox.messageHistoryTable, peerChatInterfaceStateTable: postbox.peerChatInterfaceStateTable) { self.additionalMixedItemEntries.append(MutableChatListEntry(entry, cachedDataTable: postbox.cachedPeerDataTable, readStateTable: postbox.readStateTable, messageHistoryTable: postbox.messageHistoryTable)) } @@ -755,6 +779,12 @@ final class MutableChatListView { if !filterPredicate.includes(peer: peer, notificationSettings: postbox.peerNotificationSettingsTable.getEffective(index.messageIndex.id.peerId), isUnread: isUnread) { return false } + if self.additionalMixedItemIds.contains(peer.id) { + return false + } + if self.additionalMixedPinnedItemIds.contains(peer.id) { + return false + } } else { return false } @@ -1076,12 +1106,17 @@ public final class ChatListView { existingIds.insert(messageEntry.0.messageIndex.id.peerId) } } - for entry in mutableView.additionalMixedItemEntries { + loop: for entry in mutableView.additionalMixedItemEntries { if case let .MessageEntry(messageEntry) = entry { if !existingIds.contains(messageEntry.0.messageIndex.id.peerId) { switch entry { case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed): - entries.append(.MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed)) + if let filterPredicate = mutableView.filterPredicate, let peerValue = peer.peer { + if filterPredicate.includes(peer: peerValue, notificationSettings: notificationSettings, isUnread: combinedReadState?.isUnread ?? false) { + existingIds.insert(messageEntry.0.messageIndex.id.peerId) + entries.append(.MessageEntry(ChatListIndex(pinningIndex: nil, messageIndex: index.messageIndex), message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed)) + } + } case let .HoleEntry(hole): entries.append(.HoleEntry(hole)) case .IntermediateMessageEntry: @@ -1104,12 +1139,8 @@ public final class ChatListView { additionalItemEntries.append(.MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed)) case .HoleEntry: assertionFailure() - /*case .GroupReferenceEntry: - assertionFailure()*/ case .IntermediateMessageEntry: assertionFailure() - /*case .IntermediateGroupReferenceEntry: - assertionFailure()*/ } } diff --git a/submodules/Postbox/Sources/Postbox.swift b/submodules/Postbox/Sources/Postbox.swift index 7c837fcf1f..775b063ee8 100644 --- a/submodules/Postbox/Sources/Postbox.swift +++ b/submodules/Postbox/Sources/Postbox.swift @@ -763,6 +763,39 @@ public final class Transaction { } } + public func getChatCountMatchingPredicate(_ predicate: ChatListFilterPredicate) -> Int { + assert(!self.disposed) + guard let postbox = self.postbox else { + return 0 + } + var includedPeerIds: [PeerId: Bool] = [:] + for peerId in predicate.includePeerIds { + includedPeerIds[peerId] = false + } + var count = postbox.chatListTable.countWithPredicate(groupId: .root, predicate: { peerId in + if let peer = postbox.peerTable.get(peerId) { + let isUnread = postbox.readStateTable.getCombinedState(peerId)?.isUnread ?? false + let notificationsPeerId = peer.notificationSettingsPeerId ?? peerId + if predicate.includes(peer: peer, notificationSettings: postbox.peerNotificationSettingsTable.getEffective(notificationsPeerId), isUnread: isUnread) { + includedPeerIds[peer.id] = true + return true + } else { + return false + } + } else { + return false + } + }) + for (peerId, included) in includedPeerIds { + if !included { + if postbox.chatListTable.getPeerChatListIndex(peerId: peerId) != nil { + count += 1 + } + } + } + return count + } + public func legacyGetAccessChallengeData() -> PostboxAccessChallengeData { assert(!self.disposed) if let postbox = self.postbox { @@ -1657,9 +1690,13 @@ public final class Postbox { return { entry in switch entry { case let .message(index, _, _): + if index.pinningIndex != nil { + return false + } if let peer = self.peerTable.get(index.messageIndex.id.peerId) { let isUnread = self.readStateTable.getCombinedState(index.messageIndex.id.peerId)?.isUnread ?? false - if predicate.includes(peer: peer, notificationSettings: self.peerNotificationSettingsTable.getEffective(index.messageIndex.id.peerId), isUnread: isUnread) { + let notificationsPeerId = peer.notificationSettingsPeerId ?? peer.id + if predicate.includes(peer: peer, notificationSettings: self.peerNotificationSettingsTable.getEffective(notificationsPeerId), isUnread: isUnread) { return true } else { return false diff --git a/submodules/Postbox/Sources/SqliteValueBox.swift b/submodules/Postbox/Sources/SqliteValueBox.swift index 9370955ce2..da3048f7e2 100644 --- a/submodules/Postbox/Sources/SqliteValueBox.swift +++ b/submodules/Postbox/Sources/SqliteValueBox.swift @@ -1505,7 +1505,10 @@ public final class SqliteValueBox: ValueBox { public func filteredRange(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, values: (ValueBoxKey, ReadBuffer) -> ValueBoxFilterResult, limit: Int) { var currentStart = start var acceptedCount = 0 - while acceptedCount < limit { + while true { + if limit > 0 && acceptedCount >= limit { + break + } var hadStop = false var lastKey: ValueBoxKey? self.range(table, start: currentStart, end: end, values: { key, value in @@ -1534,6 +1537,41 @@ public final class SqliteValueBox: ValueBox { } } + public func filteredRange(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, keys: (ValueBoxKey) -> ValueBoxFilterResult, limit: Int) { + var currentStart = start + var acceptedCount = 0 + while true { + if limit > 0 && acceptedCount >= limit { + break + } + var hadStop = false + var lastKey: ValueBoxKey? + self.range(table, start: currentStart, end: end, keys: { key in + lastKey = key + let result = keys(key) + switch result { + case .accept: + acceptedCount += 1 + return true + case .skip: + return true + case .stop: + hadStop = true + return false + } + return true + }, limit: limit) + if let lastKey = lastKey { + currentStart = lastKey + } else { + break + } + if hadStop { + break + } + } + } + public func range(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, keys: (ValueBoxKey) -> Bool, limit: Int) { precondition(self.queue.isCurrent()) if let _ = self.tables[table.id] { diff --git a/submodules/Postbox/Sources/ValueBox.swift b/submodules/Postbox/Sources/ValueBox.swift index 08396740e6..bdc4010f1f 100644 --- a/submodules/Postbox/Sources/ValueBox.swift +++ b/submodules/Postbox/Sources/ValueBox.swift @@ -73,6 +73,7 @@ public protocol ValueBox { func range(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, values: (ValueBoxKey, ReadBuffer) -> Bool, limit: Int) func filteredRange(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, values: (ValueBoxKey, ReadBuffer) -> ValueBoxFilterResult, limit: Int) + func filteredRange(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, keys: (ValueBoxKey) -> ValueBoxFilterResult, limit: Int) func range(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, keys: (ValueBoxKey) -> Bool, limit: Int) func scan(_ table: ValueBoxTable, values: (ValueBoxKey, ReadBuffer) -> Bool) func scan(_ table: ValueBoxTable, keys: (ValueBoxKey) -> Bool) diff --git a/submodules/RMIntro/BUCK b/submodules/RMIntro/BUCK index b26aaeaad8..b69acbdcdb 100644 --- a/submodules/RMIntro/BUCK +++ b/submodules/RMIntro/BUCK @@ -8,10 +8,10 @@ static_library( ]), headers = glob([ "Sources/**/*.h", - ], exclude = ["Sources/RMIntro.h"]), + ]), exported_headers = glob([ - "Sources/**/*.h", - ], exclude = ["Sources/RMIntro.h"]), + "PublicHeaders/**/*.h", + ]), deps = [ "//submodules/LegacyComponents:LegacyComponents", ], diff --git a/submodules/RaiseToListen/BUCK b/submodules/RaiseToListen/BUCK index b483bcfd14..ae88e727e0 100644 --- a/submodules/RaiseToListen/BUCK +++ b/submodules/RaiseToListen/BUCK @@ -3,17 +3,10 @@ load("//Config:buck_rule_macros.bzl", "static_library") static_library( name = "RaiseToListen", srcs = glob([ - "Sources/*.m", "Sources/*.swift", ]), - headers = glob([ - "Sources/*.h", - ], exclude = ["Sources/RaiseToListen.h"]), - exported_headers = glob([ - "Sources/*.h", - ], exclude = ["Sources/RaiseToListen.h"]), deps = [ - "//submodules/DeviceProximity:DeviceProximity", + "//submodules/RaiseToListen/Impl:RaiseToListenImpl", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/RaiseToListen/Impl/BUCK b/submodules/RaiseToListen/Impl/BUCK new file mode 100644 index 0000000000..93e01caeeb --- /dev/null +++ b/submodules/RaiseToListen/Impl/BUCK @@ -0,0 +1,21 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "RaiseToListenImpl", + srcs = glob([ + "Sources/**/*.m", + ]), + headers = glob([ + "Sources/**/*.h", + ]), + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), + deps = [ + "//submodules/DeviceProximity:DeviceProximity", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/UIKit.framework", + ], +) diff --git a/submodules/RingBuffer/BUCK b/submodules/RingBuffer/BUCK index 5380c8191d..8896626f86 100644 --- a/submodules/RingBuffer/BUCK +++ b/submodules/RingBuffer/BUCK @@ -1,7 +1,7 @@ load("//Config:buck_rule_macros.bzl", "static_library") static_library( - name = "Crc32", + name = "RingBuffer", srcs = glob([ "Sources/*.m", ]), diff --git a/submodules/SettingsUI/Sources/SettingsController.swift b/submodules/SettingsUI/Sources/SettingsController.swift index 40d1114116..5db7242a96 100644 --- a/submodules/SettingsUI/Sources/SettingsController.swift +++ b/submodules/SettingsUI/Sources/SettingsController.swift @@ -114,6 +114,7 @@ private final class SettingsItemArguments { let openPhoneNumberChange: () -> Void let accountContextAction: (AccountRecordId, ASDisplayNode, ContextGesture?) -> Void let openDevices: () -> Void + let openFilters: () -> Void init( sharedContext: SharedAccountContext, @@ -147,7 +148,8 @@ private final class SettingsItemArguments { keepPhone: @escaping () -> Void, openPhoneNumberChange: @escaping () -> Void, accountContextAction: @escaping (AccountRecordId, ASDisplayNode, ContextGesture?) -> Void, - openDevices: @escaping () -> Void + openDevices: @escaping () -> Void, + openFilters: @escaping () -> Void ) { self.sharedContext = sharedContext self.avatarAndNameInfoContext = avatarAndNameInfoContext @@ -181,6 +183,7 @@ private final class SettingsItemArguments { self.openPhoneNumberChange = openPhoneNumberChange self.accountContextAction = accountContextAction self.openDevices = openDevices + self.openFilters = openFilters } } @@ -211,6 +214,8 @@ private indirect enum SettingsEntry: ItemListNodeEntry { case devices(PresentationTheme, UIImage?, String, String) + case filters(PresentationTheme, UIImage?, String, String) + case savedMessages(PresentationTheme, UIImage?, String) case recentCalls(PresentationTheme, UIImage?, String) case stickers(PresentationTheme, UIImage?, String, String, [ArchivedStickerPackItem]?) @@ -240,7 +245,7 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return SettingsSection.accounts.rawValue case .proxy: return SettingsSection.proxy.rawValue - case .devices: + case .devices, .filters: return SettingsSection.media.rawValue case .savedMessages, .recentCalls, .stickers: return SettingsSection.media.rawValue @@ -285,30 +290,32 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return 1006 case .devices: return 1007 - case .notificationsAndSounds: + case .filters: return 1008 - case .privacyAndSecurity: + case .notificationsAndSounds: return 1009 - case .dataAndStorage: + case .privacyAndSecurity: return 1010 - case .themes: + case .dataAndStorage: return 1011 - case .language: + case .themes: return 1012 - case .contentStickers: + case .language: return 1013 + case .contentStickers: + return 1014 #if ENABLE_WALLET case .wallet: - return 1014 + return 1015 #endif case .passport: - return 1015 - case .watch: return 1016 - case .askAQuestion: + case .watch: return 1017 - case .faq: + case .askAQuestion: return 1018 + case .faq: + return 1019 } } @@ -406,6 +413,12 @@ private indirect enum SettingsEntry: ItemListNodeEntry { } else { return false } + case let .filters(lhsTheme, lhsImage, lhsText, lhsValue): + if case let .filters(rhsTheme, rhsImage, rhsText, rhsValue) = rhs, lhsTheme === rhsTheme, lhsImage === rhsImage, lhsText == rhsText, lhsValue == rhsValue { + return true + } else { + return false + } case let .savedMessages(lhsTheme, lhsImage, lhsText): if case let .savedMessages(rhsTheme, rhsImage, rhsText) = rhs, lhsTheme === rhsTheme, lhsImage === rhsImage, lhsText == rhsText { return true @@ -567,6 +580,10 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: value, sectionId: ItemListSectionId(self.section), style: .blocks, action: { arguments.openDevices() }) + case let .filters(theme, image, text, value): + return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: value, sectionId: ItemListSectionId(self.section), style: .blocks, action: { + arguments.openFilters() + }) case let .savedMessages(theme, image, text): return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: "", sectionId: ItemListSectionId(self.section), style: .blocks, action: { arguments.openSavedMessages() @@ -635,7 +652,7 @@ private struct SettingsState: Equatable { var isSearching: Bool } -private func settingsEntries(account: Account, presentationData: PresentationData, state: SettingsState, view: PeerView, proxySettings: ProxySettings, notifyExceptions: NotificationExceptionsList?, notificationsAuthorizationStatus: AccessType, notificationsWarningSuppressed: Bool, unreadTrendingStickerPacks: Int, archivedPacks: [ArchivedStickerPackItem]?, privacySettings: AccountPrivacySettings?, hasWallet: Bool, hasPassport: Bool, hasWatchApp: Bool, accountsAndPeers: [(Account, Peer, Int32)], inAppNotificationSettings: InAppNotificationSettings, experimentalUISettings: ExperimentalUISettings, displayPhoneNumberConfirmation: Bool, otherSessionCount: Int, enableQRLogin: Bool) -> [SettingsEntry] { +private func settingsEntries(account: Account, presentationData: PresentationData, state: SettingsState, view: PeerView, proxySettings: ProxySettings, notifyExceptions: NotificationExceptionsList?, notificationsAuthorizationStatus: AccessType, notificationsWarningSuppressed: Bool, unreadTrendingStickerPacks: Int, archivedPacks: [ArchivedStickerPackItem]?, privacySettings: AccountPrivacySettings?, hasWallet: Bool, hasPassport: Bool, hasWatchApp: Bool, accountsAndPeers: [(Account, Peer, Int32)], inAppNotificationSettings: InAppNotificationSettings, experimentalUISettings: ExperimentalUISettings, displayPhoneNumberConfirmation: Bool, otherSessionCount: Int, enableQRLogin: Bool, enableFilters: Bool) -> [SettingsEntry] { var entries: [SettingsEntry] = [] if let peer = peerViewMainPeer(view) as? TelegramUser { @@ -688,6 +705,10 @@ private func settingsEntries(account: Account, presentationData: PresentationDat } else { entries.append(.devices(presentationData.theme, UIImage(bundleImageName: "Settings/MenuIcons/Sessions")?.precomposed(), presentationData.strings.Settings_Devices, otherSessionCount == 0 ? "" : "\(otherSessionCount + 1)")) } + if enableFilters { + //TODO:localize + entries.append(.filters(presentationData.theme, UIImage(bundleImageName: "Settings/MenuIcons/SavedMessages")?.precomposed(), "Chat Filters", "")) + } let notificationsWarning = shouldDisplayNotificationsPermissionWarning(status: notificationsAuthorizationStatus, suppressed: notificationsWarningSuppressed) entries.append(.notificationsAndSounds(presentationData.theme, PresentationResourcesSettings.notifications, presentationData.strings.Settings_NotificationsAndSounds, notifyExceptions, notificationsWarning)) @@ -925,6 +946,7 @@ public func settingsController(context: AccountContext, accountManager: AccountM let privacySettings = Promise(nil) let enableQRLogin = Promise() + let enableFilters = Promise() let openFaq: (Promise, String?) -> Void = { resolvedUrl, customAnchor in let _ = (contextValue.get() @@ -1221,17 +1243,27 @@ public func settingsController(context: AccountContext, accountManager: AccountM gesture?.cancel() } }, openDevices: { - let _ = (combineLatest(queue: .mainQueue(), - activeSessionsContextAndCount.get(), - enableQRLogin.get() - ) - |> take(1)).start(next: { activeSessionsContextAndCount, enableQRLogin in - let (activeSessionsContext, count, webSessionsContext) = activeSessionsContextAndCount - if count == 0 && enableQRLogin { - pushControllerImpl?(AuthDataTransferSplashScreen(context: context, activeSessionsContext: activeSessionsContext)) - } else { - pushControllerImpl?(recentSessionsController(context: context, activeSessionsContext: activeSessionsContext, webSessionsContext: webSessionsContext, websitesOnly: false)) - } + let _ = (contextValue.get() + |> deliverOnMainQueue + |> take(1)).start(next: { context in + let _ = (combineLatest(queue: .mainQueue(), + activeSessionsContextAndCount.get(), + enableQRLogin.get() + ) + |> take(1)).start(next: { activeSessionsContextAndCount, enableQRLogin in + let (activeSessionsContext, count, webSessionsContext) = activeSessionsContextAndCount + if count == 0 && enableQRLogin { + pushControllerImpl?(AuthDataTransferSplashScreen(context: context, activeSessionsContext: activeSessionsContext)) + } else { + pushControllerImpl?(recentSessionsController(context: context, activeSessionsContext: activeSessionsContext, webSessionsContext: webSessionsContext, websitesOnly: false)) + } + }) + }) + }, openFilters: { + let _ = (contextValue.get() + |> deliverOnMainQueue + |> take(1)).start(next: { context in + pushControllerImpl?(chatListFilterPresetListController(context: context, updated: { _ in })) }) }) @@ -1496,7 +1528,21 @@ public func settingsController(context: AccountContext, accountManager: AccountM } enableQRLogin.set(enableQRLoginSignal) - let signal = combineLatest(queue: Queue.mainQueue(), contextValue.get(), updatedPresentationData, statePromise.get(), peerView, combineLatest(queue: Queue.mainQueue(), preferences, notifyExceptions.get(), notificationsAuthorizationStatus.get(), notificationsWarningSuppressed.get(), privacySettings.get(), displayPhoneNumberConfirmation.get()), combineLatest(featuredStickerPacks, archivedPacks.get()), combineLatest(hasWallet, hasPassport.get(), hasWatchApp, enableQRLogin.get()), accountsAndPeers.get(), activeSessionsContextAndCount.get()) + let enableFiltersSignal = contextValue.get() + |> mapToSignal { context -> Signal in + return context.account.postbox.preferencesView(keys: [PreferencesKeys.appConfiguration]) + |> map { view -> Bool in + guard let appConfiguration = view.values[PreferencesKeys.appConfiguration] as? AppConfiguration else { + return false + } + let configuration = ChatListFilteringConfiguration(appConfiguration: appConfiguration) + return configuration.isEnabled + } + |> distinctUntilChanged + } + enableFilters.set(enableFiltersSignal) + + let signal = combineLatest(queue: Queue.mainQueue(), contextValue.get(), updatedPresentationData, statePromise.get(), peerView, combineLatest(queue: Queue.mainQueue(), preferences, notifyExceptions.get(), notificationsAuthorizationStatus.get(), notificationsWarningSuppressed.get(), privacySettings.get(), displayPhoneNumberConfirmation.get()), combineLatest(featuredStickerPacks, archivedPacks.get()), combineLatest(hasWallet, hasPassport.get(), hasWatchApp, enableQRLogin.get(), enableFilters.get()), accountsAndPeers.get(), activeSessionsContextAndCount.get()) |> map { context, presentationData, state, view, preferencesAndExceptions, featuredAndArchived, hasWalletPassportAndWatch, accountsAndPeers, activeSessionsContextAndCount -> (ItemListControllerState, (ItemListNodeState, Any)) in let otherSessionCount = activeSessionsContextAndCount.1 @@ -1536,8 +1582,8 @@ public func settingsController(context: AccountContext, accountManager: AccountM pushControllerImpl?(c) }, getNavigationController: getNavigationControllerImpl, exceptionsList: notifyExceptions.get(), archivedStickerPacks: archivedPacks.get(), privacySettings: privacySettings.get(), hasWallet: hasWallet, activeSessionsContext: activeSessionsContextAndCountSignal |> map { $0.0 } |> distinctUntilChanged(isEqual: { $0 === $1 }), webSessionsContext: activeSessionsContextAndCountSignal |> map { $0.2 } |> distinctUntilChanged(isEqual: { $0 === $1 })) - let (hasWallet, hasPassport, hasWatchApp, enableQRLogin) = hasWalletPassportAndWatch - let listState = ItemListNodeState(presentationData: ItemListPresentationData(presentationData), entries: settingsEntries(account: context.account, presentationData: presentationData, state: state, view: view, proxySettings: proxySettings, notifyExceptions: preferencesAndExceptions.1, notificationsAuthorizationStatus: preferencesAndExceptions.2, notificationsWarningSuppressed: preferencesAndExceptions.3, unreadTrendingStickerPacks: unreadTrendingStickerPacks, archivedPacks: featuredAndArchived.1, privacySettings: preferencesAndExceptions.4, hasWallet: hasWallet, hasPassport: hasPassport, hasWatchApp: hasWatchApp, accountsAndPeers: accountsAndPeers.1, inAppNotificationSettings: inAppNotificationSettings, experimentalUISettings: experimentalUISettings, displayPhoneNumberConfirmation: preferencesAndExceptions.5, otherSessionCount: otherSessionCount, enableQRLogin: enableQRLogin), style: .blocks, searchItem: searchItem, initialScrollToItem: ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: false, curve: .Default(duration: 0.0), directionHint: .Up)) + let (hasWallet, hasPassport, hasWatchApp, enableQRLogin, enableFilters) = hasWalletPassportAndWatch + let listState = ItemListNodeState(presentationData: ItemListPresentationData(presentationData), entries: settingsEntries(account: context.account, presentationData: presentationData, state: state, view: view, proxySettings: proxySettings, notifyExceptions: preferencesAndExceptions.1, notificationsAuthorizationStatus: preferencesAndExceptions.2, notificationsWarningSuppressed: preferencesAndExceptions.3, unreadTrendingStickerPacks: unreadTrendingStickerPacks, archivedPacks: featuredAndArchived.1, privacySettings: preferencesAndExceptions.4, hasWallet: hasWallet, hasPassport: hasPassport, hasWatchApp: hasWatchApp, accountsAndPeers: accountsAndPeers.1, inAppNotificationSettings: inAppNotificationSettings, experimentalUISettings: experimentalUISettings, displayPhoneNumberConfirmation: preferencesAndExceptions.5, otherSessionCount: otherSessionCount, enableQRLogin: enableQRLogin, enableFilters: enableFilters), style: .blocks, searchItem: searchItem, initialScrollToItem: ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: false, curve: .Default(duration: 0.0), directionHint: .Up)) return (controllerState, (listState, arguments)) } diff --git a/submodules/ShareItems/BUCK b/submodules/ShareItems/BUCK index 19d6ca2f02..0787170e22 100644 --- a/submodules/ShareItems/BUCK +++ b/submodules/ShareItems/BUCK @@ -4,14 +4,7 @@ static_library( name = "ShareItems", srcs = glob([ "Sources/**/*.swift", - "Sources/*.m", ]), - headers = glob([ - "Sources/*.h", - ], exclude = ["Sources/ShareItems.h"]), - exported_headers = glob([ - "Sources/*.h", - ], exclude = ["Sources/ShareItems.h"]), deps = [ "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit#shared", "//submodules/Postbox:Postbox#shared", @@ -25,6 +18,7 @@ static_library( "//submodules/AccountContext:AccountContext", "//submodules/MimeTypes:MimeTypes", "//submodules/PhoneNumberFormat:PhoneNumberFormat", + "//submodules/ShareItems/Impl:ShareItemsImpl", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/ShareItems/Impl/BUCK b/submodules/ShareItems/Impl/BUCK new file mode 100644 index 0000000000..54d762b8e8 --- /dev/null +++ b/submodules/ShareItems/Impl/BUCK @@ -0,0 +1,27 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "ShareItemsImpl", + srcs = glob([ + "Sources/*.m", + ]), + headers = glob([ + "Sources/*.h", + ]), + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), + deps = [ + "//submodules/MtProtoKit:MtProtoKit#shared", + "//submodules/MimeTypes:MimeTypes", + "//submodules/PhoneNumberFormat:PhoneNumberFormat", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/UIKit.framework", + "$SDKROOT/System/Library/Frameworks/MobileCoreServices.framework", + "$SDKROOT/System/Library/Frameworks/AddressBook.framework", + "$SDKROOT/System/Library/Frameworks/AVFoundation.framework", + "$SDKROOT/System/Library/Frameworks/PassKit.framework", + ], +) diff --git a/submodules/StickerResources/BUCK b/submodules/StickerResources/BUCK index b5d224ade2..d832be586d 100644 --- a/submodules/StickerResources/BUCK +++ b/submodules/StickerResources/BUCK @@ -15,7 +15,7 @@ static_library( "//submodules/Tuples:Tuples", "//submodules/MediaResources:MediaResources", "//submodules/TelegramUIPreferences:TelegramUIPreferences", - "//submodules/WebP:WebPImage", + "//submodules/WebPBinding:WebPBinding", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/Stripe/BUCK b/submodules/Stripe/BUCK index 1d88f6909f..d2fcfd3501 100644 --- a/submodules/Stripe/BUCK +++ b/submodules/Stripe/BUCK @@ -7,33 +7,10 @@ static_library( ]), headers = glob([ "Sources/*.h", - ], exclude = ["Sources/Stripe.h"]), - exported_headers = [ - "Sources/STPAddress.h", - "Sources/STPPaymentCardTextField.h", - "Sources/STPAPIClient.h", - "Sources/STPAPIClient+ApplePay.h", - "Sources/STPAPIResponseDecodable.h", - "Sources/STPPaymentConfiguration.h", - "Sources/STPCard.h", - "Sources/STPCardBrand.h", - "Sources/STPCardParams.h", - "Sources/STPToken.h", - "Sources/STPBankAccount.h", - "Sources/STPBankAccountParams.h", - "Sources/STPBINRange.h", - "Sources/STPCardValidator.h", - "Sources/STPCardValidationState.h", - "Sources/STPCustomer.h", - "Sources/STPFormEncodable.h", - "Sources/STPPaymentMethod.h", - "Sources/STPPhoneNumberValidator.h", - "Sources/STPPostalCodeValidator.h", - "Sources/STPSource.h", - "Sources/STPBlocks.h", - "Sources/StripeError.h", - "Sources/STPBackendAPIAdapter.h", - ], + ]), + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", "$SDKROOT/System/Library/Frameworks/UIKit.framework", diff --git a/submodules/Svg/BUCK b/submodules/Svg/BUCK index f8b2a7b112..a3a62ebc99 100644 --- a/submodules/Svg/BUCK +++ b/submodules/Svg/BUCK @@ -11,7 +11,7 @@ static_library( headers = glob([ "Sources/**/*.h", ]), - exported_headers = [ - "Sources/Svg.h", - ], + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), ) diff --git a/submodules/SyncCore/Sources/Namespaces.swift b/submodules/SyncCore/Sources/Namespaces.swift index 1af4170023..7b384619c8 100644 --- a/submodules/SyncCore/Sources/Namespaces.swift +++ b/submodules/SyncCore/Sources/Namespaces.swift @@ -43,6 +43,7 @@ public struct Namespaces { public static let CloudMaskPacks: Int32 = 1 public static let EmojiKeywords: Int32 = 2 public static let CloudAnimatedEmoji: Int32 = 3 + public static let CloudDice: Int32 = 4 } public struct OrderedItemList { diff --git a/submodules/SyncCore/Sources/TelegramMediaFile.swift b/submodules/SyncCore/Sources/TelegramMediaFile.swift index 02b38d4d34..0283239a5c 100644 --- a/submodules/SyncCore/Sources/TelegramMediaFile.swift +++ b/submodules/SyncCore/Sources/TelegramMediaFile.swift @@ -13,6 +13,7 @@ public enum StickerPackReference: PostboxCoding, Hashable, Equatable { case id(id: Int64, accessHash: Int64) case name(String) case animatedEmoji + case dice public init(decoder: PostboxDecoder) { switch decoder.decodeInt32ForKey("r", orElse: 0) { @@ -22,6 +23,8 @@ public enum StickerPackReference: PostboxCoding, Hashable, Equatable { self = .name(decoder.decodeStringForKey("n", orElse: "")) case 2: self = .animatedEmoji + case 3: + self = .dice default: self = .name("") assertionFailure() @@ -39,6 +42,8 @@ public enum StickerPackReference: PostboxCoding, Hashable, Equatable { encoder.encodeString(name, forKey: "n") case .animatedEmoji: encoder.encodeInt32(2, forKey: "r") + case .dice: + encoder.encodeInt32(3, forKey: "r") } } @@ -62,6 +67,12 @@ public enum StickerPackReference: PostboxCoding, Hashable, Equatable { } else { return false } + case .dice: + if case .dice = rhs { + return true + } else { + return false + } } } } diff --git a/submodules/TelegramApi/Sources/Api0.swift b/submodules/TelegramApi/Sources/Api0.swift index 26baa33fef..afd8f5b371 100644 --- a/submodules/TelegramApi/Sources/Api0.swift +++ b/submodules/TelegramApi/Sources/Api0.swift @@ -513,7 +513,7 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[-1502174430] = { return Api.InputMessage.parse_inputMessageID($0) } dict[-1160215659] = { return Api.InputMessage.parse_inputMessageReplyTo($0) } dict[-2037963464] = { return Api.InputMessage.parse_inputMessagePinned($0) } - dict[-1564789301] = { return Api.PhoneCallProtocol.parse_phoneCallProtocol($0) } + dict[-58224696] = { return Api.PhoneCallProtocol.parse_phoneCallProtocol($0) } dict[-1237848657] = { return Api.StatsDateRangeDays.parse_statsDateRangeDays($0) } dict[-1567175714] = { return Api.MessageFwdAuthor.parse_messageFwdAuthor($0) } dict[-1539849235] = { return Api.WallPaper.parse_wallPaper($0) } @@ -579,6 +579,7 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[-1645763991] = { return Api.InputStickerSet.parse_inputStickerSetID($0) } dict[-2044933984] = { return Api.InputStickerSet.parse_inputStickerSetShortName($0) } dict[42402760] = { return Api.InputStickerSet.parse_inputStickerSetAnimatedEmoji($0) } + dict[2044861011] = { return Api.InputStickerSet.parse_inputStickerSetDice($0) } dict[-1729618630] = { return Api.BotInfo.parse_botInfo($0) } dict[-1519637954] = { return Api.updates.State.parse_state($0) } dict[372165663] = { return Api.FoundGif.parse_foundGif($0) } diff --git a/submodules/TelegramApi/Sources/Api1.swift b/submodules/TelegramApi/Sources/Api1.swift index 1046f9f6f9..790975a865 100644 --- a/submodules/TelegramApi/Sources/Api1.swift +++ b/submodules/TelegramApi/Sources/Api1.swift @@ -14600,25 +14600,30 @@ public extension Api { } public enum PhoneCallProtocol: TypeConstructorDescription { - case phoneCallProtocol(flags: Int32, minLayer: Int32, maxLayer: Int32) + case phoneCallProtocol(flags: Int32, minLayer: Int32, maxLayer: Int32, libraryVersions: [String]) public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { switch self { - case .phoneCallProtocol(let flags, let minLayer, let maxLayer): + case .phoneCallProtocol(let flags, let minLayer, let maxLayer, let libraryVersions): if boxed { - buffer.appendInt32(-1564789301) + buffer.appendInt32(-58224696) } serializeInt32(flags, buffer: buffer, boxed: false) serializeInt32(minLayer, buffer: buffer, boxed: false) serializeInt32(maxLayer, buffer: buffer, boxed: false) + buffer.appendInt32(481674261) + buffer.appendInt32(Int32(libraryVersions.count)) + for item in libraryVersions { + serializeString(item, buffer: buffer, boxed: false) + } break } } public func descriptionFields() -> (String, [(String, Any)]) { switch self { - case .phoneCallProtocol(let flags, let minLayer, let maxLayer): - return ("phoneCallProtocol", [("flags", flags), ("minLayer", minLayer), ("maxLayer", maxLayer)]) + case .phoneCallProtocol(let flags, let minLayer, let maxLayer, let libraryVersions): + return ("phoneCallProtocol", [("flags", flags), ("minLayer", minLayer), ("maxLayer", maxLayer), ("libraryVersions", libraryVersions)]) } } @@ -14629,11 +14634,16 @@ public extension Api { _2 = reader.readInt32() var _3: Int32? _3 = reader.readInt32() + var _4: [String]? + if let _ = reader.readInt32() { + _4 = Api.parseVector(reader, elementSignature: -1255641564, elementType: String.self) + } let _c1 = _1 != nil let _c2 = _2 != nil let _c3 = _3 != nil - if _c1 && _c2 && _c3 { - return Api.PhoneCallProtocol.phoneCallProtocol(flags: _1!, minLayer: _2!, maxLayer: _3!) + let _c4 = _4 != nil + if _c1 && _c2 && _c3 && _c4 { + return Api.PhoneCallProtocol.phoneCallProtocol(flags: _1!, minLayer: _2!, maxLayer: _3!, libraryVersions: _4!) } else { return nil @@ -16258,6 +16268,7 @@ public extension Api { case inputStickerSetID(id: Int64, accessHash: Int64) case inputStickerSetShortName(shortName: String) case inputStickerSetAnimatedEmoji + case inputStickerSetDice public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { switch self { @@ -16285,6 +16296,12 @@ public extension Api { buffer.appendInt32(42402760) } + break + case .inputStickerSetDice: + if boxed { + buffer.appendInt32(2044861011) + } + break } } @@ -16299,6 +16316,8 @@ public extension Api { return ("inputStickerSetShortName", [("shortName", shortName)]) case .inputStickerSetAnimatedEmoji: return ("inputStickerSetAnimatedEmoji", []) + case .inputStickerSetDice: + return ("inputStickerSetDice", []) } } @@ -16333,6 +16352,9 @@ public extension Api { public static func parse_inputStickerSetAnimatedEmoji(_ reader: BufferReader) -> InputStickerSet? { return Api.InputStickerSet.inputStickerSetAnimatedEmoji } + public static func parse_inputStickerSetDice(_ reader: BufferReader) -> InputStickerSet? { + return Api.InputStickerSet.inputStickerSetDice + } } public enum BotInfo: TypeConstructorDescription { diff --git a/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift b/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift index 6bfda0df93..2e5310dec2 100644 --- a/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift +++ b/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift @@ -75,6 +75,10 @@ public final class PresentationCallManagerImpl: PresentationCallManager { return OngoingCallContext.maxLayer } + public static var voipVersions: [String] { + return [OngoingCallContext.version] + } + public init(accountManager: AccountManager, getDeviceAccessData: @escaping () -> (presentationData: PresentationData, present: (ViewController, Any?) -> Void, openSettings: () -> Void), isMediaPlaying: @escaping () -> Bool, resumeMediaPlayback: @escaping () -> Void, audioSession: ManagedAudioSession, activeAccounts: Signal<[Account], NoError>) { self.getDeviceAccessData = getDeviceAccessData self.accountManager = accountManager diff --git a/submodules/TelegramCore/Sources/Account.swift b/submodules/TelegramCore/Sources/Account.swift index e0857de4f3..be82e24425 100644 --- a/submodules/TelegramCore/Sources/Account.swift +++ b/submodules/TelegramCore/Sources/Account.swift @@ -901,7 +901,7 @@ public class Account { self.supplementary = supplementary self.peerInputActivityManager = PeerInputActivityManager() - self.callSessionManager = CallSessionManager(postbox: postbox, network: network, maxLayer: networkArguments.voipMaxLayer, addUpdates: { [weak self] updates in + self.callSessionManager = CallSessionManager(postbox: postbox, network: network, maxLayer: networkArguments.voipMaxLayer, versions: networkArguments.voipVersions, addUpdates: { [weak self] updates in self?.stateManager?.addUpdates(updates) }) self.stateManager = AccountStateManager(accountPeerId: self.peerId, accountManager: accountManager, postbox: self.postbox, network: self.network, callSessionManager: self.callSessionManager, addIsContactUpdates: { [weak self] updates in @@ -1044,7 +1044,7 @@ public class Account { self.managedOperationsDisposable.add(managedApplyPendingMessageReactionsActions(postbox: self.postbox, network: self.network, stateManager: self.stateManager).start()) self.managedOperationsDisposable.add(managedSynchronizeEmojiKeywordsOperations(postbox: self.postbox, network: self.network).start()) self.managedOperationsDisposable.add(managedApplyPendingScheduledMessagesActions(postbox: self.postbox, network: self.network, stateManager: self.stateManager).start()) - //self.managedOperationsDisposable.add(managedChatListFilters(postbox: self.postbox, network: self.network).start()) + self.managedOperationsDisposable.add(managedChatListFilters(postbox: self.postbox, network: self.network).start()) let importantBackgroundOperations: [Signal] = [ managedSynchronizeChatInputStateOperations(postbox: self.postbox, network: self.network) |> map { $0 ? AccountRunningImportantTasks.other : [] }, diff --git a/submodules/TelegramCore/Sources/CachedStickerPack.swift b/submodules/TelegramCore/Sources/CachedStickerPack.swift index 00f7a95fc4..4582c64171 100644 --- a/submodules/TelegramCore/Sources/CachedStickerPack.swift +++ b/submodules/TelegramCore/Sources/CachedStickerPack.swift @@ -76,6 +76,20 @@ public func cachedStickerPack(postbox: Postbox, network: Network, reference: Sti } else { return (.fetching, true, nil) } + case .dice: + let namespace = Namespaces.ItemCollection.CloudDice + let id: ItemCollectionId.Id = 0 + if let cached = transaction.retrieveItemCacheEntry(id: ItemCacheEntryId(collectionId: Namespaces.CachedItemCollection.cachedStickerPacks, key: CachedStickerPack.cacheKey(ItemCollectionId(namespace: namespace, id: id)))) as? CachedStickerPack, let info = cached.info { + previousHash = cached.hash + let current: CachedStickerPackResult = .result(info, cached.items, false) + if cached.hash != info.hash { + return (current, true, previousHash) + } else { + return (current, true, previousHash) + } + } else { + return (.fetching, true, nil) + } } } |> mapToSignal { result, loadRemote, previousHash in @@ -148,6 +162,18 @@ func cachedStickerPack(transaction: Transaction, reference: StickerPackReference if let cached = transaction.retrieveItemCacheEntry(id: ItemCacheEntryId(collectionId: Namespaces.CachedItemCollection.cachedStickerPacks, key: CachedStickerPack.cacheKey(ItemCollectionId(namespace: namespace, id: id)))) as? CachedStickerPack, let info = cached.info { return (info, cached.items, false) } + case .dice: + let namespace = Namespaces.ItemCollection.CloudDice + let id: ItemCollectionId.Id = 0 + if let currentInfo = transaction.getItemCollectionInfo(collectionId: ItemCollectionId(namespace: namespace, id: id)) as? StickerPackCollectionInfo { + let items = transaction.getItemCollectionItems(collectionId: ItemCollectionId(namespace: namespace, id: id)) + if !items.isEmpty { + return (currentInfo, items, true) + } + } + if let cached = transaction.retrieveItemCacheEntry(id: ItemCacheEntryId(collectionId: Namespaces.CachedItemCollection.cachedStickerPacks, key: CachedStickerPack.cacheKey(ItemCollectionId(namespace: namespace, id: id)))) as? CachedStickerPack, let info = cached.info { + return (info, cached.items, false) + } } return nil } diff --git a/submodules/TelegramCore/Sources/CallSessionManager.swift b/submodules/TelegramCore/Sources/CallSessionManager.swift index a84206744b..301a47a4ee 100644 --- a/submodules/TelegramCore/Sources/CallSessionManager.swift +++ b/submodules/TelegramCore/Sources/CallSessionManager.swift @@ -4,7 +4,6 @@ import MtProtoKit import SwiftSignalKit import TelegramApi - import SyncCore private let minLayer: Int32 = 65 @@ -241,6 +240,7 @@ private final class CallSessionManagerContext { private let postbox: Postbox private let network: Network private let maxLayer: Int32 + private let versions: [String] private let addUpdates: (Api.Updates) -> Void private let ringingSubscribers = Bag<([CallSessionRingingState]) -> Void>() @@ -249,11 +249,12 @@ private final class CallSessionManagerContext { private let disposables = DisposableSet() - init(queue: Queue, postbox: Postbox, network: Network, maxLayer: Int32, addUpdates: @escaping (Api.Updates) -> Void) { + init(queue: Queue, postbox: Postbox, network: Network, maxLayer: Int32, versions: [String], addUpdates: @escaping (Api.Updates) -> Void) { self.queue = queue self.postbox = postbox self.network = network self.maxLayer = maxLayer + self.versions = versions self.addUpdates = addUpdates } @@ -469,7 +470,7 @@ private final class CallSessionManagerContext { if let context = self.contexts[internalId] { switch context.state { case let .ringing(id, accessHash, gAHash, b): - context.state = .accepting(id: id, accessHash: accessHash, gAHash: gAHash, b: b, disposable: (acceptCallSession(postbox: self.postbox, network: self.network, stableId: id, accessHash: accessHash, b: b, maxLayer: self.maxLayer) |> deliverOn(self.queue)).start(next: { [weak self] result in + context.state = .accepting(id: id, accessHash: accessHash, gAHash: gAHash, b: b, disposable: (acceptCallSession(postbox: self.postbox, network: self.network, stableId: id, accessHash: accessHash, b: b, maxLayer: self.maxLayer, versions: self.versions) |> deliverOn(self.queue)).start(next: { [weak self] result in if let strongSelf = self, let context = strongSelf.contexts[internalId] { if case .accepting = context.state { switch result { @@ -534,7 +535,7 @@ private final class CallSessionManagerContext { let keyVisualHash = MTSha256(key + gA)! - context.state = .confirming(id: id, accessHash: accessHash, key: key, keyId: keyId, keyVisualHash: keyVisualHash, disposable: (confirmCallSession(network: self.network, stableId: id, accessHash: accessHash, gA: gA, keyFingerprint: keyId, maxLayer: self.maxLayer) |> deliverOnMainQueue).start(next: { [weak self] updatedCall in + context.state = .confirming(id: id, accessHash: accessHash, key: key, keyId: keyId, keyVisualHash: keyVisualHash, disposable: (confirmCallSession(network: self.network, stableId: id, accessHash: accessHash, gA: gA, keyFingerprint: keyId, maxLayer: self.maxLayer, versions: self.versions) |> deliverOnMainQueue).start(next: { [weak self] updatedCall in if let strongSelf = self, let context = strongSelf.contexts[internalId], case .confirming = context.state { if let updatedCall = updatedCall { strongSelf.updateSession(updatedCall, completion: { _ in }) @@ -616,7 +617,7 @@ private final class CallSessionManagerContext { if let (key, calculatedKeyId, keyVisualHash) = self.makeSessionEncryptionKey(config: config, gAHash: gAHash, b: b, gA: gAOrB.makeData()) { if keyFingerprint == calculatedKeyId { switch callProtocol { - case let .phoneCallProtocol(_, _, maxLayer): + case let .phoneCallProtocol(_, _, maxLayer, _): context.state = .active(id: id, accessHash: accessHash, beginTimestamp: startDate, key: key, keyId: calculatedKeyId, keyVisualHash: keyVisualHash, connections: parseConnectionSet(primary: connections.first!, alternative: Array(connections[1...])), maxLayer: maxLayer, allowsP2P: allowsP2P) self.contextUpdated(internalId: internalId) } @@ -628,7 +629,7 @@ private final class CallSessionManagerContext { } case let .confirming(id, accessHash, key, keyId, keyVisualHash, _): switch callProtocol { - case let .phoneCallProtocol(_, _, maxLayer): + case let .phoneCallProtocol(_, _, maxLayer, _): context.state = .active(id: id, accessHash: accessHash, beginTimestamp: startDate, key: key, keyId: keyId, keyVisualHash: keyVisualHash, connections: parseConnectionSet(primary: connections.first!, alternative: Array(connections[1...])), maxLayer: maxLayer, allowsP2P: allowsP2P) self.contextUpdated(internalId: internalId) } @@ -709,7 +710,7 @@ private final class CallSessionManagerContext { let randomStatus = SecRandomCopyBytes(nil, 256, aBytes.assumingMemoryBound(to: UInt8.self)) let a = Data(bytesNoCopy: aBytes, count: 256, deallocator: .free) if randomStatus == 0 { - self.contexts[internalId] = CallSessionContext(peerId: peerId, isOutgoing: true, state: .requesting(a: a, disposable: (requestCallSession(postbox: self.postbox, network: self.network, peerId: peerId, a: a, maxLayer: self.maxLayer) |> deliverOn(queue)).start(next: { [weak self] result in + self.contexts[internalId] = CallSessionContext(peerId: peerId, isOutgoing: true, state: .requesting(a: a, disposable: (requestCallSession(postbox: self.postbox, network: self.network, peerId: peerId, a: a, maxLayer: self.maxLayer, versions: self.versions) |> deliverOn(queue)).start(next: { [weak self] result in if let strongSelf = self, let context = strongSelf.contexts[internalId] { if case .requesting = context.state { switch result { @@ -743,9 +744,9 @@ public final class CallSessionManager { private let queue = Queue() private var contextRef: Unmanaged? - init(postbox: Postbox, network: Network, maxLayer: Int32, addUpdates: @escaping (Api.Updates) -> Void) { + init(postbox: Postbox, network: Network, maxLayer: Int32, versions: [String], addUpdates: @escaping (Api.Updates) -> Void) { self.queue.async { - let context = CallSessionManagerContext(queue: self.queue, postbox: postbox, network: network, maxLayer: maxLayer, addUpdates: addUpdates) + let context = CallSessionManagerContext(queue: self.queue, postbox: postbox, network: network, maxLayer: maxLayer, versions: versions, addUpdates: addUpdates) self.contextRef = Unmanaged.passRetained(context) } } @@ -846,7 +847,7 @@ private enum AcceptCallResult { case success(AcceptedCall) } -private func acceptCallSession(postbox: Postbox, network: Network, stableId: CallSessionStableId, accessHash: Int64, b: Data, maxLayer: Int32) -> Signal { +private func acceptCallSession(postbox: Postbox, network: Network, stableId: CallSessionStableId, accessHash: Int64, b: Data, maxLayer: Int32, versions: [String]) -> Signal { return validatedEncryptionConfig(postbox: postbox, network: network) |> mapToSignal { config -> Signal in var gValue: Int32 = config.g.byteSwapped @@ -860,8 +861,8 @@ private func acceptCallSession(postbox: Postbox, network: Network, stableId: Cal if !MTCheckIsSafeGAOrB(network.encryptionProvider, gb, p) { return .single(.failed) } - - return network.request(Api.functions.phone.acceptCall(peer: .inputPhoneCall(id: stableId, accessHash: accessHash), gB: Buffer(data: gb), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer))) + + return network.request(Api.functions.phone.acceptCall(peer: .inputPhoneCall(id: stableId, accessHash: accessHash), gB: Buffer(data: gb), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer, libraryVersions: versions))) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) @@ -887,7 +888,7 @@ private func acceptCallSession(postbox: Postbox, network: Network, stableId: Cal case let .phoneCall(flags, id, _, _, _, _, gAOrB, _, callProtocol, connections, startDate): if id == stableId { switch callProtocol{ - case let .phoneCallProtocol(_, _, maxLayer): + case let .phoneCallProtocol(_, _, maxLayer, _): return .success(.call(config: config, gA: gAOrB.makeData(), timestamp: startDate, connections: parseConnectionSet(primary: connections.first!, alternative: Array(connections[1...])), maxLayer: maxLayer, allowsP2P: (flags & (1 << 5)) != 0)) } } else { @@ -908,7 +909,7 @@ private enum RequestCallSessionResult { case failed(CallSessionError) } -private func requestCallSession(postbox: Postbox, network: Network, peerId: PeerId, a: Data, maxLayer: Int32) -> Signal { +private func requestCallSession(postbox: Postbox, network: Network, peerId: PeerId, a: Data, maxLayer: Int32, versions: [String]) -> Signal { return validatedEncryptionConfig(postbox: postbox, network: network) |> mapToSignal { config -> Signal in return postbox.transaction { transaction -> Signal in @@ -924,7 +925,7 @@ private func requestCallSession(postbox: Postbox, network: Network, peerId: Peer let gAHash = MTSha256(ga)! - return network.request(Api.functions.phone.requestCall(flags: 0, userId: inputUser, randomId: Int32(bitPattern: arc4random()), gAHash: Buffer(data: gAHash), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer))) + return network.request(Api.functions.phone.requestCall(flags: 0, userId: inputUser, randomId: Int32(bitPattern: arc4random()), gAHash: Buffer(data: gAHash), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer, libraryVersions: versions))) |> map { result -> RequestCallSessionResult in switch result { case let .phoneCall(phoneCall, _): @@ -960,8 +961,8 @@ private func requestCallSession(postbox: Postbox, network: Network, peerId: Peer } } -private func confirmCallSession(network: Network, stableId: CallSessionStableId, accessHash: Int64, gA: Data, keyFingerprint: Int64, maxLayer: Int32) -> Signal { - return network.request(Api.functions.phone.confirmCall(peer: Api.InputPhoneCall.inputPhoneCall(id: stableId, accessHash: accessHash), gA: Buffer(data: gA), keyFingerprint: keyFingerprint, protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer))) +private func confirmCallSession(network: Network, stableId: CallSessionStableId, accessHash: Int64, gA: Data, keyFingerprint: Int64, maxLayer: Int32, versions: [String]) -> Signal { + return network.request(Api.functions.phone.confirmCall(peer: Api.InputPhoneCall.inputPhoneCall(id: stableId, accessHash: accessHash), gA: Buffer(data: gA), keyFingerprint: keyFingerprint, protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer, libraryVersions: versions))) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) diff --git a/submodules/TelegramCore/Sources/ChatListFiltering.swift b/submodules/TelegramCore/Sources/ChatListFiltering.swift index 08c374d900..8193e3c927 100644 --- a/submodules/TelegramCore/Sources/ChatListFiltering.swift +++ b/submodules/TelegramCore/Sources/ChatListFiltering.swift @@ -5,7 +5,19 @@ import TelegramApi import SyncCore -public struct ChatListFilterPeerCategories: OptionSet { +public struct ChatListFilteringConfiguration: Equatable { + public let isEnabled: Bool + + public init(appConfiguration: AppConfiguration) { + var isEnabled = false + if let data = appConfiguration.data, let value = data["dialog_filters_enabled"] as? Bool, value { + isEnabled = true + } + self.isEnabled = isEnabled + } +} + +public struct ChatListFilterPeerCategories: OptionSet, Hashable { public var rawValue: Int32 public init(rawValue: Int32) { @@ -93,50 +105,58 @@ extension ChatListFilterPeerCategories { } } -public struct ChatListFilter: PostboxCoding, Equatable { - public var id: Int32 - public var title: String? +public struct ChatListFilterData: Equatable, Hashable { public var categories: ChatListFilterPeerCategories public var excludeMuted: Bool public var excludeRead: Bool public var includePeers: [PeerId] public init( - id: Int32, - title: String?, categories: ChatListFilterPeerCategories, excludeMuted: Bool, excludeRead: Bool, includePeers: [PeerId] ) { - self.id = id - self.title = title self.categories = categories self.excludeMuted = excludeMuted self.excludeRead = excludeRead self.includePeers = includePeers } +} + +public struct ChatListFilter: PostboxCoding, Equatable { + public var id: Int32 + public var title: String + public var data: ChatListFilterData + + public init( + id: Int32, + title: String, + data: ChatListFilterData + ) { + self.id = id + self.title = title + self.data = data + } public init(decoder: PostboxDecoder) { self.id = decoder.decodeInt32ForKey("id", orElse: 0) - self.title = decoder.decodeOptionalStringForKey("title") - self.categories = ChatListFilterPeerCategories(rawValue: decoder.decodeInt32ForKey("categories", orElse: 0)) - self.excludeMuted = decoder.decodeInt32ForKey("excludeMuted", orElse: 0) != 0 - self.excludeRead = decoder.decodeInt32ForKey("excludeRead", orElse: 0) != 0 - self.includePeers = decoder.decodeInt64ArrayForKey("includePeers").map(PeerId.init) + self.title = decoder.decodeStringForKey("title", orElse: "") + self.data = ChatListFilterData( + categories: ChatListFilterPeerCategories(rawValue: decoder.decodeInt32ForKey("categories", orElse: 0)), + excludeMuted: decoder.decodeInt32ForKey("excludeMuted", orElse: 0) != 0, + excludeRead: decoder.decodeInt32ForKey("excludeRead", orElse: 0) != 0, + includePeers: decoder.decodeInt64ArrayForKey("includePeers").map(PeerId.init) + ) } public func encode(_ encoder: PostboxEncoder) { encoder.encodeInt32(self.id, forKey: "id") - if let title = self.title { - encoder.encodeString(title, forKey: "title") - } else { - encoder.encodeNil(forKey: "title") - } - encoder.encodeInt32(self.categories.rawValue, forKey: "categories") - encoder.encodeInt32(self.excludeMuted ? 1 : 0, forKey: "excludeMuted") - encoder.encodeInt32(self.excludeRead ? 1 : 0, forKey: "excludeRead") - encoder.encodeInt64Array(self.includePeers.map { $0.toInt64() }, forKey: "includePeers") + encoder.encodeString(self.title, forKey: "title") + encoder.encodeInt32(self.data.categories.rawValue, forKey: "categories") + encoder.encodeInt32(self.data.excludeMuted ? 1 : 0, forKey: "excludeMuted") + encoder.encodeInt32(self.data.excludeRead ? 1 : 0, forKey: "excludeRead") + encoder.encodeInt64Array(self.data.includePeers.map { $0.toInt64() }, forKey: "includePeers") } } @@ -146,36 +166,38 @@ extension ChatListFilter { case let .dialogFilter(flags, id, title, includePeers): self.init( id: id, - title: title.isEmpty ? nil : title, - categories: ChatListFilterPeerCategories(apiFlags: flags), - excludeMuted: (flags & (1 << 11)) != 0, - excludeRead: (flags & (1 << 12)) != 0, - includePeers: includePeers.compactMap { peer -> PeerId? in - switch peer { - case let .inputPeerUser(userId, _): - return PeerId(namespace: Namespaces.Peer.CloudUser, id: userId) - case let .inputPeerChat(chatId): - return PeerId(namespace: Namespaces.Peer.CloudGroup, id: chatId) - case let .inputPeerChannel(channelId, _): - return PeerId(namespace: Namespaces.Peer.CloudChannel, id: channelId) - default: - return nil + title: title, + data: ChatListFilterData( + categories: ChatListFilterPeerCategories(apiFlags: flags), + excludeMuted: (flags & (1 << 11)) != 0, + excludeRead: (flags & (1 << 12)) != 0, + includePeers: includePeers.compactMap { peer -> PeerId? in + switch peer { + case let .inputPeerUser(userId, _): + return PeerId(namespace: Namespaces.Peer.CloudUser, id: userId) + case let .inputPeerChat(chatId): + return PeerId(namespace: Namespaces.Peer.CloudGroup, id: chatId) + case let .inputPeerChannel(channelId, _): + return PeerId(namespace: Namespaces.Peer.CloudChannel, id: channelId) + default: + return nil + } } - } + ) ) } } func apiFilter(transaction: Transaction) -> Api.DialogFilter { var flags: Int32 = 0 - if self.excludeMuted { + if self.data.excludeMuted { flags |= 1 << 11 } - if self.excludeRead { + if self.data.excludeRead { flags |= 1 << 12 } - flags |= self.categories.apiFlags - return .dialogFilter(flags: flags, id: self.id, title: self.title ?? "", includePeers: self.includePeers.compactMap { peerId -> Api.InputPeer? in + flags |= self.data.categories.apiFlags + return .dialogFilter(flags: flags, id: self.id, title: self.title, includePeers: self.data.includePeers.compactMap { peerId -> Api.InputPeer? in return transaction.getPeer(peerId).flatMap(apiInputPeer) }) } @@ -287,46 +309,70 @@ func managedChatListFilters(postbox: Postbox, network: Network) -> Signal Signal { - return requestChatListFilters(postbox: account.postbox, network: account.network) - |> `catch` { _ -> Signal<[ChatListFilter], NoError> in - return .complete() + return account.postbox.transaction { transaction -> [ChatListFilter] in + let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default + return settings.filters } - |> mapToSignal { remoteFilters -> Signal in - var deleteSignals: [Signal] = [] - for filter in remoteFilters { - deleteSignals.append(requestUpdateChatListFilter(account: account, id: filter.id, filter: nil) - |> `catch` { _ -> Signal in - return .complete() - } - |> ignoreValues) + |> mapToSignal { filters -> Signal in + return requestChatListFilters(postbox: account.postbox, network: account.network) + |> `catch` { _ -> Signal<[ChatListFilter], NoError> in + return .complete() } - - let addFilters = account.postbox.transaction { transaction -> [(Int32, ChatListFilter)] in - let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default - return settings.filters.map { filter -> (Int32, ChatListFilter) in - return (filter.id, filter) + |> mapToSignal { remoteFilters -> Signal in + var deleteSignals: [Signal] = [] + for filter in remoteFilters { + if !filters.contains(where: { $0.id == filter.id }) { + deleteSignals.append(requestUpdateChatListFilter(account: account, id: filter.id, filter: nil) + |> `catch` { _ -> Signal in + return .complete() + } + |> ignoreValues) + } } - } - |> mapToSignal { filters -> Signal in - var signals: [Signal] = [] - for (id, filter) in filters { - signals.append(requestUpdateChatListFilter(account: account, id: id, filter: filter) + + let addFilters = account.postbox.transaction { transaction -> [(Int32, ChatListFilter)] in + let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default + return settings.filters.map { filter -> (Int32, ChatListFilter) in + return (filter.id, filter) + } + } + |> mapToSignal { filters -> Signal in + var signals: [Signal] = [] + for (id, filter) in filters { + if !remoteFilters.contains(filter) { + signals.append(requestUpdateChatListFilter(account: account, id: id, filter: filter) + |> `catch` { _ -> Signal in + return .complete() + } + |> ignoreValues) + } + } + return combineLatest(signals) + |> ignoreValues + } + + let reorderFilters: Signal + if remoteFilters.map({ $0.id }) != filters.map({ $0.id }) { + reorderFilters = account.network.request(Api.functions.messages.updateDialogFiltersOrder(order: filters.map { $0.id })) + |> ignoreValues |> `catch` { _ -> Signal in return .complete() } - |> ignoreValues) + } else { + reorderFilters = .complete() } - return combineLatest(signals) + + return combineLatest( + deleteSignals + ) |> ignoreValues + |> then( + addFilters + ) + |> then( + reorderFilters + ) } - - return combineLatest( - deleteSignals - ) - |> ignoreValues - |> then( - addFilters - ) } } diff --git a/submodules/TelegramCore/Sources/LoadedStickerPack.swift b/submodules/TelegramCore/Sources/LoadedStickerPack.swift index 5a657b13b1..d19b4ab1f5 100644 --- a/submodules/TelegramCore/Sources/LoadedStickerPack.swift +++ b/submodules/TelegramCore/Sources/LoadedStickerPack.swift @@ -18,6 +18,8 @@ extension StickerPackReference { return .inputStickerSetShortName(shortName: name) case .animatedEmoji: return .inputStickerSetAnimatedEmoji + case .dice: + return .inputStickerSetDice } } } diff --git a/submodules/TelegramCore/Sources/Network.swift b/submodules/TelegramCore/Sources/Network.swift index ffb02ddf7b..0e779d912a 100644 --- a/submodules/TelegramCore/Sources/Network.swift +++ b/submodules/TelegramCore/Sources/Network.swift @@ -403,16 +403,18 @@ public struct NetworkInitializationArguments { public let languagesCategory: String public let appVersion: String public let voipMaxLayer: Int32 + public let voipVersions: [String] public let appData: Signal public let autolockDeadine: Signal public let encryptionProvider: EncryptionProvider - public init(apiId: Int32, apiHash: String, languagesCategory: String, appVersion: String, voipMaxLayer: Int32, appData: Signal, autolockDeadine: Signal, encryptionProvider: EncryptionProvider) { + public init(apiId: Int32, apiHash: String, languagesCategory: String, appVersion: String, voipMaxLayer: Int32, voipVersions: [String], appData: Signal, autolockDeadine: Signal, encryptionProvider: EncryptionProvider) { self.apiId = apiId self.apiHash = apiHash self.languagesCategory = languagesCategory self.appVersion = appVersion self.voipMaxLayer = voipMaxLayer + self.voipVersions = voipVersions self.appData = appData self.autolockDeadine = autolockDeadine self.encryptionProvider = encryptionProvider diff --git a/submodules/TelegramCore/Sources/StickerSetInstallation.swift b/submodules/TelegramCore/Sources/StickerSetInstallation.swift index f8f84a4e2d..8a6a1eb5d8 100644 --- a/submodules/TelegramCore/Sources/StickerSetInstallation.swift +++ b/submodules/TelegramCore/Sources/StickerSetInstallation.swift @@ -38,6 +38,9 @@ public func requestStickerSet(postbox: Postbox, network: Network, reference: Sti case .animatedEmoji: collectionId = nil input = .inputStickerSetAnimatedEmoji + case .dice: + collectionId = nil + input = .inputStickerSetDice } let localSignal: (ItemCollectionId) -> Signal<(ItemCollectionInfo, [ItemCollectionItem])?, NoError> = { collectionId in diff --git a/submodules/TelegramCore/Sources/SynchronizeSavedStickersOperation.swift b/submodules/TelegramCore/Sources/SynchronizeSavedStickersOperation.swift index f606cfe342..bd53548f3e 100644 --- a/submodules/TelegramCore/Sources/SynchronizeSavedStickersOperation.swift +++ b/submodules/TelegramCore/Sources/SynchronizeSavedStickersOperation.swift @@ -62,7 +62,7 @@ public func addSavedSticker(postbox: Postbox, network: Network, file: TelegramMe if !found { fetchReference = packReference } - case .animatedEmoji: + case .animatedEmoji, .dice: break } if let fetchReference = fetchReference { diff --git a/submodules/TelegramCore/Sources/TelegramMediaFile.swift b/submodules/TelegramCore/Sources/TelegramMediaFile.swift index 51edbe126b..eebae28228 100644 --- a/submodules/TelegramCore/Sources/TelegramMediaFile.swift +++ b/submodules/TelegramCore/Sources/TelegramMediaFile.swift @@ -59,6 +59,8 @@ extension StickerPackReference { self = .name(shortName) case .inputStickerSetAnimatedEmoji: self = .animatedEmoji + case .inputStickerSetDice: + self = .dice } } } diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index 7cfafefe1a..d2bb674503 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -509,4809 +509,4807 @@ public final class PresentationStrings: Equatable { public var AuthSessions_LogOutApplicationsHelp: String { return self._s[309]! } public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[310]! } public var Month_GenFebruary: String { return self._s[311]! } - public var Wallet_Send_NetworkErrorTitle: String { return self._s[312]! } + public var ChatListFilter_AddChatsTitle: String { return self._s[312]! } + public var Wallet_Send_NetworkErrorTitle: String { return self._s[313]! } public func Login_InvalidPhoneEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[314]!, self._r[314]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[315]!, self._r[315]!, [_1, _2, _3, _4, _5]) } - public var Passport_Identity_TypeIdentityCard: String { return self._s[315]! } - public var Wallet_Month_ShortJune: String { return self._s[317]! } - public var AutoDownloadSettings_DataUsageMedium: String { return self._s[318]! } - public var GroupInfo_AddParticipant: String { return self._s[319]! } - public var KeyCommand_SendMessage: String { return self._s[320]! } - public var VoiceOver_Chat_YourContact: String { return self._s[322]! } - public var Map_LiveLocationShowAll: String { return self._s[323]! } - public var WallpaperSearch_ColorOrange: String { return self._s[325]! } - public var Appearance_AppIconDefaultX: String { return self._s[326]! } - public var Checkout_Receipt_Title: String { return self._s[327]! } - public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[328]! } - public var WallpaperPreview_PreviewTopText: String { return self._s[329]! } - public var Message_Contact: String { return self._s[330]! } - public var Call_StatusIncoming: String { return self._s[331]! } - public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[332]! } + public var Passport_Identity_TypeIdentityCard: String { return self._s[316]! } + public var Wallet_Month_ShortJune: String { return self._s[318]! } + public var AutoDownloadSettings_DataUsageMedium: String { return self._s[319]! } + public var GroupInfo_AddParticipant: String { return self._s[320]! } + public var KeyCommand_SendMessage: String { return self._s[321]! } + public var VoiceOver_Chat_YourContact: String { return self._s[323]! } + public var Map_LiveLocationShowAll: String { return self._s[324]! } + public var WallpaperSearch_ColorOrange: String { return self._s[326]! } + public var Appearance_AppIconDefaultX: String { return self._s[327]! } + public var Checkout_Receipt_Title: String { return self._s[328]! } + public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[329]! } + public var WallpaperPreview_PreviewTopText: String { return self._s[330]! } + public var Message_Contact: String { return self._s[331]! } + public var Call_StatusIncoming: String { return self._s[332]! } + public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[333]! } public func Channel_AdminLog_MessageKickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[333]!, self._r[333]!, [_1]) + return formatWithArgumentRanges(self._s[334]!, self._r[334]!, [_1]) } public func PUSH_ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[335]!, self._r[335]!, [_1]) + return formatWithArgumentRanges(self._s[336]!, self._r[336]!, [_1]) } - public var VoiceOver_Media_PlaybackRate: String { return self._s[336]! } - public var Passport_FieldIdentityDetailsHelp: String { return self._s[337]! } - public var Conversation_ViewChannel: String { return self._s[338]! } + public var VoiceOver_Media_PlaybackRate: String { return self._s[337]! } + public var Passport_FieldIdentityDetailsHelp: String { return self._s[338]! } + public var Conversation_ViewChannel: String { return self._s[339]! } public func Time_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[339]!, self._r[339]!, [_0]) + return formatWithArgumentRanges(self._s[340]!, self._r[340]!, [_0]) } - public var Theme_Colors_Accent: String { return self._s[340]! } - public var Passport_Language_nl: String { return self._s[342]! } - public var Camera_Retake: String { return self._s[343]! } + public var Theme_Colors_Accent: String { return self._s[341]! } + public var Passport_Language_nl: String { return self._s[343]! } + public var Camera_Retake: String { return self._s[344]! } public func UserInfo_BlockActionTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[344]!, self._r[344]!, [_0]) + return formatWithArgumentRanges(self._s[345]!, self._r[345]!, [_0]) } - public var AuthSessions_LogOutApplications: String { return self._s[345]! } - public var ApplyLanguage_ApplySuccess: String { return self._s[346]! } - public var Tour_Title6: String { return self._s[347]! } - public var Map_ChooseAPlace: String { return self._s[348]! } - public var CallSettings_Never: String { return self._s[350]! } + public var AuthSessions_LogOutApplications: String { return self._s[346]! } + public var ApplyLanguage_ApplySuccess: String { return self._s[347]! } + public var Tour_Title6: String { return self._s[348]! } + public var Map_ChooseAPlace: String { return self._s[349]! } + public var CallSettings_Never: String { return self._s[351]! } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[351]!, self._r[351]!, [_0]) + return formatWithArgumentRanges(self._s[352]!, self._r[352]!, [_0]) } - public var ChannelRemoved_RemoveInfo: String { return self._s[352]! } + public var ChannelRemoved_RemoveInfo: String { return self._s[353]! } public func AutoDownloadSettings_PreloadVideoInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[353]!, self._r[353]!, [_0]) + return formatWithArgumentRanges(self._s[354]!, self._r[354]!, [_0]) } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[354]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[355]! } public func Conversation_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[355]!, self._r[355]!, [_0]) + return formatWithArgumentRanges(self._s[356]!, self._r[356]!, [_0]) } - public var GroupInfo_InviteLink_Title: String { return self._s[356]! } + public var GroupInfo_InviteLink_Title: String { return self._s[357]! } public func Channel_AdminLog_MessageUnkickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[357]!, self._r[357]!, [_1, _2]) + return formatWithArgumentRanges(self._s[358]!, self._r[358]!, [_1, _2]) } - public var KeyCommand_ScrollUp: String { return self._s[358]! } - public var ContactInfo_URLLabelHomepage: String { return self._s[359]! } - public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[360]! } + public var KeyCommand_ScrollUp: String { return self._s[359]! } + public var ContactInfo_URLLabelHomepage: String { return self._s[360]! } + public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[361]! } public func Channel_AdminLog_DisabledSlowmode(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[361]!, self._r[361]!, [_0]) + return formatWithArgumentRanges(self._s[362]!, self._r[362]!, [_0]) } - public var TwoFactorSetup_Done_Title: String { return self._s[362]! } + public var TwoFactorSetup_Done_Title: String { return self._s[363]! } public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[363]!, self._r[363]!, [_0]) + return formatWithArgumentRanges(self._s[364]!, self._r[364]!, [_0]) } - public var CallFeedback_ReasonDistortedSpeech: String { return self._s[364]! } - public var Watch_LastSeen_WithinAWeek: String { return self._s[365]! } - public var ContactList_Context_SendMessage: String { return self._s[367]! } - public var Weekday_Tuesday: String { return self._s[368]! } - public var Wallet_Created_Title: String { return self._s[370]! } - public var ScheduledMessages_Delete: String { return self._s[371]! } - public var UserInfo_StartSecretChat: String { return self._s[372]! } - public var Passport_Identity_FilesTitle: String { return self._s[373]! } - public var Permissions_NotificationsAllow_v0: String { return self._s[374]! } - public var DialogList_DeleteConversationConfirmation: String { return self._s[376]! } - public var ChatList_UndoArchiveRevealedTitle: String { return self._s[377]! } + public var CallFeedback_ReasonDistortedSpeech: String { return self._s[365]! } + public var Watch_LastSeen_WithinAWeek: String { return self._s[366]! } + public var ContactList_Context_SendMessage: String { return self._s[368]! } + public var Weekday_Tuesday: String { return self._s[369]! } + public var Wallet_Created_Title: String { return self._s[371]! } + public var ScheduledMessages_Delete: String { return self._s[372]! } + public var UserInfo_StartSecretChat: String { return self._s[373]! } + public var Passport_Identity_FilesTitle: String { return self._s[374]! } + public var Permissions_NotificationsAllow_v0: String { return self._s[375]! } + public var DialogList_DeleteConversationConfirmation: String { return self._s[377]! } + public var ChatList_UndoArchiveRevealedTitle: String { return self._s[378]! } public func Wallet_Configuration_ApplyErrorTextURLUnreachable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[378]!, self._r[378]!, [_0]) + return formatWithArgumentRanges(self._s[379]!, self._r[379]!, [_0]) } - public var AuthSessions_Sessions: String { return self._s[379]! } + public var AuthSessions_Sessions: String { return self._s[380]! } public func Settings_KeepPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[381]!, self._r[381]!, [_0]) + return formatWithArgumentRanges(self._s[382]!, self._r[382]!, [_0]) } - public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[382]! } - public var Call_StatusWaiting: String { return self._s[383]! } - public var CreateGroup_SoftUserLimitAlert: String { return self._s[384]! } - public var FastTwoStepSetup_HintHelp: String { return self._s[385]! } - public var WallpaperPreview_CustomColorBottomText: String { return self._s[386]! } - public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[387]! } - public var LogoutOptions_AddAccountText: String { return self._s[388]! } - public var PasscodeSettings_6DigitCode: String { return self._s[389]! } - public var Settings_LogoutConfirmationText: String { return self._s[390]! } - public var Passport_Identity_TypePassport: String { return self._s[392]! } - public var Map_Work: String { return self._s[395]! } + public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[383]! } + public var Call_StatusWaiting: String { return self._s[384]! } + public var CreateGroup_SoftUserLimitAlert: String { return self._s[385]! } + public var FastTwoStepSetup_HintHelp: String { return self._s[386]! } + public var WallpaperPreview_CustomColorBottomText: String { return self._s[387]! } + public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[388]! } + public var LogoutOptions_AddAccountText: String { return self._s[389]! } + public var PasscodeSettings_6DigitCode: String { return self._s[390]! } + public var Settings_LogoutConfirmationText: String { return self._s[391]! } + public var Passport_Identity_TypePassport: String { return self._s[393]! } + public var Map_Work: String { return self._s[396]! } public func PUSH_MESSAGE_VIDEOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[396]!, self._r[396]!, [_1, _2]) + return formatWithArgumentRanges(self._s[397]!, self._r[397]!, [_1, _2]) } - public var SocksProxySetup_SaveProxy: String { return self._s[397]! } - public var AccessDenied_SaveMedia: String { return self._s[398]! } - public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[400]! } - public var CreatePoll_MultipleChoice: String { return self._s[401]! } - public var Settings_Title: String { return self._s[403]! } - public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[404]! } - public var Contacts_InviteSearchLabel: String { return self._s[406]! } - public var PrivacySettings_WebSessions: String { return self._s[407]! } - public var ConvertToSupergroup_Title: String { return self._s[408]! } + public var SocksProxySetup_SaveProxy: String { return self._s[398]! } + public var AccessDenied_SaveMedia: String { return self._s[399]! } + public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[401]! } + public var CreatePoll_MultipleChoice: String { return self._s[402]! } + public var Settings_Title: String { return self._s[404]! } + public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[405]! } + public var Contacts_InviteSearchLabel: String { return self._s[407]! } + public var PrivacySettings_WebSessions: String { return self._s[408]! } + public var ConvertToSupergroup_Title: String { return self._s[409]! } public func Channel_AdminLog_CaptionEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[409]!, self._r[409]!, [_0]) + return formatWithArgumentRanges(self._s[410]!, self._r[410]!, [_0]) } - public var TwoFactorSetup_Hint_Text: String { return self._s[410]! } - public var InfoPlist_NSSiriUsageDescription: String { return self._s[411]! } + public var TwoFactorSetup_Hint_Text: String { return self._s[411]! } + public var InfoPlist_NSSiriUsageDescription: String { return self._s[412]! } public func PUSH_MESSAGE_CHANNEL_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[412]!, self._r[412]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[413]!, self._r[413]!, [_1, _2, _3]) } - public var ChatSettings_AutomaticPhotoDownload: String { return self._s[413]! } - public var UserInfo_BotHelp: String { return self._s[414]! } - public var PrivacySettings_LastSeenEverybody: String { return self._s[415]! } - public var Checkout_Name: String { return self._s[416]! } - public var AutoDownloadSettings_DataUsage: String { return self._s[417]! } - public var Channel_BanUser_BlockFor: String { return self._s[418]! } - public var Checkout_ShippingAddress: String { return self._s[419]! } - public var AutoDownloadSettings_MaxVideoSize: String { return self._s[420]! } - public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[421]! } - public var Privacy_Forwards: String { return self._s[422]! } - public var Channel_BanUser_PermissionSendPolls: String { return self._s[423]! } - public var Appearance_ThemeCarouselNewNight: String { return self._s[424]! } + public var ChatSettings_AutomaticPhotoDownload: String { return self._s[414]! } + public var UserInfo_BotHelp: String { return self._s[415]! } + public var PrivacySettings_LastSeenEverybody: String { return self._s[416]! } + public var Checkout_Name: String { return self._s[417]! } + public var AutoDownloadSettings_DataUsage: String { return self._s[418]! } + public var Channel_BanUser_BlockFor: String { return self._s[419]! } + public var Checkout_ShippingAddress: String { return self._s[420]! } + public var AutoDownloadSettings_MaxVideoSize: String { return self._s[421]! } + public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[422]! } + public var Privacy_Forwards: String { return self._s[423]! } + public var Channel_BanUser_PermissionSendPolls: String { return self._s[424]! } + public var Appearance_ThemeCarouselNewNight: String { return self._s[425]! } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[427]!, self._r[427]!, [_0]) + return formatWithArgumentRanges(self._s[428]!, self._r[428]!, [_0]) } - public var Contacts_SortedByName: String { return self._s[428]! } - public var Group_OwnershipTransfer_Title: String { return self._s[429]! } - public var PeerInfo_BioExpand: String { return self._s[431]! } - public var VoiceOver_Chat_OpenHint: String { return self._s[432]! } - public var Group_LeaveGroup: String { return self._s[433]! } - public var Settings_UsernameEmpty: String { return self._s[434]! } + public var Contacts_SortedByName: String { return self._s[429]! } + public var Group_OwnershipTransfer_Title: String { return self._s[430]! } + public var PeerInfo_BioExpand: String { return self._s[432]! } + public var VoiceOver_Chat_OpenHint: String { return self._s[433]! } + public var Group_LeaveGroup: String { return self._s[434]! } + public var Settings_UsernameEmpty: String { return self._s[435]! } public func Notification_PinnedPollMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[435]!, self._r[435]!, [_0]) + return formatWithArgumentRanges(self._s[436]!, self._r[436]!, [_0]) } public func TwoStepAuth_ConfirmEmailDescription(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[436]!, self._r[436]!, [_1]) + return formatWithArgumentRanges(self._s[437]!, self._r[437]!, [_1]) } public func Channel_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[437]!, self._r[437]!, [_1, _2]) + return formatWithArgumentRanges(self._s[438]!, self._r[438]!, [_1, _2]) } - public var Message_ImageExpired: String { return self._s[438]! } - public var TwoStepAuth_RecoveryFailed: String { return self._s[440]! } - public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[441]! } - public var UserInfo_AddToExisting: String { return self._s[442]! } - public var TwoStepAuth_EnabledSuccess: String { return self._s[443]! } - public var Wallet_Send_SyncInProgress: String { return self._s[444]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[445]! } + public var Message_ImageExpired: String { return self._s[439]! } + public var TwoStepAuth_RecoveryFailed: String { return self._s[441]! } + public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[442]! } + public var UserInfo_AddToExisting: String { return self._s[443]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[444]! } + public var Wallet_Send_SyncInProgress: String { return self._s[445]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[446]! } public func PUSH_CHANNEL_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[446]!, self._r[446]!, [_1]) + return formatWithArgumentRanges(self._s[447]!, self._r[447]!, [_1]) } - public var Notifications_GroupNotificationsAlert: String { return self._s[447]! } - public var Passport_Language_km: String { return self._s[448]! } - public var SocksProxySetup_AdNoticeHelp: String { return self._s[450]! } - public var VoiceOver_Media_PlaybackPlay: String { return self._s[451]! } - public var Notification_CallMissedShort: String { return self._s[452]! } - public var Wallet_Info_YourBalance: String { return self._s[453]! } - public var ReportPeer_ReasonOther_Send: String { return self._s[455]! } - public var Watch_Compose_Send: String { return self._s[456]! } - public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[459]! } - public var TwoFactorSetup_Email_Action: String { return self._s[460]! } - public var Conversation_HoldForVideo: String { return self._s[461]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[462]! } - public var AuthSessions_OtherDevices: String { return self._s[463]! } - public var Wallet_TransactionInfo_CommentHeader: String { return self._s[464]! } - public var CheckoutInfo_ErrorCityInvalid: String { return self._s[466]! } - public var Appearance_AutoNightThemeDisabled: String { return self._s[468]! } - public var Channel_LinkItem: String { return self._s[469]! } + public var Notifications_GroupNotificationsAlert: String { return self._s[448]! } + public var Passport_Language_km: String { return self._s[449]! } + public var SocksProxySetup_AdNoticeHelp: String { return self._s[451]! } + public var VoiceOver_Media_PlaybackPlay: String { return self._s[452]! } + public var Notification_CallMissedShort: String { return self._s[453]! } + public var Wallet_Info_YourBalance: String { return self._s[454]! } + public var ReportPeer_ReasonOther_Send: String { return self._s[456]! } + public var Watch_Compose_Send: String { return self._s[457]! } + public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[460]! } + public var TwoFactorSetup_Email_Action: String { return self._s[461]! } + public var Conversation_HoldForVideo: String { return self._s[462]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[463]! } + public var AuthSessions_OtherDevices: String { return self._s[464]! } + public var Wallet_TransactionInfo_CommentHeader: String { return self._s[465]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[467]! } + public var Appearance_AutoNightThemeDisabled: String { return self._s[469]! } + public var Channel_LinkItem: String { return self._s[470]! } public func PrivacySettings_LastSeenContactsMinusPlus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[470]!, self._r[470]!, [_0, _1]) + return formatWithArgumentRanges(self._s[471]!, self._r[471]!, [_0, _1]) } public func Passport_Identity_NativeNameTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[473]!, self._r[473]!, [_0]) + return formatWithArgumentRanges(self._s[474]!, self._r[474]!, [_0]) } - public var VoiceOver_Recording_StopAndPreview: String { return self._s[474]! } - public var Passport_Language_dv: String { return self._s[475]! } - public var Undo_LeftChannel: String { return self._s[476]! } - public var Notifications_ExceptionsMuted: String { return self._s[477]! } - public var ChatList_UnhideAction: String { return self._s[478]! } - public var Conversation_ContextMenuShare: String { return self._s[479]! } - public var Conversation_ContextMenuStickerPackInfo: String { return self._s[480]! } - public var ShareFileTip_Title: String { return self._s[481]! } - public var NotificationsSound_Chord: String { return self._s[482]! } - public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[483]! } + public var VoiceOver_Recording_StopAndPreview: String { return self._s[475]! } + public var Passport_Language_dv: String { return self._s[476]! } + public var Undo_LeftChannel: String { return self._s[477]! } + public var Notifications_ExceptionsMuted: String { return self._s[478]! } + public var ChatList_UnhideAction: String { return self._s[479]! } + public var Conversation_ContextMenuShare: String { return self._s[480]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[481]! } + public var ShareFileTip_Title: String { return self._s[482]! } + public var NotificationsSound_Chord: String { return self._s[483]! } + public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[484]! } public func PUSH_CHAT_RETURNED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[484]!, self._r[484]!, [_1, _2]) + return formatWithArgumentRanges(self._s[485]!, self._r[485]!, [_1, _2]) } - public var Passport_Address_EditTemporaryRegistration: String { return self._s[485]! } + public var Passport_Address_EditTemporaryRegistration: String { return self._s[486]! } public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[486]!, self._r[486]!, [_0]) + return formatWithArgumentRanges(self._s[487]!, self._r[487]!, [_0]) } public func Wallet_Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[487]!, self._r[487]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[488]!, self._r[488]!, [_1, _2, _3]) } - public var Wallet_Settings_ConfigurationInfo: String { return self._s[488]! } - public var Wallpaper_ErrorNotFound: String { return self._s[489]! } - public var Notification_CallOutgoingShort: String { return self._s[491]! } - public var Wallet_WordImport_IncorrectText: String { return self._s[492]! } + public var Wallet_Settings_ConfigurationInfo: String { return self._s[489]! } + public var Wallpaper_ErrorNotFound: String { return self._s[490]! } + public var Notification_CallOutgoingShort: String { return self._s[492]! } + public var Wallet_WordImport_IncorrectText: String { return self._s[493]! } public func Watch_Time_ShortFullAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[493]!, self._r[493]!, [_1, _2]) + return formatWithArgumentRanges(self._s[494]!, self._r[494]!, [_1, _2]) } - public var Passport_Address_TypeUtilityBill: String { return self._s[494]! } - public var Privacy_Forwards_LinkIfAllowed: String { return self._s[495]! } - public var ReportPeer_Report: String { return self._s[496]! } - public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[497]! } - public var GroupInfo_DeactivatedStatus: String { return self._s[498]! } + public var Passport_Address_TypeUtilityBill: String { return self._s[495]! } + public var Privacy_Forwards_LinkIfAllowed: String { return self._s[496]! } + public var ReportPeer_Report: String { return self._s[497]! } + public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[498]! } + public var GroupInfo_DeactivatedStatus: String { return self._s[499]! } public func VoiceOver_Chat_MusicTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[499]!, self._r[499]!, [_1, _2]) + return formatWithArgumentRanges(self._s[500]!, self._r[500]!, [_1, _2]) } - public var StickerPack_Send: String { return self._s[500]! } - public var Login_CodeSentInternal: String { return self._s[501]! } - public var Wallet_Month_GenJanuary: String { return self._s[502]! } - public var GroupInfo_InviteLink_LinkSection: String { return self._s[503]! } + public var StickerPack_Send: String { return self._s[501]! } + public var Login_CodeSentInternal: String { return self._s[502]! } + public var Wallet_Month_GenJanuary: String { return self._s[503]! } + public var GroupInfo_InviteLink_LinkSection: String { return self._s[504]! } public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[504]!, self._r[504]!, [_0]) + return formatWithArgumentRanges(self._s[505]!, self._r[505]!, [_0]) } public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[506]!, self._r[506]!, [_0]) + return formatWithArgumentRanges(self._s[507]!, self._r[507]!, [_0]) } - public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[507]! } + public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[508]! } public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[508]!, self._r[508]!, [_1]) + return formatWithArgumentRanges(self._s[509]!, self._r[509]!, [_1]) } - public var ReportPeer_ReasonViolence: String { return self._s[510]! } - public var Appearance_ShareThemeColor: String { return self._s[511]! } - public var Map_Locating: String { return self._s[512]! } + public var ReportPeer_ReasonViolence: String { return self._s[511]! } + public var Appearance_ShareThemeColor: String { return self._s[512]! } + public var Map_Locating: String { return self._s[513]! } public func VoiceOver_Chat_VideoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[513]!, self._r[513]!, [_0]) + return formatWithArgumentRanges(self._s[514]!, self._r[514]!, [_0]) } public func PUSH_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[514]!, self._r[514]!, [_1]) + return formatWithArgumentRanges(self._s[515]!, self._r[515]!, [_1]) } - public var AutoDownloadSettings_GroupChats: String { return self._s[516]! } - public var CheckoutInfo_SaveInfo: String { return self._s[517]! } - public var SharedMedia_EmptyLinksText: String { return self._s[519]! } - public var Passport_Address_CityPlaceholder: String { return self._s[520]! } - public var CheckoutInfo_ErrorStateInvalid: String { return self._s[521]! } - public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[522]! } - public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[524]! } - public var Channel_AdminLog_CanAddAdmins: String { return self._s[525]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[517]! } + public var CheckoutInfo_SaveInfo: String { return self._s[518]! } + public var SharedMedia_EmptyLinksText: String { return self._s[520]! } + public var Passport_Address_CityPlaceholder: String { return self._s[521]! } + public var CheckoutInfo_ErrorStateInvalid: String { return self._s[522]! } + public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[523]! } + public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[525]! } + public var Channel_AdminLog_CanAddAdmins: String { return self._s[526]! } public func PUSH_CHANNEL_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[526]!, self._r[526]!, [_1]) + return formatWithArgumentRanges(self._s[527]!, self._r[527]!, [_1]) } public func Time_MonthOfYear_m8(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[527]!, self._r[527]!, [_0]) + return formatWithArgumentRanges(self._s[528]!, self._r[528]!, [_0]) } - public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[528]! } - public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[529]! } - public var ChangePhoneNumberCode_Code: String { return self._s[530]! } - public var Appearance_CreateTheme: String { return self._s[531]! } + public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[529]! } + public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[530]! } + public var ChangePhoneNumberCode_Code: String { return self._s[531]! } + public var Appearance_CreateTheme: String { return self._s[532]! } public func UserInfo_NotificationsDefaultSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[532]!, self._r[532]!, [_0]) + return formatWithArgumentRanges(self._s[533]!, self._r[533]!, [_0]) } - public var TwoStepAuth_SetupEmail: String { return self._s[533]! } - public var HashtagSearch_AllChats: String { return self._s[534]! } - public var MediaPlayer_UnknownTrack: String { return self._s[535]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[537]! } + public var TwoStepAuth_SetupEmail: String { return self._s[534]! } + public var HashtagSearch_AllChats: String { return self._s[535]! } + public var MediaPlayer_UnknownTrack: String { return self._s[536]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[538]! } public func ChatList_DeleteForEveryone(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[538]!, self._r[538]!, [_0]) + return formatWithArgumentRanges(self._s[539]!, self._r[539]!, [_0]) } - public var PhotoEditor_QualityHigh: String { return self._s[540]! } + public var PhotoEditor_QualityHigh: String { return self._s[541]! } public func Passport_Phone_UseTelegramNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[541]!, self._r[541]!, [_0]) + return formatWithArgumentRanges(self._s[542]!, self._r[542]!, [_0]) } - public var ApplyLanguage_ApplyLanguageAction: String { return self._s[542]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[543]! } - public var Message_LiveLocation: String { return self._s[544]! } - public var Cache_LowDiskSpaceText: String { return self._s[545]! } - public var Wallet_Receive_ShareAddress: String { return self._s[546]! } - public var EditTheme_ErrorLinkTaken: String { return self._s[547]! } - public var Conversation_SendMessage: String { return self._s[548]! } - public var AuthSessions_EmptyTitle: String { return self._s[549]! } - public var Privacy_PhoneNumber: String { return self._s[550]! } - public var PeopleNearby_CreateGroup: String { return self._s[551]! } - public var Stats_SharesPerPost: String { return self._s[553]! } - public var CallSettings_UseLessData: String { return self._s[554]! } - public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[555]! } - public var Stickers_AddToFavorites: String { return self._s[556]! } - public var Wallet_WordImport_Title: String { return self._s[557]! } - public var PhotoEditor_QualityLow: String { return self._s[558]! } - public var Watch_UserInfo_Unblock: String { return self._s[559]! } - public var Settings_Logout: String { return self._s[560]! } + public var ApplyLanguage_ApplyLanguageAction: String { return self._s[543]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[544]! } + public var Message_LiveLocation: String { return self._s[545]! } + public var Cache_LowDiskSpaceText: String { return self._s[546]! } + public var Wallet_Receive_ShareAddress: String { return self._s[547]! } + public var EditTheme_ErrorLinkTaken: String { return self._s[548]! } + public var Conversation_SendMessage: String { return self._s[549]! } + public var AuthSessions_EmptyTitle: String { return self._s[550]! } + public var Privacy_PhoneNumber: String { return self._s[551]! } + public var PeopleNearby_CreateGroup: String { return self._s[552]! } + public var Stats_SharesPerPost: String { return self._s[554]! } + public var CallSettings_UseLessData: String { return self._s[555]! } + public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[556]! } + public var Stickers_AddToFavorites: String { return self._s[557]! } + public var Wallet_WordImport_Title: String { return self._s[558]! } + public var PhotoEditor_QualityLow: String { return self._s[559]! } + public var Watch_UserInfo_Unblock: String { return self._s[560]! } + public var Settings_Logout: String { return self._s[561]! } public func PUSH_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[561]!, self._r[561]!, [_1]) + return formatWithArgumentRanges(self._s[562]!, self._r[562]!, [_1]) } - public var ContactInfo_PhoneLabelWork: String { return self._s[562]! } - public var ChannelInfo_Stats: String { return self._s[563]! } - public var TextFormat_Link: String { return self._s[564]! } + public var ContactInfo_PhoneLabelWork: String { return self._s[563]! } + public var ChannelInfo_Stats: String { return self._s[564]! } + public var TextFormat_Link: String { return self._s[565]! } public func Date_ChatDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[565]!, self._r[565]!, [_1, _2]) + return formatWithArgumentRanges(self._s[566]!, self._r[566]!, [_1, _2]) } - public var Wallet_TransactionInfo_Title: String { return self._s[566]! } + public var Wallet_TransactionInfo_Title: String { return self._s[567]! } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[567]!, self._r[567]!, [_0]) + return formatWithArgumentRanges(self._s[568]!, self._r[568]!, [_0]) } - public var Watch_Notification_Joined: String { return self._s[568]! } - public var Group_Setup_TypePublicHelp: String { return self._s[569]! } - public var Passport_Scans_UploadNew: String { return self._s[570]! } - public var Checkout_LiabilityAlertTitle: String { return self._s[571]! } - public var DialogList_Title: String { return self._s[574]! } - public var NotificationSettings_ContactJoined: String { return self._s[575]! } - public var GroupInfo_LabelAdmin: String { return self._s[576]! } - public var KeyCommand_ChatInfo: String { return self._s[577]! } - public var Conversation_EditingCaptionPanelTitle: String { return self._s[578]! } - public var Call_ReportIncludeLog: String { return self._s[579]! } + public var Watch_Notification_Joined: String { return self._s[569]! } + public var Group_Setup_TypePublicHelp: String { return self._s[570]! } + public var Passport_Scans_UploadNew: String { return self._s[571]! } + public var Checkout_LiabilityAlertTitle: String { return self._s[572]! } + public var DialogList_Title: String { return self._s[575]! } + public var NotificationSettings_ContactJoined: String { return self._s[576]! } + public var GroupInfo_LabelAdmin: String { return self._s[577]! } + public var KeyCommand_ChatInfo: String { return self._s[578]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[579]! } + public var Call_ReportIncludeLog: String { return self._s[580]! } public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[582]!, self._r[582]!, [_0]) + return formatWithArgumentRanges(self._s[583]!, self._r[583]!, [_0]) } - public var Stats_Followers: String { return self._s[583]! } - public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[584]! } - public var ChatAdmins_AllMembersAreAdmins: String { return self._s[585]! } - public var LocalGroup_IrrelevantWarning: String { return self._s[586]! } - public var Conversation_DefaultRestrictedInline: String { return self._s[587]! } - public var Message_Sticker: String { return self._s[588]! } - public var LastSeen_JustNow: String { return self._s[590]! } - public var Passport_Email_EmailPlaceholder: String { return self._s[592]! } - public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[593]! } - public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[594]! } - public var Channel_EditAdmin_PermissionsHeader: String { return self._s[595]! } - public var TwoStepAuth_Email: String { return self._s[596]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[597]! } - public var PhotoEditor_BlurToolOff: String { return self._s[598]! } - public var Message_PinnedStickerMessage: String { return self._s[599]! } - public var ContactInfo_PhoneLabelPager: String { return self._s[600]! } - public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[601]! } - public var Passport_DiscardMessageTitle: String { return self._s[602]! } - public var Privacy_PaymentsTitle: String { return self._s[603]! } - public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[604]! } - public var ClearCache_StorageCache: String { return self._s[605]! } - public var Appearance_TextSizeSetting: String { return self._s[606]! } - public var Channel_DiscussionGroup_Header: String { return self._s[608]! } - public var VoiceOver_Chat_OptionSelected: String { return self._s[609]! } - public var Appearance_ColorTheme: String { return self._s[610]! } - public var UserInfo_ShareContact: String { return self._s[611]! } - public var Passport_Address_TypePassportRegistration: String { return self._s[612]! } - public var Common_More: String { return self._s[613]! } - public var Watch_Message_Call: String { return self._s[614]! } - public var Profile_EncryptionKey: String { return self._s[617]! } - public var Privacy_TopPeers: String { return self._s[618]! } - public var Conversation_StopPollConfirmation: String { return self._s[619]! } - public var Wallet_Words_NotDoneText: String { return self._s[621]! } - public var Privacy_TopPeersWarning: String { return self._s[623]! } - public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[624]! } - public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[625]! } - public var Wallet_RestoreFailed_EnterWords: String { return self._s[628]! } - public var DialogList_SearchSectionMessages: String { return self._s[629]! } - public var Notifications_ChannelNotifications: String { return self._s[630]! } - public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[631]! } - public var Passport_Language_sk: String { return self._s[632]! } - public var Notification_MessageLifetime1h: String { return self._s[633]! } - public var Wallpaper_ResetWallpapersInfo: String { return self._s[634]! } - public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[635]! } - public var Call_ReportSkip: String { return self._s[637]! } - public var Cache_ServiceFiles: String { return self._s[638]! } - public var Group_ErrorAddTooMuchAdmins: String { return self._s[639]! } - public var VoiceOver_Chat_YourFile: String { return self._s[640]! } - public var Map_Hybrid: String { return self._s[641]! } - public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[643]! } + public var Stats_Followers: String { return self._s[584]! } + public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[585]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[586]! } + public var LocalGroup_IrrelevantWarning: String { return self._s[587]! } + public var Conversation_DefaultRestrictedInline: String { return self._s[588]! } + public var Message_Sticker: String { return self._s[589]! } + public var LastSeen_JustNow: String { return self._s[591]! } + public var Passport_Email_EmailPlaceholder: String { return self._s[593]! } + public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[594]! } + public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[595]! } + public var Channel_EditAdmin_PermissionsHeader: String { return self._s[596]! } + public var TwoStepAuth_Email: String { return self._s[597]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[598]! } + public var PhotoEditor_BlurToolOff: String { return self._s[599]! } + public var Message_PinnedStickerMessage: String { return self._s[600]! } + public var ContactInfo_PhoneLabelPager: String { return self._s[601]! } + public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[602]! } + public var Passport_DiscardMessageTitle: String { return self._s[603]! } + public var Privacy_PaymentsTitle: String { return self._s[604]! } + public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[605]! } + public var ClearCache_StorageCache: String { return self._s[606]! } + public var Appearance_TextSizeSetting: String { return self._s[607]! } + public var Channel_DiscussionGroup_Header: String { return self._s[609]! } + public var VoiceOver_Chat_OptionSelected: String { return self._s[610]! } + public var Appearance_ColorTheme: String { return self._s[611]! } + public var UserInfo_ShareContact: String { return self._s[612]! } + public var Passport_Address_TypePassportRegistration: String { return self._s[613]! } + public var Common_More: String { return self._s[614]! } + public var Watch_Message_Call: String { return self._s[615]! } + public var Profile_EncryptionKey: String { return self._s[618]! } + public var Privacy_TopPeers: String { return self._s[619]! } + public var Conversation_StopPollConfirmation: String { return self._s[620]! } + public var Wallet_Words_NotDoneText: String { return self._s[622]! } + public var Privacy_TopPeersWarning: String { return self._s[624]! } + public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[625]! } + public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[626]! } + public var Wallet_RestoreFailed_EnterWords: String { return self._s[629]! } + public var DialogList_SearchSectionMessages: String { return self._s[630]! } + public var Notifications_ChannelNotifications: String { return self._s[631]! } + public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[632]! } + public var Passport_Language_sk: String { return self._s[633]! } + public var Notification_MessageLifetime1h: String { return self._s[634]! } + public var Wallpaper_ResetWallpapersInfo: String { return self._s[635]! } + public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[636]! } + public var Call_ReportSkip: String { return self._s[638]! } + public var Cache_ServiceFiles: String { return self._s[639]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[640]! } + public var VoiceOver_Chat_YourFile: String { return self._s[641]! } + public var Map_Hybrid: String { return self._s[642]! } + public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[644]! } public func PUSH_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[644]!, self._r[644]!, [_1]) + return formatWithArgumentRanges(self._s[645]!, self._r[645]!, [_1]) } - public var ChatSettings_AutoDownloadVideos: String { return self._s[646]! } - public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[647]! } - public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[648]! } - public var SocksProxySetup_ProxyTelegram: String { return self._s[651]! } + public var ChatSettings_AutoDownloadVideos: String { return self._s[647]! } + public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[648]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[649]! } + public var SocksProxySetup_ProxyTelegram: String { return self._s[652]! } public func PUSH_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[652]!, self._r[652]!, [_1]) + return formatWithArgumentRanges(self._s[653]!, self._r[653]!, [_1]) } - public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[654]! } - public var ScheduledMessages_ScheduledToday: String { return self._s[655]! } + public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[655]! } + public var ScheduledMessages_ScheduledToday: String { return self._s[656]! } public func PUSH_CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[656]!, self._r[656]!, [_1, _2]) + return formatWithArgumentRanges(self._s[657]!, self._r[657]!, [_1, _2]) } - public var Conversation_LiveLocationYou: String { return self._s[657]! } - public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[658]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[659]! } - public var UserInfo_ShareBot: String { return self._s[662]! } + public var Conversation_LiveLocationYou: String { return self._s[658]! } + public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[659]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[660]! } + public var UserInfo_ShareBot: String { return self._s[663]! } public func PUSH_AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[663]!, self._r[663]!, [_1, _2]) + return formatWithArgumentRanges(self._s[664]!, self._r[664]!, [_1, _2]) } - public var Conversation_ClearCache: String { return self._s[664]! } - public var PhotoEditor_ShadowsTint: String { return self._s[665]! } - public var Message_Audio: String { return self._s[666]! } - public var Passport_Language_lt: String { return self._s[667]! } + public var Conversation_ClearCache: String { return self._s[665]! } + public var PhotoEditor_ShadowsTint: String { return self._s[666]! } + public var Message_Audio: String { return self._s[667]! } + public var Passport_Language_lt: String { return self._s[668]! } public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[668]!, self._r[668]!, [_0]) + return formatWithArgumentRanges(self._s[669]!, self._r[669]!, [_0]) } - public var Permissions_SiriText_v0: String { return self._s[669]! } - public var Conversation_FileICloudDrive: String { return self._s[670]! } - public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[671]! } - public var Notifications_Badge_IncludeMutedChats: String { return self._s[672]! } + public var Permissions_SiriText_v0: String { return self._s[670]! } + public var Conversation_FileICloudDrive: String { return self._s[671]! } + public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[672]! } + public var Notifications_Badge_IncludeMutedChats: String { return self._s[673]! } public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[673]!, self._r[673]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[674]!, self._r[674]!, [_1, _2, _3, _4, _5, _6]) } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[674]! } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[675]! } public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[675]!, self._r[675]!, [_0]) + return formatWithArgumentRanges(self._s[676]!, self._r[676]!, [_0]) } - public var Channel_SignMessages: String { return self._s[676]! } + public var Channel_SignMessages: String { return self._s[677]! } public func PUSH_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[677]!, self._r[677]!, [_1]) + return formatWithArgumentRanges(self._s[678]!, self._r[678]!, [_1]) } - public var Compose_ChannelTokenListPlaceholder: String { return self._s[678]! } - public var Passport_ScanPassport: String { return self._s[679]! } - public var Watch_Suggestion_Thanks: String { return self._s[680]! } - public var BlockedUsers_AddNew: String { return self._s[681]! } + public var Compose_ChannelTokenListPlaceholder: String { return self._s[679]! } + public var Passport_ScanPassport: String { return self._s[680]! } + public var Watch_Suggestion_Thanks: String { return self._s[681]! } + public var BlockedUsers_AddNew: String { return self._s[682]! } public func PUSH_CHAT_MESSAGE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[682]!, self._r[682]!, [_1, _2]) + return formatWithArgumentRanges(self._s[683]!, self._r[683]!, [_1, _2]) } - public var Watch_Message_Invoice: String { return self._s[683]! } - public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[684]! } - public var Month_GenJuly: String { return self._s[685]! } - public var CreatePoll_QuizInfo: String { return self._s[686]! } - public var UserInfo_StartSecretChatStart: String { return self._s[687]! } - public var SocksProxySetup_ProxySocks5: String { return self._s[688]! } - public var IntentsSettings_SuggestByShare: String { return self._s[690]! } - public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[691]! } - public var Notification_ChannelInviterSelf: String { return self._s[692]! } - public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[693]! } + public var Watch_Message_Invoice: String { return self._s[684]! } + public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[685]! } + public var Month_GenJuly: String { return self._s[686]! } + public var CreatePoll_QuizInfo: String { return self._s[687]! } + public var UserInfo_StartSecretChatStart: String { return self._s[688]! } + public var SocksProxySetup_ProxySocks5: String { return self._s[689]! } + public var IntentsSettings_SuggestByShare: String { return self._s[691]! } + public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[692]! } + public var Notification_ChannelInviterSelf: String { return self._s[693]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[694]! } public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[694]!, self._r[694]!, [_1, _2]) + return formatWithArgumentRanges(self._s[695]!, self._r[695]!, [_1, _2]) } - public var Stats_FollowersTitle: String { return self._s[695]! } - public var CheckoutInfo_Title: String { return self._s[696]! } - public var Watch_Stickers_RecentPlaceholder: String { return self._s[697]! } + public var Stats_FollowersTitle: String { return self._s[696]! } + public var CheckoutInfo_Title: String { return self._s[697]! } + public var Watch_Stickers_RecentPlaceholder: String { return self._s[698]! } public func Map_DistanceAway(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[698]!, self._r[698]!, [_0]) + return formatWithArgumentRanges(self._s[699]!, self._r[699]!, [_0]) } - public var Passport_Identity_MainPage: String { return self._s[699]! } - public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[700]! } - public var Passport_Language_de: String { return self._s[701]! } - public var PeerInfo_PaneVoice: String { return self._s[702]! } - public var Update_Title: String { return self._s[703]! } - public var ContactInfo_PhoneLabelWorkFax: String { return self._s[704]! } - public var Channel_AdminLog_BanEmbedLinks: String { return self._s[705]! } - public var Passport_Email_UseTelegramEmailHelp: String { return self._s[706]! } - public var Notifications_ChannelNotificationsPreview: String { return self._s[707]! } - public var NotificationsSound_Telegraph: String { return self._s[708]! } - public var Watch_LastSeen_ALongTimeAgo: String { return self._s[709]! } - public var ChannelMembers_WhoCanAddMembers: String { return self._s[710]! } + public var Passport_Identity_MainPage: String { return self._s[700]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[701]! } + public var Passport_Language_de: String { return self._s[702]! } + public var PeerInfo_PaneVoice: String { return self._s[703]! } + public var Update_Title: String { return self._s[704]! } + public var ContactInfo_PhoneLabelWorkFax: String { return self._s[705]! } + public var Channel_AdminLog_BanEmbedLinks: String { return self._s[706]! } + public var Passport_Email_UseTelegramEmailHelp: String { return self._s[707]! } + public var Notifications_ChannelNotificationsPreview: String { return self._s[708]! } + public var NotificationsSound_Telegraph: String { return self._s[709]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[710]! } + public var ChannelMembers_WhoCanAddMembers: String { return self._s[711]! } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[711]!, self._r[711]!, [_0]) + return formatWithArgumentRanges(self._s[712]!, self._r[712]!, [_0]) } - public var ClearCache_Description: String { return self._s[712]! } - public var Stickers_SuggestAll: String { return self._s[713]! } - public var Conversation_ForwardTitle: String { return self._s[714]! } - public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[715]! } + public var ClearCache_Description: String { return self._s[713]! } + public var Stickers_SuggestAll: String { return self._s[714]! } + public var Conversation_ForwardTitle: String { return self._s[715]! } + public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[716]! } public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[716]!, self._r[716]!, [_0]) + return formatWithArgumentRanges(self._s[717]!, self._r[717]!, [_0]) } - public var Calls_NewCall: String { return self._s[717]! } - public var Call_StatusEnded: String { return self._s[718]! } - public var AutoDownloadSettings_DataUsageLow: String { return self._s[719]! } - public var Settings_ProxyConnected: String { return self._s[720]! } - public var Channel_AdminLogFilter_EventsPinned: String { return self._s[721]! } - public var PhotoEditor_QualityVeryLow: String { return self._s[722]! } - public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[723]! } - public var Passport_PasswordPlaceholder: String { return self._s[724]! } - public var Message_PinnedInvoice: String { return self._s[725]! } - public var Passport_Identity_IssueDate: String { return self._s[726]! } - public var Passport_Language_pl: String { return self._s[727]! } + public var Calls_NewCall: String { return self._s[718]! } + public var Call_StatusEnded: String { return self._s[719]! } + public var AutoDownloadSettings_DataUsageLow: String { return self._s[720]! } + public var Settings_ProxyConnected: String { return self._s[721]! } + public var Channel_AdminLogFilter_EventsPinned: String { return self._s[722]! } + public var PhotoEditor_QualityVeryLow: String { return self._s[723]! } + public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[724]! } + public var Passport_PasswordPlaceholder: String { return self._s[725]! } + public var Message_PinnedInvoice: String { return self._s[726]! } + public var Passport_Identity_IssueDate: String { return self._s[727]! } + public var Passport_Language_pl: String { return self._s[728]! } public func ChannelInfo_ChannelForbidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[728]!, self._r[728]!, [_0]) + return formatWithArgumentRanges(self._s[729]!, self._r[729]!, [_0]) } - public var Call_StatusConnecting: String { return self._s[729]! } - public var SocksProxySetup_PasteFromClipboard: String { return self._s[730]! } + public var Call_StatusConnecting: String { return self._s[730]! } + public var SocksProxySetup_PasteFromClipboard: String { return self._s[731]! } public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[731]!, self._r[731]!, [_0]) + return formatWithArgumentRanges(self._s[732]!, self._r[732]!, [_0]) } - public var ChatSettings_ConnectionType_UseProxy: String { return self._s[733]! } - public var Common_Edit: String { return self._s[734]! } - public var PrivacySettings_LastSeenNobody: String { return self._s[735]! } + public var ChatSettings_ConnectionType_UseProxy: String { return self._s[734]! } + public var Common_Edit: String { return self._s[735]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[736]! } public func Notification_LeftChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[736]!, self._r[736]!, [_0]) + return formatWithArgumentRanges(self._s[737]!, self._r[737]!, [_0]) } - public var GroupInfo_ChatAdmins: String { return self._s[737]! } - public var PrivateDataSettings_Title: String { return self._s[738]! } - public var Login_CancelPhoneVerificationStop: String { return self._s[739]! } - public var ChatList_Read: String { return self._s[740]! } - public var Wallet_WordImport_Text: String { return self._s[741]! } - public var Undo_ChatClearedForBothSides: String { return self._s[742]! } - public var GroupPermission_SectionTitle: String { return self._s[743]! } - public var TwoFactorSetup_Intro_Title: String { return self._s[745]! } + public var GroupInfo_ChatAdmins: String { return self._s[738]! } + public var PrivateDataSettings_Title: String { return self._s[739]! } + public var Login_CancelPhoneVerificationStop: String { return self._s[740]! } + public var ChatList_Read: String { return self._s[741]! } + public var Wallet_WordImport_Text: String { return self._s[742]! } + public var Undo_ChatClearedForBothSides: String { return self._s[743]! } + public var GroupPermission_SectionTitle: String { return self._s[744]! } + public var TwoFactorSetup_Intro_Title: String { return self._s[746]! } public func PUSH_CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[746]!, self._r[746]!, [_1, _2]) + return formatWithArgumentRanges(self._s[747]!, self._r[747]!, [_1, _2]) } - public var Checkout_ErrorPaymentFailed: String { return self._s[747]! } - public var Update_UpdateApp: String { return self._s[748]! } - public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[749]! } - public var Settings_Appearance: String { return self._s[750]! } - public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[754]! } - public var Watch_Location_Access: String { return self._s[755]! } - public var ShareMenu_CopyShareLink: String { return self._s[757]! } - public var TwoStepAuth_SetupHintTitle: String { return self._s[758]! } - public var Conversation_Theme: String { return self._s[760]! } + public var Checkout_ErrorPaymentFailed: String { return self._s[748]! } + public var Update_UpdateApp: String { return self._s[749]! } + public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[750]! } + public var Settings_Appearance: String { return self._s[751]! } + public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[755]! } + public var Watch_Location_Access: String { return self._s[756]! } + public var ShareMenu_CopyShareLink: String { return self._s[758]! } + public var TwoStepAuth_SetupHintTitle: String { return self._s[759]! } + public var Conversation_Theme: String { return self._s[761]! } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[761]!, self._r[761]!, [_0]) + return formatWithArgumentRanges(self._s[762]!, self._r[762]!, [_0]) } - public var Notifications_ClassicTones: String { return self._s[762]! } - public var Weekday_ShortWednesday: String { return self._s[763]! } - public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[764]! } - public var Undo_LeftGroup: String { return self._s[767]! } - public var Wallet_RestoreFailed_Text: String { return self._s[768]! } - public var Conversation_LinkDialogCopy: String { return self._s[769]! } - public var Wallet_TransactionInfo_NoAddress: String { return self._s[771]! } - public var Wallet_Navigation_Back: String { return self._s[772]! } - public var KeyCommand_FocusOnInputField: String { return self._s[773]! } - public var Contacts_SelectAll: String { return self._s[774]! } - public var Preview_SaveToCameraRoll: String { return self._s[775]! } - public var PrivacySettings_PasscodeOff: String { return self._s[776]! } - public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[777]! } + public var Notifications_ClassicTones: String { return self._s[763]! } + public var Weekday_ShortWednesday: String { return self._s[764]! } + public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[765]! } + public var Undo_LeftGroup: String { return self._s[768]! } + public var Wallet_RestoreFailed_Text: String { return self._s[769]! } + public var Conversation_LinkDialogCopy: String { return self._s[770]! } + public var Wallet_TransactionInfo_NoAddress: String { return self._s[772]! } + public var Wallet_Navigation_Back: String { return self._s[773]! } + public var KeyCommand_FocusOnInputField: String { return self._s[774]! } + public var Contacts_SelectAll: String { return self._s[775]! } + public var Preview_SaveToCameraRoll: String { return self._s[776]! } + public var PrivacySettings_PasscodeOff: String { return self._s[777]! } + public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[778]! } public func PUSH_CHANNEL_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[778]!, self._r[778]!, [_1]) + return formatWithArgumentRanges(self._s[779]!, self._r[779]!, [_1]) } - public var Wallpaper_Title: String { return self._s[779]! } - public var Conversation_FilePhotoOrVideo: String { return self._s[780]! } - public var AccessDenied_Camera: String { return self._s[781]! } - public var Watch_Compose_CurrentLocation: String { return self._s[782]! } - public var PeerInfo_ButtonMessage: String { return self._s[784]! } - public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[785]! } + public var Wallpaper_Title: String { return self._s[780]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[781]! } + public var AccessDenied_Camera: String { return self._s[782]! } + public var Watch_Compose_CurrentLocation: String { return self._s[783]! } + public var PeerInfo_ButtonMessage: String { return self._s[785]! } + public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[786]! } public func SecretImage_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[786]!, self._r[786]!, [_0]) + return formatWithArgumentRanges(self._s[787]!, self._r[787]!, [_0]) } - public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[787]! } - public var Passport_Language_ro: String { return self._s[788]! } - public var EditTheme_UploadNewTheme: String { return self._s[789]! } - public var CheckoutInfo_SaveInfoHelp: String { return self._s[790]! } - public var Wallet_Intro_Terms: String { return self._s[791]! } + public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[788]! } + public var Passport_Language_ro: String { return self._s[789]! } + public var EditTheme_UploadNewTheme: String { return self._s[790]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[791]! } + public var Wallet_Intro_Terms: String { return self._s[792]! } public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[792]!, self._r[792]!, [_0]) + return formatWithArgumentRanges(self._s[793]!, self._r[793]!, [_0]) } - public var Login_CancelPhoneVerification: String { return self._s[793]! } - public var State_ConnectingToProxy: String { return self._s[794]! } - public var Calls_RatingTitle: String { return self._s[795]! } - public var Generic_ErrorMoreInfo: String { return self._s[796]! } - public var ChatList_Search_ShowMore: String { return self._s[797]! } - public var Appearance_PreviewReplyText: String { return self._s[798]! } - public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[799]! } + public var Login_CancelPhoneVerification: String { return self._s[794]! } + public var State_ConnectingToProxy: String { return self._s[795]! } + public var Calls_RatingTitle: String { return self._s[796]! } + public var Generic_ErrorMoreInfo: String { return self._s[797]! } + public var ChatList_Search_ShowMore: String { return self._s[798]! } + public var Appearance_PreviewReplyText: String { return self._s[799]! } + public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[800]! } public func Wallet_Send_Balance(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[800]!, self._r[800]!, [_0]) + return formatWithArgumentRanges(self._s[801]!, self._r[801]!, [_0]) } - public var IntentsSettings_SuggestedChatsContacts: String { return self._s[801]! } - public var SharedMedia_CategoryLinks: String { return self._s[802]! } - public var Calls_Missed: String { return self._s[803]! } - public var Cache_Photos: String { return self._s[807]! } - public var GroupPermission_NoAddMembers: String { return self._s[808]! } - public var ScheduledMessages_Title: String { return self._s[809]! } + public var IntentsSettings_SuggestedChatsContacts: String { return self._s[802]! } + public var SharedMedia_CategoryLinks: String { return self._s[803]! } + public var Calls_Missed: String { return self._s[804]! } + public var Cache_Photos: String { return self._s[808]! } + public var GroupPermission_NoAddMembers: String { return self._s[809]! } + public var ScheduledMessages_Title: String { return self._s[810]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[810]!, self._r[810]!, [_0]) + return formatWithArgumentRanges(self._s[811]!, self._r[811]!, [_0]) } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[811]! } - public var Settings_ProxyDisabled: String { return self._s[812]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[812]! } + public var Settings_ProxyDisabled: String { return self._s[813]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[813]!, self._r[813]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[814]!, self._r[814]!, [_1, _2, _3, _4]) } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[814]!, self._r[814]!, [_0]) + return formatWithArgumentRanges(self._s[815]!, self._r[815]!, [_0]) } - public var Stats_ViewsPerPost: String { return self._s[816]! } - public var ChatList_Context_RemoveFromRecents: String { return self._s[817]! } - public var Appearance_Title: String { return self._s[818]! } + public var Stats_ViewsPerPost: String { return self._s[817]! } + public var ChatList_Context_RemoveFromRecents: String { return self._s[818]! } + public var Appearance_Title: String { return self._s[819]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[820]!, self._r[820]!, [_0]) + return formatWithArgumentRanges(self._s[821]!, self._r[821]!, [_0]) } - public var Conversation_WalletRequiredText: String { return self._s[821]! } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[822]! } - public var OldChannels_NoticeCreateText: String { return self._s[823]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[824]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[825]! } - public var Preview_DeletePhoto: String { return self._s[826]! } - public var Appearance_AppIconFilledX: String { return self._s[827]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[828]! } + public var Conversation_WalletRequiredText: String { return self._s[822]! } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[823]! } + public var OldChannels_NoticeCreateText: String { return self._s[824]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[825]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[826]! } + public var Preview_DeletePhoto: String { return self._s[827]! } + public var Appearance_AppIconFilledX: String { return self._s[828]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[829]! } public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[829]!, self._r[829]!, [_0]) + return formatWithArgumentRanges(self._s[830]!, self._r[830]!, [_0]) } - public var Coub_TapForSound: String { return self._s[832]! } - public var Map_LocatingError: String { return self._s[833]! } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[835]! } - public var Conversation_SendMessage_SendSilently: String { return self._s[836]! } - public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[837]! } + public var Coub_TapForSound: String { return self._s[833]! } + public var Map_LocatingError: String { return self._s[834]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[836]! } + public var Conversation_SendMessage_SendSilently: String { return self._s[837]! } + public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[838]! } public func Wallet_Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[838]!, self._r[838]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[839]!, self._r[839]!, [_1, _2, _3]) } - public var Passport_ForgottenPassword: String { return self._s[839]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[840]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[841]! } - public var Login_TermsOfServiceSignupDecline: String { return self._s[843]! } - public var Channel_Moderator_AccessLevelRevoke: String { return self._s[844]! } - public var Message_Location: String { return self._s[845]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[846]! } - public var Channel_Management_Title: String { return self._s[847]! } - public var DialogList_SearchSectionDialogs: String { return self._s[849]! } - public var Compose_NewChannel_Members: String { return self._s[850]! } + public var Passport_ForgottenPassword: String { return self._s[840]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[841]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[842]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[844]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[845]! } + public var Message_Location: String { return self._s[846]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[847]! } + public var Channel_Management_Title: String { return self._s[848]! } + public var DialogList_SearchSectionDialogs: String { return self._s[850]! } + public var Compose_NewChannel_Members: String { return self._s[851]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[851]!, self._r[851]!, [_0]) + return formatWithArgumentRanges(self._s[852]!, self._r[852]!, [_0]) } - public var GroupInfo_Location: String { return self._s[852]! } - public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[853]! } - public var ClearCache_Clear: String { return self._s[854]! } - public var AutoNightTheme_ScheduledFrom: String { return self._s[855]! } - public var PhotoEditor_WarmthTool: String { return self._s[856]! } - public var Passport_Language_tr: String { return self._s[857]! } + public var GroupInfo_Location: String { return self._s[853]! } + public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[854]! } + public var ClearCache_Clear: String { return self._s[855]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[856]! } + public var PhotoEditor_WarmthTool: String { return self._s[857]! } + public var Passport_Language_tr: String { return self._s[858]! } public func PUSH_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[858]!, self._r[858]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[859]!, self._r[859]!, [_1, _2, _3]) } - public var OldChannels_NoticeUpgradeText: String { return self._s[859]! } - public var Login_ResetAccountProtected_Reset: String { return self._s[861]! } - public var Watch_PhotoView_Title: String { return self._s[862]! } - public var Passport_Phone_Delete: String { return self._s[863]! } - public var Undo_ChatDeletedForBothSides: String { return self._s[864]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[865]! } - public var GroupInfo_Permissions: String { return self._s[866]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[867]! } - public var Profile_ShareContactButton: String { return self._s[868]! } - public var ChatSettings_Other: String { return self._s[869]! } - public var UserInfo_NotificationsDisabled: String { return self._s[870]! } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[871]! } - public var LastSeen_WithinAMonth: String { return self._s[872]! } - public var VoiceOver_Chat_PlayHint: String { return self._s[873]! } - public var Conversation_ReportGroupLocation: String { return self._s[874]! } - public var Conversation_EncryptionCanceled: String { return self._s[875]! } - public var MediaPicker_GroupDescription: String { return self._s[876]! } - public var WebSearch_Images: String { return self._s[877]! } + public var OldChannels_NoticeUpgradeText: String { return self._s[860]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[862]! } + public var Watch_PhotoView_Title: String { return self._s[863]! } + public var Passport_Phone_Delete: String { return self._s[864]! } + public var Undo_ChatDeletedForBothSides: String { return self._s[865]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[866]! } + public var GroupInfo_Permissions: String { return self._s[867]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[868]! } + public var Profile_ShareContactButton: String { return self._s[869]! } + public var ChatSettings_Other: String { return self._s[870]! } + public var UserInfo_NotificationsDisabled: String { return self._s[871]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[872]! } + public var LastSeen_WithinAMonth: String { return self._s[873]! } + public var VoiceOver_Chat_PlayHint: String { return self._s[874]! } + public var Conversation_ReportGroupLocation: String { return self._s[875]! } + public var Conversation_EncryptionCanceled: String { return self._s[876]! } + public var MediaPicker_GroupDescription: String { return self._s[877]! } + public var WebSearch_Images: String { return self._s[878]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[878]!, self._r[878]!, [_0]) + return formatWithArgumentRanges(self._s[879]!, self._r[879]!, [_0]) } - public var Message_Photo: String { return self._s[879]! } - public var PasscodeSettings_HelpBottom: String { return self._s[880]! } - public var AutoDownloadSettings_VideosTitle: String { return self._s[881]! } - public var VoiceOver_Media_PlaybackRateChange: String { return self._s[882]! } - public var Passport_Identity_AddDriversLicense: String { return self._s[883]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[884]! } - public var NotificationsSound_Calypso: String { return self._s[885]! } - public var Map_Map: String { return self._s[886]! } + public var Message_Photo: String { return self._s[880]! } + public var PasscodeSettings_HelpBottom: String { return self._s[881]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[882]! } + public var VoiceOver_Media_PlaybackRateChange: String { return self._s[883]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[884]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[885]! } + public var NotificationsSound_Calypso: String { return self._s[886]! } + public var Map_Map: String { return self._s[887]! } public func Conversation_LiveLocationYouAndOther(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[887]!, self._r[887]!, [_0]) + return formatWithArgumentRanges(self._s[888]!, self._r[888]!, [_0]) } - public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[889]! } - public var ChatSettings_TextSizeUnits: String { return self._s[890]! } + public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[890]! } + public var ChatSettings_TextSizeUnits: String { return self._s[891]! } public func VoiceOver_Chat_FileFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[891]!, self._r[891]!, [_0]) + return formatWithArgumentRanges(self._s[892]!, self._r[892]!, [_0]) } - public var Common_of: String { return self._s[892]! } - public var Conversation_ForwardContacts: String { return self._s[895]! } - public var IntentsSettings_SuggestByAll: String { return self._s[897]! } + public var Common_of: String { return self._s[893]! } + public var Conversation_ForwardContacts: String { return self._s[896]! } + public var IntentsSettings_SuggestByAll: String { return self._s[898]! } public func Call_AnsweringWithAccount(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[898]!, self._r[898]!, [_0]) + return formatWithArgumentRanges(self._s[899]!, self._r[899]!, [_0]) } - public var Passport_Language_hy: String { return self._s[899]! } - public var Notifications_MessageNotificationsHelp: String { return self._s[900]! } - public var AutoDownloadSettings_Reset: String { return self._s[901]! } - public var Wallet_TransactionInfo_AddressCopied: String { return self._s[902]! } - public var Paint_ClearConfirm: String { return self._s[903]! } - public var Camera_VideoMode: String { return self._s[904]! } + public var Passport_Language_hy: String { return self._s[900]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[901]! } + public var AutoDownloadSettings_Reset: String { return self._s[902]! } + public var Wallet_TransactionInfo_AddressCopied: String { return self._s[903]! } + public var Paint_ClearConfirm: String { return self._s[904]! } + public var Camera_VideoMode: String { return self._s[905]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[905]!, self._r[905]!, [_0]) + return formatWithArgumentRanges(self._s[906]!, self._r[906]!, [_0]) } - public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[906]! } - public var Conversation_ViewBackground: String { return self._s[907]! } + public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[907]! } + public var Conversation_ViewBackground: String { return self._s[908]! } public func Wallet_Info_TransactionDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[908]!, self._r[908]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[909]!, self._r[909]!, [_1, _2, _3]) } - public var Passport_Language_el: String { return self._s[909]! } - public var PhotoEditor_Original: String { return self._s[910]! } - public var Settings_FAQ_Button: String { return self._s[912]! } - public var Channel_Setup_PublicNoLink: String { return self._s[914]! } - public var Conversation_UnsupportedMedia: String { return self._s[915]! } - public var Conversation_SlideToCancel: String { return self._s[916]! } - public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[917]! } - public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[918]! } - public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[919]! } - public var Conversation_ReportSpamChannelConfirmation: String { return self._s[920]! } - public var AutoNightTheme_NotAvailable: String { return self._s[921]! } - public var Conversation_Owner: String { return self._s[922]! } - public var Common_Create: String { return self._s[923]! } - public var Settings_ApplyProxyAlertEnable: String { return self._s[924]! } - public var ContactList_Context_Call: String { return self._s[925]! } - public var Localization_ChooseLanguage: String { return self._s[927]! } - public var ChatList_Context_AddToContacts: String { return self._s[929]! } - public var OldChannels_NoticeTitle: String { return self._s[930]! } - public var Settings_Proxy: String { return self._s[932]! } - public var Privacy_TopPeersHelp: String { return self._s[933]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[934]! } - public var Chat_UnsendMyMessages: String { return self._s[935]! } + public var Passport_Language_el: String { return self._s[910]! } + public var PhotoEditor_Original: String { return self._s[911]! } + public var Settings_FAQ_Button: String { return self._s[913]! } + public var Channel_Setup_PublicNoLink: String { return self._s[915]! } + public var Conversation_UnsupportedMedia: String { return self._s[916]! } + public var Conversation_SlideToCancel: String { return self._s[917]! } + public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[918]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[919]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[920]! } + public var Conversation_ReportSpamChannelConfirmation: String { return self._s[921]! } + public var AutoNightTheme_NotAvailable: String { return self._s[922]! } + public var Conversation_Owner: String { return self._s[923]! } + public var Common_Create: String { return self._s[924]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[925]! } + public var ContactList_Context_Call: String { return self._s[926]! } + public var Localization_ChooseLanguage: String { return self._s[928]! } + public var ChatList_Context_AddToContacts: String { return self._s[930]! } + public var OldChannels_NoticeTitle: String { return self._s[931]! } + public var Settings_Proxy: String { return self._s[933]! } + public var Privacy_TopPeersHelp: String { return self._s[934]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[935]! } + public var Chat_UnsendMyMessages: String { return self._s[936]! } public func VoiceOver_Chat_Duration(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[936]!, self._r[936]!, [_0]) + return formatWithArgumentRanges(self._s[937]!, self._r[937]!, [_0]) } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[937]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[938]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[939]!, self._r[939]!, [_0]) + return formatWithArgumentRanges(self._s[940]!, self._r[940]!, [_0]) } - public var Contacts_SortedByPresence: String { return self._s[940]! } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[941]! } - public var Cache_Title: String { return self._s[942]! } + public var Contacts_SortedByPresence: String { return self._s[941]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[942]! } + public var Cache_Title: String { return self._s[943]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[943]!, self._r[943]!, [_0]) + return formatWithArgumentRanges(self._s[944]!, self._r[944]!, [_0]) } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[944]! } - public var Channel_Moderator_Title: String { return self._s[945]! } - public var InstantPage_AutoNightTheme: String { return self._s[947]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[945]! } + public var Channel_Moderator_Title: String { return self._s[946]! } + public var InstantPage_AutoNightTheme: String { return self._s[948]! } public func PUSH_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[950]!, self._r[950]!, [_1]) + return formatWithArgumentRanges(self._s[951]!, self._r[951]!, [_1]) } - public var Passport_Scans_Upload: String { return self._s[951]! } - public var Undo_Undo: String { return self._s[953]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[954]! } - public var TwoStepAuth_RemovePassword: String { return self._s[955]! } - public var Common_Delete: String { return self._s[956]! } - public var Contacts_AddPeopleNearby: String { return self._s[958]! } - public var Conversation_ContextMenuDelete: String { return self._s[959]! } - public var SocksProxySetup_Credentials: String { return self._s[960]! } - public var Appearance_EditTheme: String { return self._s[962]! } - public var ClearCache_StorageOtherApps: String { return self._s[963]! } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[964]! } - public var Wallet_Send_NetworkErrorText: String { return self._s[965]! } - public var AuthSessions_DevicesTitle: String { return self._s[967]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[969]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[970]! } - public var Passport_Language_id: String { return self._s[972]! } - public var WallpaperSearch_ColorTeal: String { return self._s[973]! } - public var ChannelIntro_Title: String { return self._s[974]! } + public var Passport_Scans_Upload: String { return self._s[952]! } + public var Undo_Undo: String { return self._s[954]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[955]! } + public var TwoStepAuth_RemovePassword: String { return self._s[956]! } + public var Common_Delete: String { return self._s[957]! } + public var Contacts_AddPeopleNearby: String { return self._s[959]! } + public var Conversation_ContextMenuDelete: String { return self._s[960]! } + public var SocksProxySetup_Credentials: String { return self._s[961]! } + public var Appearance_EditTheme: String { return self._s[963]! } + public var ClearCache_StorageOtherApps: String { return self._s[964]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[965]! } + public var Wallet_Send_NetworkErrorText: String { return self._s[966]! } + public var AuthSessions_DevicesTitle: String { return self._s[968]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[970]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[971]! } + public var Passport_Language_id: String { return self._s[973]! } + public var WallpaperSearch_ColorTeal: String { return self._s[974]! } + public var ChannelIntro_Title: String { return self._s[975]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[975]!, self._r[975]!, [_0]) + return formatWithArgumentRanges(self._s[976]!, self._r[976]!, [_0]) } - public var VoiceOver_Chat_OpenLinkHint: String { return self._s[977]! } - public var VoiceOver_Chat_Reply: String { return self._s[978]! } - public var ScheduledMessages_BotActionUnavailable: String { return self._s[979]! } - public var Channel_Info_Description: String { return self._s[980]! } - public var Stickers_FavoriteStickers: String { return self._s[981]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[982]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[983]! } - public var ChatSearch_ResultsTooltip: String { return self._s[984]! } - public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[985]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[986]! } - public var Group_PublicLink_Placeholder: String { return self._s[987]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[988]! } + public var VoiceOver_Chat_OpenLinkHint: String { return self._s[978]! } + public var VoiceOver_Chat_Reply: String { return self._s[979]! } + public var ScheduledMessages_BotActionUnavailable: String { return self._s[980]! } + public var Channel_Info_Description: String { return self._s[981]! } + public var Stickers_FavoriteStickers: String { return self._s[982]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[983]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[984]! } + public var ChatSearch_ResultsTooltip: String { return self._s[985]! } + public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[986]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[987]! } + public var Group_PublicLink_Placeholder: String { return self._s[988]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[989]! } public func PUSH_CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[989]!, self._r[989]!, [_1]) + return formatWithArgumentRanges(self._s[990]!, self._r[990]!, [_1]) } - public var TextFormat_Underline: String { return self._s[990]! } + public var TextFormat_Underline: String { return self._s[991]! } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[992]!, self._r[992]!, [_1, _2]) + return formatWithArgumentRanges(self._s[993]!, self._r[993]!, [_1, _2]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[993]!, self._r[993]!, [_0]) + return formatWithArgumentRanges(self._s[994]!, self._r[994]!, [_0]) } - public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[994]! } + public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[995]! } public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[995]!, self._r[995]!, [_1, _2]) + return formatWithArgumentRanges(self._s[996]!, self._r[996]!, [_1, _2]) } - public var Wallet_Intro_ImportExisting: String { return self._s[996]! } - public var GroupPermission_Delete: String { return self._s[997]! } - public var Passport_Language_uk: String { return self._s[998]! } - public var StickerPack_HideStickers: String { return self._s[1000]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1001]! } + public var Wallet_Intro_ImportExisting: String { return self._s[997]! } + public var GroupPermission_Delete: String { return self._s[998]! } + public var Passport_Language_uk: String { return self._s[999]! } + public var StickerPack_HideStickers: String { return self._s[1001]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1002]! } public func PUSH_CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1002]!, self._r[1002]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1003]!, self._r[1003]!, [_1, _2]) } - public var Activity_UploadingVideoMessage: String { return self._s[1003]! } + public var Activity_UploadingVideoMessage: String { return self._s[1004]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1004]!, self._r[1004]!, [_0]) + return formatWithArgumentRanges(self._s[1005]!, self._r[1005]!, [_0]) } - public var Channel_TitleInfo: String { return self._s[1005]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1006]! } - public var Settings_CallSettings: String { return self._s[1007]! } - public var Camera_SquareMode: String { return self._s[1008]! } - public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1009]! } - public var GroupInfo_SharedMediaNone: String { return self._s[1010]! } + public var Channel_TitleInfo: String { return self._s[1006]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1007]! } + public var Settings_CallSettings: String { return self._s[1008]! } + public var Camera_SquareMode: String { return self._s[1009]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1010]! } + public var GroupInfo_SharedMediaNone: String { return self._s[1011]! } public func PUSH_MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1011]!, self._r[1011]!, [_1]) + return formatWithArgumentRanges(self._s[1012]!, self._r[1012]!, [_1]) } - public var Bot_GenericBotStatus: String { return self._s[1012]! } - public var Application_Update: String { return self._s[1014]! } - public var Month_ShortJanuary: String { return self._s[1015]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[1016]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[1017]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[1018]! } - public var Passport_Address_Street2Placeholder: String { return self._s[1019]! } + public var Bot_GenericBotStatus: String { return self._s[1013]! } + public var Application_Update: String { return self._s[1015]! } + public var Month_ShortJanuary: String { return self._s[1016]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[1017]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[1018]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[1019]! } + public var Passport_Address_Street2Placeholder: String { return self._s[1020]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1020]!, self._r[1020]!, [_0]) + return formatWithArgumentRanges(self._s[1021]!, self._r[1021]!, [_0]) } - public var NetworkUsageSettings_Cellular: String { return self._s[1021]! } - public var Appearance_PreviewOutgoingText: String { return self._s[1022]! } + public var NetworkUsageSettings_Cellular: String { return self._s[1022]! } + public var Appearance_PreviewOutgoingText: String { return self._s[1023]! } public func StickerPackActionInfo_RemovedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1023]!, self._r[1023]!, [_0]) + return formatWithArgumentRanges(self._s[1024]!, self._r[1024]!, [_0]) } - public var Notifications_PermissionsAllowInSettings: String { return self._s[1024]! } - public var AutoDownloadSettings_OnForAll: String { return self._s[1026]! } - public var Map_Directions: String { return self._s[1027]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[1029]! } - public var Appearance_ThemeDay: String { return self._s[1030]! } - public var LogoutOptions_LogOut: String { return self._s[1031]! } - public var Group_PublicLink_Title: String { return self._s[1033]! } - public var Channel_AddBotErrorNoRights: String { return self._s[1034]! } - public var ChatList_Search_ShowLess: String { return self._s[1035]! } - public var Passport_Identity_AddPassport: String { return self._s[1036]! } - public var LocalGroup_ButtonTitle: String { return self._s[1037]! } - public var Stats_InteractionsTitle: String { return self._s[1038]! } - public var Call_Message: String { return self._s[1039]! } - public var PhotoEditor_ExposureTool: String { return self._s[1040]! } - public var Wallet_Receive_CommentInfo: String { return self._s[1042]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[1043]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[1045]! } - public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1046]! } - public var Appearance_Preview: String { return self._s[1047]! } - public var Compose_ChannelMembers: String { return self._s[1048]! } - public var Conversation_DeleteManyMessages: String { return self._s[1049]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[1050]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1051]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1052]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[1055]! } - public var Conversation_UpdateTelegram: String { return self._s[1056]! } - public var EditTheme_Create_TopInfo: String { return self._s[1057]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[1025]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[1027]! } + public var Map_Directions: String { return self._s[1028]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[1030]! } + public var Appearance_ThemeDay: String { return self._s[1031]! } + public var LogoutOptions_LogOut: String { return self._s[1032]! } + public var Group_PublicLink_Title: String { return self._s[1034]! } + public var Channel_AddBotErrorNoRights: String { return self._s[1035]! } + public var ChatList_Search_ShowLess: String { return self._s[1036]! } + public var Passport_Identity_AddPassport: String { return self._s[1037]! } + public var LocalGroup_ButtonTitle: String { return self._s[1038]! } + public var Stats_InteractionsTitle: String { return self._s[1039]! } + public var Call_Message: String { return self._s[1040]! } + public var PhotoEditor_ExposureTool: String { return self._s[1041]! } + public var Wallet_Receive_CommentInfo: String { return self._s[1043]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[1044]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[1046]! } + public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1047]! } + public var Appearance_Preview: String { return self._s[1048]! } + public var Compose_ChannelMembers: String { return self._s[1049]! } + public var Conversation_DeleteManyMessages: String { return self._s[1050]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[1051]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1052]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1053]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[1056]! } + public var Conversation_UpdateTelegram: String { return self._s[1057]! } + public var EditTheme_Create_TopInfo: String { return self._s[1058]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1058]!, self._r[1058]!, [_0]) + return formatWithArgumentRanges(self._s[1059]!, self._r[1059]!, [_0]) } - public var Wallet_WordCheck_Continue: String { return self._s[1059]! } - public var TwoFactorSetup_Hint_Action: String { return self._s[1060]! } - public var IntentsSettings_ResetAll: String { return self._s[1061]! } + public var Wallet_WordCheck_Continue: String { return self._s[1060]! } + public var TwoFactorSetup_Hint_Action: String { return self._s[1061]! } + public var IntentsSettings_ResetAll: String { return self._s[1062]! } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1062]!, self._r[1062]!, [_1]) + return formatWithArgumentRanges(self._s[1063]!, self._r[1063]!, [_1]) } - public var GroupInfo_Administrators_Title: String { return self._s[1063]! } - public var Privacy_Forwards_PreviewMessageText: String { return self._s[1064]! } + public var GroupInfo_Administrators_Title: String { return self._s[1064]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[1065]! } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1065]!, self._r[1065]!, [_0]) + return formatWithArgumentRanges(self._s[1066]!, self._r[1066]!, [_0]) } - public var Tour_Title3: String { return self._s[1066]! } - public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1067]! } - public var Clipboard_SendPhoto: String { return self._s[1071]! } - public var MediaPicker_Videos: String { return self._s[1072]! } - public var Passport_Email_Title: String { return self._s[1073]! } + public var Tour_Title3: String { return self._s[1067]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1068]! } + public var Clipboard_SendPhoto: String { return self._s[1072]! } + public var MediaPicker_Videos: String { return self._s[1073]! } + public var Passport_Email_Title: String { return self._s[1074]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1074]!, self._r[1074]!, [_0]) + return formatWithArgumentRanges(self._s[1075]!, self._r[1075]!, [_0]) } - public var StickerPacksSettings_Title: String { return self._s[1075]! } - public var Conversation_MessageDialogDelete: String { return self._s[1076]! } - public var Privacy_Calls_CustomHelp: String { return self._s[1078]! } - public var Message_Wallpaper: String { return self._s[1079]! } - public var MemberSearch_BotSection: String { return self._s[1080]! } - public var GroupInfo_SetSound: String { return self._s[1081]! } + public var StickerPacksSettings_Title: String { return self._s[1076]! } + public var Conversation_MessageDialogDelete: String { return self._s[1077]! } + public var Privacy_Calls_CustomHelp: String { return self._s[1079]! } + public var Message_Wallpaper: String { return self._s[1080]! } + public var MemberSearch_BotSection: String { return self._s[1081]! } + public var GroupInfo_SetSound: String { return self._s[1082]! } public func Time_TomorrowAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1082]!, self._r[1082]!, [_0]) + return formatWithArgumentRanges(self._s[1083]!, self._r[1083]!, [_0]) } - public var Core_ServiceUserStatus: String { return self._s[1083]! } - public var LiveLocationUpdated_JustNow: String { return self._s[1084]! } - public var Call_StatusFailed: String { return self._s[1085]! } - public var TwoFactorSetup_Email_Placeholder: String { return self._s[1086]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1087]! } - public var TwoStepAuth_SetPassword: String { return self._s[1088]! } - public var Permissions_PeopleNearbyText_v0: String { return self._s[1089]! } + public var Core_ServiceUserStatus: String { return self._s[1084]! } + public var LiveLocationUpdated_JustNow: String { return self._s[1085]! } + public var Call_StatusFailed: String { return self._s[1086]! } + public var TwoFactorSetup_Email_Placeholder: String { return self._s[1087]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1088]! } + public var TwoStepAuth_SetPassword: String { return self._s[1089]! } + public var Permissions_PeopleNearbyText_v0: String { return self._s[1090]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1091]!, self._r[1091]!, [_0]) + return formatWithArgumentRanges(self._s[1092]!, self._r[1092]!, [_0]) } - public var Calls_SubmitRating: String { return self._s[1092]! } - public var Map_NoPlacesNearby: String { return self._s[1093]! } - public var Profile_Username: String { return self._s[1094]! } - public var Bot_DescriptionTitle: String { return self._s[1095]! } - public var MaskStickerSettings_Title: String { return self._s[1096]! } - public var SharedMedia_CategoryOther: String { return self._s[1097]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[1098]! } - public var Common_NotNow: String { return self._s[1099]! } - public var CallFeedback_IncludeLogsInfo: String { return self._s[1100]! } - public var Conversation_ShareMyPhoneNumber: String { return self._s[1101]! } - public var Map_Location: String { return self._s[1102]! } - public var Invitation_JoinGroup: String { return self._s[1103]! } - public var AutoDownloadSettings_Title: String { return self._s[1105]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1106]! } - public var Channel_ErrorAddBlocked: String { return self._s[1107]! } - public var Conversation_UnblockUser: String { return self._s[1108]! } - public var EditTheme_Edit_TopInfo: String { return self._s[1109]! } - public var Watch_Bot_Restart: String { return self._s[1110]! } - public var TwoStepAuth_Title: String { return self._s[1111]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[1112]! } - public var Checkout_ShippingMethod: String { return self._s[1113]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1114]! } + public var Calls_SubmitRating: String { return self._s[1093]! } + public var Map_NoPlacesNearby: String { return self._s[1094]! } + public var Profile_Username: String { return self._s[1095]! } + public var Bot_DescriptionTitle: String { return self._s[1096]! } + public var MaskStickerSettings_Title: String { return self._s[1097]! } + public var SharedMedia_CategoryOther: String { return self._s[1098]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[1099]! } + public var Common_NotNow: String { return self._s[1100]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[1101]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[1102]! } + public var Map_Location: String { return self._s[1103]! } + public var Invitation_JoinGroup: String { return self._s[1104]! } + public var AutoDownloadSettings_Title: String { return self._s[1106]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1107]! } + public var Channel_ErrorAddBlocked: String { return self._s[1108]! } + public var Conversation_UnblockUser: String { return self._s[1109]! } + public var EditTheme_Edit_TopInfo: String { return self._s[1110]! } + public var Watch_Bot_Restart: String { return self._s[1111]! } + public var TwoStepAuth_Title: String { return self._s[1112]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[1113]! } + public var Checkout_ShippingMethod: String { return self._s[1114]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1115]! } public func PUSH_CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1115]!, self._r[1115]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1116]!, self._r[1116]!, [_1, _2, _3]) } - public var PeerInfo_ButtonDiscuss: String { return self._s[1116]! } - public var EditTheme_ChangeColors: String { return self._s[1118]! } + public var PeerInfo_ButtonDiscuss: String { return self._s[1117]! } + public var EditTheme_ChangeColors: String { return self._s[1119]! } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1119]!, self._r[1119]!, [_0]) - } - public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1120]!, self._r[1120]!, [_0]) } - public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1121]! } - public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1122]! } - public var AuthSessions_TerminateOtherSessions: String { return self._s[1123]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[1124]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[1125]! } - public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1126]! } - public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1127]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[1128]! } - public var Checkout_PaymentMethod_Title: String { return self._s[1129]! } - public var SocksProxySetup_Connection: String { return self._s[1130]! } - public var Group_MessagePhotoRemoved: String { return self._s[1131]! } - public var PeopleNearby_MakeInvisible: String { return self._s[1133]! } - public var Channel_Stickers_NotFound: String { return self._s[1135]! } - public var Group_About_Help: String { return self._s[1136]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[1137]! } - public var PeopleNearby_Title: String { return self._s[1139]! } - public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1140]!, self._r[1140]!, [_1]) + public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1121]!, self._r[1121]!, [_0]) } - public var Map_Home: String { return self._s[1141]! } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1143]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1144]! } - public var SocksProxySetup_Password: String { return self._s[1145]! } - public var Notifications_PermissionsEnable: String { return self._s[1146]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[1148]! } + public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1122]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1123]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[1124]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[1125]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[1126]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1127]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1128]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[1129]! } + public var Checkout_PaymentMethod_Title: String { return self._s[1130]! } + public var SocksProxySetup_Connection: String { return self._s[1131]! } + public var Group_MessagePhotoRemoved: String { return self._s[1132]! } + public var PeopleNearby_MakeInvisible: String { return self._s[1134]! } + public var Channel_Stickers_NotFound: String { return self._s[1136]! } + public var Group_About_Help: String { return self._s[1137]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[1138]! } + public var PeopleNearby_Title: String { return self._s[1140]! } + public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1141]!, self._r[1141]!, [_1]) + } + public var Map_Home: String { return self._s[1142]! } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1144]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1145]! } + public var SocksProxySetup_Password: String { return self._s[1146]! } + public var Notifications_PermissionsEnable: String { return self._s[1147]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[1149]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1149]!, self._r[1149]!, [_1]) + return formatWithArgumentRanges(self._s[1150]!, self._r[1150]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1151]!, self._r[1151]!, [_0]) + return formatWithArgumentRanges(self._s[1152]!, self._r[1152]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[1152]! } - public var ArchivedPacksAlert_Title: String { return self._s[1153]! } - public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1154]! } - public var Map_PlacesNearby: String { return self._s[1155]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[1153]! } + public var ArchivedPacksAlert_Title: String { return self._s[1154]! } + public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1155]! } + public var Map_PlacesNearby: String { return self._s[1156]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1156]!, self._r[1156]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1157]!, self._r[1157]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1157]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1159]! } - public var Conversation_StatusTyping: String { return self._s[1160]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[1161]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[1162]! } - public var UserInfo_CreateNewContact: String { return self._s[1163]! } - public var Passport_Identity_FrontSide: String { return self._s[1164]! } - public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1165]! } - public var Calls_CallTabTitle: String { return self._s[1166]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1167]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1158]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1160]! } + public var Conversation_StatusTyping: String { return self._s[1161]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[1162]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[1163]! } + public var UserInfo_CreateNewContact: String { return self._s[1164]! } + public var Passport_Identity_FrontSide: String { return self._s[1165]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1166]! } + public var Calls_CallTabTitle: String { return self._s[1167]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1168]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1169]!, self._r[1169]!, [_0]) + return formatWithArgumentRanges(self._s[1170]!, self._r[1170]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[1170]! } - public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1171]! } - public var SharedMedia_EmptyMusicText: String { return self._s[1172]! } - public var Wallet_Completed_Text: String { return self._s[1173]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1174]! } - public var Paint_Stickers: String { return self._s[1175]! } - public var Privacy_GroupsAndChannels: String { return self._s[1176]! } - public var ChatList_Context_Delete: String { return self._s[1178]! } - public var UserInfo_AddContact: String { return self._s[1179]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[1171]! } + public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1172]! } + public var SharedMedia_EmptyMusicText: String { return self._s[1173]! } + public var Wallet_Completed_Text: String { return self._s[1174]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1175]! } + public var Paint_Stickers: String { return self._s[1176]! } + public var Privacy_GroupsAndChannels: String { return self._s[1177]! } + public var ChatList_Context_Delete: String { return self._s[1179]! } + public var UserInfo_AddContact: String { return self._s[1180]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1180]!, self._r[1180]!, [_0]) + return formatWithArgumentRanges(self._s[1181]!, self._r[1181]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[1182]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[1183]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1184]!, self._r[1184]!, [_0]) + return formatWithArgumentRanges(self._s[1185]!, self._r[1185]!, [_0]) } - public var DialogList_NoMessagesTitle: String { return self._s[1185]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[1186]! } - public var BlockedUsers_BlockUser: String { return self._s[1187]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[1188]! } - public var MediaPicker_UngroupDescription: String { return self._s[1190]! } - public var Watch_NoConnection: String { return self._s[1191]! } - public var Month_GenSeptember: String { return self._s[1192]! } - public var Conversation_ViewGroup: String { return self._s[1194]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1197]! } - public var Privacy_Forwards_AlwaysLink: String { return self._s[1198]! } - public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1199]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1200]! } - public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1201]! } - public var MediaPicker_CameraRoll: String { return self._s[1203]! } - public var Month_GenAugust: String { return self._s[1204]! } - public var Wallet_Configuration_SourceHeader: String { return self._s[1205]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[1206]! } - public var SharedMedia_EmptyText: String { return self._s[1207]! } - public var Map_ShareLiveLocation: String { return self._s[1208]! } - public var Calls_All: String { return self._s[1209]! } - public var Map_SendThisPlace: String { return self._s[1211]! } - public var Appearance_ThemeNight: String { return self._s[1213]! } - public var Conversation_HoldForAudio: String { return self._s[1214]! } - public var SettingsSearch_Synonyms_Support: String { return self._s[1217]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[1218]! } - public var SocksProxySetup_Secret: String { return self._s[1219]! } + public var DialogList_NoMessagesTitle: String { return self._s[1186]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1187]! } + public var BlockedUsers_BlockUser: String { return self._s[1188]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[1189]! } + public var MediaPicker_UngroupDescription: String { return self._s[1191]! } + public var Watch_NoConnection: String { return self._s[1192]! } + public var Month_GenSeptember: String { return self._s[1193]! } + public var Conversation_ViewGroup: String { return self._s[1195]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1198]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[1199]! } + public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1200]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1201]! } + public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1202]! } + public var MediaPicker_CameraRoll: String { return self._s[1204]! } + public var Month_GenAugust: String { return self._s[1205]! } + public var Wallet_Configuration_SourceHeader: String { return self._s[1206]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[1207]! } + public var SharedMedia_EmptyText: String { return self._s[1208]! } + public var Map_ShareLiveLocation: String { return self._s[1209]! } + public var Calls_All: String { return self._s[1210]! } + public var Map_SendThisPlace: String { return self._s[1212]! } + public var Appearance_ThemeNight: String { return self._s[1214]! } + public var Conversation_HoldForAudio: String { return self._s[1215]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[1218]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[1219]! } + public var SocksProxySetup_Secret: String { return self._s[1220]! } public func Activity_RemindAboutChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1220]!, self._r[1220]!, [_0]) + return formatWithArgumentRanges(self._s[1221]!, self._r[1221]!, [_0]) } - public var Channel_BanList_RestrictedTitle: String { return self._s[1222]! } - public var Conversation_Location: String { return self._s[1223]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[1223]! } + public var Conversation_Location: String { return self._s[1224]! } public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1224]!, self._r[1224]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1225]!, self._r[1225]!, [_1, _2]) } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[1226]! } - public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1227]! } - public var Notifications_PermissionsText: String { return self._s[1228]! } - public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1229]! } - public var Call_Flip: String { return self._s[1230]! } - public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1232]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1233]! } - public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1234]! } - public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1235]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1237]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1239]! } - public var Channel_TooMuchBots: String { return self._s[1241]! } - public var Passport_DeletePassportConfirmation: String { return self._s[1242]! } - public var Login_InvalidCodeError: String { return self._s[1243]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[1244]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[1227]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1228]! } + public var Notifications_PermissionsText: String { return self._s[1229]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1230]! } + public var Call_Flip: String { return self._s[1231]! } + public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1233]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1234]! } + public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1235]! } + public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1236]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1238]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1240]! } + public var Channel_TooMuchBots: String { return self._s[1242]! } + public var Passport_DeletePassportConfirmation: String { return self._s[1243]! } + public var Login_InvalidCodeError: String { return self._s[1244]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[1245]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1245]!, self._r[1245]!, [_0]) - } - public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1246]!, self._r[1246]!, [_0]) } - public var VoiceOver_Navigation_ProxySettings: String { return self._s[1247]! } - public var Call_CallInProgressTitle: String { return self._s[1248]! } - public var Month_ShortSeptember: String { return self._s[1249]! } - public var Watch_ChannelInfo_Title: String { return self._s[1250]! } - public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1253]! } - public var DialogList_PasscodeLockHelp: String { return self._s[1254]! } - public var Chat_MultipleTextMessagesDisabled: String { return self._s[1255]! } - public var Wallet_Receive_Title: String { return self._s[1256]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[1257]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1258]! } - public var PhotoEditor_CropReset: String { return self._s[1259]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1261]! } - public var Channel_Management_LabelEditor: String { return self._s[1262]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[1264]! } - public var PhotoEditor_HighlightsTool: String { return self._s[1265]! } - public var Wallet_Info_WalletCreated: String { return self._s[1266]! } - public var UserInfo_Title: String { return self._s[1267]! } - public var ChatList_HideAction: String { return self._s[1268]! } - public var AccessDenied_Title: String { return self._s[1269]! } - public var DialogList_SearchLabel: String { return self._s[1270]! } - public var Group_Setup_HistoryHidden: String { return self._s[1271]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1272]! } - public var State_Updating: String { return self._s[1274]! } - public var Contacts_TabTitle: String { return self._s[1275]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[1277]! } - public var GroupInfo_GroupHistory: String { return self._s[1278]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1279]! } - public var Wallpaper_SetColor: String { return self._s[1280]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1281]! } - public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1282]! } - public var Chat_AttachmentLimitReached: String { return self._s[1283]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1284]! } - public var Contacts_NotRegisteredSection: String { return self._s[1285]! } + public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1247]!, self._r[1247]!, [_0]) + } + public var VoiceOver_Navigation_ProxySettings: String { return self._s[1248]! } + public var Call_CallInProgressTitle: String { return self._s[1249]! } + public var Month_ShortSeptember: String { return self._s[1250]! } + public var Watch_ChannelInfo_Title: String { return self._s[1251]! } + public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1254]! } + public var DialogList_PasscodeLockHelp: String { return self._s[1255]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[1256]! } + public var Wallet_Receive_Title: String { return self._s[1257]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[1258]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1259]! } + public var PhotoEditor_CropReset: String { return self._s[1260]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1262]! } + public var Channel_Management_LabelEditor: String { return self._s[1263]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[1265]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1266]! } + public var Wallet_Info_WalletCreated: String { return self._s[1267]! } + public var UserInfo_Title: String { return self._s[1268]! } + public var ChatList_HideAction: String { return self._s[1269]! } + public var AccessDenied_Title: String { return self._s[1270]! } + public var DialogList_SearchLabel: String { return self._s[1271]! } + public var Group_Setup_HistoryHidden: String { return self._s[1272]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1273]! } + public var State_Updating: String { return self._s[1275]! } + public var Contacts_TabTitle: String { return self._s[1276]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1278]! } + public var GroupInfo_GroupHistory: String { return self._s[1279]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1280]! } + public var Wallpaper_SetColor: String { return self._s[1281]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1282]! } + public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1283]! } + public var Chat_AttachmentLimitReached: String { return self._s[1284]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1285]! } + public var Contacts_NotRegisteredSection: String { return self._s[1286]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1286]!, self._r[1286]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1287]!, self._r[1287]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[1287]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[1288]! } - public var SocksProxySetup_Connecting: String { return self._s[1289]! } - public var ExplicitContent_AlertChannel: String { return self._s[1290]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[1291]! } - public var Conversation_Contact: String { return self._s[1292]! } - public var Login_CodeExpired: String { return self._s[1293]! } - public var Passport_DiscardMessageAction: String { return self._s[1294]! } - public var ChatList_Context_Unpin: String { return self._s[1295]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1296]! } + public var Paint_Clear: String { return self._s[1288]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1289]! } + public var SocksProxySetup_Connecting: String { return self._s[1290]! } + public var ExplicitContent_AlertChannel: String { return self._s[1291]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[1292]! } + public var Conversation_Contact: String { return self._s[1293]! } + public var Login_CodeExpired: String { return self._s[1294]! } + public var Passport_DiscardMessageAction: String { return self._s[1295]! } + public var ChatList_Context_Unpin: String { return self._s[1296]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1297]! } public func VoiceOver_Chat_MusicFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1297]!, self._r[1297]!, [_0]) + return formatWithArgumentRanges(self._s[1298]!, self._r[1298]!, [_0]) } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[1298]! } - public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1299]! } + public var Channel_AdminLog_EmptyMessageText: String { return self._s[1299]! } + public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1300]! } public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1300]!, self._r[1300]!, [_0]) + return formatWithArgumentRanges(self._s[1301]!, self._r[1301]!, [_0]) } - public var Month_ShortApril: String { return self._s[1301]! } - public var AuthSessions_CurrentSession: String { return self._s[1302]! } - public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1305]! } - public var Wallet_Navigation_Cancel: String { return self._s[1307]! } - public var WallpaperPreview_CropTopText: String { return self._s[1308]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1309]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1310]! } + public var Month_ShortApril: String { return self._s[1302]! } + public var AuthSessions_CurrentSession: String { return self._s[1303]! } + public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1306]! } + public var Wallet_Navigation_Cancel: String { return self._s[1308]! } + public var WallpaperPreview_CropTopText: String { return self._s[1309]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1310]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1311]! } public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1311]!, self._r[1311]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1312]!, self._r[1312]!, [_0, _1]) } - public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1312]! } - public var Channel_Setup_TypePrivate: String { return self._s[1314]! } - public var Forward_ChannelReadOnly: String { return self._s[1317]! } - public var PhotoEditor_CurvesBlue: String { return self._s[1318]! } - public var AddContact_SharedContactException: String { return self._s[1319]! } - public var UserInfo_BotPrivacy: String { return self._s[1321]! } - public var Wallet_CreateInvoice_Title: String { return self._s[1322]! } - public var Notification_PassportValueEmail: String { return self._s[1323]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[1324]! } - public var GroupPermission_NewTitle: String { return self._s[1325]! } - public var CallFeedback_ReasonDropped: String { return self._s[1326]! } - public var GroupInfo_Permissions_AddException: String { return self._s[1327]! } - public var Channel_SignMessages_Help: String { return self._s[1329]! } - public var Undo_ChatDeleted: String { return self._s[1331]! } - public var Conversation_ChatBackground: String { return self._s[1332]! } + public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1313]! } + public var Channel_Setup_TypePrivate: String { return self._s[1315]! } + public var Forward_ChannelReadOnly: String { return self._s[1318]! } + public var PhotoEditor_CurvesBlue: String { return self._s[1319]! } + public var AddContact_SharedContactException: String { return self._s[1320]! } + public var UserInfo_BotPrivacy: String { return self._s[1322]! } + public var Wallet_CreateInvoice_Title: String { return self._s[1323]! } + public var Notification_PassportValueEmail: String { return self._s[1324]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[1325]! } + public var GroupPermission_NewTitle: String { return self._s[1326]! } + public var CallFeedback_ReasonDropped: String { return self._s[1327]! } + public var GroupInfo_Permissions_AddException: String { return self._s[1328]! } + public var Channel_SignMessages_Help: String { return self._s[1330]! } + public var Undo_ChatDeleted: String { return self._s[1332]! } + public var Conversation_ChatBackground: String { return self._s[1333]! } public func Wallet_WordCheck_Text(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1333]!, self._r[1333]!, [_1, _2, _3]) - } - public func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1334]!, self._r[1334]!, [_1, _2, _3]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1335]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1336]! } - public var Passport_Language_pt: String { return self._s[1337]! } - public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1338]! } - public var NotificationsSound_Popcorn: String { return self._s[1341]! } - public var AutoNightTheme_Disabled: String { return self._s[1342]! } - public var BlockedUsers_LeavePrefix: String { return self._s[1343]! } - public var WallpaperPreview_CustomColorTopText: String { return self._s[1344]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[1345]! } - public var WallpaperSearch_ColorBlue: String { return self._s[1346]! } + public func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1335]!, self._r[1335]!, [_1, _2, _3]) + } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1336]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1337]! } + public var Passport_Language_pt: String { return self._s[1338]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1339]! } + public var NotificationsSound_Popcorn: String { return self._s[1342]! } + public var AutoNightTheme_Disabled: String { return self._s[1343]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1344]! } + public var WallpaperPreview_CustomColorTopText: String { return self._s[1345]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1346]! } + public var WallpaperSearch_ColorBlue: String { return self._s[1347]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1347]!, self._r[1347]!, [_0]) + return formatWithArgumentRanges(self._s[1348]!, self._r[1348]!, [_0]) } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1348]! } - public var SocksProxySetup_UseForCalls: String { return self._s[1349]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1351]! } - public var PeerInfo_PaneGroups: String { return self._s[1352]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1349]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1350]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1352]! } + public var PeerInfo_PaneGroups: String { return self._s[1353]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1353]!, self._r[1353]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1354]!, self._r[1354]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[1356]! } - public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1357]! } - public var Compose_NewEncryptedChat: String { return self._s[1358]! } - public var Login_CodeFloodError: String { return self._s[1359]! } - public var Calls_TabTitle: String { return self._s[1360]! } - public var Privacy_ProfilePhoto: String { return self._s[1361]! } - public var Passport_Language_he: String { return self._s[1362]! } + public var SocksProxySetup_Hostname: String { return self._s[1357]! } + public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1358]! } + public var Compose_NewEncryptedChat: String { return self._s[1359]! } + public var Login_CodeFloodError: String { return self._s[1360]! } + public var Calls_TabTitle: String { return self._s[1361]! } + public var Privacy_ProfilePhoto: String { return self._s[1362]! } + public var Passport_Language_he: String { return self._s[1363]! } public func Conversation_SetReminder_RemindToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1363]!, self._r[1363]!, [_0]) + return formatWithArgumentRanges(self._s[1364]!, self._r[1364]!, [_0]) } - public var GroupPermission_Title: String { return self._s[1364]! } + public var GroupPermission_Title: String { return self._s[1365]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1365]!, self._r[1365]!, [_0]) + return formatWithArgumentRanges(self._s[1366]!, self._r[1366]!, [_0]) } - public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1366]! } - public var GroupPermission_NoChangeInfo: String { return self._s[1367]! } - public var ChatList_DeleteForCurrentUser: String { return self._s[1368]! } - public var Tour_Text1: String { return self._s[1369]! } - public var Channel_EditAdmin_TransferOwnership: String { return self._s[1370]! } - public var Month_ShortFebruary: String { return self._s[1371]! } - public var TwoStepAuth_EmailSkip: String { return self._s[1372]! } + public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1367]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1368]! } + public var ChatList_DeleteForCurrentUser: String { return self._s[1369]! } + public var Tour_Text1: String { return self._s[1370]! } + public var Channel_EditAdmin_TransferOwnership: String { return self._s[1371]! } + public var Month_ShortFebruary: String { return self._s[1372]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1373]! } public func Wallet_Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1373]!, self._r[1373]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1374]!, self._r[1374]!, [_1, _2, _3]) } - public var Stats_LanguagesTitle: String { return self._s[1374]! } - public var NotificationsSound_Glass: String { return self._s[1375]! } - public var Appearance_ThemeNightBlue: String { return self._s[1376]! } - public var CheckoutInfo_Pay: String { return self._s[1377]! } - public var PeerInfo_ButtonLeave: String { return self._s[1379]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1380]! } - public var Call_CallAgain: String { return self._s[1382]! } - public var AttachmentMenu_SendAsFile: String { return self._s[1383]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[1384]! } - public var Passport_InvalidPasswordError: String { return self._s[1385]! } - public var Watch_Message_Game: String { return self._s[1386]! } - public var Stickers_Install: String { return self._s[1387]! } - public var VoiceOver_Chat_Message: String { return self._s[1388]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1389]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[1391]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[1392]! } - public var AuthSessions_OtherSessions: String { return self._s[1393]! } - public var Channel_Username_Help: String { return self._s[1394]! } - public var Camera_Title: String { return self._s[1395]! } - public var IntentsSettings_Title: String { return self._s[1396]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1398]! } - public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1399]! } - public var Channel_AdminLog_SendPolls: String { return self._s[1400]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1401]! } - public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1402]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1403]! } - public var ScheduledMessages_DeleteMany: String { return self._s[1404]! } - public var Conversation_RestrictedStickers: String { return self._s[1405]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1407]! } - public var UserInfo_TelegramCall: String { return self._s[1409]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1410]! } - public var CreatePoll_OptionsHeader: String { return self._s[1411]! } - public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1412]! } - public var ArchivedChats_IntroTitle1: String { return self._s[1413]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1414]! } - public var Theme_Colors_Proceed: String { return self._s[1415]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1416]! } + public var Stats_LanguagesTitle: String { return self._s[1375]! } + public var NotificationsSound_Glass: String { return self._s[1376]! } + public var Appearance_ThemeNightBlue: String { return self._s[1377]! } + public var CheckoutInfo_Pay: String { return self._s[1378]! } + public var PeerInfo_ButtonLeave: String { return self._s[1380]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1381]! } + public var Call_CallAgain: String { return self._s[1383]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1384]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1385]! } + public var Passport_InvalidPasswordError: String { return self._s[1386]! } + public var Watch_Message_Game: String { return self._s[1387]! } + public var Stickers_Install: String { return self._s[1388]! } + public var VoiceOver_Chat_Message: String { return self._s[1389]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1390]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1392]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1393]! } + public var AuthSessions_OtherSessions: String { return self._s[1394]! } + public var Channel_Username_Help: String { return self._s[1395]! } + public var Camera_Title: String { return self._s[1396]! } + public var IntentsSettings_Title: String { return self._s[1397]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1399]! } + public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1400]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1401]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1402]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1403]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1404]! } + public var ScheduledMessages_DeleteMany: String { return self._s[1405]! } + public var Conversation_RestrictedStickers: String { return self._s[1406]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1408]! } + public var UserInfo_TelegramCall: String { return self._s[1410]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1411]! } + public var CreatePoll_OptionsHeader: String { return self._s[1412]! } + public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1413]! } + public var ArchivedChats_IntroTitle1: String { return self._s[1414]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1415]! } + public var Theme_Colors_Proceed: String { return self._s[1416]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1417]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1417]!, self._r[1417]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1418]!, self._r[1418]!, [_1, _2, _3]) } - public var Wallet_Month_GenAugust: String { return self._s[1418]! } - public var Settings_SaveEditedPhotos: String { return self._s[1419]! } - public var Stats_FollowersBySourceTitle: String { return self._s[1420]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1421]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1422]! } - public var Conversation_MessageDialogRetry: String { return self._s[1423]! } - public var ChatList_Context_MarkAsUnread: String { return self._s[1424]! } - public var MessagePoll_SubmitVote: String { return self._s[1425]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1426]! } - public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1427]! } - public var Group_Setup_TypeHeader: String { return self._s[1428]! } - public var Paint_RecentStickers: String { return self._s[1429]! } - public var PhotoEditor_GrainTool: String { return self._s[1430]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1431]! } - public var EmptyGroupInfo_Line4: String { return self._s[1432]! } - public var Watch_AuthRequired: String { return self._s[1434]! } + public var Wallet_Month_GenAugust: String { return self._s[1419]! } + public var Settings_SaveEditedPhotos: String { return self._s[1420]! } + public var Stats_FollowersBySourceTitle: String { return self._s[1421]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1422]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1423]! } + public var Conversation_MessageDialogRetry: String { return self._s[1424]! } + public var ChatList_Context_MarkAsUnread: String { return self._s[1425]! } + public var MessagePoll_SubmitVote: String { return self._s[1426]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1427]! } + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1428]! } + public var Group_Setup_TypeHeader: String { return self._s[1429]! } + public var Paint_RecentStickers: String { return self._s[1430]! } + public var PhotoEditor_GrainTool: String { return self._s[1431]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1432]! } + public var EmptyGroupInfo_Line4: String { return self._s[1433]! } + public var Watch_AuthRequired: String { return self._s[1435]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1435]!, self._r[1435]!, [_0]) + return formatWithArgumentRanges(self._s[1436]!, self._r[1436]!, [_0]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1436]! } - public var ChannelIntro_Text: String { return self._s[1437]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1438]! } - public var GroupPermission_NoSendMedia: String { return self._s[1439]! } - public var Calls_AddTab: String { return self._s[1440]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1441]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1442]! } - public var Conversation_WalletRequiredSetup: String { return self._s[1443]! } - public var Notification_MessageLifetime1d: String { return self._s[1444]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1445]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1446]! } - public var Passport_Identity_GenderFemale: String { return self._s[1447]! } - public var BlockedUsers_BlockTitle: String { return self._s[1448]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1437]! } + public var ChannelIntro_Text: String { return self._s[1438]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1439]! } + public var GroupPermission_NoSendMedia: String { return self._s[1440]! } + public var Calls_AddTab: String { return self._s[1441]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1442]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1443]! } + public var Conversation_WalletRequiredSetup: String { return self._s[1444]! } + public var Notification_MessageLifetime1d: String { return self._s[1445]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1446]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1447]! } + public var Passport_Identity_GenderFemale: String { return self._s[1448]! } + public var BlockedUsers_BlockTitle: String { return self._s[1449]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1449]!, self._r[1449]!, [_1]) + return formatWithArgumentRanges(self._s[1450]!, self._r[1450]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1450]! } - public var WallpaperSearch_ColorBlack: String { return self._s[1451]! } - public var Settings_Context_Logout: String { return self._s[1452]! } - public var Wallet_Info_UnknownTransaction: String { return self._s[1453]! } - public var ChatList_ArchiveAction: String { return self._s[1454]! } - public var AutoNightTheme_Scheduled: String { return self._s[1455]! } - public var TwoFactorSetup_Email_SkipAction: String { return self._s[1456]! } - public var Settings_Devices: String { return self._s[1457]! } - public var ContactInfo_Note: String { return self._s[1458]! } + public var Weekday_Yesterday: String { return self._s[1451]! } + public var WallpaperSearch_ColorBlack: String { return self._s[1452]! } + public var Settings_Context_Logout: String { return self._s[1453]! } + public var Wallet_Info_UnknownTransaction: String { return self._s[1454]! } + public var ChatList_ArchiveAction: String { return self._s[1455]! } + public var AutoNightTheme_Scheduled: String { return self._s[1456]! } + public var TwoFactorSetup_Email_SkipAction: String { return self._s[1457]! } + public var Settings_Devices: String { return self._s[1458]! } + public var ContactInfo_Note: String { return self._s[1459]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1459]!, self._r[1459]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1460]!, self._r[1460]!, [_1, _2, _3, _4, _5, _6]) } - public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1460]! } - public var Wallet_Receive_CreateInvoice: String { return self._s[1461]! } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1462]! } - public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1463]! } + public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1461]! } + public var Wallet_Receive_CreateInvoice: String { return self._s[1462]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1463]! } + public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1464]! } public func PUSH_CHAT_JOINED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1464]!, self._r[1464]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1465]!, self._r[1465]!, [_1, _2]) } - public var CreatePoll_Create: String { return self._s[1465]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1466]! } + public var CreatePoll_Create: String { return self._s[1466]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1467]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1467]!, self._r[1467]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1468]!, self._r[1468]!, [_1, _2]) } - public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1468]! } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1469]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1471]! } + public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1469]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1470]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1472]! } public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1472]!, self._r[1472]!, [_1]) + return formatWithArgumentRanges(self._s[1473]!, self._r[1473]!, [_1]) } - public var Preview_OpenInInstagram: String { return self._s[1473]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1474]! } + public var Preview_OpenInInstagram: String { return self._s[1474]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1475]! } public func PUSH_CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1475]!, self._r[1475]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1476]!, self._r[1476]!, [_1, _2, _3]) } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1476]!, self._r[1476]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1477]!, self._r[1477]!, [_1, _2]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1477]! } - public var ArchivedChats_IntroText3: String { return self._s[1478]! } - public var ChatList_UndoArchiveHiddenText: String { return self._s[1479]! } - public var NetworkUsageSettings_TotalSection: String { return self._s[1480]! } - public var Wallet_Month_GenSeptember: String { return self._s[1481]! } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1482]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1478]! } + public var ArchivedChats_IntroText3: String { return self._s[1479]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[1480]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1481]! } + public var Wallet_Month_GenSeptember: String { return self._s[1482]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1483]! } public func PUSH_CHAT_MESSAGE_POLL(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1483]!, self._r[1483]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1484]!, self._r[1484]!, [_1, _2, _3]) } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1485]! } - public var FastTwoStepSetup_HintSection: String { return self._s[1486]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1487]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1488]! } - public var Gif_NoGifsFound: String { return self._s[1489]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1490]! } - public var VoiceOver_MessageContextDelete: String { return self._s[1491]! } - public var EditTheme_Preview: String { return self._s[1492]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1486]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1487]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1488]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1489]! } + public var Gif_NoGifsFound: String { return self._s[1490]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1491]! } + public var VoiceOver_MessageContextDelete: String { return self._s[1492]! } + public var EditTheme_Preview: String { return self._s[1493]! } public func ClearCache_StorageTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1493]!, self._r[1493]!, [_0]) + return formatWithArgumentRanges(self._s[1494]!, self._r[1494]!, [_0]) } - public var GroupInfo_ActionPromote: String { return self._s[1494]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1495]! } - public var GroupInfo_Permissions_Title: String { return self._s[1496]! } - public var Permissions_ContactsText_v0: String { return self._s[1497]! } - public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1498]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1499]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1502]! } - public var Passport_FieldEmailHelp: String { return self._s[1503]! } + public var GroupInfo_ActionPromote: String { return self._s[1495]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1496]! } + public var GroupInfo_Permissions_Title: String { return self._s[1497]! } + public var Permissions_ContactsText_v0: String { return self._s[1498]! } + public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1499]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1500]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1503]! } + public var Passport_FieldEmailHelp: String { return self._s[1504]! } public func Activity_RemindAboutUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1504]!, self._r[1504]!, [_0]) + return formatWithArgumentRanges(self._s[1505]!, self._r[1505]!, [_0]) } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1505]! } - public var Weekday_ShortSaturday: String { return self._s[1506]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1507]! } - public var Watch_Conversation_UserInfo: String { return self._s[1508]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1509]! } - public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1510]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1511]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1512]! } - public var PhotoEditor_VignetteTool: String { return self._s[1513]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1514]! } - public var Passport_Language_et: String { return self._s[1515]! } - public var AppUpgrade_Running: String { return self._s[1516]! } - public var Channel_DiscussionGroup_Info: String { return self._s[1518]! } - public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1519]! } - public var Passport_Language_bg: String { return self._s[1520]! } - public var Stickers_NoStickersFound: String { return self._s[1522]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1506]! } + public var Weekday_ShortSaturday: String { return self._s[1507]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1508]! } + public var Watch_Conversation_UserInfo: String { return self._s[1509]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1510]! } + public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1511]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1512]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1513]! } + public var PhotoEditor_VignetteTool: String { return self._s[1514]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1515]! } + public var Passport_Language_et: String { return self._s[1516]! } + public var AppUpgrade_Running: String { return self._s[1517]! } + public var Channel_DiscussionGroup_Info: String { return self._s[1519]! } + public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1520]! } + public var Passport_Language_bg: String { return self._s[1521]! } + public var Stickers_NoStickersFound: String { return self._s[1523]! } public func PUSH_CHANNEL_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1524]!, self._r[1524]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1525]!, self._r[1525]!, [_1, _2]) } public func VoiceOver_Chat_ContactFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1525]!, self._r[1525]!, [_0]) + return formatWithArgumentRanges(self._s[1526]!, self._r[1526]!, [_0]) } - public var Wallet_Month_GenJuly: String { return self._s[1526]! } - public var Wallet_Receive_AddressHeader: String { return self._s[1527]! } - public var Wallet_Send_AmountText: String { return self._s[1528]! } - public var Settings_About: String { return self._s[1529]! } + public var Wallet_Month_GenJuly: String { return self._s[1527]! } + public var Wallet_Receive_AddressHeader: String { return self._s[1528]! } + public var Wallet_Send_AmountText: String { return self._s[1529]! } + public var Settings_About: String { return self._s[1530]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1530]!, self._r[1530]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1531]!, self._r[1531]!, [_0, _1, _2]) } - public var ChatList_Context_MarkAsRead: String { return self._s[1532]! } - public var KeyCommand_NewMessage: String { return self._s[1533]! } - public var Group_ErrorAddBlocked: String { return self._s[1534]! } + public var ChatList_Context_MarkAsRead: String { return self._s[1533]! } + public var KeyCommand_NewMessage: String { return self._s[1534]! } + public var Group_ErrorAddBlocked: String { return self._s[1535]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1535]!, self._r[1535]!, [_0]) + return formatWithArgumentRanges(self._s[1536]!, self._r[1536]!, [_0]) } - public var Map_LocationTitle: String { return self._s[1536]! } - public var ReportGroupLocation_Title: String { return self._s[1537]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1538]! } - public var Cache_ClearProgress: String { return self._s[1539]! } + public var Map_LocationTitle: String { return self._s[1537]! } + public var ReportGroupLocation_Title: String { return self._s[1538]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1539]! } + public var Cache_ClearProgress: String { return self._s[1540]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1540]!, self._r[1540]!, [_0]) + return formatWithArgumentRanges(self._s[1541]!, self._r[1541]!, [_0]) } - public var GroupRemoved_AddToGroup: String { return self._s[1541]! } + public var GroupRemoved_AddToGroup: String { return self._s[1542]! } public func External_OpenIn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1542]!, self._r[1542]!, [_0]) + return formatWithArgumentRanges(self._s[1543]!, self._r[1543]!, [_0]) } - public var Passport_UpdateRequiredError: String { return self._s[1543]! } - public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1544]! } + public var Passport_UpdateRequiredError: String { return self._s[1544]! } + public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1545]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1545]!, self._r[1545]!, [_1]) + return formatWithArgumentRanges(self._s[1546]!, self._r[1546]!, [_1]) } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1547]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1548]! } - public var PeerInfo_ButtonSearch: String { return self._s[1549]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1550]! } - public var Passport_Language_ka: String { return self._s[1551]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1548]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1549]! } + public var PeerInfo_ButtonSearch: String { return self._s[1550]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1551]! } + public var Passport_Language_ka: String { return self._s[1552]! } public func Wallet_Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1552]!, self._r[1552]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1553]!, self._r[1553]!, [_1, _2, _3]) } - public var Call_Decline: String { return self._s[1553]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1554]! } - public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1557]! } + public var Call_Decline: String { return self._s[1554]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1555]! } + public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1558]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1558]!, self._r[1558]!, [_0]) + return formatWithArgumentRanges(self._s[1559]!, self._r[1559]!, [_0]) } - public var CallFeedback_Send: String { return self._s[1559]! } - public var EditTheme_EditTitle: String { return self._s[1560]! } + public var CallFeedback_Send: String { return self._s[1560]! } + public var EditTheme_EditTitle: String { return self._s[1561]! } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1561]!, self._r[1561]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1562]!, self._r[1562]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1562]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1563]! } public func Wallet_Updated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1564]!, self._r[1564]!, [_0]) + return formatWithArgumentRanges(self._s[1565]!, self._r[1565]!, [_0]) } - public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1565]! } - public var Passport_DeletePassport: String { return self._s[1566]! } - public var Appearance_AppIconFilled: String { return self._s[1567]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1568]! } - public var Month_ShortDecember: String { return self._s[1569]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1571]! } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1566]! } + public var Passport_DeletePassport: String { return self._s[1567]! } + public var Appearance_AppIconFilled: String { return self._s[1568]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1569]! } + public var Month_ShortDecember: String { return self._s[1570]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1572]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1572]!, self._r[1572]!, [_0]) + return formatWithArgumentRanges(self._s[1573]!, self._r[1573]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1573]! } - public var Conversation_EncryptedDescription1: String { return self._s[1574]! } - public var Conversation_EncryptedDescription2: String { return self._s[1575]! } - public var PasscodeSettings_PasscodeOptions: String { return self._s[1576]! } - public var Conversation_EncryptedDescription3: String { return self._s[1578]! } - public var PhotoEditor_SharpenTool: String { return self._s[1579]! } - public var Wallet_Configuration_Title: String { return self._s[1580]! } + public var Channel_Stickers_Searching: String { return self._s[1574]! } + public var Conversation_EncryptedDescription1: String { return self._s[1575]! } + public var Conversation_EncryptedDescription2: String { return self._s[1576]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[1577]! } + public var Conversation_EncryptedDescription3: String { return self._s[1579]! } + public var PhotoEditor_SharpenTool: String { return self._s[1580]! } + public var Wallet_Configuration_Title: String { return self._s[1581]! } public func Conversation_AddNameToContacts(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1581]!, self._r[1581]!, [_0]) + return formatWithArgumentRanges(self._s[1582]!, self._r[1582]!, [_0]) } - public var Conversation_EncryptedDescription4: String { return self._s[1583]! } - public var Channel_Members_AddMembers: String { return self._s[1584]! } - public var Wallpaper_Search: String { return self._s[1585]! } - public var Weekday_Friday: String { return self._s[1587]! } - public var Privacy_ContactsSync: String { return self._s[1588]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1589]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1590]! } + public var Conversation_EncryptedDescription4: String { return self._s[1584]! } + public var Channel_Members_AddMembers: String { return self._s[1585]! } + public var Wallpaper_Search: String { return self._s[1586]! } + public var Weekday_Friday: String { return self._s[1588]! } + public var Privacy_ContactsSync: String { return self._s[1589]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1590]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1591]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1591]!, self._r[1591]!, [_0]) + return formatWithArgumentRanges(self._s[1592]!, self._r[1592]!, [_0]) } - public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1592]! } - public var GroupInfo_Permissions_Removed: String { return self._s[1593]! } - public var ScheduledMessages_ScheduledOnline: String { return self._s[1594]! } - public var Passport_Identity_GenderMale: String { return self._s[1595]! } + public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1593]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1594]! } + public var ScheduledMessages_ScheduledOnline: String { return self._s[1595]! } + public var Passport_Identity_GenderMale: String { return self._s[1596]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1596]!, self._r[1596]!, [_0]) + return formatWithArgumentRanges(self._s[1597]!, self._r[1597]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1597]! } - public var Conversation_JumpToDate: String { return self._s[1598]! } - public var Contacts_GlobalSearch: String { return self._s[1599]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1600]! } - public var SettingsSearch_Synonyms_FAQ: String { return self._s[1601]! } - public var Profile_MessageLifetime1d: String { return self._s[1602]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1598]! } + public var Conversation_JumpToDate: String { return self._s[1599]! } + public var Contacts_GlobalSearch: String { return self._s[1600]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1601]! } + public var SettingsSearch_Synonyms_FAQ: String { return self._s[1602]! } + public var Profile_MessageLifetime1d: String { return self._s[1603]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1603]!, self._r[1603]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1604]!, self._r[1604]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1606]! } + public var StickerPack_BuiltinPackName: String { return self._s[1607]! } public func PUSH_CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1607]!, self._r[1607]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1608]!, self._r[1608]!, [_1, _2]) } - public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1608]! } - public var Passport_InfoTitle: String { return self._s[1610]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1611]! } + public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1609]! } + public var Passport_InfoTitle: String { return self._s[1611]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1612]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1615]!, self._r[1615]!, [_0]) + return formatWithArgumentRanges(self._s[1616]!, self._r[1616]!, [_0]) } public func PUSH_CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1616]!, self._r[1616]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1617]!, self._r[1617]!, [_1, _2]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1617]! } - public var Profile_BotInfo: String { return self._s[1618]! } - public var Watch_Compose_CreateMessage: String { return self._s[1619]! } - public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1620]! } - public var Month_ShortNovember: String { return self._s[1621]! } - public var Conversation_ScamWarning: String { return self._s[1622]! } - public var Wallpaper_SetCustomBackground: String { return self._s[1623]! } - public var Appearance_TextSize_Title: String { return self._s[1624]! } - public var Passport_Identity_TranslationsHelp: String { return self._s[1625]! } - public var NotificationsSound_Chime: String { return self._s[1626]! } - public var Passport_Language_ko: String { return self._s[1628]! } - public var InviteText_URL: String { return self._s[1629]! } - public var TextFormat_Monospace: String { return self._s[1630]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1618]! } + public var Profile_BotInfo: String { return self._s[1619]! } + public var Watch_Compose_CreateMessage: String { return self._s[1620]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1621]! } + public var Month_ShortNovember: String { return self._s[1622]! } + public var Conversation_ScamWarning: String { return self._s[1623]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1624]! } + public var Appearance_TextSize_Title: String { return self._s[1625]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1626]! } + public var NotificationsSound_Chime: String { return self._s[1627]! } + public var Passport_Language_ko: String { return self._s[1629]! } + public var InviteText_URL: String { return self._s[1630]! } + public var TextFormat_Monospace: String { return self._s[1631]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1631]!, self._r[1631]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1632]!, self._r[1632]!, [_1, _2, _3]) } - public var EditTheme_Edit_BottomInfo: String { return self._s[1632]! } + public var EditTheme_Edit_BottomInfo: String { return self._s[1633]! } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1633]!, self._r[1633]!, [_0]) + return formatWithArgumentRanges(self._s[1634]!, self._r[1634]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1634]!, self._r[1634]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1635]!, self._r[1635]!, [_1, _2]) } - public var Wallet_Words_Title: String { return self._s[1635]! } - public var Wallet_Month_ShortMay: String { return self._s[1636]! } - public var EditTheme_CreateTitle: String { return self._s[1638]! } - public var Passport_InfoLearnMore: String { return self._s[1639]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1640]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1641]! } - public var Your_card_has_expired: String { return self._s[1642]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1643]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1644]! } - public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1648]! } - public var Conversation_Report: String { return self._s[1650]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1651]! } - public var Notification_MessageLifetime1m: String { return self._s[1652]! } - public var Privacy_ContactsTitle: String { return self._s[1653]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1654]! } - public var Wallet_WordCheck_Title: String { return self._s[1655]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1656]! } - public var Channel_Members_Title: String { return self._s[1657]! } - public var Map_OpenInWaze: String { return self._s[1658]! } - public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1659]! } - public var Login_PhoneBannedError: String { return self._s[1660]! } + public var Wallet_Words_Title: String { return self._s[1636]! } + public var Wallet_Month_ShortMay: String { return self._s[1637]! } + public var EditTheme_CreateTitle: String { return self._s[1639]! } + public var Passport_InfoLearnMore: String { return self._s[1640]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1641]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1642]! } + public var Your_card_has_expired: String { return self._s[1643]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1644]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1645]! } + public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1649]! } + public var Conversation_Report: String { return self._s[1651]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1652]! } + public var Notification_MessageLifetime1m: String { return self._s[1653]! } + public var Privacy_ContactsTitle: String { return self._s[1654]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1655]! } + public var Wallet_WordCheck_Title: String { return self._s[1656]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1657]! } + public var Channel_Members_Title: String { return self._s[1658]! } + public var Map_OpenInWaze: String { return self._s[1659]! } + public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1660]! } + public var Login_PhoneBannedError: String { return self._s[1661]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1661]!, self._r[1661]!, [_0]) + return formatWithArgumentRanges(self._s[1662]!, self._r[1662]!, [_0]) } - public var IntentsSettings_MainAccount: String { return self._s[1662]! } - public var Group_Management_AddModeratorHelp: String { return self._s[1663]! } - public var AutoDownloadSettings_WifiTitle: String { return self._s[1664]! } - public var Common_OK: String { return self._s[1665]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1666]! } - public var Wallet_Words_NotDoneResponse: String { return self._s[1667]! } - public var Cache_Music: String { return self._s[1668]! } - public var Wallet_Configuration_SourceURL: String { return self._s[1669]! } - public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1670]! } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1673]! } - public var ChatList_EmptyChatListEditFilter: String { return self._s[1674]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1675]! } + public var IntentsSettings_MainAccount: String { return self._s[1663]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1664]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[1665]! } + public var Common_OK: String { return self._s[1666]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1667]! } + public var Wallet_Words_NotDoneResponse: String { return self._s[1668]! } + public var Cache_Music: String { return self._s[1669]! } + public var Wallet_Configuration_SourceURL: String { return self._s[1670]! } + public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1671]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1674]! } + public var ChatList_EmptyChatListEditFilter: String { return self._s[1675]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1676]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1676]!, self._r[1676]!, [_1]) + return formatWithArgumentRanges(self._s[1677]!, self._r[1677]!, [_1]) } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1677]!, self._r[1677]!, [_0]) + return formatWithArgumentRanges(self._s[1678]!, self._r[1678]!, [_0]) } - public var TwoFactorSetup_Done_Action: String { return self._s[1678]! } + public var TwoFactorSetup_Done_Action: String { return self._s[1679]! } public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1679]!, self._r[1679]!, [_0]) + return formatWithArgumentRanges(self._s[1680]!, self._r[1680]!, [_0]) } - public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1680]! } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1682]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1683]! } - public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1685]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1686]! } - public var State_ConnectingToProxyInfo: String { return self._s[1687]! } - public var Conversation_SwipeToReplyHintTitle: String { return self._s[1688]! } - public var Message_VideoMessage: String { return self._s[1690]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1691]! } - public var ContactInfo_PhoneLabelOther: String { return self._s[1692]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1693]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1694]! } + public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1681]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1683]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1684]! } + public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1686]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1687]! } + public var State_ConnectingToProxyInfo: String { return self._s[1688]! } + public var Conversation_SwipeToReplyHintTitle: String { return self._s[1689]! } + public var Message_VideoMessage: String { return self._s[1691]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1692]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1693]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1694]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1695]! } public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1695]!, self._r[1695]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1696]!, self._r[1696]!, [_1, _2, _3]) } - public var WallpaperPreview_SwipeBottomText: String { return self._s[1696]! } - public var Activity_RecordingAudio: String { return self._s[1697]! } - public var SettingsSearch_Synonyms_Watch: String { return self._s[1698]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1699]! } - public var Wallet_Info_Address: String { return self._s[1700]! } + public var WallpaperPreview_SwipeBottomText: String { return self._s[1697]! } + public var Activity_RecordingAudio: String { return self._s[1698]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[1699]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1700]! } + public var Wallet_Info_Address: String { return self._s[1701]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1702]!, self._r[1702]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1703]!, self._r[1703]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1706]!, self._r[1706]!, [_0]) + return formatWithArgumentRanges(self._s[1707]!, self._r[1707]!, [_0]) } - public var Conversation_ApplyLocalization: String { return self._s[1707]! } - public var TwoFactorSetup_Intro_Action: String { return self._s[1708]! } - public var UserInfo_AddPhone: String { return self._s[1709]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1710]! } + public var Conversation_ApplyLocalization: String { return self._s[1708]! } + public var TwoFactorSetup_Intro_Action: String { return self._s[1709]! } + public var UserInfo_AddPhone: String { return self._s[1710]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1711]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1711]!, self._r[1711]!, [_0]) + return formatWithArgumentRanges(self._s[1712]!, self._r[1712]!, [_0]) } - public var Passport_Scans: String { return self._s[1713]! } - public var BlockedUsers_Unblock: String { return self._s[1714]! } + public var Passport_Scans: String { return self._s[1714]! } + public var BlockedUsers_Unblock: String { return self._s[1715]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1715]!, self._r[1715]!, [_1]) + return formatWithArgumentRanges(self._s[1716]!, self._r[1716]!, [_1]) } - public var Channel_Management_LabelCreator: String { return self._s[1716]! } - public var Conversation_ReportSpamAndLeave: String { return self._s[1717]! } - public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1718]! } - public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1719]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1720]! } + public var Channel_Management_LabelCreator: String { return self._s[1717]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[1718]! } + public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1719]! } + public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1720]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1721]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1721]!, self._r[1721]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1722]!, self._r[1722]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1722]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1723]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1724]! } - public var ChannelIntro_CreateChannel: String { return self._s[1725]! } - public var Conversation_UnreadMessages: String { return self._s[1726]! } - public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1727]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1728]! } - public var Theme_Context_Apply: String { return self._s[1729]! } - public var Notification_GroupActivated: String { return self._s[1730]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1731]! } - public var Wallet_Intro_CreateWallet: String { return self._s[1732]! } + public var Login_PhoneNumberHelp: String { return self._s[1723]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1724]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1725]! } + public var ChannelIntro_CreateChannel: String { return self._s[1726]! } + public var Conversation_UnreadMessages: String { return self._s[1727]! } + public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1728]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1729]! } + public var Theme_Context_Apply: String { return self._s[1730]! } + public var Notification_GroupActivated: String { return self._s[1731]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1732]! } + public var Wallet_Intro_CreateWallet: String { return self._s[1733]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1733]!, self._r[1733]!, [_0]) + return formatWithArgumentRanges(self._s[1734]!, self._r[1734]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1734]!, self._r[1734]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1735]!, self._r[1735]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1736]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1737]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1737]!, self._r[1737]!, [_0]) + return formatWithArgumentRanges(self._s[1738]!, self._r[1738]!, [_0]) } - public var Undo_DeletedChannel: String { return self._s[1738]! } - public var CallFeedback_AddComment: String { return self._s[1739]! } + public var Undo_DeletedChannel: String { return self._s[1739]! } + public var CallFeedback_AddComment: String { return self._s[1740]! } public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1740]!, self._r[1740]!, [_0]) + return formatWithArgumentRanges(self._s[1741]!, self._r[1741]!, [_0]) } - public var Document_TargetConfirmationFormat: String { return self._s[1741]! } + public var Document_TargetConfirmationFormat: String { return self._s[1742]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1742]!, self._r[1742]!, [_0]) + return formatWithArgumentRanges(self._s[1743]!, self._r[1743]!, [_0]) } - public var LogoutOptions_SetPasscodeTitle: String { return self._s[1743]! } + public var LogoutOptions_SetPasscodeTitle: String { return self._s[1744]! } public func PUSH_CHAT_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1744]!, self._r[1744]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[1745]!, self._r[1745]!, [_1, _2, _3, _4]) } - public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1745]! } - public var Theme_ErrorNotFound: String { return self._s[1746]! } - public var Contacts_SortByName: String { return self._s[1747]! } - public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1748]! } + public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1746]! } + public var Theme_ErrorNotFound: String { return self._s[1747]! } + public var Contacts_SortByName: String { return self._s[1748]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1749]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1750]!, self._r[1750]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1751]!, self._r[1751]!, [_1, _2, _3]) } - public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1751]! } - public var ScheduledMessages_EditTime: String { return self._s[1752]! } - public var Conversation_ClearSelfHistory: String { return self._s[1753]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1754]! } - public var PasscodeSettings_DoNotMatch: String { return self._s[1755]! } - public var Stickers_SuggestNone: String { return self._s[1756]! } - public var ChatSettings_Cache: String { return self._s[1757]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1758]! } - public var Media_ShareThisPhoto: String { return self._s[1759]! } - public var Chat_SlowmodeTooltipPending: String { return self._s[1760]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1761]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1762]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1763]! } - public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1764]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1765]! } - public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1766]! } + public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1752]! } + public var ScheduledMessages_EditTime: String { return self._s[1753]! } + public var Conversation_ClearSelfHistory: String { return self._s[1754]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1755]! } + public var PasscodeSettings_DoNotMatch: String { return self._s[1756]! } + public var Stickers_SuggestNone: String { return self._s[1757]! } + public var ChatSettings_Cache: String { return self._s[1758]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1759]! } + public var Media_ShareThisPhoto: String { return self._s[1760]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[1761]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1762]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1763]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1764]! } + public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1765]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1766]! } + public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1767]! } public func Wallet_SecureStorageReset_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1767]!, self._r[1767]!, [_0]) + return formatWithArgumentRanges(self._s[1768]!, self._r[1768]!, [_0]) } - public var Permissions_CellularDataTitle_v0: String { return self._s[1768]! } - public var WallpaperSearch_ColorWhite: String { return self._s[1770]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1771]! } - public var Conversation_ErrorInaccessibleMessage: String { return self._s[1772]! } - public var Map_OpenIn: String { return self._s[1773]! } - public var PeerInfo_ButtonCall: String { return self._s[1774]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1769]! } + public var WallpaperSearch_ColorWhite: String { return self._s[1771]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1772]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[1773]! } + public var Map_OpenIn: String { return self._s[1774]! } + public var PeerInfo_ButtonCall: String { return self._s[1775]! } public func PUSH_PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1777]!, self._r[1777]!, [_1]) + return formatWithArgumentRanges(self._s[1778]!, self._r[1778]!, [_1]) } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1778]!, self._r[1778]!, [_0]) + return formatWithArgumentRanges(self._s[1779]!, self._r[1779]!, [_0]) } - public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1779]! } - public var MessagePoll_LabelClosed: String { return self._s[1780]! } - public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1782]! } - public var Wallet_Send_SendAnyway: String { return self._s[1783]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1784]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1785]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1786]! } - public var Map_SetThisPlace: String { return self._s[1787]! } - public var Login_SelectCountry_Title: String { return self._s[1788]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1789]! } + public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1780]! } + public var MessagePoll_LabelClosed: String { return self._s[1781]! } + public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1783]! } + public var Wallet_Send_SendAnyway: String { return self._s[1784]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1785]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1786]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1787]! } + public var Map_SetThisPlace: String { return self._s[1788]! } + public var Login_SelectCountry_Title: String { return self._s[1789]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1790]! } public func Conversation_OpenBotLinkLogin(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1790]!, self._r[1790]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1791]!, self._r[1791]!, [_1, _2]) } - public var Channel_AdminLog_ChangeInfo: String { return self._s[1791]! } - public var Watch_Suggestion_BRB: String { return self._s[1792]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1793]! } - public var Contacts_PermissionsTitle: String { return self._s[1794]! } - public var Conversation_RestrictedInline: String { return self._s[1795]! } - public var Appearance_RemoveThemeColor: String { return self._s[1797]! } - public var StickerPack_ViewPack: String { return self._s[1798]! } - public var Wallet_UnknownError: String { return self._s[1799]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[1792]! } + public var Watch_Suggestion_BRB: String { return self._s[1793]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1794]! } + public var Contacts_PermissionsTitle: String { return self._s[1795]! } + public var Conversation_RestrictedInline: String { return self._s[1796]! } + public var Appearance_RemoveThemeColor: String { return self._s[1798]! } + public var StickerPack_ViewPack: String { return self._s[1799]! } + public var Wallet_UnknownError: String { return self._s[1800]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1800]!, self._r[1800]!, [_0]) + return formatWithArgumentRanges(self._s[1801]!, self._r[1801]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1802]! } - public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1805]! } - public var MessagePoll_LabelQuiz: String { return self._s[1807]! } - public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1808]! } - public var Channel_Info_Stickers: String { return self._s[1809]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1810]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1811]! } - public var Passport_DeletePersonalDetails: String { return self._s[1812]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[1813]! } - public var Channel_DiscussionGroupInfo: String { return self._s[1814]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1815]! } - public var Conversation_SearchNoResults: String { return self._s[1818]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1819]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1820]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1821]! } - public var Login_Code: String { return self._s[1822]! } - public var EditTheme_Create_BottomInfo: String { return self._s[1823]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1824]! } - public var Weekday_ShortThursday: String { return self._s[1825]! } - public var Resolve_ErrorNotFound: String { return self._s[1827]! } - public var LastSeen_Offline: String { return self._s[1828]! } - public var PeopleNearby_NoMembers: String { return self._s[1829]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[1830]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1831]! } - public var GroupInfo_Title: String { return self._s[1833]! } - public var NotificationsSound_Note: String { return self._s[1834]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1835]! } - public var Watch_Message_Poll: String { return self._s[1836]! } - public var Privacy_Calls: String { return self._s[1837]! } + public var Compose_NewChannel: String { return self._s[1803]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1806]! } + public var MessagePoll_LabelQuiz: String { return self._s[1808]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1809]! } + public var Channel_Info_Stickers: String { return self._s[1810]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1811]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1812]! } + public var Passport_DeletePersonalDetails: String { return self._s[1813]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1814]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1815]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1816]! } + public var Conversation_SearchNoResults: String { return self._s[1819]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1820]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1821]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1822]! } + public var Login_Code: String { return self._s[1823]! } + public var EditTheme_Create_BottomInfo: String { return self._s[1824]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1825]! } + public var Weekday_ShortThursday: String { return self._s[1826]! } + public var Resolve_ErrorNotFound: String { return self._s[1828]! } + public var LastSeen_Offline: String { return self._s[1829]! } + public var PeopleNearby_NoMembers: String { return self._s[1830]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1831]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1832]! } + public var GroupInfo_Title: String { return self._s[1834]! } + public var NotificationsSound_Note: String { return self._s[1835]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1836]! } + public var Watch_Message_Poll: String { return self._s[1837]! } + public var Privacy_Calls: String { return self._s[1838]! } public func Channel_AdminLog_MessageRankUsername(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1838]!, self._r[1838]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1839]!, self._r[1839]!, [_1, _2, _3]) } - public var Month_ShortAugust: String { return self._s[1839]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1840]! } - public var Notifications_Reset: String { return self._s[1841]! } - public var Conversation_Pin: String { return self._s[1842]! } - public var Passport_Language_lv: String { return self._s[1843]! } - public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1844]! } - public var BlockedUsers_Info: String { return self._s[1845]! } - public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1847]! } - public var Watch_Conversation_Unblock: String { return self._s[1849]! } + public var Month_ShortAugust: String { return self._s[1840]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1841]! } + public var Notifications_Reset: String { return self._s[1842]! } + public var Conversation_Pin: String { return self._s[1843]! } + public var Passport_Language_lv: String { return self._s[1844]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1845]! } + public var BlockedUsers_Info: String { return self._s[1846]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1848]! } + public var Watch_Conversation_Unblock: String { return self._s[1850]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1850]!, self._r[1850]!, [_0]) + return formatWithArgumentRanges(self._s[1851]!, self._r[1851]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1851]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1852]! } + public var CloudStorage_Title: String { return self._s[1852]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1853]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1853]!, self._r[1853]!, [_0]) + return formatWithArgumentRanges(self._s[1854]!, self._r[1854]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1854]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1855]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1856]! } - public var Passport_Address_EditBankStatement: String { return self._s[1857]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1855]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1856]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1857]! } + public var Passport_Address_EditBankStatement: String { return self._s[1858]! } public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1858]!, self._r[1858]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1859]!, self._r[1859]!, [_1, _2]) } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1859]! } - public var ShareMenu_Comment: String { return self._s[1860]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1861]! } - public var Notifications_PermissionsTitle: String { return self._s[1862]! } - public var GroupPermission_NoSendLinks: String { return self._s[1863]! } - public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1864]! } - public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1865]! } - public var PeerInfo_PaneLinks: String { return self._s[1866]! } - public var Settings_Support: String { return self._s[1867]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1868]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1869]! } - public var Privacy_Forwards_Preview: String { return self._s[1870]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[1871]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1872]! } - public var Common_Select: String { return self._s[1874]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1875]! } - public var WallpaperSearch_ColorGray: String { return self._s[1878]! } - public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1879]! } - public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1880]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1881]! } - public var PollResults_Title: String { return self._s[1882]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1883]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1884]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1885]! } - public var Widget_AuthRequired: String { return self._s[1886]! } - public var Camera_FlashOn: String { return self._s[1887]! } - public var Conversation_ContextMenuLookUp: String { return self._s[1888]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1889]! } - public var Watch_Suggestion_OK: String { return self._s[1890]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1860]! } + public var ShareMenu_Comment: String { return self._s[1861]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1862]! } + public var Notifications_PermissionsTitle: String { return self._s[1863]! } + public var GroupPermission_NoSendLinks: String { return self._s[1864]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1865]! } + public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1866]! } + public var PeerInfo_PaneLinks: String { return self._s[1867]! } + public var Settings_Support: String { return self._s[1868]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1869]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1870]! } + public var Privacy_Forwards_Preview: String { return self._s[1871]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1872]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1873]! } + public var Common_Select: String { return self._s[1875]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1876]! } + public var WallpaperSearch_ColorGray: String { return self._s[1879]! } + public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1880]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1881]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1882]! } + public var PollResults_Title: String { return self._s[1883]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1884]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1885]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1886]! } + public var Widget_AuthRequired: String { return self._s[1887]! } + public var Camera_FlashOn: String { return self._s[1888]! } + public var Conversation_ContextMenuLookUp: String { return self._s[1889]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1890]! } + public var Watch_Suggestion_OK: String { return self._s[1891]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1892]!, self._r[1892]!, [_0]) + return formatWithArgumentRanges(self._s[1893]!, self._r[1893]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1894]!, self._r[1894]!, [_0]) + return formatWithArgumentRanges(self._s[1895]!, self._r[1895]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[1895]! } - public var DialogList_AdLabel: String { return self._s[1896]! } - public var WatchRemote_NotificationText: String { return self._s[1897]! } - public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1898]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1899]! } - public var Conversation_ReportSpam: String { return self._s[1900]! } - public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1901]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1903]! } - public var PhoneLabel_Title: String { return self._s[1904]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1905]! } - public var Settings_ChangePhoneNumber: String { return self._s[1906]! } - public var Notifications_ExceptionsTitle: String { return self._s[1907]! } - public var Notifications_AlertTones: String { return self._s[1908]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1909]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1910]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1911]! } - public var VoiceOver_Chat_Photo: String { return self._s[1913]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1914]! } - public var ReportPeer_ReasonOther: String { return self._s[1915]! } - public var ChatList_Context_JoinChannel: String { return self._s[1916]! } - public var KeyCommand_ScrollDown: String { return self._s[1918]! } - public var Conversation_ScheduleMessage_Title: String { return self._s[1919]! } + public var TextFormat_Strikethrough: String { return self._s[1896]! } + public var DialogList_AdLabel: String { return self._s[1897]! } + public var WatchRemote_NotificationText: String { return self._s[1898]! } + public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1899]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1900]! } + public var Conversation_ReportSpam: String { return self._s[1901]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1902]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1904]! } + public var PhoneLabel_Title: String { return self._s[1905]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1906]! } + public var Settings_ChangePhoneNumber: String { return self._s[1907]! } + public var Notifications_ExceptionsTitle: String { return self._s[1908]! } + public var Notifications_AlertTones: String { return self._s[1909]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1910]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1911]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1912]! } + public var VoiceOver_Chat_Photo: String { return self._s[1914]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1915]! } + public var ReportPeer_ReasonOther: String { return self._s[1916]! } + public var ChatList_Context_JoinChannel: String { return self._s[1917]! } + public var KeyCommand_ScrollDown: String { return self._s[1919]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[1920]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1920]!, self._r[1920]!, [_0]) + return formatWithArgumentRanges(self._s[1921]!, self._r[1921]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1921]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1922]! } - public var AuthSessions_LogOut: String { return self._s[1923]! } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1924]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1925]! } - public var Passport_Phone_Title: String { return self._s[1926]! } - public var ContactList_Context_StartSecretChat: String { return self._s[1927]! } - public var Settings_PhoneNumber: String { return self._s[1928]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1922]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1923]! } + public var AuthSessions_LogOut: String { return self._s[1924]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1925]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1926]! } + public var Passport_Phone_Title: String { return self._s[1927]! } + public var ContactList_Context_StartSecretChat: String { return self._s[1928]! } + public var Settings_PhoneNumber: String { return self._s[1929]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1929]!, self._r[1929]!, [_0]) + return formatWithArgumentRanges(self._s[1930]!, self._r[1930]!, [_0]) } - public var NotificationsSound_Alert: String { return self._s[1931]! } - public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1932]! } - public var WebSearch_SearchNoResults: String { return self._s[1933]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1935]! } - public var Wallet_Configuration_SourceInfo: String { return self._s[1936]! } - public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1937]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[1938]! } - public var PhotoEditor_CurvesTool: String { return self._s[1939]! } - public var Checkout_PaymentMethod: String { return self._s[1941]! } + public var NotificationsSound_Alert: String { return self._s[1932]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1933]! } + public var WebSearch_SearchNoResults: String { return self._s[1934]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1936]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[1937]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1938]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[1939]! } + public var PhotoEditor_CurvesTool: String { return self._s[1940]! } + public var Checkout_PaymentMethod: String { return self._s[1942]! } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1942]!, self._r[1942]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1943]!, self._r[1943]!, [_1, _2]) } - public var Contacts_AccessDeniedError: String { return self._s[1943]! } - public var Camera_PhotoMode: String { return self._s[1946]! } - public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1947]! } - public var Appearance_TextSize_Apply: String { return self._s[1948]! } - public var Passport_Address_AddUtilityBill: String { return self._s[1950]! } - public var CallSettings_OnMobile: String { return self._s[1951]! } - public var Tour_Text2: String { return self._s[1952]! } + public var Contacts_AccessDeniedError: String { return self._s[1944]! } + public var Camera_PhotoMode: String { return self._s[1947]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1948]! } + public var Appearance_TextSize_Apply: String { return self._s[1949]! } + public var Passport_Address_AddUtilityBill: String { return self._s[1951]! } + public var CallSettings_OnMobile: String { return self._s[1952]! } + public var Tour_Text2: String { return self._s[1953]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1953]!, self._r[1953]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1954]!, self._r[1954]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[1955]! } - public var Permissions_Skip: String { return self._s[1956]! } - public var Wallet_Words_NotDoneOk: String { return self._s[1957]! } - public var SecretImage_Title: String { return self._s[1958]! } - public var Watch_MessageView_Title: String { return self._s[1959]! } - public var Channel_DiscussionGroupAdd: String { return self._s[1960]! } - public var AttachmentMenu_Poll: String { return self._s[1961]! } + public var DialogList_EncryptionProcessing: String { return self._s[1956]! } + public var Permissions_Skip: String { return self._s[1957]! } + public var Wallet_Words_NotDoneOk: String { return self._s[1958]! } + public var SecretImage_Title: String { return self._s[1959]! } + public var Watch_MessageView_Title: String { return self._s[1960]! } + public var Channel_DiscussionGroupAdd: String { return self._s[1961]! } + public var AttachmentMenu_Poll: String { return self._s[1962]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1962]!, self._r[1962]!, [_0]) + return formatWithArgumentRanges(self._s[1963]!, self._r[1963]!, [_0]) } public func Channel_DiscussionGroup_PrivateChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1963]!, self._r[1963]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1964]!, self._r[1964]!, [_1, _2]) } - public var Notification_CallCanceled: String { return self._s[1964]! } - public var WallpaperPreview_Title: String { return self._s[1965]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1966]! } - public var Settings_ProxyConnecting: String { return self._s[1967]! } - public var Settings_CheckPhoneNumberText: String { return self._s[1969]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[1970]! } - public var Wallet_Intro_Title: String { return self._s[1971]! } - public var TwoFactorSetup_Password_Action: String { return self._s[1972]! } - public var Profile_MessageLifetime5s: String { return self._s[1973]! } - public var Username_InvalidCharacters: String { return self._s[1974]! } - public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1975]! } - public var ScheduledMessages_ClearAll: String { return self._s[1976]! } - public var WallpaperPreview_CropBottomText: String { return self._s[1977]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[1978]! } - public var Settings_AddAccount: String { return self._s[1979]! } - public var Notification_CreatedChannel: String { return self._s[1982]! } + public var Notification_CallCanceled: String { return self._s[1965]! } + public var WallpaperPreview_Title: String { return self._s[1966]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1967]! } + public var Settings_ProxyConnecting: String { return self._s[1968]! } + public var Settings_CheckPhoneNumberText: String { return self._s[1970]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[1971]! } + public var Wallet_Intro_Title: String { return self._s[1972]! } + public var TwoFactorSetup_Password_Action: String { return self._s[1973]! } + public var Profile_MessageLifetime5s: String { return self._s[1974]! } + public var Username_InvalidCharacters: String { return self._s[1975]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1976]! } + public var ScheduledMessages_ClearAll: String { return self._s[1977]! } + public var WallpaperPreview_CropBottomText: String { return self._s[1978]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[1979]! } + public var Settings_AddAccount: String { return self._s[1980]! } + public var Notification_CreatedChannel: String { return self._s[1983]! } public func PUSH_CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1983]!, self._r[1983]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1984]!, self._r[1984]!, [_1, _2, _3]) } - public var Passcode_AppLockedAlert: String { return self._s[1985]! } - public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1986]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[1987]! } - public var Contacts_TopSection: String { return self._s[1988]! } - public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1989]! } + public var Passcode_AppLockedAlert: String { return self._s[1986]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1987]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[1988]! } + public var Contacts_TopSection: String { return self._s[1989]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1990]! } public func Conversation_SetReminder_RemindOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1990]!, self._r[1990]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1991]!, self._r[1991]!, [_0, _1]) } - public var Wallet_Info_Receive: String { return self._s[1991]! } - public var Wallet_Completed_ViewWallet: String { return self._s[1992]! } + public var Wallet_Info_Receive: String { return self._s[1992]! } + public var Wallet_Completed_ViewWallet: String { return self._s[1993]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1993]!, self._r[1993]!, [_0]) + return formatWithArgumentRanges(self._s[1994]!, self._r[1994]!, [_0]) } - public var ReportPeer_ReasonSpam: String { return self._s[1994]! } - public var UserInfo_TapToCall: String { return self._s[1995]! } - public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1997]! } - public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1998]! } - public var Common_Search: String { return self._s[1999]! } - public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2000]! } + public var ReportPeer_ReasonSpam: String { return self._s[1995]! } + public var UserInfo_TapToCall: String { return self._s[1996]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1998]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1999]! } + public var Common_Search: String { return self._s[2000]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2001]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2001]!, self._r[2001]!, [_0]) + return formatWithArgumentRanges(self._s[2002]!, self._r[2002]!, [_0]) } - public var Wallet_Month_ShortJuly: String { return self._s[2002]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2004]! } - public var Message_InvoiceLabel: String { return self._s[2005]! } - public var Conversation_InputTextPlaceholder: String { return self._s[2006]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2007]! } + public var Wallet_Month_ShortJuly: String { return self._s[2003]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2005]! } + public var Message_InvoiceLabel: String { return self._s[2006]! } + public var Conversation_InputTextPlaceholder: String { return self._s[2007]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2008]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2008]!, self._r[2008]!, [_0]) + return formatWithArgumentRanges(self._s[2009]!, self._r[2009]!, [_0]) } - public var IntentsSettings_Reset: String { return self._s[2009]! } - public var Conversation_Info: String { return self._s[2010]! } - public var Login_InfoDeletePhoto: String { return self._s[2011]! } - public var Passport_Language_vi: String { return self._s[2013]! } - public var UserInfo_ScamUserWarning: String { return self._s[2014]! } - public var Conversation_Search: String { return self._s[2015]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2017]! } - public var ReportPeer_ReasonPornography: String { return self._s[2018]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[2019]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2020]! } - public var Map_LiveLocationGroupDescription: String { return self._s[2021]! } - public var Channel_Setup_TypeHeader: String { return self._s[2022]! } - public var AuthSessions_LoggedIn: String { return self._s[2023]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2024]! } - public var Login_SmsRequestState3: String { return self._s[2025]! } - public var Passport_Address_EditUtilityBill: String { return self._s[2026]! } - public var Appearance_ReduceMotionInfo: String { return self._s[2027]! } - public var Join_ChannelsTooMuch: String { return self._s[2028]! } - public var Channel_Edit_LinkItem: String { return self._s[2029]! } - public var Privacy_Calls_P2PNever: String { return self._s[2030]! } - public var Conversation_AddToReadingList: String { return self._s[2032]! } - public var Share_MultipleMessagesDisabled: String { return self._s[2033]! } - public var Message_Animation: String { return self._s[2034]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[2035]! } - public var Map_Unknown: String { return self._s[2036]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[2037]! } + public var IntentsSettings_Reset: String { return self._s[2010]! } + public var Conversation_Info: String { return self._s[2011]! } + public var Login_InfoDeletePhoto: String { return self._s[2012]! } + public var Passport_Language_vi: String { return self._s[2014]! } + public var UserInfo_ScamUserWarning: String { return self._s[2015]! } + public var Conversation_Search: String { return self._s[2016]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2018]! } + public var ReportPeer_ReasonPornography: String { return self._s[2019]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[2020]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2021]! } + public var Map_LiveLocationGroupDescription: String { return self._s[2022]! } + public var Channel_Setup_TypeHeader: String { return self._s[2023]! } + public var AuthSessions_LoggedIn: String { return self._s[2024]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2025]! } + public var Login_SmsRequestState3: String { return self._s[2026]! } + public var Passport_Address_EditUtilityBill: String { return self._s[2027]! } + public var Appearance_ReduceMotionInfo: String { return self._s[2028]! } + public var Join_ChannelsTooMuch: String { return self._s[2029]! } + public var Channel_Edit_LinkItem: String { return self._s[2030]! } + public var Privacy_Calls_P2PNever: String { return self._s[2031]! } + public var Conversation_AddToReadingList: String { return self._s[2033]! } + public var Share_MultipleMessagesDisabled: String { return self._s[2034]! } + public var Message_Animation: String { return self._s[2035]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[2036]! } + public var Map_Unknown: String { return self._s[2037]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[2038]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2038]!, self._r[2038]!, [_1, _2]) - } - public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2039]!, self._r[2039]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[2040]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[2041]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2042]! } + public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2040]!, self._r[2040]!, [_1, _2]) + } + public var Call_StatusRequesting: String { return self._s[2041]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[2042]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2043]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2043]!, self._r[2043]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2044]!, self._r[2044]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2044]!, self._r[2044]!, [_0]) + return formatWithArgumentRanges(self._s[2045]!, self._r[2045]!, [_0]) } - public var Update_Skip: String { return self._s[2045]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2046]! } - public var BlockedUsers_Title: String { return self._s[2047]! } - public var Weekday_Monday: String { return self._s[2048]! } + public var Update_Skip: String { return self._s[2046]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2047]! } + public var BlockedUsers_Title: String { return self._s[2048]! } + public var Weekday_Monday: String { return self._s[2049]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2049]!, self._r[2049]!, [_1]) + return formatWithArgumentRanges(self._s[2050]!, self._r[2050]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[2050]! } - public var NotificationsSound_Bell: String { return self._s[2051]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[2052]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2053]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2054]! } - public var ChatSettings_Groups: String { return self._s[2055]! } - public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2056]! } + public var Username_CheckingUsername: String { return self._s[2051]! } + public var NotificationsSound_Bell: String { return self._s[2052]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[2053]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2054]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2055]! } + public var ChatSettings_Groups: String { return self._s[2056]! } + public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2057]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2057]!, self._r[2057]!, [_0]) + return formatWithArgumentRanges(self._s[2058]!, self._r[2058]!, [_0]) } - public var Your_card_was_declined: String { return self._s[2058]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2060]! } - public var Wallet_Month_ShortApril: String { return self._s[2061]! } - public var ChatList_Unmute: String { return self._s[2062]! } - public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2063]! } - public var PhotoEditor_CurvesAll: String { return self._s[2064]! } - public var Weekday_ShortTuesday: String { return self._s[2065]! } - public var DialogList_Read: String { return self._s[2066]! } - public var Appearance_AppIconClassic: String { return self._s[2067]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2068]! } - public var Passport_Identity_Gender: String { return self._s[2069]! } + public var Your_card_was_declined: String { return self._s[2059]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2061]! } + public var Wallet_Month_ShortApril: String { return self._s[2062]! } + public var ChatList_Unmute: String { return self._s[2063]! } + public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2064]! } + public var PhotoEditor_CurvesAll: String { return self._s[2065]! } + public var Weekday_ShortTuesday: String { return self._s[2066]! } + public var DialogList_Read: String { return self._s[2067]! } + public var Appearance_AppIconClassic: String { return self._s[2068]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2069]! } + public var Passport_Identity_Gender: String { return self._s[2070]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2070]!, self._r[2070]!, [_0]) + return formatWithArgumentRanges(self._s[2071]!, self._r[2071]!, [_0]) } - public var Target_SelectGroup: String { return self._s[2071]! } - public var Map_HomeAndWorkInfo: String { return self._s[2073]! } + public var Target_SelectGroup: String { return self._s[2072]! } + public var Map_HomeAndWorkInfo: String { return self._s[2074]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2074]!, self._r[2074]!, [_0]) + return formatWithArgumentRanges(self._s[2075]!, self._r[2075]!, [_0]) } - public var Passport_Language_en: String { return self._s[2075]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2076]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2077]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[2078]! } - public var ScheduledMessages_SendNow: String { return self._s[2079]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[2081]! } - public var Login_InfoHelp: String { return self._s[2082]! } - public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2083]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2084]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2085]! } + public var Passport_Language_en: String { return self._s[2076]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2077]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2078]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[2079]! } + public var ScheduledMessages_SendNow: String { return self._s[2080]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[2082]! } + public var Login_InfoHelp: String { return self._s[2083]! } + public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2084]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2085]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2086]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2086]!, self._r[2086]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2087]!, self._r[2087]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[2089]! } - public var CreatePoll_Title: String { return self._s[2090]! } - public var MessagePoll_QuizNoUsers: String { return self._s[2091]! } - public var Conversation_ViewTheme: String { return self._s[2092]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2093]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2094]! } - public var TwoFactorSetup_Intro_Text: String { return self._s[2095]! } - public var UserInfo_GroupsInCommon: String { return self._s[2096]! } - public var TelegramWallet_Intro_TermsUrl: String { return self._s[2097]! } - public var Call_AudioRouteHide: String { return self._s[2098]! } + public var SocksProxySetup_AddProxy: String { return self._s[2090]! } + public var CreatePoll_Title: String { return self._s[2091]! } + public var MessagePoll_QuizNoUsers: String { return self._s[2092]! } + public var Conversation_ViewTheme: String { return self._s[2093]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2094]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2095]! } + public var TwoFactorSetup_Intro_Text: String { return self._s[2096]! } + public var UserInfo_GroupsInCommon: String { return self._s[2097]! } + public var TelegramWallet_Intro_TermsUrl: String { return self._s[2098]! } + public var Call_AudioRouteHide: String { return self._s[2099]! } public func Wallet_Info_TransactionDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2100]!, self._r[2100]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2101]!, self._r[2101]!, [_1, _2]) } - public var ContactInfo_PhoneLabelMobile: String { return self._s[2101]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2102]! } - public var CreatePoll_QuizOptionsHeader: String { return self._s[2103]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[2102]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2103]! } + public var CreatePoll_QuizOptionsHeader: String { return self._s[2104]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_0]) + return formatWithArgumentRanges(self._s[2105]!, self._r[2105]!, [_0]) } - public var TextFormat_Bold: String { return self._s[2105]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2106]! } - public var StickerPackActionInfo_AddedTitle: String { return self._s[2107]! } - public var Notifications_Title: String { return self._s[2108]! } - public var Group_Username_InvalidTooShort: String { return self._s[2109]! } - public var Channel_ErrorAddTooMuch: String { return self._s[2110]! } + public var TextFormat_Bold: String { return self._s[2106]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2107]! } + public var StickerPackActionInfo_AddedTitle: String { return self._s[2108]! } + public var Notifications_Title: String { return self._s[2109]! } + public var Group_Username_InvalidTooShort: String { return self._s[2110]! } + public var Channel_ErrorAddTooMuch: String { return self._s[2111]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2111]!, self._r[2111]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[2113]! } - public var Stickers_SuggestAdded: String { return self._s[2114]! } - public var Login_CountryCode: String { return self._s[2115]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[2116]! } - public var Map_GetDirections: String { return self._s[2117]! } - public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2118]! } - public var Login_PhoneFloodError: String { return self._s[2119]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[2114]! } + public var Stickers_SuggestAdded: String { return self._s[2115]! } + public var Login_CountryCode: String { return self._s[2116]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[2117]! } + public var Map_GetDirections: String { return self._s[2118]! } + public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2119]! } + public var Login_PhoneFloodError: String { return self._s[2120]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2120]!, self._r[2120]!, [_0]) + return formatWithArgumentRanges(self._s[2121]!, self._r[2121]!, [_0]) } public func Wallet_Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2121]!, self._r[2121]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2122]!, self._r[2122]!, [_1, _2, _3]) } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2122]! } - public var Settings_SetUsername: String { return self._s[2124]! } - public var Group_Location_ChangeLocation: String { return self._s[2125]! } - public var Notification_GroupInviterSelf: String { return self._s[2126]! } - public var InstantPage_TapToOpenLink: String { return self._s[2127]! } + public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2123]! } + public var Settings_SetUsername: String { return self._s[2125]! } + public var Group_Location_ChangeLocation: String { return self._s[2126]! } + public var Notification_GroupInviterSelf: String { return self._s[2127]! } + public var InstantPage_TapToOpenLink: String { return self._s[2128]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2128]!, self._r[2128]!, [_0]) + return formatWithArgumentRanges(self._s[2129]!, self._r[2129]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[2129]! } - public var SecretChat_Title: String { return self._s[2130]! } - public var Group_UpgradeNoticeText1: String { return self._s[2131]! } - public var AuthSessions_Title: String { return self._s[2132]! } + public var Watch_Suggestion_TalkLater: String { return self._s[2130]! } + public var SecretChat_Title: String { return self._s[2131]! } + public var Group_UpgradeNoticeText1: String { return self._s[2132]! } + public var AuthSessions_Title: String { return self._s[2133]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2133]!, self._r[2133]!, [_0]) + return formatWithArgumentRanges(self._s[2134]!, self._r[2134]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[2134]! } - public var Channel_About_Title: String { return self._s[2135]! } - public var Theme_ThemeChanged: String { return self._s[2136]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[2137]! } + public var PhotoEditor_CropAuto: String { return self._s[2135]! } + public var Channel_About_Title: String { return self._s[2136]! } + public var Theme_ThemeChanged: String { return self._s[2137]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[2138]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2139]!, self._r[2139]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2140]!, self._r[2140]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[2140]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2142]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[2143]! } + public var VoiceOver_MessageContextReport: String { return self._s[2141]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2143]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[2144]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2144]!, self._r[2144]!, [_1]) + return formatWithArgumentRanges(self._s[2145]!, self._r[2145]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2146]!, self._r[2146]!, [_0]) - } - public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2147]!, self._r[2147]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2148]! } - public var PeopleNearby_DiscoverDescription: String { return self._s[2150]! } - public var Presence_online: String { return self._s[2152]! } - public var PasscodeSettings_Title: String { return self._s[2153]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2154]! } - public var Web_OpenExternal: String { return self._s[2155]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[2157]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2158]! } - public var LocalGroup_Title: String { return self._s[2159]! } + public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2148]!, self._r[2148]!, [_0]) + } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2149]! } + public var PeopleNearby_DiscoverDescription: String { return self._s[2151]! } + public var Presence_online: String { return self._s[2153]! } + public var PasscodeSettings_Title: String { return self._s[2154]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2155]! } + public var Web_OpenExternal: String { return self._s[2156]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[2158]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2159]! } + public var LocalGroup_Title: String { return self._s[2160]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2160]!, self._r[2160]!, [_0]) + return formatWithArgumentRanges(self._s[2161]!, self._r[2161]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2161]! } - public var Conversation_StopQuizConfirmation: String { return self._s[2162]! } - public var Map_YouAreHere: String { return self._s[2163]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2162]! } + public var Conversation_StopQuizConfirmation: String { return self._s[2163]! } + public var Map_YouAreHere: String { return self._s[2164]! } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2164]!, self._r[2164]!, [_0]) - } - public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2165]!, self._r[2165]!, [_0]) } - public var Theme_Context_ChangeColors: String { return self._s[2166]! } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2167]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2168]! } - public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2169]!, self._r[2169]!, [_0]) + public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2166]!, self._r[2166]!, [_0]) } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Theme_Context_ChangeColors: String { return self._s[2167]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2168]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2169]! } + public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2170]!, self._r[2170]!, [_0]) } - public var SocksProxySetup_Username: String { return self._s[2171]! } - public var Bot_Start: String { return self._s[2172]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2173]!, self._r[2173]!, [_0]) + public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2171]!, self._r[2171]!, [_0]) } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + public var SocksProxySetup_Username: String { return self._s[2172]! } + public var Bot_Start: String { return self._s[2173]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2174]!, self._r[2174]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[2175]! } - public var AccentColor_Title: String { return self._s[2177]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2178]! } + public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2175]!, self._r[2175]!, [_0]) + } + public var Contacts_SortByPresence: String { return self._s[2176]! } + public var AccentColor_Title: String { return self._s[2178]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2179]! } public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2179]!, self._r[2179]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2180]!, self._r[2180]!, [_1, _2]) } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2180]!, self._r[2180]!, [_0]) + return formatWithArgumentRanges(self._s[2181]!, self._r[2181]!, [_0]) } public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2181]!, self._r[2181]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2182]!, self._r[2182]!, [_1, _2]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[2182]! } - public var Login_InfoAvatarPhoto: String { return self._s[2183]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2184]! } - public var Tour_Title4: String { return self._s[2185]! } - public var Passport_Identity_Translation: String { return self._s[2186]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2187]! } - public var Login_TermsOfServiceLabel: String { return self._s[2189]! } - public var Passport_Language_it: String { return self._s[2190]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2191]! } - public var Passport_Identity_SelfieHelp: String { return self._s[2192]! } - public var Conversation_ClearAll: String { return self._s[2194]! } - public var Wallet_Send_UninitializedText: String { return self._s[2196]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[2197]! } - public var TwoStepAuth_FloodError: String { return self._s[2198]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[2183]! } + public var Login_InfoAvatarPhoto: String { return self._s[2184]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2185]! } + public var Tour_Title4: String { return self._s[2186]! } + public var Passport_Identity_Translation: String { return self._s[2187]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2188]! } + public var Login_TermsOfServiceLabel: String { return self._s[2190]! } + public var Passport_Language_it: String { return self._s[2191]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2192]! } + public var Passport_Identity_SelfieHelp: String { return self._s[2193]! } + public var Conversation_ClearAll: String { return self._s[2195]! } + public var Wallet_Send_UninitializedText: String { return self._s[2197]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[2198]! } + public var TwoStepAuth_FloodError: String { return self._s[2199]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2199]!, self._r[2199]!, [_1]) + return formatWithArgumentRanges(self._s[2200]!, self._r[2200]!, [_1]) } - public var Paint_Delete: String { return self._s[2200]! } + public var Paint_Delete: String { return self._s[2201]! } public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2201]!, self._r[2201]!, [_0]) + return formatWithArgumentRanges(self._s[2202]!, self._r[2202]!, [_0]) } - public var Privacy_AddNewPeer: String { return self._s[2202]! } + public var Privacy_AddNewPeer: String { return self._s[2203]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2203]!, self._r[2203]!, [_1]) + return formatWithArgumentRanges(self._s[2204]!, self._r[2204]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2204]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[2205]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2205]!, self._r[2205]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2206]!, self._r[2206]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2206]! } + public var Message_PinnedAudioMessage: String { return self._s[2207]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2207]!, self._r[2207]!, [_0]) + return formatWithArgumentRanges(self._s[2208]!, self._r[2208]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[2208]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2209]! } - public var Wallet_Month_GenNovember: String { return self._s[2210]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[2211]! } - public var Conversation_MessageEditedLabel: String { return self._s[2212]! } + public var Notification_Mute1hMin: String { return self._s[2209]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2210]! } + public var Wallet_Month_GenNovember: String { return self._s[2211]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[2212]! } + public var Conversation_MessageEditedLabel: String { return self._s[2213]! } public func ClearCache_Success(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2213]!, self._r[2213]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2214]!, self._r[2214]!, [_0, _1]) } - public var Notification_Exceptions_AlwaysOff: String { return self._s[2214]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2215]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[2215]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2216]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2216]!, self._r[2216]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2217]!, self._r[2217]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2217]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2218]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2218]!, self._r[2218]!, [_1]) + return formatWithArgumentRanges(self._s[2219]!, self._r[2219]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[2219]! } - public var Month_GenOctober: String { return self._s[2220]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2221]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2222]! } - public var MediaPicker_TimerTooltip: String { return self._s[2224]! } - public var SharedMedia_TitleAll: String { return self._s[2225]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2228]! } - public var Conversation_RestrictedMedia: String { return self._s[2229]! } - public var AccessDenied_PhotosRestricted: String { return self._s[2230]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2232]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2233]! } + public var AccessDenied_LocationTracking: String { return self._s[2220]! } + public var Month_GenOctober: String { return self._s[2221]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2222]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2223]! } + public var MediaPicker_TimerTooltip: String { return self._s[2225]! } + public var SharedMedia_TitleAll: String { return self._s[2226]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2229]! } + public var Conversation_RestrictedMedia: String { return self._s[2230]! } + public var AccessDenied_PhotosRestricted: String { return self._s[2231]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2233]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2234]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2234]!, self._r[2234]!, [_0]) + return formatWithArgumentRanges(self._s[2235]!, self._r[2235]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[2237]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2239]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2240]! } + public var Conversation_SavedMessages: String { return self._s[2238]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2240]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2241]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2242]!, self._r[2242]!, [_0]) + return formatWithArgumentRanges(self._s[2243]!, self._r[2243]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[2243]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2244]! } public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2244]!, self._r[2244]!, [_0]) + return formatWithArgumentRanges(self._s[2245]!, self._r[2245]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[2245]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2246]! } + public var ReportPeer_AlertSuccess: String { return self._s[2246]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2247]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2247]!, self._r[2247]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2248]!, self._r[2248]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[2248]! } - public var PhotoEditor_FadeTool: String { return self._s[2249]! } - public var Privacy_ContactsReset: String { return self._s[2250]! } + public var Checkout_PasswordEntry_Title: String { return self._s[2249]! } + public var PhotoEditor_FadeTool: String { return self._s[2250]! } + public var Privacy_ContactsReset: String { return self._s[2251]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2252]!, self._r[2252]!, [_0]) + return formatWithArgumentRanges(self._s[2253]!, self._r[2253]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[2253]! } - public var ChatList_Mute: String { return self._s[2254]! } + public var Message_PinnedVideoMessage: String { return self._s[2254]! } + public var ChatList_Mute: String { return self._s[2255]! } public func Wallet_Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2255]!, self._r[2255]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2256]!, self._r[2256]!, [_1, _2, _3]) } - public var Permissions_CellularDataText_v0: String { return self._s[2256]! } - public var Conversation_PinnedQuiz: String { return self._s[2258]! } - public var ShareMenu_SelectChats: String { return self._s[2260]! } - public var ChatList_Context_Unarchive: String { return self._s[2261]! } - public var MusicPlayer_VoiceNote: String { return self._s[2262]! } - public var Conversation_RestrictedText: String { return self._s[2263]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2264]! } - public var Wallet_Month_GenApril: String { return self._s[2265]! } - public var Wallet_Month_ShortMarch: String { return self._s[2266]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2267]! } - public var Cache_Videos: String { return self._s[2268]! } - public var PrivacySettings_PhoneNumber: String { return self._s[2269]! } - public var Wallet_Month_GenFebruary: String { return self._s[2270]! } - public var FeatureDisabled_Oops: String { return self._s[2272]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[2273]! } + public var Permissions_CellularDataText_v0: String { return self._s[2257]! } + public var Conversation_PinnedQuiz: String { return self._s[2259]! } + public var ShareMenu_SelectChats: String { return self._s[2261]! } + public var ChatList_Context_Unarchive: String { return self._s[2262]! } + public var MusicPlayer_VoiceNote: String { return self._s[2263]! } + public var Conversation_RestrictedText: String { return self._s[2264]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2265]! } + public var Wallet_Month_GenApril: String { return self._s[2266]! } + public var Wallet_Month_ShortMarch: String { return self._s[2267]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2268]! } + public var Cache_Videos: String { return self._s[2269]! } + public var PrivacySettings_PhoneNumber: String { return self._s[2270]! } + public var Wallet_Month_GenFebruary: String { return self._s[2271]! } + public var FeatureDisabled_Oops: String { return self._s[2273]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[2274]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2274]!, self._r[2274]!, [_0]) + return formatWithArgumentRanges(self._s[2275]!, self._r[2275]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[2276]! } - public var GroupPermission_NoSendPolls: String { return self._s[2277]! } - public var Wallet_Qr_ScanCode: String { return self._s[2278]! } - public var Message_VideoExpired: String { return self._s[2280]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2281]! } - public var Notifications_Badge: String { return self._s[2282]! } - public var Wallet_Receive_AddressCopied: String { return self._s[2283]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[2284]! } - public var Username_InvalidTooShort: String { return self._s[2285]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2286]! } - public var Channel_AdminLog_PinMessages: String { return self._s[2287]! } - public var ArchivedChats_IntroTitle3: String { return self._s[2288]! } + public var Stickers_GroupStickersHelp: String { return self._s[2277]! } + public var GroupPermission_NoSendPolls: String { return self._s[2278]! } + public var Wallet_Qr_ScanCode: String { return self._s[2279]! } + public var Message_VideoExpired: String { return self._s[2281]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2282]! } + public var Notifications_Badge: String { return self._s[2283]! } + public var Wallet_Receive_AddressCopied: String { return self._s[2284]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[2285]! } + public var Username_InvalidTooShort: String { return self._s[2286]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2287]! } + public var Channel_AdminLog_PinMessages: String { return self._s[2288]! } + public var ArchivedChats_IntroTitle3: String { return self._s[2289]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2289]!, self._r[2289]!, [_1]) + return formatWithArgumentRanges(self._s[2290]!, self._r[2290]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[2290]! } - public var Conversation_DefaultRestrictedText: String { return self._s[2291]! } - public var SharedMedia_CategoryDocs: String { return self._s[2294]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[2291]! } + public var Conversation_DefaultRestrictedText: String { return self._s[2292]! } + public var SharedMedia_CategoryDocs: String { return self._s[2295]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2295]!, self._r[2295]!, [_1]) + return formatWithArgumentRanges(self._s[2296]!, self._r[2296]!, [_1]) } - public var Wallet_Send_UninitializedTitle: String { return self._s[2296]! } - public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2297]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2299]! } + public var Wallet_Send_UninitializedTitle: String { return self._s[2297]! } + public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2298]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2300]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2300]!, self._r[2300]!, [_1]) + return formatWithArgumentRanges(self._s[2301]!, self._r[2301]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2301]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2302]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2302]!, self._r[2302]!, [_0]) + return formatWithArgumentRanges(self._s[2303]!, self._r[2303]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[2303]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2304]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[2305]! } - public var Channel_UpdatePhotoItem: String { return self._s[2306]! } - public var GroupInfo_LeftStatus: String { return self._s[2307]! } - public var Watch_MessageView_Forward: String { return self._s[2309]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[2310]! } - public var Cache_ClearEmpty: String { return self._s[2312]! } - public var Localization_LanguageName: String { return self._s[2313]! } - public var Wallet_AccessDenied_Title: String { return self._s[2314]! } - public var WebSearch_GIFs: String { return self._s[2315]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2316]! } - public var Wallet_AccessDenied_Settings: String { return self._s[2317]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2318]! } - public var Common_Back: String { return self._s[2319]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2320]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2321]! } - public var Wallet_Send_Send: String { return self._s[2322]! } + public var ChatSettings_PrivateChats: String { return self._s[2304]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2305]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[2306]! } + public var Channel_UpdatePhotoItem: String { return self._s[2307]! } + public var GroupInfo_LeftStatus: String { return self._s[2308]! } + public var Watch_MessageView_Forward: String { return self._s[2310]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[2311]! } + public var Cache_ClearEmpty: String { return self._s[2313]! } + public var Localization_LanguageName: String { return self._s[2314]! } + public var Wallet_AccessDenied_Title: String { return self._s[2315]! } + public var WebSearch_GIFs: String { return self._s[2316]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2317]! } + public var Wallet_AccessDenied_Settings: String { return self._s[2318]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2319]! } + public var Common_Back: String { return self._s[2320]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2321]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2322]! } + public var Wallet_Send_Send: String { return self._s[2323]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2324]!, self._r[2324]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2325]!, self._r[2325]!, [_1, _2]) } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[2325]! } - public var Wallet_Month_GenJune: String { return self._s[2326]! } - public var Passport_Email_Help: String { return self._s[2327]! } - public var Watch_Conversation_Reply: String { return self._s[2329]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2332]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2333]! } - public var Channel_BanUser_Unban: String { return self._s[2335]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2336]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2337]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2339]! } - public var Wallet_Send_AddressHeader: String { return self._s[2340]! } - public var Passport_Identity_Name: String { return self._s[2341]! } + public var Wallet_Info_RefreshErrorTitle: String { return self._s[2326]! } + public var Wallet_Month_GenJune: String { return self._s[2327]! } + public var Passport_Email_Help: String { return self._s[2328]! } + public var Watch_Conversation_Reply: String { return self._s[2330]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2333]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2334]! } + public var Channel_BanUser_Unban: String { return self._s[2336]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2337]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2338]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2340]! } + public var Wallet_Send_AddressHeader: String { return self._s[2341]! } + public var Passport_Identity_Name: String { return self._s[2342]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2342]!, self._r[2342]!, [_0]) + return formatWithArgumentRanges(self._s[2343]!, self._r[2343]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2343]! } - public var Conversation_BlockUser: String { return self._s[2344]! } - public var Month_GenJanuary: String { return self._s[2345]! } - public var ChatSettings_TextSize: String { return self._s[2346]! } - public var Notification_PassportValuePhone: String { return self._s[2347]! } - public var MediaPlayer_UnknownArtist: String { return self._s[2348]! } - public var Passport_Language_ne: String { return self._s[2349]! } - public var Notification_CallBack: String { return self._s[2350]! } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2351]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2352]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[2344]! } + public var Conversation_BlockUser: String { return self._s[2345]! } + public var Month_GenJanuary: String { return self._s[2346]! } + public var ChatSettings_TextSize: String { return self._s[2347]! } + public var Notification_PassportValuePhone: String { return self._s[2348]! } + public var MediaPlayer_UnknownArtist: String { return self._s[2349]! } + public var Passport_Language_ne: String { return self._s[2350]! } + public var Notification_CallBack: String { return self._s[2351]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2352]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2353]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2353]!, self._r[2353]!, [_0]) + return formatWithArgumentRanges(self._s[2354]!, self._r[2354]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2354]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2355]! } - public var Stickers_FrequentlyUsed: String { return self._s[2356]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2357]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2359]! } + public var Channel_Info_Management: String { return self._s[2355]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2356]! } + public var Stickers_FrequentlyUsed: String { return self._s[2357]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2358]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2360]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2360]!, self._r[2360]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2361]!, self._r[2361]!, [_1, "\(_2)"]) } - public var TwoFactorSetup_Password_Title: String { return self._s[2361]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[2362]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2363]! } - public var CreatePoll_TextHeader: String { return self._s[2364]! } + public var TwoFactorSetup_Password_Title: String { return self._s[2362]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2363]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2364]! } + public var CreatePoll_TextHeader: String { return self._s[2365]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2365]!, self._r[2365]!, [_0]) + return formatWithArgumentRanges(self._s[2366]!, self._r[2366]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[2366]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2367]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2369]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2370]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2371]! } + public var PhotoEditor_QualityMedium: String { return self._s[2367]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2368]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2370]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2371]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2372]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2372]!, self._r[2372]!, [_0]) + return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_1]) + return formatWithArgumentRanges(self._s[2374]!, self._r[2374]!, [_1]) } - public var LogoutOptions_LogOutWalletInfo: String { return self._s[2374]! } - public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2375]! } - public var Conversation_LinkDialogOpen: String { return self._s[2377]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2378]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2379]! } - public var Settings_Username: String { return self._s[2381]! } - public var Conversation_Block: String { return self._s[2383]! } - public var Wallpaper_Wallpaper: String { return self._s[2384]! } - public var SocksProxySetup_UseProxy: String { return self._s[2386]! } - public var Wallet_Send_Confirmation: String { return self._s[2387]! } - public var EditTheme_UploadEditedTheme: String { return self._s[2388]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2389]! } - public var MessageTimer_Forever: String { return self._s[2390]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2391]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2392]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2393]! } - public var Passport_Language_da: String { return self._s[2394]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2395]! } + public var LogoutOptions_LogOutWalletInfo: String { return self._s[2375]! } + public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2376]! } + public var Conversation_LinkDialogOpen: String { return self._s[2378]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2379]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2380]! } + public var Settings_Username: String { return self._s[2382]! } + public var Conversation_Block: String { return self._s[2384]! } + public var Wallpaper_Wallpaper: String { return self._s[2385]! } + public var SocksProxySetup_UseProxy: String { return self._s[2387]! } + public var Wallet_Send_Confirmation: String { return self._s[2388]! } + public var EditTheme_UploadEditedTheme: String { return self._s[2389]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2390]! } + public var MessageTimer_Forever: String { return self._s[2391]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2392]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2393]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2394]! } + public var Passport_Language_da: String { return self._s[2395]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2396]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2396]!, self._r[2396]!, [_0]) + return formatWithArgumentRanges(self._s[2397]!, self._r[2397]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2397]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2398]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2399]!, self._r[2399]!, [_0]) + return formatWithArgumentRanges(self._s[2400]!, self._r[2400]!, [_0]) } - public var Settings_AddDevice: String { return self._s[2400]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2402]! } - public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2403]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2404]! } - public var Conversation_PinnedPoll: String { return self._s[2405]! } - public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2406]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2407]! } - public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2408]! } + public var Settings_AddDevice: String { return self._s[2401]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2403]! } + public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2404]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2405]! } + public var Conversation_PinnedPoll: String { return self._s[2406]! } + public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2407]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2408]! } + public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2409]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2409]!, self._r[2409]!, [_1]) + return formatWithArgumentRanges(self._s[2410]!, self._r[2410]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2410]! } - public var Cache_ByPeerHeader: String { return self._s[2411]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2411]! } + public var Cache_ByPeerHeader: String { return self._s[2412]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2412]!, self._r[2412]!, [_0]) + return formatWithArgumentRanges(self._s[2413]!, self._r[2413]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2413]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2416]! } - public var Wallet_Completed_Title: String { return self._s[2417]! } - public var Notification_PinnedMessage: String { return self._s[2418]! } - public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2419]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2421]! } - public var Contacts_SortBy: String { return self._s[2422]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2414]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2417]! } + public var Wallet_Completed_Title: String { return self._s[2418]! } + public var Notification_PinnedMessage: String { return self._s[2419]! } + public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2420]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2422]! } + public var Contacts_SortBy: String { return self._s[2423]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2423]!, self._r[2423]!, [_1]) + return formatWithArgumentRanges(self._s[2424]!, self._r[2424]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2425]! } + public var Appearance_ColorThemeNight: String { return self._s[2426]! } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2426]!, self._r[2426]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2427]!, self._r[2427]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2427]! } - public var Watch_UserInfo_Service: String { return self._s[2428]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2430]! } - public var Conversation_Unpin: String { return self._s[2432]! } - public var CancelResetAccount_Title: String { return self._s[2433]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2434]! } + public var Call_EncryptionKey_Title: String { return self._s[2428]! } + public var Watch_UserInfo_Service: String { return self._s[2429]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2431]! } + public var Conversation_Unpin: String { return self._s[2433]! } + public var CancelResetAccount_Title: String { return self._s[2434]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2435]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2436]!, self._r[2436]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2437]!, self._r[2437]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2437]! } - public var Appearance_BubbleCorners_Title: String { return self._s[2438]! } - public var CallSettings_Title: String { return self._s[2439]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2440]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2442]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2443]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2438]! } + public var Appearance_BubbleCorners_Title: String { return self._s[2439]! } + public var CallSettings_Title: String { return self._s[2440]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2441]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2443]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2444]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2444]!, self._r[2444]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2445]!, self._r[2445]!, [_1, _2]) } - public var Passport_Identity_DocumentDetails: String { return self._s[2445]! } - public var LoginPassword_PasswordHelp: String { return self._s[2446]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2447]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2448]! } - public var ChatContextMenu_TextSelectionTip: String { return self._s[2449]! } - public var Checkout_TotalPaidAmount: String { return self._s[2450]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2446]! } + public var LoginPassword_PasswordHelp: String { return self._s[2447]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2448]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2449]! } + public var ChatContextMenu_TextSelectionTip: String { return self._s[2450]! } + public var Checkout_TotalPaidAmount: String { return self._s[2451]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2451]!, self._r[2451]!, [_0]) + return formatWithArgumentRanges(self._s[2452]!, self._r[2452]!, [_0]) } - public var ChatState_Updating: String { return self._s[2452]! } - public var PasscodeSettings_ChangePasscode: String { return self._s[2453]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2455]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2456]! } + public var ChatState_Updating: String { return self._s[2453]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2454]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2456]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2457]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2457]!, self._r[2457]!, [_1]) + return formatWithArgumentRanges(self._s[2458]!, self._r[2458]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2458]! } - public var Contacts_InviteFriends: String { return self._s[2460]! } - public var Map_ChooseLocationTitle: String { return self._s[2461]! } - public var Conversation_StopPoll: String { return self._s[2463]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2459]! } + public var Contacts_InviteFriends: String { return self._s[2461]! } + public var Map_ChooseLocationTitle: String { return self._s[2462]! } + public var Conversation_StopPoll: String { return self._s[2464]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2464]!, self._r[2464]!, [_0]) + return formatWithArgumentRanges(self._s[2465]!, self._r[2465]!, [_0]) } - public var Call_Camera: String { return self._s[2465]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2466]! } - public var AppWallet_Intro_Text: String { return self._s[2467]! } - public var Appearance_BubbleCornersSetting: String { return self._s[2468]! } - public var Calls_RatingFeedback: String { return self._s[2469]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2471]! } - public var Wallet_Alert_OK: String { return self._s[2472]! } - public var NotificationsSound_Pulse: String { return self._s[2473]! } - public var Watch_LastSeen_Lately: String { return self._s[2474]! } - public var ReportGroupLocation_Report: String { return self._s[2477]! } - public var Widget_NoUsers: String { return self._s[2478]! } - public var Conversation_UnvotePoll: String { return self._s[2479]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2481]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2482]! } - public var NotificationsSound_Circles: String { return self._s[2483]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2486]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2487]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2488]! } - public var Proxy_TooltipUnavailable: String { return self._s[2489]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2491]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2493]! } - public var Conversation_FileDropbox: String { return self._s[2494]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2495]! } - public var Tour_Text3: String { return self._s[2497]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2499]! } - public var GroupPermission_NoSendMessages: String { return self._s[2500]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2501]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2502]! } + public var Call_Camera: String { return self._s[2466]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2467]! } + public var AppWallet_Intro_Text: String { return self._s[2468]! } + public var Appearance_BubbleCornersSetting: String { return self._s[2469]! } + public var Calls_RatingFeedback: String { return self._s[2470]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2472]! } + public var Wallet_Alert_OK: String { return self._s[2473]! } + public var NotificationsSound_Pulse: String { return self._s[2474]! } + public var Watch_LastSeen_Lately: String { return self._s[2475]! } + public var ReportGroupLocation_Report: String { return self._s[2478]! } + public var Widget_NoUsers: String { return self._s[2479]! } + public var Conversation_UnvotePoll: String { return self._s[2480]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2482]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2483]! } + public var NotificationsSound_Circles: String { return self._s[2484]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2487]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2488]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2489]! } + public var Proxy_TooltipUnavailable: String { return self._s[2490]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2492]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2494]! } + public var Conversation_FileDropbox: String { return self._s[2495]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2496]! } + public var Tour_Text3: String { return self._s[2498]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2500]! } + public var GroupPermission_NoSendMessages: String { return self._s[2501]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2502]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2503]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2504]!, self._r[2504]!, [_0]) + return formatWithArgumentRanges(self._s[2505]!, self._r[2505]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2505]! } - public var Checkout_ShippingOption_Title: String { return self._s[2506]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2507]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2506]! } + public var Checkout_ShippingOption_Title: String { return self._s[2507]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2508]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2508]!, self._r[2508]!, [_0]) - } - public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2509]!, self._r[2509]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2510]! } - public var EditTheme_FileReadError: String { return self._s[2511]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2512]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2513]! } - public var AutoDownloadSettings_Photos: String { return self._s[2515]! } - public var Appearance_PreviewIncomingText: String { return self._s[2516]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2517]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2518]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2519]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2520]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2521]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2522]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2523]! } - public var Notification_SecretChatScreenshot: String { return self._s[2524]! } - public var AccessDenied_Wallpapers: String { return self._s[2525]! } - public var ChatList_Context_Mute: String { return self._s[2527]! } - public var Passport_Address_City: String { return self._s[2528]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2529]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2530]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2531]! } - public var AccessDenied_LocationDisabled: String { return self._s[2532]! } - public var Group_Location_Title: String { return self._s[2533]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2535]! } - public var GroupInfo_Sound: String { return self._s[2536]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2537]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2538]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2539]! } - public var Contacts_Title: String { return self._s[2540]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2541]! } - public var Passport_Language_fr: String { return self._s[2542]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2543]! } - public var Notifications_ResetAllNotifications: String { return self._s[2544]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2546]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2548]! } - public var Checkout_NewCard_Title: String { return self._s[2549]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2550]! } - public var Conversation_ForwardChats: String { return self._s[2551]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2553]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2554]! } - public var Settings_FAQ: String { return self._s[2556]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2557]! } - public var Conversation_ContextMenuForward: String { return self._s[2558]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2561]! } - public var PrivacyPolicy_Title: String { return self._s[2564]! } - public var Notifications_TextTone: String { return self._s[2565]! } - public var Profile_CreateNewContact: String { return self._s[2566]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2567]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2569]! } - public var Call_Speaker: String { return self._s[2570]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2571]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2573]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2574]! } + public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2510]!, self._r[2510]!, [_0]) + } + public var Channel_Management_LabelAdministrator: String { return self._s[2511]! } + public var EditTheme_FileReadError: String { return self._s[2512]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2513]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2514]! } + public var AutoDownloadSettings_Photos: String { return self._s[2516]! } + public var Appearance_PreviewIncomingText: String { return self._s[2517]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2518]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2519]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2520]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2521]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2522]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2523]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2524]! } + public var Notification_SecretChatScreenshot: String { return self._s[2525]! } + public var AccessDenied_Wallpapers: String { return self._s[2526]! } + public var ChatList_Context_Mute: String { return self._s[2528]! } + public var Passport_Address_City: String { return self._s[2529]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2530]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2531]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2532]! } + public var AccessDenied_LocationDisabled: String { return self._s[2533]! } + public var Group_Location_Title: String { return self._s[2534]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2536]! } + public var GroupInfo_Sound: String { return self._s[2537]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2538]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2539]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2540]! } + public var Contacts_Title: String { return self._s[2541]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2542]! } + public var Passport_Language_fr: String { return self._s[2543]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2544]! } + public var Notifications_ResetAllNotifications: String { return self._s[2545]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2547]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2549]! } + public var Checkout_NewCard_Title: String { return self._s[2550]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2551]! } + public var Conversation_ForwardChats: String { return self._s[2552]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2554]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2555]! } + public var Settings_FAQ: String { return self._s[2557]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2558]! } + public var Conversation_ContextMenuForward: String { return self._s[2559]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2562]! } + public var PrivacyPolicy_Title: String { return self._s[2565]! } + public var Notifications_TextTone: String { return self._s[2566]! } + public var Profile_CreateNewContact: String { return self._s[2567]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2568]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2570]! } + public var Call_Speaker: String { return self._s[2571]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2572]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2574]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2575]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2575]!, self._r[2575]!, [_0]) + return formatWithArgumentRanges(self._s[2576]!, self._r[2576]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2576]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2577]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2578]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2579]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2580]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2581]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2582]! } - public var Bot_Unblock: String { return self._s[2583]! } - public var TextFormat_Italic: String { return self._s[2584]! } - public var WallpaperSearch_ColorPink: String { return self._s[2585]! } - public var Settings_About_Help: String { return self._s[2587]! } - public var SearchImages_Title: String { return self._s[2588]! } - public var Weekday_Wednesday: String { return self._s[2589]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2590]! } - public var ExplicitContent_AlertTitle: String { return self._s[2591]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2577]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2578]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2579]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2580]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2581]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2582]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2583]! } + public var Bot_Unblock: String { return self._s[2584]! } + public var TextFormat_Italic: String { return self._s[2585]! } + public var WallpaperSearch_ColorPink: String { return self._s[2586]! } + public var Settings_About_Help: String { return self._s[2588]! } + public var SearchImages_Title: String { return self._s[2589]! } + public var Weekday_Wednesday: String { return self._s[2590]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2591]! } + public var ExplicitContent_AlertTitle: String { return self._s[2592]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2592]!, self._r[2592]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2593]!, self._r[2593]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2593]! } - public var Weekday_Thursday: String { return self._s[2594]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2595]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2596]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2594]! } + public var Weekday_Thursday: String { return self._s[2595]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2596]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2597]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2597]!, self._r[2597]!, [_0]) + return formatWithArgumentRanges(self._s[2598]!, self._r[2598]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2598]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2599]! } - public var Passport_RequestedInformation: String { return self._s[2600]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2601]! } - public var Conversation_EncryptionProcessing: String { return self._s[2603]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2604]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2606]! } - public var Channel_Setup_Title: String { return self._s[2607]! } - public var Conversation_SearchPlaceholder: String { return self._s[2608]! } - public var OldChannels_GroupEmptyFormat: String { return self._s[2609]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2610]! } - public var Checkout_ErrorGeneric: String { return self._s[2611]! } - public var Passport_Language_hu: String { return self._s[2612]! } - public var GroupPermission_EditingDisabled: String { return self._s[2613]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2615]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2599]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2600]! } + public var Passport_RequestedInformation: String { return self._s[2601]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2602]! } + public var Conversation_EncryptionProcessing: String { return self._s[2604]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2605]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2607]! } + public var Channel_Setup_Title: String { return self._s[2608]! } + public var Conversation_SearchPlaceholder: String { return self._s[2609]! } + public var OldChannels_GroupEmptyFormat: String { return self._s[2610]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2611]! } + public var Checkout_ErrorGeneric: String { return self._s[2612]! } + public var Passport_Language_hu: String { return self._s[2613]! } + public var GroupPermission_EditingDisabled: String { return self._s[2614]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2616]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2616]!, self._r[2616]!, [_0]) + return formatWithArgumentRanges(self._s[2617]!, self._r[2617]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2619]!, self._r[2619]!, [_1]) + return formatWithArgumentRanges(self._s[2620]!, self._r[2620]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2620]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2621]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2621]!, self._r[2621]!, [_0]) + return formatWithArgumentRanges(self._s[2622]!, self._r[2622]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2622]! } - public var Group_Location_Info: String { return self._s[2623]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2624]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2625]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2623]! } + public var Group_Location_Info: String { return self._s[2624]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2625]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2626]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2626]!, self._r[2626]!, [_0]) + return formatWithArgumentRanges(self._s[2627]!, self._r[2627]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2627]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2628]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2629]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2630]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2628]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2629]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2630]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2631]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2631]!, self._r[2631]!, [_0]) - } - public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2632]!, self._r[2632]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2633]! } - public var Message_PinnedAnimationMessage: String { return self._s[2635]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2637]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2638]! } - public var Wallet_Info_TransactionTo: String { return self._s[2640]! } - public var Stats_ViewsBySourceTitle: String { return self._s[2641]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2642]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2643]! } - public var Embed_PlayingInPIP: String { return self._s[2644]! } - public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2645]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2646]! } + public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2633]!, self._r[2633]!, [_0]) + } + public var Passport_Language_cs: String { return self._s[2634]! } + public var Message_PinnedAnimationMessage: String { return self._s[2636]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2638]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2639]! } + public var Wallet_Info_TransactionTo: String { return self._s[2641]! } + public var Stats_ViewsBySourceTitle: String { return self._s[2642]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2643]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2644]! } + public var Embed_PlayingInPIP: String { return self._s[2645]! } + public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2646]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2647]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2647]!, self._r[2647]!, [_0]) + return formatWithArgumentRanges(self._s[2648]!, self._r[2648]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2648]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2649]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2649]!, self._r[2649]!, [_1]) + return formatWithArgumentRanges(self._s[2650]!, self._r[2650]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2650]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2651]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2652]! } - public var AutoNightTheme_System: String { return self._s[2653]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2654]! } - public var CreatePoll_QuizTitle: String { return self._s[2655]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2656]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2657]! } + public var Notification_PaymentSent: String { return self._s[2651]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2652]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2653]! } + public var AutoNightTheme_System: String { return self._s[2654]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2655]! } + public var CreatePoll_QuizTitle: String { return self._s[2656]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2657]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2658]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2660]!, self._r[2660]!, [_1]) - } - public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2661]!, self._r[2661]!, [_1]) } - public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2662]!, self._r[2662]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2664]! } - public var PasscodeSettings_HelpTop: String { return self._s[2665]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2666]! } - public var PeerInfo_AddToContacts: String { return self._s[2667]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2668]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2669]! } - public var EditTheme_ShortLink: String { return self._s[2670]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2671]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2672]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2673]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2674]! } - public var Call_Accept: String { return self._s[2676]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2677]! } - public var Month_GenMarch: String { return self._s[2679]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2680]! } - public var LoginPassword_Title: String { return self._s[2681]! } - public var Call_End: String { return self._s[2682]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2683]! } - public var VoiceOver_Chat_Contact: String { return self._s[2684]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2685]! } - public var CallSettings_Always: String { return self._s[2686]! } - public var CallFeedback_Success: String { return self._s[2687]! } - public var TwoStepAuth_SetupHint: String { return self._s[2688]! } + public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2663]!, self._r[2663]!, [_1]) + } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2665]! } + public var PasscodeSettings_HelpTop: String { return self._s[2666]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2667]! } + public var PeerInfo_AddToContacts: String { return self._s[2668]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2669]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2670]! } + public var EditTheme_ShortLink: String { return self._s[2671]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2672]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2673]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2674]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2675]! } + public var Call_Accept: String { return self._s[2677]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2678]! } + public var Month_GenMarch: String { return self._s[2680]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2681]! } + public var LoginPassword_Title: String { return self._s[2682]! } + public var Call_End: String { return self._s[2683]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2684]! } + public var VoiceOver_Chat_Contact: String { return self._s[2685]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2686]! } + public var CallSettings_Always: String { return self._s[2687]! } + public var CallFeedback_Success: String { return self._s[2688]! } + public var TwoStepAuth_SetupHint: String { return self._s[2689]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2689]!, self._r[2689]!, [_1]) + return formatWithArgumentRanges(self._s[2690]!, self._r[2690]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2690]! } - public var PeerInfo_ButtonAddMember: String { return self._s[2691]! } - public var Login_PhoneTitle: String { return self._s[2692]! } - public var Passport_FieldPhoneHelp: String { return self._s[2693]! } - public var Weekday_ShortSunday: String { return self._s[2694]! } - public var Passport_InfoFAQ_URL: String { return self._s[2695]! } - public var ContactInfo_Job: String { return self._s[2697]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2698]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2699]! } - public var CreatePoll_QuizTip: String { return self._s[2700]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2701]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2702]! } - public var Invite_ChannelsTooMuch: String { return self._s[2703]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2704]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2705]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2706]! } - public var Wallet_Receive_AmountText: String { return self._s[2707]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2708]! } - public var CallFeedback_ReasonNoise: String { return self._s[2709]! } - public var Appearance_AppIconDefault: String { return self._s[2711]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2712]! } - public var MediaPicker_AddCaption: String { return self._s[2713]! } - public var CallSettings_TabIconDescription: String { return self._s[2714]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2691]! } + public var PeerInfo_ButtonAddMember: String { return self._s[2692]! } + public var Login_PhoneTitle: String { return self._s[2693]! } + public var Passport_FieldPhoneHelp: String { return self._s[2694]! } + public var Weekday_ShortSunday: String { return self._s[2695]! } + public var Passport_InfoFAQ_URL: String { return self._s[2696]! } + public var ContactInfo_Job: String { return self._s[2698]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2699]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2700]! } + public var CreatePoll_QuizTip: String { return self._s[2701]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2702]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2703]! } + public var Invite_ChannelsTooMuch: String { return self._s[2704]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2705]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2706]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2707]! } + public var Wallet_Receive_AmountText: String { return self._s[2708]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2709]! } + public var CallFeedback_ReasonNoise: String { return self._s[2710]! } + public var Appearance_AppIconDefault: String { return self._s[2712]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2713]! } + public var MediaPicker_AddCaption: String { return self._s[2714]! } + public var CallSettings_TabIconDescription: String { return self._s[2715]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2715]!, self._r[2715]!, [_0]) + return formatWithArgumentRanges(self._s[2716]!, self._r[2716]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2716]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2717]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2717]!, self._r[2717]!, [_0]) + return formatWithArgumentRanges(self._s[2718]!, self._r[2718]!, [_0]) } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2718]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2719]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2720]! } - public var DialogList_SearchSectionRecent: String { return self._s[2721]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2722]! } - public var CreatePoll_Anonymous: String { return self._s[2723]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2726]! } - public var LastSeen_WithinAWeek: String { return self._s[2727]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2728]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2730]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2731]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2719]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2720]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2721]! } + public var DialogList_SearchSectionRecent: String { return self._s[2722]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2723]! } + public var CreatePoll_Anonymous: String { return self._s[2724]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2727]! } + public var LastSeen_WithinAWeek: String { return self._s[2728]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2729]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2731]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2732]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2732]!, self._r[2732]!, [_0]) + return formatWithArgumentRanges(self._s[2733]!, self._r[2733]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2733]! } - public var Conversation_StatusLeftGroup: String { return self._s[2734]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2735]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2737]! } - public var GroupPermission_AddSuccess: String { return self._s[2738]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2740]! } - public var Conversation_ContextMenuCopy: String { return self._s[2741]! } - public var AccessDenied_CallMicrophone: String { return self._s[2742]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2734]! } + public var Conversation_StatusLeftGroup: String { return self._s[2735]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2736]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2738]! } + public var GroupPermission_AddSuccess: String { return self._s[2739]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2741]! } + public var Conversation_ContextMenuCopy: String { return self._s[2742]! } + public var AccessDenied_CallMicrophone: String { return self._s[2743]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2743]!, self._r[2743]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2744]!, self._r[2744]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2744]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2745]! } - public var Checkout_PaymentMethod_New: String { return self._s[2746]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2747]! } - public var PhotoEditor_QualityTool: String { return self._s[2748]! } - public var Login_SendCodeViaSms: String { return self._s[2749]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2750]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2751]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2752]! } - public var Login_EmailNotConfiguredError: String { return self._s[2753]! } - public var SocksProxySetup_Status: String { return self._s[2754]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2755]! } - public var PrivacyPolicy_Accept: String { return self._s[2756]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2757]! } - public var Appearance_AppIconClassicX: String { return self._s[2758]! } + public var Login_InvalidFirstNameError: String { return self._s[2745]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2746]! } + public var Checkout_PaymentMethod_New: String { return self._s[2747]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2748]! } + public var PhotoEditor_QualityTool: String { return self._s[2749]! } + public var Login_SendCodeViaSms: String { return self._s[2750]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2751]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2752]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2753]! } + public var Login_EmailNotConfiguredError: String { return self._s[2754]! } + public var SocksProxySetup_Status: String { return self._s[2755]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2756]! } + public var PrivacyPolicy_Accept: String { return self._s[2757]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2758]! } + public var Appearance_AppIconClassicX: String { return self._s[2759]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2759]!, self._r[2759]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2760]!, self._r[2760]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2760]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2762]! } - public var AutoNightTheme_Automatic: String { return self._s[2763]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2764]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2765]! } - public var Cache_Help: String { return self._s[2766]! } - public var Group_ErrorAccessDenied: String { return self._s[2767]! } - public var Passport_Language_fa: String { return self._s[2768]! } - public var Wallet_Intro_Text: String { return self._s[2769]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2770]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2771]! } - public var PrivacySettings_LastSeen: String { return self._s[2772]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2761]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2763]! } + public var AutoNightTheme_Automatic: String { return self._s[2764]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2765]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2766]! } + public var Cache_Help: String { return self._s[2767]! } + public var Group_ErrorAccessDenied: String { return self._s[2768]! } + public var Passport_Language_fa: String { return self._s[2769]! } + public var Wallet_Intro_Text: String { return self._s[2770]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2771]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2772]! } + public var PrivacySettings_LastSeen: String { return self._s[2773]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2773]!, self._r[2773]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2774]!, self._r[2774]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2777]! } - public var Preview_SaveGif: String { return self._s[2778]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2779]! } - public var Profile_About: String { return self._s[2780]! } - public var Channel_About_Placeholder: String { return self._s[2781]! } - public var Login_InfoTitle: String { return self._s[2782]! } + public var Wallet_Configuration_Apply: String { return self._s[2778]! } + public var Preview_SaveGif: String { return self._s[2779]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2780]! } + public var Profile_About: String { return self._s[2781]! } + public var Channel_About_Placeholder: String { return self._s[2782]! } + public var Login_InfoTitle: String { return self._s[2783]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2783]!, self._r[2783]!, [_0]) + return formatWithArgumentRanges(self._s[2784]!, self._r[2784]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2784]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2786]! } - public var ContactInfo_Title: String { return self._s[2787]! } - public var Media_ShareThisVideo: String { return self._s[2788]! } - public var Weekday_ShortFriday: String { return self._s[2789]! } - public var AccessDenied_Contacts: String { return self._s[2791]! } - public var Notification_CallIncomingShort: String { return self._s[2792]! } - public var Group_Setup_TypePublic: String { return self._s[2793]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2794]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2795]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2798]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2799]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2800]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2801]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2802]! } + public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2785]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2787]! } + public var ContactInfo_Title: String { return self._s[2788]! } + public var Media_ShareThisVideo: String { return self._s[2789]! } + public var Weekday_ShortFriday: String { return self._s[2790]! } + public var AccessDenied_Contacts: String { return self._s[2792]! } + public var Notification_CallIncomingShort: String { return self._s[2793]! } + public var Group_Setup_TypePublic: String { return self._s[2794]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2795]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2796]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2799]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2800]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2801]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2802]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2803]! } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2803]!, self._r[2803]!, [_0]) + return formatWithArgumentRanges(self._s[2804]!, self._r[2804]!, [_0]) } - public var DialogList_Typing: String { return self._s[2804]! } - public var CallFeedback_IncludeLogs: String { return self._s[2806]! } - public var Checkout_Phone: String { return self._s[2808]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2811]! } - public var Privacy_Calls_Integration: String { return self._s[2812]! } - public var Notifications_PermissionsAllow: String { return self._s[2813]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2818]! } - public var Settings_ChatSettings: String { return self._s[2819]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[2820]! } + public var DialogList_Typing: String { return self._s[2805]! } + public var CallFeedback_IncludeLogs: String { return self._s[2807]! } + public var Checkout_Phone: String { return self._s[2809]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2812]! } + public var Privacy_Calls_Integration: String { return self._s[2813]! } + public var Notifications_PermissionsAllow: String { return self._s[2814]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2819]! } + public var Settings_ChatSettings: String { return self._s[2820]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[2821]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2822]!, self._r[2822]!, [_0]) + return formatWithArgumentRanges(self._s[2823]!, self._r[2823]!, [_0]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2823]!, self._r[2823]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2824]!, self._r[2824]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2825]! } + public var GroupRemoved_DeleteUser: String { return self._s[2826]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2826]!, self._r[2826]!, [_0]) + return formatWithArgumentRanges(self._s[2827]!, self._r[2827]!, [_0]) } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2827]!, self._r[2827]!, [_1]) + return formatWithArgumentRanges(self._s[2828]!, self._r[2828]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2828]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2829]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2831]! } - public var Conversation_Unblock: String { return self._s[2832]! } - public var PrivacySettings_DataSettings: String { return self._s[2833]! } - public var WallpaperPreview_PatternPaternApply: String { return self._s[2834]! } - public var Group_PublicLink_Info: String { return self._s[2835]! } + public var Login_ContinueWithLocalization: String { return self._s[2829]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2830]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2832]! } + public var Conversation_Unblock: String { return self._s[2833]! } + public var PrivacySettings_DataSettings: String { return self._s[2834]! } + public var WallpaperPreview_PatternPaternApply: String { return self._s[2835]! } + public var Group_PublicLink_Info: String { return self._s[2836]! } public func Wallet_Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2836]!, self._r[2836]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2837]!, self._r[2837]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2837]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2838]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2838]!, self._r[2838]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2839]!, self._r[2839]!, [_0, _1]) } - public var OldChannels_ChannelsHeader: String { return self._s[2840]! } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2841]! } - public var PrivacySettings_Passcode: String { return self._s[2843]! } - public var Call_Mute: String { return self._s[2844]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2845]! } - public var Passport_Language_dz: String { return self._s[2846]! } - public var Wallet_Receive_AmountHeader: String { return self._s[2847]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2848]! } - public var Passport_Language_tk: String { return self._s[2849]! } + public var OldChannels_ChannelsHeader: String { return self._s[2841]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2842]! } + public var PrivacySettings_Passcode: String { return self._s[2844]! } + public var Call_Mute: String { return self._s[2845]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2846]! } + public var Passport_Language_dz: String { return self._s[2847]! } + public var Wallet_Receive_AmountHeader: String { return self._s[2848]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2849]! } + public var Passport_Language_tk: String { return self._s[2850]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2850]!, self._r[2850]!, [_0]) + return formatWithArgumentRanges(self._s[2851]!, self._r[2851]!, [_0]) } - public var Settings_Search: String { return self._s[2851]! } - public var Wallet_Month_ShortFebruary: String { return self._s[2852]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2853]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[2854]! } - public var Conversation_ContextMenuReply: String { return self._s[2855]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2856]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2857]! } - public var Tour_Title1: String { return self._s[2858]! } - public var Wallet_Alert_Cancel: String { return self._s[2859]! } - public var Conversation_ClearGroupHistory: String { return self._s[2861]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2862]! } - public var WallpaperPreview_Motion: String { return self._s[2863]! } + public var Settings_Search: String { return self._s[2852]! } + public var Wallet_Month_ShortFebruary: String { return self._s[2853]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2854]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[2855]! } + public var Conversation_ContextMenuReply: String { return self._s[2856]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2857]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2858]! } + public var Tour_Title1: String { return self._s[2859]! } + public var Wallet_Alert_Cancel: String { return self._s[2860]! } + public var Conversation_ClearGroupHistory: String { return self._s[2862]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2863]! } + public var WallpaperPreview_Motion: String { return self._s[2864]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2864]!, self._r[2864]!, [_0]) + return formatWithArgumentRanges(self._s[2865]!, self._r[2865]!, [_0]) } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2865]! } - public var Call_RateCall: String { return self._s[2866]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2867]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2868]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2869]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2871]! } + public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2866]! } + public var Call_RateCall: String { return self._s[2867]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2868]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2869]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2870]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2872]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2873]!, self._r[2873]!, [_0]) + return formatWithArgumentRanges(self._s[2874]!, self._r[2874]!, [_0]) } - public var Compose_Create: String { return self._s[2874]! } - public var Contacts_InviteToTelegram: String { return self._s[2875]! } - public var GroupInfo_Notifications: String { return self._s[2876]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2878]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2879]! } - public var Month_GenApril: String { return self._s[2880]! } - public var Appearance_AutoNightTheme: String { return self._s[2881]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2883]! } - public var Login_CodeSentSms: String { return self._s[2885]! } + public var Compose_Create: String { return self._s[2875]! } + public var Contacts_InviteToTelegram: String { return self._s[2876]! } + public var GroupInfo_Notifications: String { return self._s[2877]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2879]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2880]! } + public var Month_GenApril: String { return self._s[2881]! } + public var Appearance_AutoNightTheme: String { return self._s[2882]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2884]! } + public var Login_CodeSentSms: String { return self._s[2886]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2886]!, self._r[2886]!, [_0]) + return formatWithArgumentRanges(self._s[2887]!, self._r[2887]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2887]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2888]! } - public var Passport_Language_hr: String { return self._s[2889]! } - public var Common_ActionNotAllowedError: String { return self._s[2890]! } + public var EmptyGroupInfo_Line3: String { return self._s[2888]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2889]! } + public var Passport_Language_hr: String { return self._s[2890]! } + public var Common_ActionNotAllowedError: String { return self._s[2891]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2891]!, self._r[2891]!, [_0]) + return formatWithArgumentRanges(self._s[2892]!, self._r[2892]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2892]! } - public var Wallet_Info_TransactionFrom: String { return self._s[2893]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2894]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2895]! } - public var Privacy_SecretChatsTitle: String { return self._s[2896]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2898]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2899]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2900]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2901]! } - public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[2902]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[2903]! } - public var Preview_DeleteGif: String { return self._s[2904]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2905]! } - public var Group_ErrorNotMutualContact: String { return self._s[2906]! } - public var Notification_MessageLifetime5s: String { return self._s[2907]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[2908]! } - public var OldChannels_ChannelFormat: String { return self._s[2909]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2893]! } + public var Wallet_Info_TransactionFrom: String { return self._s[2894]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2895]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2896]! } + public var Privacy_SecretChatsTitle: String { return self._s[2897]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2899]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2900]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2901]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[2902]! } + public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[2903]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[2904]! } + public var Preview_DeleteGif: String { return self._s[2905]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2906]! } + public var Group_ErrorNotMutualContact: String { return self._s[2907]! } + public var Notification_MessageLifetime5s: String { return self._s[2908]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[2909]! } + public var OldChannels_ChannelFormat: String { return self._s[2910]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2910]!, self._r[2910]!, [_0]) + return formatWithArgumentRanges(self._s[2911]!, self._r[2911]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[2911]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2913]! } - public var ReportSpam_DeleteThisChat: String { return self._s[2914]! } - public var Passport_Address_AddBankStatement: String { return self._s[2915]! } - public var Notification_CallIncoming: String { return self._s[2916]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[2917]! } - public var Compose_NewGroupTitle: String { return self._s[2918]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2920]! } - public var Passport_Address_Postcode: String { return self._s[2922]! } + public var VoiceOver_Chat_Video: String { return self._s[2912]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2914]! } + public var ReportSpam_DeleteThisChat: String { return self._s[2915]! } + public var Passport_Address_AddBankStatement: String { return self._s[2916]! } + public var Notification_CallIncoming: String { return self._s[2917]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[2918]! } + public var Compose_NewGroupTitle: String { return self._s[2919]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2921]! } + public var Passport_Address_Postcode: String { return self._s[2923]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2923]!, self._r[2923]!, [_0]) + return formatWithArgumentRanges(self._s[2924]!, self._r[2924]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2924]! } - public var Wallet_Month_ShortOctober: String { return self._s[2925]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[2926]! } - public var WallpaperColors_Title: String { return self._s[2927]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2928]! } - public var VoiceOver_MessageContextForward: String { return self._s[2929]! } - public var GroupPermission_Duration: String { return self._s[2930]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2925]! } + public var Wallet_Month_ShortOctober: String { return self._s[2926]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[2927]! } + public var WallpaperColors_Title: String { return self._s[2928]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2929]! } + public var VoiceOver_MessageContextForward: String { return self._s[2930]! } + public var GroupPermission_Duration: String { return self._s[2931]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2931]!, self._r[2931]!, [_0]) + return formatWithArgumentRanges(self._s[2932]!, self._r[2932]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2932]! } - public var Username_Placeholder: String { return self._s[2933]! } - public var CallFeedback_WhatWentWrong: String { return self._s[2934]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2935]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2936]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2933]! } + public var Username_Placeholder: String { return self._s[2934]! } + public var CallFeedback_WhatWentWrong: String { return self._s[2935]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2936]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2937]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2938]!, self._r[2938]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2939]!, self._r[2939]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[2939]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2940]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2941]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2942]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2943]! } - public var Conversation_ContextMenuMore: String { return self._s[2944]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2945]! } - public var CallSettings_TabIcon: String { return self._s[2946]! } - public var KeyCommand_Find: String { return self._s[2947]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[2948]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2949]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2950]! } - public var Message_PinnedGame: String { return self._s[2951]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2952]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2954]! } - public var Login_CallRequestState2: String { return self._s[2956]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2958]! } + public var Passport_PasswordDescription: String { return self._s[2940]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2941]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2942]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2943]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2944]! } + public var Conversation_ContextMenuMore: String { return self._s[2945]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2946]! } + public var CallSettings_TabIcon: String { return self._s[2947]! } + public var KeyCommand_Find: String { return self._s[2948]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[2949]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2950]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2951]! } + public var Message_PinnedGame: String { return self._s[2952]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2953]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2955]! } + public var Login_CallRequestState2: String { return self._s[2957]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2959]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2959]!, self._r[2959]!, [_0]) + return formatWithArgumentRanges(self._s[2960]!, self._r[2960]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2961]!, self._r[2961]!, [_0]) + return formatWithArgumentRanges(self._s[2962]!, self._r[2962]!, [_0]) } - public var AuthSessions_AddDevice: String { return self._s[2962]! } - public var WallpaperPreview_Blurred: String { return self._s[2963]! } - public var Conversation_InstantPagePreview: String { return self._s[2964]! } - public var PeerInfo_ButtonUnmute: String { return self._s[2965]! } + public var AuthSessions_AddDevice: String { return self._s[2963]! } + public var WallpaperPreview_Blurred: String { return self._s[2964]! } + public var Conversation_InstantPagePreview: String { return self._s[2965]! } + public var PeerInfo_ButtonUnmute: String { return self._s[2966]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2966]!, self._r[2966]!, [_0]) + return formatWithArgumentRanges(self._s[2967]!, self._r[2967]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2969]! } - public var WallpaperSearch_ColorRed: String { return self._s[2970]! } - public var GroupPermission_NoPinMessages: String { return self._s[2971]! } - public var Passport_Language_es: String { return self._s[2972]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2974]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2975]! } + public var SecretTimer_VideoDescription: String { return self._s[2970]! } + public var WallpaperSearch_ColorRed: String { return self._s[2971]! } + public var GroupPermission_NoPinMessages: String { return self._s[2972]! } + public var Passport_Language_es: String { return self._s[2973]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2975]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2976]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2976]!, self._r[2976]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2977]!, self._r[2977]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[2977]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2978]! } - public var Watch_UserInfo_Unmute: String { return self._s[2979]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2980]! } - public var AccessDenied_CameraRestricted: String { return self._s[2982]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[2978]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2979]! } + public var Watch_UserInfo_Unmute: String { return self._s[2980]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2981]! } + public var AccessDenied_CameraRestricted: String { return self._s[2983]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2983]!, self._r[2983]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2984]!, self._r[2984]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2985]! } - public var Settings_CopyUsername: String { return self._s[2986]! } - public var Contacts_SearchLabel: String { return self._s[2987]! } - public var Map_OpenInYandexNavigator: String { return self._s[2989]! } - public var PasscodeSettings_EncryptData: String { return self._s[2990]! } - public var Settings_Wallet: String { return self._s[2991]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2992]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[2993]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2994]! } - public var DialogList_AdNoticeAlert: String { return self._s[2995]! } - public var Wallet_Month_GenMay: String { return self._s[2997]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2998]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2999]! } - public var Localization_LanguageCustom: String { return self._s[3000]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3001]! } - public var CallFeedback_Title: String { return self._s[3002]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3005]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3006]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[3007]! } - public var Conversation_InfoGroup: String { return self._s[3008]! } - public var Compose_NewMessage: String { return self._s[3009]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3010]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3011]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3012]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3013]! } + public var ChatList_ReadAll: String { return self._s[2986]! } + public var Settings_CopyUsername: String { return self._s[2987]! } + public var Contacts_SearchLabel: String { return self._s[2988]! } + public var Map_OpenInYandexNavigator: String { return self._s[2990]! } + public var PasscodeSettings_EncryptData: String { return self._s[2991]! } + public var Settings_Wallet: String { return self._s[2992]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2993]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[2994]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2995]! } + public var DialogList_AdNoticeAlert: String { return self._s[2996]! } + public var Wallet_Month_GenMay: String { return self._s[2998]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2999]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3000]! } + public var Localization_LanguageCustom: String { return self._s[3001]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3002]! } + public var CallFeedback_Title: String { return self._s[3003]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3006]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3007]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[3008]! } + public var Conversation_InfoGroup: String { return self._s[3009]! } + public var Compose_NewMessage: String { return self._s[3010]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3011]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3012]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3013]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3014]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3014]!, self._r[3014]!, [_0]) + return formatWithArgumentRanges(self._s[3015]!, self._r[3015]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3015]! } - public var Login_CancelSignUpConfirmation: String { return self._s[3016]! } - public var ChangePhoneNumberCode_Help: String { return self._s[3017]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[3018]! } - public var Channel_BlackList_Title: String { return self._s[3019]! } - public var UserInfo_PhoneCall: String { return self._s[3020]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3022]! } - public var Wallet_Month_ShortJanuary: String { return self._s[3023]! } - public var State_connecting: String { return self._s[3024]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3025]! } - public var Wallet_Month_GenMarch: String { return self._s[3026]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[3027]! } - public var AuthSessions_AddedDeviceTerminate: String { return self._s[3028]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3016]! } + public var Login_CancelSignUpConfirmation: String { return self._s[3017]! } + public var ChangePhoneNumberCode_Help: String { return self._s[3018]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[3019]! } + public var Channel_BlackList_Title: String { return self._s[3020]! } + public var UserInfo_PhoneCall: String { return self._s[3021]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3023]! } + public var Wallet_Month_ShortJanuary: String { return self._s[3024]! } + public var State_connecting: String { return self._s[3025]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3026]! } + public var Wallet_Month_GenMarch: String { return self._s[3027]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[3028]! } + public var AuthSessions_AddedDeviceTerminate: String { return self._s[3029]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3029]!, self._r[3029]!, [_0]) - } - public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3030]!, self._r[3030]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[3031]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3032]! } - public var Passport_Identity_EditPassport: String { return self._s[3033]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[3035]! } - public var Localization_EnglishLanguageName: String { return self._s[3036]! } - public var Share_AuthDescription: String { return self._s[3037]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3038]! } - public var Passport_Identity_Surname: String { return self._s[3039]! } - public var Compose_TokenListPlaceholder: String { return self._s[3040]! } - public var Wallet_AccessDenied_Camera: String { return self._s[3041]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[3042]! } - public var Settings_AboutEmpty: String { return self._s[3043]! } - public var Conversation_Unmute: String { return self._s[3044]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[3046]! } - public var Wallet_Sending_Text: String { return self._s[3047]! } - public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3048]!, self._r[3048]!, [_1]) + public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3031]!, self._r[3031]!, [_0]) } - public var Login_CodeSentCall: String { return self._s[3049]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3051]! } - public var ChatSettings_Appearance: String { return self._s[3052]! } - public var ClearCache_StorageUsage: String { return self._s[3053]! } - public var Appearance_PickAccentColor: String { return self._s[3054]! } + public var Notifications_GroupNotifications: String { return self._s[3032]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3033]! } + public var Passport_Identity_EditPassport: String { return self._s[3034]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[3036]! } + public var Localization_EnglishLanguageName: String { return self._s[3037]! } + public var Share_AuthDescription: String { return self._s[3038]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3039]! } + public var Passport_Identity_Surname: String { return self._s[3040]! } + public var Compose_TokenListPlaceholder: String { return self._s[3041]! } + public var Wallet_AccessDenied_Camera: String { return self._s[3042]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[3043]! } + public var Settings_AboutEmpty: String { return self._s[3044]! } + public var Conversation_Unmute: String { return self._s[3045]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[3047]! } + public var Wallet_Sending_Text: String { return self._s[3048]! } + public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3049]!, self._r[3049]!, [_1]) + } + public var Login_CodeSentCall: String { return self._s[3050]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3052]! } + public var ChatSettings_Appearance: String { return self._s[3053]! } + public var ClearCache_StorageUsage: String { return self._s[3054]! } + public var Appearance_PickAccentColor: String { return self._s[3055]! } public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3055]!, self._r[3055]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3056]!, self._r[3056]!, [_1, _2]) } public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3056]!, self._r[3056]!, [_1]) + return formatWithArgumentRanges(self._s[3057]!, self._r[3057]!, [_1]) } - public var Notification_CallMissed: String { return self._s[3057]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3058]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3059]! } - public var Wallet_Month_GenOctober: String { return self._s[3061]! } - public var ChatAdmins_AdminLabel: String { return self._s[3062]! } - public var KeyCommand_JumpToNextChat: String { return self._s[3063]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[3065]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3066]! } - public var Month_GenJune: String { return self._s[3067]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[3068]! } - public var Watch_Location_Current: String { return self._s[3069]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3070]! } - public var Conversation_TitleMute: String { return self._s[3071]! } - public var Map_PlacesInThisArea: String { return self._s[3072]! } + public var Notification_CallMissed: String { return self._s[3058]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3059]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3060]! } + public var Wallet_Month_GenOctober: String { return self._s[3062]! } + public var ChatAdmins_AdminLabel: String { return self._s[3063]! } + public var KeyCommand_JumpToNextChat: String { return self._s[3064]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[3066]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3067]! } + public var Month_GenJune: String { return self._s[3068]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[3069]! } + public var Watch_Location_Current: String { return self._s[3070]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3071]! } + public var Conversation_TitleMute: String { return self._s[3072]! } + public var Map_PlacesInThisArea: String { return self._s[3073]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3073]!, self._r[3073]!, [_1]) + return formatWithArgumentRanges(self._s[3074]!, self._r[3074]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[3074]! } + public var GroupInfo_DeleteAndExit: String { return self._s[3075]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3075]!, self._r[3075]!, [_0]) + return formatWithArgumentRanges(self._s[3076]!, self._r[3076]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[3076]! } - public var Chat_SlowmodeSendError: String { return self._s[3077]! } - public var MaskStickerSettings_Info: String { return self._s[3078]! } - public var EditTheme_Expand_TopInfo: String { return self._s[3079]! } + public var Call_ReportPlaceholder: String { return self._s[3077]! } + public var Chat_SlowmodeSendError: String { return self._s[3078]! } + public var MaskStickerSettings_Info: String { return self._s[3079]! } + public var EditTheme_Expand_TopInfo: String { return self._s[3080]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3080]!, self._r[3080]!, [_0]) + return formatWithArgumentRanges(self._s[3081]!, self._r[3081]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[3081]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[3083]! } - public var Contacts_ShareTelegram: String { return self._s[3084]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3085]! } - public var Map_AddressOnMap: String { return self._s[3086]! } - public var Channel_ErrorAccessDenied: String { return self._s[3087]! } - public var UserInfo_ScamBotWarning: String { return self._s[3089]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[3090]! } - public var Call_ConnectionErrorTitle: String { return self._s[3091]! } - public var UserInfo_NotificationsEnable: String { return self._s[3092]! } - public var ArchivedChats_IntroText1: String { return self._s[3093]! } - public var Tour_Text4: String { return self._s[3096]! } - public var WallpaperSearch_Recent: String { return self._s[3097]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[3098]! } - public var PeopleNearby_MakeVisibleTitle: String { return self._s[3099]! } - public var Profile_MessageLifetime2s: String { return self._s[3101]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3102]! } - public var Notification_MessageLifetime2s: String { return self._s[3103]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[3082]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[3084]! } + public var Contacts_ShareTelegram: String { return self._s[3085]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3086]! } + public var Map_AddressOnMap: String { return self._s[3087]! } + public var Channel_ErrorAccessDenied: String { return self._s[3088]! } + public var UserInfo_ScamBotWarning: String { return self._s[3090]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[3091]! } + public var Call_ConnectionErrorTitle: String { return self._s[3092]! } + public var UserInfo_NotificationsEnable: String { return self._s[3093]! } + public var ArchivedChats_IntroText1: String { return self._s[3094]! } + public var Tour_Text4: String { return self._s[3097]! } + public var WallpaperSearch_Recent: String { return self._s[3098]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[3099]! } + public var PeopleNearby_MakeVisibleTitle: String { return self._s[3100]! } + public var Profile_MessageLifetime2s: String { return self._s[3102]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3103]! } + public var Notification_MessageLifetime2s: String { return self._s[3104]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3104]!, self._r[3104]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3105]!, self._r[3105]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[3105]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[3106]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3107]! } + public var Cache_ClearCache: String { return self._s[3106]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3107]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3108]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3111]!, self._r[3111]!, [_0]) + return formatWithArgumentRanges(self._s[3112]!, self._r[3112]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3113]!, self._r[3113]!, [_0]) + return formatWithArgumentRanges(self._s[3114]!, self._r[3114]!, [_0]) } - public var LocalGroup_Text: String { return self._s[3114]! } - public var PeerInfo_PaneMembers: String { return self._s[3115]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3116]! } - public var SocksProxySetup_TypeSocks: String { return self._s[3117]! } - public var ChatList_UnarchiveAction: String { return self._s[3118]! } - public var AutoNightTheme_Title: String { return self._s[3119]! } - public var InstantPage_FeedbackButton: String { return self._s[3120]! } - public var Passport_FieldAddress: String { return self._s[3121]! } + public var LocalGroup_Text: String { return self._s[3115]! } + public var PeerInfo_PaneMembers: String { return self._s[3116]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3117]! } + public var SocksProxySetup_TypeSocks: String { return self._s[3118]! } + public var ChatList_UnarchiveAction: String { return self._s[3119]! } + public var AutoNightTheme_Title: String { return self._s[3120]! } + public var InstantPage_FeedbackButton: String { return self._s[3121]! } + public var Passport_FieldAddress: String { return self._s[3122]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3122]!, self._r[3122]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3123]!, self._r[3123]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3123]! } + public var Month_ShortMarch: String { return self._s[3124]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3124]!, self._r[3124]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3125]!, self._r[3125]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3125]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3126]! } - public var Passport_FloodError: String { return self._s[3127]! } - public var SecretGif_Title: String { return self._s[3128]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3129]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3130]! } - public var Passport_Language_th: String { return self._s[3132]! } - public var Passport_Address_Address: String { return self._s[3133]! } - public var Login_InvalidLastNameError: String { return self._s[3134]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3135]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3136]! } - public var ChatList_Context_Archive: String { return self._s[3137]! } - public var SettingsSearch_FAQ: String { return self._s[3138]! } - public var ShareMenu_Send: String { return self._s[3139]! } - public var ChatState_Connecting: String { return self._s[3140]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3142]! } - public var Month_GenNovember: String { return self._s[3144]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3146]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3126]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3127]! } + public var Passport_FloodError: String { return self._s[3128]! } + public var SecretGif_Title: String { return self._s[3129]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3130]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3131]! } + public var Passport_Language_th: String { return self._s[3133]! } + public var Passport_Address_Address: String { return self._s[3134]! } + public var Login_InvalidLastNameError: String { return self._s[3135]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3136]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3137]! } + public var ChatList_Context_Archive: String { return self._s[3138]! } + public var SettingsSearch_FAQ: String { return self._s[3139]! } + public var ShareMenu_Send: String { return self._s[3140]! } + public var ChatState_Connecting: String { return self._s[3141]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3143]! } + public var Month_GenNovember: String { return self._s[3145]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3147]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3147]!, self._r[3147]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3148]!, self._r[3148]!, [_1, _2]) } - public var Conversation_SwipeToReplyHintText: String { return self._s[3148]! } - public var Checkout_Email: String { return self._s[3149]! } - public var NotificationsSound_Tritone: String { return self._s[3150]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3152]! } - public var Wallet_ContextMenuCopy: String { return self._s[3154]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3149]! } + public var Checkout_Email: String { return self._s[3150]! } + public var NotificationsSound_Tritone: String { return self._s[3151]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3153]! } + public var Wallet_ContextMenuCopy: String { return self._s[3155]! } public func Wallet_Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3156]!, self._r[3156]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3157]!, self._r[3157]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3157]! } + public var Appearance_TextSize_Automatic: String { return self._s[3158]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3158]!, self._r[3158]!, [_1]) + return formatWithArgumentRanges(self._s[3159]!, self._r[3159]!, [_1]) } public func StickerPackActionInfo_AddedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3159]!, self._r[3159]!, [_0]) + return formatWithArgumentRanges(self._s[3160]!, self._r[3160]!, [_0]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3160]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3161]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3161]!, self._r[3161]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3162]!, self._r[3162]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3162]! } - public var Notification_Exceptions_Add: String { return self._s[3163]! } - public var DialogList_You: String { return self._s[3164]! } - public var MediaPicker_Send: String { return self._s[3167]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3168]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3169]! } - public var Call_AudioRouteSpeaker: String { return self._s[3170]! } - public var Watch_UserInfo_Title: String { return self._s[3171]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3172]! } - public var Appearance_AccentColor: String { return self._s[3174]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3163]! } + public var Notification_Exceptions_Add: String { return self._s[3164]! } + public var DialogList_You: String { return self._s[3165]! } + public var MediaPicker_Send: String { return self._s[3168]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3169]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3170]! } + public var Call_AudioRouteSpeaker: String { return self._s[3171]! } + public var Watch_UserInfo_Title: String { return self._s[3172]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3173]! } + public var Appearance_AccentColor: String { return self._s[3175]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3175]!, self._r[3175]!, [_0]) + return formatWithArgumentRanges(self._s[3176]!, self._r[3176]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3176]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3177]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3177]!, self._r[3177]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3178]!, self._r[3178]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3178]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3179]! } - public var Notification_CallOutgoing: String { return self._s[3180]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3181]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3182]! } - public var Call_RecordingDisabledMessage: String { return self._s[3183]! } - public var Message_Game: String { return self._s[3184]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3185]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3186]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3187]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3188]! } - public var Date_DialogDateFormat: String { return self._s[3190]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3191]! } - public var Notifications_InAppNotifications: String { return self._s[3192]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[3179]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3180]! } + public var Notification_CallOutgoing: String { return self._s[3181]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3182]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3183]! } + public var Call_RecordingDisabledMessage: String { return self._s[3184]! } + public var Message_Game: String { return self._s[3185]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3186]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3187]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3188]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3189]! } + public var Date_DialogDateFormat: String { return self._s[3191]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3192]! } + public var Notifications_InAppNotifications: String { return self._s[3193]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3193]!, self._r[3193]!, [_0]) + return formatWithArgumentRanges(self._s[3194]!, self._r[3194]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3194]!, self._r[3194]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3195]!, self._r[3195]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[3195]! } + public var NewContact_Title: String { return self._s[3196]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3196]!, self._r[3196]!, [_0]) + return formatWithArgumentRanges(self._s[3197]!, self._r[3197]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[3197]! } + public var Conversation_ViewContactDetails: String { return self._s[3198]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3199]!, self._r[3199]!, [_1]) + return formatWithArgumentRanges(self._s[3200]!, self._r[3200]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3200]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3201]! } - public var PrivacySettings_Title: String { return self._s[3202]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3205]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3206]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3207]! } - public var Contacts_PhoneNumber: String { return self._s[3208]! } - public var PeerInfo_ButtonMute: String { return self._s[3209]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3211]! } - public var Map_ShowPlaces: String { return self._s[3212]! } - public var ChatAdmins_Title: String { return self._s[3213]! } - public var InstantPage_Reference: String { return self._s[3215]! } - public var Wallet_Info_Updating: String { return self._s[3216]! } - public var ReportGroupLocation_Text: String { return self._s[3217]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3201]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3202]! } + public var PrivacySettings_Title: String { return self._s[3203]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3206]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3207]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3208]! } + public var Contacts_PhoneNumber: String { return self._s[3209]! } + public var PeerInfo_ButtonMute: String { return self._s[3210]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3212]! } + public var Map_ShowPlaces: String { return self._s[3213]! } + public var ChatAdmins_Title: String { return self._s[3214]! } + public var InstantPage_Reference: String { return self._s[3216]! } + public var Wallet_Info_Updating: String { return self._s[3217]! } + public var ReportGroupLocation_Text: String { return self._s[3218]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3218]!, self._r[3218]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3219]!, self._r[3219]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3219]! } - public var Watch_UserInfo_Block: String { return self._s[3220]! } - public var ChatSettings_Stickers: String { return self._s[3221]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3222]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3223]! } + public var Camera_FlashOff: String { return self._s[3220]! } + public var Watch_UserInfo_Block: String { return self._s[3221]! } + public var ChatSettings_Stickers: String { return self._s[3222]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3223]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3224]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3224]!, self._r[3224]!, [_0]) + return formatWithArgumentRanges(self._s[3225]!, self._r[3225]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3225]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3226]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3227]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3228]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3229]! } - public var VoiceOver_MessageContextShare: String { return self._s[3230]! } + public var Settings_ViewPhoto: String { return self._s[3226]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3227]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3228]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3229]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3230]! } + public var VoiceOver_MessageContextShare: String { return self._s[3231]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3232]!, self._r[3232]!, [_0]) + return formatWithArgumentRanges(self._s[3233]!, self._r[3233]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[3233]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3234]! } + public var Privacy_DeleteDrafts: String { return self._s[3234]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3235]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3235]!, self._r[3235]!, [_0]) + return formatWithArgumentRanges(self._s[3236]!, self._r[3236]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[3236]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3237]! } - public var DialogList_SavedMessages: String { return self._s[3238]! } - public var GroupInfo_UpgradeButton: String { return self._s[3239]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3241]! } - public var DialogList_Pin: String { return self._s[3242]! } + public var DialogList_SavedMessagesHelp: String { return self._s[3237]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3238]! } + public var DialogList_SavedMessages: String { return self._s[3239]! } + public var GroupInfo_UpgradeButton: String { return self._s[3240]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3242]! } + public var DialogList_Pin: String { return self._s[3243]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3243]!, self._r[3243]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3244]!, self._r[3244]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3244]!, self._r[3244]!, [_0]) + return formatWithArgumentRanges(self._s[3245]!, self._r[3245]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3245]! } - public var UserInfo_NotificationsDisable: String { return self._s[3246]! } - public var Conversation_ContextMenuCancelEditing: String { return self._s[3247]! } - public var Paint_Outlined: String { return self._s[3248]! } - public var Activity_PlayingGame: String { return self._s[3249]! } - public var SearchImages_NoImagesFound: String { return self._s[3250]! } - public var SocksProxySetup_ProxyType: String { return self._s[3251]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3253]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3254]! } - public var Settings_AppLanguage: String { return self._s[3255]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3256]! } - public var Common_ChoosePhoto: String { return self._s[3257]! } - public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3258]! } - public var CallFeedback_ReasonEcho: String { return self._s[3259]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3246]! } + public var UserInfo_NotificationsDisable: String { return self._s[3247]! } + public var Conversation_ContextMenuCancelEditing: String { return self._s[3248]! } + public var Paint_Outlined: String { return self._s[3249]! } + public var Activity_PlayingGame: String { return self._s[3250]! } + public var SearchImages_NoImagesFound: String { return self._s[3251]! } + public var SocksProxySetup_ProxyType: String { return self._s[3252]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3254]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3255]! } + public var Settings_AppLanguage: String { return self._s[3256]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3257]! } + public var Common_ChoosePhoto: String { return self._s[3258]! } + public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3259]! } + public var CallFeedback_ReasonEcho: String { return self._s[3260]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3260]!, self._r[3260]!, [_1]) + return formatWithArgumentRanges(self._s[3261]!, self._r[3261]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3261]! } - public var PollResults_Collapse: String { return self._s[3262]! } - public var Activity_UploadingVideo: String { return self._s[3263]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3264]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3265]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3266]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3267]! } - public var PUSH_SENDER_YOU: String { return self._s[3268]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3269]! } - public var Checkout_PayWithTouchId: String { return self._s[3270]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3271]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[3262]! } + public var PollResults_Collapse: String { return self._s[3263]! } + public var Activity_UploadingVideo: String { return self._s[3264]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3265]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3266]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3267]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3268]! } + public var PUSH_SENDER_YOU: String { return self._s[3269]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3270]! } + public var Checkout_PayWithTouchId: String { return self._s[3271]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3272]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3273]!, self._r[3273]!, [_1]) + return formatWithArgumentRanges(self._s[3274]!, self._r[3274]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[3274]! } + public var Notifications_ExceptionsNone: String { return self._s[3275]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3275]!, self._r[3275]!, [_0]) + return formatWithArgumentRanges(self._s[3276]!, self._r[3276]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3276]!, self._r[3276]!, [_1]) + return formatWithArgumentRanges(self._s[3277]!, self._r[3277]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3278]! } - public var Passport_Address_Region: String { return self._s[3281]! } - public var ChatList_DeleteChat: String { return self._s[3282]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3283]! } - public var PhotoEditor_TiltShift: String { return self._s[3284]! } - public var Settings_FAQ_URL: String { return self._s[3285]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3286]! } - public var Passport_Language_sl: String { return self._s[3287]! } - public var Settings_PrivacySettings: String { return self._s[3289]! } - public var SharedMedia_TitleLink: String { return self._s[3290]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3291]! } - public var Settings_SetProfilePhoto: String { return self._s[3292]! } - public var Channel_About_Help: String { return self._s[3293]! } - public var Contacts_PermissionsEnable: String { return self._s[3294]! } - public var Wallet_Sending_Title: String { return self._s[3295]! } - public var PeerInfo_PaneMedia: String { return self._s[3296]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3297]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3298]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3300]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3301]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3302]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3303]! } - public var OldChannels_Title: String { return self._s[3304]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3305]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3307]! } - public var Map_OpenInYandexMaps: String { return self._s[3309]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3310]! } - public var VoiceOver_MessageContextReply: String { return self._s[3311]! } - public var PhotoEditor_SaturationTool: String { return self._s[3313]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[3279]! } + public var Passport_Address_Region: String { return self._s[3282]! } + public var ChatList_DeleteChat: String { return self._s[3283]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3284]! } + public var PhotoEditor_TiltShift: String { return self._s[3285]! } + public var Settings_FAQ_URL: String { return self._s[3286]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3287]! } + public var Passport_Language_sl: String { return self._s[3288]! } + public var Settings_PrivacySettings: String { return self._s[3290]! } + public var SharedMedia_TitleLink: String { return self._s[3291]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3292]! } + public var Settings_SetProfilePhoto: String { return self._s[3293]! } + public var Channel_About_Help: String { return self._s[3294]! } + public var Contacts_PermissionsEnable: String { return self._s[3295]! } + public var Wallet_Sending_Title: String { return self._s[3296]! } + public var PeerInfo_PaneMedia: String { return self._s[3297]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3298]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3299]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3301]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3302]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3303]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3304]! } + public var OldChannels_Title: String { return self._s[3305]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3306]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3308]! } + public var Map_OpenInYandexMaps: String { return self._s[3310]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3311]! } + public var VoiceOver_MessageContextReply: String { return self._s[3312]! } + public var PhotoEditor_SaturationTool: String { return self._s[3314]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3314]!, self._r[3314]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3315]!, self._r[3315]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3315]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3316]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3317]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3316]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3317]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3318]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3318]!, self._r[3318]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3319]!, self._r[3319]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3319]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3321]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3322]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3320]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3322]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3323]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3323]!, self._r[3323]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3324]!, self._r[3324]!, [_1, _2]) } - public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3324]! } + public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3325]! } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3325]!, self._r[3325]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3326]!, self._r[3326]!, [_1, _2, _3]) } - public var WallpaperPreview_PatternTitle: String { return self._s[3326]! } - public var GroupInfo_PublicLinkAdd: String { return self._s[3327]! } - public var Passport_PassportInformation: String { return self._s[3330]! } - public var Theme_Unsupported: String { return self._s[3331]! } - public var WatchRemote_AlertTitle: String { return self._s[3332]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3333]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3335]! } + public var WallpaperPreview_PatternTitle: String { return self._s[3327]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3328]! } + public var Passport_PassportInformation: String { return self._s[3331]! } + public var Theme_Unsupported: String { return self._s[3332]! } + public var WatchRemote_AlertTitle: String { return self._s[3333]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3334]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3336]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3336]!, self._r[3336]!, [_0]) + return formatWithArgumentRanges(self._s[3337]!, self._r[3337]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3337]!, self._r[3337]!, [_1]) + return formatWithArgumentRanges(self._s[3338]!, self._r[3338]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3338]! } - public var Wallet_Navigation_Done: String { return self._s[3340]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3341]! } - public var AccessDenied_CameraDisabled: String { return self._s[3342]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3339]! } + public var Wallet_Navigation_Done: String { return self._s[3341]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3342]! } + public var AccessDenied_CameraDisabled: String { return self._s[3343]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3343]!, self._r[3343]!, [_0]) + return formatWithArgumentRanges(self._s[3344]!, self._r[3344]!, [_0]) } - public var ClearCache_Forever: String { return self._s[3344]! } - public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3345]! } - public var CreatePoll_Quiz: String { return self._s[3346]! } - public var PhotoEditor_ContrastTool: String { return self._s[3349]! } + public var ClearCache_Forever: String { return self._s[3345]! } + public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3346]! } + public var CreatePoll_Quiz: String { return self._s[3347]! } + public var PhotoEditor_ContrastTool: String { return self._s[3350]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3350]!, self._r[3350]!, [_1]) + return formatWithArgumentRanges(self._s[3351]!, self._r[3351]!, [_1]) } - public var DialogList_Draft: String { return self._s[3351]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3352]! } + public var DialogList_Draft: String { return self._s[3352]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3353]! } public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3353]!, self._r[3353]!, [_0]) + return formatWithArgumentRanges(self._s[3354]!, self._r[3354]!, [_0]) } - public var Privacy_TopPeersDelete: String { return self._s[3355]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3356]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3357]! } - public var WebSearch_RecentSectionClear: String { return self._s[3358]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3359]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3361]! } - public var PeerInfo_ButtonMore: String { return self._s[3363]! } - public var Common_Done: String { return self._s[3364]! } - public var Shortcut_SwitchAccount: String { return self._s[3365]! } - public var AuthSessions_EmptyText: String { return self._s[3366]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3367]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3368]! } - public var Tour_Title5: String { return self._s[3369]! } - public var Wallet_Settings_Title: String { return self._s[3370]! } + public var Privacy_TopPeersDelete: String { return self._s[3356]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3357]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3358]! } + public var WebSearch_RecentSectionClear: String { return self._s[3359]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3360]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3362]! } + public var PeerInfo_ButtonMore: String { return self._s[3364]! } + public var Common_Done: String { return self._s[3365]! } + public var Shortcut_SwitchAccount: String { return self._s[3366]! } + public var AuthSessions_EmptyText: String { return self._s[3367]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3368]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3369]! } + public var Tour_Title5: String { return self._s[3370]! } + public var Wallet_Settings_Title: String { return self._s[3371]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3371]!, self._r[3371]!, [_0]) + return formatWithArgumentRanges(self._s[3372]!, self._r[3372]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3372]! } - public var Conversation_LinkDialogSave: String { return self._s[3373]! } - public var GroupInfo_ActionRestrict: String { return self._s[3374]! } - public var Checkout_Title: String { return self._s[3375]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3377]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3379]! } - public var Notification_RenamedGroup: String { return self._s[3380]! } - public var PeopleNearby_Groups: String { return self._s[3381]! } - public var Checkout_PayWithFaceId: String { return self._s[3382]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3383]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3385]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3386]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3387]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3373]! } + public var Conversation_LinkDialogSave: String { return self._s[3374]! } + public var GroupInfo_ActionRestrict: String { return self._s[3375]! } + public var Checkout_Title: String { return self._s[3376]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3378]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3380]! } + public var Notification_RenamedGroup: String { return self._s[3381]! } + public var PeopleNearby_Groups: String { return self._s[3382]! } + public var Checkout_PayWithFaceId: String { return self._s[3383]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3384]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3386]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3387]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3388]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3388]!, self._r[3388]!, [_0]) + return formatWithArgumentRanges(self._s[3389]!, self._r[3389]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[3390]! } + public var Profile_AddToExisting: String { return self._s[3391]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3391]!, self._r[3391]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3392]!, self._r[3392]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3393]! } - public var Permissions_PrivacyPolicy: String { return self._s[3394]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3395]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3396]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3398]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3400]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3401]! } + public var Cache_Files: String { return self._s[3394]! } + public var Permissions_PrivacyPolicy: String { return self._s[3395]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3396]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3397]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3399]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3401]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3402]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3402]!, self._r[3402]!, [_0]) + return formatWithArgumentRanges(self._s[3403]!, self._r[3403]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3403]! } - public var VoiceOver_AttachMedia: String { return self._s[3406]! } - public var ChatList_EmptyChatFilterList: String { return self._s[3407]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3408]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3404]! } + public var VoiceOver_AttachMedia: String { return self._s[3407]! } + public var ChatList_EmptyChatFilterList: String { return self._s[3408]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3409]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3409]!, self._r[3409]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3410]!, self._r[3410]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3410]! } - public var Conversation_SetReminder_Title: String { return self._s[3411]! } - public var Passport_FieldAddressHelp: String { return self._s[3412]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3413]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3414]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3411]! } + public var Conversation_SetReminder_Title: String { return self._s[3412]! } + public var Passport_FieldAddressHelp: String { return self._s[3413]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3414]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3415]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3415]!, self._r[3415]!, [_0]) + return formatWithArgumentRanges(self._s[3416]!, self._r[3416]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3416]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3417]! } - public var Login_UnknownError: String { return self._s[3418]! } - public var Group_UpgradeNoticeText2: String { return self._s[3421]! } - public var Watch_Compose_AddContact: String { return self._s[3422]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3423]! } - public var Web_Error: String { return self._s[3424]! } - public var Gif_Search: String { return self._s[3425]! } - public var Profile_MessageLifetime1h: String { return self._s[3426]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3427]! } - public var Channel_Username_CheckingUsername: String { return self._s[3428]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3429]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3430]! } - public var Channel_AboutItem: String { return self._s[3431]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3433]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3434]! } - public var GroupInfo_SharedMedia: String { return self._s[3435]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[3417]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3418]! } + public var Login_UnknownError: String { return self._s[3419]! } + public var Group_UpgradeNoticeText2: String { return self._s[3422]! } + public var Watch_Compose_AddContact: String { return self._s[3423]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3424]! } + public var Web_Error: String { return self._s[3425]! } + public var Gif_Search: String { return self._s[3426]! } + public var Profile_MessageLifetime1h: String { return self._s[3427]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3428]! } + public var Channel_Username_CheckingUsername: String { return self._s[3429]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3430]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3431]! } + public var Channel_AboutItem: String { return self._s[3432]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3434]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3435]! } + public var GroupInfo_SharedMedia: String { return self._s[3436]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_1]) + return formatWithArgumentRanges(self._s[3437]!, self._r[3437]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3437]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3438]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3438]!, self._r[3438]!, [_1]) + return formatWithArgumentRanges(self._s[3439]!, self._r[3439]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3439]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3440]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3441]! } - public var CreatePoll_AddOption: String { return self._s[3442]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3443]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3444]! } - public var Channel_Management_AddModerator: String { return self._s[3445]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3446]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3447]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3448]! } - public var Theme_Colors_Background: String { return self._s[3449]! } - public var NotificationsSound_Hello: String { return self._s[3451]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3452]! } - public var Channel_Stickers_Placeholder: String { return self._s[3454]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3440]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3441]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3442]! } + public var CreatePoll_AddOption: String { return self._s[3443]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3444]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3445]! } + public var Channel_Management_AddModerator: String { return self._s[3446]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3447]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3448]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3449]! } + public var Theme_Colors_Background: String { return self._s[3450]! } + public var NotificationsSound_Hello: String { return self._s[3452]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3453]! } + public var Channel_Stickers_Placeholder: String { return self._s[3455]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3455]!, self._r[3455]!, [_0]) + return formatWithArgumentRanges(self._s[3456]!, self._r[3456]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3456]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3457]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3458]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3459]! } - public var AutoDownloadSettings_Channels: String { return self._s[3460]! } - public var Passport_Language_mn: String { return self._s[3461]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3464]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3465]! } - public var Passport_Language_ja: String { return self._s[3467]! } - public var Settings_About_Title: String { return self._s[3468]! } - public var Settings_NotificationsAndSounds: String { return self._s[3469]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3470]! } - public var Settings_BlockedUsers: String { return self._s[3471]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3457]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3458]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3459]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3460]! } + public var AutoDownloadSettings_Channels: String { return self._s[3461]! } + public var Passport_Language_mn: String { return self._s[3462]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[3465]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3466]! } + public var Passport_Language_ja: String { return self._s[3468]! } + public var Settings_About_Title: String { return self._s[3469]! } + public var Settings_NotificationsAndSounds: String { return self._s[3470]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3471]! } + public var Settings_BlockedUsers: String { return self._s[3472]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3472]!, self._r[3472]!, [_0]) + return formatWithArgumentRanges(self._s[3473]!, self._r[3473]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3473]! } - public var Wallet_Weekday_Today: String { return self._s[3474]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3475]! } - public var Widget_ApplicationLocked: String { return self._s[3476]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3477]! } - public var Channel_Username_Title: String { return self._s[3478]! } + public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3474]! } + public var Wallet_Weekday_Today: String { return self._s[3475]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3476]! } + public var Widget_ApplicationLocked: String { return self._s[3477]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3478]! } + public var Channel_Username_Title: String { return self._s[3479]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3479]!, self._r[3479]!, [_0]) + return formatWithArgumentRanges(self._s[3480]!, self._r[3480]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3481]! } - public var AppleWatch_Title: String { return self._s[3482]! } - public var Activity_RecordingVideoMessage: String { return self._s[3483]! } + public var AttachmentMenu_File: String { return self._s[3482]! } + public var AppleWatch_Title: String { return self._s[3483]! } + public var Activity_RecordingVideoMessage: String { return self._s[3484]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3484]!, self._r[3484]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3485]!, self._r[3485]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3485]! } - public var Weekday_Saturday: String { return self._s[3486]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3487]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3488]! } - public var Common_Next: String { return self._s[3490]! } - public var Channel_Stickers_YourStickers: String { return self._s[3492]! } - public var Message_Theme: String { return self._s[3493]! } - public var Call_AudioRouteHeadphones: String { return self._s[3494]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3496]! } - public var Watch_Contacts_NoResults: String { return self._s[3498]! } - public var PhotoEditor_TintTool: String { return self._s[3501]! } - public var LoginPassword_ResetAccount: String { return self._s[3503]! } - public var Settings_SavedMessages: String { return self._s[3504]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3505]! } - public var Bot_GenericSupportStatus: String { return self._s[3506]! } - public var StickerPack_Add: String { return self._s[3507]! } - public var Checkout_TotalAmount: String { return self._s[3508]! } - public var Your_cards_number_is_invalid: String { return self._s[3509]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3510]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3511]! } + public var Theme_Colors_Messages: String { return self._s[3486]! } + public var Weekday_Saturday: String { return self._s[3487]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3488]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3489]! } + public var Common_Next: String { return self._s[3491]! } + public var Channel_Stickers_YourStickers: String { return self._s[3493]! } + public var Message_Theme: String { return self._s[3494]! } + public var Call_AudioRouteHeadphones: String { return self._s[3495]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3497]! } + public var Watch_Contacts_NoResults: String { return self._s[3499]! } + public var PhotoEditor_TintTool: String { return self._s[3502]! } + public var LoginPassword_ResetAccount: String { return self._s[3504]! } + public var Settings_SavedMessages: String { return self._s[3505]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3506]! } + public var Bot_GenericSupportStatus: String { return self._s[3507]! } + public var StickerPack_Add: String { return self._s[3508]! } + public var Checkout_TotalAmount: String { return self._s[3509]! } + public var Your_cards_number_is_invalid: String { return self._s[3510]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3511]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3512]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3512]!, self._r[3512]!, [_0]) + return formatWithArgumentRanges(self._s[3513]!, self._r[3513]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3513]!, self._r[3513]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3514]!, self._r[3514]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3514]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3515]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3516]!, self._r[3516]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3517]!, self._r[3517]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3517]!, self._r[3517]!, [_0]) + return formatWithArgumentRanges(self._s[3518]!, self._r[3518]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3518]! } - public var StickerPack_Share: String { return self._s[3519]! } - public var Passport_DeleteAddress: String { return self._s[3520]! } - public var Settings_Passport: String { return self._s[3521]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3522]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3523]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3524]! } - public var Contacts_PermissionsText: String { return self._s[3525]! } - public var Group_Setup_HistoryVisible: String { return self._s[3526]! } - public var Wallet_Month_ShortDecember: String { return self._s[3528]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3529]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3530]! } - public var SocksProxySetup_Title: String { return self._s[3531]! } - public var Notification_Mute1h: String { return self._s[3532]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3519]! } + public var StickerPack_Share: String { return self._s[3520]! } + public var Passport_DeleteAddress: String { return self._s[3521]! } + public var Settings_Passport: String { return self._s[3522]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3523]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3524]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3525]! } + public var Contacts_PermissionsText: String { return self._s[3526]! } + public var Group_Setup_HistoryVisible: String { return self._s[3527]! } + public var Wallet_Month_ShortDecember: String { return self._s[3529]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3530]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3531]! } + public var SocksProxySetup_Title: String { return self._s[3532]! } + public var Notification_Mute1h: String { return self._s[3533]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3533]!, self._r[3533]!, [_0]) + return formatWithArgumentRanges(self._s[3534]!, self._r[3534]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3534]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3535]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3535]!, self._r[3535]!, [_1]) + return formatWithArgumentRanges(self._s[3536]!, self._r[3536]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3536]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3539]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3541]! } - public var DialogList_NoMessagesText: String { return self._s[3542]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3543]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3544]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3546]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3547]! } - public var Common_TakePhotoOrVideo: String { return self._s[3548]! } - public var Wallet_Words_Text: String { return self._s[3549]! } - public var Call_StatusBusy: String { return self._s[3550]! } - public var Conversation_PinnedMessage: String { return self._s[3551]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3552]! } - public var ChatList_EmptyChatListNewMessage: String { return self._s[3553]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3554]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3555]! } - public var Undo_ChatCleared: String { return self._s[3556]! } - public var AppleWatch_ReplyPresets: String { return self._s[3557]! } - public var Passport_DiscardMessageDescription: String { return self._s[3559]! } - public var Login_NetworkError: String { return self._s[3560]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3537]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3540]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3542]! } + public var DialogList_NoMessagesText: String { return self._s[3543]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3544]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3545]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3547]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3548]! } + public var Common_TakePhotoOrVideo: String { return self._s[3549]! } + public var Wallet_Words_Text: String { return self._s[3550]! } + public var Call_StatusBusy: String { return self._s[3551]! } + public var Conversation_PinnedMessage: String { return self._s[3552]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3553]! } + public var ChatList_EmptyChatListNewMessage: String { return self._s[3554]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3555]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3556]! } + public var Undo_ChatCleared: String { return self._s[3557]! } + public var AppleWatch_ReplyPresets: String { return self._s[3558]! } + public var Passport_DiscardMessageDescription: String { return self._s[3560]! } + public var Login_NetworkError: String { return self._s[3561]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3561]!, self._r[3561]!, [_0]) - } - public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3562]!, self._r[3562]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3563]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3565]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3566]! } + public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3563]!, self._r[3563]!, [_0]) + } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3564]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3566]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3567]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3568]!, self._r[3568]!, [_0]) + return formatWithArgumentRanges(self._s[3569]!, self._r[3569]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3569]! } - public var VoiceOver_Chat_Music: String { return self._s[3570]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3571]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3573]! } - public var ConversationMedia_Title: String { return self._s[3574]! } - public var EncryptionKey_Title: String { return self._s[3576]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3577]! } - public var Notification_Exceptions_AddException: String { return self._s[3578]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3579]! } - public var Profile_MessageLifetime1m: String { return self._s[3580]! } + public var Call_ConnectionErrorMessage: String { return self._s[3570]! } + public var VoiceOver_Chat_Music: String { return self._s[3571]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3572]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3574]! } + public var ConversationMedia_Title: String { return self._s[3575]! } + public var EncryptionKey_Title: String { return self._s[3577]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3578]! } + public var Notification_Exceptions_AddException: String { return self._s[3579]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3580]! } + public var Profile_MessageLifetime1m: String { return self._s[3581]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3581]!, self._r[3581]!, [_1]) + return formatWithArgumentRanges(self._s[3582]!, self._r[3582]!, [_1]) } - public var Month_GenMay: String { return self._s[3582]! } + public var Month_GenMay: String { return self._s[3583]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3583]!, self._r[3583]!, [_0]) + return formatWithArgumentRanges(self._s[3584]!, self._r[3584]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3584]! } - public var Wallet_Send_AddressInfo: String { return self._s[3585]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3586]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3587]! } + public var PeopleNearby_Users: String { return self._s[3585]! } + public var Wallet_Send_AddressInfo: String { return self._s[3586]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3587]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3588]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3589]!, self._r[3589]!, [_0]) + return formatWithArgumentRanges(self._s[3590]!, self._r[3590]!, [_0]) } - public var Conversation_EmptyPlaceholder: String { return self._s[3590]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3591]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3592]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3593]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3594]! } - public var Channel_JoinChannel: String { return self._s[3596]! } - public var Appearance_Animations: String { return self._s[3599]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3591]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3592]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3593]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3594]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3595]! } + public var Channel_JoinChannel: String { return self._s[3597]! } + public var Appearance_Animations: String { return self._s[3600]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3600]!, self._r[3600]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3601]!, self._r[3601]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3602]! } - public var Appearance_ShareTheme: String { return self._s[3603]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3604]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3606]! } - public var StickerPackActionInfo_RemovedTitle: String { return self._s[3607]! } - public var Passport_Address_Street: String { return self._s[3608]! } - public var Conversation_AddContact: String { return self._s[3609]! } - public var Login_PhonePlaceholder: String { return self._s[3610]! } - public var Channel_Members_InviteLink: String { return self._s[3612]! } - public var Bot_Stop: String { return self._s[3613]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3615]! } - public var Notification_PassportValueAddress: String { return self._s[3616]! } - public var Month_ShortJuly: String { return self._s[3617]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3618]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3619]! } - public var Passport_Identity_ReverseSide: String { return self._s[3620]! } - public var Watch_Stickers_Recents: String { return self._s[3623]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3625]! } - public var Map_SendThisLocation: String { return self._s[3626]! } + public var Stickers_GroupStickers: String { return self._s[3603]! } + public var Appearance_ShareTheme: String { return self._s[3604]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3605]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3607]! } + public var StickerPackActionInfo_RemovedTitle: String { return self._s[3608]! } + public var Passport_Address_Street: String { return self._s[3609]! } + public var Conversation_AddContact: String { return self._s[3610]! } + public var Login_PhonePlaceholder: String { return self._s[3611]! } + public var Channel_Members_InviteLink: String { return self._s[3613]! } + public var Bot_Stop: String { return self._s[3614]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3616]! } + public var Notification_PassportValueAddress: String { return self._s[3617]! } + public var Month_ShortJuly: String { return self._s[3618]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3619]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3620]! } + public var Passport_Identity_ReverseSide: String { return self._s[3621]! } + public var Watch_Stickers_Recents: String { return self._s[3624]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3626]! } + public var Map_SendThisLocation: String { return self._s[3627]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3627]!, self._r[3627]!, [_0]) - } - public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3628]!, self._r[3628]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[3629]! } - public var Wallet_Intro_NotNow: String { return self._s[3630]! } + public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3629]!, self._r[3629]!, [_0]) + } + public var ConvertToSupergroup_Note: String { return self._s[3630]! } + public var Wallet_Intro_NotNow: String { return self._s[3631]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3631]!, self._r[3631]!, [_0]) + return formatWithArgumentRanges(self._s[3632]!, self._r[3632]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3632]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3633]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3633]!, self._r[3633]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3634]!, self._r[3634]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3635]! } - public var Wallpaper_SearchShort: String { return self._s[3636]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3638]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3639]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3640]! } + public var Login_CallRequestState3: String { return self._s[3636]! } + public var Wallpaper_SearchShort: String { return self._s[3637]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3639]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3640]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3641]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3641]!, self._r[3641]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3642]!, self._r[3642]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3642]! } - public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3644]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3647]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3643]! } + public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3645]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3648]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3648]!, self._r[3648]!, [_0]) + return formatWithArgumentRanges(self._s[3649]!, self._r[3649]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3649]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3650]! } + public var Passport_CorrectErrors: String { return self._s[3650]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3651]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3651]!, self._r[3651]!, [_0]) + return formatWithArgumentRanges(self._s[3652]!, self._r[3652]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3652]! } - public var Channel_DiscussionGroup: String { return self._s[3653]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3654]! } + public var Map_SendMyCurrentLocation: String { return self._s[3653]! } + public var Channel_DiscussionGroup: String { return self._s[3654]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3655]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3655]!, self._r[3655]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3656]!, self._r[3656]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3656]! } - public var Permissions_NotificationsText_v0: String { return self._s[3657]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3658]! } - public var Appearance_AppIcon: String { return self._s[3659]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3660]! } - public var LoginPassword_FloodError: String { return self._s[3661]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3663]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3664]! } + public var SharedMedia_SearchNoResults: String { return self._s[3657]! } + public var Permissions_NotificationsText_v0: String { return self._s[3658]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3659]! } + public var Appearance_AppIcon: String { return self._s[3660]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3661]! } + public var LoginPassword_FloodError: String { return self._s[3662]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3664]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3665]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3665]!, self._r[3665]!, [_0]) + return formatWithArgumentRanges(self._s[3666]!, self._r[3666]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3666]! } + public var Passport_Language_bn: String { return self._s[3667]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3667]!, self._r[3667]!, [_0]) + return formatWithArgumentRanges(self._s[3668]!, self._r[3668]!, [_0]) } - public var ChatList_Context_Pin: String { return self._s[3668]! } + public var ChatList_Context_Pin: String { return self._s[3669]! } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3669]!, self._r[3669]!, [_0]) - } - public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3670]!, self._r[3670]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3671]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3675]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3677]! } - public var Wallet_Month_GenDecember: String { return self._s[3678]! } - public var Contacts_PermissionsAllow: String { return self._s[3679]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3680]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3681]! } - public var WallpaperPreview_Pattern: String { return self._s[3682]! } - public var Paint_Duplicate: String { return self._s[3683]! } - public var Passport_Address_Country: String { return self._s[3684]! } - public var Notification_RenamedChannel: String { return self._s[3686]! } - public var ChatList_Context_Unmute: String { return self._s[3687]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3688]! } - public var Group_MessagePhotoUpdated: String { return self._s[3689]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3690]! } - public var Conversation_ContextMenuBan: String { return self._s[3691]! } - public var TwoStepAuth_EmailSent: String { return self._s[3692]! } - public var MessagePoll_NoVotes: String { return self._s[3693]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3694]! } - public var Passport_Language_is: String { return self._s[3696]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3698]! } - public var Tour_Text5: String { return self._s[3699]! } + public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3671]!, self._r[3671]!, [_0]) + } + public var Wallet_Navigation_Close: String { return self._s[3672]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3676]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3678]! } + public var Wallet_Month_GenDecember: String { return self._s[3679]! } + public var Contacts_PermissionsAllow: String { return self._s[3680]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3681]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3682]! } + public var WallpaperPreview_Pattern: String { return self._s[3683]! } + public var Paint_Duplicate: String { return self._s[3684]! } + public var Passport_Address_Country: String { return self._s[3685]! } + public var Notification_RenamedChannel: String { return self._s[3687]! } + public var ChatList_Context_Unmute: String { return self._s[3688]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3689]! } + public var Group_MessagePhotoUpdated: String { return self._s[3690]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3691]! } + public var Conversation_ContextMenuBan: String { return self._s[3692]! } + public var TwoStepAuth_EmailSent: String { return self._s[3693]! } + public var MessagePoll_NoVotes: String { return self._s[3694]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3695]! } + public var Passport_Language_is: String { return self._s[3697]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3699]! } + public var Tour_Text5: String { return self._s[3700]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3702]!, self._r[3702]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3703]!, self._r[3703]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3703]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3704]! } + public var Undo_SecretChatDeleted: String { return self._s[3704]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3705]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3705]!, self._r[3705]!, [_0]) + return formatWithArgumentRanges(self._s[3706]!, self._r[3706]!, [_0]) } - public var Forward_ErrorDisabledForChat: String { return self._s[3706]! } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3707]! } - public var Paint_Edit: String { return self._s[3709]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3711]! } - public var Undo_DeletedGroup: String { return self._s[3713]! } - public var LoginPassword_ForgotPassword: String { return self._s[3714]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3715]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3716]! } + public var Forward_ErrorDisabledForChat: String { return self._s[3707]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3708]! } + public var Paint_Edit: String { return self._s[3710]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3712]! } + public var Undo_DeletedGroup: String { return self._s[3714]! } + public var LoginPassword_ForgotPassword: String { return self._s[3715]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3716]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3717]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3717]!, self._r[3717]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3718]!, self._r[3718]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3718]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3719]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3720]! } - public var Passport_Language_uz: String { return self._s[3721]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3722]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3723]! } - public var Map_StopLiveLocation: String { return self._s[3725]! } - public var VoiceOver_MessageContextSend: String { return self._s[3727]! } - public var PasscodeSettings_Help: String { return self._s[3728]! } - public var NotificationsSound_Input: String { return self._s[3729]! } - public var Share_Title: String { return self._s[3732]! } - public var LogoutOptions_Title: String { return self._s[3733]! } - public var Wallet_Send_AddressText: String { return self._s[3734]! } - public var Login_TermsOfServiceAgree: String { return self._s[3735]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3736]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3737]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3738]! } - public var EnterPasscode_EnterTitle: String { return self._s[3739]! } + public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3719]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3720]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3721]! } + public var Passport_Language_uz: String { return self._s[3722]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3723]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3724]! } + public var Map_StopLiveLocation: String { return self._s[3726]! } + public var VoiceOver_MessageContextSend: String { return self._s[3728]! } + public var PasscodeSettings_Help: String { return self._s[3729]! } + public var NotificationsSound_Input: String { return self._s[3730]! } + public var Share_Title: String { return self._s[3733]! } + public var LogoutOptions_Title: String { return self._s[3734]! } + public var Wallet_Send_AddressText: String { return self._s[3735]! } + public var Login_TermsOfServiceAgree: String { return self._s[3736]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3737]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3738]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3739]! } + public var EnterPasscode_EnterTitle: String { return self._s[3740]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3740]!, self._r[3740]!, [_0]) + return formatWithArgumentRanges(self._s[3741]!, self._r[3741]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3741]! } - public var Conversation_AddToContacts: String { return self._s[3742]! } + public var Settings_CopyPhoneNumber: String { return self._s[3742]! } + public var Conversation_AddToContacts: String { return self._s[3743]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3743]!, self._r[3743]!, [_0]) + return formatWithArgumentRanges(self._s[3744]!, self._r[3744]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3744]! } + public var NotificationsSound_Keys: String { return self._s[3745]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3745]!, self._r[3745]!, [_0]) + return formatWithArgumentRanges(self._s[3746]!, self._r[3746]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[3746]! } - public var Message_Video: String { return self._s[3747]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3748]! } + public var Notification_MessageLifetime1w: String { return self._s[3747]! } + public var Message_Video: String { return self._s[3748]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3749]! } public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3749]!, self._r[3749]!, [_1]) + return formatWithArgumentRanges(self._s[3750]!, self._r[3750]!, [_1]) } - public var Wallet_Receive_AmountInfo: String { return self._s[3752]! } - public var Stats_Overview: String { return self._s[3753]! } + public var Wallet_Receive_AmountInfo: String { return self._s[3753]! } + public var Stats_Overview: String { return self._s[3754]! } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3754]!, self._r[3754]!, [_0]) - } - public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3755]!, self._r[3755]!, [_0]) } - public var Passport_Language_mk: String { return self._s[3756]! } - public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3757]!, self._r[3757]!, [_1, _2, _3]) + public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3756]!, self._r[3756]!, [_0]) } - public var CreatePoll_CancelConfirmation: String { return self._s[3758]! } - public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3759]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3761]! } - public var PrivacyPolicy_Decline: String { return self._s[3762]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3763]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3764]! } - public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3765]! } - public var Permissions_SiriAllow_v0: String { return self._s[3767]! } - public var Wallet_Month_ShortAugust: String { return self._s[3768]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3769]! } + public var Passport_Language_mk: String { return self._s[3757]! } + public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3758]!, self._r[3758]!, [_1, _2, _3]) + } + public var CreatePoll_CancelConfirmation: String { return self._s[3759]! } + public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3760]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3762]! } + public var PrivacyPolicy_Decline: String { return self._s[3763]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3764]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3765]! } + public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3766]! } + public var Permissions_SiriAllow_v0: String { return self._s[3768]! } + public var Wallet_Month_ShortAugust: String { return self._s[3769]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3770]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3770]!, self._r[3770]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3771]!, self._r[3771]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3771]!, self._r[3771]!, [_0]) + return formatWithArgumentRanges(self._s[3772]!, self._r[3772]!, [_0]) } - public var Paint_Regular: String { return self._s[3772]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3773]! } - public var SocksProxySetup_ShareLink: String { return self._s[3774]! } - public var Wallet_Qr_Title: String { return self._s[3775]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3776]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3778]! } - public var Wallet_Settings_Configuration: String { return self._s[3779]! } - public var GroupInfo_InviteByLink: String { return self._s[3780]! } - public var MessageTimer_Custom: String { return self._s[3781]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3782]! } - public var Conversation_StopQuizConfirmationTitle: String { return self._s[3783]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3785]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3786]! } - public var VoiceOver_Chat_Selected: String { return self._s[3787]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3788]! } - public var Channel_Username_InvalidTaken: String { return self._s[3789]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3790]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3791]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[3792]! } - public var Settings_ChatBackground: String { return self._s[3793]! } - public var Channel_Subscribers_Title: String { return self._s[3794]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3795]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3796]! } - public var Watch_ConnectionDescription: String { return self._s[3797]! } - public var OldChannels_NoticeText: String { return self._s[3800]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3801]! } - public var IntentsSettings_SuggestBy: String { return self._s[3803]! } - public var Theme_ThemeChangedText: String { return self._s[3804]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3805]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3806]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[3807]! } - public var EditProfile_Title: String { return self._s[3808]! } - public var NotificationsSound_Bamboo: String { return self._s[3810]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3812]! } - public var Login_SmsRequestState2: String { return self._s[3813]! } - public var Passport_Language_ar: String { return self._s[3814]! } + public var Paint_Regular: String { return self._s[3773]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3774]! } + public var SocksProxySetup_ShareLink: String { return self._s[3775]! } + public var Wallet_Qr_Title: String { return self._s[3776]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3777]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3779]! } + public var Wallet_Settings_Configuration: String { return self._s[3780]! } + public var GroupInfo_InviteByLink: String { return self._s[3781]! } + public var MessageTimer_Custom: String { return self._s[3782]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3783]! } + public var Conversation_StopQuizConfirmationTitle: String { return self._s[3784]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3786]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3787]! } + public var VoiceOver_Chat_Selected: String { return self._s[3788]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3789]! } + public var Channel_Username_InvalidTaken: String { return self._s[3790]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3791]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3792]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[3793]! } + public var Settings_ChatBackground: String { return self._s[3794]! } + public var Channel_Subscribers_Title: String { return self._s[3795]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3796]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3797]! } + public var Watch_ConnectionDescription: String { return self._s[3798]! } + public var OldChannels_NoticeText: String { return self._s[3801]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3802]! } + public var IntentsSettings_SuggestBy: String { return self._s[3804]! } + public var Theme_ThemeChangedText: String { return self._s[3805]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3806]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3807]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[3808]! } + public var EditProfile_Title: String { return self._s[3809]! } + public var NotificationsSound_Bamboo: String { return self._s[3811]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3813]! } + public var Login_SmsRequestState2: String { return self._s[3814]! } + public var Passport_Language_ar: String { return self._s[3815]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3815]!, self._r[3815]!, [_0]) + return formatWithArgumentRanges(self._s[3816]!, self._r[3816]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3816]! } - public var Wallet_Created_Text: String { return self._s[3817]! } - public var Conversation_MessageDialogEdit: String { return self._s[3819]! } - public var Wallet_Created_Proceed: String { return self._s[3820]! } - public var Wallet_Words_Done: String { return self._s[3821]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3822]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3817]! } + public var Wallet_Created_Text: String { return self._s[3818]! } + public var Conversation_MessageDialogEdit: String { return self._s[3820]! } + public var Wallet_Created_Proceed: String { return self._s[3821]! } + public var Wallet_Words_Done: String { return self._s[3822]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3823]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3823]!, self._r[3823]!, [_1]) + return formatWithArgumentRanges(self._s[3824]!, self._r[3824]!, [_1]) } - public var Common_Close: String { return self._s[3824]! } - public var GroupInfo_PublicLink: String { return self._s[3825]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3826]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3827]! } + public var Common_Close: String { return self._s[3825]! } + public var GroupInfo_PublicLink: String { return self._s[3826]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3827]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3828]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3831]!, self._r[3831]!, [_0]) + return formatWithArgumentRanges(self._s[3832]!, self._r[3832]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3832]! } + public var UserInfo_About_Placeholder: String { return self._s[3833]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3833]!, self._r[3833]!, [_0]) + return formatWithArgumentRanges(self._s[3834]!, self._r[3834]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3834]! } - public var Channel_Info_Banned: String { return self._s[3836]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[3835]! } + public var Channel_Info_Banned: String { return self._s[3837]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3837]!, self._r[3837]!, [_0]) + return formatWithArgumentRanges(self._s[3838]!, self._r[3838]!, [_0]) } - public var Appearance_Other: String { return self._s[3838]! } - public var Passport_Language_my: String { return self._s[3839]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3840]! } + public var Appearance_Other: String { return self._s[3839]! } + public var Passport_Language_my: String { return self._s[3840]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3841]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3841]!, self._r[3841]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3842]!, self._r[3842]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3842]! } - public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3843]! } - public var Preview_CopyAddress: String { return self._s[3844]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3843]! } + public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3844]! } + public var Preview_CopyAddress: String { return self._s[3845]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3845]!, self._r[3845]!, [_0]) + return formatWithArgumentRanges(self._s[3846]!, self._r[3846]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3846]! } - public var UserInfo_BotSettings: String { return self._s[3847]! } - public var LiveLocation_MenuStopAll: String { return self._s[3849]! } - public var Passport_PasswordCreate: String { return self._s[3850]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3851]! } - public var Message_PinnedLocationMessage: String { return self._s[3852]! } - public var Map_Satellite: String { return self._s[3853]! } - public var Watch_Message_Unsupported: String { return self._s[3854]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3855]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3856]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3847]! } + public var UserInfo_BotSettings: String { return self._s[3848]! } + public var LiveLocation_MenuStopAll: String { return self._s[3850]! } + public var Passport_PasswordCreate: String { return self._s[3851]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3852]! } + public var Message_PinnedLocationMessage: String { return self._s[3853]! } + public var Map_Satellite: String { return self._s[3854]! } + public var Watch_Message_Unsupported: String { return self._s[3855]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3856]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3857]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3857]!, self._r[3857]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3858]!, self._r[3858]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3858]!, self._r[3858]!, [_0]) + return formatWithArgumentRanges(self._s[3859]!, self._r[3859]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[3859]! } + public var Wallet_WordImport_Continue: String { return self._s[3860]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3860]!, self._r[3860]!, [_0]) + return formatWithArgumentRanges(self._s[3861]!, self._r[3861]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3861]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3862]! } - public var NotificationsSound_None: String { return self._s[3863]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3864]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3866]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3867]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[3862]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3863]! } + public var NotificationsSound_None: String { return self._s[3864]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3865]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3867]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3868]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3868]!, self._r[3868]!, [_1]) + return formatWithArgumentRanges(self._s[3869]!, self._r[3869]!, [_1]) } - public var Cache_Indexing: String { return self._s[3869]! } - public var DialogList_RecentTitlePeople: String { return self._s[3871]! } - public var DialogList_EncryptionRejected: String { return self._s[3872]! } - public var GroupInfo_Administrators: String { return self._s[3873]! } - public var Passport_ScanPassportHelp: String { return self._s[3874]! } - public var Application_Name: String { return self._s[3875]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3876]! } - public var PeopleNearby_MakeVisible: String { return self._s[3878]! } - public var Appearance_ThemeCarouselDay: String { return self._s[3879]! } - public var Stats_GrowthTitle: String { return self._s[3880]! } - public var Passport_Identity_TranslationHelp: String { return self._s[3881]! } + public var Cache_Indexing: String { return self._s[3870]! } + public var DialogList_RecentTitlePeople: String { return self._s[3872]! } + public var DialogList_EncryptionRejected: String { return self._s[3873]! } + public var GroupInfo_Administrators: String { return self._s[3874]! } + public var Passport_ScanPassportHelp: String { return self._s[3875]! } + public var Application_Name: String { return self._s[3876]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3877]! } + public var PeopleNearby_MakeVisible: String { return self._s[3879]! } + public var Appearance_ThemeCarouselDay: String { return self._s[3880]! } + public var Stats_GrowthTitle: String { return self._s[3881]! } + public var Passport_Identity_TranslationHelp: String { return self._s[3882]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3882]!, self._r[3882]!, [_0]) - } - public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3883]!, self._r[3883]!, [_0]) } - public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3884]!, self._r[3884]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3885]! } - public var Privacy_ChatsTitle: String { return self._s[3886]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[3887]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3888]! } - public var Watch_Suggestion_HoldOn: String { return self._s[3889]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[3890]! } - public var WebBrowser_Title: String { return self._s[3891]! } - public var Group_LinkedChannel: String { return self._s[3892]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3893]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[3894]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3895]! } - public var Appearance_TextSize_UseSystem: String { return self._s[3896]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[3897]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[3899]! } - public var Channel_Setup_TypePublic: String { return self._s[3901]! } + public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3885]!, self._r[3885]!, [_0]) + } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3886]! } + public var Privacy_ChatsTitle: String { return self._s[3887]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[3888]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3889]! } + public var Watch_Suggestion_HoldOn: String { return self._s[3890]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[3891]! } + public var WebBrowser_Title: String { return self._s[3892]! } + public var Group_LinkedChannel: String { return self._s[3893]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3894]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[3895]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3896]! } + public var Appearance_TextSize_UseSystem: String { return self._s[3897]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[3898]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[3900]! } + public var Channel_Setup_TypePublic: String { return self._s[3902]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3902]!, self._r[3902]!, [_0]) + return formatWithArgumentRanges(self._s[3903]!, self._r[3903]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[3904]! } - public var MessagePoll_ViewResults: String { return self._s[3905]! } - public var Map_OpenInMaps: String { return self._s[3907]! } + public var Channel_TypeSetup_Title: String { return self._s[3905]! } + public var MessagePoll_ViewResults: String { return self._s[3906]! } + public var Map_OpenInMaps: String { return self._s[3908]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3908]!, self._r[3908]!, [_1]) + return formatWithArgumentRanges(self._s[3909]!, self._r[3909]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[3910]! } + public var NotificationsSound_Tremolo: String { return self._s[3911]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3911]!, self._r[3911]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3912]!, self._r[3912]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[3912]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3913]! } - public var Passport_PasswordHelp: String { return self._s[3914]! } - public var Login_CodeExpiredError: String { return self._s[3915]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3916]! } - public var Conversation_TitleUnmute: String { return self._s[3917]! } - public var Passport_Identity_ScansHelp: String { return self._s[3918]! } - public var Passport_Language_lo: String { return self._s[3919]! } - public var Camera_FlashAuto: String { return self._s[3920]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[3921]! } - public var Common_Cancel: String { return self._s[3922]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[3923]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3924]! } - public var Appearance_TintAllColors: String { return self._s[3925]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[3913]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3914]! } + public var Passport_PasswordHelp: String { return self._s[3915]! } + public var Login_CodeExpiredError: String { return self._s[3916]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3917]! } + public var Conversation_TitleUnmute: String { return self._s[3918]! } + public var Passport_Identity_ScansHelp: String { return self._s[3919]! } + public var Passport_Language_lo: String { return self._s[3920]! } + public var Camera_FlashAuto: String { return self._s[3921]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[3922]! } + public var Common_Cancel: String { return self._s[3923]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[3924]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3925]! } + public var Appearance_TintAllColors: String { return self._s[3926]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3926]!, self._r[3926]!, [_1]) + return formatWithArgumentRanges(self._s[3927]!, self._r[3927]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[3927]! } - public var ChatSettings_Title: String { return self._s[3929]! } - public var Passport_PasswordReset: String { return self._s[3930]! } - public var SocksProxySetup_TypeNone: String { return self._s[3931]! } - public var EditTheme_Title: String { return self._s[3934]! } - public var PhoneNumberHelp_Help: String { return self._s[3935]! } - public var Checkout_EnterPassword: String { return self._s[3936]! } - public var Activity_UploadingDocument: String { return self._s[3938]! } - public var Share_AuthTitle: String { return self._s[3939]! } - public var State_Connecting: String { return self._s[3940]! } - public var Profile_MessageLifetime1w: String { return self._s[3941]! } - public var Conversation_ContextMenuReport: String { return self._s[3942]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3943]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[3944]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[3928]! } + public var ChatSettings_Title: String { return self._s[3930]! } + public var Passport_PasswordReset: String { return self._s[3931]! } + public var SocksProxySetup_TypeNone: String { return self._s[3932]! } + public var EditTheme_Title: String { return self._s[3935]! } + public var PhoneNumberHelp_Help: String { return self._s[3936]! } + public var Checkout_EnterPassword: String { return self._s[3937]! } + public var Activity_UploadingDocument: String { return self._s[3939]! } + public var Share_AuthTitle: String { return self._s[3940]! } + public var State_Connecting: String { return self._s[3941]! } + public var Profile_MessageLifetime1w: String { return self._s[3942]! } + public var Conversation_ContextMenuReport: String { return self._s[3943]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3944]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[3945]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3945]!, self._r[3945]!, [_0]) + return formatWithArgumentRanges(self._s[3946]!, self._r[3946]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[3946]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[3947]! } - public var PeerInfo_PaneAudio: String { return self._s[3948]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3950]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3951]! } - public var PhotoEditor_Set: String { return self._s[3952]! } - public var EmptyGroupInfo_Title: String { return self._s[3953]! } - public var Login_PadPhoneHelp: String { return self._s[3954]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3956]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3958]! } - public var NotificationsSound_Complete: String { return self._s[3959]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3960]! } - public var Group_Info_AdminLog: String { return self._s[3961]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3962]! } + public var AuthSessions_Terminate: String { return self._s[3947]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[3948]! } + public var PeerInfo_PaneAudio: String { return self._s[3949]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3951]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3952]! } + public var PhotoEditor_Set: String { return self._s[3953]! } + public var EmptyGroupInfo_Title: String { return self._s[3954]! } + public var Login_PadPhoneHelp: String { return self._s[3955]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3957]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3959]! } + public var NotificationsSound_Complete: String { return self._s[3960]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3961]! } + public var Group_Info_AdminLog: String { return self._s[3962]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3963]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3963]!, self._r[3963]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3964]!, self._r[3964]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3964]! } - public var Group_Location_CreateInThisPlace: String { return self._s[3966]! } - public var Conversation_Admin: String { return self._s[3967]! } - public var Conversation_GifTooltip: String { return self._s[3968]! } - public var Passport_NotLoggedInMessage: String { return self._s[3969]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3965]! } + public var Group_Location_CreateInThisPlace: String { return self._s[3967]! } + public var Conversation_Admin: String { return self._s[3968]! } + public var Conversation_GifTooltip: String { return self._s[3969]! } + public var Passport_NotLoggedInMessage: String { return self._s[3970]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3971]!, self._r[3971]!, [_0]) + return formatWithArgumentRanges(self._s[3972]!, self._r[3972]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[3972]! } - public var SharedMedia_EmptyTitle: String { return self._s[3974]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3976]! } - public var Username_Help: String { return self._s[3977]! } - public var DialogList_LanguageTooltip: String { return self._s[3979]! } - public var Map_LoadError: String { return self._s[3980]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3981]! } - public var Channel_AdminLog_AddMembers: String { return self._s[3982]! } - public var ArchivedChats_IntroTitle2: String { return self._s[3983]! } - public var Notification_Exceptions_NewException: String { return self._s[3984]! } - public var TwoStepAuth_EmailTitle: String { return self._s[3985]! } - public var WatchRemote_AlertText: String { return self._s[3986]! } + public var Profile_MessageLifetimeForever: String { return self._s[3973]! } + public var SharedMedia_EmptyTitle: String { return self._s[3975]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3977]! } + public var Username_Help: String { return self._s[3978]! } + public var DialogList_LanguageTooltip: String { return self._s[3980]! } + public var Map_LoadError: String { return self._s[3981]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3982]! } + public var Channel_AdminLog_AddMembers: String { return self._s[3983]! } + public var ArchivedChats_IntroTitle2: String { return self._s[3984]! } + public var Notification_Exceptions_NewException: String { return self._s[3985]! } + public var TwoStepAuth_EmailTitle: String { return self._s[3986]! } + public var WatchRemote_AlertText: String { return self._s[3987]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3987]!, self._r[3987]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3988]!, self._r[3988]!, [_1, _2, _3]) } - public var ChatSettings_ConnectionType_Title: String { return self._s[3991]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[3992]! } public func PUSH_PINNED_QUIZ(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3992]!, self._r[3992]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3993]!, self._r[3993]!, [_1, _2]) } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3993]!, self._r[3993]!, [_0]) + return formatWithArgumentRanges(self._s[3994]!, self._r[3994]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3994]! } - public var WebBrowser_DefaultBrowser: String { return self._s[3995]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[3996]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3995]! } + public var WebBrowser_DefaultBrowser: String { return self._s[3996]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[3997]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3997]!, self._r[3997]!, [_0]) + return formatWithArgumentRanges(self._s[3998]!, self._r[3998]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3998]!, self._r[3998]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3999]!, self._r[3999]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[3999]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4000]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[4002]! } - public var Wallet_Created_ExportErrorText: String { return self._s[4003]! } - public var ChatList_UndoArchiveText1: String { return self._s[4004]! } - public var AccessDenied_VideoMicrophone: String { return self._s[4005]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4006]! } - public var Cache_ClearNone: String { return self._s[4007]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[4008]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[4009]! } + public var Group_AdminLog_EmptyText: String { return self._s[4000]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4001]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[4003]! } + public var Wallet_Created_ExportErrorText: String { return self._s[4004]! } + public var ChatList_UndoArchiveText1: String { return self._s[4005]! } + public var AccessDenied_VideoMicrophone: String { return self._s[4006]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4007]! } + public var Cache_ClearNone: String { return self._s[4008]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[4009]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[4010]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4010]!, self._r[4010]!, [_0]) + return formatWithArgumentRanges(self._s[4011]!, self._r[4011]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[4011]! } + public var Passport_Identity_Country: String { return self._s[4012]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4012]!, self._r[4012]!, [_0]) - } - public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4013]!, self._r[4013]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[4014]! } - public var AccessDenied_Settings: String { return self._s[4015]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4016]! } - public var Month_ShortMay: String { return self._s[4017]! } - public var Compose_NewGroup: String { return self._s[4019]! } - public var Group_Setup_TypePrivate: String { return self._s[4021]! } - public var Login_PadPhoneHelpTitle: String { return self._s[4023]! } - public var Appearance_ThemeDayClassic: String { return self._s[4024]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4025]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[4026]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4027]! } - public var Conversation_typing: String { return self._s[4029]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[4030]! } - public var Paint_Masks: String { return self._s[4031]! } - public var Contacts_DeselectAll: String { return self._s[4032]! } - public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4033]!, self._r[4033]!, [_0]) + public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4014]!, self._r[4014]!, [_0]) } - public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4034]! } - public var Username_InvalidTaken: String { return self._s[4035]! } - public var Call_StatusNoAnswer: String { return self._s[4036]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[4037]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4038]! } - public var Passport_Identity_Selfie: String { return self._s[4039]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[4040]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4041]! } - public var Conversation_ClearSecretHistory: String { return self._s[4042]! } - public var PeopleNearby_Description: String { return self._s[4044]! } - public var NetworkUsageSettings_Title: String { return self._s[4045]! } - public var Your_cards_security_code_is_invalid: String { return self._s[4047]! } - public var Stats_EnabledNotifications: String { return self._s[4048]! } + public var Exceptions_AddToExceptions: String { return self._s[4015]! } + public var AccessDenied_Settings: String { return self._s[4016]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4017]! } + public var Month_ShortMay: String { return self._s[4018]! } + public var Compose_NewGroup: String { return self._s[4020]! } + public var Group_Setup_TypePrivate: String { return self._s[4022]! } + public var Login_PadPhoneHelpTitle: String { return self._s[4024]! } + public var Appearance_ThemeDayClassic: String { return self._s[4025]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4026]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[4027]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4028]! } + public var Conversation_typing: String { return self._s[4030]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[4031]! } + public var Paint_Masks: String { return self._s[4032]! } + public var Contacts_DeselectAll: String { return self._s[4033]! } + public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4034]!, self._r[4034]!, [_0]) + } + public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4035]! } + public var Username_InvalidTaken: String { return self._s[4036]! } + public var Call_StatusNoAnswer: String { return self._s[4037]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[4038]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4039]! } + public var Passport_Identity_Selfie: String { return self._s[4040]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[4041]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4042]! } + public var Conversation_ClearSecretHistory: String { return self._s[4043]! } + public var PeopleNearby_Description: String { return self._s[4045]! } + public var NetworkUsageSettings_Title: String { return self._s[4046]! } + public var Your_cards_security_code_is_invalid: String { return self._s[4048]! } + public var Stats_EnabledNotifications: String { return self._s[4049]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4050]!, self._r[4050]!, [_0]) + return formatWithArgumentRanges(self._s[4051]!, self._r[4051]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4051]!, self._r[4051]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4052]!, self._r[4052]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[4053]! } - public var VoiceOver_Navigation_Search: String { return self._s[4054]! } - public var Map_LiveLocationTitle: String { return self._s[4055]! } - public var Login_InfoAvatarAdd: String { return self._s[4056]! } - public var Passport_Identity_FilesView: String { return self._s[4057]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[4058]! } - public var Privacy_Calls_NeverAllow: String { return self._s[4059]! } - public var VoiceOver_Chat_File: String { return self._s[4060]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4061]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[4054]! } + public var VoiceOver_Navigation_Search: String { return self._s[4055]! } + public var Map_LiveLocationTitle: String { return self._s[4056]! } + public var Login_InfoAvatarAdd: String { return self._s[4057]! } + public var Passport_Identity_FilesView: String { return self._s[4058]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[4059]! } + public var Privacy_Calls_NeverAllow: String { return self._s[4060]! } + public var VoiceOver_Chat_File: String { return self._s[4061]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4062]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4062]!, self._r[4062]!, [_0]) + return formatWithArgumentRanges(self._s[4063]!, self._r[4063]!, [_0]) } - public var ChatList_EmptyChatList: String { return self._s[4063]! } - public var ContactInfo_PhoneNumberHidden: String { return self._s[4064]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[4065]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4066]! } + public var ChatList_EmptyChatList: String { return self._s[4064]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[4065]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[4066]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4067]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4067]!, self._r[4067]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4068]!, self._r[4068]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4068]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[4069]! } - public var Tour_Title2: String { return self._s[4070]! } - public var Wallet_Sent_ViewWallet: String { return self._s[4071]! } - public var Conversation_FileOpenIn: String { return self._s[4072]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4073]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4074]! } - public var Wallpaper_Set: String { return self._s[4075]! } - public var Passport_Identity_Translations: String { return self._s[4077]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4069]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[4070]! } + public var Tour_Title2: String { return self._s[4071]! } + public var Wallet_Sent_ViewWallet: String { return self._s[4072]! } + public var Conversation_FileOpenIn: String { return self._s[4073]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4074]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4075]! } + public var Wallpaper_Set: String { return self._s[4076]! } + public var Passport_Identity_Translations: String { return self._s[4078]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4078]!, self._r[4078]!, [_0]) + return formatWithArgumentRanges(self._s[4079]!, self._r[4079]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[4079]! } + public var Channel_LeaveChannel: String { return self._s[4080]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4080]!, self._r[4080]!, [_1]) + return formatWithArgumentRanges(self._s[4081]!, self._r[4081]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4082]! } - public var PhotoEditor_HighlightsTint: String { return self._s[4083]! } - public var MessagePoll_LabelPoll: String { return self._s[4084]! } - public var Passport_Email_Delete: String { return self._s[4085]! } - public var Conversation_Mute: String { return self._s[4087]! } - public var Channel_AddBotAsAdmin: String { return self._s[4088]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[4090]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4091]! } - public var ChatSettings_IntentsSettings: String { return self._s[4093]! } - public var Channel_Management_LabelOwner: String { return self._s[4094]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4083]! } + public var PhotoEditor_HighlightsTint: String { return self._s[4084]! } + public var MessagePoll_LabelPoll: String { return self._s[4085]! } + public var Passport_Email_Delete: String { return self._s[4086]! } + public var Conversation_Mute: String { return self._s[4088]! } + public var Channel_AddBotAsAdmin: String { return self._s[4089]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[4091]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4092]! } + public var ChatSettings_IntentsSettings: String { return self._s[4094]! } + public var Channel_Management_LabelOwner: String { return self._s[4095]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4095]!, self._r[4095]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4096]!, self._r[4096]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[4096]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[4097]! } - public var Common_No: String { return self._s[4098]! } - public var Weekday_Sunday: String { return self._s[4099]! } - public var Notification_Reply: String { return self._s[4100]! } - public var Conversation_ViewMessage: String { return self._s[4101]! } + public var Calls_CallTabDescription: String { return self._s[4097]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[4098]! } + public var Common_No: String { return self._s[4099]! } + public var Weekday_Sunday: String { return self._s[4100]! } + public var Notification_Reply: String { return self._s[4101]! } + public var Conversation_ViewMessage: String { return self._s[4102]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4102]!, self._r[4102]!, [_0]) - } - public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4103]!, self._r[4103]!, [_0]) } + public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4104]!, self._r[4104]!, [_0]) + } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4104]!, self._r[4104]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4105]!, self._r[4105]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4105]! } - public var Wallet_Send_Title: String { return self._s[4106]! } - public var Message_PinnedDocumentMessage: String { return self._s[4107]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[4108]! } - public var DialogList_TabTitle: String { return self._s[4110]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[4111]! } - public var Passport_FieldEmail: String { return self._s[4112]! } - public var Conversation_UnpinMessageAlert: String { return self._s[4113]! } - public var Passport_Address_TypeBankStatement: String { return self._s[4114]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[4115]! } - public var Passport_Identity_ExpiryDate: String { return self._s[4116]! } - public var Privacy_Calls_P2P: String { return self._s[4117]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4106]! } + public var Wallet_Send_Title: String { return self._s[4107]! } + public var Message_PinnedDocumentMessage: String { return self._s[4108]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[4109]! } + public var DialogList_TabTitle: String { return self._s[4111]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[4112]! } + public var Passport_FieldEmail: String { return self._s[4113]! } + public var Conversation_UnpinMessageAlert: String { return self._s[4114]! } + public var Passport_Address_TypeBankStatement: String { return self._s[4115]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[4116]! } + public var Passport_Identity_ExpiryDate: String { return self._s[4117]! } + public var Privacy_Calls_P2P: String { return self._s[4118]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4119]!, self._r[4119]!, [_0]) + return formatWithArgumentRanges(self._s[4120]!, self._r[4120]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[4120]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[4121]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4121]!, self._r[4121]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4122]!, self._r[4122]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[4122]! } - public var EnterPasscode_ChangeTitle: String { return self._s[4123]! } - public var TwoFactorSetup_Email_Title: String { return self._s[4124]! } - public var Passport_InfoText: String { return self._s[4125]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4126]! } + public var Stickers_ClearRecent: String { return self._s[4123]! } + public var EnterPasscode_ChangeTitle: String { return self._s[4124]! } + public var TwoFactorSetup_Email_Title: String { return self._s[4125]! } + public var Passport_InfoText: String { return self._s[4126]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4127]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4127]!, self._r[4127]!, [_0]) + return formatWithArgumentRanges(self._s[4128]!, self._r[4128]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4128]!, self._r[4128]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4129]!, self._r[4129]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4129]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[4130]! } - public var VoiceOver_Navigation_Compose: String { return self._s[4131]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[4132]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[4134]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4135]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4130]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[4131]! } + public var VoiceOver_Navigation_Compose: String { return self._s[4132]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[4133]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[4135]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4136]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4136]!, self._r[4136]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4137]!, self._r[4137]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4139]! } - public var ChatSettings_OpenLinksIn: String { return self._s[4140]! } - public var Map_HomeAndWorkTitle: String { return self._s[4141]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4140]! } + public var ChatSettings_OpenLinksIn: String { return self._s[4141]! } + public var Map_HomeAndWorkTitle: String { return self._s[4142]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4143]!, self._r[4143]!, [_0]) + return formatWithArgumentRanges(self._s[4144]!, self._r[4144]!, [_0]) } - public var DialogList_Unread: String { return self._s[4144]! } + public var DialogList_Unread: String { return self._s[4145]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4145]!, self._r[4145]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4146]!, self._r[4146]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[4146]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4147]! } + public var User_DeletedAccount: String { return self._s[4147]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4148]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4148]!, self._r[4148]!, [_0]) + return formatWithArgumentRanges(self._s[4149]!, self._r[4149]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[4149]! } - public var SharedMedia_CategoryMedia: String { return self._s[4150]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4151]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4152]! } - public var Watch_ChatList_Compose: String { return self._s[4153]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4154]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[4155]! } - public var Watch_Microphone_Access: String { return self._s[4156]! } - public var Group_Setup_HistoryHeader: String { return self._s[4157]! } - public var Map_SetThisLocation: String { return self._s[4158]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4159]! } - public var Activity_UploadingPhoto: String { return self._s[4160]! } - public var Conversation_Edit: String { return self._s[4162]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[4163]! } - public var Login_TermsOfServiceDecline: String { return self._s[4164]! } - public var Message_PinnedContactMessage: String { return self._s[4165]! } + public var UserInfo_NotificationsDefault: String { return self._s[4150]! } + public var SharedMedia_CategoryMedia: String { return self._s[4151]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4152]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4153]! } + public var Watch_ChatList_Compose: String { return self._s[4154]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4155]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[4156]! } + public var Watch_Microphone_Access: String { return self._s[4157]! } + public var Group_Setup_HistoryHeader: String { return self._s[4158]! } + public var Map_SetThisLocation: String { return self._s[4159]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4160]! } + public var Activity_UploadingPhoto: String { return self._s[4161]! } + public var Conversation_Edit: String { return self._s[4163]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[4164]! } + public var Login_TermsOfServiceDecline: String { return self._s[4165]! } + public var Message_PinnedContactMessage: String { return self._s[4166]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4166]!, self._r[4166]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4167]!, self._r[4167]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4167]!, self._r[4167]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[4168]!, self._r[4168]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[4168]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[4170]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4171]! } + public var Appearance_LargeEmoji: String { return self._s[4169]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4171]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4172]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4172]!, self._r[4172]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4173]!, self._r[4173]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[4173]! } - public var Message_PinnedPhotoMessage: String { return self._s[4174]! } - public var Passport_FieldPhone: String { return self._s[4175]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4176]! } - public var Stats_NotificationsTitle: String { return self._s[4177]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4178]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4180]! } - public var Conversation_Call: String { return self._s[4181]! } - public var Common_TakePhoto: String { return self._s[4183]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4184]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4185]! } - public var Channel_NotificationLoading: String { return self._s[4186]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[4174]! } + public var Message_PinnedPhotoMessage: String { return self._s[4175]! } + public var Passport_FieldPhone: String { return self._s[4176]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4177]! } + public var Stats_NotificationsTitle: String { return self._s[4178]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4179]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4181]! } + public var Conversation_Call: String { return self._s[4182]! } + public var Common_TakePhoto: String { return self._s[4184]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4185]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4186]! } + public var Channel_NotificationLoading: String { return self._s[4187]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4187]!, self._r[4187]!, [_0]) - } - public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4188]!, self._r[4188]!, [_0]) } + public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4189]!, self._r[4189]!, [_0]) + } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4189]!, self._r[4189]!, [_1]) + return formatWithArgumentRanges(self._s[4190]!, self._r[4190]!, [_1]) } - public var Permissions_SiriTitle_v0: String { return self._s[4190]! } + public var Permissions_SiriTitle_v0: String { return self._s[4191]! } public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4191]!, self._r[4191]!, [_0]) - } - public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4192]!, self._r[4192]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4193]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4194]! } - public var ClearCache_FreeSpace: String { return self._s[4195]! } - public var Appearance_BubbleCorners_Apply: String { return self._s[4196]! } - public var Common_edit: String { return self._s[4197]! } - public var PrivacySettings_AuthSessions: String { return self._s[4198]! } - public var Month_ShortJune: String { return self._s[4199]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4200]! } - public var Call_ReportSend: String { return self._s[4201]! } - public var Watch_LastSeen_JustNow: String { return self._s[4202]! } - public var Notifications_MessageNotifications: String { return self._s[4203]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4204]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4206]! } - public var Group_Status: String { return self._s[4207]! } + public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4193]!, self._r[4193]!, [_0]) + } + public var Channel_MessagePhotoRemoved: String { return self._s[4194]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4195]! } + public var ClearCache_FreeSpace: String { return self._s[4196]! } + public var Appearance_BubbleCorners_Apply: String { return self._s[4197]! } + public var Common_edit: String { return self._s[4198]! } + public var PrivacySettings_AuthSessions: String { return self._s[4199]! } + public var Month_ShortJune: String { return self._s[4200]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4201]! } + public var Call_ReportSend: String { return self._s[4202]! } + public var Watch_LastSeen_JustNow: String { return self._s[4203]! } + public var Notifications_MessageNotifications: String { return self._s[4204]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4205]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4207]! } + public var Group_Status: String { return self._s[4208]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4208]!, self._r[4208]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4209]!, self._r[4209]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4209]! } - public var ShareMenu_ShareTo: String { return self._s[4210]! } - public var Conversation_Moderate_Ban: String { return self._s[4211]! } + public var TextFormat_AddLinkTitle: String { return self._s[4210]! } + public var ShareMenu_ShareTo: String { return self._s[4211]! } + public var Conversation_Moderate_Ban: String { return self._s[4212]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4212]!, self._r[4212]!, [_0]) + return formatWithArgumentRanges(self._s[4213]!, self._r[4213]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4213]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4214]! } + public var SharedMedia_ViewInChat: String { return self._s[4214]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4215]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4215]!, self._r[4215]!, [_1]) + return formatWithArgumentRanges(self._s[4216]!, self._r[4216]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4216]!, self._r[4216]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4217]!, self._r[4217]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4218]!, self._r[4218]!, [_0]) + return formatWithArgumentRanges(self._s[4219]!, self._r[4219]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4219]! } - public var Appearance_ReduceMotion: String { return self._s[4220]! } + public var Map_OpenInHereMaps: String { return self._s[4220]! } + public var Appearance_ReduceMotion: String { return self._s[4221]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4221]!, self._r[4221]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4222]!, self._r[4222]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4222]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4223]! } - public var PhotoEditor_Skip: String { return self._s[4224]! } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public var Channel_Setup_TypePublicHelp: String { return self._s[4223]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4224]! } + public var PhotoEditor_Skip: String { return self._s[4225]! } + public func Conversation_StatusSubscribers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + public func MuteFor_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) } - public func Map_ETAHours(_ value: Int32) -> String { + public func Media_SharePhoto(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_StickerCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Link(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Media_ShareItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ForwardedPolls(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) - } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Years(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusMembers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func SharedMedia_Generic(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortHours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MessagePoll_VotedCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) - } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_File(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Call_ShortMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeletedChats(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Photo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_SelectedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Media_ShareVideo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func MessageTimer_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) - } - public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedVideoMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Map_ETAMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveYear(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func UserCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Video(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusOnline(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Passport_Scans(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, _1, _2) } public func MuteExpires_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedGifs(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedContacts(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedPhotos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Months(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedLocations(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, _0, _1) } - public func Invitation_Members(_ value: Int32) -> String { + public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Call_Seconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) } - public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveMonth(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessagePoll_QuizCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteFor_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) } public func Contacts_ImportersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) } - public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + public func Invitation_Members(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_InviteContacts(_ value: Int32) -> String { + public func OldChannels_InactiveMonth(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) } - public func InviteText_ContactsCountText(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatList_SelectedChats(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusOnline(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_InactiveYear(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) } public func MuteFor_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func QuickSend_Photos(_ value: Int32) -> String { + public func SharedMedia_Link(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_InactiveWeek(_ value: Int32) -> String { + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) } - public func PollResults_ShowMore(_ value: Int32) -> String { + public func MessageTimer_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedAudios(_ value: Int32) -> String { + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + public func Passport_Scans(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + public func MessagePoll_VotedCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) } - public func Theme_UsersCount(_ value: Int32) -> String { + public func Map_ETAHours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedStickers(_ value: Int32) -> String { + public func MessageTimer_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_Exceptions(_ value: Int32) -> String { + public func Map_ETAMinutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_SharePhoto(_ value: Int32) -> String { + public func MuteExpires_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreSimple(_ value: Int32) -> String { + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) } public func OldChannels_Leave(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Generic(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Video(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_SelectedChats(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) + } + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_AddStickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Media_ShareItem(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedGifs(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Weeks(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Seconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) + } + public func QuickSend_Photos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func MessageTimer_ShortDays(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) + } + public func UserCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_InactiveWeek(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAudios(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedStickers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_SelectedMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_Exceptions(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_File(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Media_ShareVideo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_UserInfo_Mute(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedPhotos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Theme_UsersCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendItem(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedLocations(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Contacts_InviteContacts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Call_ShortSeconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) } public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, _1, _2) } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_AddMaskCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_StickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendGif(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notification_GameScoreSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideoMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LastSeen_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_GroupFormat(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) + } + public func InviteText_ContactsCountText(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Call_ShortMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func MuteExpires_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_DeletedChats(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedFiles(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortHours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + } + public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, stringValue) @@ -5321,59 +5319,62 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[114 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_ShortSeconds(_ value: Int32) -> String { + public func Call_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, _1, _2) + public func ForwardedPolls(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedVideos(_ value: Int32) -> String { + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func MessagePoll_QuizCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[118 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, _1, _2) + public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[120 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, _0, _1) + public func PollResults_ShowMore(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Weeks(_ value: Int32) -> String { + public func Notification_GameScoreExtended(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[122 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[123 * 6 + Int(form.rawValue)]!, stringValue) } - public func LastSeen_HoursAgo(_ value: Int32) -> String { + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[124 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_GroupFormat(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[125 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public func MessageTimer_Months(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[126 * 6 + Int(form.rawValue)]!, stringValue) diff --git a/submodules/TelegramUI/BUCK b/submodules/TelegramUI/BUCK index b4036d3a53..ca062c5cd7 100644 --- a/submodules/TelegramUI/BUCK +++ b/submodules/TelegramUI/BUCK @@ -34,10 +34,10 @@ framework( "//submodules/TelegramPresentationData:TelegramPresentationData", "//submodules/AccountContext:AccountContext", "//submodules/LegacyComponents:LegacyComponents", - "//submodules/libtgvoip:libtgvoip", + "//submodules/TgVoip:TgVoip", "//submodules/lottie-ios:Lottie", - "//submodules/FFMpeg:FFMpeg", - "//submodules/WebP:WebPImage", + "//submodules/FFMpegBinding:FFMpegBinding", + "//submodules/WebPBinding:WebPBinding", "//submodules/RMIntro:RMIntro", "//submodules/GZip:GZip", "//submodules/TelegramCallsUI:TelegramCallsUI", diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/Contents.json index f9fa203bb7..75a938d28b 100644 --- a/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/Contents.json +++ b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/Contents.json @@ -2,7 +2,7 @@ "images" : [ { "idiom" : "universal", - "filename" : "ic_list.pdf" + "filename" : "ic_folder.pdf" } ], "info" : { diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_list.pdf b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_folder.pdf similarity index 76% rename from submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_list.pdf rename to submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_folder.pdf index 2f376dc273..842ae3b953 100644 Binary files a/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_list.pdf and b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_folder.pdf differ diff --git a/submodules/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/Resources/PresentationStrings.mapping index 989b8c032d..0aa86834bd 100644 Binary files a/submodules/TelegramUI/Resources/PresentationStrings.mapping and b/submodules/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/submodules/TelegramUI/Sources/AppDelegate.swift b/submodules/TelegramUI/Sources/AppDelegate.swift index d437702629..cffbe977ea 100644 --- a/submodules/TelegramUI/Sources/AppDelegate.swift +++ b/submodules/TelegramUI/Sources/AppDelegate.swift @@ -393,7 +393,7 @@ final class SharedApplicationContext { } } - let networkArguments = NetworkInitializationArguments(apiId: apiId, apiHash: apiHash, languagesCategory: languagesCategory, appVersion: appVersion, voipMaxLayer: PresentationCallManagerImpl.voipMaxLayer, appData: self.deviceToken.get() + let networkArguments = NetworkInitializationArguments(apiId: apiId, apiHash: apiHash, languagesCategory: languagesCategory, appVersion: appVersion, voipMaxLayer: PresentationCallManagerImpl.voipMaxLayer, voipVersions: PresentationCallManagerImpl.voipVersions, appData: self.deviceToken.get() |> map { token in let data = buildConfig.bundleData(withAppToken: token, signatureDict: signatureDict) if let data = data, let jsonString = String(data: data, encoding: .utf8) { @@ -2400,8 +2400,4 @@ private func downloadHTTPData(url: URL) -> Signal { } } } - - func testMethod() { - - } } diff --git a/submodules/TelegramUI/Sources/ContactMultiselectionController.swift b/submodules/TelegramUI/Sources/ContactMultiselectionController.swift index 0e48b3d6f4..0de42883d4 100644 --- a/submodules/TelegramUI/Sources/ContactMultiselectionController.swift +++ b/submodules/TelegramUI/Sources/ContactMultiselectionController.swift @@ -83,7 +83,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection self.scrollToTop = { [weak self] in if let strongSelf = self { - strongSelf.contactsNode.contactListNode.scrollToTop() + strongSelf.contactsNode.scrollToTop() } } @@ -132,33 +132,51 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection private func updateTitle() { switch self.mode { - case .groupCreation: - let maxCount: Int32 = self.limitsConfiguration?.maxSupergroupMemberCount ?? 5000 - let count = self.contactsNode.contactListNode.selectionState?.selectedPeerIndices.count ?? 0 - self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.Compose_NewGroupTitle, counter: "\(count)/\(maxCount)") - let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) - self.rightNavigationButton = rightNavigationButton - self.navigationItem.rightBarButtonItem = self.rightNavigationButton - rightNavigationButton.isEnabled = count != 0 - case .channelCreation: - self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.GroupInfo_AddParticipantTitle, counter: "") - let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) - self.rightNavigationButton = rightNavigationButton - self.navigationItem.rightBarButtonItem = self.rightNavigationButton - rightNavigationButton.isEnabled = true - case .peerSelection: - self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.PrivacyLastSeenSettings_EmpryUsersPlaceholder, counter: "") - let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Done, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) - self.rightNavigationButton = rightNavigationButton - self.navigationItem.leftBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Common_Cancel, style: .plain, target: self, action: #selector(cancelPressed)) - self.navigationItem.rightBarButtonItem = self.rightNavigationButton - rightNavigationButton.isEnabled = false + case .groupCreation: + let maxCount: Int32 = self.limitsConfiguration?.maxSupergroupMemberCount ?? 5000 + let count: Int + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + count = contactsNode.selectionState?.selectedPeerIndices.count ?? 0 + case let .chats(chatsNode): + count = chatsNode.currentState.selectedPeerIds.count + } + self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.Compose_NewGroupTitle, counter: "\(count)/\(maxCount)") + let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) + self.rightNavigationButton = rightNavigationButton + self.navigationItem.rightBarButtonItem = self.rightNavigationButton + rightNavigationButton.isEnabled = count != 0 + case .channelCreation: + self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.GroupInfo_AddParticipantTitle, counter: "") + let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) + self.rightNavigationButton = rightNavigationButton + self.navigationItem.rightBarButtonItem = self.rightNavigationButton + rightNavigationButton.isEnabled = true + case .peerSelection: + self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.PrivacyLastSeenSettings_EmpryUsersPlaceholder, counter: "") + let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Done, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) + self.rightNavigationButton = rightNavigationButton + self.navigationItem.leftBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Common_Cancel, style: .plain, target: self, action: #selector(cancelPressed)) + self.navigationItem.rightBarButtonItem = self.rightNavigationButton + rightNavigationButton.isEnabled = false + case .chatSelection: + self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.ChatListFilter_AddChatsTitle, counter: "") + let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Done, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) + self.rightNavigationButton = rightNavigationButton + self.navigationItem.leftBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Common_Cancel, style: .plain, target: self, action: #selector(cancelPressed)) + self.navigationItem.rightBarButtonItem = self.rightNavigationButton + rightNavigationButton.isEnabled = false } } override func loadDisplayNode() { self.displayNode = ContactMultiselectionControllerNode(context: self.context, mode: self.mode, options: self.options, filters: filters) - self._listReady.set(self.contactsNode.contactListNode.ready) + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + self._listReady.set(contactsNode.ready) + case let .chats(chatsNode): + self._listReady.set(chatsNode.ready) + } self.contactsNode.dismiss = { [weak self] in self?.presentingViewController?.dismiss(animated: true, completion: nil) @@ -174,25 +192,47 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection var displayCountAlert = false var selectionState: ContactListNodeGroupSelectionState? - strongSelf.contactsNode.contactListNode.updateSelectionState { state in - if let state = state { - var updatedState = state.withToggledPeerId(.peer(peer.id)) - if updatedState.selectedPeerIndices[.peer(peer.id)] == nil { + switch strongSelf.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.updateSelectionState { state in + if let state = state { + var updatedState = state.withToggledPeerId(.peer(peer.id)) + if updatedState.selectedPeerIndices[.peer(peer.id)] == nil { + removedTokenId = peer.id + } else { + if updatedState.selectedPeerIndices.count >= maxRegularCount { + displayCountAlert = true + updatedState = updatedState.withToggledPeerId(.peer(peer.id)) + } else { + addedToken = EditableTokenListToken(id: peer.id, title: peer.displayTitle(strings: strongSelf.presentationData.strings, displayOrder: strongSelf.presentationData.nameDisplayOrder)) + } + } + updatedCount = updatedState.selectedPeerIndices.count + selectionState = updatedState + return updatedState + } else { + return nil + } + } + case let .chats(chatsNode): + chatsNode.updateState { state in + var state = state + if state.selectedPeerIds.contains(peer.id) { + state.selectedPeerIds.remove(peer.id) removedTokenId = peer.id } else { - if updatedState.selectedPeerIndices.count >= maxRegularCount { - displayCountAlert = true - updatedState = updatedState.withToggledPeerId(.peer(peer.id)) - } else { - addedToken = EditableTokenListToken(id: peer.id, title: peer.displayTitle(strings: strongSelf.presentationData.strings, displayOrder: strongSelf.presentationData.nameDisplayOrder)) - } + addedToken = EditableTokenListToken(id: peer.id, title: peer.displayTitle(strings: strongSelf.presentationData.strings, displayOrder: strongSelf.presentationData.nameDisplayOrder)) + state.selectedPeerIds.insert(peer.id) + } + updatedCount = state.selectedPeerIds.count + var updatedState = ContactListNodeGroupSelectionState() + for peerId in state.selectedPeerIds { + updatedState = updatedState.withToggledPeerId(.peer(peerId)) } - updatedCount = updatedState.selectedPeerIndices.count selectionState = updatedState - return updatedState - } else { - return nil + return state } + break } if let searchResultsNode = strongSelf.contactsNode.searchResultsNode { searchResultsNode.updateSelectionState { _ in @@ -202,7 +242,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection if let updatedCount = updatedCount { switch strongSelf.mode { - case .groupCreation, .peerSelection: + case .groupCreation, .peerSelection, .chatSelection: strongSelf.rightNavigationButton?.isEnabled = updatedCount != 0 case .channelCreation: break @@ -212,7 +252,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection case .groupCreation: let maxCount: Int32 = strongSelf.limitsConfiguration?.maxSupergroupMemberCount ?? 5000 strongSelf.titleView.title = CounterContollerTitle(title: strongSelf.presentationData.strings.Compose_NewGroupTitle, counter: "\(updatedCount)/\(maxCount)") - case .peerSelection, .channelCreation: + case .peerSelection, .channelCreation, .chatSelection: break } } @@ -238,19 +278,39 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection var removedTokenId: AnyHashable? var selectionState: ContactListNodeGroupSelectionState? - strongSelf.contactsNode.contactListNode.updateSelectionState { state in - if let state = state { - let updatedState = state.withToggledPeerId(peerId) - if updatedState.selectedPeerIndices[peerId] == nil { - if case let .peer(peerId) = peerId { + switch strongSelf.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.updateSelectionState { state in + if let state = state { + let updatedState = state.withToggledPeerId(peerId) + if updatedState.selectedPeerIndices[peerId] == nil { + if case let .peer(peerId) = peerId { + removedTokenId = peerId + } + } + updatedCount = updatedState.selectedPeerIndices.count + selectionState = updatedState + return updatedState + } else { + return nil + } + } + case let .chats(chatsNode): + chatsNode.updateState { state in + var state = state + if case let .peer(peerIdValue) = peerId { + if state.selectedPeerIds.contains(peerIdValue) { + state.selectedPeerIds.remove(peerIdValue) removedTokenId = peerId } } - updatedCount = updatedState.selectedPeerIndices.count + updatedCount = state.selectedPeerIds.count + var updatedState = ContactListNodeGroupSelectionState() + for peerId in state.selectedPeerIds { + updatedState = updatedState.withToggledPeerId(.peer(peerId)) + } selectionState = updatedState - return updatedState - } else { - return nil + return state } } if let searchResultsNode = strongSelf.contactsNode.searchResultsNode { @@ -261,7 +321,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection if let updatedCount = updatedCount { switch strongSelf.mode { - case .groupCreation, .peerSelection: + case .groupCreation, .peerSelection, .chatSelection: strongSelf.rightNavigationButton?.isEnabled = updatedCount != 0 case .channelCreation: break @@ -270,7 +330,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection case .groupCreation: let maxCount: Int32 = strongSelf.limitsConfiguration?.maxSupergroupMemberCount ?? 5000 strongSelf.titleView.title = CounterContollerTitle(title: strongSelf.presentationData.strings.Compose_NewGroupTitle, counter: "\(updatedCount)/\(maxCount)") - case .peerSelection, .channelCreation: + case .peerSelection, .channelCreation, .chatSelection: break } } @@ -290,7 +350,12 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection override func viewWillAppear(_ animated: Bool) { super.viewWillAppear(animated) - self.contactsNode.contactListNode.enableUpdates = true + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.enableUpdates = true + case .chats: + break + } } override func viewDidAppear(_ animated: Bool) { @@ -307,7 +372,12 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection override func viewDidDisappear(_ animated: Bool) { super.viewDidDisappear(animated) - self.contactsNode.contactListNode.enableUpdates = false + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.enableUpdates = false + case .chats: + break + } } override func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { @@ -323,11 +393,18 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection @objc func rightNavigationButtonPressed() { var peerIds: [ContactListPeerId] = [] - self.contactsNode.contactListNode.updateSelectionState { state in - if let state = state { - peerIds = Array(state.selectedPeerIndices.keys) + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.updateSelectionState { state in + if let state = state { + peerIds = Array(state.selectedPeerIndices.keys) + } + return state + } + case let .chats(chatsNode): + for peerId in chatsNode.currentState.selectedPeerIds { + peerIds.append(.peer(peerId)) } - return state } self._result.set(.single(peerIds)) } diff --git a/submodules/TelegramUI/Sources/ContactMultiselectionControllerNode.swift b/submodules/TelegramUI/Sources/ContactMultiselectionControllerNode.swift index bf5aa6a548..60ed433094 100644 --- a/submodules/TelegramUI/Sources/ContactMultiselectionControllerNode.swift +++ b/submodules/TelegramUI/Sources/ContactMultiselectionControllerNode.swift @@ -9,6 +9,7 @@ import TelegramPresentationData import MergeLists import AccountContext import ContactListUI +import ChatListUI private struct SearchResultEntry: Identifiable { let index: Int @@ -27,8 +28,22 @@ private struct SearchResultEntry: Identifiable { } } +enum ContactMultiselectionContentNode { + case contacts(ContactListNode) + case chats(ChatListNode) + + var node: ASDisplayNode { + switch self { + case let .contacts(contacts): + return contacts + case let .chats(chats): + return chats + } + } +} + final class ContactMultiselectionControllerNode: ASDisplayNode { - let contactListNode: ContactListNode + let contentNode: ContactMultiselectionContentNode let tokenListNode: EditableTokenListNode var searchResultsNode: ContactListNode? @@ -53,7 +68,7 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { self.context = context self.presentationData = context.sharedContext.currentPresentationData.with { $0 } - let placeholder: String + var placeholder: String var includeChatList = false switch mode { case let .peerSelection(_, searchGroups, searchChannels): @@ -67,7 +82,13 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { placeholder = self.presentationData.strings.Compose_TokenListPlaceholder } - self.contactListNode = ContactListNode(context: context, presentation: .single(.natural(options: options, includeChatList: includeChatList)), filters: filters, selectionState: ContactListNodeGroupSelectionState()) + if case .chatSelection = mode { + placeholder = self.presentationData.strings.Common_Search + self.contentNode = .chats(ChatListNode(context: context, groupId: .root, previewing: false, controlsHistoryPreload: false, mode: .peers(filter: [.excludeSavedMessages], isSelecting: true), theme: self.presentationData.theme, fontSize: self.presentationData.listsFontSize, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameSortOrder: self.presentationData.nameSortOrder, nameDisplayOrder: self.presentationData.nameDisplayOrder, disableAnimations: true)) + } else { + self.contentNode = .contacts(ContactListNode(context: context, presentation: .single(.natural(options: options, includeChatList: includeChatList)), filters: filters, selectionState: ContactListNodeGroupSelectionState())) + } + self.tokenListNode = EditableTokenListNode(theme: EditableTokenListNodeTheme(backgroundColor: self.presentationData.theme.rootController.navigationBar.backgroundColor, separatorColor: self.presentationData.theme.rootController.navigationBar.separatorColor, placeholderTextColor: self.presentationData.theme.list.itemPlaceholderTextColor, primaryTextColor: self.presentationData.theme.list.itemPrimaryTextColor, selectedTextColor: self.presentationData.theme.list.itemCheckColors.foregroundColor, selectedBackgroundColor: self.presentationData.theme.list.itemCheckColors.fillColor, accentColor: self.presentationData.theme.list.itemAccentColor, keyboardColor: self.presentationData.theme.rootController.keyboardColor), placeholder: placeholder) super.init() @@ -78,11 +99,18 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { self.backgroundColor = self.presentationData.theme.chatList.backgroundColor - self.addSubnode(self.contactListNode) + self.addSubnode(self.contentNode.node) self.addSubnode(self.tokenListNode) - self.contactListNode.openPeer = { [weak self] peer in - self?.openPeer?(peer) + switch self.contentNode { + case let .contacts(contactsNode): + contactsNode.openPeer = { [weak self] peer in + self?.openPeer?(peer) + } + case let .chats(chatsNode): + chatsNode.peerSelected = { [weak self] peer, _, _ in + self?.openPeer?(.peer(peer: peer, isGlobal: false, participantCount: nil)) + } } let searchText = ValuePromise() @@ -102,9 +130,14 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { } else { if strongSelf.searchResultsNode == nil { var selectionState: ContactListNodeGroupSelectionState? - strongSelf.contactListNode.updateSelectionState { state in - selectionState = state - return state + switch strongSelf.contentNode { + case let .contacts(contactsNode): + contactsNode.updateSelectionState { state in + selectionState = state + return state + } + case .chats: + break } var searchChatList = false var searchGroups = false @@ -113,6 +146,10 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { searchChatList = peerSelection.searchChatList searchGroups = peerSelection.searchGroups searchChannels = peerSelection.searchChannels + } else if case .chatSelection = mode { + searchChatList = true + searchGroups = true + searchChannels = true } let searchResultsNode = ContactListNode(context: context, presentation: .single(.search(signal: searchText.get(), searchChatList: searchChatList, searchDeviceContacts: false, searchGroups: searchGroups, searchChannels: searchChannels)), filters: filters, selectionState: selectionState) searchResultsNode.openPeer = { peer in @@ -136,7 +173,7 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { strongSelf.searchResultsReadyDisposable.set((searchResultsNode.ready |> deliverOnMainQueue).start(next: { _ in if let strongSelf = self, let searchResultsNode = strongSelf.searchResultsNode { - strongSelf.insertSubnode(searchResultsNode, aboveSubnode: strongSelf.contactListNode) + strongSelf.insertSubnode(searchResultsNode, aboveSubnode: strongSelf.contentNode.node) } })) } @@ -167,6 +204,15 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { self.backgroundColor = self.presentationData.theme.chatList.backgroundColor } + func scrollToTop() { + switch self.contentNode { + case let .contacts(contactsNode): + contactsNode.scrollToTop() + case let .chats(chatsNode): + chatsNode.scrollToPosition(.top) + } + } + func containerLayoutUpdated(_ layout: ContainerViewLayout, navigationBarHeight: CGFloat, actualNavigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { self.containerLayout = (layout, navigationBarHeight, actualNavigationBarHeight) @@ -183,8 +229,15 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { insets.top += tokenListHeight headerInsets.top += tokenListHeight - self.contactListNode.containerLayoutUpdated(ContainerViewLayout(size: layout.size, metrics: layout.metrics, deviceMetrics: layout.deviceMetrics, intrinsicInsets: insets, safeInsets: layout.safeInsets, statusBarHeight: layout.statusBarHeight, inputHeight: layout.inputHeight, inputHeightIsInteractivellyChanging: layout.inputHeightIsInteractivellyChanging, inVoiceOver: layout.inVoiceOver), headerInsets: headerInsets, transition: transition) - self.contactListNode.frame = CGRect(origin: CGPoint(), size: layout.size) + switch self.contentNode { + case let .contacts(contactsNode): + contactsNode.containerLayoutUpdated(ContainerViewLayout(size: layout.size, metrics: layout.metrics, deviceMetrics: layout.deviceMetrics, intrinsicInsets: insets, safeInsets: layout.safeInsets, statusBarHeight: layout.statusBarHeight, inputHeight: layout.inputHeight, inputHeightIsInteractivellyChanging: layout.inputHeightIsInteractivellyChanging, inVoiceOver: layout.inVoiceOver), headerInsets: headerInsets, transition: transition) + case let .chats(chatsNode): + let (duration, curve) = listViewAnimationDurationAndCurve(transition: transition) + let updateSizeAndInsets = ListViewUpdateSizeAndInsets(size: layout.size, insets: insets, headerInsets: headerInsets, duration: duration, curve: curve) + chatsNode.updateLayout(transition: transition, updateSizeAndInsets: updateSizeAndInsets) + } + self.contentNode.node.frame = CGRect(origin: CGPoint(), size: layout.size) if let searchResultsNode = self.searchResultsNode { searchResultsNode.containerLayoutUpdated(ContainerViewLayout(size: layout.size, metrics: layout.metrics, deviceMetrics: layout.deviceMetrics, intrinsicInsets: insets, safeInsets: layout.safeInsets, statusBarHeight: layout.statusBarHeight, inputHeight: layout.inputHeight, inputHeightIsInteractivellyChanging: layout.inputHeightIsInteractivellyChanging, inVoiceOver: layout.inVoiceOver), headerInsets: headerInsets, transition: transition) diff --git a/submodules/TelegramUI/Sources/NotificationContentContext.swift b/submodules/TelegramUI/Sources/NotificationContentContext.swift index 415104c251..50b8133924 100644 --- a/submodules/TelegramUI/Sources/NotificationContentContext.swift +++ b/submodules/TelegramUI/Sources/NotificationContentContext.swift @@ -154,7 +154,7 @@ public final class NotificationViewControllerImpl { return nil }) - sharedAccountContext = SharedAccountContextImpl(mainWindow: nil, basePath: rootPath, encryptionParameters: ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: self.initializationData.encryptionParameters.0)!, salt: ValueBoxEncryptionParameters.Salt(data: self.initializationData.encryptionParameters.1)!), accountManager: accountManager, appLockContext: appLockContext, applicationBindings: applicationBindings, initialPresentationDataAndSettings: initialPresentationDataAndSettings!, networkArguments: NetworkInitializationArguments(apiId: self.initializationData.apiId, apiHash: self.initializationData.apiHash, languagesCategory: self.initializationData.languagesCategory, appVersion: self.initializationData.appVersion, voipMaxLayer: 0, appData: .single(self.initializationData.bundleData), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), rootPath: rootPath, legacyBasePath: nil, legacyCache: nil, apsNotificationToken: .never(), voipNotificationToken: .never(), setNotificationCall: { _ in }, navigateToChat: { _, _, _ in }) + sharedAccountContext = SharedAccountContextImpl(mainWindow: nil, basePath: rootPath, encryptionParameters: ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: self.initializationData.encryptionParameters.0)!, salt: ValueBoxEncryptionParameters.Salt(data: self.initializationData.encryptionParameters.1)!), accountManager: accountManager, appLockContext: appLockContext, applicationBindings: applicationBindings, initialPresentationDataAndSettings: initialPresentationDataAndSettings!, networkArguments: NetworkInitializationArguments(apiId: self.initializationData.apiId, apiHash: self.initializationData.apiHash, languagesCategory: self.initializationData.languagesCategory, appVersion: self.initializationData.appVersion, voipMaxLayer: 0, voipVersions: [], appData: .single(self.initializationData.bundleData), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), rootPath: rootPath, legacyBasePath: nil, legacyCache: nil, apsNotificationToken: .never(), voipNotificationToken: .never(), setNotificationCall: { _ in }, navigateToChat: { _, _, _ in }) presentationDataPromise.set(sharedAccountContext!.presentationData) } diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoPaneContainerNode.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoPaneContainerNode.swift index 070320143f..3212d5c133 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoPaneContainerNode.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoPaneContainerNode.swift @@ -509,7 +509,7 @@ final class PeerInfoPaneContainerNode: ASDisplayNode, UIGestureRecognizerDelegat override func didLoad() { super.didLoad() - let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] in + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] _ in guard let strongSelf = self, let currentPaneKey = strongSelf.currentPaneKey, let availablePanes = strongSelf.currentParams?.data?.availablePanes, let index = availablePanes.index(of: currentPaneKey) else { return [] } diff --git a/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift b/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift index 8d30cec7a7..00083acf52 100644 --- a/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift +++ b/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift @@ -85,7 +85,7 @@ final class PeerSelectionControllerNode: ASDisplayNode { self.segmentedControlNode = nil } - self.chatListNode = ChatListNode(context: context, groupId: .root, previewing: false, controlsHistoryPreload: false, mode: .peers(filter: filter), theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) + self.chatListNode = ChatListNode(context: context, groupId: .root, previewing: false, controlsHistoryPreload: false, mode: .peers(filter: filter, isSelecting: false), theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) super.init() @@ -99,8 +99,8 @@ final class PeerSelectionControllerNode: ASDisplayNode { self?.requestActivateSearch?() } - self.chatListNode.peerSelected = { [weak self] peerId, _, _ in - self?.requestOpenPeer?(peerId) + self.chatListNode.peerSelected = { [weak self] peer, _, _ in + self?.requestOpenPeer?(peer.id) } self.chatListNode.disabledPeerSelected = { [weak self] peer in diff --git a/submodules/TelegramUI/Sources/ShareExtensionContext.swift b/submodules/TelegramUI/Sources/ShareExtensionContext.swift index 1f0d7d4f0f..2148715929 100644 --- a/submodules/TelegramUI/Sources/ShareExtensionContext.swift +++ b/submodules/TelegramUI/Sources/ShareExtensionContext.swift @@ -193,7 +193,7 @@ public class ShareRootControllerImpl { return nil }) - let sharedContext = SharedAccountContextImpl(mainWindow: nil, basePath: rootPath, encryptionParameters: ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: self.initializationData.encryptionParameters.0)!, salt: ValueBoxEncryptionParameters.Salt(data: self.initializationData.encryptionParameters.1)!), accountManager: accountManager, appLockContext: appLockContext, applicationBindings: applicationBindings, initialPresentationDataAndSettings: initialPresentationDataAndSettings!, networkArguments: NetworkInitializationArguments(apiId: self.initializationData.apiId, apiHash: self.initializationData.apiHash, languagesCategory: self.initializationData.languagesCategory, appVersion: self.initializationData.appVersion, voipMaxLayer: 0, appData: .single(self.initializationData.bundleData), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), rootPath: rootPath, legacyBasePath: nil, legacyCache: nil, apsNotificationToken: .never(), voipNotificationToken: .never(), setNotificationCall: { _ in }, navigateToChat: { _, _, _ in }) + let sharedContext = SharedAccountContextImpl(mainWindow: nil, basePath: rootPath, encryptionParameters: ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: self.initializationData.encryptionParameters.0)!, salt: ValueBoxEncryptionParameters.Salt(data: self.initializationData.encryptionParameters.1)!), accountManager: accountManager, appLockContext: appLockContext, applicationBindings: applicationBindings, initialPresentationDataAndSettings: initialPresentationDataAndSettings!, networkArguments: NetworkInitializationArguments(apiId: self.initializationData.apiId, apiHash: self.initializationData.apiHash, languagesCategory: self.initializationData.languagesCategory, appVersion: self.initializationData.appVersion, voipMaxLayer: 0, voipVersions: [], appData: .single(self.initializationData.bundleData), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), rootPath: rootPath, legacyBasePath: nil, legacyCache: nil, apsNotificationToken: .never(), voipNotificationToken: .never(), setNotificationCall: { _ in }, navigateToChat: { _, _, _ in }) presentationDataPromise.set(sharedContext.presentationData) internalContext = InternalContext(sharedContext: sharedContext) globalInternalContext = internalContext diff --git a/submodules/TelegramVoip/BUCK b/submodules/TelegramVoip/BUCK index 1ff247472b..6d74bfe5bb 100644 --- a/submodules/TelegramVoip/BUCK +++ b/submodules/TelegramVoip/BUCK @@ -11,7 +11,7 @@ static_library( "//submodules/SyncCore:SyncCore#shared", "//submodules/Postbox:Postbox#shared", "//submodules/TelegramUIPreferences:TelegramUIPreferences", - "//submodules/libtgvoip:libtgvoip", + "//submodules/TgVoip:TgVoip", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/TelegramVoip/Sources/OngoingCallContext.swift b/submodules/TelegramVoip/Sources/OngoingCallContext.swift index a884f06c50..876978cd37 100644 --- a/submodules/TelegramVoip/Sources/OngoingCallContext.swift +++ b/submodules/TelegramVoip/Sources/OngoingCallContext.swift @@ -173,6 +173,10 @@ public final class OngoingCallContext { return OngoingCallThreadLocalContext.maxLayer() } + public static var version: String { + return OngoingCallThreadLocalContext.version()! + } + public init(account: Account, callSessionManager: CallSessionManager, internalId: CallSessionInternalId, proxyServer: ProxyServerSettings?, initialNetworkType: NetworkType, updatedNetworkType: Signal, serializedData: String?, dataSaving: VoiceCallDataSaving, derivedState: VoipDerivedState) { let _ = setupLogs OngoingCallThreadLocalContext.applyServerConfig(serializedData) diff --git a/submodules/TgVoip/BUCK b/submodules/TgVoip/BUCK index cb8649b287..e8d8d2596e 100644 --- a/submodules/TgVoip/BUCK +++ b/submodules/TgVoip/BUCK @@ -1,8 +1,11 @@ load("//Config:buck_rule_macros.bzl", "static_library", "glob_map", "glob_sub_map", "merge_maps") static_library( - name = "libtgvoip", + name = "TgVoip", srcs = glob([ + "Sources/**/*.m", + "Sources/**/*.mm", + "Sources/**/*.h", "libtgvoip/*.m", "libtgvoip/*.mm", "libtgvoip/*.cpp", @@ -18,24 +21,28 @@ static_library( ], exclude = ["libtgvoip/os/darwin/*OSX*"]), has_cpp = True, headers = merge_maps([ - glob_map(glob([ + glob_sub_map("libtgvoip/", [ "libtgvoip/*.h", + "libtgvoip/*.hpp", "libtgvoip/audio/*.h", + "libtgvoip/audio/*.hpp", "libtgvoip/video/*.h", - ])), - glob_map(glob([ + "libtgvoip/video/*.hpp", + ]), + glob_sub_map("libtgvoip/", [ "libtgvoip/os/darwin/*.h", - ], exclude = ["libtgvoip/os/darwin/*OSX*"])), + ], exclude = ["libtgvoip/os/darwin/*OSX*"]), glob_sub_map("libtgvoip/webrtc_dsp/", [ "libtgvoip/webrtc_dsp/**/*.h", ]), ]), exported_headers = glob([ - "libtgvoip/OngoingCallThreadLocalContext.h" - ], exclude = ["libtgvoip/libtgvoip.h"]), + "PublicHeaders/**/*.h", + ]), platform_compiler_flags = [ ('arm.*', [ '-DTGVOIP_USE_CUSTOM_CRYPTO', + '-DTGVOIP_USE_INSTALLED_OPUS', '-DWEBRTC_APM_DEBUG_DUMP=0', '-DWEBRTC_POSIX', '-DTGVOIP_HAVE_TGLOG', @@ -45,6 +52,7 @@ static_library( ]), ('.*', [ '-DTGVOIP_USE_CUSTOM_CRYPTO', + '-DTGVOIP_USE_INSTALLED_OPUS', '-DWEBRTC_APM_DEBUG_DUMP=0', '-DWEBRTC_POSIX', '-DTGVOIP_HAVE_TGLOG', diff --git a/submodules/TgVoip/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.h b/submodules/TgVoip/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.h index 374c9dc6a2..674a80d80e 100644 --- a/submodules/TgVoip/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.h +++ b/submodules/TgVoip/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.h @@ -59,6 +59,7 @@ typedef NS_ENUM(int32_t, OngoingCallDataSaving) { + (void)setupLoggingFunction:(void (* _Nullable)(NSString * _Nullable))loggingFunction; + (void)applyServerConfig:(NSString * _Nullable)data; + (int32_t)maxLayer; ++ (NSString *)version; @property (nonatomic, copy) void (^ _Nullable stateChanged)(OngoingCallState); @property (nonatomic, copy) void (^ _Nullable signalBarsChanged)(int32_t); diff --git a/submodules/TgVoip/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.mm b/submodules/TgVoip/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.mm index c98bcf146f..125a7b849a 100644 --- a/submodules/TgVoip/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.mm +++ b/submodules/TgVoip/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.mm @@ -218,6 +218,10 @@ static int callControllerDataSavingForType(OngoingCallDataSaving type) { return tgvoip::VoIPController::GetConnectionMaxLayer(); } ++ (NSString *)version { + return [NSString stringWithUTF8String:tgvoip::VoIPController::GetVersion()]; +} + - (instancetype _Nonnull)initWithQueue:(id _Nonnull)queue proxy:(VoipProxyServer * _Nullable)proxy networkType:(OngoingCallNetworkType)networkType dataSaving:(OngoingCallDataSaving)dataSaving derivedState:(NSData * _Nonnull)derivedState { self = [super init]; if (self != nil) { diff --git a/submodules/WalletUI/Resources/WalletStrings.mapping b/submodules/WalletUI/Resources/WalletStrings.mapping index 589c6fe85e..9f7c348920 100644 Binary files a/submodules/WalletUI/Resources/WalletStrings.mapping and b/submodules/WalletUI/Resources/WalletStrings.mapping differ diff --git a/submodules/WalletUI/Sources/WalletStrings.swift b/submodules/WalletUI/Sources/WalletStrings.swift index c572929515..9d5c0af52d 100644 --- a/submodules/WalletUI/Sources/WalletStrings.swift +++ b/submodules/WalletUI/Sources/WalletStrings.swift @@ -448,12 +448,12 @@ public final class WalletStrings: Equatable { public var Wallet_SecureStorageReset_Title: String { return self._s[218]! } public var Wallet_Receive_CommentHeader: String { return self._s[219]! } public var Wallet_Info_ReceiveGrams: String { return self._s[220]! } - public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = walletStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = walletStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) diff --git a/submodules/WatchBridge/BUCK b/submodules/WatchBridge/BUCK index db0cc53f52..43887ef484 100644 --- a/submodules/WatchBridge/BUCK +++ b/submodules/WatchBridge/BUCK @@ -4,14 +4,7 @@ static_library( name = "WatchBridge", srcs = glob([ "Sources/**/*.swift", - "Sources/**/*.m", ]), - headers = glob([ - "Sources/**/*.h", - ], exclude = ["Sources/WatchBridge.h"]), - exported_headers = glob([ - "Sources/**/*.h", - ], exclude = ["Sources/WatchBridge.h"]), deps = [ "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit#shared", "//submodules/SSignalKit/SSignalKit:SSignalKit", @@ -29,6 +22,7 @@ static_library( "//submodules/LegacyComponents:LegacyComponents", "//submodules/LegacyUI:LegacyUI", "//submodules/PhoneNumberFormat:PhoneNumberFormat", + "//submodules/WatchBridge/Impl:WatchBridgeImpl", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/WatchBridge/Impl/BUCK b/submodules/WatchBridge/Impl/BUCK new file mode 100644 index 0000000000..0fffa19506 --- /dev/null +++ b/submodules/WatchBridge/Impl/BUCK @@ -0,0 +1,38 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "WatchBridgeImpl", + srcs = glob([ + "Sources/**/*.swift", + "Sources/**/*.m", + ]), + headers = glob([ + "Sources/**/*.h", + ]), + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), + deps = [ + "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit#shared", + "//submodules/SSignalKit/SSignalKit:SSignalKit", + "//submodules/Postbox:Postbox#shared", + "//submodules/TelegramCore:TelegramCore#shared", + "//submodules/SyncCore:SyncCore#shared", + "//submodules/WatchCommon/Host:WatchCommon", + "//submodules/WatchBridgeAudio:WatchBridgeAudio", + "//submodules/TelegramPresentationData:TelegramPresentationData", + "//submodules/TelegramUIPreferences:TelegramUIPreferences", + "//submodules/AccountContext:AccountContext", + "//submodules/AvatarNode:AvatarNode", + "//submodules/StickerResources:StickerResources", + "//submodules/PhotoResources:PhotoResources", + "//submodules/LegacyComponents:LegacyComponents", + "//submodules/LegacyUI:LegacyUI", + "//submodules/PhoneNumberFormat:PhoneNumberFormat", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/UIKit.framework", + "$SDKROOT/System/Library/Frameworks/WatchConnectivity.framework", + ], +) diff --git a/submodules/WatchBridgeAudio/BUCK b/submodules/WatchBridgeAudio/BUCK index 6f2e9a7088..c344d50cd6 100644 --- a/submodules/WatchBridgeAudio/BUCK +++ b/submodules/WatchBridgeAudio/BUCK @@ -4,17 +4,10 @@ static_library( name = "WatchBridgeAudio", srcs = glob([ "Sources/**/*.swift", - "Sources/**/*.m", - "Sources/**/*.mm", ]), - headers = glob([ - "Sources/**/*.h", - ], exclude = ["Sources/WatchBridgeAudio.h"]), - exported_headers = glob([ - "Sources/**/*.h", - ], exclude = ["Sources/WatchBridgeAudio.h"]), deps = [ "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit#shared", + "//submodules/WatchBridgeAudio/Impl:WatchBridgeAudioImpl", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/WatchBridgeAudio/Impl/BUCK b/submodules/WatchBridgeAudio/Impl/BUCK new file mode 100644 index 0000000000..68519a7f3e --- /dev/null +++ b/submodules/WatchBridgeAudio/Impl/BUCK @@ -0,0 +1,24 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "WatchBridgeAudioImpl", + srcs = glob([ + "Sources/**/*.m", + "Sources/**/*.mm", + ]), + headers = glob([ + "Sources/**/*.h", + ]), + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), + deps = [ + "//submodules/SSignalKit/SSignalKit:SSignalKit", + "//submodules/OpusBinding:OpusBinding", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/AVFoundation.framework", + "$SDKROOT/System/Library/Frameworks/AudioToolbox.framework", + ], +) diff --git a/submodules/WatchCommon/BUCK b/submodules/WatchCommon/BUCK new file mode 100644 index 0000000000..e69de29bb2 diff --git a/submodules/WatchCommon/Host/BUCK b/submodules/WatchCommon/Host/BUCK index b4a597439b..56fb1a1683 100644 --- a/submodules/WatchCommon/Host/BUCK +++ b/submodules/WatchCommon/Host/BUCK @@ -7,10 +7,10 @@ static_library( ]), headers = glob([ "Sources/*.h", - ], exclude = ["Sources/WatchCommon.h", "Sources/WatchCommon.h"]), + ]), exported_headers = glob([ - "Sources/*.h", - ], exclude = ["Sources/WatchCommon.h", "Sources/WatchCommon.h"]), + "PublicHeaders/**/*.h", + ]), frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", ], diff --git a/submodules/WebPBinding/BUCK b/submodules/WebPBinding/BUCK new file mode 100644 index 0000000000..7e23c440ec --- /dev/null +++ b/submodules/WebPBinding/BUCK @@ -0,0 +1,21 @@ +load("//Config:buck_rule_macros.bzl", "static_library", "framework") + +static_library( + name = "WebPBinding", + srcs = glob([ + "Sources/**/*.m", + ]), + headers = glob([ + "Sources/**/*.h", + ]), + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), + deps = [ + "//submodules/webp:webp", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/UIKit.framework", + ], +) diff --git a/submodules/ffmpeg/BUCK b/submodules/ffmpeg/BUCK index 19a4d37012..67e9c161eb 100644 --- a/submodules/ffmpeg/BUCK +++ b/submodules/ffmpeg/BUCK @@ -1,4 +1,4 @@ -load("//Config:buck_rule_macros.bzl", "static_library", "gen_header_targets") +load("//Config:buck_rule_macros.bzl", "static_library", "gen_header_targets", "merge_maps") ffmpeg_header_paths = [ "libavutil/hwcontext.h", @@ -111,11 +111,11 @@ library_archs = "arm64 armv7 x86_64" genrule( name = "libffmpeg_build", srcs = glob([ - "FFMpeg/**/*", - ], exclude = ["FFMpeg/**/.*"]), + "Sources/FFMpeg/**/*", + ], exclude = ["Sources/FFMpeg/**/.*"]), bash = "PATH=\"$PATH:$(location //third-party/yasm:yasm)/yasm-1.3.0/build\" " + - "$SRCDIR/FFMpeg/build-ffmpeg.sh release \"" + library_archs + "\" $OUT $SRCDIR/FFMpeg", + "$SRCDIR/Sources/FFMpeg/build-ffmpeg-buck.sh release \"" + library_archs + "\" $OUT $SRCDIR/Sources/FFMpeg", out = "libffmpeg", visibility = [ "//submodules/ffmpeg:FFMpeg", @@ -159,13 +159,12 @@ apple_library( ) static_library( - name = "FFMpeg", - srcs = glob([ - "FFMpeg/*.m", - ]), - headers = ffmpeg_header_targets, - exported_headers = glob([ - "FFMpeg/*.h", + name = "ffmpeg", + exported_headers = merge_maps([ + { + "ffmpeg/ffmpeg.h": "PublicHeaders/ffmpeg/ffmpeg.h", + }, + ffmpeg_header_targets, ]), deps = [ ":libffmpeg_build", diff --git a/submodules/ffmpeg/BUILD b/submodules/ffmpeg/BUILD index c7524d20d3..edcc75499d 100644 --- a/submodules/ffmpeg/BUILD +++ b/submodules/ffmpeg/BUILD @@ -147,7 +147,7 @@ genrule( echo "Unsupported architecture $(TARGET_CPU)" fi - PATH="$$PATH:$$YASM_DIR" "$$SOURCE_PATH/build-ffmpeg.sh" release "$$BUILD_ARCH" "$$BUILD_DIR" "$$SOURCE_PATH" + PATH="$$PATH:$$YASM_DIR" "$$SOURCE_PATH/build-ffmpeg-bazel.sh" release "$$BUILD_ARCH" "$$BUILD_DIR" "$$SOURCE_PATH" """ + "\n" + "\n".join([ "cp \"$$BUILD_DIR/FFmpeg-iOS/include/{header_path}\" \"$(location Public/ffmpeg/{header_path})\"".format(header_path = header_path) for header_path in ffmpeg_header_paths ]) + "\n" + "\n".join([ diff --git a/submodules/ffmpeg/PublicHeaders/ffmpeg/ffmpeg.h b/submodules/ffmpeg/PublicHeaders/ffmpeg/ffmpeg.h new file mode 100644 index 0000000000..e69de29bb2 diff --git a/submodules/ffmpeg/Sources/FFMpeg/build-ffmpeg.sh b/submodules/ffmpeg/Sources/FFMpeg/build-ffmpeg-bazel.sh similarity index 100% rename from submodules/ffmpeg/Sources/FFMpeg/build-ffmpeg.sh rename to submodules/ffmpeg/Sources/FFMpeg/build-ffmpeg-bazel.sh diff --git a/submodules/ffmpeg/Sources/FFMpeg/build-ffmpeg-buck.sh b/submodules/ffmpeg/Sources/FFMpeg/build-ffmpeg-buck.sh new file mode 100755 index 0000000000..cc7f8a753b --- /dev/null +++ b/submodules/ffmpeg/Sources/FFMpeg/build-ffmpeg-buck.sh @@ -0,0 +1,230 @@ +#!/bin/sh + +RAW_ARCHS="$2" +ARCHS="" + +for RAW_ARCH in $RAW_ARCHS; do + ARCH_NAME="$RAW_ARCH" + if [ "$ARCH_NAME" == "iphoneos-arm64" ]; then + ARCH_NAME="arm64" + elif [ "$ARCH_NAME" == "iphoneos-armv7" ]; then + ARCH_NAME="armv7" + elif [ "$ARCH_NAME" == "iphonesimulator-x86_64" ]; then + ARCH_NAME="x86_64" + elif [ "$ARCH_NAME" == "iphonesimulator-i386" ]; then + ARCH_NAME="i386" + fi + + if [ "$ARCH_NAME" = "i386" -o "$ARCH_NAME" = "x86_64" -o "$ARCH_NAME" = "arm64" -o "$ARCH_NAME" = "armv7" ] + then + ARCHS="$ARCHS $ARCH_NAME" + else + echo "Invalid architecture $ARCH" + exit 1 + fi +done + +BUILD_DIR=$3 +SOURCE_DIR=$4 + +FF_VERSION="4.1" +SOURCE="$SOURCE_DIR/ffmpeg-$FF_VERSION" + +GAS_PREPROCESSOR_PATH="$SOURCE_DIR/gas-preprocessor.pl" + +FAT="$BUILD_DIR/FFmpeg-iOS" + +SCRATCH="$BUILD_DIR/scratch" +THIN="$BUILD_DIR/thin" + +PKG_CONFIG="$SOURCE_DIR/pkg-config" + +export PATH="$SOURCE_DIR:$PATH" + +LIB_NAMES="libavcodec libavformat libavutil libswresample" + +set -e + +CONFIGURE_FLAGS="--enable-cross-compile --disable-programs \ + --disable-armv5te --disable-armv6 --disable-armv6t2 \ + --disable-doc --enable-pic --disable-all --disable-everything \ + --enable-avcodec \ + --enable-swresample \ + --enable-avformat \ + --disable-xlib \ + --enable-libopus \ + --enable-audiotoolbox \ + --enable-bsf=aac_adtstoasc \ + --enable-decoder=h264,hevc,libopus,mp3_at,aac,flac,alac_at,pcm_s16le,pcm_s24le,gsm_ms_at \ + --enable-demuxer=aac,mov,m4v,mp3,ogg,libopus,flac,wav,aiff,matroska \ + --enable-parser=aac,h264,mp3,libopus \ + --enable-protocol=file \ + --enable-muxer=mp4 \ + " + + +#--enable-hwaccel=h264_videotoolbox,hevc_videotoolbox \ + +if [ "$1" = "debug" ]; +then + CONFIGURE_FLAGS="$CONFIGURE_FLAGS --disable-optimizations --disable-stripping" +elif [ "$1" = "release" ]; +then + CONFIGURE_FLAGS="$CONFIGURE_FLAGS --disable-debug" +else + echo "No configuration specified (debug / release)" + exit 1 +fi + +COMPILE="y" + +DEPLOYMENT_TARGET="8.0" + +LIBS_HASH="" +for ARCH in $ARCHS +do + for LIB_NAME in $LIB_NAMES + do + LIB="$SCRATCH/$ARCH/$LIB_NAME/$LIB_NAME.a" + if [ -e "$LIB" ] + then + LIB_DATE=`crc32 "$LIB"` + LIBS_HASH="$LIBS_HASH $ARCH/$LIB:$LIB_DATE" + fi + done +done + +if [ "$COMPILE" ] +then + if [ ! `which yasm` ]; then + echo 'Yasm not found' + exit 1 + fi + if [ ! `which pkg-config` ]; then + echo 'pkg-config not found' + exit 1 + else + echo "PATH=$PATH" + echo "pkg-config=$(which pkg-config)" + fi + if [ ! `which "$GAS_PREPROCESSOR_PATH"` ]; then + echo '$GAS_PREPROCESSOR_PATH not found.' + exit 1 + fi + + if [ ! -r $SOURCE ]; then + echo "FFmpeg source not found at $SOURCE" + exit 1 + fi + + CWD="$BUILD_DIR" + for ARCH in $ARCHS + do + echo "building $ARCH..." + mkdir -p "$SCRATCH/$ARCH" + cd "$SCRATCH/$ARCH" + + LIBOPUS_PATH="$SOURCE_DIR/libopus" + + CFLAGS="-arch $ARCH" + if [ "$ARCH" = "i386" -o "$ARCH" = "x86_64" ] + then + PLATFORM="iPhoneSimulator" + CFLAGS="$CFLAGS -mios-simulator-version-min=$DEPLOYMENT_TARGET" + else + PLATFORM="iPhoneOS" + CFLAGS="$CFLAGS -mios-version-min=$DEPLOYMENT_TARGET" + if [ "$ARCH" = "arm64" ] + then + EXPORT="GASPP_FIX_XCODE5=1" + fi + fi + + XCRUN_SDK=`echo $PLATFORM | tr '[:upper:]' '[:lower:]'` + CC="xcrun -sdk $XCRUN_SDK clang" + + if [ "$ARCH" = "arm64" ] + then + AS="$GAS_PREPROCESSOR_PATH -arch aarch64 -- $CC" + else + AS="$GAS_PREPROCESSOR_PATH -- $CC" + fi + + CXXFLAGS="$CFLAGS" + LDFLAGS="$CFLAGS" + + CONFIGURED_MARKER="$THIN/$ARCH/configured_marker" + CONFIGURED_MARKER_CONTENTS="" + if [ -r "$CONFIGURED_MARKER" ] + then + CONFIGURED_MARKER_CONTENTS=`cat "$CONFIGURED_MARKER"` + fi + if [ "$CONFIGURED_MARKER_CONTENTS" = "$CONFIGURE_FLAGS" ] + then + echo "1" >/dev/null + else + mkdir -p "$THIN/$ARCH" + TMPDIR=${TMPDIR/%\/} "$SOURCE/configure" \ + --target-os=darwin \ + --arch=$ARCH \ + --cc="$CC" \ + --as="$AS" \ + $CONFIGURE_FLAGS \ + --extra-cflags="$CFLAGS" \ + --extra-ldflags="$LDFLAGS" \ + --prefix="$THIN/$ARCH" \ + --pkg-config="$PKG_CONFIG" \ + --pkg-config-flags="--libopus_path $LIBOPUS_PATH" \ + || exit 1 + echo "$CONFIGURE_FLAGS" > "$CONFIGURED_MARKER" + fi + + CORE_COUNT=`sysctl -n hw.logicalcpu` + make -j$CORE_COUNT install $EXPORT || exit 1 + cd "$CWD" + done +fi + +UPDATED_LIBS_HASH="" +for ARCH in $ARCHS +do + for LIB_NAME in $LIB_NAMES + do + LIB="$SCRATCH/$ARCH/$LIB_NAME/$LIB_NAME.a" + if [ -e "$LIB" ] + then + LIB_DATE=`crc32 "$LIB"` + UPDATED_LIBS_HASH="$UPDATED_LIBS_HASH $ARCH/$LIB:$LIB_DATE" + fi + done +done + +if [ "$UPDATED_LIBS_HASH" = "$LIBS_HASH" ] +then + echo "Libs aren't changed, skipping lipo" +else + echo "UPDATED_LIBS_HASH=$UPDATED_LIBS_HASH" + echo "LIBS_HASH=$LIBS_HASH" + LIPO="y" +fi + +if [ "$LIPO" ] +then + echo "building fat binaries..." + mkdir -p "$FAT"/lib + set - $ARCHS + CWD="$BUILD_DIR" + cd "$THIN/$1/lib" + for LIB in *.a + do + cd "$CWD" + echo lipo -create `find "$THIN" -name "$LIB"` -output "$FAT/lib/$LIB" 1>&2 + LIPO_INPUT=`find "$THIN" -name "$LIB"` + lipo -create $LIPO_INPUT -output "$FAT/lib/$LIB" || exit 1 + done + + cd "$CWD" + cp -rf "$THIN/$1/include" "$FAT" +fi + +echo Done diff --git a/submodules/libphonenumber/BUCK b/submodules/libphonenumber/BUCK index 14fc48fa58..2bf07e7f10 100644 --- a/submodules/libphonenumber/BUCK +++ b/submodules/libphonenumber/BUCK @@ -8,12 +8,9 @@ static_library( headers = glob([ "Sources/*.h", ]), - exported_headers = [ - "Sources/NBPhoneNumberDefines.h", - "Sources/NBPhoneNumber.h", - "Sources/NBPhoneNumberUtil.h", - "Sources/NBAsYouTypeFormatter.h", - ], + exported_headers = glob([ + "PublicHeaders/**/*.h", + ]), deps = [ ], frameworks = [ diff --git a/submodules/lottie-ios/BUCK b/submodules/lottie-ios/BUCK index 91f6530fad..18430670c3 100644 --- a/submodules/lottie-ios/BUCK +++ b/submodules/lottie-ios/BUCK @@ -1,15 +1,19 @@ load("//Config:buck_rule_macros.bzl", "static_library") +private_headers = glob([ + "lottie-ios/**/*.h", +], exclude = [ + "lottie-ios/Classes/PublicHeaders/**/*.h", +]) + static_library( name = "Lottie", srcs = glob([ "lottie-ios/**/*.m", ]), - headers = glob([ - "lottie-ios/**/*.h", - ]), + headers = private_headers, exported_headers = glob([ - "lottie-ios/Classes/PublicHeaders/*.h", + "lottie-ios/Classes/PublicHeaders/**/*.h", ]), deps = [ ], diff --git a/submodules/webp/BUCK b/submodules/webp/BUCK index c8f7bc56c0..afd63155da 100644 --- a/submodules/webp/BUCK +++ b/submodules/webp/BUCK @@ -11,10 +11,7 @@ genrule( ) apple_library( - name = "WebP_lib", - visibility = [ - "//submodules/WebP:..." - ], + name = "webp", header_namespace = "webp", exported_headers = { "webp/encode.h": "include/webp/encode.h", @@ -25,24 +22,5 @@ apple_library( "-lwebp", "-L$(location :WebP_lib_file)", ], -) - -static_library( - name = "WebPImage", - srcs = glob([ - "WebP/*.m", - ]), - headers = [ - "WebP/UIImage+WebP.h", - ], - exported_headers = [ - "WebP/UIImage+WebP.h", - ], - deps = [ - ":WebP_lib", - ], - frameworks = [ - "$SDKROOT/System/Library/Frameworks/Foundation.framework", - "$SDKROOT/System/Library/Frameworks/UIKit.framework", - ], + visibility = ["PUBLIC"], )