From 8dca02259c2d48c63e16bc45dabbbdb21faad64d Mon Sep 17 00:00:00 2001 From: Peter Iakovlev Date: Wed, 20 Nov 2019 09:20:22 +0000 Subject: [PATCH 01/25] Update BUCK --- BUCK | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/BUCK b/BUCK index aa8a301c7e..9a0e72c2ba 100644 --- a/BUCK +++ b/BUCK @@ -466,7 +466,7 @@ apple_binary( linker_flags = [ "-e", "_WKExtensionMain", - "-lWKExtensionMainLegacy", + "-l", "-force_load", "WKExtensionMainLegacy", ], configs = watch_extension_binary_configs(), frameworks = [ From 993987ce30955db69f024bf22fcfcd43a24bb7f2 Mon Sep 17 00:00:00 2001 From: Peter Iakovlev Date: Wed, 20 Nov 2019 09:23:48 +0000 Subject: [PATCH 02/25] Update BUCK --- BUCK | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/BUCK b/BUCK index 9a0e72c2ba..5c95fcc09b 100644 --- a/BUCK +++ b/BUCK @@ -466,7 +466,7 @@ apple_binary( linker_flags = [ "-e", "_WKExtensionMain", - "-l", "-force_load", "WKExtensionMainLegacy", + "-l", "-force_load", "/usr/lib/libWKExtensionMainLegacy.a", ], configs = watch_extension_binary_configs(), frameworks = [ From 6d3946fe20830c3c814f2fd7664bc51e33e218de Mon Sep 17 00:00:00 2001 From: Peter Iakovlev Date: Wed, 20 Nov 2019 09:27:50 +0000 Subject: [PATCH 03/25] Revert BUCK [skip ci] --- BUCK | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/BUCK b/BUCK index 5c95fcc09b..aa8a301c7e 100644 --- a/BUCK +++ b/BUCK @@ -466,7 +466,7 @@ apple_binary( linker_flags = [ "-e", "_WKExtensionMain", - "-l", "-force_load", "/usr/lib/libWKExtensionMainLegacy.a", + "-lWKExtensionMainLegacy", ], configs = watch_extension_binary_configs(), frameworks = [ From 888be4247136e6674c6a465463f3126c13ff803a Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 20:15:08 +0400 Subject: [PATCH 04/25] verify --- Makefile | 2 +- .../certs/distribution}/SelfSigned.p12 | Bin ...db2-42b4-9215-d8544da24da1.mobileprovision | Bin ...b03-4327-b13e-5a81d77a417f.mobileprovision | Bin ...9b0-43a9-81dc-c5db42768deb.mobileprovision | Bin ...214-4456-96f3-3beab43c8a49.mobileprovision | Bin ...a34-4f37-9bdf-d93d7e67f935.mobileprovision | Bin ...e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision | Bin ...88a-4de9-846a-bc207ea9b8dd.mobileprovision | Bin ...353-4f44-8022-979f48e73c04.mobileprovision | Bin build-system/verify.sh | 51 ++++++++ buildbox/build-telegram.sh | 2 +- .../certs/distribution/SelfSigned.p12 | Bin 0 -> 5280 bytes ...db2-42b4-9215-d8544da24da1.mobileprovision | Bin 0 -> 5920 bytes ...b03-4327-b13e-5a81d77a417f.mobileprovision | Bin 0 -> 4644 bytes ...9b0-43a9-81dc-c5db42768deb.mobileprovision | Bin 0 -> 4625 bytes ...214-4456-96f3-3beab43c8a49.mobileprovision | Bin 0 -> 4667 bytes ...a34-4f37-9bdf-d93d7e67f935.mobileprovision | Bin 0 -> 4641 bytes ...e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision | Bin 0 -> 4682 bytes ...88a-4de9-846a-bc207ea9b8dd.mobileprovision | Bin 0 -> 4667 bytes ...353-4f44-8022-979f48e73c04.mobileprovision | Bin 0 -> 4627 bytes buildbox/generate_fake_codesigning.sh | 2 + buildbox/guest-build-telegram.sh | 110 +++++++++--------- 23 files changed, 108 insertions(+), 59 deletions(-) rename {buildbox/fake-codesigning/certs => build-system/fake-codesigning/certs/distribution}/SelfSigned.p12 (100%) rename {buildbox/fake-codesigning/profiles => build-system/fake-codesigning/profiles/appstore}/self_17a6dde8-0db2-42b4-9215-d8544da24da1.mobileprovision (100%) rename {buildbox/fake-codesigning/profiles => build-system/fake-codesigning/profiles/appstore}/self_38e2d395-3b03-4327-b13e-5a81d77a417f.mobileprovision (100%) rename {buildbox/fake-codesigning/profiles => build-system/fake-codesigning/profiles/appstore}/self_66d9e1ed-89b0-43a9-81dc-c5db42768deb.mobileprovision (100%) rename {buildbox/fake-codesigning/profiles => build-system/fake-codesigning/profiles/appstore}/self_a064880e-5214-4456-96f3-3beab43c8a49.mobileprovision (100%) rename {buildbox/fake-codesigning/profiles => build-system/fake-codesigning/profiles/appstore}/self_c7ce0e4f-4a34-4f37-9bdf-d93d7e67f935.mobileprovision (100%) rename {buildbox/fake-codesigning/profiles => build-system/fake-codesigning/profiles/appstore}/self_d5420e53-0e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision (100%) rename {buildbox/fake-codesigning/profiles => build-system/fake-codesigning/profiles/appstore}/self_f5d6daf2-b88a-4de9-846a-bc207ea9b8dd.mobileprovision (100%) rename {buildbox/fake-codesigning/profiles => build-system/fake-codesigning/profiles/appstore}/self_fd2bced7-6353-4f44-8022-979f48e73c04.mobileprovision (100%) create mode 100644 build-system/verify.sh create mode 100644 buildbox/fake-codesigning/certs/distribution/SelfSigned.p12 create mode 100644 buildbox/fake-codesigning/profiles/appstore/self_17a6dde8-0db2-42b4-9215-d8544da24da1.mobileprovision create mode 100644 buildbox/fake-codesigning/profiles/appstore/self_38e2d395-3b03-4327-b13e-5a81d77a417f.mobileprovision create mode 100644 buildbox/fake-codesigning/profiles/appstore/self_66d9e1ed-89b0-43a9-81dc-c5db42768deb.mobileprovision create mode 100644 buildbox/fake-codesigning/profiles/appstore/self_a064880e-5214-4456-96f3-3beab43c8a49.mobileprovision create mode 100644 buildbox/fake-codesigning/profiles/appstore/self_c7ce0e4f-4a34-4f37-9bdf-d93d7e67f935.mobileprovision create mode 100644 buildbox/fake-codesigning/profiles/appstore/self_d5420e53-0e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision create mode 100644 buildbox/fake-codesigning/profiles/appstore/self_f5d6daf2-b88a-4de9-846a-bc207ea9b8dd.mobileprovision create mode 100644 buildbox/fake-codesigning/profiles/appstore/self_fd2bced7-6353-4f44-8022-979f48e73c04.mobileprovision create mode 100644 buildbox/generate_fake_codesigning.sh diff --git a/Makefile b/Makefile index 86cb7456a9..fbc92fdae8 100644 --- a/Makefile +++ b/Makefile @@ -356,7 +356,7 @@ build_verbose: check_env //:NotificationContentExtension#dwarf-and-dsym,iphoneos-arm64 \ //:NotificationServiceExtension#dwarf-and-dsym,iphoneos-arm64 \ //:IntentsExtension#dwarf-and-dsym,iphoneos-arm64 \ - --verbose 8 ${BUCK_OPTIONS} ${BUCK_THREADS_OPTIONS} ${BUCK_DEBUG_OPTIONS} + --verbose 8 ${BUCK_OPTIONS} ${BUCK_THREADS_OPTIONS} ${BUCK_DEBUG_OPTIONS} ${BUCK_CACHE_OPTIONS} deps: check_env $(BUCK) query "deps(//:AppPackage)" --dot \ diff --git a/buildbox/fake-codesigning/certs/SelfSigned.p12 b/build-system/fake-codesigning/certs/distribution/SelfSigned.p12 similarity index 100% rename from buildbox/fake-codesigning/certs/SelfSigned.p12 rename to build-system/fake-codesigning/certs/distribution/SelfSigned.p12 diff --git a/buildbox/fake-codesigning/profiles/self_17a6dde8-0db2-42b4-9215-d8544da24da1.mobileprovision b/build-system/fake-codesigning/profiles/appstore/self_17a6dde8-0db2-42b4-9215-d8544da24da1.mobileprovision similarity index 100% rename from buildbox/fake-codesigning/profiles/self_17a6dde8-0db2-42b4-9215-d8544da24da1.mobileprovision rename to build-system/fake-codesigning/profiles/appstore/self_17a6dde8-0db2-42b4-9215-d8544da24da1.mobileprovision diff --git a/buildbox/fake-codesigning/profiles/self_38e2d395-3b03-4327-b13e-5a81d77a417f.mobileprovision b/build-system/fake-codesigning/profiles/appstore/self_38e2d395-3b03-4327-b13e-5a81d77a417f.mobileprovision similarity index 100% rename from buildbox/fake-codesigning/profiles/self_38e2d395-3b03-4327-b13e-5a81d77a417f.mobileprovision rename to build-system/fake-codesigning/profiles/appstore/self_38e2d395-3b03-4327-b13e-5a81d77a417f.mobileprovision diff --git a/buildbox/fake-codesigning/profiles/self_66d9e1ed-89b0-43a9-81dc-c5db42768deb.mobileprovision b/build-system/fake-codesigning/profiles/appstore/self_66d9e1ed-89b0-43a9-81dc-c5db42768deb.mobileprovision similarity index 100% rename from buildbox/fake-codesigning/profiles/self_66d9e1ed-89b0-43a9-81dc-c5db42768deb.mobileprovision rename to build-system/fake-codesigning/profiles/appstore/self_66d9e1ed-89b0-43a9-81dc-c5db42768deb.mobileprovision diff --git a/buildbox/fake-codesigning/profiles/self_a064880e-5214-4456-96f3-3beab43c8a49.mobileprovision b/build-system/fake-codesigning/profiles/appstore/self_a064880e-5214-4456-96f3-3beab43c8a49.mobileprovision similarity index 100% rename from buildbox/fake-codesigning/profiles/self_a064880e-5214-4456-96f3-3beab43c8a49.mobileprovision rename to build-system/fake-codesigning/profiles/appstore/self_a064880e-5214-4456-96f3-3beab43c8a49.mobileprovision diff --git a/buildbox/fake-codesigning/profiles/self_c7ce0e4f-4a34-4f37-9bdf-d93d7e67f935.mobileprovision b/build-system/fake-codesigning/profiles/appstore/self_c7ce0e4f-4a34-4f37-9bdf-d93d7e67f935.mobileprovision similarity index 100% rename from buildbox/fake-codesigning/profiles/self_c7ce0e4f-4a34-4f37-9bdf-d93d7e67f935.mobileprovision rename to build-system/fake-codesigning/profiles/appstore/self_c7ce0e4f-4a34-4f37-9bdf-d93d7e67f935.mobileprovision diff --git a/buildbox/fake-codesigning/profiles/self_d5420e53-0e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision b/build-system/fake-codesigning/profiles/appstore/self_d5420e53-0e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision similarity index 100% rename from buildbox/fake-codesigning/profiles/self_d5420e53-0e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision rename to build-system/fake-codesigning/profiles/appstore/self_d5420e53-0e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision diff --git a/buildbox/fake-codesigning/profiles/self_f5d6daf2-b88a-4de9-846a-bc207ea9b8dd.mobileprovision b/build-system/fake-codesigning/profiles/appstore/self_f5d6daf2-b88a-4de9-846a-bc207ea9b8dd.mobileprovision similarity index 100% rename from buildbox/fake-codesigning/profiles/self_f5d6daf2-b88a-4de9-846a-bc207ea9b8dd.mobileprovision rename to build-system/fake-codesigning/profiles/appstore/self_f5d6daf2-b88a-4de9-846a-bc207ea9b8dd.mobileprovision diff --git a/buildbox/fake-codesigning/profiles/self_fd2bced7-6353-4f44-8022-979f48e73c04.mobileprovision b/build-system/fake-codesigning/profiles/appstore/self_fd2bced7-6353-4f44-8022-979f48e73c04.mobileprovision similarity index 100% rename from buildbox/fake-codesigning/profiles/self_fd2bced7-6353-4f44-8022-979f48e73c04.mobileprovision rename to build-system/fake-codesigning/profiles/appstore/self_fd2bced7-6353-4f44-8022-979f48e73c04.mobileprovision diff --git a/build-system/verify.sh b/build-system/verify.sh new file mode 100644 index 0000000000..df4150211b --- /dev/null +++ b/build-system/verify.sh @@ -0,0 +1,51 @@ +#!/bin/bash + +export TELEGRAM_ENV_SET="1" + +export DEVELOPMENT_CODE_SIGN_IDENTITY="iPhone Distribution: Digital Fortress LLC (C67CF9S4VU)" +export DISTRIBUTION_CODE_SIGN_IDENTITY="iPhone Distribution: Digital Fortress LLC (C67CF9S4VU)" +export DEVELOPMENT_TEAM="C67CF9S4VU" + +export API_ID="8" +export API_HASH="7245de8e747a0d6fbe11f7cc14fcc0bb" + +export BUNDLE_ID="ph.telegra.Telegraph" +export IS_INTERNAL_BUILD="false" +export IS_APPSTORE_BUILD="true" +export APPSTORE_ID="686449807" +export APP_SPECIFIC_URL_SCHEME="tgapp" + +if [ -z "$BUILD_NUMBER" ]; then + echo "BUILD_NUMBER is not defined" + exit 1 +fi + +export ENTITLEMENTS_APP="Telegram-iOS/Telegram-iOS-AppStoreLLC.entitlements" +export DEVELOPMENT_PROVISIONING_PROFILE_APP="match Development ph.telegra.Telegraph" +export DISTRIBUTION_PROVISIONING_PROFILE_APP="match AppStore ph.telegra.Telegraph" +export ENTITLEMENTS_EXTENSION_SHARE="Share/Share-AppStoreLLC.entitlements" +export DEVELOPMENT_PROVISIONING_PROFILE_EXTENSION_SHARE="match Development ph.telegra.Telegraph.Share" +export DISTRIBUTION_PROVISIONING_PROFILE_EXTENSION_SHARE="match AppStore ph.telegra.Telegraph.Share" +export ENTITLEMENTS_EXTENSION_WIDGET="Widget/Widget-AppStoreLLC.entitlements" +export DEVELOPMENT_PROVISIONING_PROFILE_EXTENSION_WIDGET="match Development ph.telegra.Telegraph.Widget" +export DISTRIBUTION_PROVISIONING_PROFILE_EXTENSION_WIDGET="match AppStore ph.telegra.Telegraph.Widget" +export ENTITLEMENTS_EXTENSION_NOTIFICATIONSERVICE="NotificationService/NotificationService-AppStoreLLC.entitlements" +export DEVELOPMENT_PROVISIONING_PROFILE_EXTENSION_NOTIFICATIONSERVICE="match Development ph.telegra.Telegraph.NotificationService" +export DISTRIBUTION_PROVISIONING_PROFILE_EXTENSION_NOTIFICATIONSERVICE="match AppStore ph.telegra.Telegraph.NotificationService" +export ENTITLEMENTS_EXTENSION_NOTIFICATIONCONTENT="NotificationContent/NotificationContent-AppStoreLLC.entitlements" +export DEVELOPMENT_PROVISIONING_PROFILE_EXTENSION_NOTIFICATIONCONTENT="match Development ph.telegra.Telegraph.NotificationContent" +export DISTRIBUTION_PROVISIONING_PROFILE_EXTENSION_NOTIFICATIONCONTENT="match AppStore ph.telegra.Telegraph.NotificationContent" +export ENTITLEMENTS_EXTENSION_INTENTS="SiriIntents/SiriIntents-AppStoreLLC.entitlements" +export DEVELOPMENT_PROVISIONING_PROFILE_EXTENSION_INTENTS="match Development ph.telegra.Telegraph.SiriIntents" +export DISTRIBUTION_PROVISIONING_PROFILE_EXTENSION_INTENTS="match AppStore ph.telegra.Telegraph.SiriIntents" +export DEVELOPMENT_PROVISIONING_PROFILE_WATCH_APP="match Development ph.telegra.Telegraph.watchkitapp" +export DISTRIBUTION_PROVISIONING_PROFILE_WATCH_APP="match AppStore ph.telegra.Telegraph.watchkitapp" +export DEVELOPMENT_PROVISIONING_PROFILE_WATCH_EXTENSION="match Development ph.telegra.Telegraph.watchkitapp.watchkitextension" +export DISTRIBUTION_PROVISIONING_PROFILE_WATCH_EXTENSION="match AppStore ph.telegra.Telegraph.watchkitapp.watchkitextension" + +BUILDBOX_DIR="buildbox" + +export CODESIGNING_PROFILES_VARIANT="appstore" +export PACKAGE_METHOD="appstore" + +$@ diff --git a/buildbox/build-telegram.sh b/buildbox/build-telegram.sh index 28a82587be..b901178f21 100644 --- a/buildbox/build-telegram.sh +++ b/buildbox/build-telegram.sh @@ -180,7 +180,7 @@ else fi scp -o LogLevel=ERROR -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -pr "$BUILDBOX_DIR/guest-build-telegram.sh" "$BUILDBOX_DIR/transient-data/source.tar" telegram@"$VM_IP": -ssh -o LogLevel=ERROR -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null telegram@"$VM_IP" -o ServerAliveInterval=60 -t "export TELEGRAM_BUILD_APPSTORE_PASSWORD=\"$TELEGRAM_BUILD_APPSTORE_PASSWORD\"; export TELEGRAM_BUILD_APPSTORE_TEAM_NAME=\"$TELEGRAM_BUILD_APPSTORE_TEAM_NAME\"; export TELEGRAM_BUILD_APPSTORE_USERNAME=\"$TELEGRAM_BUILD_APPSTORE_USERNAME\"; export BUILD_NUMBER=\"$BUILD_NUMBER\"; export COMMIT_ID=\"$COMMIT_ID\"; export COMMIT_AUTHOR=\"$COMMIT_AUTHOR\"; export BUCK_HTTP_CACHE=\"$BUCK_HTTP_CACHE\"; $GUEST_SHELL -l guest-build-telegram.sh $BUILD_CONFIGURATION" || true +ssh -o LogLevel=ERROR -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null telegram@"$VM_IP" -o ServerAliveInterval=60 -t "export TELEGRAM_BUILD_APPSTORE_PASSWORD=\"$TELEGRAM_BUILD_APPSTORE_PASSWORD\"; export TELEGRAM_BUILD_APPSTORE_TEAM_NAME=\"$TELEGRAM_BUILD_APPSTORE_TEAM_NAME\"; export TELEGRAM_BUILD_APPSTORE_USERNAME=\"$TELEGRAM_BUILD_APPSTORE_USERNAME\"; export BUILD_NUMBER=\"$BUILD_NUMBER\"; export COMMIT_ID=\"$COMMIT_ID\"; export COMMIT_AUTHOR=\"$COMMIT_AUTHOR\"; export BUCK_HTTP_CACHE=\"$BUCK_HTTP_CACHE\"; export BUCK_DIR_CACHE=\"$BUCK_DIR_CACHE\"; export BUCK_CACHE_MODE=\"$BUCK_CACHE_MODE\"; $GUEST_SHELL -l guest-build-telegram.sh $BUILD_CONFIGURATION" || true OUTPUT_PATH="build/artifacts" rm -rf "$OUTPUT_PATH" diff --git a/buildbox/fake-codesigning/certs/distribution/SelfSigned.p12 b/buildbox/fake-codesigning/certs/distribution/SelfSigned.p12 new file mode 100644 index 0000000000000000000000000000000000000000..aa2097875be6cd0403d05afdbe2c4cd51f819d27 GIT binary patch literal 5280 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 u;J`-%QDOklp+vAUXqJ!LsWy5;EicIU8NK}g literal 0 HcmV?d00001 diff --git a/buildbox/fake-codesigning/profiles/appstore/self_17a6dde8-0db2-42b4-9215-d8544da24da1.mobileprovision b/buildbox/fake-codesigning/profiles/appstore/self_17a6dde8-0db2-42b4-9215-d8544da24da1.mobileprovision new file mode 100644 index 0000000000000000000000000000000000000000..1aa18b471441f895689096e65b5ce1b941ba3bad GIT binary patch literal 5920 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 S?n@juF`A7>ZcLxRy#E6Bb;t1l literal 0 HcmV?d00001 diff --git a/buildbox/fake-codesigning/profiles/appstore/self_38e2d395-3b03-4327-b13e-5a81d77a417f.mobileprovision b/buildbox/fake-codesigning/profiles/appstore/self_38e2d395-3b03-4327-b13e-5a81d77a417f.mobileprovision new file mode 100644 index 0000000000000000000000000000000000000000..fd919b2eaf93633e8f19776978701e99aaa34bd5 GIT binary patch literal 4644 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 lf4$ZT(Dl$e5qI{Plj$`#0k95YYet literal 0 HcmV?d00001 diff --git a/buildbox/fake-codesigning/profiles/appstore/self_66d9e1ed-89b0-43a9-81dc-c5db42768deb.mobileprovision b/buildbox/fake-codesigning/profiles/appstore/self_66d9e1ed-89b0-43a9-81dc-c5db42768deb.mobileprovision new file mode 100644 index 0000000000000000000000000000000000000000..9c07924826d4c6bc9134d5a77c09cf008f2e57f3 GIT binary patch literal 4625 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 W{p+TzNiN*HeDO0oU%vek=lvU%gZ&Kv literal 0 HcmV?d00001 diff --git a/buildbox/fake-codesigning/profiles/appstore/self_a064880e-5214-4456-96f3-3beab43c8a49.mobileprovision b/buildbox/fake-codesigning/profiles/appstore/self_a064880e-5214-4456-96f3-3beab43c8a49.mobileprovision new file mode 100644 index 0000000000000000000000000000000000000000..e51dbf5f7ac4e495379640cff796a426f7d9fcb8 GIT binary patch literal 4667 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 literal 0 HcmV?d00001 diff --git a/buildbox/fake-codesigning/profiles/appstore/self_c7ce0e4f-4a34-4f37-9bdf-d93d7e67f935.mobileprovision b/buildbox/fake-codesigning/profiles/appstore/self_c7ce0e4f-4a34-4f37-9bdf-d93d7e67f935.mobileprovision new file mode 100644 index 0000000000000000000000000000000000000000..6fbbd2bde979b9fc04bcdec0f2c8806628e5ed52 GIT binary patch literal 4641 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 b&o3@N@yL-onJvHm$yf0EFC0x>=Dhy^=@bR| literal 0 HcmV?d00001 diff --git a/buildbox/fake-codesigning/profiles/appstore/self_d5420e53-0e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision b/buildbox/fake-codesigning/profiles/appstore/self_d5420e53-0e9a-4745-ab22-1dc7f0f8f0e6.mobileprovision new file mode 100644 index 0000000000000000000000000000000000000000..86b7d0a3f85f70de6a284f409da68879cf721289 GIT binary patch literal 4682 zcmdT|d2k!$6}K$gL3VCJ;syf3ga8q;c4b*dke%7pu4Nsodvzt4taewc)veW9E2$I` z(*!1@5RNcFLNO3%3p7AW2+)M95K4v|B%w5rtE3R;Xi1YHM~8;499uTv4*fIT8O`kb zzNh!z_j~Vqzb65U8)S2rbuT+JK{Bqke=)GQRw4nL09ix5VxqKmW_=AXNeEx4~ssc)Iz*=W2PahiM~7b?#t**q_I z;jrCelD8;TDkz&x(kd0=L*y>I#p{!cHdHFq(IRh&@qBikN+k$FD^byEB{QjtVqWFq zGFh7AOLoziQv5$6h;grS(4zzEel1bc{a+@oQtEQY_V#R;5cHmZIf1K z>N0pWetfhwRaLDLiHV~JjUog;5*sB7ooWEoD?vc1R{KERJOG^6)*d#h2DgS{awQ2q zn&DDE2%vg8*6AI~wOo7#VX@?cV$x`gND~ZA4cQsojS|T`tr~_8p$l}fg1t$EUp%@9 z1f3tltr#8AiCHWN?=zX8teSxY3k)&h#|JrJCXtIJShGO@V91^Cf)EqT#8DN70A>ip zQAiNfgdfgC)a^+N>dBIAo)QtTf|NN~h{Q9D$DB+PK~F4Vg3XaOD?q0FWwHcgJ``hY zD5iD*4ztsb0sbVO#XNvu7D9;M?Y1GX2PFbjmNIwcEoitvrah%_&{4LaMa*4BeHe@m z`Zo!J&0P+)xq(nSUiJk1KGcpuiNQTMhMD|+Oz4i04$PMju(+j!#Ua5Fhf0CUT6}P= zSY3<%|DBCtP!@v#v&ow?do7VR#Epu1!XZdwfe`@`#C;o-5p(HAm?Eh*hsvrpuOa8| zQV^^)*F(;r7)d3P)>p+loU!Hyf<3%s`9>c(w@gLZ;8P;*6Je?PG>l$(YsW( zB$*Et6KN-n0cg-ishs(s$r?kkHZDVE6oDe=VtEE}`O=1X-0r76Y*(8lO9w)@-UUW* zjn^!6CwX-d?9SNo;Wn&S2oZvUG8Eg(JX7q|mTAftC+uFmyW~x1g2fns1X-}`!OON{ z9BrrFUN^5wCIE2Ft!@&&N1-nTEhC&vb5Q1Sh-VF(ufVe|eTPAFY6-WoEcyIr<+uP<$-O8H=dgzaQX-xdHo4u(^h z%>d-*g@hAK2>y783zW%#T}^m`P>u*;WKkdM4gy{IR5?JRRJ^RvH~?!j>qkIy%+Io1 z*-|#8oEFRnshwu0-W@r^@`8Ws71PtqxoH%7YV5ItSs zCy@%s7{R8M1WD5QyprKEz1ga+%s9*$vTAD|A(z&<)gCXCHHsR;?#0&%#V|Cl6s}wh)KE#Kk{AOdV`~~`K9imZjMX2y-g5^bX)pvRf zR=wa=%%VkEM>#Y!Jr7T8IBxo_qa{rzB4a3y0ou@I(Ygd1d`o|h&QiBtW zIO%x#3`fhy!las!AIr{Q;rK*EMuwf?N*Jld;TdYABt{`KQiWApV+D<{j94p4d6$SC zCsw}PZa0m#Qi0dUrf6TrJ_=PMo91bT<~rN78l!4h7`kmZZb7QS4plAHu2BPYdz%uV z4TMso)3hszh+3@#DN+{&qWUO6YrpT-e__0>ni_Tkj`BF1Q=@8d2JLLD8GQQtq^|*e z()B=J?PLAYT1l-qRRa^MleVNuoU51gf%Acm1}R=A9j|3wu}qqlBjRAov60@&m^n|B zeu$0y`Vq8m0A~T0R}3_cpEi~*cquTYvfVVkapX&b!@aoJaA_^>1+JVi0W<(=@c{rW zpbpQNpstAEka%$f*(Yfk4W6XFM%pKtR0H%$8f*I`lA43>ZCysrKV$oJ<%}<%oZ~*Z zWKaFetzWindT86t+>{U1sO|9&RL319+e@aYTcnD+9{hCWp+}y(chWb%S@_ZlYR%yl zJJ4Oispl8A5R;W+Hs2kc}2dqB2NdVHC&=-kkr?Ylh#$=q@!^ai&Df@Qgg@A z+|xbN-r70m^sTF6tKXO#uHE43fARS3%vWZa^2BTvcJAGAq3NrpKJfXR&L`Kex%1ww zskeQ5mM?q4s$R2wrm|=9{(HkW6Hn#3e>LtP+r0F%)$cUwbhk9DyX)zr9|`OBO1+tZ z0qDKw_99;era0%UU3Aap-N4m1_DqO}j*kN--szvL&G&Df^gxHvvW?fD{k`?UzVa;a zO!GJWuOIL}+p)`=_P&K23(rwXw|p`C@U?rN?=ef1A8g#0nxbty-<+!P@11>92=Hqa z3v|;}(fbxQKDy|A@Z^+Fb}X2)m8mNj&mY_;yKR+ecMM-X_tZ7OGx|F&m6FSDdV95J z^Un@>4;?XqeNv@(d2guP*(G;f6jz`U%E(Xh{ys?wXs&h>nG|fQ3gaZeHB~`Y2Tre> zHe=Ji$T?cw^Y?iT2ljq8VSVza!g^rIBMmaK9O@)}y2*9mlDjXalP+1^&@}X)gluwc zlNeq9MU;n8ZCva`b$ybW9hcY7*njAYYcHF5_P*BsuKo8s%$+(wNw@#uZ+HHS0?zNh zycJ)1K)(fVy6*m211F`9t2TjqdQPlcT|D_)|CX!%eB;ied)|3^&5>Kyo<;{YkUKRq zUufo=fnB!orFT|X*If3@hXdKQz3)Bh^7uZNns9b{cOrVtjlT=&w*O+&AJ?8*d8l5p zN~xH+v6imSetk4B^)|z;q21o)_KkOcxuoHiPlH7#x$&D%j+`mIGO*$17Wa{d zUg->c`|IdZxAyfv9e(!ZU6VAom+NOtJoAszo9}imZ4DB4ATK@srtRF0%edDMziQ)7 ncG#{sv%-J-t#6%J2rPep(Fuc>CaEeP=mYx7B@(a}sIHtMpDrz*Go=iepdcCOo8MQ_ zUt8P0IG2davNV@rQ^}4duo-BQ(Mc*5Vv|fq6XEVsXqy&y*0f)W+VpO}9h0TwY=)QF z3B+R5%bFBQC7e#jX{8c%qcXe2=yJngscw(a`A*TD5w(&Dx?Ncm#nlYYiNSWd z={U`BWI7_Vrg%2YQY0@P$whNnmJ*dmwZ^T)M>UKgI$6}GIXg#(*<8sk$#LXF2YR(e z-=%Y@Jj6t6%92_!96d)5yG2QUJiw4BbV2~AQvjd>YITF^HdSjIpbfMuhqp#!vd2k2 zoZ=Ec37~XD*5;bbwM=}5u`y}lq}K$74DoC*nqr)Wc#`xvBSAf42)392D&Z+mc?5T3IAg|e z$O>2uHV+PX;zSyE0)j#CqaKIDj3Q2q^oG(QLs!O#1+rAqnGg7^1tXTj9Rxd?#zSg_zE3g%oC zYo#472d|9Dvxo)i>6J%AI#Udk=VIANG-Sh5T#}8c5)q9jrbz~r>4?uQkF%VONtmoE zJzz5SxMNYm8n!Zlc(TVN&*ZsYpG`-AdX?Spr-*Kqk9A~$0O>R$0n8qZxB^**(0kQd zE0x!E+3kYXtETj5FcX1wJj~z-3>%_W6wc$Ys#td+RKO6W;1KVIv713*24Sq8ZWn>T zVJ+4bg$aaVIE2Bv5C?@Ku-|AF{0QP8x?uqqP>0`SP6dpSEM%!M2&3z`W-;jB}L@mjqj>kcO|1dMs(PP1FZ`sFFkOGQ*l zYmn+9Ab*b`MWpgcTuWL!Do0C7NBX>mC`GVIM2@5lMqedkHOqslimj;;@@rUGAhQl+XBL6k?$g+7>V1v@)FB zU;tnbFT`wMOz=egoVP%EEfDGS!9AoOr*hgzw-4ybBnn;%3q=cZl@&0B(;gHwL_93Z z6^sRa!e+$XFk~~>w1yy&3FuUyJ*p<~j^XA^7F*_6i?11N)R@Q@e4I{*yfNN2M>%SQ zq(my9A|#tskQ7B{G75%E^`=X@)$L=PQC({7K?ui(i{ zOhLxuDPgQ@SGSj1{D@kSa7P(V!Img)Tz!-eC-_ZAn)wk9Z7y+X^UrhXh%1rRNBKQN zQ@tF^=ZD2H@4tNbVU6a={Fk7Z1c-6Bp)o!a4?rgVx8wfEauL@c&65g_PNz6NBj$}~ zvn2+vZs)n)B7GK%Vd5}?<aG(fv@Oc=dc1Ytx=!H!mFxHY5>kzq&?)M`nEDn#oPT9ukq z1Sts6(4;P?4T+=9kHMJ+yOesBHkPq!^_oLTYil*gMtZF%;N z{a14{UWYLAJ+CTHTJz>d^cU}w%5UEI-ujR3dg!*gZy#Lx$lB1B&(8GXKi<#h!y7Ui$F7CD~UT#~1Dupp%WUx~=Et zW&SiZc|x<*s=n3y5@fQ@-aA*iOp(DX`}Tsme8u`Fzv+DD;E6q~%q8fUGEAUX*764V4$kD!P>fgUDa5cHTr~84bV{GHfzi)oAMx*&nZNcVj*|Fg@F>{@1!C|-T$Xkv!C=KID(ndiv-tNegREnlLUr3~M`wC3*R zuYhM}96GRM!5~wSZU6q*(dz3r=?_MTH4BF>1Mb(}I8#cky6T0^&b`-ts9_wI!iS0$f%Ssw==*6%BT`Zu!p27w*h2 z|9)P_Ys5_(A(&vfeR=P6WX}g zi7NUfW!FBwb{F!)Jca$Ymz=AOMsFEfyXVk#J9BR?+OnT_4PCVFOJGs?4br+Zd*)W$ ze$QcBV)vfF*H`SB-S(@$zIynoZ%)5=@NWx0-co;m!`Voi=P%~@TRW!Dz5e>{LjCeT zR~!m_`T0>}(tKuR?S@-kd}@8tNwm!Q!9(b`|MA5ghM9q(wcDQ6_E9@O_-@66%7-^^ zI{xyahaNzqORAR0H)juPzWjIw`P`uL^2BFCs@1;k%xdpz*F4|2qh|2C2L9Ij(RKem z-79%|Fl<}$?XeS{`y8$3n{W7M-z#s=xaKBwTXxX*hrvMC-A$TB8|zx2)sGDws0UtJ c|F4s$%0HAW^)6S;#M%V$*<_PEg2RE4x7ytkO literal 0 HcmV?d00001 diff --git a/buildbox/fake-codesigning/profiles/appstore/self_fd2bced7-6353-4f44-8022-979f48e73c04.mobileprovision b/buildbox/fake-codesigning/profiles/appstore/self_fd2bced7-6353-4f44-8022-979f48e73c04.mobileprovision new file mode 100644 index 0000000000000000000000000000000000000000..e2e79540164dcaf3afaf73bc55d52655bd35dc46 GIT binary patch literal 4627 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 ZKYROzYlW8&+1^FIJ+bHDKW}i}zW{br|Fi%A literal 0 HcmV?d00001 diff --git a/buildbox/generate_fake_codesigning.sh b/buildbox/generate_fake_codesigning.sh new file mode 100644 index 0000000000..05a7907cf5 --- /dev/null +++ b/buildbox/generate_fake_codesigning.sh @@ -0,0 +1,2 @@ +#!/bin/bash + diff --git a/buildbox/guest-build-telegram.sh b/buildbox/guest-build-telegram.sh index 2b1ea2a1fc..99ea747998 100644 --- a/buildbox/guest-build-telegram.sh +++ b/buildbox/guest-build-telegram.sh @@ -1,5 +1,7 @@ #!/bin/sh +set -x + if [ -z "BUILD_NUMBER" ]; then echo "BUILD_NUMBER is not set" exit 1 @@ -11,15 +13,12 @@ if [ -z "COMMIT_ID" ]; then fi if [ "$1" == "hockeyapp" ] || [ "$1" == "testinghockeyapp" ]; then - FASTLANE_BUILD_CONFIGURATION="internalhockeyapp" CERTS_PATH="codesigning_data/certs" PROFILES_PATH="codesigning_data/profiles" elif [ "$1" == "testinghockeyapp-local" ]; then - FASTLANE_BUILD_CONFIGURATION="testinghockeyapp" CERTS_PATH="codesigning_data/certs" PROFILES_PATH="codesigning_data/profiles" elif [ "$1" == "appstore" ]; then - FASTLANE_BUILD_CONFIGURATION="testflight_llc" if [ -z "$TELEGRAM_BUILD_APPSTORE_PASSWORD" ]; then echo "TELEGRAM_BUILD_APPSTORE_PASSWORD is not set" exit 1 @@ -31,16 +30,9 @@ elif [ "$1" == "appstore" ]; then FASTLANE_ITC_USERNAME="$TELEGRAM_BUILD_APPSTORE_USERNAME" FASTLANE_PASSWORD="$TELEGRAM_BUILD_APPSTORE_PASSWORD" FASTLANE_ITC_TEAM_NAME="$TELEGRAM_BUILD_APPSTORE_TEAM_NAME" - CERTS_PATH="codesigning_data/certs" - PROFILES_PATH="codesigning_data/profiles" elif [ "$1" == "verify" ]; then - FASTLANE_BUILD_CONFIGURATION="build_for_appstore" - CERTS_PATH="codesigning_data/certs" - PROFILES_PATH="codesigning_data/profiles" -elif [ "$1" == "verify-local" ]; then - FASTLANE_BUILD_CONFIGURATION="build_for_appstore" - CERTS_PATH="buildbox/fake-codesigning/certs" - PROFILES_PATH="buildbox/fake-codesigning/profiles" + CERTS_PATH="buildbox/build-system/fake-codesigning/certs/distribution" + PROFILES_PATH="buildbox/build-system/fake-codesigning/profiles" else echo "Unknown configuration $1" exit 1 @@ -58,7 +50,7 @@ security set-keychain-settings "$MY_KEYCHAIN" security unlock-keychain -p "$MY_KEYCHAIN_PASSWORD" "$MY_KEYCHAIN" for f in $(ls "$CERTS_PATH"); do - fastlane run import_certificate "certificate_path:$CERTS_PATH/$f" keychain_name:"$MY_KEYCHAIN" keychain_password:"$MY_KEYCHAIN_PASSWORD" log_output:true + "$HOME/.fastlane/bin/fastlane" run import_certificate "certificate_path:$CERTS_PATH/$f" keychain_name:"$MY_KEYCHAIN" keychain_password:"$MY_KEYCHAIN_PASSWORD" log_output:true done mkdir -p "$HOME/Library/MobileDevice/Provisioning Profiles" @@ -69,19 +61,16 @@ for f in $(ls "$PROFILES_PATH"); do cp -f "$PROFILE_PATH" "$HOME/Library/MobileDevice/Provisioning Profiles/$uuid.mobileprovision" done -if [ "$1" == "verify-local" ]; then - fastlane "$FASTLANE_BUILD_CONFIGURATION" -else - SOURCE_PATH="telegram-ios" +SOURCE_PATH="telegram-ios" - if [ -d "$SOURCE_PATH" ]; then - echo "Directory $SOURCE_PATH should not exist" - exit 1 - fi - - mkdir "$SOURCE_PATH" +if [ -d "$SOURCE_PATH" ]; then + echo "Directory $SOURCE_PATH should not exist" + exit 1 +fi +mkdir "$SOURCE_PATH" +if [ "$1" != "verify" ]; then SIZE_IN_BLOCKS=$((12*1024*1024*1024/512)) DEV=`hdid -nomount ram://$SIZE_IN_BLOCKS` @@ -95,38 +84,45 @@ else echo "Error creating ramdisk" exit 1 fi - - echo "Unpacking files..." - - mkdir -p "$SOURCE_PATH/buildbox" - mkdir -p "$SOURCE_PATH/buildbox/transient-data" - cp -r "$HOME/codesigning_teams" "$SOURCE_PATH/buildbox/transient-data/teams" - - BASE_DIR=$(pwd) - cd "$SOURCE_PATH" - tar -xf "../source.tar" - - if [ "$1" == "hockeyapp" ]; then - BUILD_ENV_SCRIPT="internal" - FASTLANE_BUILD_CONFIGURATION="internalhockeyapp" - APP_TARGET="app_arm64" - elif [ "$1" == "appstore" ]; then - BUILD_ENV_SCRIPT="appstore" - FASTLANE_BUILD_CONFIGURATION="testflight_llc" - APP_TARGET="app" - else - echo "Unsupported configuration $1" - exit 1 - fi - - BUCK="$(pwd)/tools/buck" BUCK_HTTP_CACHE="$BUCK_HTTP_CACHE" LOCAL_CODESIGNING=1 sh "../telegram-ios-shared/buildbox/bin/$BUILD_ENV_SCRIPT.sh" make "$APP_TARGET" - - OUTPUT_PATH="build/artifacts" - rm -rf "$OUTPUT_PATH" - mkdir -p "$OUTPUT_PATH" - - cp "build/Telegram_signed.ipa" "./$OUTPUT_PATH/Telegram.ipa" - cp "build/DSYMs.zip" "./$OUTPUT_PATH/Telegram.DSYMs.zip" - - cd "$BASE_DIR" fi + +echo "Unpacking files..." + +mkdir -p "$SOURCE_PATH/buildbox" +mkdir -p "$SOURCE_PATH/buildbox/transient-data" +cp -r "$HOME/codesigning_teams" "$SOURCE_PATH/buildbox/transient-data/teams" + +BASE_DIR=$(pwd) +cd "$SOURCE_PATH" +tar -xf "../source.tar" + +if [ "$1" == "hockeyapp" ]; then + BUILD_ENV_SCRIPT="../telegram-ios-shared/buildbox/bin/internal.sh" + APP_TARGET="app_arm64" +elif [ "$1" == "appstore" ]; then + BUILD_ENV_SCRIPT="../telegram-ios-shared/buildbox/bin/appstore.sh" + APP_TARGET="app" +elif [ "$1" == "verify" ]; then + BUILD_ENV_SCRIPT="build-system/verify.sh" + APP_TARGET="app" + APP_TARGET="build_verbose" + export CODESIGNING_DATA_PATH="build-system/fake-codesigning" +else + echo "Unsupported configuration $1" + exit 1 +fi + +if [ -d "$BUCK_DIR_CACHE" ]; then + sudo chown telegram "$BUCK_DIR_CACHE" +fi + +BUCK="$(pwd)/tools/buck" BUCK_HTTP_CACHE="$BUCK_HTTP_CACHE" BUCK_CACHE_MODE="$BUCK_CACHE_MODE" BUCK_DIR_CACHE="$BUCK_DIR_CACHE" LOCAL_CODESIGNING=1 sh "$BUILD_ENV_SCRIPT" make "$APP_TARGET" + +OUTPUT_PATH="build/artifacts" +rm -rf "$OUTPUT_PATH" +mkdir -p "$OUTPUT_PATH" + +cp "build/Telegram_signed.ipa" "./$OUTPUT_PATH/Telegram.ipa" +cp "build/DSYMs.zip" "./$OUTPUT_PATH/Telegram.DSYMs.zip" + +cd "$BASE_DIR" From fd8e7d6e780185e5a28233cf7cc28ea889623c77 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 21:57:07 +0400 Subject: [PATCH 05/25] Fix certificate and profile import --- buildbox/guest-build-telegram.sh | 31 ++++++++++++++++--------------- 1 file changed, 16 insertions(+), 15 deletions(-) diff --git a/buildbox/guest-build-telegram.sh b/buildbox/guest-build-telegram.sh index 99ea747998..1614fde691 100644 --- a/buildbox/guest-build-telegram.sh +++ b/buildbox/guest-build-telegram.sh @@ -31,8 +31,8 @@ elif [ "$1" == "appstore" ]; then FASTLANE_PASSWORD="$TELEGRAM_BUILD_APPSTORE_PASSWORD" FASTLANE_ITC_TEAM_NAME="$TELEGRAM_BUILD_APPSTORE_TEAM_NAME" elif [ "$1" == "verify" ]; then - CERTS_PATH="buildbox/build-system/fake-codesigning/certs/distribution" - PROFILES_PATH="buildbox/build-system/fake-codesigning/profiles" + CERTS_PATH="build-system/fake-codesigning/certs/distribution" + PROFILES_PATH="build-system/fake-codesigning/profiles" else echo "Unknown configuration $1" exit 1 @@ -49,18 +49,6 @@ security list-keychains -d user -s "$MY_KEYCHAIN" $(security list-keychains -d u security set-keychain-settings "$MY_KEYCHAIN" security unlock-keychain -p "$MY_KEYCHAIN_PASSWORD" "$MY_KEYCHAIN" -for f in $(ls "$CERTS_PATH"); do - "$HOME/.fastlane/bin/fastlane" run import_certificate "certificate_path:$CERTS_PATH/$f" keychain_name:"$MY_KEYCHAIN" keychain_password:"$MY_KEYCHAIN_PASSWORD" log_output:true -done - -mkdir -p "$HOME/Library/MobileDevice/Provisioning Profiles" - -for f in $(ls "$PROFILES_PATH"); do - PROFILE_PATH="$PROFILES_PATH/$f" - uuid=`grep UUID -A1 -a "$PROFILE_PATH" | grep -io "[-A-F0-9]\{36\}"` - cp -f "$PROFILE_PATH" "$HOME/Library/MobileDevice/Provisioning Profiles/$uuid.mobileprovision" -done - SOURCE_PATH="telegram-ios" if [ -d "$SOURCE_PATH" ]; then @@ -96,6 +84,18 @@ BASE_DIR=$(pwd) cd "$SOURCE_PATH" tar -xf "../source.tar" +for f in $(ls "$CERTS_PATH"); do + "$HOME/.fastlane/bin/fastlane" run import_certificate "certificate_path:$CERTS_PATH/$f" keychain_name:"$MY_KEYCHAIN" keychain_password:"$MY_KEYCHAIN_PASSWORD" log_output:true +done + +mkdir -p "$HOME/Library/MobileDevice/Provisioning Profiles" + +for f in $(ls "$PROFILES_PATH"); do + PROFILE_PATH="$PROFILES_PATH/$f" + uuid=`grep UUID -A1 -a "$PROFILE_PATH" | grep -io "[-A-F0-9]\{36\}"` + cp -f "$PROFILE_PATH" "$HOME/Library/MobileDevice/Provisioning Profiles/$uuid.mobileprovision" +done + if [ "$1" == "hockeyapp" ]; then BUILD_ENV_SCRIPT="../telegram-ios-shared/buildbox/bin/internal.sh" APP_TARGET="app_arm64" @@ -105,8 +105,9 @@ elif [ "$1" == "appstore" ]; then elif [ "$1" == "verify" ]; then BUILD_ENV_SCRIPT="build-system/verify.sh" APP_TARGET="app" - APP_TARGET="build_verbose" export CODESIGNING_DATA_PATH="build-system/fake-codesigning" + export CODESIGNING_CERTS_VARIANT="distribution" + export CODESIGNING_PROFILES_VARIANT="appstore" else echo "Unsupported configuration $1" exit 1 From 778cc939e1bcea611d990ccff4043d5f93344d1a Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 22:44:32 +0400 Subject: [PATCH 06/25] Don't check CFBundleVersion --- tools/ipadiff.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/ipadiff.py b/tools/ipadiff.py index 11455dd713..15011851ec 100644 --- a/tools/ipadiff.py +++ b/tools/ipadiff.py @@ -163,7 +163,7 @@ def is_plist(file1): def diff_plists(file1, file2): - remove_properties = ['UISupportedDevices', 'DTAppStoreToolsBuild', 'MinimumOSVersion', 'BuildMachineOSBuild'] + remove_properties = ['UISupportedDevices', 'DTAppStoreToolsBuild', 'MinimumOSVersion', 'BuildMachineOSBuild', 'CFBundleVersion'] clean1_properties = '' clean2_properties = '' From 6ec6e660b3a1d1b3ce2f8fb810f95dd3a94148cd Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 22:45:57 +0400 Subject: [PATCH 07/25] Bump version number --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index fbc92fdae8..39017124bd 100644 --- a/Makefile +++ b/Makefile @@ -3,7 +3,7 @@ include Utils.makefile BUCK_OPTIONS=\ - --config custom.appVersion="5.12.2" \ + --config custom.appVersion="5.13" \ --config custom.developmentCodeSignIdentity="${DEVELOPMENT_CODE_SIGN_IDENTITY}" \ --config custom.distributionCodeSignIdentity="${DISTRIBUTION_CODE_SIGN_IDENTITY}" \ --config custom.developmentTeam="${DEVELOPMENT_TEAM}" \ From 159be236acd206d01b407df982ea78c1d01a5f47 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 22:51:49 +0400 Subject: [PATCH 08/25] Verify after build --- .gitlab-ci.yml | 14 ++++++++++++++ buildbox/verify-telegram.sh | 33 +++++++++++++++++++++++++++++++++ 2 files changed, 47 insertions(+) create mode 100644 buildbox/verify-telegram.sh diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 596615308c..8c470b0fde 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,6 +1,7 @@ stages: - build - deploy + - verify variables: LANG: "en_US.UTF-8" @@ -50,3 +51,16 @@ deploy_beta_testflight: - bash buildbox/deploy-telegram.sh appstore environment: name: testflight_llc + +verify_beta_testflight: + tags: + - ios_beta + stage: verify + only: + - beta + except: + - tags + script: + - bash buildbox/verify-telegram.sh appstore + environment: + name: testflight_llc diff --git a/buildbox/verify-telegram.sh b/buildbox/verify-telegram.sh new file mode 100644 index 0000000000..b0db41e5a3 --- /dev/null +++ b/buildbox/verify-telegram.sh @@ -0,0 +1,33 @@ +#!/bin/bash + +set -e +set -x + +CONFIGURATION="$1" + +if [ -z "$CONFIGURATION" ]; then + echo "Usage: sh deploy-telegram.sh CONFIGURATION" + exit 1 +fi + +OUTPUT_PATH="build/artifacts" + +if [ "$CONFIGURATION" == "appstore" ]; then + IPA_PATH="$OUTPUT_PATH/Telegram.ipa" +else + echo "Unknown configuration $CONFIGURATION" + exit 1 +fi + +if [ ! -f "$IPA_PATH" ]; then + echo "$IPA_PATH not found" + exit 1 +fi + +VERIFY_PATH="TelegramVerifyBuild.ipa" + +mv "$IPA_PATH" "$VERIFY_PATH" + +BUCK_HTTP_CACHE="" sh buildbox/build-telegram.sh verify + +python3 tools/ipadiff.py "$IPA_PATH" "$VERIFY_PATH" From 25910e64b2bf61a38156014a9c407d123af90b8d Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 23:07:45 +0400 Subject: [PATCH 09/25] Fix script --- buildbox/guest-build-telegram.sh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/buildbox/guest-build-telegram.sh b/buildbox/guest-build-telegram.sh index 1614fde691..52435617a5 100644 --- a/buildbox/guest-build-telegram.sh +++ b/buildbox/guest-build-telegram.sh @@ -30,6 +30,8 @@ elif [ "$1" == "appstore" ]; then FASTLANE_ITC_USERNAME="$TELEGRAM_BUILD_APPSTORE_USERNAME" FASTLANE_PASSWORD="$TELEGRAM_BUILD_APPSTORE_PASSWORD" FASTLANE_ITC_TEAM_NAME="$TELEGRAM_BUILD_APPSTORE_TEAM_NAME" + CERTS_PATH="codesigning_data/certs" + PROFILES_PATH="codesigning_data/profiles" elif [ "$1" == "verify" ]; then CERTS_PATH="build-system/fake-codesigning/certs/distribution" PROFILES_PATH="build-system/fake-codesigning/profiles" From 8e23ba3d9b5c5898ba9284fa1de84a3ff3440e46 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 23:09:14 +0400 Subject: [PATCH 10/25] Fix script --- buildbox/guest-build-telegram.sh | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/buildbox/guest-build-telegram.sh b/buildbox/guest-build-telegram.sh index 52435617a5..887af15e07 100644 --- a/buildbox/guest-build-telegram.sh +++ b/buildbox/guest-build-telegram.sh @@ -13,11 +13,11 @@ if [ -z "COMMIT_ID" ]; then fi if [ "$1" == "hockeyapp" ] || [ "$1" == "testinghockeyapp" ]; then - CERTS_PATH="codesigning_data/certs" - PROFILES_PATH="codesigning_data/profiles" + CERTS_PATH="$HOME/codesigning_data/certs" + PROFILES_PATH="$HOME/codesigning_data/profiles" elif [ "$1" == "testinghockeyapp-local" ]; then - CERTS_PATH="codesigning_data/certs" - PROFILES_PATH="codesigning_data/profiles" + CERTS_PATH="$HOME/codesigning_data/certs" + PROFILES_PATH="$HOME/codesigning_data/profiles" elif [ "$1" == "appstore" ]; then if [ -z "$TELEGRAM_BUILD_APPSTORE_PASSWORD" ]; then echo "TELEGRAM_BUILD_APPSTORE_PASSWORD is not set" @@ -30,8 +30,8 @@ elif [ "$1" == "appstore" ]; then FASTLANE_ITC_USERNAME="$TELEGRAM_BUILD_APPSTORE_USERNAME" FASTLANE_PASSWORD="$TELEGRAM_BUILD_APPSTORE_PASSWORD" FASTLANE_ITC_TEAM_NAME="$TELEGRAM_BUILD_APPSTORE_TEAM_NAME" - CERTS_PATH="codesigning_data/certs" - PROFILES_PATH="codesigning_data/profiles" + CERTS_PATH="$HOME/codesigning_data/certs" + PROFILES_PATH="$HOME/codesigning_data/profiles" elif [ "$1" == "verify" ]; then CERTS_PATH="build-system/fake-codesigning/certs/distribution" PROFILES_PATH="build-system/fake-codesigning/profiles" From ce4e72604ffb150f69f29a3a47664669df969cf7 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 23:16:21 +0400 Subject: [PATCH 11/25] Test verification --- .gitlab-ci.yml | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 8c470b0fde..520929544d 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,6 +1,7 @@ stages: - build - - deploy + #- deploy + - verifysanity - verify variables: @@ -52,6 +53,19 @@ deploy_beta_testflight: environment: name: testflight_llc +verifysanity_beta_testflight: + tags: + - ios_beta + stage: verifysanity + only: + - beta + except: + - tags + script: + - bash buildbox/verify-telegram.sh appstore cached + environment: + name: testflight_llc + verify_beta_testflight: tags: - ios_beta @@ -61,6 +75,6 @@ verify_beta_testflight: except: - tags script: - - bash buildbox/verify-telegram.sh appstore + - bash buildbox/verify-telegram.sh appstore full environment: name: testflight_llc From 355a788b82b3db5778a79579400a666bdbd9e8ae Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 23:16:55 +0400 Subject: [PATCH 12/25] Test verification --- .gitlab-ci.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 520929544d..ec6ab76803 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,6 +1,5 @@ stages: - build - #- deploy - verifysanity - verify From 1ec29251a93a7b8b347208e5bb7d381ae3c82829 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 23:17:59 +0400 Subject: [PATCH 13/25] Test verification --- .gitlab-ci.yml | 25 +++++++++++++------------ 1 file changed, 13 insertions(+), 12 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index ec6ab76803..83c306ed3b 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,5 +1,6 @@ stages: - build + #- deploy - verifysanity - verify @@ -39,18 +40,18 @@ beta_testflight: - build/artifacts expire_in: 1 week -deploy_beta_testflight: - tags: - - ios_beta - stage: deploy - only: - - beta - except: - - tags - script: - - bash buildbox/deploy-telegram.sh appstore - environment: - name: testflight_llc +#deploy_beta_testflight: +# tags: +# - ios_beta +# stage: deploy +# only: +# - beta +# except: +# - tags +# script: +# - bash buildbox/deploy-telegram.sh appstore +# environment: +# name: testflight_llc verifysanity_beta_testflight: tags: From f47363dd7ed152e77ce59ca24c2fde863823ef3a Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 23:20:11 +0400 Subject: [PATCH 14/25] Fix modes --- buildbox/verify-telegram.sh | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/buildbox/verify-telegram.sh b/buildbox/verify-telegram.sh index b0db41e5a3..849933f37c 100644 --- a/buildbox/verify-telegram.sh +++ b/buildbox/verify-telegram.sh @@ -4,9 +4,19 @@ set -e set -x CONFIGURATION="$1" +MODE="$2" -if [ -z "$CONFIGURATION" ]; then - echo "Usage: sh deploy-telegram.sh CONFIGURATION" +if [ -z "$CONFIGURATION" ] || [ -z "$MODE" ] ; then + echo "Usage: sh deploy-telegram.sh CONFIGURATION [cached|full]" + exit 1 +fi + +if [ "$MODE" == "cached" ]; then + BUCK_HTTP_CACHE="$BUCK_HTTP_CACHE" +elif [ "$MODE" == "full" ]; then + BUCK_HTTP_CACHE="" +else + echo "Unknown mode $MODE" exit 1 fi @@ -28,6 +38,6 @@ VERIFY_PATH="TelegramVerifyBuild.ipa" mv "$IPA_PATH" "$VERIFY_PATH" -BUCK_HTTP_CACHE="" sh buildbox/build-telegram.sh verify +BUCK_HTTP_CACHE="$BUCK_HTTP_CACHE" sh buildbox/build-telegram.sh verify python3 tools/ipadiff.py "$IPA_PATH" "$VERIFY_PATH" From 82311c52341f77c1e95621ad1e6033ea8d647741 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Wed, 20 Nov 2019 23:45:26 +0400 Subject: [PATCH 15/25] Try again --- .gitlab-ci.yml | 24 ++++++++++++------------ buildbox/build-telegram.sh | 1 + tools/ipadiff.py | 1 + 3 files changed, 14 insertions(+), 12 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 83c306ed3b..9619491d8f 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -53,18 +53,18 @@ beta_testflight: # environment: # name: testflight_llc -verifysanity_beta_testflight: - tags: - - ios_beta - stage: verifysanity - only: - - beta - except: - - tags - script: - - bash buildbox/verify-telegram.sh appstore cached - environment: - name: testflight_llc +#verifysanity_beta_testflight: +# tags: +# - ios_beta +# stage: verifysanity +# only: +# - beta +# except: +# - tags +# script: +# - bash buildbox/verify-telegram.sh appstore cached +# environment: +# name: testflight_llc verify_beta_testflight: tags: diff --git a/buildbox/build-telegram.sh b/buildbox/build-telegram.sh index b901178f21..7aa409ef61 100644 --- a/buildbox/build-telegram.sh +++ b/buildbox/build-telegram.sh @@ -62,6 +62,7 @@ if [ "$BUILD_CONFIGURATION" == "hockeyapp" ]; then elif [ "$BUILD_CONFIGURATION" == "appstore" ]; then CODESIGNING_SUBPATH="transient-data/codesigning" CODESIGNING_TEAMS_SUBPATH="transient-data/teams" + export BUCK_HTTP_CACHE="" elif [ "$BUILD_CONFIGURATION" == "verify" ]; then CODESIGNING_SUBPATH="fake-codesigning" else diff --git a/tools/ipadiff.py b/tools/ipadiff.py index 15011851ec..b62b5accab 100644 --- a/tools/ipadiff.py +++ b/tools/ipadiff.py @@ -285,6 +285,7 @@ def ipadiff(self_base_path, ipa1, ipa2): print('Different files in ' + ipa1 + ' and ' + ipa2) for relative_file_path in different_files: print(' ' + relative_file_path) + sys.exit(1) else: if len(encrypted_files) != 0 or len(watch_ipa1_files) != 0 or len(plugin_ipa1_files) != 0: print('IPAs are equal, except for the files that can\'t currently be checked:') From 229f5359d8ec2a74622ca8fa17e7df77819c0aed Mon Sep 17 00:00:00 2001 From: Ali <> Date: Thu, 21 Nov 2019 00:00:29 +0400 Subject: [PATCH 16/25] Try again --- .gitlab-ci.yml | 34 +++++++++++++++++++++------------- buildbox/build-telegram.sh | 10 ++++++++-- 2 files changed, 29 insertions(+), 15 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 9619491d8f..01e9d6be44 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,6 +1,6 @@ stages: - build - #- deploy + - deploy - verifysanity - verify @@ -53,18 +53,22 @@ beta_testflight: # environment: # name: testflight_llc -#verifysanity_beta_testflight: -# tags: -# - ios_beta -# stage: verifysanity -# only: -# - beta -# except: -# - tags -# script: -# - bash buildbox/verify-telegram.sh appstore cached -# environment: -# name: testflight_llc +verifysanity_beta_testflight: + tags: + - ios_beta + stage: verifysanity + only: + - beta + except: + - tags + script: + - bash buildbox/verify-telegram.sh appstore cached + environment: + name: testflight_llc + artifacts: + paths: + - build/artifacts + expire_in: 1 week verify_beta_testflight: tags: @@ -78,3 +82,7 @@ verify_beta_testflight: - bash buildbox/verify-telegram.sh appstore full environment: name: testflight_llc + artifacts: + paths: + - build/artifacts + expire_in: 1 week diff --git a/buildbox/build-telegram.sh b/buildbox/build-telegram.sh index 7aa409ef61..c58df8318d 100644 --- a/buildbox/build-telegram.sh +++ b/buildbox/build-telegram.sh @@ -62,7 +62,6 @@ if [ "$BUILD_CONFIGURATION" == "hockeyapp" ]; then elif [ "$BUILD_CONFIGURATION" == "appstore" ]; then CODESIGNING_SUBPATH="transient-data/codesigning" CODESIGNING_TEAMS_SUBPATH="transient-data/teams" - export BUCK_HTTP_CACHE="" elif [ "$BUILD_CONFIGURATION" == "verify" ]; then CODESIGNING_SUBPATH="fake-codesigning" else @@ -70,7 +69,14 @@ else exit 1 fi -COMMIT_ID=$(git rev-parse HEAD) +COMMIT_COMMENT="$(git log -1 --pretty=%B)" +case "$COMMIT_COMMENT" in + *"[nocache]"*) + export BUCK_HTTP_CACHE="" + ;; +esac + +COMMIT_ID="$(git rev-parse HEAD)" COMMIT_AUTHOR=$(git log -1 --pretty=format:'%an') if [ -z "$2" ]; then COMMIT_COUNT=$(git rev-list --count HEAD) From c2ff694004dbe766d071598e41b1fa31c97bbcb7 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Thu, 21 Nov 2019 05:58:43 +0400 Subject: [PATCH 17/25] Bring back deployment --- .gitlab-ci.yml | 24 ++++++++++++------------ buildbox/verify-telegram.sh | 3 +++ 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 01e9d6be44..bf32c59567 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -40,18 +40,18 @@ beta_testflight: - build/artifacts expire_in: 1 week -#deploy_beta_testflight: -# tags: -# - ios_beta -# stage: deploy -# only: -# - beta -# except: -# - tags -# script: -# - bash buildbox/deploy-telegram.sh appstore -# environment: -# name: testflight_llc +deploy_beta_testflight: + tags: + - ios_beta + stage: deploy + only: + - beta + except: + - tags + script: + - bash buildbox/deploy-telegram.sh appstore + environment: + name: testflight_llc verifysanity_beta_testflight: tags: diff --git a/buildbox/verify-telegram.sh b/buildbox/verify-telegram.sh index 849933f37c..38da0b6949 100644 --- a/buildbox/verify-telegram.sh +++ b/buildbox/verify-telegram.sh @@ -41,3 +41,6 @@ mv "$IPA_PATH" "$VERIFY_PATH" BUCK_HTTP_CACHE="$BUCK_HTTP_CACHE" sh buildbox/build-telegram.sh verify python3 tools/ipadiff.py "$IPA_PATH" "$VERIFY_PATH" + +# No need to upload artifacts if the output matches previous step +rm -rf "$OUTPUT_PATH" From 94b880c4dc6d32e4db404eb97c31382d8a7ed34b Mon Sep 17 00:00:00 2001 From: Ali <> Date: Thu, 21 Nov 2019 06:42:47 +0400 Subject: [PATCH 18/25] Upload verify artifacts on failure --- .gitlab-ci.yml | 6 ++++-- buildbox/verify-telegram.sh | 11 +++++++++-- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index bf32c59567..d89926d6ad 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -66,8 +66,9 @@ verifysanity_beta_testflight: environment: name: testflight_llc artifacts: + when: on_failure paths: - - build/artifacts + - build/verifysanity_artifacts expire_in: 1 week verify_beta_testflight: @@ -83,6 +84,7 @@ verify_beta_testflight: environment: name: testflight_llc artifacts: + when: on_failure paths: - - build/artifacts + - build/verify_artifacts expire_in: 1 week diff --git a/buildbox/verify-telegram.sh b/buildbox/verify-telegram.sh index 38da0b6949..371382f6be 100644 --- a/buildbox/verify-telegram.sh +++ b/buildbox/verify-telegram.sh @@ -13,8 +13,10 @@ fi if [ "$MODE" == "cached" ]; then BUCK_HTTP_CACHE="$BUCK_HTTP_CACHE" + ERROR_OUTPUT_PATH="build/verifysanity_artifacts" elif [ "$MODE" == "full" ]; then BUCK_HTTP_CACHE="" + ERROR_OUTPUT_PATH="build/verify_artifacts" else echo "Unknown mode $MODE" exit 1 @@ -41,6 +43,11 @@ mv "$IPA_PATH" "$VERIFY_PATH" BUCK_HTTP_CACHE="$BUCK_HTTP_CACHE" sh buildbox/build-telegram.sh verify python3 tools/ipadiff.py "$IPA_PATH" "$VERIFY_PATH" +retVal=$? +if [ $retVal -ne 0 ]; then + mkdir -p "$ERROR_OUTPUT_PATH" + cp "$IPA_PATH" "$ERROR_OUTPUT_PATH"/ + exit 1 +fi + -# No need to upload artifacts if the output matches previous step -rm -rf "$OUTPUT_PATH" From 144df3cc33785d7502c15d1bae0a36a5524a7adf Mon Sep 17 00:00:00 2001 From: Ali <> Date: Thu, 21 Nov 2019 14:22:33 +0400 Subject: [PATCH 19/25] Fix ipadiff [skip ci] --- tools/ipadiff.py | 5 ---- tools/main.cpp | 63 +++++++++++++++++++++++++++++++++++++++++++++--- 2 files changed, 59 insertions(+), 9 deletions(-) diff --git a/tools/ipadiff.py b/tools/ipadiff.py index b62b5accab..532e0ea363 100644 --- a/tools/ipadiff.py +++ b/tools/ipadiff.py @@ -181,11 +181,6 @@ def diff_plists(file1, file2): if data1 == data2: return 'equal' else: - with open('lhs.plist', 'wb') as f: - f.write(str.encode(data1)) - with open('rhs.plist', 'wb') as f: - f.write(str.encode(data2)) - sys.exit(1) return 'not_equal' diff --git a/tools/main.cpp b/tools/main.cpp index 99c513eda5..540eee9687 100644 --- a/tools/main.cpp +++ b/tools/main.cpp @@ -175,16 +175,54 @@ static void writeDataToFile(std::vector const &data, std::string const static std::vector stripSwiftSymbols(std::string const &file) { std::string command; - command += "xcrun strip -ST -o /dev/stdout \""; + + command += "xcrun bitcode_strip \""; command += file; - command += "\" 2> /dev/null"; - + command += "\" -r -o \""; + command += file; + command += ".stripped\""; + uint8_t buffer[128]; - std::vector result; + FILE *pipe = popen(command.c_str(), "r"); if (!pipe) { throw std::runtime_error("popen() failed!"); } + while (true) { + size_t readBytes = fread(buffer, 1, 128, pipe); + if (readBytes <= 0) { + break; + } + } + pclose(pipe); + + command = ""; + command += "codesign --remove-signature \""; + command += file; + command += ".stripped\""; + + pipe = popen(command.c_str(), "r"); + if (!pipe) { + throw std::runtime_error("popen() failed!"); + } + while (true) { + size_t readBytes = fread(buffer, 1, 128, pipe); + if (readBytes <= 0) { + break; + } + } + pclose(pipe); + + command = ""; + command += "xcrun strip -ST -o /dev/stdout \""; + command += file; + command += ".stripped\" 2> /dev/null"; + + std::vector result; + pipe = popen(command.c_str(), "r"); + if (!pipe) { + throw std::runtime_error("popen() failed!"); + } while (true) { size_t readBytes = fread(buffer, 1, 128, pipe); if (readBytes <= 0) { @@ -193,6 +231,23 @@ static std::vector stripSwiftSymbols(std::string const &file) { result.insert(result.end(), buffer, buffer + readBytes); } pclose(pipe); + + command = ""; + command += "rm \""; + command += file; + command += ".stripped\""; + + pipe = popen(command.c_str(), "r"); + if (!pipe) { + throw std::runtime_error("popen() failed!"); + } + while (true) { + size_t readBytes = fread(buffer, 1, 128, pipe); + if (readBytes <= 0) { + break; + } + } + pclose(pipe); return result; } From 40b0b3479eaff8ba5d6e85b974442d2c2b125907 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Thu, 21 Nov 2019 18:49:32 +0400 Subject: [PATCH 20/25] Initial QR login API [skip ci] --- .../NotificationViewController.swift | 2 +- Share/ShareRootController.swift | 2 +- SiriIntents/IntentHandler.swift | 3 +- submodules/AuthTransferUI/BUCK | 23 ++ .../Sources/AuthTransferScanScreen.swift | 349 ++++++++++++++++++ submodules/SettingsUI/BUCK | 1 + .../Sources/SettingsController.swift | 89 +++-- submodules/TelegramApi/Sources/Api0.swift | 10 + submodules/TelegramApi/Sources/Api1.swift | 38 ++ submodules/TelegramApi/Sources/Api2.swift | 154 ++++++++ submodules/TelegramApi/Sources/Api3.swift | 57 +++ .../TelegramCore/Sources/AuthTransfer.swift | 144 ++++++++ .../TelegramCore/Sources/Authorization.swift | 2 +- submodules/TelegramCore/Sources/Network.swift | 4 +- .../TelegramUI/TelegramUI/AppDelegate.swift | 3 +- .../AuthorizationSequenceController.swift | 8 +- ...rizationSequencePhoneEntryController.swift | 17 +- ...tionSequencePhoneEntryControllerNode.swift | 79 +++- ...textResultsChatInputContextPanelNode.swift | 1 + .../NotificationContentContext.swift | 6 +- .../TelegramUI/ShareExtensionContext.swift | 6 +- 21 files changed, 952 insertions(+), 46 deletions(-) create mode 100644 submodules/AuthTransferUI/BUCK create mode 100644 submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift create mode 100644 submodules/TelegramCore/Sources/AuthTransfer.swift diff --git a/NotificationContent/NotificationViewController.swift b/NotificationContent/NotificationViewController.swift index 9f5f7e31e6..8a6372ecdd 100644 --- a/NotificationContent/NotificationViewController.swift +++ b/NotificationContent/NotificationViewController.swift @@ -38,7 +38,7 @@ class NotificationViewController: UIViewController, UNNotificationContentExtensi let appVersion = (Bundle.main.infoDictionary?["CFBundleShortVersionString"] as? String) ?? "unknown" - self.impl = NotificationViewControllerImpl(initializationData: NotificationViewControllerInitializationData(appGroupPath: appGroupUrl.path, apiId: buildConfig.apiId, languagesCategory: languagesCategory, encryptionParameters: encryptionParameters, appVersion: appVersion, bundleData: buildConfig.bundleData(withAppToken: nil, signatureDict: nil)), setPreferredContentSize: { [weak self] size in + self.impl = NotificationViewControllerImpl(initializationData: NotificationViewControllerInitializationData(appGroupPath: appGroupUrl.path, apiId: buildConfig.apiId, apiHash: buildConfig.apiHash, languagesCategory: languagesCategory, encryptionParameters: encryptionParameters, appVersion: appVersion, bundleData: buildConfig.bundleData(withAppToken: nil, signatureDict: nil)), setPreferredContentSize: { [weak self] size in self?.preferredContentSize = size }) } diff --git a/Share/ShareRootController.swift b/Share/ShareRootController.swift index 5dac1a0097..c0da95155d 100644 --- a/Share/ShareRootController.swift +++ b/Share/ShareRootController.swift @@ -45,7 +45,7 @@ class ShareRootController: UIViewController { let appVersion = (Bundle.main.infoDictionary?["CFBundleShortVersionString"] as? String) ?? "unknown" - self.impl = ShareRootControllerImpl(initializationData: ShareRootControllerInitializationData(appGroupPath: appGroupUrl.path, apiId: buildConfig.apiId, languagesCategory: languagesCategory, encryptionParameters: encryptionParameters, appVersion: appVersion, bundleData: buildConfig.bundleData(withAppToken: nil, signatureDict: nil)), getExtensionContext: { [weak self] in + self.impl = ShareRootControllerImpl(initializationData: ShareRootControllerInitializationData(appGroupPath: appGroupUrl.path, apiId: buildConfig.apiId, apiHash: buildConfig.apiHash, languagesCategory: languagesCategory, encryptionParameters: encryptionParameters, appVersion: appVersion, bundleData: buildConfig.bundleData(withAppToken: nil, signatureDict: nil)), getExtensionContext: { [weak self] in return self?.extensionContext }) } diff --git a/SiriIntents/IntentHandler.swift b/SiriIntents/IntentHandler.swift index 694cbce0ae..e0d00c1ea1 100644 --- a/SiriIntents/IntentHandler.swift +++ b/SiriIntents/IntentHandler.swift @@ -69,6 +69,7 @@ public class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchFo let buildConfig = BuildConfig(baseAppBundleId: baseAppBundleId) let apiId: Int32 = buildConfig.apiId + let apiHash: String = buildConfig.apiHash let languagesCategory = "ios" let appGroupName = "group.\(baseAppBundleId)" @@ -100,7 +101,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, 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, 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/submodules/AuthTransferUI/BUCK b/submodules/AuthTransferUI/BUCK new file mode 100644 index 0000000000..494377d70f --- /dev/null +++ b/submodules/AuthTransferUI/BUCK @@ -0,0 +1,23 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "AuthTransferUI", + srcs = glob([ + "Sources/**/*.swift", + ]), + deps = [ + "//submodules/TelegramCore:TelegramCore#shared", + "//submodules/SyncCore:SyncCore#shared", + "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit#shared", + "//submodules/Display:Display#shared", + "//submodules/TelegramPresentationData:TelegramPresentationData", + "//submodules/AccountContext:AccountContext", + "//submodules/QrCode:QrCode", + "//submodules/Camera:Camera", + "//submodules/GlassButtonNode:GlassButtonNode", + "//submodules/AlertUI:AlertUI", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + ], +) diff --git a/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift b/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift new file mode 100644 index 0000000000..05bf3e34ba --- /dev/null +++ b/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift @@ -0,0 +1,349 @@ +import Foundation +import UIKit +import AccountContext +import AsyncDisplayKit +import Display +import SwiftSignalKit +import Camera +import GlassButtonNode +import CoreImage +import AlertUI +import TelegramPresentationData +import TelegramCore + +private func parseAuthTransferUrl(_ url: URL) -> Data? { + var tokenString: String? + if let query = url.query, let components = URLComponents(string: "/?" + query), let queryItems = components.queryItems { + for queryItem in queryItems { + if let value = queryItem.value { + if queryItem.name == "token", !value.isEmpty { + tokenString = value + } + } + } + } + if var tokenString = tokenString { + tokenString = tokenString.replacingOccurrences(of: "-", with: "+") + tokenString = tokenString.replacingOccurrences(of: "_", with: "/") + while tokenString.count % 4 != 0 { + tokenString.append("=") + } + if let data = Data(base64Encoded: tokenString) { + return data + } + } + return nil +} + +private func generateFrameImage() -> UIImage? { + return generateImage(CGSize(width: 64.0, height: 64.0), contextGenerator: { size, context in + let bounds = CGRect(origin: CGPoint(), size: size) + context.clear(bounds) + context.setStrokeColor(UIColor.white.cgColor) + context.setLineWidth(4.0) + context.setLineCap(.round) + + var path = CGMutablePath(); + path.move(to: CGPoint(x: 2.0, y: 2.0 + 26.0)) + path.addArc(tangent1End: CGPoint(x: 2.0, y: 2.0), tangent2End: CGPoint(x: 2.0 + 26.0, y: 2.0), radius: 6.0) + path.addLine(to: CGPoint(x: 2.0 + 26.0, y: 2.0)) + context.addPath(path) + context.strokePath() + + path.move(to: CGPoint(x: size.width - 2.0, y: 2.0 + 26.0)) + path.addArc(tangent1End: CGPoint(x: size.width - 2.0, y: 2.0), tangent2End: CGPoint(x: 2.0 + 26.0, y: 2.0), radius: 6.0) + path.addLine(to: CGPoint(x: size.width - 2.0 - 26.0, y: 2.0)) + context.addPath(path) + context.strokePath() + + path.move(to: CGPoint(x: 2.0, y: size.height - 2.0 - 26.0)) + path.addArc(tangent1End: CGPoint(x: 2.0, y: size.height - 2.0), tangent2End: CGPoint(x: 2.0 + 26.0, y: size.height - 2.0), radius: 6.0) + path.addLine(to: CGPoint(x: 2.0 + 26.0, y: size.height - 2.0)) + context.addPath(path) + context.strokePath() + + path.move(to: CGPoint(x: size.width - 2.0, y: size.height - 2.0 - 26.0)) + path.addArc(tangent1End: CGPoint(x: size.width - 2.0, y: size.height - 2.0), tangent2End: CGPoint(x: 2.0 + 26.0, y: size.height - 2.0), radius: 6.0) + path.addLine(to: CGPoint(x: size.width - 2.0 - 26.0, y: size.height - 2.0)) + context.addPath(path) + context.strokePath() + })?.stretchableImage(withLeftCapWidth: 32, topCapHeight: 32) +} + +public final class AuthTransferScanScreen: ViewController { + private let context: AccountContext + private var presentationData: PresentationData + + private var codeDisposable: Disposable? + private var inForegroundDisposable: Disposable? + private let approveDisposable = MetaDisposable() + + public init(context: AccountContext) { + self.context = context + + self.presentationData = context.sharedContext.currentPresentationData.with { $0 } + + let navigationBarTheme = NavigationBarTheme(buttonColor: .white, disabledButtonColor: .white, primaryTextColor: .white, backgroundColor: .clear, separatorColor: .clear, badgeBackgroundColor: .clear, badgeStrokeColor: .clear, badgeTextColor: .clear) + + super.init(navigationBarPresentationData: NavigationBarPresentationData(theme: navigationBarTheme, strings: NavigationBarStrings(back: self.presentationData.strings.Common_Back, close: self.presentationData.strings.Common_Close))) + + self.statusBar.statusBarStyle = .White + + self.navigationPresentation = .modalInLargeLayout + self.supportedOrientations = ViewControllerSupportedOrientations(regularSize: .all, compactSize: .portrait) + self.navigationBar?.intrinsicCanTransitionInline = false + + self.navigationItem.backBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Wallet_Navigation_Back, style: .plain, target: nil, action: nil) + + self.inForegroundDisposable = (context.sharedContext.applicationBindings.applicationInForeground + |> deliverOnMainQueue).start(next: { [weak self] inForeground in + guard let strongSelf = self else { + return + } + (strongSelf.displayNode as! AuthTransferScanScreenNode).updateInForeground(inForeground) + }) + } + + required init(coder aDecoder: NSCoder) { + fatalError("init(coder:) has not been implemented") + } + + deinit { + self.codeDisposable?.dispose() + self.inForegroundDisposable?.dispose() + self.approveDisposable.dispose() + } + + @objc private func backPressed() { + self.dismiss() + } + + override public func loadDisplayNode() { + self.displayNode = AuthTransferScanScreenNode(presentationData: self.presentationData) + + self.displayNodeDidLoad() + + self.codeDisposable = ((self.displayNode as! AuthTransferScanScreenNode).focusedCode.get() + |> map { code -> String? in + return code?.message + } + |> distinctUntilChanged + |> mapToSignal { code -> Signal in + return .single(code) + |> delay(0.5, queue: Queue.mainQueue()) + }).start(next: { [weak self] code in + guard let strongSelf = self, let code = code else { + return + } + if let url = URL(string: code), let parsedToken = parseAuthTransferUrl(url) { + print("import token: \(parsedToken.base64EncodedString())") + + strongSelf.approveDisposable.set((approveAuthTransferToken(account: strongSelf.context.account, token: parsedToken) + |> deliverOnMainQueue).start(error: { _ in + }, completed: { + guard let strongSelf = self else { + return + } + strongSelf.dismiss() + })) + } + }) + } + + override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { + super.containerLayoutUpdated(layout, transition: transition) + + (self.displayNode as! AuthTransferScanScreenNode).containerLayoutUpdated(layout: layout, navigationHeight: self.navigationHeight, transition: transition) + } +} + +private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScrollViewDelegate { + private var presentationData: PresentationData + + private let previewNode: CameraPreviewNode + private let fadeNode: ASDisplayNode + private let topDimNode: ASDisplayNode + private let bottomDimNode: ASDisplayNode + private let leftDimNode: ASDisplayNode + private let rightDimNode: ASDisplayNode + private let frameNode: ASImageNode + private let torchButtonNode: GlassButtonNode + private let titleNode: ImmediateTextNode + + private let camera: Camera + private let codeDisposable = MetaDisposable() + + fileprivate let focusedCode = ValuePromise(ignoreRepeated: true) + private var focusedRect: CGRect? + + private var validLayout: (ContainerViewLayout, CGFloat)? + + init(presentationData: PresentationData) { + self.presentationData = presentationData + + self.previewNode = CameraPreviewNode() + self.previewNode.backgroundColor = .black + + self.fadeNode = ASDisplayNode() + self.fadeNode.alpha = 0.0 + self.fadeNode.backgroundColor = .black + + self.topDimNode = ASDisplayNode() + self.topDimNode.alpha = 0.625 + self.topDimNode.backgroundColor = UIColor(rgb: 0x000000, alpha: 0.8) + + self.bottomDimNode = ASDisplayNode() + self.bottomDimNode.alpha = 0.625 + self.bottomDimNode.backgroundColor = UIColor(rgb: 0x000000, alpha: 0.8) + + self.leftDimNode = ASDisplayNode() + self.leftDimNode.alpha = 0.625 + self.leftDimNode.backgroundColor = UIColor(rgb: 0x000000, alpha: 0.8) + + self.rightDimNode = ASDisplayNode() + self.rightDimNode.alpha = 0.625 + self.rightDimNode.backgroundColor = UIColor(rgb: 0x000000, alpha: 0.8) + + self.frameNode = ASImageNode() + self.frameNode.image = generateFrameImage() + + self.torchButtonNode = GlassButtonNode(icon: UIImage(bundleImageName: "Wallet/CameraFlashIcon")!, label: nil) + + self.titleNode = ImmediateTextNode() + self.titleNode.displaysAsynchronously = false + self.titleNode.attributedText = NSAttributedString(string: presentationData.strings.Wallet_Qr_ScanCode, font: Font.bold(32.0), textColor: .white) + self.titleNode.maximumNumberOfLines = 0 + self.titleNode.textAlignment = .center + + self.camera = Camera(configuration: .init(preset: .hd1920x1080, position: .back, audio: false)) + + super.init() + + self.backgroundColor = self.presentationData.theme.list.plainBackgroundColor + + self.addSubnode(self.previewNode) + self.addSubnode(self.fadeNode) + self.addSubnode(self.topDimNode) + self.addSubnode(self.bottomDimNode) + self.addSubnode(self.leftDimNode) + self.addSubnode(self.rightDimNode) + self.addSubnode(self.frameNode) + self.addSubnode(self.torchButtonNode) + self.addSubnode(self.titleNode) + + self.torchButtonNode.addTarget(self, action: #selector(self.torchPressed), forControlEvents: .touchUpInside) + } + + deinit { + self.codeDisposable.dispose() + self.camera.stopCapture(invalidate: true) + } + + fileprivate func updateInForeground(_ inForeground: Bool) { + if !inForeground { + self.camera.stopCapture(invalidate: false) + } else { + self.camera.startCapture() + } + } + + override func didLoad() { + super.didLoad() + + self.camera.attachPreviewNode(self.previewNode) + self.camera.startCapture() + + let throttledSignal = self.camera.detectedCodes + |> mapToThrottled { next -> Signal<[CameraCode], NoError> in + return .single(next) |> then(.complete() |> delay(0.3, queue: Queue.concurrentDefaultQueue())) + } + + self.codeDisposable.set((throttledSignal + |> deliverOnMainQueue).start(next: { [weak self] codes in + guard let strongSelf = self else { + return + } + let filteredCodes = codes.filter { $0.message.hasPrefix("tg://") } + if let code = filteredCodes.first, CGRect(x: 0.3, y: 0.3, width: 0.4, height: 0.4).contains(code.boundingBox.center) { + strongSelf.focusedCode.set(code) + strongSelf.updateFocusedRect(code.boundingBox) + } else { + strongSelf.focusedCode.set(nil) + strongSelf.updateFocusedRect(nil) + } + })) + } + + private func updateFocusedRect(_ rect: CGRect?) { + self.focusedRect = rect + if let (layout, navigationHeight) = self.validLayout { + self.containerLayoutUpdated(layout: layout, navigationHeight: navigationHeight, transition: .animated(duration: 0.4, curve: .spring)) + } + } + + func containerLayoutUpdated(layout: ContainerViewLayout, navigationHeight: CGFloat, transition: ContainedViewLayoutTransition) { + self.validLayout = (layout, navigationHeight) + + let sideInset: CGFloat = 66.0 + let titleSpacing: CGFloat = 48.0 + let bounds = CGRect(origin: CGPoint(), size: layout.size) + + if case .tablet = layout.deviceMetrics.type { + if UIDevice.current.orientation == .landscapeLeft { + self.previewNode.transform = CATransform3DMakeRotation(-CGFloat.pi / 2.0, 0.0, 0.0, 1.0) + } else if UIDevice.current.orientation == .landscapeRight { + self.previewNode.transform = CATransform3DMakeRotation(CGFloat.pi / 2.0, 0.0, 0.0, 1.0) + } else { + self.previewNode.transform = CATransform3DIdentity + } + } + transition.updateFrame(node: self.previewNode, frame: bounds) + transition.updateFrame(node: self.fadeNode, frame: bounds) + + let frameSide = max(240.0, layout.size.width - sideInset * 2.0) + let dimHeight = ceil((layout.size.height - frameSide) / 2.0) + let dimInset = (layout.size.width - frameSide) / 2.0 + + let dimAlpha: CGFloat + let dimRect: CGRect + let controlsAlpha: CGFloat + if let focusedRect = self.focusedRect { + controlsAlpha = 0.0 + dimAlpha = 1.0 + let side = max(bounds.width * focusedRect.width, bounds.height * focusedRect.height) * 0.6 + let center = CGPoint(x: (1.0 - focusedRect.center.y) * bounds.width, y: focusedRect.center.x * bounds.height) + dimRect = CGRect(x: center.x - side / 2.0, y: center.y - side / 2.0, width: side, height: side) + } else { + controlsAlpha = 1.0 + dimAlpha = 0.625 + dimRect = CGRect(x: dimInset, y: dimHeight, width: layout.size.width - dimInset * 2.0, height: layout.size.height - dimHeight * 2.0) + } + + transition.updateAlpha(node: self.topDimNode, alpha: dimAlpha) + transition.updateAlpha(node: self.bottomDimNode, alpha: dimAlpha) + transition.updateAlpha(node: self.leftDimNode, alpha: dimAlpha) + transition.updateAlpha(node: self.rightDimNode, alpha: dimAlpha) + + transition.updateFrame(node: self.topDimNode, frame: CGRect(x: 0.0, y: 0.0, width: layout.size.width, height: dimRect.minY)) + transition.updateFrame(node: self.bottomDimNode, frame: CGRect(x: 0.0, y: dimRect.maxY, width: layout.size.width, height: max(0.0, layout.size.height - dimRect.maxY))) + transition.updateFrame(node: self.leftDimNode, frame: CGRect(x: 0.0, y: dimRect.minY, width: max(0.0, dimRect.minX), height: dimRect.height)) + transition.updateFrame(node: self.rightDimNode, frame: CGRect(x: dimRect.maxX, y: dimRect.minY, width: max(0.0, layout.size.width - dimRect.maxX), height: dimRect.height)) + transition.updateFrame(node: self.frameNode, frame: dimRect.insetBy(dx: -2.0, dy: -2.0)) + + let buttonSize = CGSize(width: 72.0, height: 72.0) + transition.updateFrame(node: self.torchButtonNode, frame: CGRect(origin: CGPoint(x: floor((layout.size.width - buttonSize.width) / 2.0), y: dimHeight + frameSide + 50.0), size: buttonSize)) + + transition.updateAlpha(node: self.titleNode, alpha: controlsAlpha) + transition.updateAlpha(node: self.torchButtonNode, alpha: controlsAlpha) + + let titleSize = self.titleNode.updateLayout(CGSize(width: layout.size.width - sideInset * 2.0, height: layout.size.height)) + let titleFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - titleSize.width) / 2.0), y: dimHeight - titleSize.height - titleSpacing), size: titleSize) + transition.updateFrameAdditive(node: self.titleNode, frame: titleFrame) + } + + @objc private func torchPressed() { + self.torchButtonNode.isSelected = !self.torchButtonNode.isSelected + self.camera.setTorchActive(self.torchButtonNode.isSelected) + } +} + diff --git a/submodules/SettingsUI/BUCK b/submodules/SettingsUI/BUCK index f703b3fc54..6716a137ef 100644 --- a/submodules/SettingsUI/BUCK +++ b/submodules/SettingsUI/BUCK @@ -84,6 +84,7 @@ static_library( "//submodules/DeleteChatPeerActionSheetItem:DeleteChatPeerActionSheetItem", "//submodules/PhoneNumberFormat:PhoneNumberFormat", "//submodules/OpenInExternalAppUI:OpenInExternalAppUI", + "//submodules/AuthTransferUI:AuthTransferUI", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/SettingsUI/Sources/SettingsController.swift b/submodules/SettingsUI/Sources/SettingsController.swift index bc8349bb7b..5292743553 100644 --- a/submodules/SettingsUI/Sources/SettingsController.swift +++ b/submodules/SettingsUI/Sources/SettingsController.swift @@ -35,6 +35,7 @@ import AppBundle import ContextUI import WalletUI import PhoneNumberFormat +import AuthTransferUI private let maximumNumberOfAccounts = 3 @@ -112,6 +113,7 @@ private final class SettingsItemArguments { let keepPhone: () -> Void let openPhoneNumberChange: () -> Void let accountContextAction: (AccountRecordId, ASDisplayNode, ContextGesture?) -> Void + let openLoginDesktop: () -> Void init( accountManager: AccountManager, @@ -144,7 +146,8 @@ private final class SettingsItemArguments { removeAccount: @escaping (AccountRecordId) -> Void, keepPhone: @escaping () -> Void, openPhoneNumberChange: @escaping () -> Void, - accountContextAction: @escaping (AccountRecordId, ASDisplayNode, ContextGesture?) -> Void + accountContextAction: @escaping (AccountRecordId, ASDisplayNode, ContextGesture?) -> Void, + openLoginDesktop: @escaping () -> Void ) { self.accountManager = accountManager self.avatarAndNameInfoContext = avatarAndNameInfoContext @@ -177,6 +180,7 @@ private final class SettingsItemArguments { self.keepPhone = keepPhone self.openPhoneNumberChange = openPhoneNumberChange self.accountContextAction = accountContextAction + self.openLoginDesktop = openLoginDesktop } } @@ -185,6 +189,7 @@ private enum SettingsSection: Int32 { case phone case accounts case proxy + case loginDesktop case media case generalSettings case advanced @@ -205,6 +210,8 @@ private indirect enum SettingsEntry: ItemListNodeEntry { case proxy(PresentationTheme, UIImage?, String, String) + case loginDesktop(PresentationTheme, UIImage?, String) + case savedMessages(PresentationTheme, UIImage?, String) case recentCalls(PresentationTheme, UIImage?, String) case stickers(PresentationTheme, UIImage?, String, String, [ArchivedStickerPackItem]?) @@ -223,22 +230,24 @@ private indirect enum SettingsEntry: ItemListNodeEntry { var section: ItemListSectionId { switch self { - case .userInfo, .setProfilePhoto, .setUsername: - return SettingsSection.info.rawValue - case .phoneInfo, .keepPhone, .changePhone: - return SettingsSection.phone.rawValue - case .account, .addAccount: - return SettingsSection.accounts.rawValue - case .proxy: - return SettingsSection.proxy.rawValue - case .savedMessages, .recentCalls, .stickers: - return SettingsSection.media.rawValue - case .notificationsAndSounds, .privacyAndSecurity, .dataAndStorage, .themes, .language: - return SettingsSection.generalSettings.rawValue - case .passport, .wallet, .watch : - return SettingsSection.advanced.rawValue - case .askAQuestion, .faq: - return SettingsSection.help.rawValue + case .userInfo, .setProfilePhoto, .setUsername: + return SettingsSection.info.rawValue + case .phoneInfo, .keepPhone, .changePhone: + return SettingsSection.phone.rawValue + case .account, .addAccount: + return SettingsSection.accounts.rawValue + case .proxy: + return SettingsSection.proxy.rawValue + case .loginDesktop: + return SettingsSection.loginDesktop.rawValue + case .savedMessages, .recentCalls, .stickers: + return SettingsSection.media.rawValue + case .notificationsAndSounds, .privacyAndSecurity, .dataAndStorage, .themes, .language: + return SettingsSection.generalSettings.rawValue + case .passport, .wallet, .watch : + return SettingsSection.advanced.rawValue + case .askAQuestion, .faq: + return SettingsSection.help.rawValue } } @@ -262,32 +271,34 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return 1002 case .proxy: return 1003 - case .savedMessages: + case .loginDesktop: return 1004 - case .recentCalls: + case .savedMessages: return 1005 - case .stickers: + case .recentCalls: return 1006 - case .notificationsAndSounds: + case .stickers: return 1007 - case .privacyAndSecurity: + case .notificationsAndSounds: return 1008 - case .dataAndStorage: + case .privacyAndSecurity: return 1009 - case .themes: + case .dataAndStorage: return 1010 - case .language: + case .themes: return 1011 - case .wallet: + case .language: return 1012 - case .passport: + case .wallet: return 1013 - case .watch: + case .passport: return 1014 - case .askAQuestion: + case .watch: return 1015 - case .faq: + case .askAQuestion: return 1016 + case .faq: + return 1017 } } @@ -379,6 +390,12 @@ private indirect enum SettingsEntry: ItemListNodeEntry { } else { return false } + case let .loginDesktop(lhsTheme, lhsImage, lhsText): + if case let .loginDesktop(rhsTheme, rhsImage, rhsText) = rhs, lhsTheme === rhsTheme, lhsImage === rhsImage, lhsText == rhsText { + 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 @@ -528,6 +545,10 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: value, sectionId: ItemListSectionId(self.section), style: .blocks, action: { arguments.openProxy() }) + case let .loginDesktop(theme, image, text): + return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: "", sectionId: ItemListSectionId(self.section), style: .blocks, action: { + arguments.openLoginDesktop() + }) case let .savedMessages(theme, image, text): return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: "", sectionId: ItemListSectionId(self.section), style: .blocks, action: { arguments.openSavedMessages() @@ -636,6 +657,8 @@ private func settingsEntries(account: Account, presentationData: PresentationDat entries.append(.proxy(presentationData.theme, PresentationResourcesSettings.proxy, presentationData.strings.Settings_Proxy, valueString)) } + entries.append(.loginDesktop(presentationData.theme, PresentationResourcesSettings.security, "Telegram Desktop")) + entries.append(.savedMessages(presentationData.theme, PresentationResourcesSettings.savedMessages, presentationData.strings.Settings_SavedMessages)) entries.append(.recentCalls(presentationData.theme, PresentationResourcesSettings.recentCalls, presentationData.strings.CallSettings_RecentCalls)) entries.append(.stickers(presentationData.theme, PresentationResourcesSettings.stickers, presentationData.strings.ChatSettings_Stickers, unreadTrendingStickerPacks == 0 ? "" : "\(unreadTrendingStickerPacks)", archivedPacks)) @@ -1045,6 +1068,12 @@ public func settingsController(context: AccountContext, accountManager: AccountM } else { gesture?.cancel() } + }, openLoginDesktop: { + let _ = (contextValue.get() + |> deliverOnMainQueue + |> take(1)).start(next: { context in + pushControllerImpl?(AuthTransferScanScreen(context: context)) + }) }) changeProfilePhotoImpl = { diff --git a/submodules/TelegramApi/Sources/Api0.swift b/submodules/TelegramApi/Sources/Api0.swift index da6e2194bf..c3eff97993 100644 --- a/submodules/TelegramApi/Sources/Api0.swift +++ b/submodules/TelegramApi/Sources/Api0.swift @@ -53,6 +53,9 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[-614138572] = { return Api.account.TmpPassword.parse_tmpPassword($0) } dict[-2103600678] = { return Api.SecureRequiredType.parse_secureRequiredType($0) } dict[41187252] = { return Api.SecureRequiredType.parse_secureRequiredTypeOneOf($0) } + dict[1654593920] = { return Api.auth.LoginToken.parse_loginToken($0) } + dict[110008598] = { return Api.auth.LoginToken.parse_loginTokenMigrateTo($0) } + dict[957176926] = { return Api.auth.LoginToken.parse_loginTokenSuccess($0) } dict[1064139624] = { return Api.JSONValue.parse_jsonNull($0) } dict[-952869270] = { return Api.JSONValue.parse_jsonBool($0) } dict[736157604] = { return Api.JSONValue.parse_jsonNumber($0) } @@ -242,6 +245,8 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[-1870238482] = { return Api.Update.parse_updateDeleteScheduledMessages($0) } dict[-2112423005] = { return Api.Update.parse_updateTheme($0) } dict[357013699] = { return Api.Update.parse_updateMessageReactions($0) } + dict[-2027964103] = { return Api.Update.parse_updateGeoLiveViewed($0) } + dict[1448076945] = { return Api.Update.parse_updateLoginToken($0) } dict[1558266229] = { return Api.PopularContact.parse_popularContact($0) } dict[-373643672] = { return Api.FolderPeer.parse_folderPeer($0) } dict[367766557] = { return Api.ChannelParticipant.parse_channelParticipant($0) } @@ -594,6 +599,7 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[70813275] = { return Api.InputStickeredMedia.parse_inputStickeredMediaDocument($0) } dict[82699215] = { return Api.messages.FeaturedStickers.parse_featuredStickersNotModified($0) } dict[-123893531] = { return Api.messages.FeaturedStickers.parse_featuredStickers($0) } + dict[1375940666] = { return Api.auth.LoginTokenInfo.parse_loginTokenInfo($0) } dict[-2048646399] = { return Api.PhoneCallDiscardReason.parse_phoneCallDiscardReasonMissed($0) } dict[-527056480] = { return Api.PhoneCallDiscardReason.parse_phoneCallDiscardReasonDisconnect($0) } dict[1471006352] = { return Api.PhoneCallDiscardReason.parse_phoneCallDiscardReasonHangup($0) } @@ -868,6 +874,8 @@ public struct Api { _1.serialize(buffer, boxed) case let _1 as Api.SecureRequiredType: _1.serialize(buffer, boxed) + case let _1 as Api.auth.LoginToken: + _1.serialize(buffer, boxed) case let _1 as Api.JSONValue: _1.serialize(buffer, boxed) case let _1 as Api.Photo: @@ -1244,6 +1252,8 @@ public struct Api { _1.serialize(buffer, boxed) case let _1 as Api.messages.FeaturedStickers: _1.serialize(buffer, boxed) + case let _1 as Api.auth.LoginTokenInfo: + _1.serialize(buffer, boxed) case let _1 as Api.PhoneCallDiscardReason: _1.serialize(buffer, boxed) case let _1 as Api.NearestDc: diff --git a/submodules/TelegramApi/Sources/Api1.swift b/submodules/TelegramApi/Sources/Api1.swift index dea26f3ed2..3cbf567230 100644 --- a/submodules/TelegramApi/Sources/Api1.swift +++ b/submodules/TelegramApi/Sources/Api1.swift @@ -4145,6 +4145,8 @@ public extension Api { case updateDeleteScheduledMessages(peer: Api.Peer, messages: [Int32]) case updateTheme(theme: Api.Theme) case updateMessageReactions(peer: Api.Peer, msgId: Int32, reactions: Api.MessageReactions) + case updateGeoLiveViewed(peer: Api.Peer, msgId: Int32) + case updateLoginToken public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { switch self { @@ -4776,6 +4778,19 @@ public extension Api { peer.serialize(buffer, true) serializeInt32(msgId, buffer: buffer, boxed: false) reactions.serialize(buffer, true) + break + case .updateGeoLiveViewed(let peer, let msgId): + if boxed { + buffer.appendInt32(-2027964103) + } + peer.serialize(buffer, true) + serializeInt32(msgId, buffer: buffer, boxed: false) + break + case .updateLoginToken: + if boxed { + buffer.appendInt32(1448076945) + } + break } } @@ -4932,6 +4947,10 @@ public extension Api { return ("updateTheme", [("theme", theme)]) case .updateMessageReactions(let peer, let msgId, let reactions): return ("updateMessageReactions", [("peer", peer), ("msgId", msgId), ("reactions", reactions)]) + case .updateGeoLiveViewed(let peer, let msgId): + return ("updateGeoLiveViewed", [("peer", peer), ("msgId", msgId)]) + case .updateLoginToken: + return ("updateLoginToken", []) } } @@ -6211,6 +6230,25 @@ public extension Api { return nil } } + public static func parse_updateGeoLiveViewed(_ reader: BufferReader) -> Update? { + var _1: Api.Peer? + if let signature = reader.readInt32() { + _1 = Api.parse(reader, signature: signature) as? Api.Peer + } + var _2: Int32? + _2 = reader.readInt32() + let _c1 = _1 != nil + let _c2 = _2 != nil + if _c1 && _c2 { + return Api.Update.updateGeoLiveViewed(peer: _1!, msgId: _2!) + } + else { + return nil + } + } + public static func parse_updateLoginToken(_ reader: BufferReader) -> Update? { + return Api.Update.updateLoginToken + } } public enum PopularContact: TypeConstructorDescription { diff --git a/submodules/TelegramApi/Sources/Api2.swift b/submodules/TelegramApi/Sources/Api2.swift index 02f63a3f26..0eacd270a2 100644 --- a/submodules/TelegramApi/Sources/Api2.swift +++ b/submodules/TelegramApi/Sources/Api2.swift @@ -494,6 +494,90 @@ public struct payments { } public extension Api { public struct auth { + public enum LoginToken: TypeConstructorDescription { + case loginToken(expires: Int32, token: Buffer) + case loginTokenMigrateTo(dcId: Int32, token: Buffer) + case loginTokenSuccess(authorization: Api.auth.Authorization) + + public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { + switch self { + case .loginToken(let expires, let token): + if boxed { + buffer.appendInt32(1654593920) + } + serializeInt32(expires, buffer: buffer, boxed: false) + serializeBytes(token, buffer: buffer, boxed: false) + break + case .loginTokenMigrateTo(let dcId, let token): + if boxed { + buffer.appendInt32(110008598) + } + serializeInt32(dcId, buffer: buffer, boxed: false) + serializeBytes(token, buffer: buffer, boxed: false) + break + case .loginTokenSuccess(let authorization): + if boxed { + buffer.appendInt32(957176926) + } + authorization.serialize(buffer, true) + break + } + } + + public func descriptionFields() -> (String, [(String, Any)]) { + switch self { + case .loginToken(let expires, let token): + return ("loginToken", [("expires", expires), ("token", token)]) + case .loginTokenMigrateTo(let dcId, let token): + return ("loginTokenMigrateTo", [("dcId", dcId), ("token", token)]) + case .loginTokenSuccess(let authorization): + return ("loginTokenSuccess", [("authorization", authorization)]) + } + } + + public static func parse_loginToken(_ reader: BufferReader) -> LoginToken? { + var _1: Int32? + _1 = reader.readInt32() + var _2: Buffer? + _2 = parseBytes(reader) + let _c1 = _1 != nil + let _c2 = _2 != nil + if _c1 && _c2 { + return Api.auth.LoginToken.loginToken(expires: _1!, token: _2!) + } + else { + return nil + } + } + public static func parse_loginTokenMigrateTo(_ reader: BufferReader) -> LoginToken? { + var _1: Int32? + _1 = reader.readInt32() + var _2: Buffer? + _2 = parseBytes(reader) + let _c1 = _1 != nil + let _c2 = _2 != nil + if _c1 && _c2 { + return Api.auth.LoginToken.loginTokenMigrateTo(dcId: _1!, token: _2!) + } + else { + return nil + } + } + public static func parse_loginTokenSuccess(_ reader: BufferReader) -> LoginToken? { + var _1: Api.auth.Authorization? + if let signature = reader.readInt32() { + _1 = Api.parse(reader, signature: signature) as? Api.auth.Authorization + } + let _c1 = _1 != nil + if _c1 { + return Api.auth.LoginToken.loginTokenSuccess(authorization: _1!) + } + else { + return nil + } + } + + } public enum Authorization: TypeConstructorDescription { case authorization(flags: Int32, tmpSessions: Int32?, user: Api.User) case authorizationSignUpRequired(flags: Int32, termsOfService: Api.help.TermsOfService?) @@ -775,6 +859,76 @@ public struct auth { return Api.auth.CodeType.codeTypeFlashCall } + } + public enum LoginTokenInfo: TypeConstructorDescription { + case loginTokenInfo(dcId: Int32, authKeyId: Int64, deviceModel: String, platform: String, systemVersion: String, apiId: Int32, appName: String, appVersion: String, ip: String, region: String) + + public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { + switch self { + case .loginTokenInfo(let dcId, let authKeyId, let deviceModel, let platform, let systemVersion, let apiId, let appName, let appVersion, let ip, let region): + if boxed { + buffer.appendInt32(1375940666) + } + serializeInt32(dcId, buffer: buffer, boxed: false) + serializeInt64(authKeyId, buffer: buffer, boxed: false) + serializeString(deviceModel, buffer: buffer, boxed: false) + serializeString(platform, buffer: buffer, boxed: false) + serializeString(systemVersion, buffer: buffer, boxed: false) + serializeInt32(apiId, buffer: buffer, boxed: false) + serializeString(appName, buffer: buffer, boxed: false) + serializeString(appVersion, buffer: buffer, boxed: false) + serializeString(ip, buffer: buffer, boxed: false) + serializeString(region, buffer: buffer, boxed: false) + break + } + } + + public func descriptionFields() -> (String, [(String, Any)]) { + switch self { + case .loginTokenInfo(let dcId, let authKeyId, let deviceModel, let platform, let systemVersion, let apiId, let appName, let appVersion, let ip, let region): + return ("loginTokenInfo", [("dcId", dcId), ("authKeyId", authKeyId), ("deviceModel", deviceModel), ("platform", platform), ("systemVersion", systemVersion), ("apiId", apiId), ("appName", appName), ("appVersion", appVersion), ("ip", ip), ("region", region)]) + } + } + + public static func parse_loginTokenInfo(_ reader: BufferReader) -> LoginTokenInfo? { + var _1: Int32? + _1 = reader.readInt32() + var _2: Int64? + _2 = reader.readInt64() + var _3: String? + _3 = parseString(reader) + var _4: String? + _4 = parseString(reader) + var _5: String? + _5 = parseString(reader) + var _6: Int32? + _6 = reader.readInt32() + var _7: String? + _7 = parseString(reader) + var _8: String? + _8 = parseString(reader) + var _9: String? + _9 = parseString(reader) + var _10: String? + _10 = parseString(reader) + let _c1 = _1 != nil + let _c2 = _2 != nil + let _c3 = _3 != nil + let _c4 = _4 != nil + let _c5 = _5 != nil + let _c6 = _6 != nil + let _c7 = _7 != nil + let _c8 = _8 != nil + let _c9 = _9 != nil + let _c10 = _10 != nil + if _c1 && _c2 && _c3 && _c4 && _c5 && _c6 && _c7 && _c8 && _c9 && _c10 { + return Api.auth.LoginTokenInfo.loginTokenInfo(dcId: _1!, authKeyId: _2!, deviceModel: _3!, platform: _4!, systemVersion: _5!, apiId: _6!, appName: _7!, appVersion: _8!, ip: _9!, region: _10!) + } + else { + return nil + } + } + } public enum SentCodeType: TypeConstructorDescription { case sentCodeTypeApp(length: Int32) diff --git a/submodules/TelegramApi/Sources/Api3.swift b/submodules/TelegramApi/Sources/Api3.swift index 172bd06c92..ef1dad0a75 100644 --- a/submodules/TelegramApi/Sources/Api3.swift +++ b/submodules/TelegramApi/Sources/Api3.swift @@ -4139,6 +4139,63 @@ public extension Api { return result }) } + + public static func exportLoginToken(apiId: Int32, apiHash: String) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(434003159) + serializeInt32(apiId, buffer: buffer, boxed: false) + serializeString(apiHash, buffer: buffer, boxed: false) + return (FunctionDescription(name: "auth.exportLoginToken", parameters: [("apiId", apiId), ("apiHash", apiHash)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.auth.LoginToken? in + let reader = BufferReader(buffer) + var result: Api.auth.LoginToken? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.auth.LoginToken + } + return result + }) + } + + public static func importLoginToken(token: Buffer) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(-1783866140) + serializeBytes(token, buffer: buffer, boxed: false) + return (FunctionDescription(name: "auth.importLoginToken", parameters: [("token", token)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.auth.LoginToken? in + let reader = BufferReader(buffer) + var result: Api.auth.LoginToken? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.auth.LoginToken + } + return result + }) + } + + public static func acceptLoginToken(token: Buffer) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(1122447801) + serializeBytes(token, buffer: buffer, boxed: false) + return (FunctionDescription(name: "auth.acceptLoginToken", parameters: [("token", token)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in + let reader = BufferReader(buffer) + var result: Api.Updates? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.Updates + } + return result + }) + } + + public static func checkLoginToken(token: Buffer) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(2102383792) + serializeBytes(token, buffer: buffer, boxed: false) + return (FunctionDescription(name: "auth.checkLoginToken", parameters: [("token", token)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.auth.LoginTokenInfo? in + let reader = BufferReader(buffer) + var result: Api.auth.LoginTokenInfo? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.auth.LoginTokenInfo + } + return result + }) + } } public struct bots { public static func sendCustomRequest(customMethod: String, params: Api.DataJSON) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { diff --git a/submodules/TelegramCore/Sources/AuthTransfer.swift b/submodules/TelegramCore/Sources/AuthTransfer.swift new file mode 100644 index 0000000000..cb582da25b --- /dev/null +++ b/submodules/TelegramCore/Sources/AuthTransfer.swift @@ -0,0 +1,144 @@ +import Foundation +import Postbox +import TelegramApi +import SyncCore +import SwiftSignalKit + +public struct AuthTransferExportedToken { + public let value: Data + public let validUntil: Int32 +} + +public struct AuthTransferTokenInfo { + public let datacenterId: Int32 + public let authKeyId: Int64 + public let deviceModel: String + public let platform: String + public let systemVersion: String + public let apiId: Int32 + public let appName: String + public let appVersion: String + public let ip: String + public let region: String +} + +public enum ExportAuthTransferTokenError { + case generic +} + +public enum ExportAuthTransferTokenResult { + case displayToken(AuthTransferExportedToken) + case changeAccountAndRetry(UnauthorizedAccount) + case loggedIn +} + +public func exportAuthTransferToken(accountManager: AccountManager, account: UnauthorizedAccount, syncContacts: Bool) -> Signal { + return account.network.request(Api.functions.auth.exportLoginToken(apiId: account.networkArguments.apiId, apiHash: account.networkArguments.apiHash)) + |> mapError { _ -> ExportAuthTransferTokenError in + return .generic + } + |> mapToSignal { result -> Signal in + switch result { + case let .loginToken(expires, token): + return .single(.displayToken(AuthTransferExportedToken(value: token.makeData(), validUntil: expires))) + case let .loginTokenMigrateTo(dcId, token): + let updatedAccount = account.changedMasterDatacenterId(accountManager: accountManager, masterDatacenterId: dcId) + return updatedAccount + |> castError(ExportAuthTransferTokenError.self) + |> mapToSignal { updatedAccount -> Signal in + return updatedAccount.network.request(Api.functions.auth.importLoginToken(token: token)) + |> mapError { _ -> ExportAuthTransferTokenError in + return .generic + } + |> mapToSignal { result -> Signal in + switch result { + case let .loginTokenSuccess(authorization): + switch authorization { + case let .authorization(_, _, user): + return updatedAccount.postbox.transaction { transaction -> Signal in + let user = TelegramUser(user: user) + let state = AuthorizedAccountState(isTestingEnvironment: updatedAccount.testingEnvironment, masterDatacenterId: updatedAccount.masterDatacenterId, peerId: user.id, state: nil) + initializedAppSettingsAfterLogin(transaction: transaction, appVersion: updatedAccount.networkArguments.appVersion, syncContacts: syncContacts) + transaction.setState(state) + return accountManager.transaction { transaction -> ExportAuthTransferTokenResult in + switchToAuthorizedAccount(transaction: transaction, account: updatedAccount) + return .loggedIn + } + |> castError(ExportAuthTransferTokenError.self) + } + |> castError(ExportAuthTransferTokenError.self) + |> switchToLatest + default: + return .fail(.generic) + } + default: + return .single(.changeAccountAndRetry(updatedAccount)) + } + } + } + case let .loginTokenSuccess(authorization): + switch authorization { + case let .authorization(_, _, user): + return account.postbox.transaction { transaction -> Signal in + let user = TelegramUser(user: user) + let state = AuthorizedAccountState(isTestingEnvironment: account.testingEnvironment, masterDatacenterId: account.masterDatacenterId, peerId: user.id, state: nil) + initializedAppSettingsAfterLogin(transaction: transaction, appVersion: account.networkArguments.appVersion, syncContacts: syncContacts) + transaction.setState(state) + return accountManager.transaction { transaction -> ExportAuthTransferTokenResult in + switchToAuthorizedAccount(transaction: transaction, account: account) + return .loggedIn + } + |> castError(ExportAuthTransferTokenError.self) + } + |> castError(ExportAuthTransferTokenError.self) + |> switchToLatest + case let .authorizationSignUpRequired: + return .fail(.generic) + } + } + } +} + +public enum GetAuthTransferTokenInfoError { + case generic + case invalid + case expired + case alreadyAccepted +} + +public func getAuthTransferTokenInfo(network: Network, token: Data) -> Signal { + return network.request(Api.functions.auth.checkLoginToken(token: Buffer(data: token))) + |> mapError { error -> GetAuthTransferTokenInfoError in + switch error.errorDescription { + case "AUTH_TOKEN_INVALID": + return .invalid + case "AUTH_TOKEN_EXPIRED": + return .expired + case "AUTH_TOKEN_ALREADY_ACCEPTED": + return .alreadyAccepted + default: + return .generic + } + } + |> map { result -> AuthTransferTokenInfo in + switch result { + case let .loginTokenInfo(dcId, authKeyId, deviceModel, platform, systemVersion, apiId, appName, appVersion, ip, region): + return AuthTransferTokenInfo(datacenterId: dcId, authKeyId: authKeyId, deviceModel: deviceModel, platform: platform, systemVersion: systemVersion, apiId: apiId, appName: appName, appVersion: appVersion, ip: ip, region: region) + } + } +} + +public enum ApproveAuthTransferTokenError { + case generic +} + +public func approveAuthTransferToken(account: Account, token: Data) -> Signal { + return account.network.request(Api.functions.auth.acceptLoginToken(token: Buffer(data: token))) + |> mapError { _ -> ApproveAuthTransferTokenError in + return .generic + } + |> mapToSignal { updates -> Signal in + account.stateManager.addUpdates(updates) + return .complete() + } +} diff --git a/submodules/TelegramCore/Sources/Authorization.swift b/submodules/TelegramCore/Sources/Authorization.swift index 6708108d95..89926bef3c 100644 --- a/submodules/TelegramCore/Sources/Authorization.swift +++ b/submodules/TelegramCore/Sources/Authorization.swift @@ -15,7 +15,7 @@ public enum AuthorizationCodeRequestError { case timeout } -private func switchToAuthorizedAccount(transaction: AccountManagerModifier, account: UnauthorizedAccount) { +func switchToAuthorizedAccount(transaction: AccountManagerModifier, account: UnauthorizedAccount) { let nextSortOrder = (transaction.getRecords().map({ record -> Int32 in for attribute in record.attributes { if let attribute = attribute as? AccountSortOrderAttribute { diff --git a/submodules/TelegramCore/Sources/Network.swift b/submodules/TelegramCore/Sources/Network.swift index 5f155e0917..3d74acad6e 100644 --- a/submodules/TelegramCore/Sources/Network.swift +++ b/submodules/TelegramCore/Sources/Network.swift @@ -399,6 +399,7 @@ func networkUsageStats(basePath: String, reset: ResetNetworkUsageStats) -> Signa public struct NetworkInitializationArguments { public let apiId: Int32 + public let apiHash: String public let languagesCategory: String public let appVersion: String public let voipMaxLayer: Int32 @@ -406,8 +407,9 @@ public struct NetworkInitializationArguments { public let autolockDeadine: Signal public let encryptionProvider: EncryptionProvider - public init(apiId: Int32, languagesCategory: String, appVersion: String, voipMaxLayer: Int32, appData: Signal, autolockDeadine: Signal, encryptionProvider: EncryptionProvider) { + public init(apiId: Int32, apiHash: String, languagesCategory: String, appVersion: String, voipMaxLayer: Int32, appData: Signal, autolockDeadine: Signal, encryptionProvider: EncryptionProvider) { self.apiId = apiId + self.apiHash = apiHash self.languagesCategory = languagesCategory self.appVersion = appVersion self.voipMaxLayer = voipMaxLayer diff --git a/submodules/TelegramUI/TelegramUI/AppDelegate.swift b/submodules/TelegramUI/TelegramUI/AppDelegate.swift index d01f618e87..a2da5a7dd0 100644 --- a/submodules/TelegramUI/TelegramUI/AppDelegate.swift +++ b/submodules/TelegramUI/TelegramUI/AppDelegate.swift @@ -370,9 +370,10 @@ final class SharedApplicationContext { let signatureDict = BuildConfigExtra.signatureDict() let apiId: Int32 = buildConfig.apiId + let apiHash: String = buildConfig.apiHash let languagesCategory = "ios" - let networkArguments = NetworkInitializationArguments(apiId: apiId, 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, 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) { diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceController.swift index 86b5a570ec..9ef68b15a7 100644 --- a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceController.swift +++ b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceController.swift @@ -144,7 +144,7 @@ public final class AuthorizationSequenceController: NavigationController, MFMail if let currentController = currentController { controller = currentController } else { - controller = AuthorizationSequencePhoneEntryController(sharedContext: self.sharedContext, isTestingEnvironment: self.account.testingEnvironment, otherAccountPhoneNumbers: self.otherAccountPhoneNumbers, network: self.account.network, presentationData: self.presentationData, openUrl: { [weak self] url in + controller = AuthorizationSequencePhoneEntryController(sharedContext: self.sharedContext, account: self.account, isTestingEnvironment: self.account.testingEnvironment, otherAccountPhoneNumbers: self.otherAccountPhoneNumbers, network: self.account.network, presentationData: self.presentationData, openUrl: { [weak self] url in self?.openUrl(url) }, back: { [weak self] in guard let strongSelf = self else { @@ -160,6 +160,12 @@ public final class AuthorizationSequenceController: NavigationController, MFMail }).start() } }) + controller.accountUpdated = { [weak self] updatedAccount in + guard let strongSelf = self else { + return + } + strongSelf.account = updatedAccount + } controller.loginWithNumber = { [weak self, weak controller] number, syncContacts in if let strongSelf = self { controller?.inProgress = true diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryController.swift index c232bc8e2a..31c66b248a 100644 --- a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryController.swift +++ b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryController.swift @@ -19,6 +19,7 @@ final class AuthorizationSequencePhoneEntryController: ViewController { } private let sharedContext: SharedAccountContext + private var account: UnauthorizedAccount private let isTestingEnvironment: Bool private let otherAccountPhoneNumbers: ((String, AccountRecordId, Bool)?, [(String, AccountRecordId, Bool)]) private let network: Network @@ -41,13 +42,15 @@ final class AuthorizationSequencePhoneEntryController: ViewController { } } var loginWithNumber: ((String, Bool) -> Void)? + var accountUpdated: ((UnauthorizedAccount) -> Void)? private let termsDisposable = MetaDisposable() private let hapticFeedback = HapticFeedback() - init(sharedContext: SharedAccountContext, isTestingEnvironment: Bool, otherAccountPhoneNumbers: ((String, AccountRecordId, Bool)?, [(String, AccountRecordId, Bool)]), network: Network, presentationData: PresentationData, openUrl: @escaping (String) -> Void, back: @escaping () -> Void) { + init(sharedContext: SharedAccountContext, account: UnauthorizedAccount, isTestingEnvironment: Bool, otherAccountPhoneNumbers: ((String, AccountRecordId, Bool)?, [(String, AccountRecordId, Bool)]), network: Network, presentationData: PresentationData, openUrl: @escaping (String) -> Void, back: @escaping () -> Void) { self.sharedContext = sharedContext + self.account = account self.isTestingEnvironment = isTestingEnvironment self.otherAccountPhoneNumbers = otherAccountPhoneNumbers self.network = network @@ -95,13 +98,21 @@ final class AuthorizationSequencePhoneEntryController: ViewController { } override public func loadDisplayNode() { - self.displayNode = AuthorizationSequencePhoneEntryControllerNode(strings: self.presentationData.strings, theme: self.presentationData.theme, debugAction: { [weak self] in + self.displayNode = AuthorizationSequencePhoneEntryControllerNode(accountManager: self.sharedContext.accountManager, account: self.account, strings: self.presentationData.strings, theme: self.presentationData.theme, debugAction: { [weak self] in guard let strongSelf = self else { return } strongSelf.view.endEditing(true) self?.present(debugController(sharedContext: strongSelf.sharedContext, context: nil, modal: true), in: .window(.root), with: ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) - }, hasOtherAccounts: self.otherAccountPhoneNumbers.0 != nil) + }, hasOtherAccounts: self.otherAccountPhoneNumbers.0 != nil) + self.controllerNode.accountUpdated = { [weak self] account in + guard let strongSelf = self else { + return + } + strongSelf.account = account + strongSelf.accountUpdated?(account) + } + if let (code, name, number) = self.currentData { self.controllerNode.codeAndNumber = (code, name, number) } diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift index af8e2af666..0aec588b88 100644 --- a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift @@ -8,6 +8,9 @@ import TelegramPresentationData import PhoneInputNode import CountrySelectionUI import AuthorizationUI +import QrCode +import SwiftSignalKit +import Postbox private func emojiFlagForISOCountryCode(_ countryCode: NSString) -> String { if countryCode.length != 2 { @@ -201,6 +204,8 @@ private final class ContactSyncNode: ASDisplayNode { } final class AuthorizationSequencePhoneEntryControllerNode: ASDisplayNode { + private let accountManager: AccountManager + private var account: UnauthorizedAccount private let strings: PresentationStrings private let theme: PresentationTheme private let hasOtherAccounts: Bool @@ -210,6 +215,10 @@ final class AuthorizationSequencePhoneEntryControllerNode: ASDisplayNode { private let phoneAndCountryNode: PhoneAndCountryNode private let contactSyncNode: ContactSyncNode + private var qrNode: ASImageNode? + private let exportTokenDisposable = MetaDisposable() + var accountUpdated: ((UnauthorizedAccount) -> Void)? + private let debugAction: () -> Void var currentNumber: String { @@ -245,7 +254,10 @@ final class AuthorizationSequencePhoneEntryControllerNode: ASDisplayNode { } } - init(strings: PresentationStrings, theme: PresentationTheme, debugAction: @escaping () -> Void, hasOtherAccounts: Bool) { + init(accountManager: AccountManager, account: UnauthorizedAccount, strings: PresentationStrings, theme: PresentationTheme, debugAction: @escaping () -> Void, hasOtherAccounts: Bool) { + self.accountManager = accountManager + self.account = account + self.strings = strings self.theme = theme self.debugAction = debugAction @@ -257,7 +269,7 @@ final class AuthorizationSequencePhoneEntryControllerNode: ASDisplayNode { self.titleNode.attributedText = NSAttributedString(string: strings.Login_PhoneTitle, font: Font.light(30.0), textColor: theme.list.itemPrimaryTextColor) self.noticeNode = ASTextNode() - self.noticeNode.isUserInteractionEnabled = false + self.noticeNode.isUserInteractionEnabled = true self.noticeNode.displaysAsynchronously = false self.noticeNode.attributedText = NSAttributedString(string: strings.Login_PhoneAndCountryHelp, font: Font.regular(16.0), textColor: theme.list.itemPrimaryTextColor, paragraphAlignment: .center) @@ -287,10 +299,15 @@ final class AuthorizationSequencePhoneEntryControllerNode: ASDisplayNode { } } + deinit { + self.exportTokenDisposable.dispose() + } + override func didLoad() { super.didLoad() self.titleNode.view.addGestureRecognizer(UITapGestureRecognizer(target: self, action: #selector(self.debugTap(_:)))) + self.noticeNode.view.addGestureRecognizer(UITapGestureRecognizer(target: self, action: #selector(self.debugQrTap(_:)))) } func containerLayoutUpdated(_ layout: ContainerViewLayout, navigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { @@ -356,4 +373,62 @@ final class AuthorizationSequencePhoneEntryControllerNode: ASDisplayNode { } } } + + @objc private func debugQrTap(_ recognizer: UITapGestureRecognizer) { + if self.qrNode == nil { + let qrNode = ASImageNode() + qrNode.frame = CGRect(origin: CGPoint(x: 16.0, y: 64.0 + 16.0), size: CGSize(width: 200.0, height: 200.0)) + self.qrNode = qrNode + self.addSubnode(qrNode) + + self.refreshQrToken() + } + } + + private func refreshQrToken() { + let tokenSignal = exportAuthTransferToken(accountManager: self.accountManager, account: self.account, syncContacts: true) + + self.exportTokenDisposable.set((tokenSignal + |> deliverOnMainQueue).start(next: { [weak self] result in + guard let strongSelf = self else { + return + } + switch result { + case let .displayToken(token): + var tokenString = token.value.base64EncodedString() + print("export token \(tokenString)") + tokenString = tokenString.replacingOccurrences(of: "+", with: "-") + tokenString = tokenString.replacingOccurrences(of: "/", with: "_") + let urlString = "tg://login?token=\(tokenString)" + let _ = (qrCode(string: urlString, color: .black, backgroundColor: .white, icon: .none) + |> deliverOnMainQueue).start(next: { _, generate in + guard let strongSelf = self else { + return + } + + let context = generate(TransformImageArguments(corners: ImageCorners(), imageSize: CGSize(width: 200.0, height: 200.0), boundingSize: CGSize(width: 200.0, height: 200.0), intrinsicInsets: UIEdgeInsets())) + if let image = context?.generateImage() { + strongSelf.qrNode?.image = image + } + }) + + let timestamp = Int32(Date().timeIntervalSince1970) + let timeout = max(5, token.validUntil - timestamp) + strongSelf.exportTokenDisposable.set((Signal.complete() + |> delay(Double(timeout), queue: .mainQueue())).start(completed: { + guard let strongSelf = self else { + return + } + strongSelf.refreshQrToken() + })) + case let .changeAccountAndRetry(account): + strongSelf.exportTokenDisposable.set(nil) + strongSelf.account = account + strongSelf.accountUpdated?(account) + strongSelf.refreshQrToken() + case .loggedIn: + strongSelf.exportTokenDisposable.set(nil) + } + })) + } } diff --git a/submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputContextPanelNode.swift index e0ff3ff5b0..1c0d07952b 100644 --- a/submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputContextPanelNode.swift +++ b/submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputContextPanelNode.swift @@ -127,6 +127,7 @@ final class HorizontalListContextResultsChatInputContextPanelNode: ChatInputCont super.didLoad() self.listView.view.disablesInteractiveTransitionGestureRecognizer = true + self.listView.view.disablesInteractiveKeyboardGestureRecognizer = true self.view.addGestureRecognizer(PeekControllerGestureRecognizer(contentAtPoint: { [weak self] point in if let strongSelf = self { let convertedPoint = strongSelf.listView.view.convert(point, from: strongSelf.view) diff --git a/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift b/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift index 9182ea9df4..27f5c533c0 100644 --- a/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift +++ b/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift @@ -55,14 +55,16 @@ private func parseFileLocationResource(_ dict: [AnyHashable: Any]) -> TelegramMe public struct NotificationViewControllerInitializationData { public let appGroupPath: String public let apiId: Int32 + public let apiHash: String public let languagesCategory: String public let encryptionParameters: (Data, Data) public let appVersion: String public let bundleData: Data? - public init(appGroupPath: String, apiId: Int32, languagesCategory: String, encryptionParameters: (Data, Data), appVersion: String, bundleData: Data?) { + public init(appGroupPath: String, apiId: Int32, apiHash: String, languagesCategory: String, encryptionParameters: (Data, Data), appVersion: String, bundleData: Data?) { self.appGroupPath = appGroupPath self.apiId = apiId + self.apiHash = apiHash self.languagesCategory = languagesCategory self.encryptionParameters = encryptionParameters self.appVersion = appVersion @@ -152,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, 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, 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/TelegramUI/ShareExtensionContext.swift b/submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift index f667a98f59..283192e7a9 100644 --- a/submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift +++ b/submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift @@ -48,14 +48,16 @@ private enum ShareAuthorizationError { public struct ShareRootControllerInitializationData { public let appGroupPath: String public let apiId: Int32 + public let apiHash: String public let languagesCategory: String public let encryptionParameters: (Data, Data) public let appVersion: String public let bundleData: Data? - public init(appGroupPath: String, apiId: Int32, languagesCategory: String, encryptionParameters: (Data, Data), appVersion: String, bundleData: Data?) { + public init(appGroupPath: String, apiId: Int32, apiHash: String, languagesCategory: String, encryptionParameters: (Data, Data), appVersion: String, bundleData: Data?) { self.appGroupPath = appGroupPath self.apiId = apiId + self.apiHash = apiHash self.languagesCategory = languagesCategory self.encryptionParameters = encryptionParameters self.appVersion = appVersion @@ -190,7 +192,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, 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, 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 From 9f686dc0cb4fd9f0b8b083fb9974b4f7c8eb8b2e Mon Sep 17 00:00:00 2001 From: Ali <> Date: Fri, 22 Nov 2019 03:18:45 +0400 Subject: [PATCH 21/25] Initial QR Auth UI --- submodules/AuthTransferUI/BUCK | 3 + .../AuthTransferConfirmationScreen.swift | 166 ++++++++++++++++++ .../Sources/AuthTransferScanScreen.swift | 99 ++++++++++- .../Sources/SettingsController.swift | 36 ++-- submodules/TelegramCore/Sources/Account.swift | 12 ++ .../UnauthorizedAccountStateManager.swift | 86 +++++++++ .../TransferAuthLaptop.imageset/Contents.json | 12 ++ .../EmojiComputer.pdf | Bin 0 -> 22801 bytes ...tionSequencePhoneEntryControllerNode.swift | 11 ++ 9 files changed, 397 insertions(+), 28 deletions(-) create mode 100644 submodules/AuthTransferUI/Sources/AuthTransferConfirmationScreen.swift create mode 100644 submodules/TelegramCore/Sources/UnauthorizedAccountStateManager.swift create mode 100644 submodules/TelegramUI/Images.xcassets/Settings/TransferAuthLaptop.imageset/Contents.json create mode 100644 submodules/TelegramUI/Images.xcassets/Settings/TransferAuthLaptop.imageset/EmojiComputer.pdf diff --git a/submodules/AuthTransferUI/BUCK b/submodules/AuthTransferUI/BUCK index 494377d70f..c496f26116 100644 --- a/submodules/AuthTransferUI/BUCK +++ b/submodules/AuthTransferUI/BUCK @@ -9,6 +9,7 @@ static_library( "//submodules/TelegramCore:TelegramCore#shared", "//submodules/SyncCore:SyncCore#shared", "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit#shared", + "//submodules/AsyncDisplayKit:AsyncDisplayKit#shared", "//submodules/Display:Display#shared", "//submodules/TelegramPresentationData:TelegramPresentationData", "//submodules/AccountContext:AccountContext", @@ -16,6 +17,8 @@ static_library( "//submodules/Camera:Camera", "//submodules/GlassButtonNode:GlassButtonNode", "//submodules/AlertUI:AlertUI", + "//submodules/AppBundle:AppBundle", + "//submodules/SolidRoundedButtonNode:SolidRoundedButtonNode", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/AuthTransferUI/Sources/AuthTransferConfirmationScreen.swift b/submodules/AuthTransferUI/Sources/AuthTransferConfirmationScreen.swift new file mode 100644 index 0000000000..8282fc23a2 --- /dev/null +++ b/submodules/AuthTransferUI/Sources/AuthTransferConfirmationScreen.swift @@ -0,0 +1,166 @@ +import Foundation +import UIKit +import AppBundle +import AsyncDisplayKit +import Display +import SolidRoundedButtonNode +import SwiftSignalKit +import OverlayStatusController +import AnimatedStickerNode +import TelegramPresentationData +import TelegramCore +import AccountContext + +final class AuthTransferConfirmationNode: ASDisplayNode { + private let context: AccountContext + private var presentationData: PresentationData + private let tokenInfo: AuthTransferTokenInfo + + private let containerNode: ASDisplayNode + private let backgroundNode: ASImageNode + private let iconNode: ASImageNode + private let titleNode: ImmediateTextNode + private let appNameNode: ImmediateTextNode + private let locationInfoNode: ImmediateTextNode + private let acceptButtonNode: SolidRoundedButtonNode + private let cancelButtonNode: SolidRoundedButtonNode + + private var validLayout: (ContainerViewLayout, CGFloat)? + + init(context: AccountContext, presentationData: PresentationData, tokenInfo: AuthTransferTokenInfo, accept: @escaping () -> Void, cancel: @escaping () -> Void) { + self.context = context + self.presentationData = presentationData + self.tokenInfo = tokenInfo + + self.containerNode = ASDisplayNode() + + self.backgroundNode = ASImageNode() + self.backgroundNode.displayWithoutProcessing = true + self.backgroundNode.displaysAsynchronously = false + self.backgroundNode.image = generateStretchableFilledCircleImage(diameter: 24.0, color: self.presentationData.theme.list.plainBackgroundColor) + + self.iconNode = ASImageNode() + self.iconNode.displayWithoutProcessing = true + self.iconNode.displaysAsynchronously = false + self.iconNode.image = UIImage(bundleImageName: "Settings/TransferAuthLaptop") + + self.titleNode = ImmediateTextNode() + self.titleNode.textAlignment = .center + self.titleNode.maximumNumberOfLines = 2 + + self.appNameNode = ImmediateTextNode() + self.appNameNode.textAlignment = .center + self.appNameNode.maximumNumberOfLines = 2 + + self.locationInfoNode = ImmediateTextNode() + self.locationInfoNode.textAlignment = .center + self.locationInfoNode.maximumNumberOfLines = 0 + + self.acceptButtonNode = SolidRoundedButtonNode(title: "Confirm Log In", icon: nil, theme: SolidRoundedButtonTheme(backgroundColor: self.presentationData.theme.list.itemDestructiveColor, foregroundColor: self.presentationData.theme.list.itemCheckColors.foregroundColor), height: 50.0, cornerRadius: 10.0, gloss: false) + self.cancelButtonNode = SolidRoundedButtonNode(title: self.presentationData.strings.Common_Cancel, icon: nil, theme: SolidRoundedButtonTheme(backgroundColor: self.presentationData.theme.list.itemCheckColors.fillColor, foregroundColor: self.presentationData.theme.list.itemCheckColors.foregroundColor), height: 50.0, cornerRadius: 10.0, gloss: false) + + super.init() + + self.addSubnode(self.containerNode) + self.containerNode.addSubnode(self.backgroundNode) + self.containerNode.addSubnode(self.iconNode) + self.containerNode.addSubnode(self.titleNode) + self.containerNode.addSubnode(self.appNameNode) + self.containerNode.addSubnode(self.locationInfoNode) + self.containerNode.addSubnode(self.acceptButtonNode) + self.containerNode.addSubnode(self.cancelButtonNode) + + let titleFont = Font.bold(24.0) + let subtitleFont = Font.regular(16.0) + let textColor = self.presentationData.theme.list.itemPrimaryTextColor + let seccondaryTextColor = self.presentationData.theme.list.itemSecondaryTextColor + + self.titleNode.attributedText = NSAttributedString(string: "\(tokenInfo.appName)", font: titleFont, textColor: textColor) + + self.appNameNode.attributedText = NSAttributedString(string: "\(tokenInfo.deviceModel), \(tokenInfo.platform) \(tokenInfo.systemVersion)", font: subtitleFont, textColor: seccondaryTextColor) + + self.locationInfoNode.attributedText = NSAttributedString(string: "\(tokenInfo.region)\nIP: \(tokenInfo.ip)", font: subtitleFont, textColor: seccondaryTextColor) + + self.acceptButtonNode.pressed = { [weak self] in + accept() + } + self.cancelButtonNode.pressed = { + cancel() + } + } + + override func didLoad() { + super.didLoad() + } + + func animateIn() { + self.containerNode.layer.animatePosition(from: CGPoint(x: 0.0, y: self.containerNode.bounds.height), to: CGPoint(), duration: 0.5, timingFunction: kCAMediaTimingFunctionSpring, additive: true) + } + + func animateOut(completion: @escaping () -> Void) { + self.containerNode.layer.animatePosition(from: CGPoint(), to: CGPoint(x: 0.0, y: self.containerNode.bounds.height), duration: 0.3, removeOnCompletion: false, additive: true, completion: { _ in + completion() + }) + } + + func updateLayout(layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { + var insets = layout.insets(options: []) + let sideInset: CGFloat = 22.0 + + let buttonSideInset: CGFloat = 16.0 + let bottomInset = insets.bottom + 10.0 + let buttonWidth = layout.size.width - buttonSideInset * 2.0 + let buttonHeight: CGFloat = 50.0 + let buttonSpacing: CGFloat = 20.0 + let contentButtonSpacing: CGFloat = 35.0 + let titleSpacing: CGFloat = 1.0 + let locationSpacing: CGFloat = 35.0 + let iconSpacing: CGFloat = 35.0 + let topInset: CGFloat = 35.0 + + let iconSize = self.iconNode.image?.size ?? CGSize(width: 10.0, height: 1.0) + let titleSize = self.titleNode.updateLayout(CGSize(width: layout.size.width - sideInset * 2.0, height: .greatestFiniteMagnitude)) + let appNameSize = self.appNameNode.updateLayout(CGSize(width: layout.size.width - sideInset * 2.0, height: .greatestFiniteMagnitude)) + let locationSize = self.locationInfoNode.updateLayout(CGSize(width: layout.size.width - sideInset * 2.0, height: .greatestFiniteMagnitude)) + + var contentHeight: CGFloat = 0.0 + contentHeight += topInset + iconSize.height + contentHeight += iconSpacing + titleSize.height + contentHeight += titleSpacing + appNameSize.height + contentHeight += locationSpacing + locationSize.height + contentHeight += contentButtonSpacing + bottomInset + buttonHeight + buttonSpacing + buttonHeight + + let iconFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - iconSize.width) / 2.0), y: topInset), size: iconSize) + transition.updateFrame(node: self.iconNode, frame: iconFrame) + + let titleFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - titleSize.width) / 2.0), y: iconFrame.maxY + iconSpacing), size: titleSize) + transition.updateFrame(node: self.titleNode, frame: titleFrame) + + let appNameFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - appNameSize.width) / 2.0), y: titleFrame.maxY + titleSpacing), size: appNameSize) + transition.updateFrame(node: self.appNameNode, frame: appNameFrame) + + let locationFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - locationSize.width) / 2.0), y: appNameFrame.maxY + locationSpacing), size: locationSize) + transition.updateFrame(node: self.locationInfoNode, frame: locationFrame) + + let cancelButtonFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - buttonWidth) / 2.0), y: contentHeight - bottomInset - buttonHeight), size: CGSize(width: buttonWidth, height: buttonHeight)) + transition.updateFrame(node: self.cancelButtonNode, frame: cancelButtonFrame) + self.cancelButtonNode.updateLayout(width: cancelButtonFrame.width, transition: transition) + + let acceptButtonFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - buttonWidth) / 2.0), y: cancelButtonFrame.minY - buttonSpacing - buttonHeight), size: CGSize(width: buttonWidth, height: buttonHeight)) + transition.updateFrame(node: self.acceptButtonNode, frame: acceptButtonFrame) + self.acceptButtonNode.updateLayout(width: acceptButtonFrame.width, transition: transition) + + transition.updateFrame(node: self.containerNode, frame: CGRect(origin: CGPoint(x: 0.0, y: layout.size.height - contentHeight), size: CGSize(width: layout.size.width, height: contentHeight))) + transition.updateFrame(node: self.backgroundNode, frame: CGRect(origin: CGPoint(x: 0.0, y: 0.0), size: CGSize(width: layout.size.width, height: contentHeight + 24.0))) + } + + override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { + if let result = self.cancelButtonNode.view.hitTest(self.view.convert(point, to: self.cancelButtonNode.view), with: event) { + return result + } + if let result = self.acceptButtonNode.view.hitTest(self.view.convert(point, to: self.acceptButtonNode.view), with: event) { + return result + } + return super.hitTest(point, with: event) + } +} diff --git a/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift b/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift index 05bf3e34ba..7ac48824ca 100644 --- a/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift +++ b/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift @@ -136,16 +136,34 @@ public final class AuthTransferScanScreen: ViewController { return } if let url = URL(string: code), let parsedToken = parseAuthTransferUrl(url) { - print("import token: \(parsedToken.base64EncodedString())") - - strongSelf.approveDisposable.set((approveAuthTransferToken(account: strongSelf.context.account, token: parsedToken) - |> deliverOnMainQueue).start(error: { _ in - }, completed: { + let _ = (getAuthTransferTokenInfo(network: strongSelf.context.account.network, token: parsedToken) + |> deliverOnMainQueue).start(next: { tokenInfo in guard let strongSelf = self else { return } - strongSelf.dismiss() - })) + (strongSelf.displayNode as! AuthTransferScanScreenNode).updateTokenPreview(confirmationNode: AuthTransferConfirmationNode(context: strongSelf.context, presentationData: strongSelf.presentationData, tokenInfo: tokenInfo, accept: { + guard let strongSelf = self else { + return + } + strongSelf.approveDisposable.set((approveAuthTransferToken(account: strongSelf.context.account, token: parsedToken) + |> deliverOnMainQueue).start(error: { _ in + guard let strongSelf = self else { + return + } + (strongSelf.displayNode as! AuthTransferScanScreenNode).updateTokenPreview(confirmationNode: nil) + }, completed: { + guard let strongSelf = self else { + return + } + strongSelf.dismiss() + })) + }, cancel: { + guard let strongSelf = self else { + return + } + (strongSelf.displayNode as! AuthTransferScanScreenNode).updateTokenPreview(confirmationNode: nil) + })) + }) } }) } @@ -166,9 +184,11 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr private let bottomDimNode: ASDisplayNode private let leftDimNode: ASDisplayNode private let rightDimNode: ASDisplayNode + private let centerDimNode: ASDisplayNode private let frameNode: ASImageNode private let torchButtonNode: GlassButtonNode private let titleNode: ImmediateTextNode + private let textNode: ImmediateTextNode private let camera: Camera private let codeDisposable = MetaDisposable() @@ -176,6 +196,8 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr fileprivate let focusedCode = ValuePromise(ignoreRepeated: true) private var focusedRect: CGRect? + private(set) var confirmationNode: AuthTransferConfirmationNode? + private var validLayout: (ContainerViewLayout, CGFloat)? init(presentationData: PresentationData) { @@ -204,6 +226,10 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr self.rightDimNode.alpha = 0.625 self.rightDimNode.backgroundColor = UIColor(rgb: 0x000000, alpha: 0.8) + self.centerDimNode = ASDisplayNode() + self.centerDimNode.alpha = 0.0 + self.centerDimNode.backgroundColor = UIColor(rgb: 0x000000, alpha: 0.8) + self.frameNode = ASImageNode() self.frameNode.image = generateFrameImage() @@ -215,6 +241,12 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr self.titleNode.maximumNumberOfLines = 0 self.titleNode.textAlignment = .center + self.textNode = ImmediateTextNode() + self.textNode.displaysAsynchronously = false + self.textNode.attributedText = NSAttributedString(string: "Scan a QR code to log into\nthis account on another device.", font: Font.regular(16.0), textColor: .white) + self.textNode.maximumNumberOfLines = 0 + self.textNode.textAlignment = .center + self.camera = Camera(configuration: .init(preset: .hd1920x1080, position: .back, audio: false)) super.init() @@ -227,9 +259,11 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr self.addSubnode(self.bottomDimNode) self.addSubnode(self.leftDimNode) self.addSubnode(self.rightDimNode) + self.addSubnode(self.centerDimNode) self.addSubnode(self.frameNode) self.addSubnode(self.torchButtonNode) self.addSubnode(self.titleNode) + self.addSubnode(self.textNode) self.torchButtonNode.addTarget(self, action: #selector(self.torchPressed), forControlEvents: .touchUpInside) } @@ -281,6 +315,28 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr } } + func updateTokenPreview(confirmationNode: AuthTransferConfirmationNode?) { + if let confirmationNode = self.confirmationNode { + confirmationNode.animateOut { [weak confirmationNode] in + confirmationNode?.removeFromSupernode() + } + self.confirmationNode = nil + } + self.confirmationNode = confirmationNode + if let confirmationNode = self.confirmationNode { + self.addSubnode(confirmationNode) + if let (layout, navigationHeight) = self.validLayout { + confirmationNode.updateLayout(layout: layout, transition: .immediate) + confirmationNode.animateIn() + self.containerLayoutUpdated(layout: layout, navigationHeight: navigationHeight, transition: .animated(duration: 0.3, curve: .easeInOut)) + } + } else { + if let (layout, navigationHeight) = self.validLayout { + self.containerLayoutUpdated(layout: layout, navigationHeight: navigationHeight, transition: .animated(duration: 0.3, curve: .easeInOut)) + } + } + } + func containerLayoutUpdated(layout: ContainerViewLayout, navigationHeight: CGFloat, transition: ContainedViewLayoutTransition) { self.validLayout = (layout, navigationHeight) @@ -307,7 +363,21 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr let dimAlpha: CGFloat let dimRect: CGRect let controlsAlpha: CGFloat - if let focusedRect = self.focusedRect { + var centerDimAlpha: CGFloat = 0.0 + var frameAlpha: CGFloat = 1.0 + if self.confirmationNode != nil { + controlsAlpha = 0.0 + dimAlpha = 0.625 + centerDimAlpha = 0.625 + frameAlpha = 0.0 + if let focusedRect = self.focusedRect { + let side = max(bounds.width * focusedRect.width, bounds.height * focusedRect.height) * 0.6 + let center = CGPoint(x: (1.0 - focusedRect.center.y) * bounds.width, y: focusedRect.center.x * bounds.height) + dimRect = CGRect(x: center.x - side / 2.0, y: center.y - side / 2.0, width: side, height: side) + } else { + dimRect = CGRect(x: dimInset, y: dimHeight, width: layout.size.width - dimInset * 2.0, height: layout.size.height - dimHeight * 2.0) + } + } else if let focusedRect = self.focusedRect { controlsAlpha = 0.0 dimAlpha = 1.0 let side = max(bounds.width * focusedRect.width, bounds.height * focusedRect.height) * 0.6 @@ -323,22 +393,33 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr transition.updateAlpha(node: self.bottomDimNode, alpha: dimAlpha) transition.updateAlpha(node: self.leftDimNode, alpha: dimAlpha) transition.updateAlpha(node: self.rightDimNode, alpha: dimAlpha) + transition.updateAlpha(node: self.centerDimNode, alpha: centerDimAlpha) + transition.updateAlpha(node: self.frameNode, alpha: frameAlpha) transition.updateFrame(node: self.topDimNode, frame: CGRect(x: 0.0, y: 0.0, width: layout.size.width, height: dimRect.minY)) transition.updateFrame(node: self.bottomDimNode, frame: CGRect(x: 0.0, y: dimRect.maxY, width: layout.size.width, height: max(0.0, layout.size.height - dimRect.maxY))) transition.updateFrame(node: self.leftDimNode, frame: CGRect(x: 0.0, y: dimRect.minY, width: max(0.0, dimRect.minX), height: dimRect.height)) transition.updateFrame(node: self.rightDimNode, frame: CGRect(x: dimRect.maxX, y: dimRect.minY, width: max(0.0, layout.size.width - dimRect.maxX), height: dimRect.height)) transition.updateFrame(node: self.frameNode, frame: dimRect.insetBy(dx: -2.0, dy: -2.0)) + transition.updateFrame(node: self.centerDimNode, frame: dimRect) let buttonSize = CGSize(width: 72.0, height: 72.0) transition.updateFrame(node: self.torchButtonNode, frame: CGRect(origin: CGPoint(x: floor((layout.size.width - buttonSize.width) / 2.0), y: dimHeight + frameSide + 50.0), size: buttonSize)) transition.updateAlpha(node: self.titleNode, alpha: controlsAlpha) + transition.updateAlpha(node: self.textNode, alpha: controlsAlpha) transition.updateAlpha(node: self.torchButtonNode, alpha: controlsAlpha) let titleSize = self.titleNode.updateLayout(CGSize(width: layout.size.width - sideInset * 2.0, height: layout.size.height)) - let titleFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - titleSize.width) / 2.0), y: dimHeight - titleSize.height - titleSpacing), size: titleSize) + let textSize = self.textNode.updateLayout(CGSize(width: layout.size.width - sideInset * 2.0, height: layout.size.height)) + let textFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - textSize.width) / 2.0), y: dimHeight - textSize.height - titleSpacing), size: textSize) + let titleFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - titleSize.width) / 2.0), y: textFrame.minY - 18.0 - titleSize.height), size: titleSize) transition.updateFrameAdditive(node: self.titleNode, frame: titleFrame) + transition.updateFrameAdditive(node: self.textNode, frame: textFrame) + + if let confirmationNode = self.confirmationNode { + confirmationNode.updateLayout(layout: layout, transition: transition) + } } @objc private func torchPressed() { diff --git a/submodules/SettingsUI/Sources/SettingsController.swift b/submodules/SettingsUI/Sources/SettingsController.swift index 5292743553..dcd5241e6d 100644 --- a/submodules/SettingsUI/Sources/SettingsController.swift +++ b/submodules/SettingsUI/Sources/SettingsController.swift @@ -113,7 +113,7 @@ private final class SettingsItemArguments { let keepPhone: () -> Void let openPhoneNumberChange: () -> Void let accountContextAction: (AccountRecordId, ASDisplayNode, ContextGesture?) -> Void - let openLoginDesktop: () -> Void + let openDevices: () -> Void init( accountManager: AccountManager, @@ -147,7 +147,7 @@ private final class SettingsItemArguments { keepPhone: @escaping () -> Void, openPhoneNumberChange: @escaping () -> Void, accountContextAction: @escaping (AccountRecordId, ASDisplayNode, ContextGesture?) -> Void, - openLoginDesktop: @escaping () -> Void + openDevices: @escaping () -> Void ) { self.accountManager = accountManager self.avatarAndNameInfoContext = avatarAndNameInfoContext @@ -180,7 +180,7 @@ private final class SettingsItemArguments { self.keepPhone = keepPhone self.openPhoneNumberChange = openPhoneNumberChange self.accountContextAction = accountContextAction - self.openLoginDesktop = openLoginDesktop + self.openDevices = openDevices } } @@ -189,7 +189,6 @@ private enum SettingsSection: Int32 { case phone case accounts case proxy - case loginDesktop case media case generalSettings case advanced @@ -210,7 +209,7 @@ private indirect enum SettingsEntry: ItemListNodeEntry { case proxy(PresentationTheme, UIImage?, String, String) - case loginDesktop(PresentationTheme, UIImage?, String) + case devices(PresentationTheme, UIImage?, String, String) case savedMessages(PresentationTheme, UIImage?, String) case recentCalls(PresentationTheme, UIImage?, String) @@ -238,8 +237,8 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return SettingsSection.accounts.rawValue case .proxy: return SettingsSection.proxy.rawValue - case .loginDesktop: - return SettingsSection.loginDesktop.rawValue + case .devices: + return SettingsSection.media.rawValue case .savedMessages, .recentCalls, .stickers: return SettingsSection.media.rawValue case .notificationsAndSounds, .privacyAndSecurity, .dataAndStorage, .themes, .language: @@ -271,13 +270,13 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return 1002 case .proxy: return 1003 - case .loginDesktop: - return 1004 case .savedMessages: - return 1005 + return 1004 case .recentCalls: - return 1006 + return 1005 case .stickers: + return 1006 + case .devices: return 1007 case .notificationsAndSounds: return 1008 @@ -390,8 +389,8 @@ private indirect enum SettingsEntry: ItemListNodeEntry { } else { return false } - case let .loginDesktop(lhsTheme, lhsImage, lhsText): - if case let .loginDesktop(rhsTheme, rhsImage, rhsText) = rhs, lhsTheme === rhsTheme, lhsImage === rhsImage, lhsText == rhsText { + case let .devices(lhsTheme, lhsImage, lhsText, lhsValue): + if case let .devices(rhsTheme, rhsImage, rhsText, rhsValue) = rhs, lhsTheme === rhsTheme, lhsImage === rhsImage, lhsText == rhsText, lhsValue == rhsValue { return true } else { return false @@ -545,9 +544,9 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: value, sectionId: ItemListSectionId(self.section), style: .blocks, action: { arguments.openProxy() }) - case let .loginDesktop(theme, image, text): - return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: "", sectionId: ItemListSectionId(self.section), style: .blocks, action: { - arguments.openLoginDesktop() + case let .devices(theme, image, text, value): + return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: value, sectionId: ItemListSectionId(self.section), style: .blocks, action: { + arguments.openDevices() }) case let .savedMessages(theme, image, text): return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: "", sectionId: ItemListSectionId(self.section), style: .blocks, action: { @@ -657,11 +656,10 @@ private func settingsEntries(account: Account, presentationData: PresentationDat entries.append(.proxy(presentationData.theme, PresentationResourcesSettings.proxy, presentationData.strings.Settings_Proxy, valueString)) } - entries.append(.loginDesktop(presentationData.theme, PresentationResourcesSettings.security, "Telegram Desktop")) - entries.append(.savedMessages(presentationData.theme, PresentationResourcesSettings.savedMessages, presentationData.strings.Settings_SavedMessages)) entries.append(.recentCalls(presentationData.theme, PresentationResourcesSettings.recentCalls, presentationData.strings.CallSettings_RecentCalls)) entries.append(.stickers(presentationData.theme, PresentationResourcesSettings.stickers, presentationData.strings.ChatSettings_Stickers, unreadTrendingStickerPacks == 0 ? "" : "\(unreadTrendingStickerPacks)", archivedPacks)) + entries.append(.devices(presentationData.theme, PresentationResourcesSettings.stickers, "Devices", "")) let notificationsWarning = shouldDisplayNotificationsPermissionWarning(status: notificationsAuthorizationStatus, suppressed: notificationsWarningSuppressed) entries.append(.notificationsAndSounds(presentationData.theme, PresentationResourcesSettings.notifications, presentationData.strings.Settings_NotificationsAndSounds, notifyExceptions, notificationsWarning)) @@ -1068,7 +1066,7 @@ public func settingsController(context: AccountContext, accountManager: AccountM } else { gesture?.cancel() } - }, openLoginDesktop: { + }, openDevices: { let _ = (contextValue.get() |> deliverOnMainQueue |> take(1)).start(next: { context in diff --git a/submodules/TelegramCore/Sources/Account.swift b/submodules/TelegramCore/Sources/Account.swift index f1fecc8907..55c03cea20 100644 --- a/submodules/TelegramCore/Sources/Account.swift +++ b/submodules/TelegramCore/Sources/Account.swift @@ -61,6 +61,12 @@ public class UnauthorizedAccount { public let testingEnvironment: Bool public let postbox: Postbox public let network: Network + private let stateManager: UnauthorizedAccountStateManager + + private let updateLoginTokenPipe = ValuePipe() + public var updateLoginTokenEvents: Signal { + return self.updateLoginTokenPipe.signal() + } public var masterDatacenterId: Int32 { return Int32(self.network.mtProto.datacenterId) @@ -76,6 +82,10 @@ public class UnauthorizedAccount { self.testingEnvironment = testingEnvironment self.postbox = postbox self.network = network + let updateLoginTokenPipe = self.updateLoginTokenPipe + self.stateManager = UnauthorizedAccountStateManager(network: network, updateLoginToken: { + updateLoginTokenPipe.putNext(Void()) + }) network.shouldKeepConnection.set(self.shouldBeServiceTaskMaster.get() |> map { mode -> Bool in @@ -99,6 +109,8 @@ public class UnauthorizedAccount { } network.context.beginExplicitBackupAddressDiscovery() }) + + self.stateManager.reset() } public func changedMasterDatacenterId(accountManager: AccountManager, masterDatacenterId: Int32) -> Signal { diff --git a/submodules/TelegramCore/Sources/UnauthorizedAccountStateManager.swift b/submodules/TelegramCore/Sources/UnauthorizedAccountStateManager.swift new file mode 100644 index 0000000000..19a87d91f3 --- /dev/null +++ b/submodules/TelegramCore/Sources/UnauthorizedAccountStateManager.swift @@ -0,0 +1,86 @@ +import Foundation +import Postbox +import SwiftSignalKit +import TelegramApi +import MtProtoKit +import SyncCore + +private final class UnauthorizedUpdateMessageService: NSObject, MTMessageService { + let pipe: ValuePipe<[Api.Update]> = ValuePipe() + var mtProto: MTProto? + + override init() { + super.init() + } + + func mtProtoWillAdd(_ mtProto: MTProto!) { + self.mtProto = mtProto + } + + func mtProtoDidChangeSession(_ mtProto: MTProto!) { + } + + func mtProtoServerDidChangeSession(_ mtProto: MTProto!, firstValidMessageId: Int64, otherValidMessageIds: [Any]!) { + } + + func putNext(_ updates: [Api.Update]) { + self.pipe.putNext(updates) + } + + func mtProto(_ mtProto: MTProto!, receivedMessage message: MTIncomingMessage!) { + if let updates = (message.body as? BoxedMessage)?.body as? Api.Updates { + self.addUpdates(updates) + } + } + + func addUpdates(_ updates: Api.Updates) { + switch updates { + case let .updates(updates, _, _, _, _): + self.putNext(updates) + case let .updatesCombined(updates, _, _, _, _, _): + self.putNext(updates) + case let .updateShort(update, _): + self.putNext([update]) + case .updateShortChatMessage, .updateShortMessage, .updatesTooLong, .updateShortSentMessage: + break + } + } +} + + +final class UnauthorizedAccountStateManager { + private let queue = Queue() + private let network: Network + private var updateService: UnauthorizedUpdateMessageService? + private let updateServiceDisposable = MetaDisposable() + private let updateLoginToken: () -> Void + + init(network: Network, updateLoginToken: @escaping () -> Void) { + self.network = network + self.updateLoginToken = updateLoginToken + } + + deinit { + self.updateServiceDisposable.dispose() + } + + func reset() { + self.queue.async { + if self.updateService == nil { + self.updateService = UnauthorizedUpdateMessageService() + let updateLoginToken = self.updateLoginToken + self.updateServiceDisposable.set(self.updateService!.pipe.signal().start(next: { updates in + for update in updates { + switch update { + case .updateLoginToken: + updateLoginToken() + default: + break + } + } + })) + self.network.mtProto.add(self.updateService) + } + } + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Settings/TransferAuthLaptop.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Settings/TransferAuthLaptop.imageset/Contents.json new file mode 100644 index 0000000000..c55acc952e --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Settings/TransferAuthLaptop.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "EmojiComputer.pdf" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/submodules/TelegramUI/Images.xcassets/Settings/TransferAuthLaptop.imageset/EmojiComputer.pdf b/submodules/TelegramUI/Images.xcassets/Settings/TransferAuthLaptop.imageset/EmojiComputer.pdf new file mode 100644 index 0000000000000000000000000000000000000000..1bf7b79ae073c613792885866ddee46e680624f7 GIT binary patch literal 22801 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 literal 0 HcmV?d00001 diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift index 0aec588b88..54bd615a18 100644 --- a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift @@ -217,6 +217,7 @@ final class AuthorizationSequencePhoneEntryControllerNode: ASDisplayNode { private var qrNode: ASImageNode? private let exportTokenDisposable = MetaDisposable() + private let tokenEventsDisposable = MetaDisposable() var accountUpdated: ((UnauthorizedAccount) -> Void)? private let debugAction: () -> Void @@ -297,10 +298,16 @@ final class AuthorizationSequencePhoneEntryControllerNode: ASDisplayNode { self.phoneAndCountryNode.checkPhone = { [weak self] in self?.checkPhone?() } + + self.tokenEventsDisposable.set((account.updateLoginTokenEvents + |> deliverOnMainQueue).start(next: { [weak self] _ in + self?.refreshQrToken() + })) } deinit { self.exportTokenDisposable.dispose() + self.tokenEventsDisposable.dispose() } override func didLoad() { @@ -425,6 +432,10 @@ final class AuthorizationSequencePhoneEntryControllerNode: ASDisplayNode { strongSelf.exportTokenDisposable.set(nil) strongSelf.account = account strongSelf.accountUpdated?(account) + strongSelf.tokenEventsDisposable.set((account.updateLoginTokenEvents + |> deliverOnMainQueue).start(next: { _ in + self?.refreshQrToken() + })) strongSelf.refreshQrToken() case .loggedIn: strongSelf.exportTokenDisposable.set(nil) From b65d5d27117365361400ad75c953ccb31385058c Mon Sep 17 00:00:00 2001 From: Ali <> Date: Fri, 22 Nov 2019 03:32:36 +0400 Subject: [PATCH 22/25] Fix build --- submodules/AuthTransferUI/BUCK | 2 ++ 1 file changed, 2 insertions(+) diff --git a/submodules/AuthTransferUI/BUCK b/submodules/AuthTransferUI/BUCK index c496f26116..5fd0f710bd 100644 --- a/submodules/AuthTransferUI/BUCK +++ b/submodules/AuthTransferUI/BUCK @@ -19,6 +19,8 @@ static_library( "//submodules/AlertUI:AlertUI", "//submodules/AppBundle:AppBundle", "//submodules/SolidRoundedButtonNode:SolidRoundedButtonNode", + "//submodules/OverlayStatusController:OverlayStatusController", + "//submodules/AnimatedStickerNode:AnimatedStickerNode", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", From f7fab3f1afd26f0efbec227a218a2058e9e776b8 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Fri, 22 Nov 2019 19:04:51 +0400 Subject: [PATCH 23/25] Improve dynamic type --- .../Sources/Node/ChatListItem.swift | 33 ++++++++++++----- .../Sources/Node/ChatListStatusNode.swift | 27 ++++++++++++-- .../Sources/Node/ChatListTypingNode.swift | 10 +++--- .../Items/ItemListSingleLineInputItem.swift | 9 ++++- .../TextSizeSelectionController.swift | 7 ++-- .../TelegramUI/ChatHistoryListNode.swift | 10 +++--- .../ChatHistorySearchContainerNode.swift | 36 ++++++++++--------- .../TelegramUI/ListMessageFileItemNode.swift | 15 ++++---- .../TelegramUI/ListMessageItem.swift | 5 ++- .../ListMessageSnippetItemNode.swift | 9 ++--- 10 files changed, 110 insertions(+), 51 deletions(-) diff --git a/submodules/ChatListUI/Sources/Node/ChatListItem.swift b/submodules/ChatListUI/Sources/Node/ChatListItem.swift index 66c24098d5..f06e3fb0b5 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListItem.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListItem.swift @@ -313,6 +313,8 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { let avatarNode: AvatarNode let titleNode: TextNode let authorNode: TextNode + let measureNode: TextNode + private var currentItemHeight: CGFloat? let textNode: TextNode let contentImageNode: TransformImageNode let inputActivitiesNode: ChatListInputActivitiesNode @@ -431,6 +433,8 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { self.contextContainer = ContextControllerSourceNode() + self.measureNode = TextNode() + self.titleNode = TextNode() self.titleNode.isUserInteractionEnabled = false self.titleNode.displaysAsynchronously = true @@ -633,6 +637,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { let textLayout = TextNode.asyncLayout(self.textNode) let titleLayout = TextNode.asyncLayout(self.titleNode) let authorLayout = TextNode.asyncLayout(self.authorNode) + let makeMeasureLayout = TextNode.asyncLayout(self.measureNode) let inputActivitiesLayout = self.inputActivitiesNode.asyncLayout() let badgeLayout = self.badgeNode.asyncLayout() let mentionBadgeLayout = self.mentionBadgeNode.asyncLayout() @@ -1105,21 +1110,21 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { } badgeSize = max(badgeSize, reorderInset) - let (authorLayout, authorApply) = authorLayout(TextNodeLayoutArguments(attributedString: hideAuthor ? nil : authorAttributedString, backgroundColor: nil, minimumNumberOfLines: 1, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: rawContentWidth - badgeSize, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets(top: 2.0, left: 1.0, bottom: 2.0, right: 1.0))) + let (authorLayout, authorApply) = authorLayout(TextNodeLayoutArguments(attributedString: hideAuthor ? nil : authorAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: rawContentWidth - badgeSize, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets(top: 2.0, left: 1.0, bottom: 2.0, right: 1.0))) var textCutout: TextNodeCutout? if !textLeftCutout.isZero { textCutout = TextNodeCutout(topLeft: CGSize(width: textLeftCutout, height: 4.0), topRight: nil, bottomRight: nil) } - let (textLayout, textApply) = textLayout(TextNodeLayoutArguments(attributedString: textAttributedString, backgroundColor: nil, minimumNumberOfLines: authorAttributedString == nil ? 2 : 1, maximumNumberOfLines: authorAttributedString == nil ? 2 : 1, truncationType: .end, constrainedSize: CGSize(width: rawContentWidth - badgeSize, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: textCutout, insets: UIEdgeInsets(top: 2.0, left: 1.0, bottom: 2.0, right: 1.0))) + let (textLayout, textApply) = textLayout(TextNodeLayoutArguments(attributedString: textAttributedString, backgroundColor: nil, maximumNumberOfLines: authorAttributedString == nil ? 2 : 1, truncationType: .end, constrainedSize: CGSize(width: rawContentWidth - badgeSize, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: textCutout, insets: UIEdgeInsets(top: 2.0, left: 1.0, bottom: 2.0, right: 1.0))) let titleRectWidth = rawContentWidth - dateLayout.size.width - 10.0 - statusWidth - titleIconsWidth - let (titleLayout, titleApply) = titleLayout(TextNodeLayoutArguments(attributedString: titleAttributedString, backgroundColor: nil, minimumNumberOfLines: 1, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: titleRectWidth, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let (titleLayout, titleApply) = titleLayout(TextNodeLayoutArguments(attributedString: titleAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: titleRectWidth, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) var inputActivitiesSize: CGSize? var inputActivitiesApply: (() -> Void)? if let inputActivities = inputActivities, !inputActivities.isEmpty { - let (size, apply) = inputActivitiesLayout(CGSize(width: rawContentWidth - badgeSize, height: 40.0), item.presentationData.strings, item.presentationData.theme.chatList.messageTextColor, item.index.messageIndex.id.peerId, inputActivities) + let (size, apply) = inputActivitiesLayout(CGSize(width: rawContentWidth - badgeSize, height: 40.0), item.presentationData, item.presentationData.theme.chatList.messageTextColor, item.index.messageIndex.id.peerId, inputActivities) inputActivitiesSize = size inputActivitiesApply = apply } @@ -1177,15 +1182,22 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { animateContent = true } + let measureString = NSAttributedString(string: "A", font: titleFont, textColor: .black) + let (measureLayout, measureApply) = makeMeasureLayout(TextNodeLayoutArguments(attributedString: titleAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: titleRectWidth, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let titleSpacing: CGFloat = -1.0 let authorSpacing: CGFloat = -3.0 - var itemHeight: CGFloat = 8.0 * 2.0 + titleLayout.size.height + titleSpacing - if authorLayout.size.height.isZero { + var itemHeight: CGFloat = 8.0 * 2.0 + 1.0 + itemHeight += measureLayout.size.height * 3.0 + itemHeight += titleSpacing + itemHeight += authorSpacing + + /*if authorLayout.size.height.isZero { itemHeight += textLayout.size.height } else { itemHeight += authorLayout.size.height itemHeight += authorSpacing + textLayout.size.height - } + }*/ let rawContentRect = CGRect(origin: CGPoint(x: 2.0, y: layoutOffset + 8.0), size: CGSize(width: rawContentWidth, height: itemHeight - 12.0 - 9.0)) @@ -1209,6 +1221,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { return (layout, { [weak self] synchronousLoads, animated in if let strongSelf = self { strongSelf.layoutParams = (item, first, last, firstWithHeader, nextIsPinned, params, countersSize) + strongSelf.currentItemHeight = itemHeight strongSelf.contentImageMedia = contentImageMedia strongSelf.cachedChatListText = chatListText strongSelf.cachedChatListSearchResult = chatListSearchResult @@ -1339,7 +1352,8 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { onlineIcon = PresentationResourcesChatList.recentStatusOnlineIcon(item.presentationData.theme, state: .regular) } strongSelf.onlineNode.setImage(onlineIcon) - + + let _ = measureApply() let _ = dateApply() let _ = textApply() let _ = authorApply() @@ -1354,6 +1368,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { let statusSize = CGSize(width: 24.0, height: 24.0) strongSelf.statusNode.frame = CGRect(origin: CGPoint(x: contentRect.origin.x + contentRect.size.width - dateLayout.size.width - statusSize.width, y: contentRect.origin.y + 2.0 - UIScreenPixel + floor((dateLayout.size.height - statusSize.height) / 2.0)), size: statusSize) + strongSelf.statusNode.fontSize = item.presentationData.fontSize.itemListBaseFontSize let _ = strongSelf.statusNode.transitionToState(statusState, animated: animateContent) if let _ = currentBadgeBackgroundImage { @@ -1817,7 +1832,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { if let item = self.item { if case .groupReference = item.content { - self.layer.sublayerTransform = CATransform3DMakeTranslation(0.0, currentValue - self.bounds.size.height, 0.0) + self.layer.sublayerTransform = CATransform3DMakeTranslation(0.0, currentValue - (self.currentItemHeight ?? 0.0), 0.0) } else { var separatorFrame = self.separatorNode.frame separatorFrame.origin.y = currentValue - UIScreenPixel diff --git a/submodules/ChatListUI/Sources/Node/ChatListStatusNode.swift b/submodules/ChatListUI/Sources/Node/ChatListStatusNode.swift index fdd9b7d121..a4f6cb2a2a 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListStatusNode.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListStatusNode.swift @@ -34,6 +34,8 @@ enum ChatListStatusNodeState: Equatable { private let transitionDuration = 0.2 class ChatListStatusContentNode: ASDisplayNode { + var fontSize: CGFloat = 17.0 + override init() { super.init() @@ -57,6 +59,13 @@ class ChatListStatusContentNode: ASDisplayNode { final class ChatListStatusNode: ASDisplayNode { private(set) var state: ChatListStatusNodeState = .none + var fontSize: CGFloat = 17.0 { + didSet { + self.contentNode?.fontSize = self.fontSize + self.nextContentNode?.fontSize = self.fontSize + } + } + private var contentNode: ChatListStatusContentNode? private var nextContentNode: ChatListStatusContentNode? @@ -66,6 +75,7 @@ final class ChatListStatusNode: ASDisplayNode { self.state = state let contentNode = state.contentNode() + contentNode?.fontSize = self.fontSize if contentNode?.classForCoder != self.contentNode?.classForCoder { contentNode?.updateWithState(state, animated: animated) self.transitionToContentNode(contentNode, state: state, fromState: currentState, animated: animated, completion: completion) @@ -190,10 +200,12 @@ private func maybeAddRotationAnimation(_ layer: CALayer, duration: Double) { private final class StatusChecksNodeParameters: NSObject { let color: UIColor let progress: CGFloat + let fontSize: CGFloat - init(color: UIColor, progress: CGFloat) { + init(color: UIColor, progress: CGFloat, fontSize: CGFloat) { self.color = color self.progress = progress + self.fontSize = fontSize super.init() } @@ -214,6 +226,12 @@ private class ChatListStatusChecksNode: ChatListStatusContentNode { } } + override var fontSize: CGFloat { + didSet { + self.setNeedsDisplay() + } + } + init(color: UIColor) { self.color = color @@ -241,7 +259,7 @@ private class ChatListStatusChecksNode: ChatListStatusContentNode { } override func drawParameters(forAsyncLayer layer: _ASDisplayLayer) -> NSObjectProtocol? { - return StatusChecksNodeParameters(color: self.color, progress: self.effectiveProgress) + return StatusChecksNodeParameters(color: self.color, progress: self.effectiveProgress, fontSize: self.fontSize) } override func didEnterHierarchy() { @@ -261,6 +279,11 @@ private class ChatListStatusChecksNode: ChatListStatusContentNode { return } + let scaleFactor = min(1.4, parameters.fontSize / 17.0) + context.translateBy(x: bounds.width / 2.0, y: bounds.height / 2.0) + context.scaleBy(x: scaleFactor, y: scaleFactor) + context.translateBy(x: -bounds.width / 2.0, y: -bounds.height / 2.0) + let progress = parameters.progress context.setStrokeColor(parameters.color.cgColor) diff --git a/submodules/ChatListUI/Sources/Node/ChatListTypingNode.swift b/submodules/ChatListUI/Sources/Node/ChatListTypingNode.swift index dbcb66e59c..e67e3f05c9 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListTypingNode.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListTypingNode.swift @@ -10,8 +10,6 @@ import TelegramPresentationData import ChatTitleActivityNode import LocalizedPeerData -private let textFont = Font.regular(15.0) - final class ChatListInputActivitiesNode: ASDisplayNode { private let activityNode: ChatTitleActivityNode @@ -23,8 +21,12 @@ final class ChatListInputActivitiesNode: ASDisplayNode { self.addSubnode(self.activityNode) } - func asyncLayout() -> (CGSize, PresentationStrings, UIColor, PeerId, [(Peer, PeerInputActivity)]) -> (CGSize, () -> Void) { - return { [weak self] boundingSize, strings, color, peerId, activities in + func asyncLayout() -> (CGSize, ChatListPresentationData, UIColor, PeerId, [(Peer, PeerInputActivity)]) -> (CGSize, () -> Void) { + return { [weak self] boundingSize, presentationData, color, peerId, activities in + let strings = presentationData.strings + + let textFont = Font.regular(floor(presentationData.fontSize.itemListBaseFontSize * 15.0 / 17.0)) + var state = ChatTitleActivityNodeState.none if !activities.isEmpty { diff --git a/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift b/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift index d1728dc26a..5b8028f7a9 100644 --- a/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift +++ b/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift @@ -108,6 +108,7 @@ public class ItemListSingleLineInputItemNode: ListViewItemNode, UITextFieldDeleg private let maskNode: ASImageNode private let titleNode: TextNode + private let measureTitleSizeNode: TextNode private let textNode: TextFieldNode private let clearIconNode: ASImageNode private let clearButtonNode: HighlightableButtonNode @@ -131,6 +132,7 @@ public class ItemListSingleLineInputItemNode: ListViewItemNode, UITextFieldDeleg self.maskNode = ASImageNode() self.titleNode = TextNode() + self.measureTitleSizeNode = TextNode() self.textNode = TextFieldNode() self.clearIconNode = ASImageNode() @@ -185,6 +187,7 @@ public class ItemListSingleLineInputItemNode: ListViewItemNode, UITextFieldDeleg public func asyncLayout() -> (_ item: ItemListSingleLineInputItem, _ params: ListViewItemLayoutParams, _ neighbors: ItemListNeighbors) -> (ListViewItemNodeLayout, () -> Void) { let makeTitleLayout = TextNode.asyncLayout(self.titleNode) + let makeMeasureTitleSizeLayout = TextNode.asyncLayout(self.measureTitleSizeNode) let currentItem = self.item @@ -215,9 +218,11 @@ public class ItemListSingleLineInputItemNode: ListViewItemNode, UITextFieldDeleg let (titleLayout, titleApply) = makeTitleLayout(TextNodeLayoutArguments(attributedString: titleString, backgroundColor: nil, maximumNumberOfLines: 0, truncationType: .end, constrainedSize: CGSize(width: params.width - 32.0 - leftInset - rightInset, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let (measureTitleLayout, measureTitleSizeApply) = makeMeasureTitleSizeLayout(TextNodeLayoutArguments(attributedString: NSAttributedString(string: "A", font: Font.regular(item.presentationData.fontSize.itemListBaseFontSize)), backgroundColor: nil, maximumNumberOfLines: 0, truncationType: .end, constrainedSize: CGSize(width: params.width - 32.0 - leftInset - rightInset, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let separatorHeight = UIScreenPixel - let contentSize = CGSize(width: params.width, height: titleLayout.size.height + 22.0) + let contentSize = CGSize(width: params.width, height: max(titleLayout.size.height, measureTitleLayout.size.height) + 22.0) let insets = itemListNeighborsGroupedInsets(neighbors) let layout = ListViewItemNodeLayout(contentSize: contentSize, insets: insets) @@ -246,6 +251,8 @@ public class ItemListSingleLineInputItemNode: ListViewItemNode, UITextFieldDeleg let _ = titleApply() strongSelf.titleNode.frame = CGRect(origin: CGPoint(x: leftInset, y: floor((layout.contentSize.height - titleLayout.size.height) / 2.0)), size: titleLayout.size) + let _ = measureTitleSizeApply() + let secureEntry: Bool let capitalizationType: UITextAutocapitalizationType let autocorrectionType: UITextAutocorrectionType diff --git a/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift b/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift index 28ede8025f..f589a7fa94 100644 --- a/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift +++ b/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift @@ -113,7 +113,6 @@ private final class TextSizeSelectionControllerNode: ASDisplayNode, UIScrollView if case let .file(file) = presentationData.theme.chat.defaultWallpaper, file.id == 0 { self.remoteChatBackgroundNode.isHidden = false - self.toolbarNode.setDoneEnabled(false) } else { self.remoteChatBackgroundNode.isHidden = true } @@ -212,7 +211,8 @@ private final class TextSizeSelectionControllerNode: ASDisplayNode, UIScrollView guard let strongSelf = self else { return } - if case let .file(file) = wallpaper { + switch wallpaper { + case let .file(file): let dimensions = file.file.dimensions ?? PixelDimensions(width: 100, height: 100) let displaySize = dimensions.cgSize.dividedByScreenScale().integralFloor @@ -267,6 +267,8 @@ private final class TextSizeSelectionControllerNode: ASDisplayNode, UIScrollView } strongSelf.remoteChatBackgroundNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: displaySize, boundingSize: displaySize, intrinsicInsets: UIEdgeInsets(), emptyColor: patternColor))() + default: + break } } applyWallpaper(self.presentationData.chatWallpaper) @@ -519,6 +521,7 @@ private final class TextSizeSelectionControllerNode: ASDisplayNode, UIScrollView self.toolbarNode.updatePresentationThemeSettings(presentationThemeSettings: self.presentationThemeSettings) if let (layout, navigationBarHeight) = self.validLayout { self.containerLayoutUpdated(layout, navigationBarHeight: navigationBarHeight, transition: .immediate) + self.recursivelyEnsureDisplaySynchronously(true) } } diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift index f034e0b8ef..26b472281d 100644 --- a/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift @@ -188,7 +188,7 @@ private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLoca case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .message(message: message, read: read, selection: selection, attributes: attributes)) case let .list(search, _): - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: search) + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: search) } return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .MessageGroupEntry(_, messages, presentationData): @@ -198,7 +198,7 @@ private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLoca item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .group(messages: messages)) case let .list(search, _): assertionFailure() - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: search) + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: search) } return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .UnreadEntry(_, presentationData): @@ -222,7 +222,7 @@ private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLoca case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .message(message: message, read: read, selection: selection, attributes: attributes)) case let .list(search, _): - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: search) + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: search) } return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .MessageGroupEntry(_, messages, presentationData): @@ -232,7 +232,7 @@ private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLoca item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .group(messages: messages)) case let .list(search, _): assertionFailure() - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: search) + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: search) } return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .UnreadEntry(_, presentationData): @@ -1547,7 +1547,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: self.context, chatLocation: self.chatLocation, associatedData: associatedData, controllerInteraction: self.controllerInteraction, content: .message(message: message, read: read, selection: selection, attributes: attributes)) case let .list(search, _): - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, context: self.context, chatLocation: self.chatLocation, controllerInteraction: self.controllerInteraction, message: message, selection: selection, displayHeader: search) + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: self.context, chatLocation: self.chatLocation, controllerInteraction: self.controllerInteraction, message: message, selection: selection, displayHeader: search) } let updateItem = ListViewUpdateItem(index: index, previousIndex: index, item: item, directionHint: nil) self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [updateItem], options: [.AnimateInsertion], scrollToItem: nil, additionalScrollDistance: 0.0, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) diff --git a/submodules/TelegramUI/TelegramUI/ChatHistorySearchContainerNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistorySearchContainerNode.swift index 974e57853c..3edfa84d36 100644 --- a/submodules/TelegramUI/TelegramUI/ChatHistorySearchContainerNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatHistorySearchContainerNode.swift @@ -10,6 +10,7 @@ import TelegramPresentationData import MergeLists import AccountContext import SearchUI +import TelegramUIPreferences private enum ChatHistorySearchEntryStableId: Hashable { case messageId(MessageId) @@ -35,19 +36,19 @@ private enum ChatHistorySearchEntryStableId: Hashable { private enum ChatHistorySearchEntry: Comparable, Identifiable { - case message(Message, PresentationTheme, PresentationStrings, PresentationDateTimeFormat) + case message(Message, PresentationTheme, PresentationStrings, PresentationDateTimeFormat, PresentationFontSize) var stableId: ChatHistorySearchEntryStableId { switch self { - case let .message(message, _, _, _): + case let .message(message, _, _, _, _): return .messageId(message.id) } } static func ==(lhs: ChatHistorySearchEntry, rhs: ChatHistorySearchEntry) -> Bool { switch lhs { - case let .message(lhsMessage, lhsTheme, lhsStrings, lhsDateTimeFormat): - if case let .message(rhsMessage, rhsTheme, rhsStrings, rhsDateTimeFormat) = rhs { + case let .message(lhsMessage, lhsTheme, lhsStrings, lhsDateTimeFormat, lhsFontSize): + if case let .message(rhsMessage, rhsTheme, rhsStrings, rhsDateTimeFormat, rhsFontSize) = rhs { if lhsMessage.id != rhsMessage.id { return false } @@ -63,6 +64,9 @@ private enum ChatHistorySearchEntry: Comparable, Identifiable { if lhsDateTimeFormat != rhsDateTimeFormat { return false } + if lhsFontSize != rhsFontSize { + return false + } return true } else { return false @@ -72,8 +76,8 @@ private enum ChatHistorySearchEntry: Comparable, Identifiable { static func <(lhs: ChatHistorySearchEntry, rhs: ChatHistorySearchEntry) -> Bool { switch lhs { - case let .message(lhsMessage, _, _, _): - if case let .message(rhsMessage, _, _, _) = rhs { + case let .message(lhsMessage, _, _, _, _): + if case let .message(rhsMessage, _, _, _, _) = rhs { return lhsMessage.index < rhsMessage.index } else { return false @@ -83,8 +87,8 @@ private enum ChatHistorySearchEntry: Comparable, Identifiable { func item(context: AccountContext, peerId: PeerId, interaction: ChatControllerInteraction) -> ListViewItem { switch self { - case let .message(message, theme, strings, dateTimeFormat): - return ListMessageItem(theme: theme, strings: strings, dateTimeFormat: dateTimeFormat, context: context, chatLocation: .peer(peerId), controllerInteraction: interaction, message: message, selection: .none, displayHeader: true) + case let .message(message, theme, strings, dateTimeFormat, fontSize): + return ListMessageItem(theme: theme, strings: strings, fontSize: fontSize, dateTimeFormat: dateTimeFormat, context: context, chatLocation: .peer(peerId), controllerInteraction: interaction, message: message, selection: .none, displayHeader: true) } } } @@ -134,7 +138,7 @@ final class ChatHistorySearchContainerNode: SearchDisplayControllerContentNode { private var presentationData: PresentationData private var presentationDataDisposable: Disposable? - private let themeAndStringsPromise: Promise<(PresentationTheme, PresentationStrings, PresentationDateTimeFormat)> + private let themeAndStringsPromise: Promise<(PresentationTheme, PresentationStrings, PresentationDateTimeFormat, PresentationFontSize)> private var enqueuedTransitions: [(ChatHistorySearchContainerTransition, Bool)] = [] @@ -143,7 +147,7 @@ final class ChatHistorySearchContainerNode: SearchDisplayControllerContentNode { self.presentationData = context.sharedContext.currentPresentationData.with { $0 } - self.themeAndStringsPromise = Promise((self.presentationData.theme, self.presentationData.strings, self.presentationData.dateTimeFormat)) + self.themeAndStringsPromise = Promise((self.presentationData.theme, self.presentationData.strings, self.presentationData.dateTimeFormat, self.presentationData.fontSize)) self.dimNode = ASDisplayNode() self.dimNode.backgroundColor = UIColor.black.withAlphaComponent(0.5) @@ -191,7 +195,7 @@ final class ChatHistorySearchContainerNode: SearchDisplayControllerContentNode { return ([], [:]) } else { return (messages.map { message -> ChatHistorySearchEntry in - return .message(message, themeAndStrings.0, themeAndStrings.1, themeAndStrings.2) + return .message(message, themeAndStrings.0, themeAndStrings.1, themeAndStrings.2, themeAndStrings.3) }, Dictionary(messages.map { ($0.id, $0) }, uniquingKeysWith: { lhs, _ in lhs })) } } @@ -224,7 +228,7 @@ final class ChatHistorySearchContainerNode: SearchDisplayControllerContentNode { self.presentationDataDisposable = context.sharedContext.presentationData.start(next: { [weak self] presentationData in if let strongSelf = self { - strongSelf.themeAndStringsPromise.set(.single((presentationData.theme, presentationData.strings, presentationData.dateTimeFormat))) + strongSelf.themeAndStringsPromise.set(.single((presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, presentationData.fontSize))) strongSelf.emptyResultsTitleNode.attributedText = NSAttributedString(string: presentationData.strings.SharedMedia_SearchNoResults, font: Font.semibold(17.0), textColor: presentationData.theme.list.freeTextColor, paragraphAlignment: .center) @@ -342,10 +346,10 @@ final class ChatHistorySearchContainerNode: SearchDisplayControllerContentNode { if let currentEntries = self.currentEntries { for entry in currentEntries { switch entry { - case let .message(message, _, _, _): - if message.id == id { - return message - } + case let .message(message, _, _, _, _): + if message.id == id { + return message + } } } } diff --git a/submodules/TelegramUI/TelegramUI/ListMessageFileItemNode.swift b/submodules/TelegramUI/TelegramUI/ListMessageFileItemNode.swift index 5f8d3516d2..030f40ed65 100644 --- a/submodules/TelegramUI/TelegramUI/ListMessageFileItemNode.swift +++ b/submodules/TelegramUI/TelegramUI/ListMessageFileItemNode.swift @@ -114,10 +114,6 @@ private func extensionImage(fileExtension: String?) -> UIImage? { return nil } } - -private let titleFont = Font.medium(16.0) -private let audioTitleFont = Font.regular(16.0) -private let descriptionFont = Font.regular(13.0) private let extensionFont = Font.medium(13.0) private struct FetchControls { @@ -316,6 +312,10 @@ final class ListMessageFileItemNode: ListMessageNode { updatedTheme = item.theme } + let titleFont = Font.medium(floor(item.fontSize.baseDisplaySize * 16.0 / 17.0)) + let audioTitleFont = Font.regular(floor(item.fontSize.baseDisplaySize * 16.0 / 17.0)) + let descriptionFont = Font.regular(floor(item.fontSize.baseDisplaySize * 13.0 / 17.0)) + var leftInset: CGFloat = 65.0 + params.leftInset let rightInset: CGFloat = 8.0 + params.rightInset @@ -494,7 +494,7 @@ final class ListMessageFileItemNode: ListMessageNode { insets.top += header.height } - let nodeLayout = ListViewItemNodeLayout(contentSize: CGSize(width: params.width, height: 56.0), insets: insets) + let nodeLayout = ListViewItemNodeLayout(contentSize: CGSize(width: params.width, height: 8.0 * 2.0 + titleNodeLayout.size.height + 3.0 + descriptionNodeLayout.size.height), insets: insets) return (nodeLayout, { animation in if let strongSelf = self { @@ -562,7 +562,7 @@ final class ListMessageFileItemNode: ListMessageNode { } } - transition.updateFrame(node: strongSelf.descriptionNode, frame: CGRect(origin: CGPoint(x: leftOffset + leftInset + descriptionOffset, y: 32.0), size: descriptionNodeLayout.size)) + transition.updateFrame(node: strongSelf.descriptionNode, frame: CGRect(origin: CGPoint(x: leftOffset + leftInset + descriptionOffset, y: strongSelf.titleNode.frame.maxY + 3.0), size: descriptionNodeLayout.size)) let _ = descriptionNodeApply() let iconFrame: CGRect @@ -630,7 +630,7 @@ final class ListMessageFileItemNode: ListMessageNode { })) } - transition.updateFrame(node: strongSelf.downloadStatusIconNode, frame: CGRect(origin: CGPoint(x: leftOffset + leftInset, y: 34.0), size: CGSize(width: 11.0, height: 11.0))) + transition.updateFrame(node: strongSelf.downloadStatusIconNode, frame: CGRect(origin: CGPoint(x: leftOffset + leftInset, y: strongSelf.descriptionNode.frame.minY + floor((strongSelf.descriptionNode.frame.height - 11.0) / 2.0)), size: CGSize(width: 11.0, height: 11.0))) if let updatedFetchControls = updatedFetchControls { let _ = strongSelf.fetchControls.swap(updatedFetchControls) @@ -840,6 +840,7 @@ final class ListMessageFileItemNode: ListMessageNode { self.descriptionProgressNode.isHidden = true self.descriptionNode.isHidden = false } + let descriptionFont = Font.regular(floor(item.fontSize.baseDisplaySize * 13.0 / 17.0)) self.descriptionProgressNode.attributedText = NSAttributedString(string: downloadingString ?? "", font: descriptionFont, textColor: item.theme.list.itemSecondaryTextColor) let descriptionSize = self.descriptionProgressNode.updateLayout(CGSize(width: size.width - 14.0, height: size.height)) transition.updateFrame(node: self.descriptionProgressNode, frame: CGRect(origin: self.descriptionNode.frame.origin, size: descriptionSize)) diff --git a/submodules/TelegramUI/TelegramUI/ListMessageItem.swift b/submodules/TelegramUI/TelegramUI/ListMessageItem.swift index fdeebefad1..ee7fc455c1 100644 --- a/submodules/TelegramUI/TelegramUI/ListMessageItem.swift +++ b/submodules/TelegramUI/TelegramUI/ListMessageItem.swift @@ -8,10 +8,12 @@ import SwiftSignalKit import Postbox import TelegramPresentationData import AccountContext +import TelegramUIPreferences final class ListMessageItem: ListViewItem { let theme: PresentationTheme let strings: PresentationStrings + let fontSize: PresentationFontSize let dateTimeFormat: PresentationDateTimeFormat let context: AccountContext let chatLocation: ChatLocation @@ -23,9 +25,10 @@ final class ListMessageItem: ListViewItem { let selectable: Bool = true - public init(theme: PresentationTheme, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, context: AccountContext, chatLocation: ChatLocation, controllerInteraction: ChatControllerInteraction, message: Message, selection: ChatHistoryMessageSelection, displayHeader: Bool) { + public init(theme: PresentationTheme, strings: PresentationStrings, fontSize: PresentationFontSize, dateTimeFormat: PresentationDateTimeFormat, context: AccountContext, chatLocation: ChatLocation, controllerInteraction: ChatControllerInteraction, message: Message, selection: ChatHistoryMessageSelection, displayHeader: Bool) { self.theme = theme self.strings = strings + self.fontSize = fontSize self.dateTimeFormat = dateTimeFormat self.context = context self.chatLocation = chatLocation diff --git a/submodules/TelegramUI/TelegramUI/ListMessageSnippetItemNode.swift b/submodules/TelegramUI/TelegramUI/ListMessageSnippetItemNode.swift index e3df40f7e7..bd72494ca3 100644 --- a/submodules/TelegramUI/TelegramUI/ListMessageSnippetItemNode.swift +++ b/submodules/TelegramUI/TelegramUI/ListMessageSnippetItemNode.swift @@ -14,8 +14,6 @@ import PhotoResources import WebsiteType import UrlHandling -private let titleFont = Font.medium(16.0) -private let descriptionFont = Font.regular(14.0) private let iconFont = Font.medium(22.0) private let iconTextBackgroundImage = generateStretchableFilledCircleImage(radius: 2.0, color: UIColor(rgb: 0xdfdfdf)) @@ -157,6 +155,9 @@ final class ListMessageSnippetItemNode: ListMessageNode { updatedTheme = item.theme } + let titleFont = Font.medium(floor(item.fontSize.baseDisplaySize * 16.0 / 17.0)) + let descriptionFont = Font.regular(floor(item.fontSize.baseDisplaySize * 14.0 / 17.0)) + let leftInset: CGFloat = 65.0 + params.leftInset var leftOffset: CGFloat = 0.0 @@ -327,7 +328,7 @@ final class ListMessageSnippetItemNode: ListMessageNode { } } - let contentHeight = 40.0 + descriptionNodeLayout.size.height + linkNodeLayout.size.height + let contentHeight = 9.0 + titleNodeLayout.size.height + 10.0 + descriptionNodeLayout.size.height + linkNodeLayout.size.height var insets = UIEdgeInsets() if dateHeaderAtBottom, let header = item.header { @@ -379,7 +380,7 @@ final class ListMessageSnippetItemNode: ListMessageNode { transition.updateFrame(node: strongSelf.titleNode, frame: CGRect(origin: CGPoint(x: leftOffset + leftInset, y: 9.0), size: titleNodeLayout.size)) let _ = titleNodeApply() - let descriptionFrame = CGRect(origin: CGPoint(x: leftOffset + leftInset - 1.0, y: 32.0), size: descriptionNodeLayout.size) + let descriptionFrame = CGRect(origin: CGPoint(x: leftOffset + leftInset - 1.0, y: strongSelf.titleNode.frame.maxY + 3.0), size: descriptionNodeLayout.size) transition.updateFrame(node: strongSelf.descriptionNode, frame: descriptionFrame) let _ = descriptionNodeApply() From 965d2628aa0ebc8d6b3431e67f7d5b2b7d1414d9 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Fri, 22 Nov 2019 19:05:24 +0400 Subject: [PATCH 24/25] Present reaction UI in a different way --- .../Sources/ReactionSelectionNode.swift | 100 +++++++++--------- .../ReactionSwipeGestureRecognizer.swift | 9 +- .../ChatMessageBubbleItemNode.swift | 9 ++ 3 files changed, 67 insertions(+), 51 deletions(-) diff --git a/submodules/ReactionSelectionNode/Sources/ReactionSelectionNode.swift b/submodules/ReactionSelectionNode/Sources/ReactionSelectionNode.swift index eb64faf4c6..9b8debf415 100644 --- a/submodules/ReactionSelectionNode/Sources/ReactionSelectionNode.swift +++ b/submodules/ReactionSelectionNode/Sources/ReactionSelectionNode.swift @@ -77,7 +77,7 @@ final class ReactionNode: ASDisplayNode { self.animationNode.automaticallyLoadFirstFrame = loadFirstFrame self.animationNode.playToCompletionOnStop = true - var intrinsicSize = CGSize(width: maximizedReactionSize + 18.0, height: maximizedReactionSize + 18.0) + var intrinsicSize = CGSize(width: maximizedReactionSize + 14.0, height: maximizedReactionSize + 14.0) self.imageNode = ASImageNode() switch reaction { @@ -195,9 +195,8 @@ final class ReactionSelectionNode: ASDisplayNode { private let hapticFeedback = HapticFeedback() private var shadowBlur: CGFloat = 8.0 - private var minimizedReactionSize: CGFloat = 30.0 - private var maximizedReactionSize: CGFloat = 60.0 - private var smallCircleSize: CGFloat = 8.0 + private var minimizedReactionSize: CGFloat = 28.0 + private var smallCircleSize: CGFloat = 14.0 private var isRightAligned: Bool = false @@ -246,44 +245,17 @@ final class ReactionSelectionNode: ASDisplayNode { isRightAligned = true } - if isInitial && self.reactionNodes.isEmpty { - let availableContentWidth = constrainedSize.width //max(100.0, initialAnchorX) - var minimizedReactionSize = (availableContentWidth - self.maximizedReactionSize) / (CGFloat(self.reactions.count - 1) + CGFloat(self.reactions.count + 1) * 0.2) - minimizedReactionSize = max(16.0, floor(minimizedReactionSize)) - minimizedReactionSize = min(30.0, minimizedReactionSize) - - self.minimizedReactionSize = minimizedReactionSize - self.shadowBlur = floor(minimizedReactionSize * 0.26) - self.smallCircleSize = 8.0 - - let backgroundHeight = floor(minimizedReactionSize * 1.4) - - self.backgroundNode.image = generateBubbleImage(foreground: .white, diameter: backgroundHeight, shadowBlur: self.shadowBlur) - self.backgroundShadowNode.image = generateBubbleShadowImage(shadow: UIColor(white: 0.0, alpha: 0.2), diameter: backgroundHeight, shadowBlur: self.shadowBlur) - for i in 0 ..< self.bubbleNodes.count { - self.bubbleNodes[i].0.image = generateBubbleImage(foreground: .white, diameter: CGFloat(i + 1) * self.smallCircleSize, shadowBlur: self.shadowBlur) - self.bubbleNodes[i].1.image = generateBubbleShadowImage(shadow: UIColor(white: 0.0, alpha: 0.2), diameter: CGFloat(i + 1) * self.smallCircleSize, shadowBlur: self.shadowBlur) - } - - self.reactionNodes = self.reactions.map { reaction -> ReactionNode in - return ReactionNode(account: self.account, theme: self.theme, reaction: reaction, maximizedReactionSize: self.maximizedReactionSize, loadFirstFrame: true) - } - self.reactionNodes.forEach(self.addSubnode(_:)) - } - - let backgroundHeight: CGFloat = floor(self.minimizedReactionSize * 1.4) - - let reactionSpacing: CGFloat = floor(self.minimizedReactionSize * 0.2) - let minimizedReactionVerticalInset: CGFloat = floor((backgroundHeight - minimizedReactionSize) / 2.0) - - let contentWidth: CGFloat = CGFloat(self.reactionNodes.count - 1) * (minimizedReactionSize) + maximizedReactionSize + CGFloat(self.reactionNodes.count + 1) * reactionSpacing + let reactionSideInset: CGFloat = 10.0 + var reactionSpacing: CGFloat = 6.0 + let minReactionSpacing: CGFloat = 2.0 + let minimizedReactionSize = self.minimizedReactionSize + let contentWidth: CGFloat = CGFloat(self.reactions.count) * (minimizedReactionSize) + CGFloat(self.reactions.count - 1) * reactionSpacing + reactionSideInset * 2.0 + let spaceForMaximizedReaction = CGFloat(self.reactions.count - 1) * reactionSpacing - CGFloat(self.reactions.count - 1) * minReactionSpacing + let maximizedReactionSize: CGFloat = minimizedReactionSize + spaceForMaximizedReaction + let backgroundHeight: CGFloat = floor(self.minimizedReactionSize * 1.8) var backgroundFrame = CGRect(origin: CGPoint(x: -shadowBlur, y: -shadowBlur), size: CGSize(width: contentWidth + shadowBlur * 2.0, height: backgroundHeight + shadowBlur * 2.0)) - if isRightAligned { - backgroundFrame = backgroundFrame.offsetBy(dx: initialAnchorX - contentWidth + backgroundHeight / 2.0, dy: startingPoint.y - backgroundHeight - 16.0) - } else { - backgroundFrame = backgroundFrame.offsetBy(dx: initialAnchorX - backgroundHeight / 2.0, dy: startingPoint.y - backgroundHeight - 16.0) - } + backgroundFrame = backgroundFrame.offsetBy(dx: floor((constrainedSize.width - contentWidth) / 2.0), dy: startingPoint.y - backgroundHeight - 12.0) backgroundFrame.origin.x = max(0.0, backgroundFrame.minX) backgroundFrame.origin.x = min(constrainedSize.width - backgroundFrame.width, backgroundFrame.minX) @@ -295,14 +267,44 @@ final class ReactionSelectionNode: ASDisplayNode { if let reaction = self.reactions.last, case .reply = reaction { maximizedIndex = self.reactions.count - 1 } - if backgroundFrame.insetBy(dx: -10.0, dy: -10.0).contains(touchPoint) { + if backgroundFrame.insetBy(dx: -10.0, dy: -10.0).offsetBy(dx: 0.0, dy: 10.0).contains(touchPoint) { maximizedIndex = Int(((touchPoint.x - anchorMinX) / (anchorMaxX - anchorMinX)) * CGFloat(self.reactionNodes.count)) maximizedIndex = max(0, min(self.reactionNodes.count - 1, maximizedIndex)) } - if maximizedIndex == -1 { + + let interReactionSpacing: CGFloat + if maximizedIndex != -1 { + interReactionSpacing = minReactionSpacing + } else { + interReactionSpacing = reactionSpacing + } + + if isInitial && self.reactionNodes.isEmpty { + let availableContentWidth = constrainedSize.width //max(100.0, initialAnchorX) + + self.shadowBlur = floor(minimizedReactionSize * 0.26) + self.smallCircleSize = 14.0 + + self.backgroundNode.image = generateBubbleImage(foreground: .white, diameter: backgroundHeight, shadowBlur: self.shadowBlur) + self.backgroundShadowNode.image = generateBubbleShadowImage(shadow: UIColor(white: 0.0, alpha: 0.2), diameter: backgroundHeight, shadowBlur: self.shadowBlur) + for i in 0 ..< self.bubbleNodes.count { + self.bubbleNodes[i].0.image = generateBubbleImage(foreground: .white, diameter: CGFloat(i + 1) * self.smallCircleSize, shadowBlur: self.shadowBlur) + self.bubbleNodes[i].1.image = generateBubbleShadowImage(shadow: UIColor(white: 0.0, alpha: 0.2), diameter: CGFloat(i + 1) * self.smallCircleSize, shadowBlur: self.shadowBlur) + } + + self.reactionNodes = self.reactions.map { reaction -> ReactionNode in + return ReactionNode(account: self.account, theme: self.theme, reaction: reaction, maximizedReactionSize: maximizedReactionSize - 12.0, loadFirstFrame: true) + } + self.reactionNodes.forEach(self.addSubnode(_:)) + } + + let minimizedReactionVerticalInset: CGFloat = floor((backgroundHeight - minimizedReactionSize) / 2.0) + + + /*if maximizedIndex == -1 { backgroundFrame.size.width -= maximizedReactionSize - minimizedReactionSize backgroundFrame.origin.x += maximizedReactionSize - minimizedReactionSize - } + }*/ self.isRightAligned = isRightAligned @@ -315,8 +317,8 @@ final class ReactionSelectionNode: ASDisplayNode { backgroundTransition.updateFrame(node: self.backgroundNode, frame: backgroundFrame) backgroundTransition.updateFrame(node: self.backgroundShadowNode, frame: backgroundFrame) - var reactionX: CGFloat = backgroundFrame.minX + shadowBlur + reactionSpacing - if offsetFromStart > backgroundFrame.maxX - shadowBlur || offsetFromStart < backgroundFrame.minX { + var reactionX: CGFloat = backgroundFrame.minX + shadowBlur + reactionSideInset + if maximizedIndex != -1 { self.hasSelectedNode = false } else { self.hasSelectedNode = true @@ -353,14 +355,14 @@ final class ReactionSelectionNode: ASDisplayNode { var reactionFrame = CGRect(origin: CGPoint(x: reactionX, y: backgroundFrame.maxY - shadowBlur - minimizedReactionVerticalInset - reactionSize), size: CGSize(width: reactionSize, height: reactionSize)) if isMaximized { - reactionFrame.origin.x -= 9.0 - reactionFrame.size.width += 18.0 + reactionFrame.origin.x -= 7.0 + reactionFrame.size.width += 14.0 } - self.reactionNodes[i].updateLayout(size: reactionFrame.size, scale: reactionFrame.size.width / (maximizedReactionSize + 18.0), transition: transition, displayText: isMaximized) + self.reactionNodes[i].updateLayout(size: reactionFrame.size, scale: reactionFrame.size.width / (maximizedReactionSize + 14.0), transition: transition, displayText: isMaximized) transition.updateFrame(node: self.reactionNodes[i], frame: reactionFrame, beginWithCurrentState: true) - reactionX += reactionSize + reactionSpacing + reactionX += reactionSize + interReactionSpacing } let mainBubbleFrame = CGRect(origin: CGPoint(x: anchorX - self.smallCircleSize - shadowBlur, y: backgroundFrame.maxY - shadowBlur - self.smallCircleSize - shadowBlur), size: CGSize(width: self.smallCircleSize * 2.0 + shadowBlur * 2.0, height: self.smallCircleSize * 2.0 + shadowBlur * 2.0)) diff --git a/submodules/ReactionSelectionNode/Sources/ReactionSwipeGestureRecognizer.swift b/submodules/ReactionSelectionNode/Sources/ReactionSwipeGestureRecognizer.swift index f82c3df64f..f03217d367 100644 --- a/submodules/ReactionSelectionNode/Sources/ReactionSwipeGestureRecognizer.swift +++ b/submodules/ReactionSelectionNode/Sources/ReactionSwipeGestureRecognizer.swift @@ -16,6 +16,7 @@ public final class ReactionSwipeGestureRecognizer: UIPanGestureRecognizer { public var availableReactions: (() -> [ReactionGestureItem])? public var getReactionContainer: (() -> ReactionSelectionParentNode?)? public var getAnchorPoint: (() -> CGPoint?)? + public var shouldElevateAnchorPoint: (() -> Bool)? public var began: (() -> Void)? public var updateOffset: ((CGFloat, Bool) -> Void)? public var completed: ((ReactionGestureItem?) -> Void)? @@ -99,7 +100,9 @@ public final class ReactionSwipeGestureRecognizer: UIPanGestureRecognizer { self.f() } } - let activationTimer = Timer(timeInterval: 0.1, target: TimerTarget { [weak self] in + let elevate = self.shouldElevateAnchorPoint?() ?? false + + let activationTimer = Timer(timeInterval: elevate ? 0.1 : 0.01, target: TimerTarget { [weak self] in guard let strongSelf = self else { return } @@ -108,7 +111,9 @@ public final class ReactionSwipeGestureRecognizer: UIPanGestureRecognizer { let location = strongSelf.currentLocation if !strongSelf.currentReactions.isEmpty, let reactionContainer = strongSelf.getReactionContainer?(), let localAnchorPoint = strongSelf.getAnchorPoint?() { strongSelf.currentContainer = reactionContainer - let reactionContainerLocation = reactionContainer.view.convert(localAnchorPoint, from: strongSelf.view) + //let reactionContainerLocation = reactionContainer.view.convert(localAnchorPoint, from: strongSelf.view) + let elevate = strongSelf.shouldElevateAnchorPoint?() ?? false + let reactionContainerLocation = reactionContainer.view.convert(location, from: nil).offsetBy(dx: 0.0, dy: elevate ? -44.0 : 22.0) let reactionContainerTouchPoint = reactionContainer.view.convert(location, from: nil) strongSelf.currentAnchorPoint = reactionContainerLocation strongSelf.currentAnchorStartPoint = location diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift index 982e67c939..ee779d5229 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift @@ -449,6 +449,12 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePrevewItemNode } return CGPoint(x: strongSelf.backgroundNode.frame.maxX, y: strongSelf.backgroundNode.frame.minY) } + reactionRecognizer.shouldElevateAnchorPoint = { [weak self] in + guard let strongSelf = self, let item = strongSelf.item else { + return false + } + return item.controllerInteraction.canSetupReply(item.message) + } reactionRecognizer.began = { [weak self] in guard let strongSelf = self, let item = strongSelf.item else { return @@ -493,6 +499,9 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePrevewItemNode guard let strongSelf = self, let item = strongSelf.item else { return } + if !item.controllerInteraction.canSetupReply(item.message) { + return + } if strongSelf.swipeToReplyFeedback == nil { strongSelf.swipeToReplyFeedback = HapticFeedback() } From 4c2b1758457e5e41982060e7999e0592b2ca1178 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Fri, 22 Nov 2019 19:05:38 +0400 Subject: [PATCH 25/25] More QR auth improvements --- Telegram-iOS/en.lproj/Localizable.strings | 5 + .../Sources/AuthTransferScanScreen.swift | 22 +- .../PrivacyAndSecurityController.swift | 4 +- .../RecentSessionsController.swift | 34 +- .../Sources/SettingsController.swift | 49 +- .../Sources/PresentationStrings.swift | 6358 +++++++++-------- .../Resources/PresentationStrings.mapping | Bin 140430 -> 140559 bytes .../WalletUI/Resources/WalletStrings.mapping | Bin 8384 -> 8384 bytes .../WalletUI/Sources/WalletStrings.swift | 4 +- 9 files changed, 3279 insertions(+), 3197 deletions(-) diff --git a/Telegram-iOS/en.lproj/Localizable.strings b/Telegram-iOS/en.lproj/Localizable.strings index fcf1023a97..f455d8cc02 100644 --- a/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram-iOS/en.lproj/Localizable.strings @@ -5136,3 +5136,8 @@ Any member of this group will be able to see messages in the channel."; "Appearance.TextSize.Title" = "Text Size"; "Appearance.TextSize.UseSystem" = "User System Text Size"; "Appearance.TextSize.Apply" = "Set"; + +"Settings.Devices" = "Devices"; +"Settings.AddDevice" = "Add"; +"AuthSessions.DevicesTitle" = "Devices"; +"AuthSessions.AddDevice" = "Add Device"; diff --git a/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift b/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift index 7ac48824ca..9a800ce23b 100644 --- a/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift +++ b/submodules/AuthTransferUI/Sources/AuthTransferScanScreen.swift @@ -72,14 +72,16 @@ private func generateFrameImage() -> UIImage? { public final class AuthTransferScanScreen: ViewController { private let context: AccountContext + private let activeSessionsContext: ActiveSessionsContext? private var presentationData: PresentationData private var codeDisposable: Disposable? private var inForegroundDisposable: Disposable? private let approveDisposable = MetaDisposable() - public init(context: AccountContext) { + public init(context: AccountContext, activeSessionsContext: ActiveSessionsContext?) { self.context = context + self.activeSessionsContext = activeSessionsContext self.presentationData = context.sharedContext.currentPresentationData.with { $0 } @@ -155,6 +157,10 @@ public final class AuthTransferScanScreen: ViewController { guard let strongSelf = self else { return } + let activeSessionsContext = strongSelf.activeSessionsContext + Queue.mainQueue().after(1.5, { + activeSessionsContext?.loadMore() + }) strongSelf.dismiss() })) }, cancel: { @@ -189,6 +195,7 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr private let torchButtonNode: GlassButtonNode private let titleNode: ImmediateTextNode private let textNode: ImmediateTextNode + private let descriptionNode: ImmediateTextNode private let camera: Camera private let codeDisposable = MetaDisposable() @@ -247,6 +254,12 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr self.textNode.maximumNumberOfLines = 0 self.textNode.textAlignment = .center + self.descriptionNode = ImmediateTextNode() + self.descriptionNode.displaysAsynchronously = false + self.descriptionNode.attributedText = NSAttributedString(string: "Telegram is available for\niPhone, iPad, macOS, Windows and Linux", font: Font.regular(14.0), textColor: .white) + self.descriptionNode.maximumNumberOfLines = 0 + self.descriptionNode.textAlignment = .center + self.camera = Camera(configuration: .init(preset: .hd1920x1080, position: .back, audio: false)) super.init() @@ -261,9 +274,10 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr self.addSubnode(self.rightDimNode) self.addSubnode(self.centerDimNode) self.addSubnode(self.frameNode) - self.addSubnode(self.torchButtonNode) + //self.addSubnode(self.torchButtonNode) self.addSubnode(self.titleNode) self.addSubnode(self.textNode) + self.addSubnode(self.descriptionNode) self.torchButtonNode.addTarget(self, action: #selector(self.torchPressed), forControlEvents: .touchUpInside) } @@ -408,14 +422,18 @@ private final class AuthTransferScanScreenNode: ViewControllerTracingNode, UIScr transition.updateAlpha(node: self.titleNode, alpha: controlsAlpha) transition.updateAlpha(node: self.textNode, alpha: controlsAlpha) + transition.updateAlpha(node: self.descriptionNode, alpha: controlsAlpha) transition.updateAlpha(node: self.torchButtonNode, alpha: controlsAlpha) let titleSize = self.titleNode.updateLayout(CGSize(width: layout.size.width - sideInset * 2.0, height: layout.size.height)) let textSize = self.textNode.updateLayout(CGSize(width: layout.size.width - sideInset * 2.0, height: layout.size.height)) + let descriptionSize = self.descriptionNode.updateLayout(CGSize(width: layout.size.width - sideInset * 2.0, height: layout.size.height)) let textFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - textSize.width) / 2.0), y: dimHeight - textSize.height - titleSpacing), size: textSize) let titleFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - titleSize.width) / 2.0), y: textFrame.minY - 18.0 - titleSize.height), size: titleSize) + let descriptionFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - descriptionSize.width) / 2.0), y: layout.size.height - dimHeight + titleSpacing), size: descriptionSize) transition.updateFrameAdditive(node: self.titleNode, frame: titleFrame) transition.updateFrameAdditive(node: self.textNode, frame: textFrame) + transition.updateFrameAdditive(node: self.descriptionNode, frame: descriptionFrame) if let confirmationNode = self.confirmationNode { confirmationNode.updateLayout(layout: layout, transition: transition) diff --git a/submodules/SettingsUI/Sources/Privacy and Security/PrivacyAndSecurityController.swift b/submodules/SettingsUI/Sources/Privacy and Security/PrivacyAndSecurityController.swift index dd8e67b148..2b2279a5d1 100644 --- a/submodules/SettingsUI/Sources/Privacy and Security/PrivacyAndSecurityController.swift +++ b/submodules/SettingsUI/Sources/Privacy and Security/PrivacyAndSecurityController.swift @@ -427,7 +427,7 @@ private func privacyAndSecurityControllerEntries(presentationData: PresentationD return entries } -public func privacyAndSecurityController(context: AccountContext, initialSettings: AccountPrivacySettings? = nil, updatedSettings: ((AccountPrivacySettings?) -> Void)? = nil, focusOnItemTag: PrivacyAndSecurityEntryTag? = nil) -> ViewController { +public func privacyAndSecurityController(context: AccountContext, initialSettings: AccountPrivacySettings? = nil, updatedSettings: ((AccountPrivacySettings?) -> Void)? = nil, focusOnItemTag: PrivacyAndSecurityEntryTag? = nil, activeSessionsContext: ActiveSessionsContext? = nil) -> ViewController { let statePromise = ValuePromise(PrivacyAndSecurityControllerState(), ignoreRepeated: true) let stateValue = Atomic(value: PrivacyAndSecurityControllerState()) let updateState: ((PrivacyAndSecurityControllerState) -> PrivacyAndSecurityControllerState) -> Void = { f in @@ -450,7 +450,7 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting privacySettingsPromise.set(.single(initialSettings) |> then(requestAccountPrivacySettings(account: context.account) |> map(Optional.init))) let blockedPeersContext = BlockedPeersContext(account: context.account) - let activeSessionsContext = ActiveSessionsContext(account: context.account) + let activeSessionsContext = activeSessionsContext ?? ActiveSessionsContext(account: context.account) let updateTwoStepAuthDisposable = MetaDisposable() actionsDisposable.add(updateTwoStepAuthDisposable) diff --git a/submodules/SettingsUI/Sources/Privacy and Security/Recent Sessions/RecentSessionsController.swift b/submodules/SettingsUI/Sources/Privacy and Security/Recent Sessions/RecentSessionsController.swift index ae4b11d53c..1afaf5085f 100644 --- a/submodules/SettingsUI/Sources/Privacy and Security/Recent Sessions/RecentSessionsController.swift +++ b/submodules/SettingsUI/Sources/Privacy and Security/Recent Sessions/RecentSessionsController.swift @@ -10,6 +10,7 @@ import TelegramUIPreferences import ItemListUI import PresentationDataUtils import AccountContext +import AuthTransferUI private final class RecentSessionsControllerArguments { let account: Account @@ -21,7 +22,9 @@ private final class RecentSessionsControllerArguments { let removeWebSession: (Int64) -> Void let terminateAllWebSessions: () -> Void - init(account: Account, setSessionIdWithRevealedOptions: @escaping (Int64?, Int64?) -> Void, removeSession: @escaping (Int64) -> Void, terminateOtherSessions: @escaping () -> Void, removeWebSession: @escaping (Int64) -> Void, terminateAllWebSessions: @escaping () -> Void) { + let addDevice: () -> Void + + init(account: Account, setSessionIdWithRevealedOptions: @escaping (Int64?, Int64?) -> Void, removeSession: @escaping (Int64) -> Void, terminateOtherSessions: @escaping () -> Void, removeWebSession: @escaping (Int64) -> Void, terminateAllWebSessions: @escaping () -> Void, addDevice: @escaping () -> Void) { self.account = account self.setSessionIdWithRevealedOptions = setSessionIdWithRevealedOptions self.removeSession = removeSession @@ -29,6 +32,8 @@ private final class RecentSessionsControllerArguments { self.removeWebSession = removeWebSession self.terminateAllWebSessions = terminateAllWebSessions + + self.addDevice = addDevice } } @@ -84,6 +89,7 @@ private enum RecentSessionsEntry: ItemListNodeEntry { case pendingSession(index: Int32, theme: PresentationTheme, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, session: RecentAccountSession, enabled: Bool, editing: Bool, revealed: Bool) case pendingSessionsInfo(PresentationTheme, String) case otherSessionsHeader(PresentationTheme, String) + case addDevice(PresentationTheme, String) case session(index: Int32, theme: PresentationTheme, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, session: RecentAccountSession, enabled: Bool, editing: Bool, revealed: Bool) case website(index: Int32, theme: PresentationTheme, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, website: WebAuthorization, peer: Peer?, enabled: Bool, editing: Bool, revealed: Bool) @@ -93,7 +99,7 @@ private enum RecentSessionsEntry: ItemListNodeEntry { return RecentSessionsSection.currentSession.rawValue case .pendingSessionsHeader, .pendingSession, .pendingSessionsInfo: return RecentSessionsSection.pendingSessions.rawValue - case .otherSessionsHeader, .session, .website: + case .otherSessionsHeader, .addDevice, .session, .website: return RecentSessionsSection.otherSessions.rawValue } } @@ -118,6 +124,8 @@ private enum RecentSessionsEntry: ItemListNodeEntry { return .index(6) case .otherSessionsHeader: return .index(7) + case .addDevice: + return .index(8) case let .session(_, _, _, _, session, _, _, _): return .session(session.hash) case let .website(_, _, _, _, _, website, _, _, _, _): @@ -175,6 +183,12 @@ private enum RecentSessionsEntry: ItemListNodeEntry { } else { return false } + case let .addDevice(lhsTheme, lhsText): + if case let .addDevice(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { + return true + } else { + return false + } case let .currentSession(lhsTheme, lhsStrings, lhsDateTimeFormat, lhsSession): if case let .currentSession(rhsTheme, rhsStrings, rhsDateTimeFormat, rhsSession) = rhs, lhsTheme === rhsTheme, lhsStrings === rhsStrings, lhsDateTimeFormat == rhsDateTimeFormat, lhsSession == rhsSession { return true @@ -271,6 +285,10 @@ private enum RecentSessionsEntry: ItemListNodeEntry { return ItemListTextItem(presentationData: presentationData, text: .plain(text), sectionId: self.section) case let .otherSessionsHeader(theme, text): return ItemListSectionHeaderItem(presentationData: presentationData, text: text, sectionId: self.section) + case let .addDevice(theme, text): + return ItemListActionItem(presentationData: presentationData, title: text, kind: .generic, alignment: .natural, sectionId: self.section, style: .blocks, action: { + arguments.addDevice() + }) case let .session(_, theme, strings, dateTimeFormat, session, enabled, editing, revealed): return ItemListRecentSessionItem(presentationData: presentationData, dateTimeFormat: dateTimeFormat, session: session, enabled: enabled, editable: true, editing: editing, revealed: revealed, sectionId: self.section, setSessionIdWithRevealedOptions: { previousId, id in arguments.setSessionIdWithRevealedOptions(previousId, id) @@ -370,6 +388,8 @@ private func recentSessionsControllerEntries(presentationData: PresentationData, entries.append(.otherSessionsHeader(presentationData.theme, presentationData.strings.AuthSessions_OtherSessions)) + entries.append(.addDevice(presentationData.theme, presentationData.strings.AuthSessions_AddDevice)) + let filteredSessions: [RecentAccountSession] = sessionsState.sessions.sorted(by: { lhs, rhs in return lhs.activityDate > rhs.activityDate }) @@ -421,7 +441,10 @@ public func recentSessionsController(context: AccountContext, activeSessionsCont statePromise.set(stateValue.modify { f($0) }) } + activeSessionsContext.loadMore() + var presentControllerImpl: ((ViewController, ViewControllerPresentationArguments?) -> Void)? + var pushControllerImpl: ((ViewController) -> Void)? let actionsDisposable = DisposableSet() @@ -575,6 +598,8 @@ public func recentSessionsController(context: AccountContext, activeSessionsCont ActionSheetItemGroup(items: [ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, action: { dismissAction() })]) ]) presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + }, addDevice: { + pushControllerImpl?(AuthTransferScanScreen(context: context, activeSessionsContext: activeSessionsContext)) }) let websitesSignal: Signal<([WebAuthorization], [PeerId : Peer])?, NoError> = .single(nil) |> then(webSessions(network: context.account.network) |> map(Optional.init)) @@ -619,7 +644,7 @@ public func recentSessionsController(context: AccountContext, activeSessionsCont if let websites = websites, !websites.isEmpty { title = .sectionControl([presentationData.strings.AuthSessions_Sessions, presentationData.strings.AuthSessions_LoggedIn], mode.rawValue) } else { - title = .text(presentationData.strings.AuthSessions_Title) + title = .text(presentationData.strings.AuthSessions_DevicesTitle) } var animateChanges = true @@ -655,6 +680,9 @@ public func recentSessionsController(context: AccountContext, activeSessionsCont controller.present(c, in: .window(.root), with: p) } } + pushControllerImpl = { [weak controller] c in + controller?.push(c) + } return controller } diff --git a/submodules/SettingsUI/Sources/SettingsController.swift b/submodules/SettingsUI/Sources/SettingsController.swift index dcd5241e6d..f6d4109627 100644 --- a/submodules/SettingsUI/Sources/SettingsController.swift +++ b/submodules/SettingsUI/Sources/SettingsController.swift @@ -610,7 +610,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) -> [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) -> [SettingsEntry] { var entries: [SettingsEntry] = [] if let peer = peerViewMainPeer(view) as? TelegramUser { @@ -659,7 +659,7 @@ private func settingsEntries(account: Account, presentationData: PresentationDat entries.append(.savedMessages(presentationData.theme, PresentationResourcesSettings.savedMessages, presentationData.strings.Settings_SavedMessages)) entries.append(.recentCalls(presentationData.theme, PresentationResourcesSettings.recentCalls, presentationData.strings.CallSettings_RecentCalls)) entries.append(.stickers(presentationData.theme, PresentationResourcesSettings.stickers, presentationData.strings.ChatSettings_Stickers, unreadTrendingStickerPacks == 0 ? "" : "\(unreadTrendingStickerPacks)", archivedPacks)) - entries.append(.devices(presentationData.theme, PresentationResourcesSettings.stickers, "Devices", "")) + entries.append(.devices(presentationData.theme, UIImage(bundleImageName: "Settings/MenuIcons/Sessions")?.precomposed(), presentationData.strings.Settings_Devices, otherSessionCount == 0 ? presentationData.strings.Settings_AddDevice : "\(otherSessionCount)")) let notificationsWarning = shouldDisplayNotificationsPermissionWarning(status: notificationsAuthorizationStatus, suppressed: notificationsWarningSuppressed) entries.append(.notificationsAndSounds(presentationData.theme, PresentationResourcesSettings.notifications, presentationData.strings.Settings_NotificationsAndSounds, notifyExceptions, notificationsWarning)) @@ -839,6 +839,23 @@ public func settingsController(context: AccountContext, accountManager: AccountM let displayPhoneNumberConfirmation = ValuePromise(false) + let activeSessionsContextAndCountSignal = contextValue.get() + |> deliverOnMainQueue + |> mapToSignal { context -> Signal<(ActiveSessionsContext, Int), NoError> in + let activeSessionsContext = ActiveSessionsContext(account: context.account) + let otherSessionCount = activeSessionsContext.state + |> map { state -> Int in + return state.sessions.filter({ !$0.isCurrent }).count + } + |> distinctUntilChanged + return otherSessionCount + |> map { value in + return (activeSessionsContext, value) + } + } + let activeSessionsContextAndCount = Promise<(ActiveSessionsContext, Int)>() + activeSessionsContextAndCount.set(activeSessionsContextAndCountSignal) + let arguments = SettingsItemArguments(accountManager: accountManager, avatarAndNameInfoContext: avatarAndNameInfoContext, avatarTapAction: { var updating = false updateState { @@ -896,9 +913,13 @@ public func settingsController(context: AccountContext, accountManager: AccountM let _ = (contextValue.get() |> deliverOnMainQueue |> take(1)).start(next: { context in - pushControllerImpl?(privacyAndSecurityController(context: context, initialSettings: privacySettingsValue, updatedSettings: { settings in - privacySettings.set(.single(settings)) - })) + let _ = (activeSessionsContextAndCount.get() + |> deliverOnMainQueue + |> take(1)).start(next: { activeSessionsContext, _ in + pushControllerImpl?(privacyAndSecurityController(context: context, initialSettings: privacySettingsValue, updatedSettings: { settings in + privacySettings.set(.single(settings)) + }, activeSessionsContext: activeSessionsContext)) + }) }) }, openDataAndStorage: { let _ = (contextValue.get() @@ -1067,10 +1088,14 @@ public func settingsController(context: AccountContext, accountManager: AccountM gesture?.cancel() } }, openDevices: { - let _ = (contextValue.get() + let _ = (activeSessionsContextAndCount.get() |> deliverOnMainQueue - |> take(1)).start(next: { context in - pushControllerImpl?(AuthTransferScanScreen(context: context)) + |> take(1)).start(next: { activeSessionsContext, count in + if count == 0 { + pushControllerImpl?(AuthTransferScanScreen(context: context, activeSessionsContext: activeSessionsContext)) + } else { + pushControllerImpl?(recentSessionsController(context: context, activeSessionsContext: activeSessionsContext)) + } }) }) @@ -1308,8 +1333,10 @@ public func settingsController(context: AccountContext, accountManager: AccountM return context.account.viewTracker.featuredStickerPacks() } - 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), accountsAndPeers.get()) - |> map { context, presentationData, state, view, preferencesAndExceptions, featuredAndArchived, hasWalletPassportAndWatch, accountsAndPeers -> (ItemListControllerState, (ItemListNodeState, Any)) in + 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), accountsAndPeers.get(), activeSessionsContextAndCount.get()) + |> map { context, presentationData, state, view, preferencesAndExceptions, featuredAndArchived, hasWalletPassportAndWatch, accountsAndPeers, activeSessionsContextAndCount -> (ItemListControllerState, (ItemListNodeState, Any)) in + let otherSessionCount = activeSessionsContextAndCount.1 + let proxySettings: ProxySettings = preferencesAndExceptions.0.entries[SharedDataKeys.proxySettings] as? ProxySettings ?? ProxySettings.defaultSettings let inAppNotificationSettings: InAppNotificationSettings = preferencesAndExceptions.0.entries[ApplicationSpecificSharedDataKeys.inAppNotificationSettings] as? InAppNotificationSettings ?? InAppNotificationSettings.defaultSettings let experimentalUISettings: ExperimentalUISettings = preferencesAndExceptions.0.entries[ApplicationSpecificSharedDataKeys.experimentalUISettings] as? ExperimentalUISettings ?? ExperimentalUISettings.defaultSettings @@ -1347,7 +1374,7 @@ public func settingsController(context: AccountContext, accountManager: AccountM }, getNavigationController: getNavigationControllerImpl, exceptionsList: notifyExceptions.get(), archivedStickerPacks: archivedPacks.get(), privacySettings: privacySettings.get(), hasWallet: hasWallet) let (hasWallet, hasPassport, hasWatchApp) = 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), style: .blocks, searchItem: searchItem, initialScrollToItem: ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: false, curve: .Default(duration: 0.0), directionHint: .Up)) + 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), 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/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index e901e134b2..58ae2f510a 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -1188,3654 +1188,3658 @@ public final class PresentationStrings: Equatable { public var ClearCache_StorageOtherApps: String { return self._s[920]! } public var PasscodeSettings_AutoLock_Disabled: String { return self._s[921]! } public var Wallet_Send_NetworkErrorText: String { return self._s[922]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[925]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[926]! } - public var Passport_Language_id: String { return self._s[928]! } - public var WallpaperSearch_ColorTeal: String { return self._s[929]! } - public var ChannelIntro_Title: String { return self._s[930]! } + public var AuthSessions_DevicesTitle: String { return self._s[924]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[926]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[927]! } + public var Passport_Language_id: String { return self._s[929]! } + public var WallpaperSearch_ColorTeal: String { return self._s[930]! } + public var ChannelIntro_Title: String { return self._s[931]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[931]!, self._r[931]!, [_0]) + return formatWithArgumentRanges(self._s[932]!, self._r[932]!, [_0]) } - public var VoiceOver_Chat_OpenLinkHint: String { return self._s[933]! } - public var VoiceOver_Chat_Reply: String { return self._s[934]! } - public var ScheduledMessages_BotActionUnavailable: String { return self._s[935]! } - public var Channel_Info_Description: String { return self._s[936]! } - public var Stickers_FavoriteStickers: String { return self._s[937]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[938]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[939]! } - public var ChatSearch_ResultsTooltip: String { return self._s[940]! } - public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[941]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[942]! } - public var Group_PublicLink_Placeholder: String { return self._s[943]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[944]! } + public var VoiceOver_Chat_OpenLinkHint: String { return self._s[934]! } + public var VoiceOver_Chat_Reply: String { return self._s[935]! } + public var ScheduledMessages_BotActionUnavailable: String { return self._s[936]! } + public var Channel_Info_Description: String { return self._s[937]! } + public var Stickers_FavoriteStickers: String { return self._s[938]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[939]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[940]! } + public var ChatSearch_ResultsTooltip: String { return self._s[941]! } + public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[942]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[943]! } + public var Group_PublicLink_Placeholder: String { return self._s[944]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[945]! } public func PUSH_CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[945]!, self._r[945]!, [_1]) + return formatWithArgumentRanges(self._s[946]!, self._r[946]!, [_1]) } - public var TextFormat_Underline: String { return self._s[946]! } + public var TextFormat_Underline: String { return self._s[947]! } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[947]!, self._r[947]!, [_1, _2]) + return formatWithArgumentRanges(self._s[948]!, self._r[948]!, [_1, _2]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[948]!, self._r[948]!, [_0]) + return formatWithArgumentRanges(self._s[949]!, self._r[949]!, [_0]) } - public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[949]! } + public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[950]! } public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[950]!, self._r[950]!, [_1, _2]) + return formatWithArgumentRanges(self._s[951]!, self._r[951]!, [_1, _2]) } - public var Wallet_Intro_ImportExisting: String { return self._s[951]! } - public var GroupPermission_Delete: String { return self._s[952]! } - public var Passport_Language_uk: String { return self._s[953]! } - public var StickerPack_HideStickers: String { return self._s[955]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[956]! } + public var Wallet_Intro_ImportExisting: String { return self._s[952]! } + public var GroupPermission_Delete: String { return self._s[953]! } + public var Passport_Language_uk: String { return self._s[954]! } + public var StickerPack_HideStickers: String { return self._s[956]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[957]! } public func PUSH_CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[957]!, self._r[957]!, [_1, _2]) + return formatWithArgumentRanges(self._s[958]!, self._r[958]!, [_1, _2]) } - public var Activity_UploadingVideoMessage: String { return self._s[958]! } + public var Activity_UploadingVideoMessage: String { return self._s[959]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[959]!, self._r[959]!, [_0]) + return formatWithArgumentRanges(self._s[960]!, self._r[960]!, [_0]) } - public var Channel_TitleInfo: String { return self._s[960]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[961]! } - public var Settings_CallSettings: String { return self._s[962]! } - public var Camera_SquareMode: String { return self._s[963]! } - public var Conversation_SendMessage_ScheduleMessage: String { return self._s[964]! } - public var GroupInfo_SharedMediaNone: String { return self._s[965]! } + public var Channel_TitleInfo: String { return self._s[961]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[962]! } + public var Settings_CallSettings: String { return self._s[963]! } + public var Camera_SquareMode: String { return self._s[964]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[965]! } + public var GroupInfo_SharedMediaNone: String { return self._s[966]! } public func PUSH_MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[966]!, self._r[966]!, [_1]) + return formatWithArgumentRanges(self._s[967]!, self._r[967]!, [_1]) } - public var Bot_GenericBotStatus: String { return self._s[967]! } - public var Application_Update: String { return self._s[969]! } - public var Month_ShortJanuary: String { return self._s[970]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[971]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[972]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[973]! } - public var Passport_Address_Street2Placeholder: String { return self._s[974]! } + public var Bot_GenericBotStatus: String { return self._s[968]! } + public var Application_Update: String { return self._s[970]! } + public var Month_ShortJanuary: String { return self._s[971]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[972]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[973]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[974]! } + public var Passport_Address_Street2Placeholder: String { return self._s[975]! } public func Map_LiveLocationShortHour(_ _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 NetworkUsageSettings_Cellular: String { return self._s[976]! } - public var Appearance_PreviewOutgoingText: String { return self._s[977]! } - public var Notifications_PermissionsAllowInSettings: String { return self._s[978]! } - public var AutoDownloadSettings_OnForAll: String { return self._s[980]! } - public var Map_Directions: String { return self._s[981]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[983]! } - public var Appearance_ThemeDay: String { return self._s[984]! } - public var LogoutOptions_LogOut: String { return self._s[985]! } - public var Group_PublicLink_Title: String { return self._s[987]! } - public var Channel_AddBotErrorNoRights: String { return self._s[988]! } - public var Passport_Identity_AddPassport: String { return self._s[989]! } - public var LocalGroup_ButtonTitle: String { return self._s[990]! } - public var Call_Message: String { return self._s[991]! } - public var PhotoEditor_ExposureTool: String { return self._s[992]! } - public var Wallet_Receive_CommentInfo: String { return self._s[994]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[995]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[997]! } - public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[998]! } - public var Appearance_Preview: String { return self._s[999]! } - public var Compose_ChannelMembers: String { return self._s[1000]! } - public var Conversation_DeleteManyMessages: String { return self._s[1001]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[1002]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1003]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1004]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[1007]! } - public var Conversation_UpdateTelegram: String { return self._s[1008]! } - public var EditTheme_Create_TopInfo: String { return self._s[1009]! } + public var NetworkUsageSettings_Cellular: String { return self._s[977]! } + public var Appearance_PreviewOutgoingText: String { return self._s[978]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[979]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[981]! } + public var Map_Directions: String { return self._s[982]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[984]! } + public var Appearance_ThemeDay: String { return self._s[985]! } + public var LogoutOptions_LogOut: String { return self._s[986]! } + public var Group_PublicLink_Title: String { return self._s[988]! } + public var Channel_AddBotErrorNoRights: String { return self._s[989]! } + public var Passport_Identity_AddPassport: String { return self._s[990]! } + public var LocalGroup_ButtonTitle: String { return self._s[991]! } + public var Call_Message: String { return self._s[992]! } + public var PhotoEditor_ExposureTool: String { return self._s[993]! } + public var Wallet_Receive_CommentInfo: String { return self._s[995]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[996]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[998]! } + public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[999]! } + public var Appearance_Preview: String { return self._s[1000]! } + public var Compose_ChannelMembers: String { return self._s[1001]! } + public var Conversation_DeleteManyMessages: String { return self._s[1002]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[1003]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1004]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1005]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[1008]! } + public var Conversation_UpdateTelegram: String { return self._s[1009]! } + public var EditTheme_Create_TopInfo: String { return self._s[1010]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1010]!, self._r[1010]!, [_0]) + return formatWithArgumentRanges(self._s[1011]!, self._r[1011]!, [_0]) } - public var Wallet_WordCheck_Continue: String { return self._s[1011]! } - public var TwoFactorSetup_Hint_Action: String { return self._s[1012]! } - public var IntentsSettings_ResetAll: String { return self._s[1013]! } + public var Wallet_WordCheck_Continue: String { return self._s[1012]! } + public var TwoFactorSetup_Hint_Action: String { return self._s[1013]! } + public var IntentsSettings_ResetAll: String { return self._s[1014]! } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1014]!, self._r[1014]!, [_1]) + return formatWithArgumentRanges(self._s[1015]!, self._r[1015]!, [_1]) } - public var GroupInfo_Administrators_Title: String { return self._s[1015]! } - public var Privacy_Forwards_PreviewMessageText: String { return self._s[1016]! } + public var GroupInfo_Administrators_Title: String { return self._s[1016]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[1017]! } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1017]!, self._r[1017]!, [_0]) + return formatWithArgumentRanges(self._s[1018]!, self._r[1018]!, [_0]) } - public var Tour_Title3: String { return self._s[1018]! } - public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1019]! } - public var Clipboard_SendPhoto: String { return self._s[1023]! } - public var MediaPicker_Videos: String { return self._s[1024]! } - public var Passport_Email_Title: String { return self._s[1025]! } + public var Tour_Title3: String { return self._s[1019]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1020]! } + public var Clipboard_SendPhoto: String { return self._s[1024]! } + public var MediaPicker_Videos: String { return self._s[1025]! } + public var Passport_Email_Title: String { return self._s[1026]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1026]!, self._r[1026]!, [_0]) + return formatWithArgumentRanges(self._s[1027]!, self._r[1027]!, [_0]) } - public var StickerPacksSettings_Title: String { return self._s[1027]! } - public var Conversation_MessageDialogDelete: String { return self._s[1028]! } - public var Privacy_Calls_CustomHelp: String { return self._s[1030]! } - public var Message_Wallpaper: String { return self._s[1031]! } - public var MemberSearch_BotSection: String { return self._s[1032]! } - public var GroupInfo_SetSound: String { return self._s[1033]! } - public var Core_ServiceUserStatus: String { return self._s[1034]! } - public var LiveLocationUpdated_JustNow: String { return self._s[1035]! } - public var Call_StatusFailed: String { return self._s[1036]! } - public var TwoFactorSetup_Email_Placeholder: String { return self._s[1037]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1038]! } - public var TwoStepAuth_SetPassword: String { return self._s[1039]! } - public var Permissions_PeopleNearbyText_v0: String { return self._s[1040]! } + public var StickerPacksSettings_Title: String { return self._s[1028]! } + public var Conversation_MessageDialogDelete: String { return self._s[1029]! } + public var Privacy_Calls_CustomHelp: String { return self._s[1031]! } + public var Message_Wallpaper: String { return self._s[1032]! } + public var MemberSearch_BotSection: String { return self._s[1033]! } + public var GroupInfo_SetSound: String { return self._s[1034]! } + public var Core_ServiceUserStatus: String { return self._s[1035]! } + public var LiveLocationUpdated_JustNow: String { return self._s[1036]! } + public var Call_StatusFailed: String { return self._s[1037]! } + public var TwoFactorSetup_Email_Placeholder: String { return self._s[1038]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1039]! } + public var TwoStepAuth_SetPassword: String { return self._s[1040]! } + public var Permissions_PeopleNearbyText_v0: String { return self._s[1041]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1042]!, self._r[1042]!, [_0]) + return formatWithArgumentRanges(self._s[1043]!, self._r[1043]!, [_0]) } - public var Calls_SubmitRating: String { return self._s[1043]! } - public var Profile_Username: String { return self._s[1044]! } - public var Bot_DescriptionTitle: String { return self._s[1045]! } - public var MaskStickerSettings_Title: String { return self._s[1046]! } - public var SharedMedia_CategoryOther: String { return self._s[1047]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[1048]! } - public var Common_NotNow: String { return self._s[1049]! } - public var CallFeedback_IncludeLogsInfo: String { return self._s[1050]! } - public var Conversation_ShareMyPhoneNumber: String { return self._s[1051]! } - public var Map_Location: String { return self._s[1052]! } - public var Invitation_JoinGroup: String { return self._s[1053]! } - public var AutoDownloadSettings_Title: String { return self._s[1055]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1056]! } - public var Channel_ErrorAddBlocked: String { return self._s[1057]! } - public var Conversation_UnblockUser: String { return self._s[1058]! } - public var EditTheme_Edit_TopInfo: String { return self._s[1059]! } - public var Watch_Bot_Restart: String { return self._s[1060]! } - public var TwoStepAuth_Title: String { return self._s[1061]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[1062]! } - public var Checkout_ShippingMethod: String { return self._s[1063]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1064]! } + public var Calls_SubmitRating: String { return self._s[1044]! } + public var Profile_Username: String { return self._s[1045]! } + public var Bot_DescriptionTitle: String { return self._s[1046]! } + public var MaskStickerSettings_Title: String { return self._s[1047]! } + public var SharedMedia_CategoryOther: String { return self._s[1048]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[1049]! } + public var Common_NotNow: String { return self._s[1050]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[1051]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[1052]! } + public var Map_Location: String { return self._s[1053]! } + public var Invitation_JoinGroup: String { return self._s[1054]! } + public var AutoDownloadSettings_Title: String { return self._s[1056]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1057]! } + public var Channel_ErrorAddBlocked: String { return self._s[1058]! } + public var Conversation_UnblockUser: String { return self._s[1059]! } + public var EditTheme_Edit_TopInfo: String { return self._s[1060]! } + public var Watch_Bot_Restart: String { return self._s[1061]! } + public var TwoStepAuth_Title: String { return self._s[1062]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[1063]! } + public var Checkout_ShippingMethod: String { return self._s[1064]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1065]! } public func PUSH_CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1065]!, self._r[1065]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1066]!, self._r[1066]!, [_1, _2, _3]) } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1067]!, self._r[1067]!, [_0]) - } - public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1068]!, self._r[1068]!, [_0]) } - public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1069]! } - public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1070]! } - public var AuthSessions_TerminateOtherSessions: String { return self._s[1071]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[1072]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[1073]! } - public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1074]! } - public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1075]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[1076]! } - public var Checkout_PaymentMethod_Title: String { return self._s[1077]! } - public var SocksProxySetup_Connection: String { return self._s[1078]! } - public var Group_MessagePhotoRemoved: String { return self._s[1079]! } - public var Channel_Stickers_NotFound: String { return self._s[1082]! } - public var Group_About_Help: String { return self._s[1083]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[1084]! } - public var PeopleNearby_Title: String { return self._s[1086]! } - public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1087]!, self._r[1087]!, [_1]) + public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1069]!, self._r[1069]!, [_0]) } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1089]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1090]! } - public var SocksProxySetup_Password: String { return self._s[1091]! } - public var Notifications_PermissionsEnable: String { return self._s[1092]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[1094]! } + public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1070]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1071]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[1072]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[1073]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[1074]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1075]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1076]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[1077]! } + public var Checkout_PaymentMethod_Title: String { return self._s[1078]! } + public var SocksProxySetup_Connection: String { return self._s[1079]! } + public var Group_MessagePhotoRemoved: String { return self._s[1080]! } + public var Channel_Stickers_NotFound: String { return self._s[1083]! } + public var Group_About_Help: String { return self._s[1084]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[1085]! } + public var PeopleNearby_Title: String { return self._s[1087]! } + public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1088]!, self._r[1088]!, [_1]) + } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1090]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1091]! } + public var SocksProxySetup_Password: String { return self._s[1092]! } + public var Notifications_PermissionsEnable: String { return self._s[1093]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[1095]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1095]!, self._r[1095]!, [_1]) + return formatWithArgumentRanges(self._s[1096]!, self._r[1096]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1097]!, self._r[1097]!, [_0]) + return formatWithArgumentRanges(self._s[1098]!, self._r[1098]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[1098]! } - public var ArchivedPacksAlert_Title: String { return self._s[1099]! } - public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1100]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[1099]! } + public var ArchivedPacksAlert_Title: String { return self._s[1100]! } + public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1101]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1101]!, self._r[1101]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1102]!, self._r[1102]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1102]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1104]! } - public var Conversation_StatusTyping: String { return self._s[1105]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[1106]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[1107]! } - public var UserInfo_CreateNewContact: String { return self._s[1108]! } - public var Passport_Identity_FrontSide: String { return self._s[1109]! } - public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1110]! } - public var Calls_CallTabTitle: String { return self._s[1111]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1112]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1103]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1105]! } + public var Conversation_StatusTyping: String { return self._s[1106]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[1107]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[1108]! } + public var UserInfo_CreateNewContact: String { return self._s[1109]! } + public var Passport_Identity_FrontSide: String { return self._s[1110]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1111]! } + public var Calls_CallTabTitle: String { return self._s[1112]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1113]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1114]!, self._r[1114]!, [_0]) + return formatWithArgumentRanges(self._s[1115]!, self._r[1115]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[1115]! } - public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1116]! } - public var SharedMedia_EmptyMusicText: String { return self._s[1117]! } - public var Wallet_Completed_Text: String { return self._s[1118]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1119]! } - public var Paint_Stickers: String { return self._s[1120]! } - public var Privacy_GroupsAndChannels: String { return self._s[1121]! } - public var ChatList_Context_Delete: String { return self._s[1123]! } - public var UserInfo_AddContact: String { return self._s[1124]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[1116]! } + public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1117]! } + public var SharedMedia_EmptyMusicText: String { return self._s[1118]! } + public var Wallet_Completed_Text: String { return self._s[1119]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1120]! } + public var Paint_Stickers: String { return self._s[1121]! } + public var Privacy_GroupsAndChannels: String { return self._s[1122]! } + public var ChatList_Context_Delete: String { return self._s[1124]! } + public var UserInfo_AddContact: String { return self._s[1125]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1125]!, self._r[1125]!, [_0]) + return formatWithArgumentRanges(self._s[1126]!, self._r[1126]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[1127]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[1128]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1129]!, self._r[1129]!, [_0]) + return formatWithArgumentRanges(self._s[1130]!, self._r[1130]!, [_0]) } - public var DialogList_NoMessagesTitle: String { return self._s[1130]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[1131]! } - public var BlockedUsers_BlockUser: String { return self._s[1132]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[1133]! } - public var MediaPicker_UngroupDescription: String { return self._s[1134]! } - public var Watch_NoConnection: String { return self._s[1135]! } - public var Month_GenSeptember: String { return self._s[1136]! } - public var Conversation_ViewGroup: String { return self._s[1138]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1141]! } - public var Privacy_Forwards_AlwaysLink: String { return self._s[1142]! } - public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1143]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1144]! } - public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1145]! } - public var MediaPicker_CameraRoll: String { return self._s[1147]! } - public var Month_GenAugust: String { return self._s[1148]! } - public var Wallet_Configuration_SourceHeader: String { return self._s[1149]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[1150]! } - public var SharedMedia_EmptyText: String { return self._s[1151]! } - public var Map_ShareLiveLocation: String { return self._s[1152]! } - public var Calls_All: String { return self._s[1153]! } - public var Appearance_ThemeNight: String { return self._s[1156]! } - public var Conversation_HoldForAudio: String { return self._s[1157]! } - public var SettingsSearch_Synonyms_Support: String { return self._s[1160]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[1161]! } - public var SocksProxySetup_Secret: String { return self._s[1162]! } + public var DialogList_NoMessagesTitle: String { return self._s[1131]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1132]! } + public var BlockedUsers_BlockUser: String { return self._s[1133]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[1134]! } + public var MediaPicker_UngroupDescription: String { return self._s[1135]! } + public var Watch_NoConnection: String { return self._s[1136]! } + public var Month_GenSeptember: String { return self._s[1137]! } + public var Conversation_ViewGroup: String { return self._s[1139]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1142]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[1143]! } + public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1144]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1145]! } + public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1146]! } + public var MediaPicker_CameraRoll: String { return self._s[1148]! } + public var Month_GenAugust: String { return self._s[1149]! } + public var Wallet_Configuration_SourceHeader: String { return self._s[1150]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[1151]! } + public var SharedMedia_EmptyText: String { return self._s[1152]! } + public var Map_ShareLiveLocation: String { return self._s[1153]! } + public var Calls_All: String { return self._s[1154]! } + public var Appearance_ThemeNight: String { return self._s[1157]! } + public var Conversation_HoldForAudio: String { return self._s[1158]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[1161]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[1162]! } + public var SocksProxySetup_Secret: String { return self._s[1163]! } public func Activity_RemindAboutChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1163]!, self._r[1163]!, [_0]) + return formatWithArgumentRanges(self._s[1164]!, self._r[1164]!, [_0]) } - public var Channel_BanList_RestrictedTitle: String { return self._s[1165]! } - public var Conversation_Location: String { return self._s[1166]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[1166]! } + public var Conversation_Location: String { return self._s[1167]! } public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1167]!, self._r[1167]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1168]!, self._r[1168]!, [_1, _2]) } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[1169]! } - public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1170]! } - public var Notifications_PermissionsText: String { return self._s[1171]! } - public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1172]! } - public var Call_Flip: String { return self._s[1173]! } - public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1175]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1176]! } - public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1177]! } - public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1178]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1180]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1182]! } - public var Channel_TooMuchBots: String { return self._s[1184]! } - public var Passport_DeletePassportConfirmation: String { return self._s[1185]! } - public var Login_InvalidCodeError: String { return self._s[1186]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[1187]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[1170]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1171]! } + public var Notifications_PermissionsText: String { return self._s[1172]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1173]! } + public var Call_Flip: String { return self._s[1174]! } + public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1176]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1177]! } + public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1178]! } + public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1179]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1181]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1183]! } + public var Channel_TooMuchBots: String { return self._s[1185]! } + public var Passport_DeletePassportConfirmation: String { return self._s[1186]! } + public var Login_InvalidCodeError: String { return self._s[1187]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[1188]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1188]!, self._r[1188]!, [_0]) - } - public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1189]!, self._r[1189]!, [_0]) } - public var VoiceOver_Navigation_ProxySettings: String { return self._s[1190]! } - public var Call_CallInProgressTitle: String { return self._s[1191]! } - public var Month_ShortSeptember: String { return self._s[1192]! } - public var Watch_ChannelInfo_Title: String { return self._s[1193]! } - public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1196]! } - public var DialogList_PasscodeLockHelp: String { return self._s[1197]! } - public var Chat_MultipleTextMessagesDisabled: String { return self._s[1198]! } - public var Wallet_Receive_Title: String { return self._s[1199]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[1200]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1201]! } - public var PhotoEditor_CropReset: String { return self._s[1202]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1204]! } - public var Channel_Management_LabelEditor: String { return self._s[1205]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[1207]! } - public var PhotoEditor_HighlightsTool: String { return self._s[1208]! } - public var Wallet_Info_WalletCreated: String { return self._s[1209]! } - public var UserInfo_Title: String { return self._s[1210]! } - public var ChatList_HideAction: String { return self._s[1211]! } - public var AccessDenied_Title: String { return self._s[1212]! } - public var DialogList_SearchLabel: String { return self._s[1213]! } - public var Group_Setup_HistoryHidden: String { return self._s[1214]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1215]! } - public var State_Updating: String { return self._s[1217]! } - public var Contacts_TabTitle: String { return self._s[1218]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[1220]! } - public var GroupInfo_GroupHistory: String { return self._s[1221]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1222]! } - public var Wallpaper_SetColor: String { return self._s[1223]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1224]! } - public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1225]! } - public var Chat_AttachmentLimitReached: String { return self._s[1226]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1227]! } - public var Contacts_NotRegisteredSection: String { return self._s[1228]! } + public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1190]!, self._r[1190]!, [_0]) + } + public var VoiceOver_Navigation_ProxySettings: String { return self._s[1191]! } + public var Call_CallInProgressTitle: String { return self._s[1192]! } + public var Month_ShortSeptember: String { return self._s[1193]! } + public var Watch_ChannelInfo_Title: String { return self._s[1194]! } + public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1197]! } + public var DialogList_PasscodeLockHelp: String { return self._s[1198]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[1199]! } + public var Wallet_Receive_Title: String { return self._s[1200]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[1201]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1202]! } + public var PhotoEditor_CropReset: String { return self._s[1203]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1205]! } + public var Channel_Management_LabelEditor: String { return self._s[1206]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[1208]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1209]! } + public var Wallet_Info_WalletCreated: String { return self._s[1210]! } + public var UserInfo_Title: String { return self._s[1211]! } + public var ChatList_HideAction: String { return self._s[1212]! } + public var AccessDenied_Title: String { return self._s[1213]! } + public var DialogList_SearchLabel: String { return self._s[1214]! } + public var Group_Setup_HistoryHidden: String { return self._s[1215]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1216]! } + public var State_Updating: String { return self._s[1218]! } + public var Contacts_TabTitle: String { return self._s[1219]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1221]! } + public var GroupInfo_GroupHistory: String { return self._s[1222]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1223]! } + public var Wallpaper_SetColor: String { return self._s[1224]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1225]! } + public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1226]! } + public var Chat_AttachmentLimitReached: String { return self._s[1227]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1228]! } + public var Contacts_NotRegisteredSection: String { return self._s[1229]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1229]!, self._r[1229]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1230]!, self._r[1230]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[1230]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[1231]! } - public var SocksProxySetup_Connecting: String { return self._s[1232]! } - public var ExplicitContent_AlertChannel: String { return self._s[1233]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[1234]! } - public var Conversation_Contact: String { return self._s[1235]! } - public var Login_CodeExpired: String { return self._s[1236]! } - public var Passport_DiscardMessageAction: String { return self._s[1237]! } - public var ChatList_Context_Unpin: String { return self._s[1238]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1239]! } + public var Paint_Clear: String { return self._s[1231]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1232]! } + public var SocksProxySetup_Connecting: String { return self._s[1233]! } + public var ExplicitContent_AlertChannel: String { return self._s[1234]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[1235]! } + public var Conversation_Contact: String { return self._s[1236]! } + public var Login_CodeExpired: String { return self._s[1237]! } + public var Passport_DiscardMessageAction: String { return self._s[1238]! } + public var ChatList_Context_Unpin: String { return self._s[1239]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1240]! } public func VoiceOver_Chat_MusicFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1240]!, self._r[1240]!, [_0]) + return formatWithArgumentRanges(self._s[1241]!, self._r[1241]!, [_0]) } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[1241]! } - public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1242]! } + public var Channel_AdminLog_EmptyMessageText: String { return self._s[1242]! } + public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1243]! } public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1243]!, self._r[1243]!, [_0]) + return formatWithArgumentRanges(self._s[1244]!, self._r[1244]!, [_0]) } - public var Month_ShortApril: String { return self._s[1244]! } - public var AuthSessions_CurrentSession: String { return self._s[1245]! } - public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1248]! } - public var Wallet_Navigation_Cancel: String { return self._s[1250]! } - public var WallpaperPreview_CropTopText: String { return self._s[1251]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1252]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1253]! } + public var Month_ShortApril: String { return self._s[1245]! } + public var AuthSessions_CurrentSession: String { return self._s[1246]! } + public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1249]! } + public var Wallet_Navigation_Cancel: String { return self._s[1251]! } + public var WallpaperPreview_CropTopText: String { return self._s[1252]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1253]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1254]! } public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1254]!, self._r[1254]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1255]!, self._r[1255]!, [_0, _1]) } - public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1255]! } - public var Channel_Setup_TypePrivate: String { return self._s[1257]! } - public var Forward_ChannelReadOnly: String { return self._s[1260]! } - public var PhotoEditor_CurvesBlue: String { return self._s[1261]! } - public var AddContact_SharedContactException: String { return self._s[1262]! } - public var UserInfo_BotPrivacy: String { return self._s[1264]! } - public var Wallet_CreateInvoice_Title: String { return self._s[1265]! } - public var Notification_PassportValueEmail: String { return self._s[1266]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[1267]! } - public var GroupPermission_NewTitle: String { return self._s[1268]! } - public var CallFeedback_ReasonDropped: String { return self._s[1269]! } - public var GroupInfo_Permissions_AddException: String { return self._s[1270]! } - public var Channel_SignMessages_Help: String { return self._s[1272]! } - public var Undo_ChatDeleted: String { return self._s[1274]! } - public var Conversation_ChatBackground: String { return self._s[1275]! } + public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1256]! } + public var Channel_Setup_TypePrivate: String { return self._s[1258]! } + public var Forward_ChannelReadOnly: String { return self._s[1261]! } + public var PhotoEditor_CurvesBlue: String { return self._s[1262]! } + public var AddContact_SharedContactException: String { return self._s[1263]! } + public var UserInfo_BotPrivacy: String { return self._s[1265]! } + public var Wallet_CreateInvoice_Title: String { return self._s[1266]! } + public var Notification_PassportValueEmail: String { return self._s[1267]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[1268]! } + public var GroupPermission_NewTitle: String { return self._s[1269]! } + public var CallFeedback_ReasonDropped: String { return self._s[1270]! } + public var GroupInfo_Permissions_AddException: String { return self._s[1271]! } + public var Channel_SignMessages_Help: String { return self._s[1273]! } + public var Undo_ChatDeleted: String { return self._s[1275]! } + public var Conversation_ChatBackground: String { return self._s[1276]! } public func Wallet_WordCheck_Text(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1276]!, self._r[1276]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1277]!, self._r[1277]!, [_1, _2, _3]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1277]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1278]! } - public var Passport_Language_pt: String { return self._s[1279]! } - public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1280]! } - public var NotificationsSound_Popcorn: String { return self._s[1283]! } - public var AutoNightTheme_Disabled: String { return self._s[1284]! } - public var BlockedUsers_LeavePrefix: String { return self._s[1285]! } - public var WallpaperPreview_CustomColorTopText: String { return self._s[1286]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[1287]! } - public var WallpaperSearch_ColorBlue: String { return self._s[1288]! } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1278]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1279]! } + public var Passport_Language_pt: String { return self._s[1280]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1281]! } + public var NotificationsSound_Popcorn: String { return self._s[1284]! } + public var AutoNightTheme_Disabled: String { return self._s[1285]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1286]! } + public var WallpaperPreview_CustomColorTopText: String { return self._s[1287]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1288]! } + public var WallpaperSearch_ColorBlue: String { return self._s[1289]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1289]!, self._r[1289]!, [_0]) + return formatWithArgumentRanges(self._s[1290]!, self._r[1290]!, [_0]) } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1290]! } - public var SocksProxySetup_UseForCalls: String { return self._s[1291]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1293]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1291]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1292]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1294]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1294]!, self._r[1294]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1295]!, self._r[1295]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[1297]! } - public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1298]! } - public var Compose_NewEncryptedChat: String { return self._s[1299]! } - public var Login_CodeFloodError: String { return self._s[1300]! } - public var Calls_TabTitle: String { return self._s[1301]! } - public var Privacy_ProfilePhoto: String { return self._s[1302]! } - public var Passport_Language_he: String { return self._s[1303]! } + public var SocksProxySetup_Hostname: String { return self._s[1298]! } + public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1299]! } + public var Compose_NewEncryptedChat: String { return self._s[1300]! } + public var Login_CodeFloodError: String { return self._s[1301]! } + public var Calls_TabTitle: String { return self._s[1302]! } + public var Privacy_ProfilePhoto: String { return self._s[1303]! } + public var Passport_Language_he: String { return self._s[1304]! } public func Conversation_SetReminder_RemindToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1304]!, self._r[1304]!, [_0]) + return formatWithArgumentRanges(self._s[1305]!, self._r[1305]!, [_0]) } - public var GroupPermission_Title: String { return self._s[1305]! } + public var GroupPermission_Title: String { return self._s[1306]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1306]!, self._r[1306]!, [_0]) + return formatWithArgumentRanges(self._s[1307]!, self._r[1307]!, [_0]) } - public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1307]! } - public var GroupPermission_NoChangeInfo: String { return self._s[1308]! } - public var ChatList_DeleteForCurrentUser: String { return self._s[1309]! } - public var Tour_Text1: String { return self._s[1310]! } - public var Channel_EditAdmin_TransferOwnership: String { return self._s[1311]! } - public var Month_ShortFebruary: String { return self._s[1312]! } - public var TwoStepAuth_EmailSkip: String { return self._s[1313]! } + public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1308]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1309]! } + public var ChatList_DeleteForCurrentUser: String { return self._s[1310]! } + public var Tour_Text1: String { return self._s[1311]! } + public var Channel_EditAdmin_TransferOwnership: String { return self._s[1312]! } + public var Month_ShortFebruary: String { return self._s[1313]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1314]! } public func Wallet_Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1314]!, self._r[1314]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1315]!, self._r[1315]!, [_1, _2, _3]) } - public var NotificationsSound_Glass: String { return self._s[1315]! } - public var Appearance_ThemeNightBlue: String { return self._s[1316]! } - public var CheckoutInfo_Pay: String { return self._s[1317]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1319]! } - public var Call_CallAgain: String { return self._s[1321]! } - public var AttachmentMenu_SendAsFile: String { return self._s[1322]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[1323]! } - public var Passport_InvalidPasswordError: String { return self._s[1324]! } - public var Watch_Message_Game: String { return self._s[1325]! } - public var Stickers_Install: String { return self._s[1326]! } - public var VoiceOver_Chat_Message: String { return self._s[1327]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1328]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[1330]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[1331]! } - public var AuthSessions_OtherSessions: String { return self._s[1332]! } - public var Channel_Username_Help: String { return self._s[1333]! } - public var Camera_Title: String { return self._s[1334]! } - public var IntentsSettings_Title: String { return self._s[1335]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1337]! } - public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1338]! } - public var Channel_AdminLog_SendPolls: String { return self._s[1339]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1340]! } - public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1341]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1342]! } - public var ScheduledMessages_DeleteMany: String { return self._s[1343]! } - public var Conversation_RestrictedStickers: String { return self._s[1344]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1346]! } - public var UserInfo_TelegramCall: String { return self._s[1348]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1349]! } - public var CreatePoll_OptionsHeader: String { return self._s[1350]! } - public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1351]! } - public var ArchivedChats_IntroTitle1: String { return self._s[1352]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1353]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1354]! } + public var NotificationsSound_Glass: String { return self._s[1316]! } + public var Appearance_ThemeNightBlue: String { return self._s[1317]! } + public var CheckoutInfo_Pay: String { return self._s[1318]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1320]! } + public var Call_CallAgain: String { return self._s[1322]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1323]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1324]! } + public var Passport_InvalidPasswordError: String { return self._s[1325]! } + public var Watch_Message_Game: String { return self._s[1326]! } + public var Stickers_Install: String { return self._s[1327]! } + public var VoiceOver_Chat_Message: String { return self._s[1328]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1329]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1331]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1332]! } + public var AuthSessions_OtherSessions: String { return self._s[1333]! } + public var Channel_Username_Help: String { return self._s[1334]! } + public var Camera_Title: String { return self._s[1335]! } + public var IntentsSettings_Title: String { return self._s[1336]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1338]! } + public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1339]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1340]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1341]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1342]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1343]! } + public var ScheduledMessages_DeleteMany: String { return self._s[1344]! } + public var Conversation_RestrictedStickers: String { return self._s[1345]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1347]! } + public var UserInfo_TelegramCall: String { return self._s[1349]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1350]! } + public var CreatePoll_OptionsHeader: String { return self._s[1351]! } + public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1352]! } + public var ArchivedChats_IntroTitle1: String { return self._s[1353]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1354]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1355]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1355]!, self._r[1355]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1356]!, self._r[1356]!, [_1, _2, _3]) } - public var Wallet_Month_GenAugust: String { return self._s[1356]! } - public var Settings_SaveEditedPhotos: String { return self._s[1357]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1358]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1359]! } - public var Conversation_MessageDialogRetry: String { return self._s[1360]! } - public var ChatList_Context_MarkAsUnread: String { return self._s[1361]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1362]! } - public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1363]! } - public var Group_Setup_TypeHeader: String { return self._s[1364]! } - public var Paint_RecentStickers: String { return self._s[1365]! } - public var PhotoEditor_GrainTool: String { return self._s[1366]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1367]! } - public var EmptyGroupInfo_Line4: String { return self._s[1368]! } - public var Watch_AuthRequired: String { return self._s[1370]! } + public var Wallet_Month_GenAugust: String { return self._s[1357]! } + public var Settings_SaveEditedPhotos: String { return self._s[1358]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1359]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1360]! } + public var Conversation_MessageDialogRetry: String { return self._s[1361]! } + public var ChatList_Context_MarkAsUnread: String { return self._s[1362]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1363]! } + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1364]! } + public var Group_Setup_TypeHeader: String { return self._s[1365]! } + public var Paint_RecentStickers: String { return self._s[1366]! } + public var PhotoEditor_GrainTool: String { return self._s[1367]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1368]! } + public var EmptyGroupInfo_Line4: String { return self._s[1369]! } + public var Watch_AuthRequired: String { return self._s[1371]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1371]!, self._r[1371]!, [_0]) + return formatWithArgumentRanges(self._s[1372]!, self._r[1372]!, [_0]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1372]! } - public var ChannelIntro_Text: String { return self._s[1373]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1374]! } - public var GroupPermission_NoSendMedia: String { return self._s[1375]! } - public var Calls_AddTab: String { return self._s[1376]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1377]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1378]! } - public var Conversation_WalletRequiredSetup: String { return self._s[1379]! } - public var Notification_MessageLifetime1d: String { return self._s[1380]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1381]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1382]! } - public var Passport_Identity_GenderFemale: String { return self._s[1383]! } - public var BlockedUsers_BlockTitle: String { return self._s[1384]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1373]! } + public var ChannelIntro_Text: String { return self._s[1374]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1375]! } + public var GroupPermission_NoSendMedia: String { return self._s[1376]! } + public var Calls_AddTab: String { return self._s[1377]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1378]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1379]! } + public var Conversation_WalletRequiredSetup: String { return self._s[1380]! } + public var Notification_MessageLifetime1d: String { return self._s[1381]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1382]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1383]! } + public var Passport_Identity_GenderFemale: String { return self._s[1384]! } + public var BlockedUsers_BlockTitle: String { return self._s[1385]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1385]!, self._r[1385]!, [_1]) + return formatWithArgumentRanges(self._s[1386]!, self._r[1386]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1386]! } - public var WallpaperSearch_ColorBlack: String { return self._s[1387]! } - public var Settings_Context_Logout: String { return self._s[1388]! } - public var Wallet_Info_UnknownTransaction: String { return self._s[1389]! } - public var ChatList_ArchiveAction: String { return self._s[1390]! } - public var AutoNightTheme_Scheduled: String { return self._s[1391]! } - public var TwoFactorSetup_Email_SkipAction: String { return self._s[1392]! } - public var ContactInfo_Note: String { return self._s[1393]! } + public var Weekday_Yesterday: String { return self._s[1387]! } + public var WallpaperSearch_ColorBlack: String { return self._s[1388]! } + public var Settings_Context_Logout: String { return self._s[1389]! } + public var Wallet_Info_UnknownTransaction: String { return self._s[1390]! } + public var ChatList_ArchiveAction: String { return self._s[1391]! } + public var AutoNightTheme_Scheduled: String { return self._s[1392]! } + public var TwoFactorSetup_Email_SkipAction: String { return self._s[1393]! } + public var Settings_Devices: String { return self._s[1394]! } + public var ContactInfo_Note: String { return self._s[1395]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1394]!, self._r[1394]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1396]!, self._r[1396]!, [_1, _2, _3, _4, _5, _6]) } - public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1395]! } - public var Wallet_Receive_CreateInvoice: String { return self._s[1396]! } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1397]! } - public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1398]! } + public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1397]! } + public var Wallet_Receive_CreateInvoice: String { return self._s[1398]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1399]! } + public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1400]! } public func PUSH_CHAT_JOINED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1399]!, self._r[1399]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1401]!, self._r[1401]!, [_1, _2]) } - public var CreatePoll_Create: String { return self._s[1400]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1401]! } + public var CreatePoll_Create: String { return self._s[1402]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1403]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1402]!, self._r[1402]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1404]!, self._r[1404]!, [_1, _2]) } - public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1403]! } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1404]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1406]! } + public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1405]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1406]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1408]! } public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1407]!, self._r[1407]!, [_1]) + return formatWithArgumentRanges(self._s[1409]!, self._r[1409]!, [_1]) } - public var Preview_OpenInInstagram: String { return self._s[1408]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1409]! } + public var Preview_OpenInInstagram: String { return self._s[1410]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1411]! } public func PUSH_CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1410]!, self._r[1410]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1412]!, self._r[1412]!, [_1, _2, _3]) } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1411]!, self._r[1411]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1413]!, self._r[1413]!, [_1, _2]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1412]! } - public var ArchivedChats_IntroText3: String { return self._s[1413]! } - public var ChatList_UndoArchiveHiddenText: String { return self._s[1414]! } - public var NetworkUsageSettings_TotalSection: String { return self._s[1415]! } - public var Wallet_Month_GenSeptember: String { return self._s[1416]! } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1417]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1414]! } + public var ArchivedChats_IntroText3: String { return self._s[1415]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[1416]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1417]! } + public var Wallet_Month_GenSeptember: String { return self._s[1418]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1419]! } public func PUSH_CHAT_MESSAGE_POLL(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1418]!, self._r[1418]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1420]!, self._r[1420]!, [_1, _2, _3]) } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1420]! } - public var FastTwoStepSetup_HintSection: String { return self._s[1421]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1422]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1423]! } - public var Gif_NoGifsFound: String { return self._s[1424]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1425]! } - public var VoiceOver_MessageContextDelete: String { return self._s[1426]! } - public var EditTheme_Preview: String { return self._s[1427]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1422]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1423]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1424]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1425]! } + public var Gif_NoGifsFound: String { return self._s[1426]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1427]! } + public var VoiceOver_MessageContextDelete: String { return self._s[1428]! } + public var EditTheme_Preview: String { return self._s[1429]! } public func ClearCache_StorageTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1428]!, self._r[1428]!, [_0]) + return formatWithArgumentRanges(self._s[1430]!, self._r[1430]!, [_0]) } - public var GroupInfo_ActionPromote: String { return self._s[1429]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1430]! } - public var GroupInfo_Permissions_Title: String { return self._s[1431]! } - public var Permissions_ContactsText_v0: String { return self._s[1432]! } - public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1433]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1434]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1437]! } - public var Passport_FieldEmailHelp: String { return self._s[1438]! } + public var GroupInfo_ActionPromote: String { return self._s[1431]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1432]! } + public var GroupInfo_Permissions_Title: String { return self._s[1433]! } + public var Permissions_ContactsText_v0: String { return self._s[1434]! } + public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1435]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1436]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1439]! } + public var Passport_FieldEmailHelp: String { return self._s[1440]! } public func Activity_RemindAboutUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1439]!, self._r[1439]!, [_0]) + return formatWithArgumentRanges(self._s[1441]!, self._r[1441]!, [_0]) } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1440]! } - public var Weekday_ShortSaturday: String { return self._s[1441]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1442]! } - public var Watch_Conversation_UserInfo: String { return self._s[1443]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1444]! } - public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1445]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1446]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1447]! } - public var PhotoEditor_VignetteTool: String { return self._s[1448]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1449]! } - public var Passport_Language_et: String { return self._s[1450]! } - public var AppUpgrade_Running: String { return self._s[1451]! } - public var Channel_DiscussionGroup_Info: String { return self._s[1453]! } - public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1454]! } - public var Passport_Language_bg: String { return self._s[1455]! } - public var Stickers_NoStickersFound: String { return self._s[1457]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1442]! } + public var Weekday_ShortSaturday: String { return self._s[1443]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1444]! } + public var Watch_Conversation_UserInfo: String { return self._s[1445]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1446]! } + public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1447]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1448]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1449]! } + public var PhotoEditor_VignetteTool: String { return self._s[1450]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1451]! } + public var Passport_Language_et: String { return self._s[1452]! } + public var AppUpgrade_Running: String { return self._s[1453]! } + public var Channel_DiscussionGroup_Info: String { return self._s[1455]! } + public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1456]! } + public var Passport_Language_bg: String { return self._s[1457]! } + public var Stickers_NoStickersFound: String { return self._s[1459]! } public func PUSH_CHANNEL_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1459]!, self._r[1459]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1461]!, self._r[1461]!, [_1, _2]) } public func VoiceOver_Chat_ContactFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1460]!, self._r[1460]!, [_0]) + return formatWithArgumentRanges(self._s[1462]!, self._r[1462]!, [_0]) } - public var Wallet_Month_GenJuly: String { return self._s[1461]! } - public var Wallet_Receive_AddressHeader: String { return self._s[1462]! } - public var Wallet_Send_AmountText: String { return self._s[1463]! } - public var Settings_About: String { return self._s[1464]! } + public var Wallet_Month_GenJuly: String { return self._s[1463]! } + public var Wallet_Receive_AddressHeader: String { return self._s[1464]! } + public var Wallet_Send_AmountText: String { return self._s[1465]! } + public var Settings_About: String { return self._s[1466]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1465]!, self._r[1465]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1467]!, self._r[1467]!, [_0, _1, _2]) } - public var ChatList_Context_MarkAsRead: String { return self._s[1467]! } - public var KeyCommand_NewMessage: String { return self._s[1468]! } - public var Group_ErrorAddBlocked: String { return self._s[1469]! } + public var ChatList_Context_MarkAsRead: String { return self._s[1469]! } + public var KeyCommand_NewMessage: String { return self._s[1470]! } + public var Group_ErrorAddBlocked: String { return self._s[1471]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1470]!, self._r[1470]!, [_0]) + return formatWithArgumentRanges(self._s[1472]!, self._r[1472]!, [_0]) } - public var Map_LocationTitle: String { return self._s[1471]! } - public var ReportGroupLocation_Title: String { return self._s[1472]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1473]! } - public var Cache_ClearProgress: String { return self._s[1474]! } + public var Map_LocationTitle: String { return self._s[1473]! } + public var ReportGroupLocation_Title: String { return self._s[1474]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1475]! } + public var Cache_ClearProgress: String { return self._s[1476]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1475]!, self._r[1475]!, [_0]) + return formatWithArgumentRanges(self._s[1477]!, self._r[1477]!, [_0]) } - public var GroupRemoved_AddToGroup: String { return self._s[1476]! } - public var Passport_UpdateRequiredError: String { return self._s[1477]! } - public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1478]! } + public var GroupRemoved_AddToGroup: String { return self._s[1478]! } + public var Passport_UpdateRequiredError: String { return self._s[1479]! } + public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1480]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1479]!, self._r[1479]!, [_1]) + return formatWithArgumentRanges(self._s[1481]!, self._r[1481]!, [_1]) } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1481]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1482]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1483]! } - public var Passport_Language_ka: String { return self._s[1484]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1483]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1484]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1485]! } + public var Passport_Language_ka: String { return self._s[1486]! } public func Wallet_Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1485]!, self._r[1485]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1487]!, self._r[1487]!, [_1, _2, _3]) } - public var Call_Decline: String { return self._s[1486]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1487]! } - public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1490]! } + public var Call_Decline: String { return self._s[1488]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1489]! } + public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1492]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1491]!, self._r[1491]!, [_0]) + return formatWithArgumentRanges(self._s[1493]!, self._r[1493]!, [_0]) } - public var CallFeedback_Send: String { return self._s[1492]! } - public var EditTheme_EditTitle: String { return self._s[1493]! } + public var CallFeedback_Send: String { return self._s[1494]! } + public var EditTheme_EditTitle: String { return self._s[1495]! } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1494]!, self._r[1494]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1496]!, self._r[1496]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1495]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1497]! } public func Wallet_Updated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1497]!, self._r[1497]!, [_0]) + return formatWithArgumentRanges(self._s[1499]!, self._r[1499]!, [_0]) } - public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1498]! } - public var Passport_DeletePassport: String { return self._s[1499]! } - public var Appearance_AppIconFilled: String { return self._s[1500]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1501]! } - public var Month_ShortDecember: String { return self._s[1502]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1504]! } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1500]! } + public var Passport_DeletePassport: String { return self._s[1501]! } + public var Appearance_AppIconFilled: String { return self._s[1502]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1503]! } + public var Month_ShortDecember: String { return self._s[1504]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1506]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1505]!, self._r[1505]!, [_0]) + return formatWithArgumentRanges(self._s[1507]!, self._r[1507]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1506]! } - public var Conversation_EncryptedDescription1: String { return self._s[1507]! } - public var Conversation_EncryptedDescription2: String { return self._s[1508]! } - public var PasscodeSettings_PasscodeOptions: String { return self._s[1509]! } - public var Conversation_EncryptedDescription3: String { return self._s[1511]! } - public var PhotoEditor_SharpenTool: String { return self._s[1512]! } - public var Wallet_Configuration_Title: String { return self._s[1513]! } + public var Channel_Stickers_Searching: String { return self._s[1508]! } + public var Conversation_EncryptedDescription1: String { return self._s[1509]! } + public var Conversation_EncryptedDescription2: String { return self._s[1510]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[1511]! } + public var Conversation_EncryptedDescription3: String { return self._s[1513]! } + public var PhotoEditor_SharpenTool: String { return self._s[1514]! } + public var Wallet_Configuration_Title: String { return self._s[1515]! } public func Conversation_AddNameToContacts(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1514]!, self._r[1514]!, [_0]) + return formatWithArgumentRanges(self._s[1516]!, self._r[1516]!, [_0]) } - public var Conversation_EncryptedDescription4: String { return self._s[1516]! } - public var Channel_Members_AddMembers: String { return self._s[1517]! } - public var Wallpaper_Search: String { return self._s[1518]! } - public var Weekday_Friday: String { return self._s[1519]! } - public var Privacy_ContactsSync: String { return self._s[1520]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1521]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1522]! } + public var Conversation_EncryptedDescription4: String { return self._s[1518]! } + public var Channel_Members_AddMembers: String { return self._s[1519]! } + public var Wallpaper_Search: String { return self._s[1520]! } + public var Weekday_Friday: String { return self._s[1521]! } + public var Privacy_ContactsSync: String { return self._s[1522]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1523]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1524]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1523]!, self._r[1523]!, [_0]) + return formatWithArgumentRanges(self._s[1525]!, self._r[1525]!, [_0]) } - public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1524]! } - public var GroupInfo_Permissions_Removed: String { return self._s[1525]! } - public var ScheduledMessages_ScheduledOnline: String { return self._s[1526]! } - public var Passport_Identity_GenderMale: String { return self._s[1527]! } + public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1526]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1527]! } + public var ScheduledMessages_ScheduledOnline: String { return self._s[1528]! } + public var Passport_Identity_GenderMale: String { return self._s[1529]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1528]!, self._r[1528]!, [_0]) + return formatWithArgumentRanges(self._s[1530]!, self._r[1530]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1529]! } - public var Conversation_JumpToDate: String { return self._s[1530]! } - public var Contacts_GlobalSearch: String { return self._s[1531]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1532]! } - public var SettingsSearch_Synonyms_FAQ: String { return self._s[1533]! } - public var Profile_MessageLifetime1d: String { return self._s[1534]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1531]! } + public var Conversation_JumpToDate: String { return self._s[1532]! } + public var Contacts_GlobalSearch: String { return self._s[1533]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1534]! } + public var SettingsSearch_Synonyms_FAQ: String { return self._s[1535]! } + public var Profile_MessageLifetime1d: String { return self._s[1536]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1535]!, self._r[1535]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1537]!, self._r[1537]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1538]! } + public var StickerPack_BuiltinPackName: String { return self._s[1540]! } public func PUSH_CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1539]!, self._r[1539]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1541]!, self._r[1541]!, [_1, _2]) } - public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1540]! } - public var Passport_InfoTitle: String { return self._s[1542]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1543]! } + public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1542]! } + public var Passport_InfoTitle: String { return self._s[1544]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1545]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1547]!, self._r[1547]!, [_0]) + return formatWithArgumentRanges(self._s[1549]!, self._r[1549]!, [_0]) } public func PUSH_CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1548]!, self._r[1548]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1550]!, self._r[1550]!, [_1, _2]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1549]! } - public var Profile_BotInfo: String { return self._s[1550]! } - public var Watch_Compose_CreateMessage: String { return self._s[1551]! } - public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1552]! } - public var Month_ShortNovember: String { return self._s[1553]! } - public var Conversation_ScamWarning: String { return self._s[1554]! } - public var Wallpaper_SetCustomBackground: String { return self._s[1555]! } - public var Appearance_TextSize_Title: String { return self._s[1556]! } - public var Passport_Identity_TranslationsHelp: String { return self._s[1557]! } - public var NotificationsSound_Chime: String { return self._s[1558]! } - public var Passport_Language_ko: String { return self._s[1560]! } - public var InviteText_URL: String { return self._s[1561]! } - public var TextFormat_Monospace: String { return self._s[1562]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1551]! } + public var Profile_BotInfo: String { return self._s[1552]! } + public var Watch_Compose_CreateMessage: String { return self._s[1553]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1554]! } + public var Month_ShortNovember: String { return self._s[1555]! } + public var Conversation_ScamWarning: String { return self._s[1556]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1557]! } + public var Appearance_TextSize_Title: String { return self._s[1558]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1559]! } + public var NotificationsSound_Chime: String { return self._s[1560]! } + public var Passport_Language_ko: String { return self._s[1562]! } + public var InviteText_URL: String { return self._s[1563]! } + public var TextFormat_Monospace: String { return self._s[1564]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1563]!, self._r[1563]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1565]!, self._r[1565]!, [_1, _2, _3]) } - public var EditTheme_Edit_BottomInfo: String { return self._s[1564]! } + public var EditTheme_Edit_BottomInfo: String { return self._s[1566]! } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1565]!, self._r[1565]!, [_0]) + return formatWithArgumentRanges(self._s[1567]!, self._r[1567]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1566]!, self._r[1566]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1568]!, self._r[1568]!, [_1, _2]) } - public var Wallet_Words_Title: String { return self._s[1567]! } - public var Wallet_Month_ShortMay: String { return self._s[1568]! } - public var EditTheme_CreateTitle: String { return self._s[1570]! } - public var Passport_InfoLearnMore: String { return self._s[1571]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1572]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1573]! } - public var Your_card_has_expired: String { return self._s[1574]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1575]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1576]! } - public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1580]! } - public var Conversation_Report: String { return self._s[1582]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1583]! } - public var Notification_MessageLifetime1m: String { return self._s[1584]! } - public var Privacy_ContactsTitle: String { return self._s[1585]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1586]! } - public var Wallet_WordCheck_Title: String { return self._s[1587]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1588]! } - public var Channel_Members_Title: String { return self._s[1589]! } - public var Map_OpenInWaze: String { return self._s[1590]! } - public var Login_PhoneBannedError: String { return self._s[1591]! } + public var Wallet_Words_Title: String { return self._s[1569]! } + public var Wallet_Month_ShortMay: String { return self._s[1570]! } + public var EditTheme_CreateTitle: String { return self._s[1572]! } + public var Passport_InfoLearnMore: String { return self._s[1573]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1574]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1575]! } + public var Your_card_has_expired: String { return self._s[1576]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1577]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1578]! } + public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1582]! } + public var Conversation_Report: String { return self._s[1584]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1585]! } + public var Notification_MessageLifetime1m: String { return self._s[1586]! } + public var Privacy_ContactsTitle: String { return self._s[1587]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1588]! } + public var Wallet_WordCheck_Title: String { return self._s[1589]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1590]! } + public var Channel_Members_Title: String { return self._s[1591]! } + public var Map_OpenInWaze: String { return self._s[1592]! } + public var Login_PhoneBannedError: String { return self._s[1593]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1592]!, self._r[1592]!, [_0]) + return formatWithArgumentRanges(self._s[1594]!, self._r[1594]!, [_0]) } - public var IntentsSettings_MainAccount: String { return self._s[1593]! } - public var Group_Management_AddModeratorHelp: String { return self._s[1594]! } - public var AutoDownloadSettings_WifiTitle: String { return self._s[1595]! } - public var Common_OK: String { return self._s[1596]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1597]! } - public var Wallet_Words_NotDoneResponse: String { return self._s[1598]! } - public var Cache_Music: String { return self._s[1599]! } - public var Wallet_Configuration_SourceURL: String { return self._s[1600]! } - public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1601]! } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1602]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1603]! } + public var IntentsSettings_MainAccount: String { return self._s[1595]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1596]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[1597]! } + public var Common_OK: String { return self._s[1598]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1599]! } + public var Wallet_Words_NotDoneResponse: String { return self._s[1600]! } + public var Cache_Music: String { return self._s[1601]! } + public var Wallet_Configuration_SourceURL: String { return self._s[1602]! } + public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1603]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1604]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1605]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1604]!, self._r[1604]!, [_1]) + return formatWithArgumentRanges(self._s[1606]!, self._r[1606]!, [_1]) } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1605]!, self._r[1605]!, [_0]) - } - public var TwoFactorSetup_Done_Action: String { return self._s[1606]! } - public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1607]!, self._r[1607]!, [_0]) } - public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1608]! } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1610]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1611]! } - public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1613]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1614]! } - public var State_ConnectingToProxyInfo: String { return self._s[1615]! } - public var Conversation_SwipeToReplyHintTitle: String { return self._s[1616]! } - public var Message_VideoMessage: String { return self._s[1618]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1619]! } - public var ContactInfo_PhoneLabelOther: String { return self._s[1620]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1621]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1622]! } - public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1623]!, self._r[1623]!, [_1, _2, _3]) + public var TwoFactorSetup_Done_Action: String { return self._s[1608]! } + public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1609]!, self._r[1609]!, [_0]) } - public var WallpaperPreview_SwipeBottomText: String { return self._s[1624]! } - public var Activity_RecordingAudio: String { return self._s[1625]! } - public var SettingsSearch_Synonyms_Watch: String { return self._s[1626]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1627]! } - public var Wallet_Info_Address: String { return self._s[1628]! } + public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1610]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1612]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1613]! } + public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1615]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1616]! } + public var State_ConnectingToProxyInfo: String { return self._s[1617]! } + public var Conversation_SwipeToReplyHintTitle: String { return self._s[1618]! } + public var Message_VideoMessage: String { return self._s[1620]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1621]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1622]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1623]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1624]! } + public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1625]!, self._r[1625]!, [_1, _2, _3]) + } + public var WallpaperPreview_SwipeBottomText: String { return self._s[1626]! } + public var Activity_RecordingAudio: String { return self._s[1627]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[1628]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1629]! } + public var Wallet_Info_Address: String { return self._s[1630]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1630]!, self._r[1630]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1632]!, self._r[1632]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1634]!, self._r[1634]!, [_0]) + return formatWithArgumentRanges(self._s[1636]!, self._r[1636]!, [_0]) } - public var Conversation_ApplyLocalization: String { return self._s[1635]! } - public var TwoFactorSetup_Intro_Action: String { return self._s[1636]! } - public var UserInfo_AddPhone: String { return self._s[1637]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1638]! } + public var Conversation_ApplyLocalization: String { return self._s[1637]! } + public var TwoFactorSetup_Intro_Action: String { return self._s[1638]! } + public var UserInfo_AddPhone: String { return self._s[1639]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1640]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1639]!, self._r[1639]!, [_0]) + return formatWithArgumentRanges(self._s[1641]!, self._r[1641]!, [_0]) } - public var Passport_Scans: String { return self._s[1641]! } - public var BlockedUsers_Unblock: String { return self._s[1642]! } + public var Passport_Scans: String { return self._s[1643]! } + public var BlockedUsers_Unblock: String { return self._s[1644]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1643]!, self._r[1643]!, [_1]) + return formatWithArgumentRanges(self._s[1645]!, self._r[1645]!, [_1]) } - public var Channel_Management_LabelCreator: String { return self._s[1644]! } - public var Conversation_ReportSpamAndLeave: String { return self._s[1645]! } - public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1646]! } - public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1647]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1648]! } + public var Channel_Management_LabelCreator: String { return self._s[1646]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[1647]! } + public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1648]! } + public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1649]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1650]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1649]!, self._r[1649]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1651]!, self._r[1651]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1650]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1651]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1652]! } - public var ChannelIntro_CreateChannel: String { return self._s[1653]! } - public var Conversation_UnreadMessages: String { return self._s[1654]! } - public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1655]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1656]! } - public var Theme_Context_Apply: String { return self._s[1657]! } - public var Notification_GroupActivated: String { return self._s[1658]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1659]! } - public var Wallet_Intro_CreateWallet: String { return self._s[1660]! } + public var Login_PhoneNumberHelp: String { return self._s[1652]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1653]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1654]! } + public var ChannelIntro_CreateChannel: String { return self._s[1655]! } + public var Conversation_UnreadMessages: String { return self._s[1656]! } + public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1657]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1658]! } + public var Theme_Context_Apply: String { return self._s[1659]! } + public var Notification_GroupActivated: String { return self._s[1660]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1661]! } + public var Wallet_Intro_CreateWallet: String { return self._s[1662]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1661]!, self._r[1661]!, [_0]) + return formatWithArgumentRanges(self._s[1663]!, self._r[1663]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1662]!, self._r[1662]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1664]!, self._r[1664]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1664]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1666]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1665]!, self._r[1665]!, [_0]) + return formatWithArgumentRanges(self._s[1667]!, self._r[1667]!, [_0]) } - public var Undo_DeletedChannel: String { return self._s[1666]! } - public var CallFeedback_AddComment: String { return self._s[1667]! } + public var Undo_DeletedChannel: String { return self._s[1668]! } + public var CallFeedback_AddComment: String { return self._s[1669]! } public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1668]!, self._r[1668]!, [_0]) - } - public var Document_TargetConfirmationFormat: String { return self._s[1669]! } - public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1670]!, self._r[1670]!, [_0]) } - public var LogoutOptions_SetPasscodeTitle: String { return self._s[1671]! } + public var Document_TargetConfirmationFormat: String { return self._s[1671]! } + public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1672]!, self._r[1672]!, [_0]) + } + public var LogoutOptions_SetPasscodeTitle: String { return self._s[1673]! } public func PUSH_CHAT_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1672]!, self._r[1672]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[1674]!, self._r[1674]!, [_1, _2, _3, _4]) } - public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1673]! } - public var Theme_ErrorNotFound: String { return self._s[1674]! } - public var Contacts_SortByName: String { return self._s[1675]! } - public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1676]! } + public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1675]! } + public var Theme_ErrorNotFound: String { return self._s[1676]! } + public var Contacts_SortByName: String { return self._s[1677]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1678]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1678]!, self._r[1678]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1680]!, self._r[1680]!, [_1, _2, _3]) } - public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1679]! } - public var ScheduledMessages_EditTime: String { return self._s[1680]! } - public var Conversation_ClearSelfHistory: String { return self._s[1681]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1682]! } - public var PasscodeSettings_DoNotMatch: String { return self._s[1683]! } - public var Stickers_SuggestNone: String { return self._s[1684]! } - public var ChatSettings_Cache: String { return self._s[1685]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1686]! } - public var Media_ShareThisPhoto: String { return self._s[1687]! } - public var Chat_SlowmodeTooltipPending: String { return self._s[1688]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1689]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1690]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1691]! } - public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1692]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1693]! } + public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1681]! } + public var ScheduledMessages_EditTime: String { return self._s[1682]! } + public var Conversation_ClearSelfHistory: String { return self._s[1683]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1684]! } + public var PasscodeSettings_DoNotMatch: String { return self._s[1685]! } + public var Stickers_SuggestNone: String { return self._s[1686]! } + public var ChatSettings_Cache: String { return self._s[1687]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1688]! } + public var Media_ShareThisPhoto: String { return self._s[1689]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[1690]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1691]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1692]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1693]! } + public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1694]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1695]! } public func Wallet_SecureStorageReset_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1694]!, self._r[1694]!, [_0]) + return formatWithArgumentRanges(self._s[1696]!, self._r[1696]!, [_0]) } - public var Permissions_CellularDataTitle_v0: String { return self._s[1695]! } - public var WallpaperSearch_ColorWhite: String { return self._s[1697]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1698]! } - public var Conversation_ErrorInaccessibleMessage: String { return self._s[1699]! } - public var Map_OpenIn: String { return self._s[1700]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1697]! } + public var WallpaperSearch_ColorWhite: String { return self._s[1699]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1700]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[1701]! } + public var Map_OpenIn: String { return self._s[1702]! } public func PUSH_PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1703]!, self._r[1703]!, [_1]) + return formatWithArgumentRanges(self._s[1705]!, self._r[1705]!, [_1]) } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1704]!, self._r[1704]!, [_0]) + return formatWithArgumentRanges(self._s[1706]!, self._r[1706]!, [_0]) } - public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1705]! } - public var MessagePoll_LabelClosed: String { return self._s[1706]! } - public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1708]! } - public var Wallet_Send_SendAnyway: String { return self._s[1709]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1710]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1711]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1712]! } - public var Login_SelectCountry_Title: String { return self._s[1713]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1714]! } + public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1707]! } + public var MessagePoll_LabelClosed: String { return self._s[1708]! } + public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1710]! } + public var Wallet_Send_SendAnyway: String { return self._s[1711]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1712]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1713]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1714]! } + public var Login_SelectCountry_Title: String { return self._s[1715]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1716]! } public func Conversation_OpenBotLinkLogin(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1715]!, self._r[1715]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1717]!, self._r[1717]!, [_1, _2]) } - public var Channel_AdminLog_ChangeInfo: String { return self._s[1716]! } - public var Watch_Suggestion_BRB: String { return self._s[1717]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1718]! } - public var Contacts_PermissionsTitle: String { return self._s[1719]! } - public var Conversation_RestrictedInline: String { return self._s[1720]! } - public var StickerPack_ViewPack: String { return self._s[1722]! } - public var Wallet_UnknownError: String { return self._s[1723]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[1718]! } + public var Watch_Suggestion_BRB: String { return self._s[1719]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1720]! } + public var Contacts_PermissionsTitle: String { return self._s[1721]! } + public var Conversation_RestrictedInline: String { return self._s[1722]! } + public var StickerPack_ViewPack: String { return self._s[1724]! } + public var Wallet_UnknownError: String { return self._s[1725]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1724]!, self._r[1724]!, [_0]) + return formatWithArgumentRanges(self._s[1726]!, self._r[1726]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1726]! } - public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1729]! } - public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1731]! } - public var Channel_Info_Stickers: String { return self._s[1732]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1733]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1734]! } - public var Passport_DeletePersonalDetails: String { return self._s[1735]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[1736]! } - public var Channel_DiscussionGroupInfo: String { return self._s[1737]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1738]! } - public var Conversation_SearchNoResults: String { return self._s[1740]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1741]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1742]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1743]! } - public var Login_Code: String { return self._s[1744]! } - public var EditTheme_Create_BottomInfo: String { return self._s[1745]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1746]! } - public var Weekday_ShortThursday: String { return self._s[1747]! } - public var Resolve_ErrorNotFound: String { return self._s[1749]! } - public var LastSeen_Offline: String { return self._s[1750]! } - public var PeopleNearby_NoMembers: String { return self._s[1751]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[1752]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1753]! } - public var GroupInfo_Title: String { return self._s[1755]! } - public var NotificationsSound_Note: String { return self._s[1756]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1757]! } - public var Watch_Message_Poll: String { return self._s[1758]! } - public var Privacy_Calls: String { return self._s[1759]! } + public var Compose_NewChannel: String { return self._s[1728]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1731]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1733]! } + public var Channel_Info_Stickers: String { return self._s[1734]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1735]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1736]! } + public var Passport_DeletePersonalDetails: String { return self._s[1737]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1738]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1739]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1740]! } + public var Conversation_SearchNoResults: String { return self._s[1742]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1743]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1744]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1745]! } + public var Login_Code: String { return self._s[1746]! } + public var EditTheme_Create_BottomInfo: String { return self._s[1747]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1748]! } + public var Weekday_ShortThursday: String { return self._s[1749]! } + public var Resolve_ErrorNotFound: String { return self._s[1751]! } + public var LastSeen_Offline: String { return self._s[1752]! } + public var PeopleNearby_NoMembers: String { return self._s[1753]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1754]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1755]! } + public var GroupInfo_Title: String { return self._s[1757]! } + public var NotificationsSound_Note: String { return self._s[1758]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1759]! } + public var Watch_Message_Poll: String { return self._s[1760]! } + public var Privacy_Calls: String { return self._s[1761]! } public func Channel_AdminLog_MessageRankUsername(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1760]!, self._r[1760]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1762]!, self._r[1762]!, [_1, _2, _3]) } - public var Month_ShortAugust: String { return self._s[1761]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1762]! } - public var Notifications_Reset: String { return self._s[1763]! } - public var Conversation_Pin: String { return self._s[1764]! } - public var Passport_Language_lv: String { return self._s[1765]! } - public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1766]! } - public var BlockedUsers_Info: String { return self._s[1767]! } - public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1769]! } - public var Watch_Conversation_Unblock: String { return self._s[1771]! } + public var Month_ShortAugust: String { return self._s[1763]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1764]! } + public var Notifications_Reset: String { return self._s[1765]! } + public var Conversation_Pin: String { return self._s[1766]! } + public var Passport_Language_lv: String { return self._s[1767]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1768]! } + public var BlockedUsers_Info: String { return self._s[1769]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1771]! } + public var Watch_Conversation_Unblock: String { return self._s[1773]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1772]!, self._r[1772]!, [_0]) + return formatWithArgumentRanges(self._s[1774]!, self._r[1774]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1773]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1774]! } + public var CloudStorage_Title: String { return self._s[1775]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1776]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1775]!, self._r[1775]!, [_0]) + return formatWithArgumentRanges(self._s[1777]!, self._r[1777]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1776]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1777]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1778]! } - public var Passport_Address_EditBankStatement: String { return self._s[1779]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1778]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1779]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1780]! } + public var Passport_Address_EditBankStatement: String { return self._s[1781]! } public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1780]!, self._r[1780]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1782]!, self._r[1782]!, [_1, _2]) } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1781]! } - public var ShareMenu_Comment: String { return self._s[1782]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1783]! } - public var Notifications_PermissionsTitle: String { return self._s[1784]! } - public var GroupPermission_NoSendLinks: String { return self._s[1785]! } - public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1786]! } - public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1787]! } - public var Settings_Support: String { return self._s[1788]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1789]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1790]! } - public var Privacy_Forwards_Preview: String { return self._s[1791]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[1792]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1793]! } - public var Common_Select: String { return self._s[1795]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1796]! } - public var WallpaperSearch_ColorGray: String { return self._s[1799]! } - public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1800]! } - public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1801]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1802]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1803]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1804]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1805]! } - public var Widget_AuthRequired: String { return self._s[1806]! } - public var Camera_FlashOn: String { return self._s[1807]! } - public var Conversation_ContextMenuLookUp: String { return self._s[1808]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1809]! } - public var Watch_Suggestion_OK: String { return self._s[1810]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1783]! } + public var ShareMenu_Comment: String { return self._s[1784]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1785]! } + public var Notifications_PermissionsTitle: String { return self._s[1786]! } + public var GroupPermission_NoSendLinks: String { return self._s[1787]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1788]! } + public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1789]! } + public var Settings_Support: String { return self._s[1790]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1791]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1792]! } + public var Privacy_Forwards_Preview: String { return self._s[1793]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1794]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1795]! } + public var Common_Select: String { return self._s[1797]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1798]! } + public var WallpaperSearch_ColorGray: String { return self._s[1801]! } + public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1802]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1803]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1804]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1805]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1806]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1807]! } + public var Widget_AuthRequired: String { return self._s[1808]! } + public var Camera_FlashOn: String { return self._s[1809]! } + public var Conversation_ContextMenuLookUp: String { return self._s[1810]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1811]! } + public var Watch_Suggestion_OK: String { return self._s[1812]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1812]!, self._r[1812]!, [_0]) - } - public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1814]!, self._r[1814]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[1815]! } - public var DialogList_AdLabel: String { return self._s[1816]! } - public var WatchRemote_NotificationText: String { return self._s[1817]! } - public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1818]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1819]! } - public var Conversation_ReportSpam: String { return self._s[1820]! } - public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1821]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1823]! } - public var PhoneLabel_Title: String { return self._s[1824]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1825]! } - public var Settings_ChangePhoneNumber: String { return self._s[1826]! } - public var Notifications_ExceptionsTitle: String { return self._s[1827]! } - public var Notifications_AlertTones: String { return self._s[1828]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1829]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1830]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1831]! } - public var VoiceOver_Chat_Photo: String { return self._s[1833]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1834]! } - public var ReportPeer_ReasonOther: String { return self._s[1835]! } - public var ChatList_Context_JoinChannel: String { return self._s[1836]! } - public var KeyCommand_ScrollDown: String { return self._s[1838]! } - public var Conversation_ScheduleMessage_Title: String { return self._s[1839]! } + public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1816]!, self._r[1816]!, [_0]) + } + public var TextFormat_Strikethrough: String { return self._s[1817]! } + public var DialogList_AdLabel: String { return self._s[1818]! } + public var WatchRemote_NotificationText: String { return self._s[1819]! } + public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1820]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1821]! } + public var Conversation_ReportSpam: String { return self._s[1822]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1823]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1825]! } + public var PhoneLabel_Title: String { return self._s[1826]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1827]! } + public var Settings_ChangePhoneNumber: String { return self._s[1828]! } + public var Notifications_ExceptionsTitle: String { return self._s[1829]! } + public var Notifications_AlertTones: String { return self._s[1830]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1831]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1832]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1833]! } + public var VoiceOver_Chat_Photo: String { return self._s[1835]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1836]! } + public var ReportPeer_ReasonOther: String { return self._s[1837]! } + public var ChatList_Context_JoinChannel: String { return self._s[1838]! } + public var KeyCommand_ScrollDown: String { return self._s[1840]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[1841]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1840]!, self._r[1840]!, [_0]) + return formatWithArgumentRanges(self._s[1842]!, self._r[1842]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1841]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1842]! } - public var AuthSessions_LogOut: String { return self._s[1843]! } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1844]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1845]! } - public var Passport_Phone_Title: String { return self._s[1846]! } - public var ContactList_Context_StartSecretChat: String { return self._s[1847]! } - public var Settings_PhoneNumber: String { return self._s[1848]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1843]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1844]! } + public var AuthSessions_LogOut: String { return self._s[1845]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1846]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1847]! } + public var Passport_Phone_Title: String { return self._s[1848]! } + public var ContactList_Context_StartSecretChat: String { return self._s[1849]! } + public var Settings_PhoneNumber: String { return self._s[1850]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1849]!, self._r[1849]!, [_0]) + return formatWithArgumentRanges(self._s[1851]!, self._r[1851]!, [_0]) } - public var NotificationsSound_Alert: String { return self._s[1850]! } - public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1851]! } - public var WebSearch_SearchNoResults: String { return self._s[1852]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1854]! } - public var Wallet_Configuration_SourceInfo: String { return self._s[1855]! } - public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1856]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[1857]! } - public var PhotoEditor_CurvesTool: String { return self._s[1858]! } - public var Checkout_PaymentMethod: String { return self._s[1860]! } + public var NotificationsSound_Alert: String { return self._s[1852]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1853]! } + public var WebSearch_SearchNoResults: String { return self._s[1854]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1856]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[1857]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1858]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[1859]! } + public var PhotoEditor_CurvesTool: String { return self._s[1860]! } + public var Checkout_PaymentMethod: String { return self._s[1862]! } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1861]!, self._r[1861]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1863]!, self._r[1863]!, [_1, _2]) } - public var Contacts_AccessDeniedError: String { return self._s[1862]! } - public var Camera_PhotoMode: String { return self._s[1865]! } - public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1866]! } - public var Appearance_TextSize_Apply: String { return self._s[1867]! } - public var Passport_Address_AddUtilityBill: String { return self._s[1869]! } - public var CallSettings_OnMobile: String { return self._s[1870]! } - public var Tour_Text2: String { return self._s[1871]! } + public var Contacts_AccessDeniedError: String { return self._s[1864]! } + public var Camera_PhotoMode: String { return self._s[1867]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1868]! } + public var Appearance_TextSize_Apply: String { return self._s[1869]! } + public var Passport_Address_AddUtilityBill: String { return self._s[1871]! } + public var CallSettings_OnMobile: String { return self._s[1872]! } + public var Tour_Text2: String { return self._s[1873]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1872]!, self._r[1872]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1874]!, self._r[1874]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[1874]! } - public var Permissions_Skip: String { return self._s[1875]! } - public var Wallet_Words_NotDoneOk: String { return self._s[1876]! } - public var SecretImage_Title: String { return self._s[1877]! } - public var Watch_MessageView_Title: String { return self._s[1878]! } - public var Channel_DiscussionGroupAdd: String { return self._s[1879]! } - public var AttachmentMenu_Poll: String { return self._s[1880]! } + public var DialogList_EncryptionProcessing: String { return self._s[1876]! } + public var Permissions_Skip: String { return self._s[1877]! } + public var Wallet_Words_NotDoneOk: String { return self._s[1878]! } + public var SecretImage_Title: String { return self._s[1879]! } + public var Watch_MessageView_Title: String { return self._s[1880]! } + public var Channel_DiscussionGroupAdd: String { return self._s[1881]! } + public var AttachmentMenu_Poll: String { return self._s[1882]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1881]!, self._r[1881]!, [_0]) + return formatWithArgumentRanges(self._s[1883]!, self._r[1883]!, [_0]) } public func Channel_DiscussionGroup_PrivateChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1882]!, self._r[1882]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1884]!, self._r[1884]!, [_1, _2]) } - public var Notification_CallCanceled: String { return self._s[1883]! } - public var WallpaperPreview_Title: String { return self._s[1884]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1885]! } - public var Settings_ProxyConnecting: String { return self._s[1886]! } - public var Settings_CheckPhoneNumberText: String { return self._s[1888]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[1889]! } - public var Wallet_Intro_Title: String { return self._s[1890]! } - public var TwoFactorSetup_Password_Action: String { return self._s[1891]! } - public var Profile_MessageLifetime5s: String { return self._s[1892]! } - public var Username_InvalidCharacters: String { return self._s[1893]! } - public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1894]! } - public var ScheduledMessages_ClearAll: String { return self._s[1895]! } - public var WallpaperPreview_CropBottomText: String { return self._s[1896]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[1897]! } - public var Settings_AddAccount: String { return self._s[1898]! } - public var Notification_CreatedChannel: String { return self._s[1901]! } + public var Notification_CallCanceled: String { return self._s[1885]! } + public var WallpaperPreview_Title: String { return self._s[1886]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1887]! } + public var Settings_ProxyConnecting: String { return self._s[1888]! } + public var Settings_CheckPhoneNumberText: String { return self._s[1890]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[1891]! } + public var Wallet_Intro_Title: String { return self._s[1892]! } + public var TwoFactorSetup_Password_Action: String { return self._s[1893]! } + public var Profile_MessageLifetime5s: String { return self._s[1894]! } + public var Username_InvalidCharacters: String { return self._s[1895]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1896]! } + public var ScheduledMessages_ClearAll: String { return self._s[1897]! } + public var WallpaperPreview_CropBottomText: String { return self._s[1898]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[1899]! } + public var Settings_AddAccount: String { return self._s[1900]! } + public var Notification_CreatedChannel: String { return self._s[1903]! } public func PUSH_CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1902]!, self._r[1902]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1904]!, self._r[1904]!, [_1, _2, _3]) } - public var Passcode_AppLockedAlert: String { return self._s[1904]! } - public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1905]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[1906]! } - public var Contacts_TopSection: String { return self._s[1907]! } - public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1908]! } + public var Passcode_AppLockedAlert: String { return self._s[1906]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1907]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[1908]! } + public var Contacts_TopSection: String { return self._s[1909]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1910]! } public func Conversation_SetReminder_RemindOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1909]!, self._r[1909]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1911]!, self._r[1911]!, [_0, _1]) } - public var Wallet_Info_Receive: String { return self._s[1910]! } - public var Wallet_Completed_ViewWallet: String { return self._s[1911]! } + public var Wallet_Info_Receive: String { return self._s[1912]! } + public var Wallet_Completed_ViewWallet: String { return self._s[1913]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1912]!, self._r[1912]!, [_0]) + return formatWithArgumentRanges(self._s[1914]!, self._r[1914]!, [_0]) } - public var ReportPeer_ReasonSpam: String { return self._s[1913]! } - public var UserInfo_TapToCall: String { return self._s[1914]! } - public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1916]! } - public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1917]! } - public var Common_Search: String { return self._s[1918]! } - public var ScheduledMessages_EmptyPlaceholder: String { return self._s[1919]! } + public var ReportPeer_ReasonSpam: String { return self._s[1915]! } + public var UserInfo_TapToCall: String { return self._s[1916]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1918]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1919]! } + public var Common_Search: String { return self._s[1920]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[1921]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1920]!, self._r[1920]!, [_0]) + return formatWithArgumentRanges(self._s[1922]!, self._r[1922]!, [_0]) } - public var Wallet_Month_ShortJuly: String { return self._s[1921]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1923]! } - public var Message_InvoiceLabel: String { return self._s[1924]! } - public var Conversation_InputTextPlaceholder: String { return self._s[1925]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1926]! } + public var Wallet_Month_ShortJuly: String { return self._s[1923]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1925]! } + public var Message_InvoiceLabel: String { return self._s[1926]! } + public var Conversation_InputTextPlaceholder: String { return self._s[1927]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1928]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1927]!, self._r[1927]!, [_0]) + return formatWithArgumentRanges(self._s[1929]!, self._r[1929]!, [_0]) } - public var IntentsSettings_Reset: String { return self._s[1928]! } - public var Conversation_Info: String { return self._s[1929]! } - public var Login_InfoDeletePhoto: String { return self._s[1930]! } - public var Passport_Language_vi: String { return self._s[1932]! } - public var UserInfo_ScamUserWarning: String { return self._s[1933]! } - public var Conversation_Search: String { return self._s[1934]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1936]! } - public var ReportPeer_ReasonPornography: String { return self._s[1937]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[1938]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1939]! } - public var Map_LiveLocationGroupDescription: String { return self._s[1940]! } - public var Channel_Setup_TypeHeader: String { return self._s[1941]! } - public var AuthSessions_LoggedIn: String { return self._s[1942]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[1943]! } - public var Login_SmsRequestState3: String { return self._s[1944]! } - public var Passport_Address_EditUtilityBill: String { return self._s[1945]! } - public var Appearance_ReduceMotionInfo: String { return self._s[1946]! } - public var Join_ChannelsTooMuch: String { return self._s[1947]! } - public var Channel_Edit_LinkItem: String { return self._s[1948]! } - public var Privacy_Calls_P2PNever: String { return self._s[1949]! } - public var Conversation_AddToReadingList: String { return self._s[1951]! } - public var Share_MultipleMessagesDisabled: String { return self._s[1952]! } - public var Message_Animation: String { return self._s[1953]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[1954]! } - public var Map_Unknown: String { return self._s[1955]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[1956]! } + public var IntentsSettings_Reset: String { return self._s[1930]! } + public var Conversation_Info: String { return self._s[1931]! } + public var Login_InfoDeletePhoto: String { return self._s[1932]! } + public var Passport_Language_vi: String { return self._s[1934]! } + public var UserInfo_ScamUserWarning: String { return self._s[1935]! } + public var Conversation_Search: String { return self._s[1936]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1938]! } + public var ReportPeer_ReasonPornography: String { return self._s[1939]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[1940]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1941]! } + public var Map_LiveLocationGroupDescription: String { return self._s[1942]! } + public var Channel_Setup_TypeHeader: String { return self._s[1943]! } + public var AuthSessions_LoggedIn: String { return self._s[1944]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[1945]! } + public var Login_SmsRequestState3: String { return self._s[1946]! } + public var Passport_Address_EditUtilityBill: String { return self._s[1947]! } + public var Appearance_ReduceMotionInfo: String { return self._s[1948]! } + public var Join_ChannelsTooMuch: String { return self._s[1949]! } + public var Channel_Edit_LinkItem: String { return self._s[1950]! } + public var Privacy_Calls_P2PNever: String { return self._s[1951]! } + public var Conversation_AddToReadingList: String { return self._s[1953]! } + public var Share_MultipleMessagesDisabled: String { return self._s[1954]! } + public var Message_Animation: String { return self._s[1955]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[1956]! } + public var Map_Unknown: String { return self._s[1957]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[1958]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1957]!, self._r[1957]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1959]!, self._r[1959]!, [_1, _2]) } public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1958]!, self._r[1958]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1960]!, self._r[1960]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[1959]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[1960]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1961]! } + public var Call_StatusRequesting: String { return self._s[1961]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[1962]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1963]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1962]!, self._r[1962]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1964]!, self._r[1964]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1963]!, self._r[1963]!, [_0]) + return formatWithArgumentRanges(self._s[1965]!, self._r[1965]!, [_0]) } - public var Update_Skip: String { return self._s[1964]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1965]! } - public var Message_PinnedPollMessage: String { return self._s[1966]! } - public var BlockedUsers_Title: String { return self._s[1967]! } + public var Update_Skip: String { return self._s[1966]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1967]! } + public var Message_PinnedPollMessage: String { return self._s[1968]! } + public var BlockedUsers_Title: String { return self._s[1969]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1968]!, self._r[1968]!, [_1]) + return formatWithArgumentRanges(self._s[1970]!, self._r[1970]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[1969]! } - public var NotificationsSound_Bell: String { return self._s[1970]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[1971]! } - public var Weekday_Monday: String { return self._s[1972]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[1973]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1974]! } - public var ChatSettings_Groups: String { return self._s[1975]! } + public var Username_CheckingUsername: String { return self._s[1971]! } + public var NotificationsSound_Bell: String { return self._s[1972]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[1973]! } + public var Weekday_Monday: String { return self._s[1974]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[1975]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1976]! } + public var ChatSettings_Groups: String { return self._s[1977]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1976]!, self._r[1976]!, [_0]) + return formatWithArgumentRanges(self._s[1978]!, self._r[1978]!, [_0]) } - public var Your_card_was_declined: String { return self._s[1977]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1979]! } - public var Wallet_Month_ShortApril: String { return self._s[1980]! } - public var ChatList_Unmute: String { return self._s[1981]! } - public var PhotoEditor_CurvesAll: String { return self._s[1982]! } - public var Weekday_ShortTuesday: String { return self._s[1983]! } - public var DialogList_Read: String { return self._s[1984]! } - public var Appearance_AppIconClassic: String { return self._s[1985]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1986]! } - public var Passport_Identity_Gender: String { return self._s[1987]! } + public var Your_card_was_declined: String { return self._s[1979]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1981]! } + public var Wallet_Month_ShortApril: String { return self._s[1982]! } + public var ChatList_Unmute: String { return self._s[1983]! } + public var PhotoEditor_CurvesAll: String { return self._s[1984]! } + public var Weekday_ShortTuesday: String { return self._s[1985]! } + public var DialogList_Read: String { return self._s[1986]! } + public var Appearance_AppIconClassic: String { return self._s[1987]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1988]! } + public var Passport_Identity_Gender: String { return self._s[1989]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1988]!, self._r[1988]!, [_0]) + return formatWithArgumentRanges(self._s[1990]!, self._r[1990]!, [_0]) } - public var Target_SelectGroup: String { return self._s[1989]! } + public var Target_SelectGroup: String { return self._s[1991]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1991]!, self._r[1991]!, [_0]) + return formatWithArgumentRanges(self._s[1993]!, self._r[1993]!, [_0]) } - public var Passport_Language_en: String { return self._s[1992]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[1993]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1994]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[1995]! } - public var ScheduledMessages_SendNow: String { return self._s[1996]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[1998]! } - public var Login_InfoHelp: String { return self._s[1999]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2000]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2001]! } + public var Passport_Language_en: String { return self._s[1994]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[1995]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1996]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[1997]! } + public var ScheduledMessages_SendNow: String { return self._s[1998]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[2000]! } + public var Login_InfoHelp: String { return self._s[2001]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2002]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2003]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2002]!, self._r[2002]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2004]!, self._r[2004]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[2005]! } - public var CreatePoll_Title: String { return self._s[2006]! } - public var Conversation_ViewTheme: String { return self._s[2007]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2008]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2009]! } - public var TwoFactorSetup_Intro_Text: String { return self._s[2010]! } - public var UserInfo_GroupsInCommon: String { return self._s[2011]! } - public var TelegramWallet_Intro_TermsUrl: String { return self._s[2012]! } - public var Call_AudioRouteHide: String { return self._s[2013]! } + public var SocksProxySetup_AddProxy: String { return self._s[2007]! } + public var CreatePoll_Title: String { return self._s[2008]! } + public var Conversation_ViewTheme: String { return self._s[2009]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2010]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2011]! } + public var TwoFactorSetup_Intro_Text: String { return self._s[2012]! } + public var UserInfo_GroupsInCommon: String { return self._s[2013]! } + public var TelegramWallet_Intro_TermsUrl: String { return self._s[2014]! } + public var Call_AudioRouteHide: String { return self._s[2015]! } public func Wallet_Info_TransactionDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2015]!, self._r[2015]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2017]!, self._r[2017]!, [_1, _2]) } - public var ContactInfo_PhoneLabelMobile: String { return self._s[2016]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2017]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[2018]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2019]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2018]!, self._r[2018]!, [_0]) + return formatWithArgumentRanges(self._s[2020]!, self._r[2020]!, [_0]) } - public var TextFormat_Bold: String { return self._s[2019]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2020]! } - public var Notifications_Title: String { return self._s[2021]! } - public var Group_Username_InvalidTooShort: String { return self._s[2022]! } - public var Channel_ErrorAddTooMuch: String { return self._s[2023]! } + public var TextFormat_Bold: String { return self._s[2021]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2022]! } + public var Notifications_Title: String { return self._s[2023]! } + public var Group_Username_InvalidTooShort: String { return self._s[2024]! } + public var Channel_ErrorAddTooMuch: String { return self._s[2025]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2024]!, self._r[2024]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2026]!, self._r[2026]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[2026]! } - public var Stickers_SuggestAdded: String { return self._s[2027]! } - public var Login_CountryCode: String { return self._s[2028]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[2029]! } - public var Map_GetDirections: String { return self._s[2030]! } - public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2031]! } - public var Login_PhoneFloodError: String { return self._s[2032]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[2028]! } + public var Stickers_SuggestAdded: String { return self._s[2029]! } + public var Login_CountryCode: String { return self._s[2030]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[2031]! } + public var Map_GetDirections: String { return self._s[2032]! } + public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2033]! } + public var Login_PhoneFloodError: String { return self._s[2034]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2033]!, self._r[2033]!, [_0]) + return formatWithArgumentRanges(self._s[2035]!, self._r[2035]!, [_0]) } public func Wallet_Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2034]!, self._r[2034]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2036]!, self._r[2036]!, [_1, _2, _3]) } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2035]! } - public var Settings_SetUsername: String { return self._s[2037]! } - public var Group_Location_ChangeLocation: String { return self._s[2038]! } - public var Notification_GroupInviterSelf: String { return self._s[2039]! } - public var InstantPage_TapToOpenLink: String { return self._s[2040]! } + public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2037]! } + public var Settings_SetUsername: String { return self._s[2039]! } + public var Group_Location_ChangeLocation: String { return self._s[2040]! } + public var Notification_GroupInviterSelf: String { return self._s[2041]! } + public var InstantPage_TapToOpenLink: String { return self._s[2042]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2041]!, self._r[2041]!, [_0]) + return formatWithArgumentRanges(self._s[2043]!, self._r[2043]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[2042]! } - public var SecretChat_Title: String { return self._s[2043]! } - public var Group_UpgradeNoticeText1: String { return self._s[2044]! } - public var AuthSessions_Title: String { return self._s[2045]! } + public var Watch_Suggestion_TalkLater: String { return self._s[2044]! } + public var SecretChat_Title: String { return self._s[2045]! } + public var Group_UpgradeNoticeText1: String { return self._s[2046]! } + public var AuthSessions_Title: String { return self._s[2047]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2046]!, self._r[2046]!, [_0]) + return formatWithArgumentRanges(self._s[2048]!, self._r[2048]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[2047]! } - public var Channel_About_Title: String { return self._s[2048]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[2049]! } + public var PhotoEditor_CropAuto: String { return self._s[2049]! } + public var Channel_About_Title: String { return self._s[2050]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[2051]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2051]!, self._r[2051]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2053]!, self._r[2053]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[2052]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2054]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[2055]! } + public var VoiceOver_MessageContextReport: String { return self._s[2054]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2056]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[2057]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2056]!, self._r[2056]!, [_1]) + return formatWithArgumentRanges(self._s[2058]!, self._r[2058]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2058]!, self._r[2058]!, [_0]) + return formatWithArgumentRanges(self._s[2060]!, self._r[2060]!, [_0]) } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2059]!, self._r[2059]!, [_0]) + return formatWithArgumentRanges(self._s[2061]!, self._r[2061]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2060]! } - public var Presence_online: String { return self._s[2063]! } - public var PasscodeSettings_Title: String { return self._s[2064]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2065]! } - public var Web_OpenExternal: String { return self._s[2066]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[2068]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2069]! } - public var LocalGroup_Title: String { return self._s[2070]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2062]! } + public var Presence_online: String { return self._s[2065]! } + public var PasscodeSettings_Title: String { return self._s[2066]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2067]! } + public var Web_OpenExternal: String { return self._s[2068]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[2070]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2071]! } + public var LocalGroup_Title: String { return self._s[2072]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2071]!, self._r[2071]!, [_0]) + return formatWithArgumentRanges(self._s[2073]!, self._r[2073]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2072]! } - public var Map_YouAreHere: String { return self._s[2073]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2074]! } + public var Map_YouAreHere: String { return self._s[2075]! } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2074]!, self._r[2074]!, [_0]) + return formatWithArgumentRanges(self._s[2076]!, self._r[2076]!, [_0]) } public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2075]!, self._r[2075]!, [_0]) + return formatWithArgumentRanges(self._s[2077]!, self._r[2077]!, [_0]) } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2076]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2077]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2078]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2079]! } public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2078]!, self._r[2078]!, [_0]) + return formatWithArgumentRanges(self._s[2080]!, self._r[2080]!, [_0]) } public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2079]!, self._r[2079]!, [_0]) + return formatWithArgumentRanges(self._s[2081]!, self._r[2081]!, [_0]) } - public var SocksProxySetup_Username: String { return self._s[2080]! } - public var Bot_Start: String { return self._s[2081]! } + public var SocksProxySetup_Username: String { return self._s[2082]! } + public var Bot_Start: String { return self._s[2083]! } public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2082]!, self._r[2082]!, [_0]) + return formatWithArgumentRanges(self._s[2084]!, self._r[2084]!, [_0]) } public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2083]!, self._r[2083]!, [_0]) + return formatWithArgumentRanges(self._s[2085]!, self._r[2085]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[2084]! } - public var AccentColor_Title: String { return self._s[2086]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2087]! } + public var Contacts_SortByPresence: String { return self._s[2086]! } + public var AccentColor_Title: String { return self._s[2088]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2089]! } public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2088]!, self._r[2088]!, [_1, _2]) - } - public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2089]!, self._r[2089]!, [_0]) - } - public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2090]!, self._r[2090]!, [_1, _2]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[2091]! } - public var Login_InfoAvatarPhoto: String { return self._s[2092]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2093]! } - public var Tour_Title4: String { return self._s[2094]! } - public var Passport_Identity_Translation: String { return self._s[2095]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2096]! } - public var Login_TermsOfServiceLabel: String { return self._s[2098]! } - public var Passport_Language_it: String { return self._s[2099]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2100]! } - public var Passport_Identity_SelfieHelp: String { return self._s[2101]! } - public var Conversation_ClearAll: String { return self._s[2103]! } - public var Wallet_Send_UninitializedText: String { return self._s[2105]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[2106]! } - public var TwoStepAuth_FloodError: String { return self._s[2107]! } + public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2091]!, self._r[2091]!, [_0]) + } + public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2092]!, self._r[2092]!, [_1, _2]) + } + public var Passport_Email_EnterOtherEmail: String { return self._s[2093]! } + public var Login_InfoAvatarPhoto: String { return self._s[2094]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2095]! } + public var Tour_Title4: String { return self._s[2096]! } + public var Passport_Identity_Translation: String { return self._s[2097]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2098]! } + public var Login_TermsOfServiceLabel: String { return self._s[2100]! } + public var Passport_Language_it: String { return self._s[2101]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2102]! } + public var Passport_Identity_SelfieHelp: String { return self._s[2103]! } + public var Conversation_ClearAll: String { return self._s[2105]! } + public var Wallet_Send_UninitializedText: String { return self._s[2107]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[2108]! } + public var TwoStepAuth_FloodError: String { return self._s[2109]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2108]!, self._r[2108]!, [_1]) + return formatWithArgumentRanges(self._s[2110]!, self._r[2110]!, [_1]) } - public var Paint_Delete: String { return self._s[2109]! } + public var Paint_Delete: String { return self._s[2111]! } public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2110]!, self._r[2110]!, [_0]) + return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, [_0]) } - public var Privacy_AddNewPeer: String { return self._s[2111]! } + public var Privacy_AddNewPeer: String { return self._s[2113]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, [_1]) + return formatWithArgumentRanges(self._s[2114]!, self._r[2114]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2113]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[2115]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2114]!, self._r[2114]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2116]!, self._r[2116]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2115]! } + public var Message_PinnedAudioMessage: String { return self._s[2117]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2116]!, self._r[2116]!, [_0]) + return formatWithArgumentRanges(self._s[2118]!, self._r[2118]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[2117]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2118]! } - public var Wallet_Month_GenNovember: String { return self._s[2119]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[2120]! } - public var Conversation_MessageEditedLabel: String { return self._s[2121]! } + public var Notification_Mute1hMin: String { return self._s[2119]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2120]! } + public var Wallet_Month_GenNovember: String { return self._s[2121]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[2122]! } + public var Conversation_MessageEditedLabel: String { return self._s[2123]! } public func ClearCache_Success(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2122]!, self._r[2122]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2124]!, self._r[2124]!, [_0, _1]) } - public var Notification_Exceptions_AlwaysOff: String { return self._s[2123]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2124]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[2125]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2126]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2125]!, self._r[2125]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2127]!, self._r[2127]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2126]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2128]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2127]!, self._r[2127]!, [_1]) + return formatWithArgumentRanges(self._s[2129]!, self._r[2129]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[2128]! } - public var Month_GenOctober: String { return self._s[2129]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2130]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2131]! } - public var MediaPicker_TimerTooltip: String { return self._s[2133]! } - public var SharedMedia_TitleAll: String { return self._s[2134]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2137]! } - public var Conversation_RestrictedMedia: String { return self._s[2138]! } - public var AccessDenied_PhotosRestricted: String { return self._s[2139]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2141]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2142]! } + public var AccessDenied_LocationTracking: String { return self._s[2130]! } + public var Month_GenOctober: String { return self._s[2131]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2132]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2133]! } + public var MediaPicker_TimerTooltip: String { return self._s[2135]! } + public var SharedMedia_TitleAll: String { return self._s[2136]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2139]! } + public var Conversation_RestrictedMedia: String { return self._s[2140]! } + public var AccessDenied_PhotosRestricted: String { return self._s[2141]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2143]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2144]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2143]!, self._r[2143]!, [_0]) + return formatWithArgumentRanges(self._s[2145]!, self._r[2145]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[2146]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2148]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2149]! } + public var Conversation_SavedMessages: String { return self._s[2148]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2150]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2151]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2151]!, self._r[2151]!, [_0]) - } - public var VoiceOver_Chat_YourMessage: String { return self._s[2152]! } - public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2153]!, self._r[2153]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[2154]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2155]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2154]! } + public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2155]!, self._r[2155]!, [_0]) + } + public var ReportPeer_AlertSuccess: String { return self._s[2156]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2157]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2156]!, self._r[2156]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2158]!, self._r[2158]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[2157]! } - public var PhotoEditor_FadeTool: String { return self._s[2158]! } - public var Privacy_ContactsReset: String { return self._s[2159]! } + public var Checkout_PasswordEntry_Title: String { return self._s[2159]! } + public var PhotoEditor_FadeTool: String { return self._s[2160]! } + public var Privacy_ContactsReset: String { return self._s[2161]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2161]!, self._r[2161]!, [_0]) + return formatWithArgumentRanges(self._s[2163]!, self._r[2163]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[2162]! } - public var ChatList_Mute: String { return self._s[2163]! } + public var Message_PinnedVideoMessage: String { return self._s[2164]! } + public var ChatList_Mute: String { return self._s[2165]! } public func Wallet_Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2164]!, self._r[2164]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2166]!, self._r[2166]!, [_1, _2, _3]) } - public var Permissions_CellularDataText_v0: String { return self._s[2165]! } - public var ShareMenu_SelectChats: String { return self._s[2168]! } - public var ChatList_Context_Unarchive: String { return self._s[2169]! } - public var MusicPlayer_VoiceNote: String { return self._s[2170]! } - public var Conversation_RestrictedText: String { return self._s[2171]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2172]! } - public var Wallet_Month_GenApril: String { return self._s[2173]! } - public var Wallet_Month_ShortMarch: String { return self._s[2174]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2175]! } - public var Cache_Videos: String { return self._s[2176]! } - public var PrivacySettings_PhoneNumber: String { return self._s[2177]! } - public var Wallet_Month_GenFebruary: String { return self._s[2178]! } - public var FeatureDisabled_Oops: String { return self._s[2180]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[2181]! } + public var Permissions_CellularDataText_v0: String { return self._s[2167]! } + public var ShareMenu_SelectChats: String { return self._s[2170]! } + public var ChatList_Context_Unarchive: String { return self._s[2171]! } + public var MusicPlayer_VoiceNote: String { return self._s[2172]! } + public var Conversation_RestrictedText: String { return self._s[2173]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2174]! } + public var Wallet_Month_GenApril: String { return self._s[2175]! } + public var Wallet_Month_ShortMarch: String { return self._s[2176]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2177]! } + public var Cache_Videos: String { return self._s[2178]! } + public var PrivacySettings_PhoneNumber: String { return self._s[2179]! } + public var Wallet_Month_GenFebruary: String { return self._s[2180]! } + public var FeatureDisabled_Oops: String { return self._s[2182]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[2183]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2182]!, self._r[2182]!, [_0]) + return formatWithArgumentRanges(self._s[2184]!, self._r[2184]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[2183]! } - public var GroupPermission_NoSendPolls: String { return self._s[2184]! } - public var Wallet_Qr_ScanCode: String { return self._s[2185]! } - public var Message_VideoExpired: String { return self._s[2187]! } - public var Notifications_Badge: String { return self._s[2188]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2189]! } - public var Wallet_Receive_AddressCopied: String { return self._s[2190]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[2191]! } - public var Username_InvalidTooShort: String { return self._s[2192]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2193]! } - public var Channel_AdminLog_PinMessages: String { return self._s[2194]! } - public var ArchivedChats_IntroTitle3: String { return self._s[2195]! } + public var Stickers_GroupStickersHelp: String { return self._s[2185]! } + public var GroupPermission_NoSendPolls: String { return self._s[2186]! } + public var Wallet_Qr_ScanCode: String { return self._s[2187]! } + public var Message_VideoExpired: String { return self._s[2189]! } + public var Notifications_Badge: String { return self._s[2190]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2191]! } + public var Wallet_Receive_AddressCopied: String { return self._s[2192]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[2193]! } + public var Username_InvalidTooShort: String { return self._s[2194]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2195]! } + public var Channel_AdminLog_PinMessages: String { return self._s[2196]! } + public var ArchivedChats_IntroTitle3: String { return self._s[2197]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2196]!, self._r[2196]!, [_1]) + return formatWithArgumentRanges(self._s[2198]!, self._r[2198]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[2197]! } - public var Conversation_DefaultRestrictedText: String { return self._s[2198]! } - public var SharedMedia_CategoryDocs: String { return self._s[2201]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[2199]! } + public var Conversation_DefaultRestrictedText: String { return self._s[2200]! } + public var SharedMedia_CategoryDocs: String { return self._s[2203]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2202]!, self._r[2202]!, [_1]) + return formatWithArgumentRanges(self._s[2204]!, self._r[2204]!, [_1]) } - public var Wallet_Send_UninitializedTitle: String { return self._s[2203]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2205]! } + public var Wallet_Send_UninitializedTitle: String { return self._s[2205]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2207]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2206]!, self._r[2206]!, [_1]) + return formatWithArgumentRanges(self._s[2208]!, self._r[2208]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2207]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2209]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2208]!, self._r[2208]!, [_0]) + return formatWithArgumentRanges(self._s[2210]!, self._r[2210]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[2209]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2210]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[2211]! } - public var Channel_UpdatePhotoItem: String { return self._s[2212]! } - public var GroupInfo_LeftStatus: String { return self._s[2213]! } - public var Watch_MessageView_Forward: String { return self._s[2215]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[2216]! } - public var Cache_ClearEmpty: String { return self._s[2218]! } - public var Localization_LanguageName: String { return self._s[2219]! } - public var Wallet_AccessDenied_Title: String { return self._s[2220]! } - public var WebSearch_GIFs: String { return self._s[2221]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2222]! } - public var Wallet_AccessDenied_Settings: String { return self._s[2223]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2224]! } - public var Common_Back: String { return self._s[2225]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2226]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2227]! } - public var Wallet_Send_Send: String { return self._s[2228]! } + public var ChatSettings_PrivateChats: String { return self._s[2211]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2212]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[2213]! } + public var Channel_UpdatePhotoItem: String { return self._s[2214]! } + public var GroupInfo_LeftStatus: String { return self._s[2215]! } + public var Watch_MessageView_Forward: String { return self._s[2217]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[2218]! } + public var Cache_ClearEmpty: String { return self._s[2220]! } + public var Localization_LanguageName: String { return self._s[2221]! } + public var Wallet_AccessDenied_Title: String { return self._s[2222]! } + public var WebSearch_GIFs: String { return self._s[2223]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2224]! } + public var Wallet_AccessDenied_Settings: String { return self._s[2225]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2226]! } + public var Common_Back: String { return self._s[2227]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2228]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2229]! } + public var Wallet_Send_Send: String { return self._s[2230]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2229]!, self._r[2229]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2231]!, self._r[2231]!, [_1, _2]) } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[2230]! } - public var Wallet_Month_GenJune: String { return self._s[2231]! } - public var Passport_Email_Help: String { return self._s[2232]! } - public var Watch_Conversation_Reply: String { return self._s[2234]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2237]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2238]! } - public var Channel_BanUser_Unban: String { return self._s[2240]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2241]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2242]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2244]! } - public var Wallet_Send_AddressHeader: String { return self._s[2245]! } - public var Passport_Identity_Name: String { return self._s[2246]! } + public var Wallet_Info_RefreshErrorTitle: String { return self._s[2232]! } + public var Wallet_Month_GenJune: String { return self._s[2233]! } + public var Passport_Email_Help: String { return self._s[2234]! } + public var Watch_Conversation_Reply: String { return self._s[2236]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2239]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2240]! } + public var Channel_BanUser_Unban: String { return self._s[2242]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2243]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2244]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2246]! } + public var Wallet_Send_AddressHeader: String { return self._s[2247]! } + public var Passport_Identity_Name: String { return self._s[2248]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2247]!, self._r[2247]!, [_0]) + return formatWithArgumentRanges(self._s[2249]!, self._r[2249]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2248]! } - public var Conversation_BlockUser: String { return self._s[2249]! } - public var Month_GenJanuary: String { return self._s[2250]! } - public var ChatSettings_TextSize: String { return self._s[2251]! } - public var Notification_PassportValuePhone: String { return self._s[2252]! } - public var Passport_Language_ne: String { return self._s[2253]! } - public var Notification_CallBack: String { return self._s[2254]! } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2255]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2256]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[2250]! } + public var Conversation_BlockUser: String { return self._s[2251]! } + public var Month_GenJanuary: String { return self._s[2252]! } + public var ChatSettings_TextSize: String { return self._s[2253]! } + public var Notification_PassportValuePhone: String { return self._s[2254]! } + public var Passport_Language_ne: String { return self._s[2255]! } + public var Notification_CallBack: String { return self._s[2256]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2257]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2258]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2257]!, self._r[2257]!, [_0]) + return formatWithArgumentRanges(self._s[2259]!, self._r[2259]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2258]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2259]! } - public var Stickers_FrequentlyUsed: String { return self._s[2260]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2261]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2263]! } + public var Channel_Info_Management: String { return self._s[2260]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2261]! } + public var Stickers_FrequentlyUsed: String { return self._s[2262]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2263]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2265]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2264]!, self._r[2264]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2266]!, self._r[2266]!, [_1, "\(_2)"]) } - public var TwoFactorSetup_Password_Title: String { return self._s[2265]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[2266]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2267]! } - public var CreatePoll_TextHeader: String { return self._s[2268]! } + public var TwoFactorSetup_Password_Title: String { return self._s[2267]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2268]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2269]! } + public var CreatePoll_TextHeader: String { return self._s[2270]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2269]!, self._r[2269]!, [_0]) + return formatWithArgumentRanges(self._s[2271]!, self._r[2271]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[2270]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2271]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2273]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2274]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2275]! } + public var PhotoEditor_QualityMedium: String { return self._s[2272]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2273]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2275]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2276]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2277]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2276]!, self._r[2276]!, [_0]) + return formatWithArgumentRanges(self._s[2278]!, self._r[2278]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2277]!, self._r[2277]!, [_1]) + return formatWithArgumentRanges(self._s[2279]!, self._r[2279]!, [_1]) } - public var LogoutOptions_LogOutWalletInfo: String { return self._s[2278]! } - public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2279]! } - public var Conversation_LinkDialogOpen: String { return self._s[2281]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2282]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2283]! } - public var Settings_Username: String { return self._s[2285]! } - public var Conversation_Block: String { return self._s[2287]! } - public var Wallpaper_Wallpaper: String { return self._s[2288]! } - public var SocksProxySetup_UseProxy: String { return self._s[2290]! } - public var Wallet_Send_Confirmation: String { return self._s[2291]! } - public var EditTheme_UploadEditedTheme: String { return self._s[2292]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2293]! } - public var MessageTimer_Forever: String { return self._s[2294]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2295]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2296]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2297]! } - public var Passport_Language_da: String { return self._s[2298]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2299]! } + public var LogoutOptions_LogOutWalletInfo: String { return self._s[2280]! } + public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2281]! } + public var Conversation_LinkDialogOpen: String { return self._s[2283]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2284]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2285]! } + public var Settings_Username: String { return self._s[2287]! } + public var Conversation_Block: String { return self._s[2289]! } + public var Wallpaper_Wallpaper: String { return self._s[2290]! } + public var SocksProxySetup_UseProxy: String { return self._s[2292]! } + public var Wallet_Send_Confirmation: String { return self._s[2293]! } + public var EditTheme_UploadEditedTheme: String { return self._s[2294]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2295]! } + public var MessageTimer_Forever: String { return self._s[2296]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2297]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2298]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2299]! } + public var Passport_Language_da: String { return self._s[2300]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2301]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2300]!, self._r[2300]!, [_0]) + return formatWithArgumentRanges(self._s[2302]!, self._r[2302]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2301]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2303]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2303]!, self._r[2303]!, [_0]) + return formatWithArgumentRanges(self._s[2305]!, self._r[2305]!, [_0]) } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2305]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2306]! } - public var Conversation_PinnedPoll: String { return self._s[2307]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2308]! } + public var Settings_AddDevice: String { return self._s[2306]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2308]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2309]! } + public var Conversation_PinnedPoll: String { return self._s[2310]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2311]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2309]!, self._r[2309]!, [_1]) + return formatWithArgumentRanges(self._s[2312]!, self._r[2312]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2310]! } - public var Cache_ByPeerHeader: String { return self._s[2311]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2313]! } + public var Cache_ByPeerHeader: String { return self._s[2314]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2312]!, self._r[2312]!, [_0]) + return formatWithArgumentRanges(self._s[2315]!, self._r[2315]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2313]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2316]! } - public var Wallet_Completed_Title: String { return self._s[2317]! } - public var Notification_PinnedMessage: String { return self._s[2318]! } - public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2319]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2321]! } - public var Contacts_SortBy: String { return self._s[2322]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2316]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2319]! } + public var Wallet_Completed_Title: String { return self._s[2320]! } + public var Notification_PinnedMessage: String { return self._s[2321]! } + public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2322]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2324]! } + public var Contacts_SortBy: String { return self._s[2325]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2323]!, self._r[2323]!, [_1]) + return formatWithArgumentRanges(self._s[2326]!, self._r[2326]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2325]! } + public var Appearance_ColorThemeNight: String { return self._s[2328]! } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2326]!, self._r[2326]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2329]!, self._r[2329]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2327]! } - public var Watch_UserInfo_Service: String { return self._s[2328]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2330]! } - public var Conversation_Unpin: String { return self._s[2332]! } - public var CancelResetAccount_Title: String { return self._s[2333]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2334]! } + public var Call_EncryptionKey_Title: String { return self._s[2330]! } + public var Watch_UserInfo_Service: String { return self._s[2331]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2333]! } + public var Conversation_Unpin: String { return self._s[2335]! } + public var CancelResetAccount_Title: String { return self._s[2336]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2337]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2336]!, self._r[2336]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2339]!, self._r[2339]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2337]! } - public var CallSettings_Title: String { return self._s[2338]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2339]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2341]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2342]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2340]! } + public var CallSettings_Title: String { return self._s[2341]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2342]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2344]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2345]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2343]!, self._r[2343]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2346]!, self._r[2346]!, [_1, _2]) } - public var Passport_Identity_DocumentDetails: String { return self._s[2344]! } - public var LoginPassword_PasswordHelp: String { return self._s[2345]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2346]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2347]! } - public var Checkout_TotalPaidAmount: String { return self._s[2348]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2347]! } + public var LoginPassword_PasswordHelp: String { return self._s[2348]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2349]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2350]! } + public var Checkout_TotalPaidAmount: String { return self._s[2351]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2349]!, self._r[2349]!, [_0]) + return formatWithArgumentRanges(self._s[2352]!, self._r[2352]!, [_0]) } - public var PasscodeSettings_ChangePasscode: String { return self._s[2350]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2352]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2353]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2353]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2355]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2356]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2354]!, self._r[2354]!, [_1]) + return formatWithArgumentRanges(self._s[2357]!, self._r[2357]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2355]! } - public var Contacts_InviteFriends: String { return self._s[2357]! } - public var Map_ChooseLocationTitle: String { return self._s[2358]! } - public var Conversation_StopPoll: String { return self._s[2360]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2358]! } + public var Contacts_InviteFriends: String { return self._s[2360]! } + public var Map_ChooseLocationTitle: String { return self._s[2361]! } + public var Conversation_StopPoll: String { return self._s[2363]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2361]!, self._r[2361]!, [_0]) + return formatWithArgumentRanges(self._s[2364]!, self._r[2364]!, [_0]) } - public var Call_Camera: String { return self._s[2362]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2363]! } - public var AppWallet_Intro_Text: String { return self._s[2364]! } - public var Calls_RatingFeedback: String { return self._s[2365]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2366]! } - public var Wallet_Alert_OK: String { return self._s[2367]! } - public var NotificationsSound_Pulse: String { return self._s[2368]! } - public var Watch_LastSeen_Lately: String { return self._s[2369]! } - public var ReportGroupLocation_Report: String { return self._s[2372]! } - public var Widget_NoUsers: String { return self._s[2373]! } - public var Conversation_UnvotePoll: String { return self._s[2374]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2376]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2377]! } - public var NotificationsSound_Circles: String { return self._s[2378]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2381]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2382]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2383]! } - public var Proxy_TooltipUnavailable: String { return self._s[2384]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2386]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2388]! } - public var Conversation_FileDropbox: String { return self._s[2389]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2390]! } - public var Tour_Text3: String { return self._s[2392]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2394]! } - public var GroupPermission_NoSendMessages: String { return self._s[2395]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2396]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2397]! } + public var Call_Camera: String { return self._s[2365]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2366]! } + public var AppWallet_Intro_Text: String { return self._s[2367]! } + public var Calls_RatingFeedback: String { return self._s[2368]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2369]! } + public var Wallet_Alert_OK: String { return self._s[2370]! } + public var NotificationsSound_Pulse: String { return self._s[2371]! } + public var Watch_LastSeen_Lately: String { return self._s[2372]! } + public var ReportGroupLocation_Report: String { return self._s[2375]! } + public var Widget_NoUsers: String { return self._s[2376]! } + public var Conversation_UnvotePoll: String { return self._s[2377]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2379]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2380]! } + public var NotificationsSound_Circles: String { return self._s[2381]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2384]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2385]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2386]! } + public var Proxy_TooltipUnavailable: String { return self._s[2387]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2389]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2391]! } + public var Conversation_FileDropbox: String { return self._s[2392]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2393]! } + public var Tour_Text3: String { return self._s[2395]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2397]! } + public var GroupPermission_NoSendMessages: String { return self._s[2398]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2399]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2400]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2399]!, self._r[2399]!, [_0]) + return formatWithArgumentRanges(self._s[2402]!, self._r[2402]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2400]! } - public var Checkout_ShippingOption_Title: String { return self._s[2401]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2402]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2403]! } + public var Checkout_ShippingOption_Title: String { return self._s[2404]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2405]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2403]!, self._r[2403]!, [_0]) + return formatWithArgumentRanges(self._s[2406]!, self._r[2406]!, [_0]) } public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2404]!, self._r[2404]!, [_0]) + return formatWithArgumentRanges(self._s[2407]!, self._r[2407]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2405]! } - public var EditTheme_FileReadError: String { return self._s[2406]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2407]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2408]! } - public var AutoDownloadSettings_Photos: String { return self._s[2410]! } - public var Appearance_PreviewIncomingText: String { return self._s[2411]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2412]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2413]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2414]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2415]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2416]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2417]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2418]! } - public var Notification_SecretChatScreenshot: String { return self._s[2419]! } - public var AccessDenied_Wallpapers: String { return self._s[2420]! } - public var ChatList_Context_Mute: String { return self._s[2422]! } - public var Passport_Address_City: String { return self._s[2423]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2424]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2425]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2426]! } - public var AccessDenied_LocationDisabled: String { return self._s[2427]! } - public var Group_Location_Title: String { return self._s[2428]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2430]! } - public var GroupInfo_Sound: String { return self._s[2431]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2432]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2433]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2434]! } - public var Contacts_Title: String { return self._s[2435]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2436]! } - public var Passport_Language_fr: String { return self._s[2437]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2438]! } - public var Notifications_ResetAllNotifications: String { return self._s[2439]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2441]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2443]! } - public var Checkout_NewCard_Title: String { return self._s[2444]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2445]! } - public var Conversation_ForwardChats: String { return self._s[2446]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2448]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2449]! } - public var Settings_FAQ: String { return self._s[2451]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2452]! } - public var Conversation_ContextMenuForward: String { return self._s[2453]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2456]! } - public var PrivacyPolicy_Title: String { return self._s[2459]! } - public var Notifications_TextTone: String { return self._s[2460]! } - public var Profile_CreateNewContact: String { return self._s[2461]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2462]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2464]! } - public var Call_Speaker: String { return self._s[2465]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2466]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2468]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2469]! } + public var Channel_Management_LabelAdministrator: String { return self._s[2408]! } + public var EditTheme_FileReadError: String { return self._s[2409]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2410]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2411]! } + public var AutoDownloadSettings_Photos: String { return self._s[2413]! } + public var Appearance_PreviewIncomingText: String { return self._s[2414]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2415]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2416]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2417]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2418]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2419]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2420]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2421]! } + public var Notification_SecretChatScreenshot: String { return self._s[2422]! } + public var AccessDenied_Wallpapers: String { return self._s[2423]! } + public var ChatList_Context_Mute: String { return self._s[2425]! } + public var Passport_Address_City: String { return self._s[2426]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2427]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2428]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2429]! } + public var AccessDenied_LocationDisabled: String { return self._s[2430]! } + public var Group_Location_Title: String { return self._s[2431]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2433]! } + public var GroupInfo_Sound: String { return self._s[2434]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2435]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2436]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2437]! } + public var Contacts_Title: String { return self._s[2438]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2439]! } + public var Passport_Language_fr: String { return self._s[2440]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2441]! } + public var Notifications_ResetAllNotifications: String { return self._s[2442]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2444]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2446]! } + public var Checkout_NewCard_Title: String { return self._s[2447]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2448]! } + public var Conversation_ForwardChats: String { return self._s[2449]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2451]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2452]! } + public var Settings_FAQ: String { return self._s[2454]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2455]! } + public var Conversation_ContextMenuForward: String { return self._s[2456]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2459]! } + public var PrivacyPolicy_Title: String { return self._s[2462]! } + public var Notifications_TextTone: String { return self._s[2463]! } + public var Profile_CreateNewContact: String { return self._s[2464]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2465]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2467]! } + public var Call_Speaker: String { return self._s[2468]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2469]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2471]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2472]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2470]!, self._r[2470]!, [_0]) + return formatWithArgumentRanges(self._s[2473]!, self._r[2473]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2471]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2472]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2473]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2474]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2475]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2476]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2477]! } - public var Bot_Unblock: String { return self._s[2478]! } - public var TextFormat_Italic: String { return self._s[2479]! } - public var WallpaperSearch_ColorPink: String { return self._s[2480]! } - public var Settings_About_Help: String { return self._s[2481]! } - public var SearchImages_Title: String { return self._s[2482]! } - public var Weekday_Wednesday: String { return self._s[2483]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2484]! } - public var ExplicitContent_AlertTitle: String { return self._s[2485]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2474]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2475]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2476]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2477]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2478]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2479]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2480]! } + public var Bot_Unblock: String { return self._s[2481]! } + public var TextFormat_Italic: String { return self._s[2482]! } + public var WallpaperSearch_ColorPink: String { return self._s[2483]! } + public var Settings_About_Help: String { return self._s[2484]! } + public var SearchImages_Title: String { return self._s[2485]! } + public var Weekday_Wednesday: String { return self._s[2486]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2487]! } + public var ExplicitContent_AlertTitle: String { return self._s[2488]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2486]!, self._r[2486]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2489]!, self._r[2489]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2487]! } - public var Weekday_Thursday: String { return self._s[2488]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2489]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2490]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2490]! } + public var Weekday_Thursday: String { return self._s[2491]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2492]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2493]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2491]!, self._r[2491]!, [_0]) + return formatWithArgumentRanges(self._s[2494]!, self._r[2494]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2492]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2493]! } - public var Passport_RequestedInformation: String { return self._s[2494]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2495]! } - public var Conversation_EncryptionProcessing: String { return self._s[2497]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2498]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2500]! } - public var Channel_Setup_Title: String { return self._s[2501]! } - public var Conversation_SearchPlaceholder: String { return self._s[2502]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2503]! } - public var Checkout_ErrorGeneric: String { return self._s[2504]! } - public var Passport_Language_hu: String { return self._s[2505]! } - public var GroupPermission_EditingDisabled: String { return self._s[2506]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2508]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2495]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2496]! } + public var Passport_RequestedInformation: String { return self._s[2497]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2498]! } + public var Conversation_EncryptionProcessing: String { return self._s[2500]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2501]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2503]! } + public var Channel_Setup_Title: String { return self._s[2504]! } + public var Conversation_SearchPlaceholder: String { return self._s[2505]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2506]! } + public var Checkout_ErrorGeneric: String { return self._s[2507]! } + public var Passport_Language_hu: String { return self._s[2508]! } + public var GroupPermission_EditingDisabled: String { return self._s[2509]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2511]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2509]!, self._r[2509]!, [_0]) + return formatWithArgumentRanges(self._s[2512]!, self._r[2512]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2512]!, self._r[2512]!, [_1]) + return formatWithArgumentRanges(self._s[2515]!, self._r[2515]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2513]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2516]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2514]!, self._r[2514]!, [_0]) + return formatWithArgumentRanges(self._s[2517]!, self._r[2517]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2515]! } - public var Group_Location_Info: String { return self._s[2516]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2517]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2518]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2518]! } + public var Group_Location_Info: String { return self._s[2519]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2520]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2521]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2519]!, self._r[2519]!, [_0]) + return formatWithArgumentRanges(self._s[2522]!, self._r[2522]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2520]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2521]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2522]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2523]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2523]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2524]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2525]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2526]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2524]!, self._r[2524]!, [_0]) + return formatWithArgumentRanges(self._s[2527]!, self._r[2527]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2525]! } - public var Message_PinnedAnimationMessage: String { return self._s[2527]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2529]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2530]! } - public var Wallet_Info_TransactionTo: String { return self._s[2532]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2533]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2534]! } - public var Embed_PlayingInPIP: String { return self._s[2535]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2536]! } + public var Passport_Language_cs: String { return self._s[2528]! } + public var Message_PinnedAnimationMessage: String { return self._s[2530]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2532]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2533]! } + public var Wallet_Info_TransactionTo: String { return self._s[2535]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2536]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2537]! } + public var Embed_PlayingInPIP: String { return self._s[2538]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2539]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2537]!, self._r[2537]!, [_0]) + return formatWithArgumentRanges(self._s[2540]!, self._r[2540]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2538]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2541]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2539]!, self._r[2539]!, [_1]) + return formatWithArgumentRanges(self._s[2542]!, self._r[2542]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2540]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2541]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2542]! } - public var AutoNightTheme_System: String { return self._s[2543]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2544]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2545]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2546]! } + public var Notification_PaymentSent: String { return self._s[2543]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2544]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2545]! } + public var AutoNightTheme_System: String { return self._s[2546]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2547]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2548]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2549]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2549]!, self._r[2549]!, [_1]) + return formatWithArgumentRanges(self._s[2552]!, self._r[2552]!, [_1]) } public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2550]!, self._r[2550]!, [_1]) + return formatWithArgumentRanges(self._s[2553]!, self._r[2553]!, [_1]) } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2551]!, self._r[2551]!, [_1]) + return formatWithArgumentRanges(self._s[2554]!, self._r[2554]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2553]! } - public var PasscodeSettings_HelpTop: String { return self._s[2554]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2555]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2556]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2557]! } - public var EditTheme_ShortLink: String { return self._s[2558]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2559]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2560]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2561]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2562]! } - public var Call_Accept: String { return self._s[2564]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2565]! } - public var Month_GenMarch: String { return self._s[2567]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2568]! } - public var LoginPassword_Title: String { return self._s[2569]! } - public var Call_End: String { return self._s[2570]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2571]! } - public var VoiceOver_Chat_Contact: String { return self._s[2572]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2573]! } - public var CallSettings_Always: String { return self._s[2574]! } - public var CallFeedback_Success: String { return self._s[2575]! } - public var TwoStepAuth_SetupHint: String { return self._s[2576]! } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2556]! } + public var PasscodeSettings_HelpTop: String { return self._s[2557]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2558]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2559]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2560]! } + public var EditTheme_ShortLink: String { return self._s[2561]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2562]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2563]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2564]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2565]! } + public var Call_Accept: String { return self._s[2567]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2568]! } + public var Month_GenMarch: String { return self._s[2570]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2571]! } + public var LoginPassword_Title: String { return self._s[2572]! } + public var Call_End: String { return self._s[2573]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2574]! } + public var VoiceOver_Chat_Contact: String { return self._s[2575]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2576]! } + public var CallSettings_Always: String { return self._s[2577]! } + public var CallFeedback_Success: String { return self._s[2578]! } + public var TwoStepAuth_SetupHint: String { return self._s[2579]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2577]!, self._r[2577]!, [_1]) + return formatWithArgumentRanges(self._s[2580]!, self._r[2580]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2578]! } - public var Login_PhoneTitle: String { return self._s[2579]! } - public var Passport_FieldPhoneHelp: String { return self._s[2580]! } - public var Weekday_ShortSunday: String { return self._s[2581]! } - public var Passport_InfoFAQ_URL: String { return self._s[2582]! } - public var ContactInfo_Job: String { return self._s[2584]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2585]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2586]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2587]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2588]! } - public var Invite_ChannelsTooMuch: String { return self._s[2589]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2590]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2591]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2592]! } - public var Wallet_Receive_AmountText: String { return self._s[2593]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2594]! } - public var CallFeedback_ReasonNoise: String { return self._s[2595]! } - public var Appearance_AppIconDefault: String { return self._s[2597]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2598]! } - public var MediaPicker_AddCaption: String { return self._s[2599]! } - public var CallSettings_TabIconDescription: String { return self._s[2600]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2581]! } + public var Login_PhoneTitle: String { return self._s[2582]! } + public var Passport_FieldPhoneHelp: String { return self._s[2583]! } + public var Weekday_ShortSunday: String { return self._s[2584]! } + public var Passport_InfoFAQ_URL: String { return self._s[2585]! } + public var ContactInfo_Job: String { return self._s[2587]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2588]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2589]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2590]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2591]! } + public var Invite_ChannelsTooMuch: String { return self._s[2592]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2593]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2594]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2595]! } + public var Wallet_Receive_AmountText: String { return self._s[2596]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2597]! } + public var CallFeedback_ReasonNoise: String { return self._s[2598]! } + public var Appearance_AppIconDefault: String { return self._s[2600]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2601]! } + public var MediaPicker_AddCaption: String { return self._s[2602]! } + public var CallSettings_TabIconDescription: String { return self._s[2603]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2601]!, self._r[2601]!, [_0]) + return formatWithArgumentRanges(self._s[2604]!, self._r[2604]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2602]! } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2603]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2604]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2605]! } - public var DialogList_SearchSectionRecent: String { return self._s[2606]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2607]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2610]! } - public var LastSeen_WithinAWeek: String { return self._s[2611]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2612]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2614]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2615]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2605]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2606]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2607]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2608]! } + public var DialogList_SearchSectionRecent: String { return self._s[2609]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2610]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2613]! } + public var LastSeen_WithinAWeek: String { return self._s[2614]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2615]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2617]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2618]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2616]!, self._r[2616]!, [_0]) + return formatWithArgumentRanges(self._s[2619]!, self._r[2619]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2617]! } - public var Conversation_StatusLeftGroup: String { return self._s[2618]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2619]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2621]! } - public var GroupPermission_AddSuccess: String { return self._s[2622]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2624]! } - public var Conversation_ContextMenuCopy: String { return self._s[2625]! } - public var AccessDenied_CallMicrophone: String { return self._s[2626]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2620]! } + public var Conversation_StatusLeftGroup: String { return self._s[2621]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2622]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2624]! } + public var GroupPermission_AddSuccess: String { return self._s[2625]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2627]! } + public var Conversation_ContextMenuCopy: String { return self._s[2628]! } + public var AccessDenied_CallMicrophone: String { return self._s[2629]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2627]!, self._r[2627]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2630]!, self._r[2630]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2628]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2629]! } - public var Checkout_PaymentMethod_New: String { return self._s[2630]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2631]! } - public var PhotoEditor_QualityTool: String { return self._s[2632]! } - public var Login_SendCodeViaSms: String { return self._s[2633]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2634]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2635]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2636]! } - public var Login_EmailNotConfiguredError: String { return self._s[2637]! } - public var SocksProxySetup_Status: String { return self._s[2638]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2639]! } - public var PrivacyPolicy_Accept: String { return self._s[2640]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2641]! } - public var Appearance_AppIconClassicX: String { return self._s[2642]! } + public var Login_InvalidFirstNameError: String { return self._s[2631]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2632]! } + public var Checkout_PaymentMethod_New: String { return self._s[2633]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2634]! } + public var PhotoEditor_QualityTool: String { return self._s[2635]! } + public var Login_SendCodeViaSms: String { return self._s[2636]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2637]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2638]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2639]! } + public var Login_EmailNotConfiguredError: String { return self._s[2640]! } + public var SocksProxySetup_Status: String { return self._s[2641]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2642]! } + public var PrivacyPolicy_Accept: String { return self._s[2643]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2644]! } + public var Appearance_AppIconClassicX: String { return self._s[2645]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2643]!, self._r[2643]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2646]!, self._r[2646]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2644]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2646]! } - public var AutoNightTheme_Automatic: String { return self._s[2647]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2648]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2649]! } - public var Cache_Help: String { return self._s[2650]! } - public var Group_ErrorAccessDenied: String { return self._s[2651]! } - public var Passport_Language_fa: String { return self._s[2652]! } - public var Wallet_Intro_Text: String { return self._s[2653]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2654]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2655]! } - public var PrivacySettings_LastSeen: String { return self._s[2656]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2647]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2649]! } + public var AutoNightTheme_Automatic: String { return self._s[2650]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2651]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2652]! } + public var Cache_Help: String { return self._s[2653]! } + public var Group_ErrorAccessDenied: String { return self._s[2654]! } + public var Passport_Language_fa: String { return self._s[2655]! } + public var Wallet_Intro_Text: String { return self._s[2656]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2657]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2658]! } + public var PrivacySettings_LastSeen: String { return self._s[2659]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2657]!, self._r[2657]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2660]!, self._r[2660]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2661]! } - public var Preview_SaveGif: String { return self._s[2662]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2663]! } - public var Profile_About: String { return self._s[2664]! } - public var Channel_About_Placeholder: String { return self._s[2665]! } - public var Login_InfoTitle: String { return self._s[2666]! } + public var Wallet_Configuration_Apply: String { return self._s[2664]! } + public var Preview_SaveGif: String { return self._s[2665]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2666]! } + public var Profile_About: String { return self._s[2667]! } + public var Channel_About_Placeholder: String { return self._s[2668]! } + public var Login_InfoTitle: String { return self._s[2669]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2667]!, self._r[2667]!, [_0]) + return formatWithArgumentRanges(self._s[2670]!, self._r[2670]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2668]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2670]! } - public var ContactInfo_Title: String { return self._s[2671]! } - public var Media_ShareThisVideo: String { return self._s[2672]! } - public var Weekday_ShortFriday: String { return self._s[2673]! } - public var AccessDenied_Contacts: String { return self._s[2675]! } - public var Notification_CallIncomingShort: String { return self._s[2676]! } - public var Group_Setup_TypePublic: String { return self._s[2677]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2678]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2679]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2682]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2683]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2684]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2685]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2686]! } + public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2671]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2673]! } + public var ContactInfo_Title: String { return self._s[2674]! } + public var Media_ShareThisVideo: String { return self._s[2675]! } + public var Weekday_ShortFriday: String { return self._s[2676]! } + public var AccessDenied_Contacts: String { return self._s[2678]! } + public var Notification_CallIncomingShort: String { return self._s[2679]! } + public var Group_Setup_TypePublic: String { return self._s[2680]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2681]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2682]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2685]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2686]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2687]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2688]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2689]! } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2687]!, self._r[2687]!, [_0]) + return formatWithArgumentRanges(self._s[2690]!, self._r[2690]!, [_0]) } - public var DialogList_Typing: String { return self._s[2688]! } - public var CallFeedback_IncludeLogs: String { return self._s[2690]! } - public var Checkout_Phone: String { return self._s[2692]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2695]! } - public var Privacy_Calls_Integration: String { return self._s[2696]! } - public var Notifications_PermissionsAllow: String { return self._s[2697]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2701]! } - public var Settings_ChatSettings: String { return self._s[2702]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[2703]! } + public var DialogList_Typing: String { return self._s[2691]! } + public var CallFeedback_IncludeLogs: String { return self._s[2693]! } + public var Checkout_Phone: String { return self._s[2695]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2698]! } + public var Privacy_Calls_Integration: String { return self._s[2699]! } + public var Notifications_PermissionsAllow: String { return self._s[2700]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2704]! } + public var Settings_ChatSettings: String { return self._s[2705]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[2706]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2704]!, self._r[2704]!, [_0]) + return formatWithArgumentRanges(self._s[2707]!, self._r[2707]!, [_0]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2705]!, self._r[2705]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2708]!, self._r[2708]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2707]! } + public var GroupRemoved_DeleteUser: String { return self._s[2710]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2708]!, self._r[2708]!, [_0]) + return formatWithArgumentRanges(self._s[2711]!, self._r[2711]!, [_0]) } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2709]!, self._r[2709]!, [_1]) + return formatWithArgumentRanges(self._s[2712]!, self._r[2712]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2710]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2711]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2713]! } - public var Conversation_Unblock: String { return self._s[2714]! } - public var PrivacySettings_DataSettings: String { return self._s[2715]! } - public var Group_PublicLink_Info: String { return self._s[2716]! } + public var Login_ContinueWithLocalization: String { return self._s[2713]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2714]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2716]! } + public var Conversation_Unblock: String { return self._s[2717]! } + public var PrivacySettings_DataSettings: String { return self._s[2718]! } + public var Group_PublicLink_Info: String { return self._s[2719]! } public func Wallet_Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2717]!, self._r[2717]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2720]!, self._r[2720]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2718]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2721]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2719]!, self._r[2719]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2722]!, self._r[2722]!, [_0, _1]) } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2721]! } - public var PrivacySettings_Passcode: String { return self._s[2723]! } - public var Call_Mute: String { return self._s[2724]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2725]! } - public var Passport_Language_dz: String { return self._s[2726]! } - public var Wallet_Receive_AmountHeader: String { return self._s[2727]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2728]! } - public var Passport_Language_tk: String { return self._s[2729]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2724]! } + public var PrivacySettings_Passcode: String { return self._s[2726]! } + public var Call_Mute: String { return self._s[2727]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2728]! } + public var Passport_Language_dz: String { return self._s[2729]! } + public var Wallet_Receive_AmountHeader: String { return self._s[2730]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2731]! } + public var Passport_Language_tk: String { return self._s[2732]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2730]!, self._r[2730]!, [_0]) + return formatWithArgumentRanges(self._s[2733]!, self._r[2733]!, [_0]) } - public var Settings_Search: String { return self._s[2731]! } - public var Wallet_Month_ShortFebruary: String { return self._s[2732]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2733]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[2734]! } - public var Conversation_ContextMenuReply: String { return self._s[2735]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2736]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2737]! } - public var Tour_Title1: String { return self._s[2738]! } - public var Wallet_Alert_Cancel: String { return self._s[2739]! } - public var Conversation_ClearGroupHistory: String { return self._s[2741]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2742]! } - public var WallpaperPreview_Motion: String { return self._s[2743]! } + public var Settings_Search: String { return self._s[2734]! } + public var Wallet_Month_ShortFebruary: String { return self._s[2735]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2736]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[2737]! } + public var Conversation_ContextMenuReply: String { return self._s[2738]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2739]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2740]! } + public var Tour_Title1: String { return self._s[2741]! } + public var Wallet_Alert_Cancel: String { return self._s[2742]! } + public var Conversation_ClearGroupHistory: String { return self._s[2744]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2745]! } + public var WallpaperPreview_Motion: String { return self._s[2746]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2744]!, self._r[2744]!, [_0]) + return formatWithArgumentRanges(self._s[2747]!, self._r[2747]!, [_0]) } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2745]! } - public var Call_RateCall: String { return self._s[2746]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2747]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2748]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2749]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2751]! } + public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2748]! } + public var Call_RateCall: String { return self._s[2749]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2750]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2751]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2752]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2754]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2753]!, self._r[2753]!, [_0]) + return formatWithArgumentRanges(self._s[2756]!, self._r[2756]!, [_0]) } - public var Compose_Create: String { return self._s[2754]! } - public var Contacts_InviteToTelegram: String { return self._s[2755]! } - public var GroupInfo_Notifications: String { return self._s[2756]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2758]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2759]! } - public var Month_GenApril: String { return self._s[2760]! } - public var Appearance_AutoNightTheme: String { return self._s[2761]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2763]! } - public var Login_CodeSentSms: String { return self._s[2765]! } + public var Compose_Create: String { return self._s[2757]! } + public var Contacts_InviteToTelegram: String { return self._s[2758]! } + public var GroupInfo_Notifications: String { return self._s[2759]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2761]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2762]! } + public var Month_GenApril: String { return self._s[2763]! } + public var Appearance_AutoNightTheme: String { return self._s[2764]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2766]! } + public var Login_CodeSentSms: String { return self._s[2768]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2766]!, self._r[2766]!, [_0]) + return formatWithArgumentRanges(self._s[2769]!, self._r[2769]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2767]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2768]! } - public var Passport_Language_hr: String { return self._s[2769]! } - public var Common_ActionNotAllowedError: String { return self._s[2770]! } + public var EmptyGroupInfo_Line3: String { return self._s[2770]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2771]! } + public var Passport_Language_hr: String { return self._s[2772]! } + public var Common_ActionNotAllowedError: String { return self._s[2773]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2771]!, self._r[2771]!, [_0]) + return formatWithArgumentRanges(self._s[2774]!, self._r[2774]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2772]! } - public var Wallet_Info_TransactionFrom: String { return self._s[2773]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2774]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2775]! } - public var Privacy_SecretChatsTitle: String { return self._s[2776]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2778]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2779]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2780]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2781]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[2782]! } - public var Preview_DeleteGif: String { return self._s[2783]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2784]! } - public var Group_ErrorNotMutualContact: String { return self._s[2785]! } - public var Notification_MessageLifetime5s: String { return self._s[2786]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[2787]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2775]! } + public var Wallet_Info_TransactionFrom: String { return self._s[2776]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2777]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2778]! } + public var Privacy_SecretChatsTitle: String { return self._s[2779]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2781]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2782]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2783]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[2784]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[2785]! } + public var Preview_DeleteGif: String { return self._s[2786]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2787]! } + public var Group_ErrorNotMutualContact: String { return self._s[2788]! } + public var Notification_MessageLifetime5s: String { return self._s[2789]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[2790]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2788]!, self._r[2788]!, [_0]) + return formatWithArgumentRanges(self._s[2791]!, self._r[2791]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[2789]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2791]! } - public var ReportSpam_DeleteThisChat: String { return self._s[2792]! } - public var Passport_Address_AddBankStatement: String { return self._s[2793]! } - public var Notification_CallIncoming: String { return self._s[2794]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[2795]! } - public var Compose_NewGroupTitle: String { return self._s[2796]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2798]! } - public var Passport_Address_Postcode: String { return self._s[2800]! } + public var VoiceOver_Chat_Video: String { return self._s[2792]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2794]! } + public var ReportSpam_DeleteThisChat: String { return self._s[2795]! } + public var Passport_Address_AddBankStatement: String { return self._s[2796]! } + public var Notification_CallIncoming: String { return self._s[2797]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[2798]! } + public var Compose_NewGroupTitle: String { return self._s[2799]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2801]! } + public var Passport_Address_Postcode: String { return self._s[2803]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2801]!, self._r[2801]!, [_0]) + return formatWithArgumentRanges(self._s[2804]!, self._r[2804]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2802]! } - public var Wallet_Month_ShortOctober: String { return self._s[2803]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[2804]! } - public var WallpaperColors_Title: String { return self._s[2805]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2806]! } - public var VoiceOver_MessageContextForward: String { return self._s[2807]! } - public var GroupPermission_Duration: String { return self._s[2808]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2805]! } + public var Wallet_Month_ShortOctober: String { return self._s[2806]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[2807]! } + public var WallpaperColors_Title: String { return self._s[2808]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2809]! } + public var VoiceOver_MessageContextForward: String { return self._s[2810]! } + public var GroupPermission_Duration: String { return self._s[2811]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2809]!, self._r[2809]!, [_0]) + return formatWithArgumentRanges(self._s[2812]!, self._r[2812]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2810]! } - public var Username_Placeholder: String { return self._s[2811]! } - public var CallFeedback_WhatWentWrong: String { return self._s[2812]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2813]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2814]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2813]! } + public var Username_Placeholder: String { return self._s[2814]! } + public var CallFeedback_WhatWentWrong: String { return self._s[2815]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2816]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2817]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2816]!, self._r[2816]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2819]!, self._r[2819]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[2817]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2818]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2819]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2820]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2821]! } - public var Conversation_ContextMenuMore: String { return self._s[2822]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2823]! } - public var CallSettings_TabIcon: String { return self._s[2824]! } - public var KeyCommand_Find: String { return self._s[2825]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[2826]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2827]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2828]! } - public var Message_PinnedGame: String { return self._s[2829]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2830]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2832]! } - public var Login_CallRequestState2: String { return self._s[2834]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2836]! } + public var Passport_PasswordDescription: String { return self._s[2820]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2821]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2822]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2823]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2824]! } + public var Conversation_ContextMenuMore: String { return self._s[2825]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2826]! } + public var CallSettings_TabIcon: String { return self._s[2827]! } + public var KeyCommand_Find: String { return self._s[2828]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[2829]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2830]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2831]! } + public var Message_PinnedGame: String { return self._s[2832]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2833]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2835]! } + public var Login_CallRequestState2: String { return self._s[2837]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2839]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2837]!, self._r[2837]!, [_0]) + return formatWithArgumentRanges(self._s[2840]!, self._r[2840]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2839]!, self._r[2839]!, [_0]) - } - public var WallpaperPreview_Blurred: String { return self._s[2840]! } - public var Conversation_InstantPagePreview: String { return self._s[2841]! } - public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2842]!, self._r[2842]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2845]! } - public var WallpaperSearch_ColorRed: String { return self._s[2846]! } - public var GroupPermission_NoPinMessages: String { return self._s[2847]! } - public var Passport_Language_es: String { return self._s[2848]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2850]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2851]! } + public var AuthSessions_AddDevice: String { return self._s[2843]! } + public var WallpaperPreview_Blurred: String { return self._s[2844]! } + public var Conversation_InstantPagePreview: String { return self._s[2845]! } + public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2846]!, self._r[2846]!, [_0]) + } + public var SecretTimer_VideoDescription: String { return self._s[2849]! } + public var WallpaperSearch_ColorRed: String { return self._s[2850]! } + public var GroupPermission_NoPinMessages: String { return self._s[2851]! } + public var Passport_Language_es: String { return self._s[2852]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2854]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2855]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2852]!, self._r[2852]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2856]!, self._r[2856]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[2853]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2854]! } - public var Watch_UserInfo_Unmute: String { return self._s[2855]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2856]! } - public var AccessDenied_CameraRestricted: String { return self._s[2858]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[2857]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2858]! } + public var Watch_UserInfo_Unmute: String { return self._s[2859]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2860]! } + public var AccessDenied_CameraRestricted: String { return self._s[2862]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2859]!, self._r[2859]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2863]!, self._r[2863]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2861]! } - public var Settings_CopyUsername: String { return self._s[2862]! } - public var Contacts_SearchLabel: String { return self._s[2863]! } - public var Map_OpenInYandexNavigator: String { return self._s[2865]! } - public var PasscodeSettings_EncryptData: String { return self._s[2866]! } - public var Settings_Wallet: String { return self._s[2867]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2868]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[2869]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2870]! } - public var DialogList_AdNoticeAlert: String { return self._s[2871]! } - public var Wallet_Month_GenMay: String { return self._s[2873]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2874]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2875]! } - public var Localization_LanguageCustom: String { return self._s[2876]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2877]! } - public var CallFeedback_Title: String { return self._s[2878]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2881]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2882]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[2883]! } - public var Conversation_InfoGroup: String { return self._s[2884]! } - public var Compose_NewMessage: String { return self._s[2885]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2886]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2887]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[2888]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2889]! } + public var ChatList_ReadAll: String { return self._s[2865]! } + public var Settings_CopyUsername: String { return self._s[2866]! } + public var Contacts_SearchLabel: String { return self._s[2867]! } + public var Map_OpenInYandexNavigator: String { return self._s[2869]! } + public var PasscodeSettings_EncryptData: String { return self._s[2870]! } + public var Settings_Wallet: String { return self._s[2871]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2872]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[2873]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2874]! } + public var DialogList_AdNoticeAlert: String { return self._s[2875]! } + public var Wallet_Month_GenMay: String { return self._s[2877]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2878]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2879]! } + public var Localization_LanguageCustom: String { return self._s[2880]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2881]! } + public var CallFeedback_Title: String { return self._s[2882]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2885]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2886]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[2887]! } + public var Conversation_InfoGroup: String { return self._s[2888]! } + public var Compose_NewMessage: String { return self._s[2889]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2890]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2891]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[2892]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2893]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2890]!, self._r[2890]!, [_0]) + return formatWithArgumentRanges(self._s[2894]!, self._r[2894]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2891]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2892]! } - public var ChangePhoneNumberCode_Help: String { return self._s[2893]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[2894]! } - public var Channel_BlackList_Title: String { return self._s[2895]! } - public var UserInfo_PhoneCall: String { return self._s[2896]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2898]! } - public var Wallet_Month_ShortJanuary: String { return self._s[2899]! } - public var State_connecting: String { return self._s[2900]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[2901]! } - public var Wallet_Month_GenMarch: String { return self._s[2902]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[2903]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2895]! } + public var Login_CancelSignUpConfirmation: String { return self._s[2896]! } + public var ChangePhoneNumberCode_Help: String { return self._s[2897]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[2898]! } + public var Channel_BlackList_Title: String { return self._s[2899]! } + public var UserInfo_PhoneCall: String { return self._s[2900]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2902]! } + public var Wallet_Month_ShortJanuary: String { return self._s[2903]! } + public var State_connecting: String { return self._s[2904]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[2905]! } + public var Wallet_Month_GenMarch: String { return self._s[2906]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[2907]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2904]!, self._r[2904]!, [_0]) + return formatWithArgumentRanges(self._s[2908]!, self._r[2908]!, [_0]) } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2905]!, self._r[2905]!, [_0]) + return formatWithArgumentRanges(self._s[2909]!, self._r[2909]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[2906]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[2907]! } - public var Passport_Identity_EditPassport: String { return self._s[2908]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[2910]! } - public var Localization_EnglishLanguageName: String { return self._s[2911]! } - public var Share_AuthDescription: String { return self._s[2912]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2913]! } - public var Passport_Identity_Surname: String { return self._s[2914]! } - public var Compose_TokenListPlaceholder: String { return self._s[2915]! } - public var Wallet_AccessDenied_Camera: String { return self._s[2916]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[2917]! } - public var Settings_AboutEmpty: String { return self._s[2918]! } - public var Conversation_Unmute: String { return self._s[2919]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[2921]! } - public var Wallet_Sending_Text: String { return self._s[2922]! } + public var Notifications_GroupNotifications: String { return self._s[2910]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[2911]! } + public var Passport_Identity_EditPassport: String { return self._s[2912]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[2914]! } + public var Localization_EnglishLanguageName: String { return self._s[2915]! } + public var Share_AuthDescription: String { return self._s[2916]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2917]! } + public var Passport_Identity_Surname: String { return self._s[2918]! } + public var Compose_TokenListPlaceholder: String { return self._s[2919]! } + public var Wallet_AccessDenied_Camera: String { return self._s[2920]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[2921]! } + public var Settings_AboutEmpty: String { return self._s[2922]! } + public var Conversation_Unmute: String { return self._s[2923]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[2925]! } + public var Wallet_Sending_Text: String { return self._s[2926]! } public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2923]!, self._r[2923]!, [_1]) + return formatWithArgumentRanges(self._s[2927]!, self._r[2927]!, [_1]) } - public var Login_CodeSentCall: String { return self._s[2924]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2926]! } - public var ChatSettings_Appearance: String { return self._s[2927]! } - public var ClearCache_StorageUsage: String { return self._s[2928]! } - public var Appearance_PickAccentColor: String { return self._s[2929]! } + public var Login_CodeSentCall: String { return self._s[2928]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2930]! } + public var ChatSettings_Appearance: String { return self._s[2931]! } + public var ClearCache_StorageUsage: String { return self._s[2932]! } + public var Appearance_PickAccentColor: String { return self._s[2933]! } public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2930]!, self._r[2930]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2934]!, self._r[2934]!, [_1, _2]) } public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2931]!, self._r[2931]!, [_1]) + return formatWithArgumentRanges(self._s[2935]!, self._r[2935]!, [_1]) } - public var Notification_CallMissed: String { return self._s[2932]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2933]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2934]! } - public var Wallet_Month_GenOctober: String { return self._s[2936]! } - public var ChatAdmins_AdminLabel: String { return self._s[2937]! } - public var KeyCommand_JumpToNextChat: String { return self._s[2938]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[2940]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2941]! } - public var Month_GenJune: String { return self._s[2942]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[2943]! } - public var Watch_Location_Current: String { return self._s[2944]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[2945]! } - public var Conversation_TitleMute: String { return self._s[2946]! } + public var Notification_CallMissed: String { return self._s[2936]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2937]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2938]! } + public var Wallet_Month_GenOctober: String { return self._s[2940]! } + public var ChatAdmins_AdminLabel: String { return self._s[2941]! } + public var KeyCommand_JumpToNextChat: String { return self._s[2942]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[2944]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2945]! } + public var Month_GenJune: String { return self._s[2946]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[2947]! } + public var Watch_Location_Current: String { return self._s[2948]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[2949]! } + public var Conversation_TitleMute: String { return self._s[2950]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2947]!, self._r[2947]!, [_1]) + return formatWithArgumentRanges(self._s[2951]!, self._r[2951]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[2948]! } + public var GroupInfo_DeleteAndExit: String { return self._s[2952]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2949]!, self._r[2949]!, [_0]) + return formatWithArgumentRanges(self._s[2953]!, self._r[2953]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[2950]! } - public var Chat_SlowmodeSendError: String { return self._s[2951]! } - public var MaskStickerSettings_Info: String { return self._s[2952]! } - public var EditTheme_Expand_TopInfo: String { return self._s[2953]! } + public var Call_ReportPlaceholder: String { return self._s[2954]! } + public var Chat_SlowmodeSendError: String { return self._s[2955]! } + public var MaskStickerSettings_Info: String { return self._s[2956]! } + public var EditTheme_Expand_TopInfo: String { return self._s[2957]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2954]!, self._r[2954]!, [_0]) + return formatWithArgumentRanges(self._s[2958]!, self._r[2958]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[2955]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[2957]! } - public var Contacts_ShareTelegram: String { return self._s[2958]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2959]! } - public var Channel_ErrorAccessDenied: String { return self._s[2960]! } - public var UserInfo_ScamBotWarning: String { return self._s[2962]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[2963]! } - public var Call_ConnectionErrorTitle: String { return self._s[2964]! } - public var UserInfo_NotificationsEnable: String { return self._s[2965]! } - public var ArchivedChats_IntroText1: String { return self._s[2966]! } - public var Tour_Text4: String { return self._s[2969]! } - public var WallpaperSearch_Recent: String { return self._s[2970]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[2971]! } - public var Profile_MessageLifetime2s: String { return self._s[2973]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[2974]! } - public var Notification_MessageLifetime2s: String { return self._s[2975]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[2959]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[2961]! } + public var Contacts_ShareTelegram: String { return self._s[2962]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2963]! } + public var Channel_ErrorAccessDenied: String { return self._s[2964]! } + public var UserInfo_ScamBotWarning: String { return self._s[2966]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[2967]! } + public var Call_ConnectionErrorTitle: String { return self._s[2968]! } + public var UserInfo_NotificationsEnable: String { return self._s[2969]! } + public var ArchivedChats_IntroText1: String { return self._s[2970]! } + public var Tour_Text4: String { return self._s[2973]! } + public var WallpaperSearch_Recent: String { return self._s[2974]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[2975]! } + public var Profile_MessageLifetime2s: String { return self._s[2977]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[2978]! } + public var Notification_MessageLifetime2s: String { return self._s[2979]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2976]!, self._r[2976]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2980]!, self._r[2980]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[2977]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[2978]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2979]! } + public var Cache_ClearCache: String { return self._s[2981]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[2982]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2983]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2983]!, self._r[2983]!, [_0]) + return formatWithArgumentRanges(self._s[2987]!, self._r[2987]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_0]) + return formatWithArgumentRanges(self._s[2989]!, self._r[2989]!, [_0]) } - public var LocalGroup_Text: String { return self._s[2986]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2987]! } - public var SocksProxySetup_TypeSocks: String { return self._s[2988]! } - public var ChatList_UnarchiveAction: String { return self._s[2989]! } - public var AutoNightTheme_Title: String { return self._s[2990]! } - public var InstantPage_FeedbackButton: String { return self._s[2991]! } - public var Passport_FieldAddress: String { return self._s[2992]! } + public var LocalGroup_Text: String { return self._s[2990]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2991]! } + public var SocksProxySetup_TypeSocks: String { return self._s[2992]! } + public var ChatList_UnarchiveAction: String { return self._s[2993]! } + public var AutoNightTheme_Title: String { return self._s[2994]! } + public var InstantPage_FeedbackButton: String { return self._s[2995]! } + public var Passport_FieldAddress: String { return self._s[2996]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2993]!, self._r[2993]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2997]!, self._r[2997]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[2994]! } + public var Month_ShortMarch: String { return self._s[2998]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2995]!, self._r[2995]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2999]!, self._r[2999]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2996]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2997]! } - public var Passport_FloodError: String { return self._s[2998]! } - public var SecretGif_Title: String { return self._s[2999]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3000]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3001]! } - public var Passport_Language_th: String { return self._s[3003]! } - public var Passport_Address_Address: String { return self._s[3004]! } - public var Login_InvalidLastNameError: String { return self._s[3005]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3006]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3007]! } - public var ChatList_Context_Archive: String { return self._s[3008]! } - public var SettingsSearch_FAQ: String { return self._s[3009]! } - public var ShareMenu_Send: String { return self._s[3010]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3012]! } - public var Month_GenNovember: String { return self._s[3014]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3016]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3000]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3001]! } + public var Passport_FloodError: String { return self._s[3002]! } + public var SecretGif_Title: String { return self._s[3003]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3004]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3005]! } + public var Passport_Language_th: String { return self._s[3007]! } + public var Passport_Address_Address: String { return self._s[3008]! } + public var Login_InvalidLastNameError: String { return self._s[3009]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3010]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3011]! } + public var ChatList_Context_Archive: String { return self._s[3012]! } + public var SettingsSearch_FAQ: String { return self._s[3013]! } + public var ShareMenu_Send: String { return self._s[3014]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3016]! } + public var Month_GenNovember: String { return self._s[3018]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3020]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3017]!, self._r[3017]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3021]!, self._r[3021]!, [_1, _2]) } - public var Conversation_SwipeToReplyHintText: String { return self._s[3018]! } - public var Checkout_Email: String { return self._s[3019]! } - public var NotificationsSound_Tritone: String { return self._s[3020]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3022]! } - public var Wallet_ContextMenuCopy: String { return self._s[3024]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3022]! } + public var Checkout_Email: String { return self._s[3023]! } + public var NotificationsSound_Tritone: String { return self._s[3024]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3026]! } + public var Wallet_ContextMenuCopy: String { return self._s[3028]! } public func Wallet_Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3026]!, self._r[3026]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3030]!, self._r[3030]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3027]! } + public var Appearance_TextSize_Automatic: String { return self._s[3031]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3028]!, self._r[3028]!, [_1]) + return formatWithArgumentRanges(self._s[3032]!, self._r[3032]!, [_1]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3029]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3033]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3030]!, self._r[3030]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3034]!, self._r[3034]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3031]! } - public var Notification_Exceptions_Add: String { return self._s[3032]! } - public var DialogList_You: String { return self._s[3033]! } - public var MediaPicker_Send: String { return self._s[3036]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3037]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3038]! } - public var Call_AudioRouteSpeaker: String { return self._s[3039]! } - public var Watch_UserInfo_Title: String { return self._s[3040]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3041]! } - public var Appearance_AccentColor: String { return self._s[3043]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3035]! } + public var Notification_Exceptions_Add: String { return self._s[3036]! } + public var DialogList_You: String { return self._s[3037]! } + public var MediaPicker_Send: String { return self._s[3040]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3041]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3042]! } + public var Call_AudioRouteSpeaker: String { return self._s[3043]! } + public var Watch_UserInfo_Title: String { return self._s[3044]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3045]! } + public var Appearance_AccentColor: String { return self._s[3047]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3044]!, self._r[3044]!, [_0]) + return formatWithArgumentRanges(self._s[3048]!, self._r[3048]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3045]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3049]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3046]!, self._r[3046]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3050]!, self._r[3050]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3047]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3048]! } - public var Notification_CallOutgoing: String { return self._s[3049]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3050]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3051]! } - public var Call_RecordingDisabledMessage: String { return self._s[3052]! } - public var Message_Game: String { return self._s[3053]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3054]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3055]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3056]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3057]! } - public var Date_DialogDateFormat: String { return self._s[3058]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3059]! } - public var Notifications_InAppNotifications: String { return self._s[3060]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[3051]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3052]! } + public var Notification_CallOutgoing: String { return self._s[3053]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3054]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3055]! } + public var Call_RecordingDisabledMessage: String { return self._s[3056]! } + public var Message_Game: String { return self._s[3057]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3058]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3059]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3060]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3061]! } + public var Date_DialogDateFormat: String { return self._s[3062]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3063]! } + public var Notifications_InAppNotifications: String { return self._s[3064]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3061]!, self._r[3061]!, [_0]) + return formatWithArgumentRanges(self._s[3065]!, self._r[3065]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3062]!, self._r[3062]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3066]!, self._r[3066]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[3063]! } + public var NewContact_Title: String { return self._s[3067]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3064]!, self._r[3064]!, [_0]) + return formatWithArgumentRanges(self._s[3068]!, self._r[3068]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[3065]! } + public var Conversation_ViewContactDetails: String { return self._s[3069]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3067]!, self._r[3067]!, [_1]) + return formatWithArgumentRanges(self._s[3071]!, self._r[3071]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3068]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3069]! } - public var PrivacySettings_Title: String { return self._s[3070]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3073]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3074]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3075]! } - public var Contacts_PhoneNumber: String { return self._s[3076]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3078]! } - public var Map_ShowPlaces: String { return self._s[3079]! } - public var ChatAdmins_Title: String { return self._s[3080]! } - public var InstantPage_Reference: String { return self._s[3082]! } - public var Wallet_Info_Updating: String { return self._s[3083]! } - public var ReportGroupLocation_Text: String { return self._s[3084]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3072]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3073]! } + public var PrivacySettings_Title: String { return self._s[3074]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3077]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3078]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3079]! } + public var Contacts_PhoneNumber: String { return self._s[3080]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3082]! } + public var Map_ShowPlaces: String { return self._s[3083]! } + public var ChatAdmins_Title: String { return self._s[3084]! } + public var InstantPage_Reference: String { return self._s[3086]! } + public var Wallet_Info_Updating: String { return self._s[3087]! } + public var ReportGroupLocation_Text: String { return self._s[3088]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3085]!, self._r[3085]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3089]!, self._r[3089]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3086]! } - public var Watch_UserInfo_Block: String { return self._s[3087]! } - public var ChatSettings_Stickers: String { return self._s[3088]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3089]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3090]! } + public var Camera_FlashOff: String { return self._s[3090]! } + public var Watch_UserInfo_Block: String { return self._s[3091]! } + public var ChatSettings_Stickers: String { return self._s[3092]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3093]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3094]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3091]!, self._r[3091]!, [_0]) + return formatWithArgumentRanges(self._s[3095]!, self._r[3095]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3092]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3093]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3094]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3095]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3096]! } - public var VoiceOver_MessageContextShare: String { return self._s[3097]! } + public var Settings_ViewPhoto: String { return self._s[3096]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3097]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3098]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3099]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3100]! } + public var VoiceOver_MessageContextShare: String { return self._s[3101]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3099]!, self._r[3099]!, [_0]) + return formatWithArgumentRanges(self._s[3103]!, self._r[3103]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[3100]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3101]! } + public var Privacy_DeleteDrafts: String { return self._s[3104]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3105]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3102]!, self._r[3102]!, [_0]) + return formatWithArgumentRanges(self._s[3106]!, self._r[3106]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[3103]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3104]! } - public var DialogList_SavedMessages: String { return self._s[3105]! } - public var GroupInfo_UpgradeButton: String { return self._s[3106]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3108]! } - public var DialogList_Pin: String { return self._s[3109]! } + public var DialogList_SavedMessagesHelp: String { return self._s[3107]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3108]! } + public var DialogList_SavedMessages: String { return self._s[3109]! } + public var GroupInfo_UpgradeButton: String { return self._s[3110]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3112]! } + public var DialogList_Pin: String { return self._s[3113]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3110]!, self._r[3110]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3114]!, self._r[3114]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3111]!, self._r[3111]!, [_0]) + return formatWithArgumentRanges(self._s[3115]!, self._r[3115]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3112]! } - public var UserInfo_NotificationsDisable: String { return self._s[3113]! } - public var Paint_Outlined: String { return self._s[3114]! } - public var Activity_PlayingGame: String { return self._s[3115]! } - public var SearchImages_NoImagesFound: String { return self._s[3116]! } - public var SocksProxySetup_ProxyType: String { return self._s[3117]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3119]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3120]! } - public var Settings_AppLanguage: String { return self._s[3121]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3122]! } - public var Common_ChoosePhoto: String { return self._s[3123]! } - public var CallFeedback_ReasonEcho: String { return self._s[3124]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3116]! } + public var UserInfo_NotificationsDisable: String { return self._s[3117]! } + public var Paint_Outlined: String { return self._s[3118]! } + public var Activity_PlayingGame: String { return self._s[3119]! } + public var SearchImages_NoImagesFound: String { return self._s[3120]! } + public var SocksProxySetup_ProxyType: String { return self._s[3121]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3123]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3124]! } + public var Settings_AppLanguage: String { return self._s[3125]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3126]! } + public var Common_ChoosePhoto: String { return self._s[3127]! } + public var CallFeedback_ReasonEcho: String { return self._s[3128]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3125]!, self._r[3125]!, [_1]) + return formatWithArgumentRanges(self._s[3129]!, self._r[3129]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3126]! } - public var Activity_UploadingVideo: String { return self._s[3127]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3128]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3129]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3130]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3131]! } - public var PUSH_SENDER_YOU: String { return self._s[3132]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3133]! } - public var Checkout_PayWithTouchId: String { return self._s[3134]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3135]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[3130]! } + public var Activity_UploadingVideo: String { return self._s[3131]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3132]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3133]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3134]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3135]! } + public var PUSH_SENDER_YOU: String { return self._s[3136]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3137]! } + public var Checkout_PayWithTouchId: String { return self._s[3138]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3139]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3137]!, self._r[3137]!, [_1]) + return formatWithArgumentRanges(self._s[3141]!, self._r[3141]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[3138]! } + public var Notifications_ExceptionsNone: String { return self._s[3142]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3139]!, self._r[3139]!, [_0]) + return formatWithArgumentRanges(self._s[3143]!, self._r[3143]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3140]!, self._r[3140]!, [_1]) + return formatWithArgumentRanges(self._s[3144]!, self._r[3144]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3142]! } - public var Passport_Address_Region: String { return self._s[3145]! } - public var ChatList_DeleteChat: String { return self._s[3146]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3147]! } - public var PhotoEditor_TiltShift: String { return self._s[3148]! } - public var Settings_FAQ_URL: String { return self._s[3149]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3150]! } - public var Passport_Language_sl: String { return self._s[3151]! } - public var Settings_PrivacySettings: String { return self._s[3153]! } - public var SharedMedia_TitleLink: String { return self._s[3154]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3155]! } - public var Settings_SetProfilePhoto: String { return self._s[3156]! } - public var Channel_About_Help: String { return self._s[3157]! } - public var Contacts_PermissionsEnable: String { return self._s[3158]! } - public var Wallet_Sending_Title: String { return self._s[3159]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3160]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3161]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3163]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3164]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3165]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3166]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3167]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3169]! } - public var Map_OpenInYandexMaps: String { return self._s[3171]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3172]! } - public var VoiceOver_MessageContextReply: String { return self._s[3173]! } - public var PhotoEditor_SaturationTool: String { return self._s[3174]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[3146]! } + public var Passport_Address_Region: String { return self._s[3149]! } + public var ChatList_DeleteChat: String { return self._s[3150]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3151]! } + public var PhotoEditor_TiltShift: String { return self._s[3152]! } + public var Settings_FAQ_URL: String { return self._s[3153]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3154]! } + public var Passport_Language_sl: String { return self._s[3155]! } + public var Settings_PrivacySettings: String { return self._s[3157]! } + public var SharedMedia_TitleLink: String { return self._s[3158]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3159]! } + public var Settings_SetProfilePhoto: String { return self._s[3160]! } + public var Channel_About_Help: String { return self._s[3161]! } + public var Contacts_PermissionsEnable: String { return self._s[3162]! } + public var Wallet_Sending_Title: String { return self._s[3163]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3164]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3165]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3167]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3168]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3169]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3170]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3171]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3173]! } + public var Map_OpenInYandexMaps: String { return self._s[3175]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3176]! } + public var VoiceOver_MessageContextReply: String { return self._s[3177]! } + public var PhotoEditor_SaturationTool: String { return self._s[3178]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3175]!, self._r[3175]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3179]!, self._r[3179]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3176]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3177]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3178]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3180]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3181]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3182]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3179]!, self._r[3179]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3183]!, self._r[3183]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3180]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3182]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3183]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3184]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3186]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3187]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3184]!, self._r[3184]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3188]!, self._r[3188]!, [_1, _2]) } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3185]!, self._r[3185]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3189]!, self._r[3189]!, [_1, _2, _3]) } - public var GroupInfo_PublicLinkAdd: String { return self._s[3186]! } - public var Passport_PassportInformation: String { return self._s[3189]! } - public var Theme_Unsupported: String { return self._s[3190]! } - public var WatchRemote_AlertTitle: String { return self._s[3191]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3192]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3194]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3190]! } + public var Passport_PassportInformation: String { return self._s[3193]! } + public var Theme_Unsupported: String { return self._s[3194]! } + public var WatchRemote_AlertTitle: String { return self._s[3195]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3196]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3198]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3195]!, self._r[3195]!, [_0]) + return formatWithArgumentRanges(self._s[3199]!, self._r[3199]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3196]!, self._r[3196]!, [_1]) + return formatWithArgumentRanges(self._s[3200]!, self._r[3200]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3197]! } - public var Wallet_Navigation_Done: String { return self._s[3199]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3200]! } - public var AccessDenied_CameraDisabled: String { return self._s[3201]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3201]! } + public var Wallet_Navigation_Done: String { return self._s[3203]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3204]! } + public var AccessDenied_CameraDisabled: String { return self._s[3205]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3202]!, self._r[3202]!, [_0]) + return formatWithArgumentRanges(self._s[3206]!, self._r[3206]!, [_0]) } - public var ClearCache_Forever: String { return self._s[3203]! } - public var PhotoEditor_ContrastTool: String { return self._s[3206]! } + public var ClearCache_Forever: String { return self._s[3207]! } + public var PhotoEditor_ContrastTool: String { return self._s[3210]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3207]!, self._r[3207]!, [_1]) + return formatWithArgumentRanges(self._s[3211]!, self._r[3211]!, [_1]) } - public var DialogList_Draft: String { return self._s[3208]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3209]! } - public var Privacy_TopPeersDelete: String { return self._s[3211]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3212]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3213]! } - public var WebSearch_RecentSectionClear: String { return self._s[3214]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3215]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3217]! } - public var Common_Done: String { return self._s[3219]! } - public var AuthSessions_EmptyText: String { return self._s[3220]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3221]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3222]! } - public var Tour_Title5: String { return self._s[3223]! } - public var Wallet_Settings_Title: String { return self._s[3224]! } + public var DialogList_Draft: String { return self._s[3212]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3213]! } + public var Privacy_TopPeersDelete: String { return self._s[3215]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3216]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3217]! } + public var WebSearch_RecentSectionClear: String { return self._s[3218]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3219]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3221]! } + public var Common_Done: String { return self._s[3223]! } + public var AuthSessions_EmptyText: String { return self._s[3224]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3225]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3226]! } + public var Tour_Title5: String { return self._s[3227]! } + public var Wallet_Settings_Title: String { return self._s[3228]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3225]!, self._r[3225]!, [_0]) + return formatWithArgumentRanges(self._s[3229]!, self._r[3229]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3226]! } - public var Conversation_LinkDialogSave: String { return self._s[3227]! } - public var GroupInfo_ActionRestrict: String { return self._s[3228]! } - public var Checkout_Title: String { return self._s[3229]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3231]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3233]! } - public var Notification_RenamedGroup: String { return self._s[3234]! } - public var PeopleNearby_Groups: String { return self._s[3235]! } - public var Checkout_PayWithFaceId: String { return self._s[3236]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3237]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3239]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3240]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3241]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3230]! } + public var Conversation_LinkDialogSave: String { return self._s[3231]! } + public var GroupInfo_ActionRestrict: String { return self._s[3232]! } + public var Checkout_Title: String { return self._s[3233]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3235]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3237]! } + public var Notification_RenamedGroup: String { return self._s[3238]! } + public var PeopleNearby_Groups: String { return self._s[3239]! } + public var Checkout_PayWithFaceId: String { return self._s[3240]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3241]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3243]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3244]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3245]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3242]!, self._r[3242]!, [_0]) + return formatWithArgumentRanges(self._s[3246]!, self._r[3246]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[3244]! } + public var Profile_AddToExisting: String { return self._s[3248]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3245]!, self._r[3245]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3249]!, self._r[3249]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3247]! } - public var Permissions_PrivacyPolicy: String { return self._s[3248]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3249]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3250]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3252]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3254]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3255]! } + public var Cache_Files: String { return self._s[3251]! } + public var Permissions_PrivacyPolicy: String { return self._s[3252]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3253]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3254]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3256]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3258]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3259]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3256]!, self._r[3256]!, [_0]) + return formatWithArgumentRanges(self._s[3260]!, self._r[3260]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3257]! } - public var VoiceOver_AttachMedia: String { return self._s[3259]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3260]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3261]! } + public var VoiceOver_AttachMedia: String { return self._s[3263]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3264]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3261]!, self._r[3261]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3265]!, self._r[3265]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3262]! } - public var Conversation_SetReminder_Title: String { return self._s[3263]! } - public var Passport_FieldAddressHelp: String { return self._s[3264]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3265]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3266]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3266]! } + public var Conversation_SetReminder_Title: String { return self._s[3267]! } + public var Passport_FieldAddressHelp: String { return self._s[3268]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3269]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3270]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3267]!, self._r[3267]!, [_0]) + return formatWithArgumentRanges(self._s[3271]!, self._r[3271]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3268]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3269]! } - public var Login_UnknownError: String { return self._s[3270]! } - public var Group_UpgradeNoticeText2: String { return self._s[3273]! } - public var Watch_Compose_AddContact: String { return self._s[3274]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3275]! } - public var Web_Error: String { return self._s[3276]! } - public var Gif_Search: String { return self._s[3277]! } - public var Profile_MessageLifetime1h: String { return self._s[3278]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3279]! } - public var Channel_Username_CheckingUsername: String { return self._s[3280]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3281]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3282]! } - public var Channel_AboutItem: String { return self._s[3283]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3285]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3286]! } - public var GroupInfo_SharedMedia: String { return self._s[3287]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[3272]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3273]! } + public var Login_UnknownError: String { return self._s[3274]! } + public var Group_UpgradeNoticeText2: String { return self._s[3277]! } + public var Watch_Compose_AddContact: String { return self._s[3278]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3279]! } + public var Web_Error: String { return self._s[3280]! } + public var Gif_Search: String { return self._s[3281]! } + public var Profile_MessageLifetime1h: String { return self._s[3282]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3283]! } + public var Channel_Username_CheckingUsername: String { return self._s[3284]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3285]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3286]! } + public var Channel_AboutItem: String { return self._s[3287]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3289]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3290]! } + public var GroupInfo_SharedMedia: String { return self._s[3291]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3288]!, self._r[3288]!, [_1]) + return formatWithArgumentRanges(self._s[3292]!, self._r[3292]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3289]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3293]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3290]!, self._r[3290]!, [_1]) + return formatWithArgumentRanges(self._s[3294]!, self._r[3294]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3291]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3292]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3293]! } - public var CreatePoll_AddOption: String { return self._s[3294]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3295]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3296]! } - public var Channel_Management_AddModerator: String { return self._s[3297]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3298]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3299]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3300]! } - public var Theme_Colors_Background: String { return self._s[3301]! } - public var NotificationsSound_Hello: String { return self._s[3303]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3304]! } - public var Channel_Stickers_Placeholder: String { return self._s[3306]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3295]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3296]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3297]! } + public var CreatePoll_AddOption: String { return self._s[3298]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3299]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3300]! } + public var Channel_Management_AddModerator: String { return self._s[3301]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3302]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3303]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3304]! } + public var Theme_Colors_Background: String { return self._s[3305]! } + public var NotificationsSound_Hello: String { return self._s[3307]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3308]! } + public var Channel_Stickers_Placeholder: String { return self._s[3310]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3307]!, self._r[3307]!, [_0]) + return formatWithArgumentRanges(self._s[3311]!, self._r[3311]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3308]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3309]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3310]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3311]! } - public var AutoDownloadSettings_Channels: String { return self._s[3312]! } - public var Passport_Language_mn: String { return self._s[3313]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3316]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3317]! } - public var Passport_Language_ja: String { return self._s[3319]! } - public var Settings_About_Title: String { return self._s[3320]! } - public var Settings_NotificationsAndSounds: String { return self._s[3321]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3322]! } - public var Settings_BlockedUsers: String { return self._s[3323]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3312]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3313]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3314]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3315]! } + public var AutoDownloadSettings_Channels: String { return self._s[3316]! } + public var Passport_Language_mn: String { return self._s[3317]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[3320]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3321]! } + public var Passport_Language_ja: String { return self._s[3323]! } + public var Settings_About_Title: String { return self._s[3324]! } + public var Settings_NotificationsAndSounds: String { return self._s[3325]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3326]! } + public var Settings_BlockedUsers: String { return self._s[3327]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3324]!, self._r[3324]!, [_0]) + return formatWithArgumentRanges(self._s[3328]!, self._r[3328]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3325]! } - public var Wallet_Weekday_Today: String { return self._s[3326]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3327]! } - public var Widget_ApplicationLocked: String { return self._s[3328]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3329]! } - public var Channel_Username_Title: String { return self._s[3330]! } + public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3329]! } + public var Wallet_Weekday_Today: String { return self._s[3330]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3331]! } + public var Widget_ApplicationLocked: String { return self._s[3332]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3333]! } + public var Channel_Username_Title: String { return self._s[3334]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3331]!, self._r[3331]!, [_0]) + return formatWithArgumentRanges(self._s[3335]!, self._r[3335]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3333]! } - public var AppleWatch_Title: String { return self._s[3334]! } - public var Activity_RecordingVideoMessage: String { return self._s[3335]! } + public var AttachmentMenu_File: String { return self._s[3337]! } + public var AppleWatch_Title: String { return self._s[3338]! } + public var Activity_RecordingVideoMessage: String { return self._s[3339]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3336]!, self._r[3336]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3340]!, self._r[3340]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3337]! } - public var Weekday_Saturday: String { return self._s[3338]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3339]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3340]! } - public var Common_Next: String { return self._s[3342]! } - public var Channel_Stickers_YourStickers: String { return self._s[3344]! } - public var Message_Theme: String { return self._s[3345]! } - public var Call_AudioRouteHeadphones: String { return self._s[3346]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3348]! } - public var Watch_Contacts_NoResults: String { return self._s[3350]! } - public var PhotoEditor_TintTool: String { return self._s[3353]! } - public var LoginPassword_ResetAccount: String { return self._s[3355]! } - public var Settings_SavedMessages: String { return self._s[3356]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3357]! } - public var Bot_GenericSupportStatus: String { return self._s[3358]! } - public var StickerPack_Add: String { return self._s[3359]! } - public var Checkout_TotalAmount: String { return self._s[3360]! } - public var Your_cards_number_is_invalid: String { return self._s[3361]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3362]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3363]! } + public var Theme_Colors_Messages: String { return self._s[3341]! } + public var Weekday_Saturday: String { return self._s[3342]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3343]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3344]! } + public var Common_Next: String { return self._s[3346]! } + public var Channel_Stickers_YourStickers: String { return self._s[3348]! } + public var Message_Theme: String { return self._s[3349]! } + public var Call_AudioRouteHeadphones: String { return self._s[3350]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3352]! } + public var Watch_Contacts_NoResults: String { return self._s[3354]! } + public var PhotoEditor_TintTool: String { return self._s[3357]! } + public var LoginPassword_ResetAccount: String { return self._s[3359]! } + public var Settings_SavedMessages: String { return self._s[3360]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3361]! } + public var Bot_GenericSupportStatus: String { return self._s[3362]! } + public var StickerPack_Add: String { return self._s[3363]! } + public var Checkout_TotalAmount: String { return self._s[3364]! } + public var Your_cards_number_is_invalid: String { return self._s[3365]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3366]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3367]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3364]!, self._r[3364]!, [_0]) + return formatWithArgumentRanges(self._s[3368]!, self._r[3368]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3365]!, self._r[3365]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3369]!, self._r[3369]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3366]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3370]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3368]!, self._r[3368]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3372]!, self._r[3372]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3369]!, self._r[3369]!, [_0]) + return formatWithArgumentRanges(self._s[3373]!, self._r[3373]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3370]! } - public var StickerPack_Share: String { return self._s[3371]! } - public var Passport_DeleteAddress: String { return self._s[3372]! } - public var Settings_Passport: String { return self._s[3373]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3374]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3375]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3376]! } - public var Contacts_PermissionsText: String { return self._s[3377]! } - public var Group_Setup_HistoryVisible: String { return self._s[3378]! } - public var Wallet_Month_ShortDecember: String { return self._s[3380]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3381]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3382]! } - public var SocksProxySetup_Title: String { return self._s[3383]! } - public var Notification_Mute1h: String { return self._s[3384]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3374]! } + public var StickerPack_Share: String { return self._s[3375]! } + public var Passport_DeleteAddress: String { return self._s[3376]! } + public var Settings_Passport: String { return self._s[3377]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3378]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3379]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3380]! } + public var Contacts_PermissionsText: String { return self._s[3381]! } + public var Group_Setup_HistoryVisible: String { return self._s[3382]! } + public var Wallet_Month_ShortDecember: String { return self._s[3384]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3385]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3386]! } + public var SocksProxySetup_Title: String { return self._s[3387]! } + public var Notification_Mute1h: String { return self._s[3388]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3385]!, self._r[3385]!, [_0]) + return formatWithArgumentRanges(self._s[3389]!, self._r[3389]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3386]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3390]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3387]!, self._r[3387]!, [_1]) + return formatWithArgumentRanges(self._s[3391]!, self._r[3391]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3388]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3391]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3393]! } - public var DialogList_NoMessagesText: String { return self._s[3394]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3395]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3396]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3398]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3399]! } - public var Common_TakePhotoOrVideo: String { return self._s[3400]! } - public var Wallet_Words_Text: String { return self._s[3401]! } - public var Call_StatusBusy: String { return self._s[3402]! } - public var Conversation_PinnedMessage: String { return self._s[3403]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3404]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3405]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3406]! } - public var Undo_ChatCleared: String { return self._s[3407]! } - public var AppleWatch_ReplyPresets: String { return self._s[3408]! } - public var Passport_DiscardMessageDescription: String { return self._s[3410]! } - public var Login_NetworkError: String { return self._s[3411]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3392]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3395]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3397]! } + public var DialogList_NoMessagesText: String { return self._s[3398]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3399]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3400]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3402]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3403]! } + public var Common_TakePhotoOrVideo: String { return self._s[3404]! } + public var Wallet_Words_Text: String { return self._s[3405]! } + public var Call_StatusBusy: String { return self._s[3406]! } + public var Conversation_PinnedMessage: String { return self._s[3407]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3408]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3409]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3410]! } + public var Undo_ChatCleared: String { return self._s[3411]! } + public var AppleWatch_ReplyPresets: String { return self._s[3412]! } + public var Passport_DiscardMessageDescription: String { return self._s[3414]! } + public var Login_NetworkError: String { return self._s[3415]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3412]!, self._r[3412]!, [_0]) + return formatWithArgumentRanges(self._s[3416]!, self._r[3416]!, [_0]) } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3413]!, self._r[3413]!, [_0]) + return formatWithArgumentRanges(self._s[3417]!, self._r[3417]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3414]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3416]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3417]! } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3418]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3420]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3421]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3419]!, self._r[3419]!, [_0]) + return formatWithArgumentRanges(self._s[3423]!, self._r[3423]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3420]! } - public var VoiceOver_Chat_Music: String { return self._s[3421]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3422]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3424]! } - public var ConversationMedia_Title: String { return self._s[3425]! } - public var EncryptionKey_Title: String { return self._s[3427]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3428]! } - public var Notification_Exceptions_AddException: String { return self._s[3429]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3430]! } - public var Profile_MessageLifetime1m: String { return self._s[3431]! } + public var Call_ConnectionErrorMessage: String { return self._s[3424]! } + public var VoiceOver_Chat_Music: String { return self._s[3425]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3426]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3428]! } + public var ConversationMedia_Title: String { return self._s[3429]! } + public var EncryptionKey_Title: String { return self._s[3431]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3432]! } + public var Notification_Exceptions_AddException: String { return self._s[3433]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3434]! } + public var Profile_MessageLifetime1m: String { return self._s[3435]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3432]!, self._r[3432]!, [_1]) + return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_1]) } - public var Month_GenMay: String { return self._s[3433]! } + public var Month_GenMay: String { return self._s[3437]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3434]!, self._r[3434]!, [_0]) + return formatWithArgumentRanges(self._s[3438]!, self._r[3438]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3435]! } - public var Wallet_Send_AddressInfo: String { return self._s[3436]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3437]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3438]! } + public var PeopleNearby_Users: String { return self._s[3439]! } + public var Wallet_Send_AddressInfo: String { return self._s[3440]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3441]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3442]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3440]!, self._r[3440]!, [_0]) + return formatWithArgumentRanges(self._s[3444]!, self._r[3444]!, [_0]) } - public var Conversation_EmptyPlaceholder: String { return self._s[3441]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3442]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3443]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3444]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3445]! } - public var Channel_JoinChannel: String { return self._s[3447]! } - public var Appearance_Animations: String { return self._s[3450]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3445]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3446]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3447]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3448]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3449]! } + public var Channel_JoinChannel: String { return self._s[3451]! } + public var Appearance_Animations: String { return self._s[3454]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3451]!, self._r[3451]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3455]!, self._r[3455]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3453]! } - public var Appearance_ShareTheme: String { return self._s[3454]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3455]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3457]! } - public var Passport_Address_Street: String { return self._s[3458]! } - public var Conversation_AddContact: String { return self._s[3459]! } - public var Login_PhonePlaceholder: String { return self._s[3460]! } - public var Channel_Members_InviteLink: String { return self._s[3462]! } - public var Bot_Stop: String { return self._s[3463]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3465]! } - public var Notification_PassportValueAddress: String { return self._s[3466]! } - public var Month_ShortJuly: String { return self._s[3467]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3468]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3469]! } - public var Passport_Identity_ReverseSide: String { return self._s[3470]! } - public var Watch_Stickers_Recents: String { return self._s[3473]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3475]! } - public var Map_SendThisLocation: String { return self._s[3476]! } + public var Stickers_GroupStickers: String { return self._s[3457]! } + public var Appearance_ShareTheme: String { return self._s[3458]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3459]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3461]! } + public var Passport_Address_Street: String { return self._s[3462]! } + public var Conversation_AddContact: String { return self._s[3463]! } + public var Login_PhonePlaceholder: String { return self._s[3464]! } + public var Channel_Members_InviteLink: String { return self._s[3466]! } + public var Bot_Stop: String { return self._s[3467]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3469]! } + public var Notification_PassportValueAddress: String { return self._s[3470]! } + public var Month_ShortJuly: String { return self._s[3471]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3472]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3473]! } + public var Passport_Identity_ReverseSide: String { return self._s[3474]! } + public var Watch_Stickers_Recents: String { return self._s[3477]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3479]! } + public var Map_SendThisLocation: String { return self._s[3480]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3477]!, self._r[3477]!, [_0]) - } - public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3478]!, self._r[3478]!, [_0]) - } - public var ConvertToSupergroup_Note: String { return self._s[3479]! } - public var Wallet_Intro_NotNow: String { return self._s[3480]! } - public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3481]!, self._r[3481]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3482]! } + public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3482]!, self._r[3482]!, [_0]) + } + public var ConvertToSupergroup_Note: String { return self._s[3483]! } + public var Wallet_Intro_NotNow: String { return self._s[3484]! } + public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3485]!, self._r[3485]!, [_0]) + } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3486]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3483]!, self._r[3483]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3487]!, self._r[3487]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3485]! } - public var Wallpaper_SearchShort: String { return self._s[3486]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3488]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3489]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3490]! } + public var Login_CallRequestState3: String { return self._s[3489]! } + public var Wallpaper_SearchShort: String { return self._s[3490]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3492]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3493]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3494]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3491]!, self._r[3491]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3495]!, self._r[3495]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3492]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3496]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3496]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3500]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3497]!, self._r[3497]!, [_0]) + return formatWithArgumentRanges(self._s[3501]!, self._r[3501]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3498]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3499]! } + public var Passport_CorrectErrors: String { return self._s[3502]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3503]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3500]!, self._r[3500]!, [_0]) + return formatWithArgumentRanges(self._s[3504]!, self._r[3504]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3501]! } - public var Channel_DiscussionGroup: String { return self._s[3502]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3503]! } + public var Map_SendMyCurrentLocation: String { return self._s[3505]! } + public var Channel_DiscussionGroup: String { return self._s[3506]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3507]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3504]!, self._r[3504]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3508]!, self._r[3508]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3505]! } - public var Permissions_NotificationsText_v0: String { return self._s[3506]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3507]! } - public var Appearance_AppIcon: String { return self._s[3508]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3509]! } - public var LoginPassword_FloodError: String { return self._s[3510]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3512]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3513]! } + public var SharedMedia_SearchNoResults: String { return self._s[3509]! } + public var Permissions_NotificationsText_v0: String { return self._s[3510]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3511]! } + public var Appearance_AppIcon: String { return self._s[3512]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3513]! } + public var LoginPassword_FloodError: String { return self._s[3514]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3516]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3517]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3514]!, self._r[3514]!, [_0]) - } - public var Passport_Language_bn: String { return self._s[3515]! } - public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3516]!, self._r[3516]!, [_0]) - } - public var ChatList_Context_Pin: String { return self._s[3517]! } - public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3518]!, self._r[3518]!, [_0]) } + public var Passport_Language_bn: String { return self._s[3519]! } + public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3520]!, self._r[3520]!, [_0]) + } + public var ChatList_Context_Pin: String { return self._s[3521]! } + public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3522]!, self._r[3522]!, [_0]) + } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3519]!, self._r[3519]!, [_0]) + return formatWithArgumentRanges(self._s[3523]!, self._r[3523]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3520]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3524]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3526]! } - public var Wallet_Month_GenDecember: String { return self._s[3527]! } - public var Contacts_PermissionsAllow: String { return self._s[3528]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3529]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3530]! } - public var WallpaperPreview_Pattern: String { return self._s[3531]! } - public var Paint_Duplicate: String { return self._s[3532]! } - public var Passport_Address_Country: String { return self._s[3533]! } - public var Notification_RenamedChannel: String { return self._s[3535]! } - public var ChatList_Context_Unmute: String { return self._s[3536]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3537]! } - public var Group_MessagePhotoUpdated: String { return self._s[3538]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3539]! } - public var Conversation_ContextMenuBan: String { return self._s[3540]! } - public var TwoStepAuth_EmailSent: String { return self._s[3541]! } - public var MessagePoll_NoVotes: String { return self._s[3542]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3543]! } - public var Passport_Language_is: String { return self._s[3544]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3546]! } - public var Tour_Text5: String { return self._s[3547]! } + public var Wallet_Navigation_Close: String { return self._s[3524]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3528]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3530]! } + public var Wallet_Month_GenDecember: String { return self._s[3531]! } + public var Contacts_PermissionsAllow: String { return self._s[3532]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3533]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3534]! } + public var WallpaperPreview_Pattern: String { return self._s[3535]! } + public var Paint_Duplicate: String { return self._s[3536]! } + public var Passport_Address_Country: String { return self._s[3537]! } + public var Notification_RenamedChannel: String { return self._s[3539]! } + public var ChatList_Context_Unmute: String { return self._s[3540]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3541]! } + public var Group_MessagePhotoUpdated: String { return self._s[3542]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3543]! } + public var Conversation_ContextMenuBan: String { return self._s[3544]! } + public var TwoStepAuth_EmailSent: String { return self._s[3545]! } + public var MessagePoll_NoVotes: String { return self._s[3546]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3547]! } + public var Passport_Language_is: String { return self._s[3548]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3550]! } + public var Tour_Text5: String { return self._s[3551]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3549]!, self._r[3549]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3553]!, self._r[3553]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3550]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3551]! } + public var Undo_SecretChatDeleted: String { return self._s[3554]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3555]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3552]!, self._r[3552]!, [_0]) + return formatWithArgumentRanges(self._s[3556]!, self._r[3556]!, [_0]) } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3553]! } - public var Paint_Edit: String { return self._s[3555]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3557]! } - public var Undo_DeletedGroup: String { return self._s[3559]! } - public var LoginPassword_ForgotPassword: String { return self._s[3560]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3561]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3562]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3557]! } + public var Paint_Edit: String { return self._s[3559]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3561]! } + public var Undo_DeletedGroup: String { return self._s[3563]! } + public var LoginPassword_ForgotPassword: String { return self._s[3564]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3565]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3566]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3563]!, self._r[3563]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3567]!, self._r[3567]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3564]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3565]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3566]! } - public var Passport_Language_uz: String { return self._s[3567]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3568]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3569]! } - public var Map_StopLiveLocation: String { return self._s[3571]! } - public var VoiceOver_MessageContextSend: String { return self._s[3573]! } - public var PasscodeSettings_Help: String { return self._s[3574]! } - public var NotificationsSound_Input: String { return self._s[3575]! } - public var Share_Title: String { return self._s[3578]! } - public var LogoutOptions_Title: String { return self._s[3579]! } - public var Wallet_Send_AddressText: String { return self._s[3580]! } - public var Login_TermsOfServiceAgree: String { return self._s[3581]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3582]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3583]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3584]! } - public var EnterPasscode_EnterTitle: String { return self._s[3585]! } + public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3568]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3569]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3570]! } + public var Passport_Language_uz: String { return self._s[3571]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3572]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3573]! } + public var Map_StopLiveLocation: String { return self._s[3575]! } + public var VoiceOver_MessageContextSend: String { return self._s[3577]! } + public var PasscodeSettings_Help: String { return self._s[3578]! } + public var NotificationsSound_Input: String { return self._s[3579]! } + public var Share_Title: String { return self._s[3582]! } + public var LogoutOptions_Title: String { return self._s[3583]! } + public var Wallet_Send_AddressText: String { return self._s[3584]! } + public var Login_TermsOfServiceAgree: String { return self._s[3585]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3586]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3587]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3588]! } + public var EnterPasscode_EnterTitle: String { return self._s[3589]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3586]!, self._r[3586]!, [_0]) + return formatWithArgumentRanges(self._s[3590]!, self._r[3590]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3587]! } - public var Conversation_AddToContacts: String { return self._s[3588]! } + public var Settings_CopyPhoneNumber: String { return self._s[3591]! } + public var Conversation_AddToContacts: String { return self._s[3592]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3589]!, self._r[3589]!, [_0]) + return formatWithArgumentRanges(self._s[3593]!, self._r[3593]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3590]! } + public var NotificationsSound_Keys: String { return self._s[3594]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3591]!, self._r[3591]!, [_0]) + return formatWithArgumentRanges(self._s[3595]!, self._r[3595]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[3592]! } - public var Message_Video: String { return self._s[3593]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3594]! } + public var Notification_MessageLifetime1w: String { return self._s[3596]! } + public var Message_Video: String { return self._s[3597]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3598]! } public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3595]!, self._r[3595]!, [_1]) + return formatWithArgumentRanges(self._s[3599]!, self._r[3599]!, [_1]) } - public var Wallet_Receive_AmountInfo: String { return self._s[3598]! } + public var Wallet_Receive_AmountInfo: String { return self._s[3602]! } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3599]!, self._r[3599]!, [_0]) + return formatWithArgumentRanges(self._s[3603]!, self._r[3603]!, [_0]) } public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3600]!, self._r[3600]!, [_0]) + return formatWithArgumentRanges(self._s[3604]!, self._r[3604]!, [_0]) } - public var Passport_Language_mk: String { return self._s[3601]! } + public var Passport_Language_mk: String { return self._s[3605]! } public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3602]!, self._r[3602]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3606]!, self._r[3606]!, [_1, _2, _3]) } - public var CreatePoll_CancelConfirmation: String { return self._s[3603]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3605]! } - public var PrivacyPolicy_Decline: String { return self._s[3606]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3607]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3608]! } - public var Permissions_SiriAllow_v0: String { return self._s[3610]! } - public var Wallet_Month_ShortAugust: String { return self._s[3611]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3612]! } + public var CreatePoll_CancelConfirmation: String { return self._s[3607]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3609]! } + public var PrivacyPolicy_Decline: String { return self._s[3610]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3611]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3612]! } + public var Permissions_SiriAllow_v0: String { return self._s[3614]! } + public var Wallet_Month_ShortAugust: String { return self._s[3615]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3616]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3613]!, self._r[3613]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3617]!, self._r[3617]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3614]!, self._r[3614]!, [_0]) + return formatWithArgumentRanges(self._s[3618]!, self._r[3618]!, [_0]) } - public var Paint_Regular: String { return self._s[3615]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3616]! } - public var SocksProxySetup_ShareLink: String { return self._s[3617]! } - public var Wallet_Qr_Title: String { return self._s[3618]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3619]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3621]! } - public var Wallet_Settings_Configuration: String { return self._s[3622]! } - public var GroupInfo_InviteByLink: String { return self._s[3623]! } - public var MessageTimer_Custom: String { return self._s[3624]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3625]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3627]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3628]! } - public var VoiceOver_Chat_Selected: String { return self._s[3629]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3630]! } - public var Channel_Username_InvalidTaken: String { return self._s[3631]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3632]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3633]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[3634]! } - public var Settings_ChatBackground: String { return self._s[3635]! } - public var Channel_Subscribers_Title: String { return self._s[3636]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3637]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3638]! } - public var Watch_ConnectionDescription: String { return self._s[3639]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3642]! } - public var IntentsSettings_SuggestBy: String { return self._s[3644]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3645]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3646]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[3647]! } - public var EditProfile_Title: String { return self._s[3648]! } - public var NotificationsSound_Bamboo: String { return self._s[3650]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3652]! } - public var Login_SmsRequestState2: String { return self._s[3653]! } - public var Passport_Language_ar: String { return self._s[3654]! } + public var Paint_Regular: String { return self._s[3619]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3620]! } + public var SocksProxySetup_ShareLink: String { return self._s[3621]! } + public var Wallet_Qr_Title: String { return self._s[3622]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3623]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3625]! } + public var Wallet_Settings_Configuration: String { return self._s[3626]! } + public var GroupInfo_InviteByLink: String { return self._s[3627]! } + public var MessageTimer_Custom: String { return self._s[3628]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3629]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3631]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3632]! } + public var VoiceOver_Chat_Selected: String { return self._s[3633]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3634]! } + public var Channel_Username_InvalidTaken: String { return self._s[3635]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3636]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3637]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[3638]! } + public var Settings_ChatBackground: String { return self._s[3639]! } + public var Channel_Subscribers_Title: String { return self._s[3640]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3641]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3642]! } + public var Watch_ConnectionDescription: String { return self._s[3643]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3646]! } + public var IntentsSettings_SuggestBy: String { return self._s[3648]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3649]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3650]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[3651]! } + public var EditProfile_Title: String { return self._s[3652]! } + public var NotificationsSound_Bamboo: String { return self._s[3654]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3656]! } + public var Login_SmsRequestState2: String { return self._s[3657]! } + public var Passport_Language_ar: String { return self._s[3658]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3655]!, self._r[3655]!, [_0]) + return formatWithArgumentRanges(self._s[3659]!, self._r[3659]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3656]! } - public var Wallet_Created_Text: String { return self._s[3657]! } - public var Conversation_MessageDialogEdit: String { return self._s[3659]! } - public var Wallet_Created_Proceed: String { return self._s[3660]! } - public var Wallet_Words_Done: String { return self._s[3661]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3662]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3660]! } + public var Wallet_Created_Text: String { return self._s[3661]! } + public var Conversation_MessageDialogEdit: String { return self._s[3663]! } + public var Wallet_Created_Proceed: String { return self._s[3664]! } + public var Wallet_Words_Done: String { return self._s[3665]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3666]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3663]!, self._r[3663]!, [_1]) + return formatWithArgumentRanges(self._s[3667]!, self._r[3667]!, [_1]) } - public var Common_Close: String { return self._s[3664]! } - public var GroupInfo_PublicLink: String { return self._s[3665]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3666]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3667]! } + public var Common_Close: String { return self._s[3668]! } + public var GroupInfo_PublicLink: String { return self._s[3669]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3670]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3671]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3671]!, self._r[3671]!, [_0]) + return formatWithArgumentRanges(self._s[3675]!, self._r[3675]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3672]! } + public var UserInfo_About_Placeholder: String { return self._s[3676]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3673]!, self._r[3673]!, [_0]) - } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3674]! } - public var Channel_Info_Banned: String { return self._s[3676]! } - public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3677]!, self._r[3677]!, [_0]) } - public var Appearance_Other: String { return self._s[3678]! } - public var Passport_Language_my: String { return self._s[3679]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3680]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[3678]! } + public var Channel_Info_Banned: String { return self._s[3680]! } + public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3681]!, self._r[3681]!, [_0]) + } + public var Appearance_Other: String { return self._s[3682]! } + public var Passport_Language_my: String { return self._s[3683]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3684]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3681]!, self._r[3681]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3685]!, self._r[3685]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3682]! } - public var Preview_CopyAddress: String { return self._s[3683]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3686]! } + public var Preview_CopyAddress: String { return self._s[3687]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3684]!, self._r[3684]!, [_0]) + return formatWithArgumentRanges(self._s[3688]!, self._r[3688]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3685]! } - public var UserInfo_BotSettings: String { return self._s[3686]! } - public var LiveLocation_MenuStopAll: String { return self._s[3688]! } - public var Passport_PasswordCreate: String { return self._s[3689]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3690]! } - public var Message_PinnedLocationMessage: String { return self._s[3691]! } - public var Map_Satellite: String { return self._s[3692]! } - public var Watch_Message_Unsupported: String { return self._s[3693]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3694]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3695]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3689]! } + public var UserInfo_BotSettings: String { return self._s[3690]! } + public var LiveLocation_MenuStopAll: String { return self._s[3692]! } + public var Passport_PasswordCreate: String { return self._s[3693]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3694]! } + public var Message_PinnedLocationMessage: String { return self._s[3695]! } + public var Map_Satellite: String { return self._s[3696]! } + public var Watch_Message_Unsupported: String { return self._s[3697]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3698]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3699]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3696]!, self._r[3696]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3700]!, self._r[3700]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3697]!, self._r[3697]!, [_0]) + return formatWithArgumentRanges(self._s[3701]!, self._r[3701]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[3698]! } + public var Wallet_WordImport_Continue: String { return self._s[3702]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3699]!, self._r[3699]!, [_0]) + return formatWithArgumentRanges(self._s[3703]!, self._r[3703]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3700]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3701]! } - public var NotificationsSound_None: String { return self._s[3702]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3703]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3705]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3706]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[3704]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3705]! } + public var NotificationsSound_None: String { return self._s[3706]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3707]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3709]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3710]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3707]!, self._r[3707]!, [_1]) + return formatWithArgumentRanges(self._s[3711]!, self._r[3711]!, [_1]) } - public var Cache_Indexing: String { return self._s[3708]! } - public var DialogList_RecentTitlePeople: String { return self._s[3710]! } - public var DialogList_EncryptionRejected: String { return self._s[3711]! } - public var GroupInfo_Administrators: String { return self._s[3712]! } - public var Passport_ScanPassportHelp: String { return self._s[3713]! } - public var Application_Name: String { return self._s[3714]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3715]! } - public var Appearance_ThemeCarouselDay: String { return self._s[3717]! } - public var Passport_Identity_TranslationHelp: String { return self._s[3718]! } + public var Cache_Indexing: String { return self._s[3712]! } + public var DialogList_RecentTitlePeople: String { return self._s[3714]! } + public var DialogList_EncryptionRejected: String { return self._s[3715]! } + public var GroupInfo_Administrators: String { return self._s[3716]! } + public var Passport_ScanPassportHelp: String { return self._s[3717]! } + public var Application_Name: String { return self._s[3718]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3719]! } + public var Appearance_ThemeCarouselDay: String { return self._s[3721]! } + public var Passport_Identity_TranslationHelp: String { return self._s[3722]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3719]!, self._r[3719]!, [_0]) + return formatWithArgumentRanges(self._s[3723]!, self._r[3723]!, [_0]) } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3720]!, self._r[3720]!, [_0]) + return formatWithArgumentRanges(self._s[3724]!, self._r[3724]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3721]!, self._r[3721]!, [_0]) + return formatWithArgumentRanges(self._s[3725]!, self._r[3725]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3722]! } - public var Privacy_ChatsTitle: String { return self._s[3723]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[3724]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3725]! } - public var Watch_Suggestion_HoldOn: String { return self._s[3726]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[3727]! } - public var WebBrowser_Title: String { return self._s[3728]! } - public var Group_LinkedChannel: String { return self._s[3729]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3730]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[3731]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3732]! } - public var Appearance_TextSize_UseSystem: String { return self._s[3733]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[3734]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[3736]! } - public var Channel_Setup_TypePublic: String { return self._s[3738]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3726]! } + public var Privacy_ChatsTitle: String { return self._s[3727]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[3728]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3729]! } + public var Watch_Suggestion_HoldOn: String { return self._s[3730]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[3731]! } + public var WebBrowser_Title: String { return self._s[3732]! } + public var Group_LinkedChannel: String { return self._s[3733]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3734]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[3735]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3736]! } + public var Appearance_TextSize_UseSystem: String { return self._s[3737]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[3738]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[3740]! } + public var Channel_Setup_TypePublic: String { return self._s[3742]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3739]!, self._r[3739]!, [_0]) + return formatWithArgumentRanges(self._s[3743]!, self._r[3743]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[3741]! } - public var Map_OpenInMaps: String { return self._s[3743]! } + public var Channel_TypeSetup_Title: String { return self._s[3745]! } + public var Map_OpenInMaps: String { return self._s[3747]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3744]!, self._r[3744]!, [_1]) + return formatWithArgumentRanges(self._s[3748]!, self._r[3748]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[3746]! } + public var NotificationsSound_Tremolo: String { return self._s[3750]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3747]!, self._r[3747]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3751]!, self._r[3751]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[3748]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3749]! } - public var Passport_PasswordHelp: String { return self._s[3750]! } - public var Login_CodeExpiredError: String { return self._s[3751]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3752]! } - public var Conversation_TitleUnmute: String { return self._s[3753]! } - public var Passport_Identity_ScansHelp: String { return self._s[3754]! } - public var Passport_Language_lo: String { return self._s[3755]! } - public var Camera_FlashAuto: String { return self._s[3756]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[3757]! } - public var Common_Cancel: String { return self._s[3758]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[3759]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3760]! } - public var Appearance_TintAllColors: String { return self._s[3761]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[3752]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3753]! } + public var Passport_PasswordHelp: String { return self._s[3754]! } + public var Login_CodeExpiredError: String { return self._s[3755]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3756]! } + public var Conversation_TitleUnmute: String { return self._s[3757]! } + public var Passport_Identity_ScansHelp: String { return self._s[3758]! } + public var Passport_Language_lo: String { return self._s[3759]! } + public var Camera_FlashAuto: String { return self._s[3760]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[3761]! } + public var Common_Cancel: String { return self._s[3762]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[3763]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3764]! } + public var Appearance_TintAllColors: String { return self._s[3765]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3762]!, self._r[3762]!, [_1]) + return formatWithArgumentRanges(self._s[3766]!, self._r[3766]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[3763]! } - public var ChatSettings_Title: String { return self._s[3765]! } - public var Passport_PasswordReset: String { return self._s[3766]! } - public var SocksProxySetup_TypeNone: String { return self._s[3767]! } - public var EditTheme_Title: String { return self._s[3769]! } - public var PhoneNumberHelp_Help: String { return self._s[3770]! } - public var Checkout_EnterPassword: String { return self._s[3771]! } - public var Share_AuthTitle: String { return self._s[3773]! } - public var Activity_UploadingDocument: String { return self._s[3774]! } - public var State_Connecting: String { return self._s[3775]! } - public var Profile_MessageLifetime1w: String { return self._s[3776]! } - public var Conversation_ContextMenuReport: String { return self._s[3777]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3778]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[3779]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[3767]! } + public var ChatSettings_Title: String { return self._s[3769]! } + public var Passport_PasswordReset: String { return self._s[3770]! } + public var SocksProxySetup_TypeNone: String { return self._s[3771]! } + public var EditTheme_Title: String { return self._s[3773]! } + public var PhoneNumberHelp_Help: String { return self._s[3774]! } + public var Checkout_EnterPassword: String { return self._s[3775]! } + public var Share_AuthTitle: String { return self._s[3777]! } + public var Activity_UploadingDocument: String { return self._s[3778]! } + public var State_Connecting: String { return self._s[3779]! } + public var Profile_MessageLifetime1w: String { return self._s[3780]! } + public var Conversation_ContextMenuReport: String { return self._s[3781]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3782]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[3783]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3780]!, self._r[3780]!, [_0]) + return formatWithArgumentRanges(self._s[3784]!, self._r[3784]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[3781]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[3782]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3784]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3785]! } - public var PhotoEditor_Set: String { return self._s[3786]! } - public var EmptyGroupInfo_Title: String { return self._s[3787]! } - public var Login_PadPhoneHelp: String { return self._s[3788]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3790]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3792]! } - public var NotificationsSound_Complete: String { return self._s[3793]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3794]! } - public var Group_Info_AdminLog: String { return self._s[3795]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3796]! } + public var AuthSessions_Terminate: String { return self._s[3785]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[3786]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3788]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3789]! } + public var PhotoEditor_Set: String { return self._s[3790]! } + public var EmptyGroupInfo_Title: String { return self._s[3791]! } + public var Login_PadPhoneHelp: String { return self._s[3792]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3794]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3796]! } + public var NotificationsSound_Complete: String { return self._s[3797]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3798]! } + public var Group_Info_AdminLog: String { return self._s[3799]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3800]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3797]!, self._r[3797]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3801]!, self._r[3801]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3798]! } - public var Group_Location_CreateInThisPlace: String { return self._s[3800]! } - public var Conversation_Admin: String { return self._s[3801]! } - public var Conversation_GifTooltip: String { return self._s[3802]! } - public var Passport_NotLoggedInMessage: String { return self._s[3803]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3802]! } + public var Group_Location_CreateInThisPlace: String { return self._s[3804]! } + public var Conversation_Admin: String { return self._s[3805]! } + public var Conversation_GifTooltip: String { return self._s[3806]! } + public var Passport_NotLoggedInMessage: String { return self._s[3807]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3805]!, self._r[3805]!, [_0]) + return formatWithArgumentRanges(self._s[3809]!, self._r[3809]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[3806]! } - public var SharedMedia_EmptyTitle: String { return self._s[3808]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3810]! } - public var Username_Help: String { return self._s[3811]! } - public var DialogList_LanguageTooltip: String { return self._s[3813]! } - public var Map_LoadError: String { return self._s[3814]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3815]! } - public var Channel_AdminLog_AddMembers: String { return self._s[3816]! } - public var ArchivedChats_IntroTitle2: String { return self._s[3817]! } - public var Notification_Exceptions_NewException: String { return self._s[3818]! } - public var TwoStepAuth_EmailTitle: String { return self._s[3819]! } - public var WatchRemote_AlertText: String { return self._s[3820]! } + public var Profile_MessageLifetimeForever: String { return self._s[3810]! } + public var SharedMedia_EmptyTitle: String { return self._s[3812]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3814]! } + public var Username_Help: String { return self._s[3815]! } + public var DialogList_LanguageTooltip: String { return self._s[3817]! } + public var Map_LoadError: String { return self._s[3818]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3819]! } + public var Channel_AdminLog_AddMembers: String { return self._s[3820]! } + public var ArchivedChats_IntroTitle2: String { return self._s[3821]! } + public var Notification_Exceptions_NewException: String { return self._s[3822]! } + public var TwoStepAuth_EmailTitle: String { return self._s[3823]! } + public var WatchRemote_AlertText: String { return self._s[3824]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3821]!, self._r[3821]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3825]!, self._r[3825]!, [_1, _2, _3]) } - public var ChatSettings_ConnectionType_Title: String { return self._s[3825]! } - public var WebBrowser_DefaultBrowser: String { return self._s[3826]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[3829]! } + public var WebBrowser_DefaultBrowser: String { return self._s[3830]! } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3827]!, self._r[3827]!, [_0]) + return formatWithArgumentRanges(self._s[3831]!, self._r[3831]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3828]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[3829]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3832]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[3833]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3830]!, self._r[3830]!, [_0]) + return formatWithArgumentRanges(self._s[3834]!, self._r[3834]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3831]!, self._r[3831]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3835]!, self._r[3835]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[3832]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3833]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[3835]! } - public var Wallet_Created_ExportErrorText: String { return self._s[3836]! } - public var ChatList_UndoArchiveText1: String { return self._s[3837]! } - public var AccessDenied_VideoMicrophone: String { return self._s[3838]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3839]! } - public var Cache_ClearNone: String { return self._s[3840]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[3841]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[3842]! } + public var Group_AdminLog_EmptyText: String { return self._s[3836]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3837]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[3839]! } + public var Wallet_Created_ExportErrorText: String { return self._s[3840]! } + public var ChatList_UndoArchiveText1: String { return self._s[3841]! } + public var AccessDenied_VideoMicrophone: String { return self._s[3842]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3843]! } + public var Cache_ClearNone: String { return self._s[3844]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[3845]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[3846]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3843]!, self._r[3843]!, [_0]) + return formatWithArgumentRanges(self._s[3847]!, self._r[3847]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[3844]! } + public var Passport_Identity_Country: String { return self._s[3848]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3845]!, self._r[3845]!, [_0]) + return formatWithArgumentRanges(self._s[3849]!, self._r[3849]!, [_0]) } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3846]!, self._r[3846]!, [_0]) + return formatWithArgumentRanges(self._s[3850]!, self._r[3850]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[3847]! } - public var AccessDenied_Settings: String { return self._s[3848]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3849]! } - public var Month_ShortMay: String { return self._s[3850]! } - public var Compose_NewGroup: String { return self._s[3852]! } - public var Group_Setup_TypePrivate: String { return self._s[3854]! } - public var Login_PadPhoneHelpTitle: String { return self._s[3856]! } - public var Appearance_ThemeDayClassic: String { return self._s[3857]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3858]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[3859]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3860]! } - public var Conversation_typing: String { return self._s[3862]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[3863]! } - public var Paint_Masks: String { return self._s[3864]! } - public var Contacts_DeselectAll: String { return self._s[3865]! } + public var Exceptions_AddToExceptions: String { return self._s[3851]! } + public var AccessDenied_Settings: String { return self._s[3852]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3853]! } + public var Month_ShortMay: String { return self._s[3854]! } + public var Compose_NewGroup: String { return self._s[3856]! } + public var Group_Setup_TypePrivate: String { return self._s[3858]! } + public var Login_PadPhoneHelpTitle: String { return self._s[3860]! } + public var Appearance_ThemeDayClassic: String { return self._s[3861]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3862]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[3863]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3864]! } + public var Conversation_typing: String { return self._s[3866]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[3867]! } + public var Paint_Masks: String { return self._s[3868]! } + public var Contacts_DeselectAll: String { return self._s[3869]! } public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3866]!, self._r[3866]!, [_0]) + return formatWithArgumentRanges(self._s[3870]!, self._r[3870]!, [_0]) } - public var Username_InvalidTaken: String { return self._s[3867]! } - public var Call_StatusNoAnswer: String { return self._s[3868]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[3869]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3870]! } - public var Passport_Identity_Selfie: String { return self._s[3871]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[3872]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3873]! } - public var Conversation_ClearSecretHistory: String { return self._s[3874]! } - public var PeopleNearby_Description: String { return self._s[3876]! } - public var NetworkUsageSettings_Title: String { return self._s[3877]! } - public var Your_cards_security_code_is_invalid: String { return self._s[3879]! } + public var Username_InvalidTaken: String { return self._s[3871]! } + public var Call_StatusNoAnswer: String { return self._s[3872]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[3873]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3874]! } + public var Passport_Identity_Selfie: String { return self._s[3875]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[3876]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3877]! } + public var Conversation_ClearSecretHistory: String { return self._s[3878]! } + public var PeopleNearby_Description: String { return self._s[3880]! } + public var NetworkUsageSettings_Title: String { return self._s[3881]! } + public var Your_cards_security_code_is_invalid: String { return self._s[3883]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3881]!, self._r[3881]!, [_0]) + return formatWithArgumentRanges(self._s[3885]!, self._r[3885]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3882]!, self._r[3882]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3886]!, self._r[3886]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[3884]! } - public var VoiceOver_Navigation_Search: String { return self._s[3885]! } - public var Map_LiveLocationTitle: String { return self._s[3886]! } - public var Login_InfoAvatarAdd: String { return self._s[3887]! } - public var Passport_Identity_FilesView: String { return self._s[3888]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[3889]! } - public var Privacy_Calls_NeverAllow: String { return self._s[3890]! } - public var VoiceOver_Chat_File: String { return self._s[3891]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[3892]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[3888]! } + public var VoiceOver_Navigation_Search: String { return self._s[3889]! } + public var Map_LiveLocationTitle: String { return self._s[3890]! } + public var Login_InfoAvatarAdd: String { return self._s[3891]! } + public var Passport_Identity_FilesView: String { return self._s[3892]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[3893]! } + public var Privacy_Calls_NeverAllow: String { return self._s[3894]! } + public var VoiceOver_Chat_File: String { return self._s[3895]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[3896]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3893]!, self._r[3893]!, [_0]) + return formatWithArgumentRanges(self._s[3897]!, self._r[3897]!, [_0]) } - public var ContactInfo_PhoneNumberHidden: String { return self._s[3894]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[3895]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3896]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[3898]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[3899]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3900]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3897]!, self._r[3897]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3901]!, self._r[3901]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3898]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[3899]! } - public var Tour_Title2: String { return self._s[3900]! } - public var Wallet_Sent_ViewWallet: String { return self._s[3901]! } - public var Conversation_FileOpenIn: String { return self._s[3902]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3903]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[3904]! } - public var Wallpaper_Set: String { return self._s[3905]! } - public var Passport_Identity_Translations: String { return self._s[3907]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3902]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[3903]! } + public var Tour_Title2: String { return self._s[3904]! } + public var Wallet_Sent_ViewWallet: String { return self._s[3905]! } + public var Conversation_FileOpenIn: String { return self._s[3906]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3907]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[3908]! } + public var Wallpaper_Set: String { return self._s[3909]! } + public var Passport_Identity_Translations: String { return self._s[3911]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3908]!, self._r[3908]!, [_0]) + return formatWithArgumentRanges(self._s[3912]!, self._r[3912]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[3909]! } + public var Channel_LeaveChannel: String { return self._s[3913]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3910]!, self._r[3910]!, [_1]) + return formatWithArgumentRanges(self._s[3914]!, self._r[3914]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3912]! } - public var PhotoEditor_HighlightsTint: String { return self._s[3913]! } - public var Passport_Email_Delete: String { return self._s[3914]! } - public var Conversation_Mute: String { return self._s[3916]! } - public var Channel_AddBotAsAdmin: String { return self._s[3917]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[3919]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[3920]! } - public var Channel_Management_LabelOwner: String { return self._s[3922]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3916]! } + public var PhotoEditor_HighlightsTint: String { return self._s[3917]! } + public var Passport_Email_Delete: String { return self._s[3918]! } + public var Conversation_Mute: String { return self._s[3920]! } + public var Channel_AddBotAsAdmin: String { return self._s[3921]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[3923]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[3924]! } + public var Channel_Management_LabelOwner: String { return self._s[3926]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3923]!, self._r[3923]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3927]!, self._r[3927]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[3924]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[3925]! } - public var Common_No: String { return self._s[3926]! } - public var Weekday_Sunday: String { return self._s[3927]! } - public var Notification_Reply: String { return self._s[3928]! } - public var Conversation_ViewMessage: String { return self._s[3929]! } + public var Calls_CallTabDescription: String { return self._s[3928]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[3929]! } + public var Common_No: String { return self._s[3930]! } + public var Weekday_Sunday: String { return self._s[3931]! } + public var Notification_Reply: String { return self._s[3932]! } + public var Conversation_ViewMessage: String { return self._s[3933]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3930]!, self._r[3930]!, [_0]) + return formatWithArgumentRanges(self._s[3934]!, self._r[3934]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3931]!, self._r[3931]!, [_0]) + return formatWithArgumentRanges(self._s[3935]!, self._r[3935]!, [_0]) } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3932]!, self._r[3932]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3936]!, self._r[3936]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3933]! } - public var Wallet_Send_Title: String { return self._s[3934]! } - public var Message_PinnedDocumentMessage: String { return self._s[3935]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[3936]! } - public var DialogList_TabTitle: String { return self._s[3938]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[3939]! } - public var Passport_FieldEmail: String { return self._s[3940]! } - public var Conversation_UnpinMessageAlert: String { return self._s[3941]! } - public var Passport_Address_TypeBankStatement: String { return self._s[3942]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[3943]! } - public var Passport_Identity_ExpiryDate: String { return self._s[3944]! } - public var Privacy_Calls_P2P: String { return self._s[3945]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3937]! } + public var Wallet_Send_Title: String { return self._s[3938]! } + public var Message_PinnedDocumentMessage: String { return self._s[3939]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[3940]! } + public var DialogList_TabTitle: String { return self._s[3942]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[3943]! } + public var Passport_FieldEmail: String { return self._s[3944]! } + public var Conversation_UnpinMessageAlert: String { return self._s[3945]! } + public var Passport_Address_TypeBankStatement: String { return self._s[3946]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[3947]! } + public var Passport_Identity_ExpiryDate: String { return self._s[3948]! } + public var Privacy_Calls_P2P: String { return self._s[3949]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3947]!, self._r[3947]!, [_0]) + return formatWithArgumentRanges(self._s[3951]!, self._r[3951]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[3948]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[3952]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3949]!, self._r[3949]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3953]!, self._r[3953]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[3950]! } - public var EnterPasscode_ChangeTitle: String { return self._s[3951]! } - public var TwoFactorSetup_Email_Title: String { return self._s[3952]! } - public var Passport_InfoText: String { return self._s[3953]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3954]! } + public var Stickers_ClearRecent: String { return self._s[3954]! } + public var EnterPasscode_ChangeTitle: String { return self._s[3955]! } + public var TwoFactorSetup_Email_Title: String { return self._s[3956]! } + public var Passport_InfoText: String { return self._s[3957]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3958]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3955]!, self._r[3955]!, [_0]) + return formatWithArgumentRanges(self._s[3959]!, self._r[3959]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3956]!, self._r[3956]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3960]!, self._r[3960]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3957]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[3958]! } - public var VoiceOver_Navigation_Compose: String { return self._s[3959]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[3960]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[3962]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[3963]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3961]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[3962]! } + public var VoiceOver_Navigation_Compose: String { return self._s[3963]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[3964]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[3966]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[3967]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3964]!, self._r[3964]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3968]!, self._r[3968]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3966]! } - public var ChatSettings_OpenLinksIn: String { return self._s[3967]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3970]! } + public var ChatSettings_OpenLinksIn: String { return self._s[3971]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3969]!, self._r[3969]!, [_0]) + return formatWithArgumentRanges(self._s[3973]!, self._r[3973]!, [_0]) } - public var DialogList_Unread: String { return self._s[3970]! } + public var DialogList_Unread: String { return self._s[3974]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3971]!, self._r[3971]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3975]!, self._r[3975]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[3972]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[3973]! } + public var User_DeletedAccount: String { return self._s[3976]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[3977]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3974]!, self._r[3974]!, [_0]) + return formatWithArgumentRanges(self._s[3978]!, self._r[3978]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[3975]! } - public var SharedMedia_CategoryMedia: String { return self._s[3976]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[3977]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[3978]! } - public var Watch_ChatList_Compose: String { return self._s[3979]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[3980]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[3981]! } - public var Watch_Microphone_Access: String { return self._s[3982]! } - public var Group_Setup_HistoryHeader: String { return self._s[3983]! } - public var Map_SetThisLocation: String { return self._s[3984]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[3985]! } - public var Activity_UploadingPhoto: String { return self._s[3986]! } - public var Conversation_Edit: String { return self._s[3988]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[3989]! } - public var Login_TermsOfServiceDecline: String { return self._s[3990]! } - public var Message_PinnedContactMessage: String { return self._s[3991]! } + public var UserInfo_NotificationsDefault: String { return self._s[3979]! } + public var SharedMedia_CategoryMedia: String { return self._s[3980]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[3981]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[3982]! } + public var Watch_ChatList_Compose: String { return self._s[3983]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[3984]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[3985]! } + public var Watch_Microphone_Access: String { return self._s[3986]! } + public var Group_Setup_HistoryHeader: String { return self._s[3987]! } + public var Map_SetThisLocation: String { return self._s[3988]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[3989]! } + public var Activity_UploadingPhoto: String { return self._s[3990]! } + public var Conversation_Edit: String { return self._s[3992]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[3993]! } + public var Login_TermsOfServiceDecline: String { return self._s[3994]! } + public var Message_PinnedContactMessage: String { return self._s[3995]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3992]!, self._r[3992]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3996]!, self._r[3996]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3993]!, self._r[3993]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[3997]!, self._r[3997]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[3994]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[3996]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[3997]! } + public var Appearance_LargeEmoji: String { return self._s[3998]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4000]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4001]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3998]!, self._r[3998]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4002]!, self._r[4002]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[3999]! } - public var Message_PinnedPhotoMessage: String { return self._s[4000]! } - public var Passport_FieldPhone: String { return self._s[4001]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4002]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4003]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4005]! } - public var Conversation_Call: String { return self._s[4006]! } - public var Common_TakePhoto: String { return self._s[4008]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4009]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4010]! } - public var Channel_NotificationLoading: String { return self._s[4011]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[4003]! } + public var Message_PinnedPhotoMessage: String { return self._s[4004]! } + public var Passport_FieldPhone: String { return self._s[4005]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4006]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4007]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4009]! } + public var Conversation_Call: String { return self._s[4010]! } + public var Common_TakePhoto: String { return self._s[4012]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4013]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4014]! } + public var Channel_NotificationLoading: String { return self._s[4015]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4012]!, self._r[4012]!, [_0]) - } - public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4013]!, self._r[4013]!, [_0]) - } - public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4014]!, self._r[4014]!, [_1]) - } - public var Permissions_SiriTitle_v0: String { return self._s[4015]! } - public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4016]!, self._r[4016]!, [_0]) } - public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4017]!, self._r[4017]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4018]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4019]! } - public var ClearCache_FreeSpace: String { return self._s[4020]! } - public var Common_edit: String { return self._s[4021]! } - public var PrivacySettings_AuthSessions: String { return self._s[4022]! } - public var Month_ShortJune: String { return self._s[4023]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4024]! } - public var Call_ReportSend: String { return self._s[4025]! } - public var Watch_LastSeen_JustNow: String { return self._s[4026]! } - public var Notifications_MessageNotifications: String { return self._s[4027]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4028]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4030]! } - public var Group_Status: String { return self._s[4031]! } + public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4018]!, self._r[4018]!, [_1]) + } + public var Permissions_SiriTitle_v0: String { return self._s[4019]! } + public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4020]!, self._r[4020]!, [_0]) + } + public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4021]!, self._r[4021]!, [_0]) + } + public var Channel_MessagePhotoRemoved: String { return self._s[4022]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4023]! } + public var ClearCache_FreeSpace: String { return self._s[4024]! } + public var Common_edit: String { return self._s[4025]! } + public var PrivacySettings_AuthSessions: String { return self._s[4026]! } + public var Month_ShortJune: String { return self._s[4027]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4028]! } + public var Call_ReportSend: String { return self._s[4029]! } + public var Watch_LastSeen_JustNow: String { return self._s[4030]! } + public var Notifications_MessageNotifications: String { return self._s[4031]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4032]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4034]! } + public var Group_Status: String { return self._s[4035]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4032]!, self._r[4032]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4036]!, self._r[4036]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4033]! } - public var ShareMenu_ShareTo: String { return self._s[4034]! } - public var Conversation_Moderate_Ban: String { return self._s[4035]! } + public var TextFormat_AddLinkTitle: String { return self._s[4037]! } + public var ShareMenu_ShareTo: String { return self._s[4038]! } + public var Conversation_Moderate_Ban: String { return self._s[4039]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4036]!, self._r[4036]!, [_0]) + return formatWithArgumentRanges(self._s[4040]!, self._r[4040]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4037]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4038]! } + public var SharedMedia_ViewInChat: String { return self._s[4041]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4042]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4039]!, self._r[4039]!, [_1]) + return formatWithArgumentRanges(self._s[4043]!, self._r[4043]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4040]!, self._r[4040]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4044]!, self._r[4044]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4042]!, self._r[4042]!, [_0]) + return formatWithArgumentRanges(self._s[4046]!, self._r[4046]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4043]! } - public var Appearance_ReduceMotion: String { return self._s[4044]! } + public var Map_OpenInHereMaps: String { return self._s[4047]! } + public var Appearance_ReduceMotion: String { return self._s[4048]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4045]!, self._r[4045]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4049]!, self._r[4049]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4046]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4047]! } - public var PhotoEditor_Skip: String { return self._s[4048]! } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + public var Channel_Setup_TypePublicHelp: String { return self._s[4050]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4051]! } + public var PhotoEditor_Skip: String { return self._s[4052]! } + public func SharedMedia_Video(_ 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_Months(_ value: Int32) -> String { + public func AttachmentMenu_SendPhoto(_ 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 Call_ShortSeconds(_ value: Int32) -> String { + public func MessageTimer_ShortDays(_ 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 ServiceMessage_GameScoreExtended(_ 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[3 * 6 + Int(form.rawValue)]!, stringValue) } - 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[4 * 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[5 * 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[6 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveStickerCount(_ 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 StickerPack_StickerCount(_ 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 MessageTimer_Years(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_ShortMinutes(_ 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 Forward_ConfirmMultipleFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[11 * 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[12 * 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[13 * 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[14 * 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[15 * 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[16 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ForwardedFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[17 * 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[18 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - 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[19 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortWeeks(_ 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 Call_Minutes(_ 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 UserCount(_ 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 MessageTimer_Seconds(_ 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 Conversation_SelectedMessages(_ 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 ForwardedAudios(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[25 * 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[26 * 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[27 * 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[28 * 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[29 * 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[30 * 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[31 * 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[32 * 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[33 * 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[34 * 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[35 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[36 * 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[37 * 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[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 Conversation_StatusOnline(_ 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 ForwardedPolls(_ 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 Theme_UsersCount(_ 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 LastSeen_HoursAgo(_ 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) + return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, _1, _2) } 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[44 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[5 * 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[6 * 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[7 * 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[8 * 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[9 * 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[10 * 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[11 * 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[12 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSelfSimple(_ 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 SharedMedia_DeleteItemsConfirmation(_ 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 MessageTimer_Years(_ 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 SharedMedia_Link(_ 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 ChatList_DeletedChats(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + 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 LastSeen_HoursAgo(_ 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 ForwardedVideoMessages(_ 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_MESSAGES(_ 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 MessageTimer_Hours(_ 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 VoiceOver_Chat_ContactPhoneNumberCount(_ 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 MessagePoll_VotedCount(_ 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 ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, _0, _1) + } + public func Notification_GameScoreExtended(_ 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 ForwardedPhotos(_ 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 Wallpaper_DeleteConfirmation(_ 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 PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ 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 SharedMedia_Photo(_ 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) + return String(format: self._ps[28 * 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[29 * 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[30 * 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[31 * 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[32 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func ForwardedAudios(_ 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 ForwardedGifs(_ 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 MessageTimer_Seconds(_ 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_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MuteFor_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 Media_ShareVideo(_ 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 Conversation_StatusSubscribers(_ 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 GroupInfo_ShowMoreMembers(_ 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 LastSeen_MinutesAgo(_ 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 MessageTimer_ShortHours(_ 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 PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Notifications_Exceptions(_ 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 ChatList_SelectedChats(_ 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 MessageTimer_ShortMinutes(_ 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 Call_ShortMinutes(_ 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 SharedMedia_Generic(_ 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 StickerPack_StickerCount(_ 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 { + public func Call_Seconds(_ 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 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[51 * 6 + Int(form.rawValue)]!, stringValue) @@ -4845,318 +4849,318 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + public func QuickSend_Photos(_ 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 Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + public func Theme_UsersCount(_ 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 MessageTimer_Hours(_ 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 MuteExpires_Minutes(_ 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 SharedMedia_Generic(_ 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 ForwardedVideos(_ 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 ForwardedStickers(_ 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 Conversation_StatusMembers(_ 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 MuteFor_Days(_ 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 Watch_LastSeen_MinutesAgo(_ 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 ForwardedContacts(_ 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 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) - } - public func Conversation_StatusSubscribers(_ 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 CreatePoll_AddMoreOptions(_ 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 PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func InviteText_ContactsCountText(_ 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 PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[69 * 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[70 * 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[71 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfExtended(_ 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 Notification_GameScoreSimple(_ 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 ServiceMessage_GameScoreSelfSimple(_ 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_Minutes(_ 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 SharedMedia_Link(_ 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 Passport_Scans(_ 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_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Notifications_Exceptions(_ 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 MessageTimer_Weeks(_ 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 Notification_GameScoreExtended(_ 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 VoiceOver_Chat_PollOptionCount(_ 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 Notifications_ExceptionMuteExpires_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 ChatList_SelectedChats(_ 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 MessageTimer_Days(_ 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) - } - public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MuteExpires_Hours(_ 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 Media_ShareVideo(_ 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 Map_ETAMinutes(_ 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 ServiceMessage_GameScoreSelfExtended(_ 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) - } - public func StickerPack_RemoveMaskCount(_ 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[55 * 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[93 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) } - public func Map_ETAHours(_ value: Int32) -> String { + public func ForwardedFiles(_ 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 Media_SharePhoto(_ 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 VoiceOver_Chat_ContactEmailCount(_ 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 AttachmentMenu_SendGif(_ 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) - } - public func SharedMedia_DeleteItemsConfirmation(_ 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 Wallet_Updated_HoursAgo(_ 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 Notifications_ExceptionMuteExpires_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 MessageTimer_ShortDays(_ 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 AttachmentMenu_SendPhoto(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[102 * 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[103 * 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[104 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ForwardedGifs(_ 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) - } - public func ChatList_DeletedChats(_ 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 GroupInfo_ParticipantCount(_ 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 PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Contacts_ImportersCount(_ 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 Invitation_Members(_ 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 ForwardedPhotos(_ 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 ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, _0, _1) - } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[114 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[57 * 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[115 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[58 * 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[59 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func ForwardedContacts(_ 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 Notifications_ExceptionMuteExpires_Minutes(_ 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 PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func ServiceMessage_GameScoreSelfExtended(_ 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 ForwardedMessages(_ 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 MessageTimer_ShortSeconds(_ 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 Passport_Scans(_ 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 Invitation_Members(_ 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 Notification_GameScoreSelfSimple(_ 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 ForwardedStickers(_ 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 MuteExpires_Days(_ 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 Map_ETAMinutes(_ 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 Notifications_ExceptionMuteExpires_Hours(_ 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_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func GroupInfo_ParticipantCount(_ 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 VoiceOver_Chat_PollVotes(_ 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 PrivacyLastSeenSettings_AddUsers(_ 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) + return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Video(_ 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[77 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Days(_ 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 ForwardedPolls(_ 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 AttachmentMenu_SendItem(_ 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 Conversation_SelectedMessages(_ 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 PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func UserCount(_ 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 PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Forward_ConfirmMultipleFiles(_ 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 LiveLocationUpdated_MinutesAgo(_ 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) + } + 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[87 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_ShortSeconds(_ 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 MessageTimer_Months(_ 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 MuteExpires_Hours(_ 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 Conversation_LiveLocationMembersCount(_ 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) + } + public func StickerPack_AddStickerCount(_ 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) + } + public func ForwardedLocations(_ 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 Notification_GameScoreSimple(_ 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 Watch_LastSeen_MinutesAgo(_ 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 MessageTimer_Minutes(_ 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 PasscodeSettings_FailedAttempts(_ 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) + } + public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Notification_GameScoreSelfExtended(_ 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 ServiceMessage_GameScoreExtended(_ 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 Conversation_StatusMembers(_ 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 Media_SharePhoto(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[102 * 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[103 * 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[104 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortWeeks(_ 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 ServiceMessage_GameScoreSimple(_ 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) + } + public func SharedMedia_Photo(_ 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 Chat_DeleteMessagesConfirmation(_ 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 PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Map_ETAHours(_ 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 Contacts_ImportersCount(_ 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 MessageTimer_Weeks(_ 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 InviteText_ContactsCountText(_ 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) + } + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[114 * 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[115 * 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[116 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func StickerPack_RemoveMaskCount(_ 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) diff --git a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping index 536dc4312c9faf604780785fe21cc3e9870a49f3..cc613a5908759aa5b3b9b9e2d21ceda021dc2d70 100644 GIT binary patch delta 33633 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 delta 33572 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

Ewi{JR!!hV{4yPoA| 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 diff --git a/submodules/WalletUI/Resources/WalletStrings.mapping b/submodules/WalletUI/Resources/WalletStrings.mapping index 589c6fe85e4fa03a50b6adefffe67915bd39bf1c..9f7c34892095545bdfb3f1e1871a24394137ff12 100644 GIT binary patch delta 17 YcmX@$c))Q(i^Al^3bKrhlN%M}070t;9smFU delta 40 vcmX@$c))Q(i-L?e0|P^NVopwKiC$ 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)